@charset "UTF-8";
/****************************************************
 * Stylesheet
 *
 * 1.リセット
 * 2.共通設定
 * 3.レイアウト設定
 * 4.テンプレートスタイル
 * 5.コンテンツスタイル
 * 6.装飾
 * 7.印刷用調整
 * 
 ****************************************************/
/****************************************************
 * 1.リセット
 ****************************************************/
html {
  box-sizing: border-box;
  -webkit-text-size-adjust: 100%;
  color: #000;
  background: #FFF;
  line-height: 1.5;
}

*, *::before, *::after {
  box-sizing: border-box;
}

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, input, textarea, p, blockquote, th, td, figure {
  margin: 0;
  padding: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

fieldset, img, svg {
  border: 0;
}

address, caption, cite, dfn, em, strong, th {
  font-style: normal;
  font-weight: normal;
}

ol, ul {
  list-style: none;
}

caption, th {
  text-align: left;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
}

abbr {
  border: 0;
  font-variant: normal;
}

sup {
  vertical-align: text-top;
}

sub {
  vertical-align: text-bottom;
}

input, textarea, select, button {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
  margin: 0;
  padding: 0;
  border: none;
  outline: none;
  background: none;
  -moz-appearance: none;
  appearance: none;
  -webkit-appearance: none;
}

input[type=submit], input[type=button], input[type=reset] {
  -moz-appearance: none;
  appearance: none;
  -webkit-appearance: none;
  border-radius: 0;
}

textarea {
  resize: vertical;
}

article, aside, footer, header, nav, section {
  display: block;
}

img, svg {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

a, a:focus, a:hover {
  text-decoration: none;
  color: inherit;
  outline: none;
}

/****************************************************
 * 2.共通
 ****************************************************/
html {
  background-color: transparent;
  background-image: none;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-size: 10px;
  font-weight: 400;
  font-style: normal;
  color: #081F3B;
  scroll-behavior: smooth;
  scroll-padding-top: 9.6rem;
}
@media only screen and (max-width: 1099px) {
  html {
    font-size: 9px;
  }
}
@media only screen and (max-width: 900px) {
  html {
    scroll-padding-top: 6.8rem;
  }
}
@media only screen and (max-width: 780px) {
  html {
    height: 100%;
    font-size: 10px;
  }
}

body {
  font-size: 1.6rem;
}
@media only screen and (max-width: 780px) {
  body {
    font-size: 1.5rem;
    -webkit-text-size-adjust: 100%;
  }
}

a {
  color: #081F3B;
}
a[href^="tel:"] {
  cursor: default;
}
a[href^="tel:"]:hover {
  text-decoration: none;
}

@media only screen and (max-width: 900px) {
  .pc {
    display: none !important;
  }
}

@media only screen and (max-width: 1279px) {
  .pc2 {
    display: none !important;
  }
}

@media only screen and (max-width: 780px) {
  .pc_tb {
    display: none !important;
  }
}

@media only screen and (min-width: 901px) {
  .tb_sp {
    display: none !important;
  }
}

@media only screen and (min-width: 781px) {
  .sp {
    display: none !important;
  }
}

.inner {
  width: 90%;
  max-width: 1080px;
  margin: 0 auto;
}

.midashi01 {
  margin-bottom: 2em;
  font-weight: 500;
  letter-spacing: 0.03em;
}
@media only screen and (max-width: 780px) {
  .midashi01 {
    margin-bottom: 1.75em;
    font-size: 1.4rem;
  }
}
.midashi01 .en {
  margin-bottom: 0.15em;
  font-family: "Montserrat", sans-serif;
  font-size: 8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1;
  color: #125BB4;
  display: block;
}
@media only screen and (max-width: 780px) {
  .midashi01 .en {
    font-size: 3.2rem;
  }
}
.midashi01.center {
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .midashi01.side {
    font-weight: 700;
  }
}
.midashi01.side .en {
  margin-bottom: 0;
  margin-right: 0.3em;
  display: inline-block;
  vertical-align: -0.25em;
}
@media only screen and (max-width: 780px) {
  .midashi01.side .en {
    font-size: 4rem;
    vertical-align: -0.15em;
  }
}
.midashi01.white {
  color: #ffffff;
}
.midashi01.white .en {
  color: #ffffff;
}
.midashi02 {
  margin-bottom: 2em;
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.035em;
}
@media only screen and (max-width: 780px) {
  .midashi02 {
    margin-bottom: 1.5em;
    font-size: 1.8rem;
  }
}
.midashi02 span {
  margin-top: 0.375em;
  font-family: "Montserrat", sans-serif;
  font-size: 2rem;
  letter-spacing: 0.05em;
  color: #125BB4;
  display: block;
}
@media only screen and (max-width: 780px) {
  .midashi02 span {
    font-size: 1.6rem;
  }
}
.midashi02.dots span:before {
  width: 0.9rem;
  height: 0.9rem;
  margin-right: 1.6rem;
  content: "";
  background-color: #125BB4;
  border-radius: 50%;
  display: inline-block;
  vertical-align: 0.15em;
}
@media only screen and (max-width: 780px) {
  .midashi02.dots span:before {
    width: 0.72rem;
    height: 0.72rem;
    margin-right: 1.28rem;
    vertical-align: 0.1em;
  }
}
.midashi02.dots.white span:before {
  background-color: #ffffff;
}
.midashi02.center {
  text-align: center;
}
.midashi02.white {
  color: #ffffff;
}
.midashi02.white span {
  color: #ffffff;
}

.btn01 {
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
  color: #ffffff;
  background: linear-gradient(to right, #ffffff, #ffffff 50%, transparent 50%, transparent);
  background-size: 200% 100%;
  background-position: 100% 0;
  border: solid 0.2rem #ffffff;
  display: inline-block;
}
@media only screen and (min-width: 781px) {
  .btn01 {
    width: 34.5rem;
    padding: 1.15em;
    transition: background-position 0.3s, color 0.3s;
  }
  .btn01:hover {
    color: #081F3B;
    background-position: 0 0;
  }
}
@media only screen and (max-width: 780px) {
  .btn01 {
    width: 28.1rem;
    padding: 0.9em;
    font-size: 1.4rem;
  }
}
.btn02 {
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
  color: #0B66AC;
  background: linear-gradient(to right, #0B66AC, #0B66AC 50%, transparent 50%, transparent);
  background-size: 200% 100%;
  background-position: 100% 0;
  border: solid 0.2rem #0B66AC;
  display: inline-block;
}
@media only screen and (min-width: 781px) {
  .btn02 {
    width: 34.5rem;
    padding: 1.15em;
    transition: background-position 0.3s, color 0.3s;
  }
  .btn02:hover {
    color: #ffffff;
    background-position: 0 0;
  }
}
@media only screen and (max-width: 780px) {
  .btn02 {
    width: 28.1rem;
    padding: 0.9em;
    font-size: 1.4rem;
  }
}

/*アニメーション*/
.fadeIn {
  opacity: 0;
  transform: translate(0, 0);
  transition: opacity 0.5s ease-in, transform 0.5s ease-in;
}
.fadeIn.from-bottom {
  transform: translateY(3rem);
}
.fadeIn.from-right {
  transform: translateX(3rem);
}
.fadeIn.from-left {
  transform: translateX(-3rem);
}
.fadeIn.view {
  opacity: 1;
  transform: translate(0, 0);
}
@media only screen and (min-width: 781px) {
  .fadeIn.delay1 {
    transition-delay: 0.2s;
  }
  .fadeIn.delay2 {
    transition-delay: 0.4s;
  }
  .fadeIn.delay3 {
    transition-delay: 0.6s;
  }
  .fadeIn.delay4 {
    transition-delay: 0.8s;
  }
  .fadeIn.delay5 {
    transition-delay: 1s;
  }
  .fadeIn.delay6 {
    transition-delay: 1.2s;
  }
  .fadeIn.delay7 {
    transition-delay: 1.4s;
  }
  .fadeIn.delay8 {
    transition-delay: 1.6s;
  }
  .fadeIn.delay9 {
    transition-delay: 1.8s;
  }
  .fadeIn.delay10 {
    transition-delay: 2s;
  }
  .fadeIn.delay11 {
    transition-delay: 2.2s;
  }
  .fadeIn.delay12 {
    transition-delay: 2.4s;
  }
  .fadeIn.delay13 {
    transition-delay: 2.6s;
  }
  .fadeIn.delay14 {
    transition-delay: 2.8s;
  }
  .fadeIn.delay15 {
    transition-delay: 3s;
  }
  .fadeIn.delay16 {
    transition-delay: 3.2s;
  }
  .fadeIn.delay17 {
    transition-delay: 3.4s;
  }
  .fadeIn.delay18 {
    transition-delay: 3.6s;
  }
  .fadeIn.delay19 {
    transition-delay: 3.8s;
  }
  .fadeIn.delay20 {
    transition-delay: 4s;
  }
}

.ttl_step_fade_view .step {
  opacity: 0;
  letter-spacing: -0.4em;
}
.ttl_step_fade_view .step > * {
  display: inline-block;
  letter-spacing: normal;
}
.ttl_step_fade_view .step > span {
  opacity: 0;
  display: inline-block;
  transition: opacity 0.2s steps(1);
}
.ttl_step_fade_view .step > span:nth-of-type(1) {
  transition-delay: 0s;
}
.ttl_step_fade_view .step > span:nth-of-type(2) {
  transition-delay: 0.05s;
}
.ttl_step_fade_view .step > span:nth-of-type(3) {
  transition-delay: 0.1s;
}
.ttl_step_fade_view .step > span:nth-of-type(4) {
  transition-delay: 0.15s;
}
.ttl_step_fade_view .step > span:nth-of-type(5) {
  transition-delay: 0.2s;
}
.ttl_step_fade_view .step > span:nth-of-type(6) {
  transition-delay: 0.25s;
}
.ttl_step_fade_view .step > span:nth-of-type(7) {
  transition-delay: 0.3s;
}
.ttl_step_fade_view .step > span:nth-of-type(8) {
  transition-delay: 0.35s;
}
.ttl_step_fade_view .step > span:nth-of-type(9) {
  transition-delay: 0.4s;
}
.ttl_step_fade_view .step > span:nth-of-type(10) {
  transition-delay: 0.45s;
}
.ttl_step_fade_view .step > span:nth-of-type(11) {
  transition-delay: 0.5s;
}
.ttl_step_fade_view .step > span:nth-of-type(12) {
  transition-delay: 0.55s;
}
.ttl_step_fade_view .step > span:nth-of-type(13) {
  transition-delay: 0.6s;
}
.ttl_step_fade_view .step > span:nth-of-type(14) {
  transition-delay: 0.65s;
}
.ttl_step_fade_view .step > span:nth-of-type(15) {
  transition-delay: 0.7s;
}
.ttl_step_fade_view .step > span:nth-of-type(16) {
  transition-delay: 0.75s;
}
.ttl_step_fade_view .step > span:nth-of-type(17) {
  transition-delay: 0.8s;
}
.ttl_step_fade_view .step > span:nth-of-type(18) {
  transition-delay: 0.85s;
}
.ttl_step_fade_view .step > span:nth-of-type(19) {
  transition-delay: 0.9s;
}
.ttl_step_fade_view .step > span:nth-of-type(20) {
  transition-delay: 0.95s;
}
.ttl_step_fade_view .step > span:nth-of-type(21) {
  transition-delay: 1s;
}
.ttl_step_fade_view .step > span:nth-of-type(22) {
  transition-delay: 1.05s;
}
.ttl_step_fade_view .step > span:nth-of-type(23) {
  transition-delay: 1.1s;
}
.ttl_step_fade_view .step > span:nth-of-type(24) {
  transition-delay: 1.15s;
}
.ttl_step_fade_view .step > span:nth-of-type(25) {
  transition-delay: 1.2s;
}
.ttl_step_fade_view .step > span:nth-of-type(26) {
  transition-delay: 1.25s;
}
.ttl_step_fade_view .step > span:nth-of-type(27) {
  transition-delay: 1.3s;
}
.ttl_step_fade_view .step > span:nth-of-type(28) {
  transition-delay: 1.35s;
}
.ttl_step_fade_view .step > span:nth-of-type(29) {
  transition-delay: 1.4s;
}
.ttl_step_fade_view .step > span:nth-of-type(30) {
  transition-delay: 1.45s;
}
.ttl_step_fade_view .step > span:nth-of-type(31) {
  transition-delay: 1.5s;
}
.ttl_step_fade_view .step > span:nth-of-type(32) {
  transition-delay: 1.55s;
}
.ttl_step_fade_view .step > span:nth-of-type(33) {
  transition-delay: 1.6s;
}
.ttl_step_fade_view .step > span:nth-of-type(34) {
  transition-delay: 1.65s;
}
.ttl_step_fade_view .step > span:nth-of-type(35) {
  transition-delay: 1.7s;
}
.ttl_step_fade_view .step > span:nth-of-type(36) {
  transition-delay: 1.75s;
}
.ttl_step_fade_view .step > span:nth-of-type(37) {
  transition-delay: 1.8s;
}
.ttl_step_fade_view .step > span:nth-of-type(38) {
  transition-delay: 1.85s;
}
.ttl_step_fade_view .step > span:nth-of-type(39) {
  transition-delay: 1.9s;
}
.ttl_step_fade_view .step > span:nth-of-type(40) {
  transition-delay: 1.95s;
}
.ttl_step_fade_view .step > span:nth-of-type(41) {
  transition-delay: 2s;
}
.ttl_step_fade_view .step > span:nth-of-type(42) {
  transition-delay: 2.05s;
}
.ttl_step_fade_view .step > span:nth-of-type(43) {
  transition-delay: 2.1s;
}
.ttl_step_fade_view .step > span:nth-of-type(44) {
  transition-delay: 2.15s;
}
.ttl_step_fade_view .step > span:nth-of-type(45) {
  transition-delay: 2.2s;
}
.ttl_step_fade_view .step > span:nth-of-type(46) {
  transition-delay: 2.25s;
}
.ttl_step_fade_view .step > span:nth-of-type(47) {
  transition-delay: 2.3s;
}
.ttl_step_fade_view .step > span:nth-of-type(48) {
  transition-delay: 2.35s;
}
.ttl_step_fade_view .step > span:nth-of-type(49) {
  transition-delay: 2.4s;
}
.ttl_step_fade_view .step > span:nth-of-type(50) {
  transition-delay: 2.45s;
}
.ttl_step_fade_view .fade {
  opacity: 0;
  transition: opacity 0.3s ease-in;
  transition-delay: calc(var(--char-count) * 0.05s + 0.15s);
}
.ttl_step_fade_view.view .step {
  opacity: 1;
}
.ttl_step_fade_view.view .step > span {
  opacity: 1;
}
.ttl_step_fade_view.view .fade {
  opacity: 1;
}

/*検索欄*/
.search_box .inner {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .search_box .inner {
    max-width: 1200px;
    border-radius: 0.8rem;
    overflow: hidden;
  }
}
@media only screen and (max-width: 780px) {
  .search_box .inner {
    width: 100%;
  }
}
.search_box .cate_list {
  padding: 4.8rem;
}
@media only screen and (max-width: 780px) {
  .search_box .cate_list {
    padding: 4rem 1.2rem;
    position: relative;
  }
}
.search_box .cate_list h2 {
  margin-bottom: 1em;
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .search_box .cate_list h2 {
    font-size: 2rem;
  }
}
.search_box .cate_list h2:before {
  width: 12rem;
  height: 0.2rem;
  margin: 0 auto 0.8rem auto;
  content: "";
  background-color: #0B66AC;
  display: block;
}
@media only screen and (max-width: 780px) {
  .search_box .cate_list h2:before {
    width: 10.8rem;
  }
}
@media only screen and (min-width: 781px) {
  .search_box .cate_list ul {
    margin-bottom: -1.6rem;
    display: flex;
    flex-wrap: wrap;
  }
}
@media only screen and (max-width: 780px) {
  .search_box .cate_list ul {
    height: 260px;
    margin-bottom: -0.8rem;
    overflow: hidden;
  }
  .search_box .cate_list ul + .more {
    width: 100%;
    padding: 2rem 0 4rem 0;
    text-align: center;
    background: linear-gradient(to top, #ffffff, #ffffff 60%, transparent);
    position: absolute;
    bottom: 0;
    left: 0;
  }
  .search_box .cate_list ul + .more button {
    width: 17.75rem;
    padding: 0.8em;
    font-size: 1.4rem;
    font-weight: 500;
    letter-spacing: 0.03em;
    text-align: center;
    color: #0B66AC;
    background-color: #ffffff;
    border: solid 1px #0B66AC;
    border-radius: 99px;
    display: inline-block;
  }
  .search_box .cate_list ul.all {
    height: auto;
  }
  .search_box .cate_list ul.all + .more {
    display: none;
  }
}
@media only screen and (min-width: 1100px) {
  .search_box .cate_list ul li {
    width: 31.8%;
    margin: 0 2.3% 1.6rem 0;
  }
  .search_box .cate_list ul li:nth-child(3n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 1099px) and (min-width: 781px) {
  .search_box .cate_list ul li {
    width: 48%;
    margin: 0 4% 1.6rem 0;
  }
  .search_box .cate_list ul li:nth-child(2n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 780px) {
  .search_box .cate_list ul li {
    margin-bottom: 0.8rem;
  }
}
.search_box .cate_list ul li a {
  background-color: #ECEEF0;
  display: flex;
}
@media only screen and (min-width: 781px) {
  .search_box .cate_list ul li a:hover .cate_name {
    background-position: calc(100% - 0.8rem) center;
  }
}
.search_box .cate_list ul li a .thumbnail {
  background-color: #0B66AC;
  overflow: hidden;
}
.search_box .cate_list ul li a .thumbnail > img,
.search_box .cate_list ul li a .thumbnail > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (min-width: 781px) {
  .search_box .cate_list ul li a .thumbnail {
    width: 5.9rem;
  }
}
@media only screen and (max-width: 780px) {
  .search_box .cate_list ul li a .thumbnail {
    width: 5.7rem;
  }
}
.search_box .cate_list ul li a .cate_name {
  font-weight: 500;
}
@media only screen and (min-width: 781px) {
  .search_box .cate_list ul li a .cate_name {
    width: calc(100% - 5.9rem);
    padding: 2rem 5.6rem 2rem 1.6rem;
    letter-spacing: 0.03em;
    background-image: url("../img/icon_arrow02.png");
    background-repeat: no-repeat;
    background-size: 2.4rem auto;
    background-position: calc(100% - 1.6rem) center;
    transition: background-position 0.3s;
  }
}
@media only screen and (max-width: 780px) {
  .search_box .cate_list ul li a .cate_name {
    width: calc(100% - 5.7rem);
    padding: 1em;
  }
}
.search_box .keyword_search {
  background-color: #DBE2EA;
}
@media only screen and (min-width: 781px) {
  .search_box .keyword_search {
    padding: 2.4rem 0;
    text-align: center;
    letter-spacing: -0.4em;
  }
  .search_box .keyword_search > * {
    display: inline-block;
    letter-spacing: normal;
  }
}
@media only screen and (max-width: 780px) {
  .search_box .keyword_search {
    padding: 1.6rem 1.2rem;
  }
}
.search_box .keyword_search dt {
  font-weight: 500;
  letter-spacing: 0.03em;
}
@media only screen and (min-width: 781px) {
  .search_box .keyword_search dt {
    margin-right: 0.88em;
    font-size: 1.8rem;
    vertical-align: middle;
  }
}
@media only screen and (max-width: 780px) {
  .search_box .keyword_search dt {
    margin-bottom: 0.8em;
    font-size: 1.6rem;
  }
}
@media only screen and (min-width: 781px) {
  .search_box .keyword_search dd {
    vertical-align: middle;
  }
}
@media only screen and (max-width: 780px) {
  .search_box .keyword_search dd {
    padding: 1.2rem;
    background-color: #ffffff;
    border: solid 1px #E6E6E6;
    border-radius: 0.4rem;
  }
}
.search_box .keyword_search dd form > div ul {
  width: 100%;
  letter-spacing: -0.4em;
}
.search_box .keyword_search dd form > div ul > * {
  display: inline-block;
  letter-spacing: normal;
}
.search_box .keyword_search dd form > div ul li {
  vertical-align: middle;
}
@media only screen and (min-width: 781px) {
  .search_box .keyword_search dd form > div ul li:nth-child(1) {
    width: 56rem;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1099px) {
  .search_box .keyword_search dd form > div ul li:nth-child(1) {
    width: 40rem;
  }
}
@media only screen and (max-width: 780px) {
  .search_box .keyword_search dd form > div ul li:nth-child(1) {
    width: calc(100% - 5rem);
    padding-right: 1rem;
  }
}
.search_box .keyword_search dd form > div ul li:nth-child(1) input {
  width: 100%;
  font-weight: 500;
}
@media only screen and (min-width: 781px) {
  .search_box .keyword_search dd form > div ul li:nth-child(1) input {
    padding: 1em;
    font-size: 1.4rem;
    background-color: #ffffff;
    border: solid 1px #E6E6E6;
    border-radius: 0.8rem;
  }
}
@media only screen and (max-width: 780px) {
  .search_box .keyword_search dd form > div ul li:nth-child(1) input {
    font-size: 1.3rem;
  }
}
.search_box .keyword_search dd form > div ul li:nth-child(1) input::-moz-placeholder {
  color: #BEBEBE;
}
.search_box .keyword_search dd form > div ul li:nth-child(1) input::placeholder {
  color: #BEBEBE;
}
.search_box .keyword_search dd form > div ul li:nth-child(2) {
  padding-right: 0;
}
@media only screen and (min-width: 781px) {
  .search_box .keyword_search dd form > div ul li:nth-child(2) {
    width: 6.4rem;
    margin-left: 1em;
  }
}
@media only screen and (max-width: 780px) {
  .search_box .keyword_search dd form > div ul li:nth-child(2) {
    width: 5rem;
  }
}
.search_box .keyword_search dd form > div ul li:nth-child(2) input {
  width: 100%;
  height: 3.2rem;
  font-weight: 500;
  text-align: center;
  color: #ffffff;
  background-color: #0B66AC;
  border-radius: 0.4rem;
}
@media only screen and (max-width: 780px) {
  .search_box .keyword_search dd form > div ul li:nth-child(2) input {
    height: 2.7rem;
    font-size: 1.3rem;
  }
}
.search_box .keyword_search dd form > div ul li:nth-child(2) input:hover {
  background-color: #1B63BE;
}

/*フォームベース*/
.wpcf7-text, .input-text {
  width: 100%;
  padding: 0.9em 0.75em;
  background-color: #F8F8F8;
}
.wpcf7-text::-moz-placeholder, .input-text::-moz-placeholder {
  color: #BEBEBE;
}
.wpcf7-text::placeholder, .input-text::placeholder {
  color: #BEBEBE;
}

.wpcf7-textarea, .input-textarea {
  width: 100%;
  height: 16em;
  padding: 0.9em 0.75em;
  background-color: #F8F8F8;
}
@media only screen and (max-width: 780px) {
  .wpcf7-textarea, .input-textarea {
    height: 8em;
  }
}
.wpcf7-textarea::-moz-placeholder, .input-textarea::-moz-placeholder {
  color: #BEBEBE;
}
.wpcf7-textarea::placeholder, .input-textarea::placeholder {
  color: #BEBEBE;
}

.wpcf7-select, .input-select {
  width: 100%;
  padding: 0.9em 0.75em;
  background-color: #F8F8F8;
  background-image: url("../img/form_select_icon.png");
  background-repeat: no-repeat;
  background-position: calc(100% - 1rem) center;
  background-size: 2rem auto;
}

.wpcf7-radio, .radio_group {
  margin-bottom: -1em;
  display: block;
  letter-spacing: -0.4em;
}
.wpcf7-radio > *, .radio_group > * {
  display: inline-block;
  letter-spacing: normal;
}
.wpcf7-radio > *, .radio_group > * {
  margin-right: 1em !important;
  margin-bottom: 1em !important;
}
.wpcf7-radio label input, .radio_group label input {
  visibility: hidden;
  position: absolute;
  left: -9999999px;
}
.wpcf7-radio label input:checked + span:after, .radio_group label input:checked + span:after {
  content: "";
}
.wpcf7-radio label input + span, .radio_group label input + span {
  padding-left: 4rem;
  display: inline-block;
  position: relative;
}
.wpcf7-radio label input + span:before, .radio_group label input + span:before {
  width: 2.4rem;
  height: 2.4rem;
  content: "";
  background-color: #ffffff;
  border: solid 1px #BEBEBE;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 0;
}
.wpcf7-radio label input + span:after, .radio_group label input + span:after {
  width: 1.4rem;
  height: 1.4rem;
  content: none;
  background-color: #000000;
  border-radius: 50%;
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
}

.wpcf7-checkbox, .wpcf7-acceptance, .check_group {
  margin-bottom: -1em;
  display: block;
  letter-spacing: -0.4em;
}
.wpcf7-checkbox > *, .wpcf7-acceptance > *, .check_group > * {
  display: inline-block;
  letter-spacing: normal;
}
.wpcf7-checkbox > *, .wpcf7-acceptance > *, .check_group > * {
  margin-right: 1em !important;
  margin-bottom: 1em !important;
}
.wpcf7-checkbox label input, .wpcf7-acceptance label input, .check_group label input {
  visibility: hidden;
  position: absolute;
  left: -9999999px;
}
.wpcf7-checkbox label input:checked + span:after, .wpcf7-acceptance label input:checked + span:after, .check_group label input:checked + span:after {
  content: "";
}
.wpcf7-checkbox label input + span, .wpcf7-acceptance label input + span, .check_group label input + span {
  padding-left: 4rem;
  display: inline-block;
  position: relative;
}
.wpcf7-checkbox label input + span:before, .wpcf7-acceptance label input + span:before, .check_group label input + span:before {
  width: 2.4rem;
  height: 2.4rem;
  content: "";
  background-color: #ffffff;
  border: solid 1px #BEBEBE;
  position: absolute;
  top: 0;
  left: 0;
}
.wpcf7-checkbox label input + span:after, .wpcf7-acceptance label input + span:after, .check_group label input + span:after {
  width: 1.6rem;
  height: 1rem;
  content: none;
  border-left: solid 0.2rem #000000;
  border-bottom: solid 0.2rem #000000;
  position: absolute;
  top: 0.4rem;
  left: 0.4rem;
  transform: rotate(-45deg);
}

/*ページネーション*/
.pagination {
  text-align: center;
  letter-spacing: -0.4em;
}
.pagination > * {
  display: inline-block;
  letter-spacing: normal;
}
.pagination > * {
  width: 4rem;
  height: 4rem;
  margin: 0 0.4rem;
  font-family: "Montserrat", sans-serif;
  font-weight: 500;
  line-height: 4rem;
  text-align: center;
  border: solid 1px #C5CAD0;
  vertical-align: top;
}
@media only screen and (max-width: 780px) {
  .pagination > * {
    width: 3rem;
    height: 3rem;
    margin: 0.4rem !important;
    line-height: 3rem;
  }
}
.pagination .current {
  color: #ffffff;
  background-color: #125BB4;
  border-color: #125BB4;
}
.pagination .dots {
  line-height: 3rem;
}
.pagination .prev, .pagination .next {
  background-image: url("../img/icon_arrow02.png");
  background-size: cover;
  border: none;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
}
.pagination .prev {
  transform: scaleX(-1);
}
.pagination a:hover {
  opacity: 0.6;
}

/****************************************************
 * 3.レイアウト設定
 ****************************************************/
.container {
  width: 100%;
  padding-top: 9.6rem;
  overflow: hidden;
}
@media only screen and (max-width: 900px) {
  .container {
    padding-top: 6.8rem;
  }
}

/****************************************************
 * 4.テンプレートスタイル
 ****************************************************/
/*ヘッダーブロック*/
#header {
  width: 100%;
  height: 9.6rem;
  padding: 0 2em;
  background-color: #ffffff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media only screen and (max-width: 900px) {
  #header {
    height: 6.8rem;
    padding: 0 0 0 1.2rem;
  }
}
#header .logo {
  width: 21.9rem;
}
@media only screen and (max-width: 900px) {
  #header .logo {
    width: 11.5rem;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .sp_menu_btn {
    width: 6.8rem;
    height: 6.8rem;
    background-image: url("../img/sp_menu_open.png");
    background-size: cover;
  }
  #header .header_right .sp_menu_btn:before {
    width: 100vw;
    height: calc(100vh - 6.8rem);
    content: "";
    background-color: #000000;
    opacity: 0.72;
    position: absolute;
    opacity: 0;
    top: 100%;
    right: 0;
    z-index: -1;
    transform: scale(0);
    transition: opacity 0.5s;
  }
  #header .header_right .sp_menu_btn.open {
    background-image: url("../img/sp_menu_close.png");
  }
  #header .header_right .sp_menu_btn.open:before {
    opacity: 1;
    transform: scale(1);
  }
  #header .header_right .sp_menu_btn.open + .navi {
    right: 0;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi {
    display: flex;
    align-items: center;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi {
    width: 86.5%;
    height: calc(100vh - 6.8rem);
    background-color: #0B66AC;
    position: absolute;
    top: 100%;
    right: -100%;
    overflow: auto;
    transition: right 0.5s;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .gnavi {
    display: table;
  }
  #header .header_right .navi .gnavi > * {
    display: table-cell;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi .gnavi {
    margin-bottom: 3.2rem;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .gnavi li {
    border-left: solid 1px #DBDBDB;
  }
  #header .header_right .navi .gnavi li:first-child {
    border-left: none;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi .gnavi li {
    border-bottom: solid 1px #73A4C9;
  }
}
#header .header_right .navi .gnavi li a {
  font-weight: 500;
  display: block;
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .gnavi li a {
    padding: 0 2em;
  }
}
@media only screen and (min-width: 901px) and (max-width: 1599px) {
  #header .header_right .navi .gnavi li a {
    padding: 0 1em;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .gnavi li a:hover {
    color: #0B66AC;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi .gnavi li a {
    padding: 1.3em;
    color: #ffffff;
  }
}
@media only screen and (min-width: 1280px) {
  #header .header_right .navi .keyword_search {
    width: 26.8rem;
  }
}
@media only screen and (max-width: 1360px) and (min-width: 901px) {
  #header .header_right .navi .keyword_search {
    display: none;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi .keyword_search {
    width: 81.5%;
    margin: 0 auto;
  }
}
#header .header_right .navi .keyword_search form div ul {
  padding: 0.8rem;
  background-color: #F4F4F4;
  border: solid 1px #E6E6E6;
  border-radius: 0.8rem;
  display: flex;
  align-items: center;
}
#header .header_right .navi .keyword_search form div ul li:nth-child(1) {
  width: calc(100% - 3.2rem);
  height: 3.2rem;
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi .keyword_search form div ul li:nth-child(1) {
    height: 3.5rem;
  }
}
#header .header_right .navi .keyword_search form div ul li:nth-child(1) input {
  width: 100%;
  height: 100%;
}
#header .header_right .navi .keyword_search form div ul li:nth-child(1) input::-moz-placeholder {
  color: #BEBEBE;
}
#header .header_right .navi .keyword_search form div ul li:nth-child(1) input::placeholder {
  color: #BEBEBE;
}
#header .header_right .navi .keyword_search form div ul li:nth-child(2) {
  width: 5rem;
  height: 3.2rem;
  padding-right: 0;
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi .keyword_search form div ul li:nth-child(2) {
    height: 3.5rem;
  }
}
#header .header_right .navi .keyword_search form div ul li:nth-child(2) input {
  width: 100%;
  height: 100%;
  font-size: 1.4rem;
  font-weight: 500;
  color: #ffffff;
  background-color: #0B66AC;
  border-radius: 0.4rem;
}
#header .header_right .navi .keyword_search form div ul li:nth-child(2) input:hover {
  background-color: #1B63BE;
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .btn_pc {
    margin-left: 2.4rem;
    display: flex;
    align-items: center;
  }
}
@media only screen and (min-width: 901px) and (max-width: 1599px) {
  #header .header_right .navi .btn_pc {
    margin-left: 1.2rem;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .btn_pc .btn_recruit a {
    padding: 1.2rem 3.2rem;
    font-weight: 500;
    color: #105BB4;
    background: linear-gradient(to right, #0B66AC, #0B66AC 50%, #ffffff 50%, #ffffff);
    background-size: 200% 100%;
    background-position: 100% 0;
    border: solid 1px #105BB4;
    border-radius: 99px;
    display: inline-block;
    transition: background-position 0.3s, color 0.3s;
  }
  #header .header_right .navi .btn_pc .btn_recruit a:hover {
    color: #ffffff;
    background-position: 0;
  }
}
@media only screen and (min-width: 901px) and (max-width: 1599px) {
  #header .header_right .navi .btn_pc .btn_recruit a {
    padding: 1.2rem;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .btn_pc .btn_mail {
    margin-left: 3.2rem;
  }
}
@media only screen and (min-width: 901px) and (max-width: 1599px) {
  #header .header_right .navi .btn_pc .btn_mail {
    margin-left: 1.2rem;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .btn_pc .btn_mail a {
    width: 21.9rem;
    padding: 0.7rem 3.2rem;
    background: linear-gradient(to right, #081F3B, #081F3B 50%, #1B63BE);
    background-size: 200% 100%;
    background-position: 100% 0;
    transition: background-position 0.3s;
    display: inline-block;
  }
}
@media only screen and (min-width: 901px) and (max-width: 1599px) {
  #header .header_right .navi .btn_pc .btn_mail a {
    width: 19rem;
    padding: 0.7rem 1rem;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .btn_pc .btn_mail a:hover {
    background-position: 0;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi .btn_sp {
    width: 81.5%;
    margin: 6.2rem auto 0 auto;
  }
  #header .header_right .navi .btn_sp .btn_tel a {
    padding: 2.5rem;
    border: solid 0.2rem #ffffff;
    text-align: center;
    border-radius: 0.8rem;
    display: block;
  }
  #header .header_right .navi .btn_sp .btn_tel a img {
    width: 15rem;
  }
  #header .header_right .navi .btn_sp .btn_mail {
    margin-top: 1.2rem;
  }
  #header .header_right .navi .btn_sp .btn_mail a {
    padding: 2.5rem;
    background-color: #ffffff;
    text-align: center;
    border-radius: 0.8rem;
    display: block;
  }
  #header .header_right .navi .btn_sp .btn_mail a img {
    width: 15rem;
  }
}

/*フッターブロック*/
#footer {
  color: #ffffff;
  background-color: #03132C;
  border-top: solid 1px #1A2C4B;
}
@media only screen and (min-width: 901px) {
  #footer .inner {
    max-width: 1200px;
    padding-top: 5.6rem;
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
  }
}
@media only screen and (max-width: 900px) {
  #footer .inner {
    padding-top: 4.4rem;
  }
}
@media only screen and (min-width: 901px) {
  #footer .navi {
    display: flex;
  }
}
@media only screen and (max-width: 900px) {
  #footer .navi {
    margin-bottom: 3.2rem;
  }
}
@media only screen and (min-width: 901px) {
  #footer .navi dl + dl {
    margin-left: 8.8rem;
  }
}
@media only screen and (min-width: 901px) and (max-width: 1599px) {
  #footer .navi dl + dl {
    margin-left: 6rem;
  }
}
@media only screen and (min-width: 901px) and (max-width: 1279px) {
  #footer .navi dl + dl {
    margin-left: 4rem;
  }
}
@media only screen and (max-width: 900px) {
  #footer .navi dl + dl {
    margin-top: 2.28em;
  }
}
#footer .navi dl dt {
  margin-bottom: 1.77em;
  font-family: "Montserrat", sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 900px) {
  #footer .navi dl dt {
    margin-bottom: 0.9em;
    padding-bottom: 0.7em;
    font-size: 2.2rem;
    border-bottom: solid 1px #1A2C4B;
  }
}
#footer .navi dl dd {
  font-size: 1.4rem;
  font-weight: 500;
}
@media only screen and (max-width: 900px) {
  #footer .navi dl dd {
    font-size: 1.7rem;
  }
}
@media only screen and (min-width: 901px) {
  #footer .navi dl dd + dd {
    margin-top: 1.7em;
  }
}
@media only screen and (max-width: 900px) {
  #footer .navi dl dd + dd {
    margin-top: 1.2em;
  }
}
#footer .navi dl dd a {
  color: #ffffff;
}
@media only screen and (min-width: 901px) {
  #footer .navi dl dd a:hover {
    color: #0B66AC;
  }
}
@media only screen and (max-width: 900px) {
  #footer .navi dl dd a {
    display: block;
  }
}
@media only screen and (min-width: 901px) {
  #footer .content {
    flex: 0 0 35rem;
  }
}
#footer .content .logo {
  width: 20.2rem;
  margin-bottom: 5.6rem;
}
@media only screen and (max-width: 900px) {
  #footer .content .logo {
    width: 19.7rem;
    margin: 0 auto 1em auto;
  }
}
#footer .content address {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.8;
}
@media only screen and (max-width: 900px) {
  #footer .content address {
    font-size: 1.3rem;
    text-align: center;
  }
}
#footer .content address + address {
  margin-top: 1em;
}
#footer .copyright {
  margin-top: 4rem;
  padding: 2em 0;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: #3F4E67;
  border-top: solid 1px #1A2C4B;
  text-align: center;
}
@media only screen and (max-width: 900px) {
  #footer .copyright {
    margin-top: 3.2rem;
    padding: 2rem 0 12.5rem 0;
    font-size: 1.4rem;
  }
}

/*CTA*/
.cta_block {
  color: #ffffff;
  background-color: #03132C;
}
@media only screen and (min-width: 901px) {
  .cta_block .inner {
    max-width: 1600px;
    padding: 4.8rem 0;
    display: flex;
    align-items: center;
  }
}
@media only screen and (max-width: 900px) {
  .cta_block .inner {
    padding: 4rem 0;
  }
}
@media only screen and (min-width: 901px) {
  .cta_block .tel {
    width: 50%;
    padding-right: 9.4rem;
    text-align: right;
  }
}
@media only screen and (min-width: 901px) and (max-width: 1099px) {
  .cta_block .tel {
    padding-right: 6rem;
  }
}
@media only screen and (max-width: 900px) {
  .cta_block .tel {
    text-align: center;
  }
}
.cta_block .tel a {
  font-size: 2.2rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: #ffffff;
  display: inline-block;
  text-align: center;
}
@media only screen and (max-width: 900px) {
  .cta_block .tel a {
    padding: 1.43em;
    font-size: 1.4rem;
    border: solid 0.2rem #ffffff;
    border-radius: 0.8rem;
    display: block;
    position: relative;
  }
  .cta_block .tel a:before {
    width: 1.85em;
    height: 1.85em;
    margin-top: -0.925em;
    content: "";
    background-image: url("../img/icon_arrow01.png");
    background-size: cover;
    position: absolute;
    top: 50%;
    right: 0.85em;
  }
}
.cta_block .tel a img {
  width: 44.6rem;
  margin: 0 auto;
  display: block;
}
@media only screen and (max-width: 1599px) {
  .cta_block .tel a img {
    width: 40rem;
  }
}
@media only screen and (max-width: 900px) {
  .cta_block .tel a img {
    width: 22.3rem;
  }
}
.cta_block .tel a .time {
  font-size: 1.4rem;
  display: block;
}
@media only screen and (min-width: 901px) {
  .cta_block .mail {
    width: 50%;
  }
}
@media only screen and (max-width: 900px) {
  .cta_block .mail {
    margin-top: 1.2rem;
  }
}
.cta_block .mail a {
  padding: 7.2rem 4rem;
  font-size: 3.4rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #ffffff;
  background: linear-gradient(to top right, #142848, #254676);
  border-radius: 0.8rem;
  display: block;
  position: relative;
}
@media only screen and (max-width: 1599px) {
  .cta_block .mail a {
    font-size: 3rem;
  }
}
@media only screen and (max-width: 1279px) {
  .cta_block .mail a {
    padding: 5rem 3rem;
    font-size: 2.4rem;
  }
}
@media only screen and (max-width: 900px) {
  .cta_block .mail a {
    padding: 2.4rem 1.6rem;
    font-size: 1.9rem;
  }
}
.cta_block .mail a:before {
  width: 1.52em;
  height: 1.52em;
  margin-top: -0.76em;
  content: "";
  background-image: url("../img/icon_arrow01.png");
  background-size: cover;
  position: absolute;
  top: 50%;
  right: 1.17em;
}
@media only screen and (max-width: 900px) {
  .cta_block .mail a:before {
    right: 0.6em;
  }
}
.cta_block .mail a:after {
  width: 2.5em;
  height: 1px;
  margin-top: 0.3em;
  content: "";
  background-color: #ffffff;
  display: block;
  transition: width 0.3s;
}
@media only screen and (max-width: 900px) {
  .cta_block .mail a:after {
    margin-top: 0.65em;
  }
}
.cta_block .mail a span {
  margin-bottom: 0.4em;
  font-family: "Montserrat", sans-serif;
  font-size: 0.58em;
  letter-spacing: 0.05em;
  display: block;
}
@media only screen and (max-width: 900px) {
  .cta_block .mail a span {
    margin-bottom: 0.25em;
    font-size: 0.84em;
  }
}
@media only screen and (min-width: 901px) {
  .cta_block .mail a:hover:after {
    width: 15em;
  }
}

/*SP追従*/
@media only screen and (max-width: 780px) {
  .sp_fix_contact {
    width: 100%;
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 90;
  }
  .sp_fix_contact ul {
    display: flex;
    flex-wrap: wrap;
  }
  .sp_fix_contact ul li a {
    padding: 1.5rem;
    font-size: 1.4rem;
    font-weight: 500;
    text-align: center;
    color: #ffffff;
    display: block;
  }
  .sp_fix_contact ul li a:after {
    width: 1.6rem;
    height: 1.6rem;
    margin-left: 1.2rem;
    content: "";
    background-image: url("../img/icon_arrow01.png");
    background-size: cover;
    display: inline-block;
    vertical-align: -0.15em;
  }
  .sp_fix_contact ul li:nth-child(1) {
    width: 50%;
    background-color: #105BB4;
  }
  .sp_fix_contact ul li:nth-child(2) {
    width: 50%;
    background-color: #00235C;
  }
  .sp_fix_contact ul li:nth-child(3) {
    width: 100%;
    background: linear-gradient(to top right, #00235C, #105BB4);
  }
  .sp_fix_contact ul li:nth-child(3) a {
    padding: 1.2rem;
  }
  .sp_fix_contact ul li:nth-child(3) a:after {
    content: none;
  }
  .sp_fix_contact ul li:nth-child(3) a img {
    width: 17.65rem;
  }
}

/****************************************************
 * 5.コンテンツスタイル
 ****************************************************/
/*TOPページ*/
.p-top__mv {
  width: 100%;
  position: relative;
}
@media only screen and (min-width: 781px) {
  .p-top__mv {
    background-image: url("../img/top/mv_bg.jpg");
    background-position: 40% center;
    background-size: cover;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv {
    height: 68rem;
    padding-top: 12.7rem;
    background-image: url("../img/top/mv_bg_sp.jpg");
    background-position: center center;
    background-size: 100% 100%;
  }
}
.p-top__mv:after {
  content: "";
  background-repeat: no-repeat;
  position: absolute;
  bottom: 0;
}
@media only screen and (min-width: 781px) {
  .p-top__mv:after {
    width: 90%;
    max-width: 1200px;
    height: 13.3rem;
    background-image: url("../img/top/mv_scroll.png");
    background-size: 2.9rem auto;
    background-position: 13% 0;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv:after {
    width: 100%;
    height: 23.9rem;
    background-image: url("../img/top/mv_scroll_sp.png");
    background-size: 2.3rem auto;
    background-position: calc(100% - 2.4rem) 0;
    left: 0;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__mv .inner {
    max-width: 1200px;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__mv .text {
    width: 53%;
    height: 72rem;
    margin-left: -3%;
    padding-top: 13rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .text {
    margin-bottom: 10rem;
  }
}
.p-top__mv .text h1 {
  width: 38rem;
  max-width: 100%;
  margin-bottom: 2.4rem;
}
@media only screen and (max-width: 780px) {
  .p-top__mv .text h1 {
    width: 24.7rem;
    margin-bottom: 0.5rem;
  }
}
.p-top__mv .text p {
  line-height: 2.5;
}
@media only screen and (max-width: 780px) {
  .p-top__mv .text p {
    line-height: 2.15;
  }
}
.p-top__mv .text p span {
  padding: 0.27em 0.5em;
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.27;
  color: #ffffff;
  background-color: #00235C;
  display: inline-block;
}
@media only screen and (max-width: 780px) {
  .p-top__mv .text p span {
    padding: 0.38em 0.5em 0.34em 0.5em;
    font-size: 1.3rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__mv .logo {
    width: 50%;
  }
  .p-top__mv .logo img {
    width: 48rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .logo {
    width: 16rem;
    margin: 0 auto;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__mv_link ul {
    display: flex;
  }
  .p-top__mv_link ul li {
    width: 50%;
  }
  .p-top__mv_link ul li a {
    padding: 1.07em 0;
    font-size: 2.2rem;
    font-weight: 500;
    text-align: center;
    color: #ffffff;
    text-align: center;
    display: block;
    transition: opacity 0.3s;
  }
  .p-top__mv_link ul li a:after {
    width: 2rem;
    height: 2rem;
    margin-left: 2.4rem;
    content: "";
    background-image: url("../img/icon_arrow01.png");
    background-size: cover;
    display: inline-block;
    vertical-align: -0.1em;
  }
  .p-top__mv_link ul li a:hover {
    opacity: 0.6;
  }
  .p-top__mv_link ul li:nth-child(1) a {
    background-color: #105BB4;
  }
  .p-top__mv_link ul li:nth-child(2) a {
    background-color: #00235C;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__product {
    padding: 4.8rem 0 8.8rem 0;
    background-image: url("../img/top/product_bg.jpg");
    background-size: cover;
    background-position: center center;
  }
}
.p-top__product .tabArea{
	display: flex;
	width: 90%;
	max-width: 1000px;
	margin: 0px auto 6.4rem auto;
	column-gap: 4rem;
}
.p-top__product .tabArea .js-tab-btn{
	width: calc(50% - 2rem);
	color: #ffffff;
	font-weight: 700;
	line-height; 1.45
	letter-spacing: 0.03em;
	text-align: center;
	border: 2px solid #FFFFFF;
	padding: 1.8rem;
	cursor: pointer;
}
.p-top__product .tabArea .js-tab-btn.current{
	 background: #FFFFFF;
	 color: #081F3B;
}
.p-top__product .js-tab-contents{
	display: none;
}
.p-top__product .js-tab-contents.current{
	display: block;
}
.p-top__product .js-tab-contents .product_list{
	margin-bottom: 6.4rem;
}
@media only screen and (max-width: 780px) {
	.p-top__product .tabArea{
		margin: 0px auto 3rem auto;
		column-gap: 1rem;
	}
	.p-top__product .tabArea .js-tab-btn{
		width: calc(50% - 0.5rem);
		border: 1px solid #FFFFFF;
		font-size: 1.5rem;
		padding: 1.2rem 1rem;
	}
	.p-top__product .tabArea .js-tab-btn span{
		display: none;
	}
}
@media only screen and (max-width: 780px) {
  .p-top__product {
    padding: 4rem 0;
    background-image: url("../img/top/product_bg_sp01.jpg");
    background-size: cover;
    background-position: center center;
  }
  .p-top__product .js-tab-contents .product_list{
    margin-bottom: 0;
  }
}
.p-top__product .product_list_area .inner {
  max-width: 1200px;
}
@media only screen and (min-width: 1280px) {
  .p-top__product .product_list_area .midashi01 .en br {
    display: none;
  }
}
.p-top__product .product_list_area h3 {
  margin-bottom: 0.66em;
  font-size: 3.6rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
  color: #ffffff;
}
@media only screen and (max-width: 780px) {
  .p-top__product .product_list_area h3 {
    font-size: 2.1rem;
    line-height: 1.23;
  }
}
.p-top__product .product_list_area h3 span {
  font-family: "Montserrat", sans-serif;
  font-size: 2.4rem;
  display: block;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 780px) {
  .p-top__product .product_list_area h3 span {
    margin-top: 0.6rem;
    font-size: 1.2rem;
  }
}
.p-top__product .product_list_area h3 + p {
  margin-bottom: 2.5em;
  letter-spacing: 0.03em;
  font-weight: 500;
  text-align: center;
  color: #ffffff;
}
@media only screen and (max-width: 780px) {
  .p-top__product .product_list_area h3 + p {
    margin-bottom: 1.25em;
    font-size: 1.5rem;
    text-align: left;
  }
}
.p-top__product .product_list_area .product_list {
  display: flex;
}
@media only screen and (min-width: 781px) {
  .p-top__product .product_list_area .product_list {
    column-gap: 2rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__product .product_list_area .product_list {
    margin-bottom: 2rem;
    flex-wrap: wrap;
  }
}
.p-top__product .product_list_area .product_list li {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-top__product .product_list_area .product_list li {
    width: calc(25% - 1.5rem);
  }
}
@media only screen and (max-width: 780px) {
  .p-top__product .product_list_area .product_list li {
    width: 47.6%;
    margin: 0 4.8% 4.8% 0;
  }
  .p-top__product .product_list_area .product_list li:nth-child(2n) {
    margin-right: 0;
  }
}
.p-top__product .product_list_area .product_list li a {
  display: block;
}
.p-top__product .product_list_area .product_list li a:hover .img img {
  transform: scale(1.1);
}
.p-top__product .product_list_area .product_list li .img {
  aspect-ratio: 288/209;
  overflow: hidden;
}
.p-top__product .product_list_area .product_list li .img > img,
.p-top__product .product_list_area .product_list li .img > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.p-top__product .product_list_area .product_list li .img img {
  transition: transform 0.3s;
}
.p-top__product .product_list_area .product_list li .text {
  padding: 1.6rem;
}
@media only screen and (max-width: 780px) {
  .p-top__product .product_list_area .product_list li .text {
    padding: 0.8rem;
  }
}
.p-top__product .product_list_area .product_list li .text p {
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.03em;
}
@media only screen and (max-width: 780px) {
  .p-top__product .product_list_area .product_list li .text p {
    font-size: 1.5rem;
  }
}
.p-top__product .product_list_area .product_list li .text .more {
  margin-top: 1rem;
  font-family: "Montserrat", sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: right;
  color: #105BB4;
}
@media only screen and (max-width: 780px) {
  .p-top__product .product_list_area .product_list li .text .more {
    margin-top: 0.5rem;
    font-size: 1.2rem;
  }
}
.p-top__product .product_list_area .product_list li .text .more:after {
  width: 1em;
  height: 1em;
  margin-left: 0.8rem;
  content: "";
  background-image: url("../img/icon_arrow02.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.25em;
}
.p-top__product .btn_area {
  text-align: center;
}
@media only screen and (min-width: 781px) {
  .p-top__product .btn_area {
    margin-top: 4rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__product .btn_area {
    padding: 3.2rem 4.8rem;
    background-image: url("../img/top/product_bg_sp02.png");
    background-size: cover;
    background-position: center center;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__about {
    padding: 12.8rem 0;
    background-image: url("../img/top/about_bg.jpg");
    background-size: cover;
    background-position: center center;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__about .inner {
    max-width: 1200px;
    display: flex;
    justify-content: space-between;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__about .img {
    width: 33.5%;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__about .img {
    width: 111%;
    margin: 0 -5.5%;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__about .text {
    width: 61.6%;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__about .text {
    margin-top: 4.5rem;
  }
  .p-top__about .text:after {
    width: 111%;
    height: 6rem;
    margin: 3.5rem 5% 0 -5%;
    content: "";
    background-image: url("../img/top/about_img02_sp.png");
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-position: right top;
    display: block;
  }
}
.p-top__about .text .midashi01 {
  position: relative;
  z-index: 1;
}
.p-top__about .text .midashi01:after {
  margin-top: -0.35em;
  content: "ABOUT";
  font-family: "Montserrat", sans-serif;
  font-size: 20rem;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  color: #F8F8F8;
  position: absolute;
  top: 0;
  left: 0.5em;
  z-index: -1;
}
@media only screen and (max-width: 1099px) {
  .p-top__about .text .midashi01:after {
    font-size: 15rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__about .text .midashi01:after {
    font-size: 10rem;
  }
}
.p-top__about .text h3 {
  margin-bottom: 0.7em;
  font-size: 3.6rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.33;
}
@media only screen and (max-width: 780px) {
  .p-top__about .text h3 {
    font-size: 1.9rem;
  }
}
.p-top__about .text h3 span {
  color: #105BB4;
}
.p-top__about .text p {
  margin-bottom: 2.5em;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 2;
}
@media only screen and (max-width: 780px) {
  .p-top__about .text p {
    margin-bottom: 1.33em;
    line-height: 1.7;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__about .text .btn {
    text-align: center;
  }
}
.p-top__achievement {
  padding: 6.4rem 0 9.6rem 0;
  background-color: #00235C;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-top__achievement {
    padding: 2rem 0 4rem 0;
  }
}
.p-top__achievement:after {
  width: 100%;
  content: "";
  background-size: cover;
  background-position: center bottom;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}
@media only screen and (min-width: 901px) {
  .p-top__achievement:after {
    height: 37.3rem;
    background-image: url("../img/top/achievement_bg.jpg");
  }
}
@media only screen and (max-width: 900px) {
  .p-top__achievement:after {
    height: 15.5rem;
    background-image: url("../img/top/achievement_bg_sp.jpg");
  }
}
.p-top__achievement .inner {
  max-width: 1600px;
}
@media only screen and (max-width: 900px) {
  .p-top__achievement .inner {
    width: 111%;
    margin: 0 -5.5%;
  }
}
.p-top__achievement h2 {
  margin-bottom: 5rem;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-top__achievement h2 {
    margin-bottom: 2.5rem;
  }
}
.p-top__achievement h2 span {
  padding: 0 2em;
  font-size: 3.6rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #ffffff;
  display: inline-block;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .p-top__achievement h2 span {
    padding: 0 1em;
    font-size: 2.1rem;
  }
}
.p-top__achievement h2 span:before, .p-top__achievement h2 span:after {
  width: 11rem;
  height: 1px;
  content: "";
  background-color: #ffffff;
  position: absolute;
  top: 50%;
}
@media only screen and (max-width: 780px) {
  .p-top__achievement h2 span:before, .p-top__achievement h2 span:after {
    width: 4.3rem;
  }
}
.p-top__achievement h2 span:before {
  right: 100%;
}
.p-top__achievement h2 span:after {
  left: 100%;
}
.p-top__achievement .box {
  background-color: #F7F7F7;
}
.p-top__achievement .box .headding {
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 2.8rem 0;
}
@media only screen and (min-width: 901px) {
  .p-top__achievement .box .headding {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
@media only screen and (max-width: 900px) {
  .p-top__achievement .box .headding {
    width: 81.08%;
    margin: 0 auto;
    padding: 2rem 0;
  }
}
.p-top__achievement .box .headding p {
  font-weight: 500;
  letter-spacing: 0.03em;
}
@media only screen and (min-width: 901px) {
  .p-top__achievement .box .headding p {
    padding-right: 5rem;
    line-height: 1.8;
  }
}
@media only screen and (max-width: 900px) {
  .p-top__achievement .box .headding .btn {
    margin-top: 1.25rem;
    text-align: center;
  }
}
.p-top__achievement .box ul {
  display: flex;
}
@media only screen and (max-width: 900px) {
  .p-top__achievement .box ul {
    padding: 0 3.2rem 2.4rem 3.2rem;
    background-color: #ffffff;
    flex-wrap: wrap;
  }
}
@media only screen and (min-width: 901px) {
  .p-top__achievement .box ul li {
    width: 25%;
    border-left: solid 1px #C5CAD0;
  }
  .p-top__achievement .box ul li:first-child {
    border-left: none;
  }
}
@media only screen and (max-width: 900px) {
  .p-top__achievement .box ul li {
    width: 50%;
  }
}
.p-top__achievement .box ul li a {
  width: 100%;
  height: 100%;
  background-color: #ffffff;
  display: block;
  position: relative;
}
@media only screen and (min-width: 901px) {
  .p-top__achievement .box ul li a {
    padding: 3.2rem 3.2rem 9.4rem 3.2rem;
  }
}
@media only screen and (max-width: 900px) {
  .p-top__achievement .box ul li a {
    padding: 2.4rem 0.8rem;
  }
}
.p-top__achievement .box ul li a:after {
  width: 0;
  height: 0;
  content: "";
  border: solid 1.2rem transparent;
  border-bottom-color: #0B66AC;
  border-right-color: #0B66AC;
  position: absolute;
  right: 3.2rem;
  bottom: 3.2rem;
}
@media only screen and (max-width: 900px) {
  .p-top__achievement .box ul li a:after {
    border-width: 0.6rem;
    right: 1.2rem;
    bottom: 0;
  }
}
.p-top__achievement .box ul li .img {
  margin-bottom: 1em;
  aspect-ratio: 336/209;
  overflow: hidden;
}
.p-top__achievement .box ul li .img > img,
.p-top__achievement .box ul li .img > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (max-width: 780px) {
  .p-top__achievement .box ul li .img {
    margin-bottom: 1.2rem;
  }
}
.p-top__achievement .box ul li p {
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.3;
}
@media only screen and (max-width: 900px) {
  .p-top__achievement .box ul li p {
    font-size: 1.5rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__company {
    padding: 9.5rem 0;
    background-image: url("../img/top/company_bg.jpg");
    background-size: cover;
    background-position: center top;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__company {
    padding: 0 0 4.8rem 0;
  }
}
.p-top__company .inner {
  max-width: 1200px;
}
@media only screen and (max-width: 780px) {
  .p-top__company .img {
    margin-bottom: 2.5rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__company .text {
    width: 50%;
  }
}
.p-top__company .text .midashi01 .en {
  white-space: nowrap;
}
@media only screen and (max-width: 780px) {
  .p-top__company .text .midashi01 .en {
    margin-right: 0.3em;
    display: inline-block;
    vertical-align: -0.15em;
  }
}
.p-top__company .text h3 {
  margin-bottom: 0.75em;
  font-size: 3.6rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.33;
}
@media only screen and (max-width: 780px) {
  .p-top__company .text h3 {
    font-size: 1.9rem;
  }
}
.p-top__company .text p {
  margin-bottom: 2.5em;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 2.2;
}
@media only screen and (max-width: 780px) {
  .p-top__company .text p {
    margin-bottom: 1.6em;
    line-height: 1.6;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__company .text .btn {
    text-align: center;
  }
}
.p-top__recruit {
  color: #ffffff;
  background-size: cover;
  background-position: center center;
}
@media only screen and (min-width: 781px) {
  .p-top__recruit {
    padding: 5.6rem 0 6.4rem 0;
    background-image: url("../img/top/recruit_bg.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .p-top__recruit {
    padding: 4.8rem 0;
    background-image: url("../img/top/recruit_bg_sp.jpg");
  }
}
.p-top__recruit .midashi01 {
  margin-bottom: 1em;
  font-size: 3.6rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-top__recruit .midashi01 {
    font-size: 2rem;
  }
}
.p-top__recruit p {
  margin-bottom: 2.5em;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.75;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-top__recruit p {
    margin-bottom: 1.3em;
    line-height: 1.5;
    text-align: left;
  }
}
.p-top__recruit .btn {
  text-align: center;
}

/*下層ページ*/
.pagetitle {
  margin-bottom: 8rem;
  padding: 7rem 0 8rem 0;
  background-image: url("../img/pagetitle_bg.jpg");
  background-size: cover;
  background-position: center center;
}
@media only screen and (max-width: 780px) {
  .pagetitle {
    margin-bottom: 4rem;
    padding: 3.5rem 0 4rem 0;
  }
}
.pagetitle .inner {
  max-width: 1200px;
}
.pagetitle h1 {
  width: 0;
  margin-bottom: 0.8em;
  font-size: 4.8rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  white-space: nowrap;
  overflow: hidden;
  transition: width 1s;
}
@media only screen and (max-width: 780px) {
  .pagetitle h1 {
    font-size: 2.4rem;
  }
}
.pagetitle h1 span {
  margin-top: 0.4em;
  font-family: "Montserrat", sans-serif;
  font-size: 2rem;
  text-transform: uppercase;
  color: #125BB4;
  display: block;
}
@media only screen and (max-width: 780px) {
  .pagetitle h1 span {
    font-size: 1.6rem;
  }
}
.pagetitle h1.view {
  width: 100%;
}
.pagetitle .pankuzu {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: -0.4em;
}
.pagetitle .pankuzu > * {
  display: inline-block;
  letter-spacing: normal;
}
@media only screen and (max-width: 780px) {
  .pagetitle .pankuzu {
    font-size: 1.2rem;
  }
}
.pagetitle .pankuzu a:after {
  width: 0.5em;
  height: 0.2rem;
  margin: 0 1em;
  content: "";
  background-color: #125BB4;
  display: inline-block;
  vertical-align: middle;
}
.pagetitle .pankuzu span {
  color: #898989;
}

.p-company__message {
  margin-bottom: 9.6rem;
}
@media only screen and (max-width: 780px) {
  .p-company__message {
    margin-bottom: 4.8rem;
  }
}
.p-company__message h3 {
  margin-bottom: 1.6em;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.27;
  letter-spacing: 0.035em;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-company__message h3 {
    font-size: 2.2rem;
  }
}
.p-company__message p {
  margin-bottom: 3em;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.875;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-company__message p {
    line-height: 1.5;
    text-align: left;
  }
}
.p-company__message .name {
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-company__message .name {
    text-align: right;
  }
}
.p-company__philosophy {
  padding: 8.8rem 0 20.7rem 0;
  background-image: url("../img/company/bg01.jpg");
}
@media only screen and (max-width: 780px) {
  .p-company__philosophy {
    padding: 4.4rem 0 6rem 0;
  }
}
.p-company__philosophy .inner {
  max-width: 1120px;
}
.p-company__philosophy p {
  font-size: 2.6rem;
  font-weight: 500;
  letter-spacing: 0.035em;
  line-height: 1.7;
  color: #ffffff;
}
@media only screen and (max-width: 780px) {
  .p-company__philosophy p {
    font-size: 1.8rem;
  }
}
.p-company__guideline {
  background-color: #F8F8F8;
}
.p-company__guideline .inner {
  max-width: 1120px;
}
.p-company__guideline .box {
  margin-bottom: -3.2rem;
  padding: 6.4rem 0;
  background-color: #ffffff;
  position: relative;
  top: -11.8rem;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-company__guideline .box {
    margin-bottom: 0;
    padding: 3.2rem 0;
    top: -2rem;
  }
}
.p-company__guideline .box ol {
  width: 90%;
  max-width: 960px;
  margin: 0 auto;
  counter-reset: num;
  border-top: solid 1px #C5CAD0;
}
.p-company__guideline .box ol li {
  padding: 3rem 0 3rem 12.5rem;
  position: relative;
  counter-increment: num;
  border-bottom: solid 1px #C5CAD0;
}
@media only screen and (max-width: 780px) {
  .p-company__guideline .box ol li {
    padding: 2rem;
  }
}
.p-company__guideline .box ol li:before {
  content: counter(num, decimal-leading-zero);
  font-family: "Montserrat", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #125BB4;
  position: absolute;
  top: 50%;
  left: 5rem;
  transform: translateY(-50%);
}
@media only screen and (max-width: 780px) {
  .p-company__guideline .box ol li:before {
    position: static;
    display: block;
    transform: none;
  }
}
.p-company__guideline .box ol li h3 {
  margin-bottom: 0.4em;
  font-size: 2.2rem;
  font-weight: 500;
  letter-spacing: 0.035em;
}
@media only screen and (max-width: 780px) {
  .p-company__guideline .box ol li h3 {
    font-size: 1.8rem;
  }
}
.p-company__guideline .box ol li p {
  font-weight: 500;
  letter-spacing: 0.03em;
}
.p-company__slogan {
  margin-bottom: 9.6rem;
  padding: 16.8rem;
  background-image: url("../img/company/bg02.jpg");
  background-size: cover;
  background-position: center center;
}
@media only screen and (max-width: 780px) {
  .p-company__slogan {
    margin-bottom: 4.8rem;
    padding: 8rem 0;
  }
}
.p-company__slogan .inner {
  max-width: 1200px;
}
.p-company__slogan .img {
  text-align: center;
}
.p-company__slogan .img img {
  width: 1178px;
}
@media only screen and (max-width: 780px) {
  .p-company__slogan .img img {
    width: 40rem;
  }
}
.p-company__outline {
  margin-bottom: 9.6rem;
}
@media only screen and (max-width: 780px) {
  .p-company__outline {
    margin-bottom: 4.8rem;
  }
}
.p-company__outline .inner {
  max-width: 1000px;
}
@media only screen and (min-width: 781px) {
  .p-company__outline .midashi02 {
    margin-bottom: 2.75em;
  }
}
.p-company__outline table {
  width: 100%;
  border-top: solid 1px #C5CAD0;
}
.p-company__outline table tbody tr td {
  padding: 2em 0;
  letter-spacing: 0.03em;
  vertical-align: top;
  border-bottom: solid 1px #C5CAD0;
}
.p-company__outline table tbody tr td:nth-child(1) {
  font-weight: 700;
  color: #0B66AC;
}
@media only screen and (min-width: 781px) {
  .p-company__outline table tbody tr td:nth-child(1) {
    width: 33rem;
    padding-left: 8rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-company__outline table tbody tr td:nth-child(1) {
    width: 30%;
  }
}
.p-company__outline table tbody tr td b {
  font-weight: 700;
}
.p-company__outline table tbody tr td span {
  margin-right: 1em;
  font-weight: 500;
  display: inline-block;
}
.p-company__office {
  padding: 8.8rem 0;
  background-color: #ECEEF0;
}
@media only screen and (max-width: 780px) {
  .p-company__office {
    padding: 4.4rem 0;
  }
}
.p-company__office .inner {
  max-width: 1000px;
}
@media only screen and (min-width: 781px) {
  .p-company__office ul {
    display: flex;
    justify-content: space-between;
  }
}
@media only screen and (min-width: 781px) {
  .p-company__office ul li {
    width: 46%;
  }
}
@media only screen and (max-width: 780px) {
  .p-company__office ul li + li {
    margin-top: 3rem;
  }
}
.p-company__office ul li .map {
  width: 100%;
  height: 24.3rem;
  margin-bottom: 2.4rem;
  border: solid 0.8rem #ffffff;
}
.p-company__office ul li .map iframe {
  width: 100%;
  height: 100%;
}
.p-company__office ul li p {
  font-size: 1.4rem;
}
.p-company__office ul li p b {
  margin-bottom: 0.5em;
  font-size: 1.14em;
  font-weight: 700;
  display: block;
}

.p-business__intro {
  margin-bottom: 12.8rem;
}
@media only screen and (max-width: 780px) {
  .p-business__intro {
    margin-bottom: 6.4rem;
  }
}
.p-business__intro .inner {
  max-width: 1120px;
}
@media only screen and (min-width: 901px) {
  .p-business__intro .headding {
    display: flex;
    align-items: center;
  }
  .p-business__intro .headding > * {
    width: 50%;
  }
}
@media only screen and (max-width: 900px) {
  .p-business__intro .headding .text {
    margin-bottom: 3rem;
  }
}
.p-business__intro .headding .text h3 {
  font-size: 3.6rem;
  font-weight: 700;
  letter-spacing: 0.035em;
  line-height: 1.27;
}
@media only screen and (max-width: 780px) {
  .p-business__intro .headding .text h3 {
    font-size: 2.4rem;
  }
}
@media only screen and (max-width: 900px) {
  .p-business__intro .headding .img {
    margin-bottom: 3rem;
    text-align: center;
  }
  .p-business__intro .headding .img img {
    max-width: 80%;
  }
}
.p-business__intro p {
  max-width: 1000px;
  margin: -1em auto 0 auto;
  padding-top: 6.4rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 2.18;
  background-color: #ffffff;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 900px) {
  .p-business__intro p {
    margin-top: 0;
    padding-top: 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-business__intro p {
    line-height: 1.6;
  }
}
.p-business__service {
  padding: 9.6rem 0;
  background-color: #ECEEF0;
}
@media only screen and (max-width: 780px) {
  .p-business__service {
    padding: 4.8rem 0;
  }
}
.p-business__service .inner {
  max-width: 1120px;
}
.p-business__service ul li {
  padding: 1em;
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-business__service ul li {
    display: flex;
  }
}
.p-business__service ul li + li {
  margin-top: 1em;
}
@media only screen and (min-width: 781px) {
  .p-business__service ul li .img {
    width: 44%;
  }
}
@media only screen and (max-width: 780px) {
  .p-business__service ul li .img {
    margin-bottom: 2rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-business__service ul li .text {
    width: 56%;
    padding-top: 4rem;
    padding-left: 4rem;
  }
}
.p-business__service ul li .text h3 {
  margin-bottom: 1em;
  font-weight: 500;
  letter-spacing: 0.03em;
}
.p-business__service ul li .text h4 {
  margin-bottom: 1.2em;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}
@media only screen and (max-width: 780px) {
  .p-business__service ul li .text h4 {
    font-size: 1.8rem;
  }
}
.p-business__service ul li .text p {
  letter-spacing: 0.03em;
  line-height: 1.75;
}
.p-business__support {
  padding: 9.2rem 0;
  background-image: url("../img/business/support_bg.jpg");
  background-size: cover;
  background-position: center center;
}
@media only screen and (max-width: 780px) {
  .p-business__support {
    padding: 4.6rem 0;
  }
}
.p-business__support .inner {
  max-width: 1120px;
}
.p-business__support h3 {
  margin-bottom: 1.2em;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.035em;
  color: #ffffff;
}
@media only screen and (max-width: 780px) {
  .p-business__support h3 {
    font-size: 1.8rem;
  }
}
.p-business__support ul {
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (min-width: 781px) {
  .p-business__support ul {
    margin-bottom: -3.2rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-business__support ul {
    margin-bottom: -1rem;
  }
}
.p-business__support ul li {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-business__support ul li {
    width: 22.8%;
    margin: 0 2.93% 3.2rem 0;
  }
  .p-business__support ul li:nth-child(4n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-business__support ul li {
    width: 49%;
    margin: 0 2% 1rem 0;
  }
  .p-business__support ul li:nth-child(2n) {
    margin-right: 0;
  }
}
.p-business__support ul li p {
  padding: 0.88em;
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.03em;
}
@media only screen and (max-width: 780px) {
  .p-business__support ul li p {
    padding: 0.5em 0.3em;
    font-size: 1.3rem;
  }
}
.p-business__support ul + h3 {
  margin-top: 2.4em;
}
.p-business__product {
  margin-bottom: 16rem;
  padding-top: 6.4rem;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-business__product {
    margin-bottom: 8rem;
    padding-top: 3.2rem;
  }
}
.p-business__product:before {
  width: 100%;
  height: 40.6rem;
  content: "";
  background-color: #00235C;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.p-business__product .box {
  padding-top: 8rem;
  background-color: #ffffff;
}
@media only screen and (max-width: 780px) {
  .p-business__product .box {
    padding-top: 4rem;
  }
}
.p-business__product .box .product_list {
  width: 90%;
  max-width: 896px;
  margin: 0 auto;
  display: flex;
}
@media only screen and (min-width: 781px) {
  .p-business__product .box .product_list {
    justify-content: space-between;
  }
}
@media only screen and (max-width: 780px) {
  .p-business__product .box .product_list {
    margin-bottom: -4.8%;
    flex-wrap: wrap;
  }
}
.p-business__product .box .product_list li {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-business__product .box .product_list li {
    width: 32%;
  }
}
@media only screen and (max-width: 780px) {
  .p-business__product .box .product_list li {
    width: 47.6%;
    margin: 0 4.8% 4.8% 0;
  }
  .p-business__product .box .product_list li:nth-child(2n) {
    margin-right: 0;
  }
}
.p-business__product .box .product_list li a {
  display: block;
}
.p-business__product .box .product_list li a:hover .img img {
  transform: scale(1.1);
}
.p-business__product .box .product_list li .img {
  aspect-ratio: 288/209;
  overflow: hidden;
}
.p-business__product .box .product_list li .img > img,
.p-business__product .box .product_list li .img > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.p-business__product .box .product_list li .img img {
  transition: transform 0.3s;
}
.p-business__product .box .product_list li .text {
  padding: 1.6rem;
}
@media only screen and (max-width: 780px) {
  .p-business__product .box .product_list li .text {
    padding: 0.8rem;
  }
}
.p-business__product .box .product_list li .text p {
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.03em;
}
@media only screen and (max-width: 780px) {
  .p-business__product .box .product_list li .text p {
    font-size: 1.5rem;
  }
}
.p-business__product .box .product_list li .text .more {
  margin-top: 1rem;
  font-family: "Montserrat", sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: right;
  color: #105BB4;
}
@media only screen and (max-width: 780px) {
  .p-business__product .box .product_list li .text .more {
    margin-top: 0.5rem;
    font-size: 1.2rem;
  }
}
.p-business__product .box .product_list li .text .more:after {
  width: 1em;
  height: 1em;
  margin-left: 0.8rem;
  content: "";
  background-image: url("../img/icon_arrow02.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.25em;
}
.p-business__product .box .btn {
  margin-top: 4rem;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-business__product .box .btn {
    margin-top: 3rem;
  }
}

@media only screen and (min-width: 781px) {
  .p-recruit__intro {
    margin-top: -8rem;
    padding: 8rem 0 9.6rem 0;
    background-image: url("../img/recruit/intro_bg.jpg");
    background-size: cover;
    background-position: center center;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__intro {
    margin-top: -4rem;
  }
  .p-recruit__intro:before {
    width: 100%;
    height: 17.8rem;
    margin-bottom: 3rem;
    content: "";
    background-image: url("../img/recruit/intro_bg_sp01.jpg");
    background-size: cover;
    background-position: center center;
    display: block;
  }
  .p-recruit__intro:after {
    width: 100%;
    height: 7.8rem;
    margin-top: 3rem;
    content: "";
    background-image: url("../img/recruit/intro_bg_sp02.jpg");
    background-size: cover;
    background-position: center center;
    display: block;
  }
}
.p-recruit__intro h2 {
  margin-bottom: 1.16em;
  font-size: 3.6rem;
  font-weight: 700;
  letter-spacing: 0.035em;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-recruit__intro h2 {
    font-size: 2.4rem;
  }
}
.p-recruit__intro p {
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.875;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-recruit__intro p {
    line-height: 1.6;
    text-align: left;
  }
}
.p-recruit__business {
  margin-bottom: 8.8rem;
  padding: 8rem 0;
  background-image: url("../img/recruit/bg01.jpg");
  background-size: cover;
  background-position: center center;
}
@media only screen and (max-width: 780px) {
  .p-recruit__business {
    margin-bottom: 4.4rem;
    padding: 4rem 0;
  }
}
.p-recruit__business .inner {
  max-width: 1120px;
}
@media only screen and (min-width: 781px) {
  .p-recruit__business ul {
    display: flex;
    justify-content: space-between;
  }
}
.p-recruit__business ul li {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-recruit__business ul li {
    width: 48%;
    padding: 4rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__business ul li {
    padding: 2rem;
  }
  .p-recruit__business ul li + li {
    margin-top: 3rem;
  }
}
.p-recruit__business ul li h3 {
  margin-bottom: 0.375em;
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}
@media only screen and (max-width: 780px) {
  .p-recruit__business ul li h3 {
    font-size: 2rem;
  }
}
.p-recruit__business ul li p {
  margin-bottom: 1.375em;
  font-weight: 500;
  letter-spacing: 0.03em;
}
.p-recruit__business ul li dl + dl {
  margin-top: 1em;
}
.p-recruit__business ul li dl dt {
  padding: 0.5em 1em;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #ffffff;
  background-color: #00235C;
}
.p-recruit__business ul li dl dd {
  padding: 0.5em 1em 0.5em 2.8125em;
  background-image: url("../img/icon_check01.png");
  background-size: 2em auto;
  background-repeat: no-repeat;
  background-position: 0.625em 0.25em;
  border: solid 1px #C5CAD0;
}
.p-recruit__business ul li dl dd + dd {
  margin-top: -1px;
}
.p-recruit__detail {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 780px) {
  .p-recruit__detail {
    margin-bottom: 6rem;
  }
}
.p-recruit__detail .inner {
  max-width: 1120px;
}
.p-recruit__detail table {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
}
.p-recruit__detail table tbody tr td {
  padding: 1.5em 2.5em;
  vertical-align: top;
  border: solid 1px #C5CAD0;
}
.p-recruit__detail table tbody tr td:nth-child(1) {
  width: 20rem;
  font-weight: 700;
  background-color: #F4F4F4;
  border-right: none;
}
.p-recruit__detail table tbody tr td:nth-child(2) {
  border-left: none;
}
.p-recruit__entry {
  color: #ffffff;
  background-size: cover;
  background-position: center center;
}
@media only screen and (min-width: 781px) {
  .p-recruit__entry {
    padding: 7rem 0 5.4rem 0;
    background-image: url("../img/recruit/recruit_bg.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__entry {
    padding: 4.8rem 0;
    background-image: url("../img/recruit/recruit_bg_sp.jpg");
  }
}
.p-recruit__entry .midashi01 {
  margin-bottom: 0.9em;
  font-size: 3.6rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-recruit__entry .midashi01 {
    font-size: 2rem;
  }
}
.p-recruit__entry p {
  margin-bottom: 2.4em;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.75;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-recruit__entry p {
    margin-bottom: 1.3em;
    line-height: 1.5;
    text-align: left;
  }
}
.p-recruit__entry .btn {
  text-align: center;
}

.p-contact__form {
  margin-bottom: 16rem;
}
@media only screen and (max-width: 780px) {
  .p-contact__form {
    margin-bottom: 8rem;
  }
}
.p-contact__form .inner {
  max-width: 1000px;
}
.p-contact__form .form_area .input_field_area {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 780px) {
  .p-contact__form .form_area .input_field_area {
    margin-bottom: 2.5rem;
  }
}
.p-contact__form .form_area .input_field_area .input_field {
  margin-bottom: 3em;
}
.p-contact__form .form_area .input_field_area .input_field .input_label {
  margin-bottom: 0.75em;
  font-size: 1.125em;
  font-weight: 500;
}
.p-contact__form .form_area .input_field_area .input_field .input_label small {
  font-size: 0.83em;
}
.p-contact__form .form_area .input_field_area .input_field .input_label span {
  margin-left: 1em;
  padding: 0 0.5em;
  font-size: 0.7em;
  font-weight: 400;
  color: #0B66AC;
  border: solid 1px #0B66AC;
  border-radius: 0.4rem;
  display: inline-block;
  vertical-align: 0;
}
.p-contact__form .form_area .input_field_area .input_field .input_label span.ninni {
  color: #BEBEBE;
  border-color: #BEBEBE;
}
.p-contact__form .form_area .input_field_area .input_field .input_area.row {
  display: flex;
  justify-content: space-between;
}
.p-contact__form .form_area .input_field_area .input_field .input_area.row .col {
  width: 48%;
}
.p-contact__form .form_area .input_field_area .input_field .input_area.row .col .label {
  margin-bottom: 0.9rem;
  display: block;
}
.p-contact__form .form_area .input_field_area .input_field .input_area .annotation {
  margin-top: 1em;
  font-size: 0.75em;
}
.p-contact__form .form_area .privacy {
  margin-bottom: 5rem;
  padding: 2em;
  border: solid 1px #C5CAD0;
}
@media only screen and (max-width: 780px) {
  .p-contact__form .form_area .privacy {
    margin-bottom: 2.5rem;
  }
}
.p-contact__form .form_area .privacy .box {
  height: 24rem;
  margin-bottom: 3.2rem;
}
@media only screen and (max-width: 780px) {
  .p-contact__form .form_area .privacy .box {
    height: 14rem;
  }
}
.p-contact__form .form_area .privacy .box .scroll {
  width: 100%;
  height: 100%;
  padding-right: 1em;
  overflow: auto;
}
.p-contact__form .form_area .privacy .box h3 {
  margin-bottom: 1.5em;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 780px) {
  .p-contact__form .form_area .privacy .box h3 {
    font-size: 1.6rem;
  }
}
.p-contact__form .form_area .privacy .box h4 {
  margin-bottom: 0.5em;
  font-size: 1.5rem;
  font-weight: 500;
  letter-spacing: 0.05em;
}
.p-contact__form .form_area .privacy .box p {
  margin-bottom: 2em;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
}
.p-contact__form .form_area .privacy .check {
  text-align: right;
}
.p-contact__form .form_area .submit {
  text-align: center;
}
.p-contact__form .form_area .submit input[type=submit] {
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
  color: #0B66AC;
  background: linear-gradient(to right, #0B66AC, #0B66AC 50%, transparent 50%, transparent);
  background-size: 200% 100%;
  background-position: 100% 0;
  border: solid 0.2rem #0B66AC;
  display: inline-block;
}
@media only screen and (min-width: 781px) {
  .p-contact__form .form_area .submit input[type=submit] {
    width: 34.5rem;
    padding: 1.15em;
    transition: background-position 0.3s, color 0.3s;
  }
  .p-contact__form .form_area .submit input[type=submit]:hover {
    color: #ffffff;
    background-position: 0 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-contact__form .form_area .submit input[type=submit] {
    width: 28.1rem;
    padding: 0.9em;
    font-size: 1.4rem;
  }
}
.p-contact__form .form_area .submit input[type=submit]:disabled {
  opacity: 0.3 !important;
}

.p-product__bg {
  background-color: #F8F8F8;
}
@media only screen and (min-width: 781px) {
  .p-product__bg {
    margin-top: -8rem;
    padding: 8rem 0 12rem 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-product__bg {
    margin-top: -4rem;
    padding: 4rem 0 6rem 0;
  }
}
.p-product__list {
  margin-top: 8rem;
}
@media only screen and (max-width: 780px) {
  .p-product__list {
    margin-top: 4rem;
  }
}
.p-product__list .inner {
  max-width: 1200px;
}
.p-product__list .product_list {
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (min-width: 781px) {
  .p-product__list .product_list {
    margin-bottom: 4.8rem;
  }
}
.p-product__list .product_list li {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-product__list .product_list li {
    width: 24%;
    margin: 0 1.33% 4.8rem 0;
  }
  .p-product__list .product_list li:nth-child(4n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-product__list .product_list li {
    width: 47.6%;
    margin: 0 4.8% 4.8% 0;
  }
  .p-product__list .product_list li:nth-child(2n) {
    margin-right: 0;
  }
}
.p-product__list .product_list li a {
  display: block;
}
.p-product__list .product_list li a:hover .img img {
  transform: scale(1.1);
}
.p-product__list .product_list li .img {
  aspect-ratio: 288/209;
  overflow: hidden;
}
.p-product__list .product_list li .img > img,
.p-product__list .product_list li .img > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.p-product__list .product_list li .img img {
  transition: transform 0.3s;
}
.p-product__list .product_list li .text {
  padding: 1.6rem;
}
@media only screen and (max-width: 780px) {
  .p-product__list .product_list li .text {
    padding: 0.8rem;
  }
}
.p-product__list .product_list li .text p {
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.03em;
}
@media only screen and (max-width: 780px) {
  .p-product__list .product_list li .text p {
    font-size: 1.5rem;
  }
}
.p-product__list .product_list li .text .more {
  margin-top: 1rem;
  font-family: "Montserrat", sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: right;
  color: #105BB4;
}
@media only screen and (max-width: 780px) {
  .p-product__list .product_list li .text .more {
    margin-top: 0.5rem;
    font-size: 1.2rem;
  }
}
.p-product__list .product_list li .text .more:after {
  width: 1em;
  height: 1em;
  margin-left: 0.8rem;
  content: "";
  background-image: url("../img/icon_arrow02.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.25em;
}
.p-product__detail {
  margin-bottom: 12.8rem;
}
@media only screen and (max-width: 780px) {
  .p-product__detail {
    margin-bottom: 6.4rem;
  }
}
.p-product__detail .inner {
  max-width: 1200px;
}
@media only screen and (min-width: 901px) {
  .p-product__detail .content {
    margin-bottom: 6.4rem;
    display: flex;
    justify-content: space-between;
  }
}
@media only screen and (max-width: 900px) {
  .p-product__detail .content {
    margin-bottom: 3.2rem;
  }
}
@media only screen and (min-width: 901px) {
  .p-product__detail .content .img_area {
    width: 45.8%;
  }
}
@media only screen and (max-width: 900px) {
  .p-product__detail .content .img_area {
    margin-bottom: 3rem;
  }
}
.p-product__detail .content .img_area .img {
  margin-bottom: 1.6rem;
}
.p-product__detail .content .img_area .img img {
  width: 100%;
}
.p-product__detail .content .img_area .thumbnail {
  letter-spacing: -0.4em;
}
.p-product__detail .content .img_area .thumbnail > * {
  display: inline-block;
  letter-spacing: normal;
}
.p-product__detail .content .img_area .thumbnail span {
  width: 17.5%;
  height: auto;
  margin: 0 3.125% 1rem 0;
  aspect-ratio: 96/72;
  overflow: hidden;
}
.p-product__detail .content .img_area .thumbnail span > img,
.p-product__detail .content .img_area .thumbnail span > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.p-product__detail .content .img_area .thumbnail span:nth-child(5n) {
  margin-right: 0;
}
.p-product__detail .content .img_area .thumbnail span.current, .p-product__detail .content .img_area .thumbnail span:hover {
  opacity: 0.3;
}
@media only screen and (min-width: 901px) {
  .p-product__detail .content .text_area {
    width: 45%;
  }
}
.p-product__detail .content .text_area h2 {
  margin-bottom: 0.28em;
  font-size: 3.2rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-product__detail .content .text_area h2 {
    font-size: 2.4rem;
  }
}
.p-product__detail .content .text_area p {
  margin-bottom: 2.45em;
  font-size: 1.5rem;
  line-height: 2;
}
@media only screen and (max-width: 780px) {
  .p-product__detail .content .text_area p {
    font-size: 1.4rem;
  }
}
.p-product__detail .content .text_area p.summary {
  margin-bottom: 1em;
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.014em;
  line-height: 1.5;
}
@media only screen and (max-width: 780px) {
  .p-product__detail .content .text_area p.summary {
    font-size: 1.6rem;
  }
}
.p-product__detail .content .text_area .cate {
  margin-bottom: 2em;
  font-size: 1.5rem;
  font-weight: 500;
  letter-spacing: -0.4em;
}
.p-product__detail .content .text_area .cate > * {
  display: inline-block;
  letter-spacing: normal;
}
@media only screen and (max-width: 780px) {
  .p-product__detail .content .text_area .cate {
    font-size: 1.3rem;
  }
}
.p-product__detail .content .text_area .cate span {
  margin: 0 0.5rem 0.5rem 0;
  padding: 0.1em 0.5em;
  background-color: #F4F4F4;
}
.p-product__detail .content .text_area table {
  width: 100%;
  font-size: 1.5rem;
  border-top: solid 1px #C5CAD0;
}
@media only screen and (max-width: 780px) {
  .p-product__detail .content .text_area table {
    font-size: 1.4rem;
  }
}
.p-product__detail .content .text_area table tbody tr th {
  width: 35%;
  padding: 1.2em;
  font-weight: 700;
  vertical-align: top;
  border-bottom: solid 1px #C5CAD0;
}
.p-product__detail .content .text_area table tbody tr td {
  padding: 1.2em 0;
  vertical-align: top;
  border-bottom: solid 1px #C5CAD0;
}
.p-product__detail .btn {
  text-align: center;
}

.p-achievements__list {
  margin-bottom: 12.8rem;
}
@media only screen and (max-width: 780px) {
  .p-achievements__list {
    margin-bottom: 6.4rem;
  }
}
.p-achievements__list .inner {
  max-width: 1120px;
}
.p-achievements__list .achievements_list {
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (min-width: 781px) {
  .p-achievements__list .achievements_list {
    margin-bottom: 4rem;
  }
}
.p-achievements__list .achievements_list li {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-achievements__list .achievements_list li {
    width: 31.4%;
    margin: 0 2.9% 5.6rem 0;
  }
  .p-achievements__list .achievements_list li:nth-child(3n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .achievements_list li {
    width: 47.6%;
    margin: 0 4.8% 4.8% 0;
  }
  .p-achievements__list .achievements_list li:nth-child(2n) {
    margin-right: 0;
  }
}
.p-achievements__list .achievements_list li a {
  display: block;
}
.p-achievements__list .achievements_list li a:hover .img img {
  transform: scale(1.1);
}
.p-achievements__list .achievements_list li .img {
  aspect-ratio: 288/209;
  overflow: hidden;
}
.p-achievements__list .achievements_list li .img > img,
.p-achievements__list .achievements_list li .img > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.p-achievements__list .achievements_list li .img img {
  transition: transform 0.3s;
}
.p-achievements__list .achievements_list li .text {
  padding: 1.6rem;
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .achievements_list li .text {
    padding: 0.8rem;
  }
}
.p-achievements__list .achievements_list li .text p {
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.03em;
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .achievements_list li .text p {
    font-size: 1.5rem;
  }
}
.p-achievements__list .achievements_list li .text .more {
  margin-top: 1rem;
  font-family: "Montserrat", sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: right;
  color: #105BB4;
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .achievements_list li .text .more {
    margin-top: 0.5rem;
    font-size: 1.2rem;
  }
}
.p-achievements__list .achievements_list li .text .more:after {
  width: 1em;
  height: 1em;
  margin-left: 0.8rem;
  content: "";
  background-image: url("../img/icon_arrow02.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.25em;
}
.p-achievements__detail {
  margin-bottom: 12.8rem;
}
@media only screen and (max-width: 780px) {
  .p-achievements__detail {
    margin-bottom: 6.4rem;
  }
}
.p-achievements__detail .inner {
  max-width: 1120px;
}
.p-achievements__detail h2 {
  margin-bottom: 1.33em;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.4;
}
@media only screen and (max-width: 780px) {
  .p-achievements__detail h2 {
    font-size: 2.4rem;
  }
}
.p-achievements__detail .img {
  width: 100%;
  margin-bottom: 6.4rem;
  padding-top: 30.2rem;
  background-color: #F8F8F8;
  border: solid 0.1rem #DBDBDB;
  border-radius: 0.8rem;
  overflow: hidden;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .p-achievements__detail .img {
    margin-bottom: 3.2rem;
    padding-top: 24rem;
  }
}
.p-achievements__detail .img img {
  width: auto;
  max-width: none;
  height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media only screen and (min-width: 781px) {
  .p-achievements__detail .text01 {
    margin-bottom: 6.4rem;
    display: flex;
  }
}
@media only screen and (max-width: 780px) {
  .p-achievements__detail .text01 {
    margin-bottom: 3.2rem;
  }
}
.p-achievements__detail .text01 h3 {
  font-weight: 700;
}
@media only screen and (min-width: 781px) {
  .p-achievements__detail .text01 h3 {
    width: 25.4%;
    padding-right: 1em;
    font-size: 2.4rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-achievements__detail .text01 h3 {
    font-size: 2rem;
    margin-bottom: 0.5em;
  }
}
.p-achievements__detail .text01 .box {
  background-color: #F8F8F8;
}
@media only screen and (min-width: 781px) {
  .p-achievements__detail .text01 .box {
    width: 74.6%;
    padding: 4.8rem;
  }
}
.p-achievements__detail .text01 .box table {
  width: 100%;
  font-size: 1.5rem;
  border-top: solid 1px #C5CAD0;
}
@media only screen and (max-width: 780px) {
  .p-achievements__detail .text01 .box table {
    font-size: 1.4rem;
  }
}
.p-achievements__detail .text01 .box table tbody tr th {
  width: 35%;
  padding: 1.2em;
  font-weight: 700;
  vertical-align: top;
  border-bottom: solid 1px #C5CAD0;
}
.p-achievements__detail .text01 .box table tbody tr td {
  padding: 1.2em 0;
  vertical-align: top;
  border-bottom: solid 1px #C5CAD0;
}
@media only screen and (min-width: 781px) {
  .p-achievements__detail .text02 {
    margin-bottom: 7.2rem;
    display: flex;
  }
}
@media only screen and (max-width: 780px) {
  .p-achievements__detail .text02 {
    margin-bottom: 3.6rem;
  }
}
.p-achievements__detail .text02 h3 {
  font-weight: 700;
}
@media only screen and (min-width: 781px) {
  .p-achievements__detail .text02 h3 {
    width: 25.4%;
    padding-right: 1em;
    font-size: 2.4rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-achievements__detail .text02 h3 {
    font-size: 2rem;
    margin-bottom: 0.5em;
  }
}
@media only screen and (min-width: 781px) {
  .p-achievements__detail .text02 .content {
    width: 74.6%;
  }
}
.p-achievements__detail .text02 .content p {
  line-height: 1.8;
}
.p-achievements__detail .btn {
  text-align: center;
}
/**
/* 修理 CSS
----------------------------------------------- */
.p-repair__bg {
	background-color: #F8F8F8;
}
@media only screen and (min-width: 781px) {
	.p-repair__bg {
		margin-top: -8rem;
		padding: 8rem 0 12rem 0;
	}
}
@media only screen and (max-width: 780px) {
	.p-repair__bg {
		margin-top: -4rem;
		padding: 4rem 0 6rem 0;
	}
}
.p-repair__list {
	margin-top: 8rem;
}
@media only screen and (max-width: 780px) {
	.p-repair__list {
		margin-top: 4rem;
	}
}
.p-repair__list .inner {
	max-width: 1200px;
}
.p-repair__list .repair_list {
	display: flex;
	flex-wrap: wrap;
}
@media only screen and (min-width: 781px) {
	.p-repair__list .repair_list {
		margin-bottom: 4.8rem;
	}
}
.p-repair__list .repair_list li {
	background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
	.p-repair__list .repair_list li {
		width: 24%;
		margin: 0 1.33% 4.8rem 0;
	}
	.p-repair__list .repair_list li:nth-child(4n) {
		margin-right: 0;
	}
}
@media only screen and (max-width: 780px) {
	.p-repair__list .repair_list li {
		width: 47.6%;
		margin: 0 4.8% 4.8% 0;
	}
	.p-repair__list .repair_list li:nth-child(2n) {
		margin-right: 0;
	}
}
.p-repair__list .repair_list li a {
	display: block;
}
.p-repair__list .repair_list li a:hover .img img {
	transform: scale(1.1);
}
.p-repair__list .repair_list li .img {
	aspect-ratio: 288/209;
	overflow: hidden;
}
.p-repair__list .repair_list li .img > img,
.p-repair__list .repair_list li .img > video {
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}
.p-repair__list .repair_list li .img img {
	transition: transform 0.3s;
}
.p-repair__list .repair_list li .text {
	padding: 1.6rem;
}
@media only screen and (max-width: 780px) {
	.p-repair__list .repair_list li .text {
		padding: 0.8rem;
	}
}
.p-repair__list .repair_list li .text p {
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 0.03em;
}
@media only screen and (max-width: 780px) {
	.p-repair__list .repair_list li .text p {
		font-size: 1.5rem;
	}
}
.p-repair__list .repair_list li .text .more {
	margin-top: 1rem;
	font-family: "Montserrat", sans-serif;
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-align: right;
	color: #105BB4;
}
@media only screen and (max-width: 780px) {
	.p-repair__list .repair_list li .text .more {
		margin-top: 0.5rem;
		font-size: 1.2rem;
	}
}
.p-repair__list .repair_list li .text .more:after {
	width: 1em;
	height: 1em;
	margin-left: 0.8rem;
	content: "";
	background-image: url("../img/icon_arrow02.png");
	background-size: cover;
	display: inline-block;
	vertical-align: -0.25em;
}
.p-repair__detail {
	margin-bottom: 12.8rem;
}
@media only screen and (max-width: 780px) {
	.p-repair__detail {
		margin-bottom: 6.4rem;
	}
}
.p-repair__detail .inner {
	max-width: 1200px;
}
@media only screen and (min-width: 901px) {
	.p-repair__detail .content {
		margin-bottom: 6.4rem;
		display: flex;
		justify-content: space-between;
	}
}
@media only screen and (max-width: 900px) {
	.p-repair__detail .content {
		margin-bottom: 3.2rem;
	}
}
@media only screen and (min-width: 901px) {
	.p-repair__detail .content .img_area {
		width: 45.8%;
	}
}
@media only screen and (max-width: 900px) {
	.p-repair__detail .content .img_area {
		margin-bottom: 3rem;
	}
}
.p-repair__detail .content .img_area .img {
	margin-bottom: 1.6rem;
}
.p-repair__detail .content .img_area .img img {
	width: 100%;
}
.p-repair__detail .content .img_area .thumbnail {
	letter-spacing: -0.4em;
}
.p-repair__detail .content .img_area .thumbnail > * {
	display: inline-block;
	letter-spacing: normal;
}
.p-repair__detail .content .img_area .thumbnail span {
	width: 17.5%;
	height: auto;
	margin: 0 3.125% 1rem 0;
	aspect-ratio: 96/72;
	overflow: hidden;
}
.p-repair__detail .content .img_area .thumbnail span > img,
.p-repair__detail .content .img_area .thumbnail span > video {
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}
.p-repair__detail .content .img_area .thumbnail span:nth-child(5n) {
	margin-right: 0;
}
.p-repair__detail .content .img_area .thumbnail span.current, .p-repair__detail .content .img_area .thumbnail span:hover {
	opacity: 0.3;
}
@media only screen and (min-width: 901px) {
	.p-repair__detail .content .text_area {
		width: 45%;
	}
}
.p-repair__detail .content .text_area h2 {
	margin-bottom: 0.28em;
	font-size: 3.2rem;
	font-weight: 700;
}
@media only screen and (max-width: 780px) {
	.p-repair__detail .content .text_area h2 {
		font-size: 2.4rem;
	}
}
.p-repair__detail .content .text_area p {
	margin-bottom: 2.45em;
	font-size: 1.5rem;
	line-height: 2;
}
@media only screen and (max-width: 780px) {
	.p-repair__detail .content .text_area p {
		font-size: 1.4rem;
	}
}
.p-repair__detail .content .text_area p.summary {
	margin-bottom: 1em;
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 0.014em;
	line-height: 1.5;
}
@media only screen and (max-width: 780px) {
	.p-repair__detail .content .text_area p.summary {
		font-size: 1.6rem;
	}
}
.p-repair__detail .content .text_area .cate {
	margin-bottom: 2em;
	font-size: 1.5rem;
	font-weight: 500;
	letter-spacing: -0.4em;
}
.p-repair__detail .content .text_area .cate > * {
	display: inline-block;
	letter-spacing: normal;
}
@media only screen and (max-width: 780px) {
	.p-repair__detail .content .text_area .cate {
		font-size: 1.3rem;
	}
}
.p-repair__detail .content .text_area .cate span {
	margin: 0 0.5rem 0.5rem 0;
	padding: 0.1em 0.5em;
	background-color: #F4F4F4;
}
.p-repair__detail .content .text_area table {
	width: 100%;
	font-size: 1.5rem;
	border-top: solid 1px #C5CAD0;
}
@media only screen and (max-width: 780px) {
	.p-repair__detail .content .text_area table {
		font-size: 1.4rem;
	}
}
.p-repair__detail .content .text_area table tbody tr th {
	width: 35%;
	padding: 1.2em;
	font-weight: 700;
	vertical-align: top;
	border-bottom: solid 1px #C5CAD0;
}
.p-repair__detail .content .text_area table tbody tr td {
	padding: 1.2em 0;
	vertical-align: top;
	border-bottom: solid 1px #C5CAD0;
}
.p-repair__detail .btn {
	text-align: center;
}
/**
/* お知らせ CSS
----------------------------------------------- */
/*　　一覧　　*/
.p-top__news{
	padding: 8rem 0 9.6rem 0;
}
.p-top__news .midashi01{
	text-align: center;
	margin-bottom: 4.8rem;
}
.news-guide{
	margin-bottom: 16rem;
}
.news-list .news-items{
	border-bottom: 1px solid #C3C3C3;
	padding-bottom: 3.2rem;
	margin-bottom: 3.2rem;
}
.news-list .news-items a{
	position: relative;
	display: flex;
}
.news-list .news-items a::after{
	content: '';
	position: absolute;
	width: 2rem;
	height: 2rem;
	right: 4rem;
	top: 50%;
	transform: translateY(-50%);
	background: url(../img/arrow_next.png) no-repeat center;
	background-size: cover;
}
.news-list .news-items dt{
	display: flex;
	align-items: center;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	width: 20.5rem;
}
.news-list .news-items dt .date{
	font-family: "Montserrat", sans-serif;
	color: #125BB4;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.65;
}
.news-list .news-items .category{
	margin-left: 4rem;
}
.news-list .news-items .category li{
	background: #0B66AC;
	color: #FFFFFF;
	font-size: 1.2rem;
	font-weight: 500;
	line-height: 1.45;
	letter-spacing: 0.03em;
	text-align: center;
	padding: 0.2rem 1.6rem;
}
.news-list .news-items dd{
	width: calc(100% - 20.5rem);
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.65;
	letter-spacing: 0.03em;
	padding: 0 7rem 0 4rem;
}
.p-top__news .btn{
	text-align: center;
	margin-top: 5.6rem;
}
.news-guide .pagination{
	margin-top: 8rem;
}
@media only screen and (max-width: 780px) {
	.p-top__news{
		padding: 5rem 0 6rem 0;
	}
	.p-top__news .midashi01{
		margin-bottom: 3.5rem;
	}
	.news-guide{
		margin-bottom: 6rem;
	}
	.news-list .news-items{
		padding-bottom: 1.6rem;
		margin-bottom: 1.6rem;
	}
	.news-list .news-items a{
		display: block;
	}
	.news-list .news-items a::after{
		right: 0.5rem;
	}
	.news-list .news-items dt{
		-webkit-justify-content: flex-start;
		justify-content: flex-start;
		width: 100%;
		margin-bottom: 1rem;
	}
	.news-list .news-items dt .date{
		font-size: 1.5rem;
	}
	.news-list .news-items .category{
		margin-left: 1.5rem;
	}
	.news-list .news-items .category li{
		padding: 0 1rem 0.2rem 1rem;
	}
	.news-list .news-items dd{
		width: 100%;
		font-size: 1.4rem;
		padding: 0 3rem 0 0;
	}
	.p-top__news .btn{
		margin-top: 3.5rem;
	}
	.news-guide .pagination{
		margin-top: 5rem;
	}
}
/*　　詳細　　*/
.news-single{
	margin-bottom: 15.2rem;
}
.news-single .inner{
	max-width: 1000px;
}
.news-single article{
	border-bottom: 1px solid #C3C3C3;
	padding-bottom: 9.6rem;
}
.news-single .entry-header{
	border-bottom: 1px solid #C3C3C3;
	padding-bottom: 2.4rem;
	margin-bottom: 4rem;
}
.news-single .entry-header h2{
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.25;
	margin-bottom: 1.6rem;
}
.news-single .category{
	margin-bottom: 1.3rem;
}
.news-single .category a{
	display: inline-block;
	background: #0B66AC;
	color: #FFFFFF;
	font-size: 1.2rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.03em;
	text-align: center;
	padding: 0.2rem 1.6rem;
}
.news-single .entry-date{
	display: flex;
	align-items: center;
}
.news-single .entry-date li{
	position: relative;
	font-family: "Montserrat", sans-serif;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.45;
	letter-spacing: 0.1em;
	padding-left: 2.4rem;
}
.news-single .entry-date li + li{
	margin-left: 1.6rem;
}
.news-single .entry-date li::before{
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
.news-single .entry-date li.public::before{
	background: url(../img/public.svg) no-repeat center;
	background-size: cover;
	width: 1.6rem;
	height: 1.6rem;
}
.news-single .entry-date li.update::before{
	background: url(../img/update.svg) no-repeat center;
	background-size: cover;
	width: 1.6rem;
	height: 1.6rem;
}
.news-single .entry-body h2{
	background: #F5F5F5;
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1.6;
	border-left: 0.4rem solid #0B66AC;
	padding: 0.8rem 1.6rem;
	margin-bottom: 2.4rem;
	margin-top: 3rem;
}
.news-single .entry-body h3{
	position: relative;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.5;
	border-bottom: 1px solid #E6E6E6;
	padding-bottom: 1rem;
	padding-left: 3.6rem;
	margin-bottom: 2.4rem;
}
.news-single .entry-body h3::before{
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	background: url(../img/square.svg) no-repeat center;
	background-size: cover;
	width: 2.2rem;
	height: 2.2rem;
}
.news-single .entry-body h4{
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: 2.4rem;
}
.news-single .entry-body p{
	font-weight: 500;
	line-height: 2.1;
	margin-bottom: 5.6rem;
}
.news-single .entry-body p:last-child{
	margin-bottom: 0;
}
.news-single .entry-body .wp-block-image{
	margin-bottom: 5.6rem;
}
.news-single .entry-body .wp-block-image:last-child{
	margin-bottom: 0;
}
.news-single .entry-body ol,
.news-single .entry-body ul{
	margin: 3rem 0;
}
.news-single .entry-body ol{
	list-style: decimal;
	margin-left: 2rem;
}
.news-single .entry-body ul{
	list-style: disc;
	margin-left: 2rem;
}
.news-single .entry-body ol li,
.news-single .entry-body ul li{
	font-weight: 400;
	line-height: 1.6;
}
.news-single .entry-body ol li + li,
.news-single .entry-body ul li + li{
	margin-top: 1rem;
}
.news-single .entry-body .alignleft {
	display: inline;
	float: left;
}
.news-single .entry-body .alignright {
	display: inline;
	float: right;
}
.news-single .entry-body .aligncenter {
	display: block;
	margin-right: auto;
	margin-left: auto;
}
.news-single .entry-body blockquote.alignleft,
.news-single .entry-body .wp-caption.alignleft,
.news-single .entry-body img.alignleft {
	margin: 0 1.6rem 0 0;
}
.news-single .entry-body blockquote.alignright,
.news-single .entry-body .wp-caption.alignright,
.news-single .entry-body img.alignright {
	margin: 0 0 0 1.6rem;
}
.news-single .entry-body blockquote.aligncenter,
.news-single .entry-body .wp-caption.aligncenter,
.news-single .entry-body img.aligncenter {
	clear: both;
}
.news-single .page-nav{
	margin-top: 7.6rem;
}
.news-single .page-nav ul{
	width: 100%;
	display: flex;
	align-items: center;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
.news-single .page-nav ul .nav__item--prev,
.news-single .page-nav ul .nav__item--next{
	width: calc(50% - 17.2rem);
}
.news-single .page-nav ul .nav__item--next{
	text-align: right;
}
.news-single .page-nav ul .nav__item--prev a,
.news-single .page-nav ul .nav__item--next a{
	display: block;
}
.news-single .page-nav ul .nav__item--prev a span,
.news-single .page-nav ul .nav__item--next a span{
	display: inline-block;
	color: #081F3B;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 2;
}
.news-single .page-nav ul .nav__item--prev a i,
.news-single .page-nav ul .nav__item--next a i{
	display: inline-block;
	width: 2rem;
	height: 2rem;
	line-height: 1;
	vertical-align: middle;
	margin-top: -0.5rem;
}
.news-single .page-nav ul .nav__item--prev a i{
	background: url(../img/arrow_prev.png) no-repeat center;
	background-size: cover;
	margin-right: 1.6rem;
}
.news-single .page-nav ul .nav__item--next a i{
	background: url(../img/arrow_next.png) no-repeat center;
	background-size: cover;
	margin-left: 1.6rem;
}
.news-single .page-nav ul .nav__item--news{
	display: inline-block;
	width: 100%;
	max-width: 34.5rem;
}
.news-single .page-nav ul .nav__item--news .btn{
	color: #0B66AC;
	background: linear-gradient(to right, #0B66AC, #0B66AC 50%, transparent 50%, transparent);
	background-size: 200% 100%;
	background-position: 100% 0;
	border: solid 0.2rem #0B66AC;
	color: #0B66AC;
	display: block;
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: 0.03em;
	text-align: center;
	padding: 1.8rem;
}
@media only screen and (min-width: 781px) {
	.news-single .page-nav ul .nav__item--news .btn{
		transition: background-position 0.3s, color 0.3s;
	}
	.news-single .page-nav ul .nav__item--news .btn:hover{
		color: #ffffff;
		background-position: 0 0;
	}
}
@media only screen and (max-width: 780px) {
	.news-single{
		margin-bottom: 6.4rem;
	}
	.news-single article{
		padding-bottom: 6.5rem;
	}
	.news-single .entry-header{
		padding-bottom: 1.5rem;
		margin-bottom: 2rem;
	}
	.news-single .entry-header h2{
		font-size: 2.2rem;
		margin-bottom: 1.5rem;
	}
	.news-single .category{
		margin-bottom: 1rem;
	}
	.news-single .category a{
		padding: 0.2rem 1rem;
	}
	.news-single .entry-date li{
		font-size: 1.3rem;
	}
	.news-single .entry-body h2{
		font-size: 1.8rem;
		line-height: 1.45;
		padding: 0.6rem 1rem;
		margin-bottom: 2rem;
		margin-top: 2rem;
	}
	.news-single .entry-body h3{
		font-size: 1.7rem;
		padding-left: 3.4rem;
		margin-bottom: 2rem;
	}
	.news-single .entry-body h3::before{
		width: 2rem;
		height: 2rem;
	}
	.news-single .entry-body h4{
		margin-bottom: 1.5rem;
	}
	.news-single .entry-body p{
		line-height: 2;
		margin-bottom: 4rem;
	}
	.news-single .entry-body .wp-block-image{
		margin-bottom: 4rem;
	}
	.news-single .entry-body ol,
	.news-single .entry-body ul{
		margin: 2rem 0;
	}
	.news-single .entry-body blockquote.alignleft,
	.news-single .entry-body .wp-caption.alignleft,
	.news-single .entry-body img.alignleft {
		margin: 0 1rem 0 0;
	}
	.news-single .entry-body blockquote.alignright,
	.news-single .entry-body .wp-caption.alignright,
	.news-single .entry-body img.alignright {
		margin: 0 0 0 1rem;
	}
	.news-single .page-nav{
		margin-top: 3.5rem;
	}
	.news-single .page-nav ul .nav__item--prev,
	.news-single .page-nav ul .nav__item--next{
		width: 50%;
	}
	.news-single .page-nav ul .nav__item--prev a span,
	.news-single .page-nav ul .nav__item--next a span{
		font-size: 1.5rem;
	}
	.news-single .page-nav ul .nav__item--prev a i,
	.news-single .page-nav ul .nav__item--next a i{
		width: 1.6rem;
		height: 1.6rem;
		margin-top: -0.4rem;
	}
	.news-single .page-nav ul .nav__item--prev a i{
		margin-right: 0.8rem;
	}
	.news-single .page-nav ul .nav__item--next a i{
		margin-left: 0.8rem;
	}
	.news-single .page-nav ul .nav__item--news{
		display: none;
	}
	.news-single .block_btn{
		text-align: center;
		margin-top: 3.5rem;
	}
	.news-single .block_btn li{
		display: inline-block;
		width: 100%;
		width: 28.1rem;
	}
	.news-single .block_btn li .btn{
		color: #0B66AC;
		background: linear-gradient(to right, #0B66AC, #0B66AC 50%, transparent 50%, transparent);
		background-size: 200% 100%;
		background-position: 100% 0;
		border: solid 0.2rem #0B66AC;
		color: #0B66AC;
		display: block;
		font-size: 1.4rem;
		font-weight: 700;
		line-height: 1.65;
		letter-spacing: 0.03em;
		text-align: center;
		padding: 1rem;
	}
}

/****************************************************
 * 6.装飾
 ****************************************************/
.underline {
  text-decoration: underline;
}

.bold {
  font-weight: 700;
}

.colorRed {
  color: #ff0000;
}

/****************************************************
 * 7.印刷用調整
 ****************************************************/
@media print {
  @page {
    /* A4縦サイズ */
    size: 210mm 297mm;
  }
  html {
    font-size: 10pt !important;
  }
  body {
    margin: 0 !important;
    padding: 0 !important;
  }
  * {
    -webkit-print-color-adjust: exact;
  }
  .container {
    padding: 0 !important;
  }
  #header {
    position: static !important;
  }
  img {
    display: block !important;
  }
}
.p-business__product .tabArea{
	display: flex;
	width: 90%;
	max-width: 1000px;
	margin: 0px auto 6.4rem auto;
	column-gap: 4rem;
}
.p-business__product .tabArea .js-tab-btn{
	width: calc(50% - 2rem);
	color: #ffffff;
	font-weight: 700;
	line-height; 1.45
	letter-spacing: 0.03em;
	text-align: center;
	border: 2px solid #FFFFFF;
	padding: 1.8rem;
	cursor: pointer;
}
.p-business__product .tabArea .js-tab-btn.current{
	 background: #FFFFFF;
	 color: #081F3B;
}
.p-business__product .js-tab-contents{
	display: none;
}
.p-business__product .js-tab-contents.current{
	display: block;
}
.p-business__product .js-tab-contents .product_list{
	margin-bottom: 6.4rem;
}
@media only screen and (max-width: 780px) {
	.p-business__product .tabArea{
		margin: 0px auto 3rem auto;
		column-gap: 1rem;
	}
	.p-business__product .tabArea .js-tab-btn{
		width: calc(50% - 0.5rem);
		border: 1px solid #FFFFFF;
		font-size: 1.5rem;
		padding: 1.2rem 1rem;
	}
	.p-business__product .tabArea .js-tab-btn span{
		display: none;
	}
}
