@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: #000000;
  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: 7.2rem;
  }
}
@media only screen and (max-width: 780px) {
  html {
    height: 100%;
    font-size: 10px;
  }
}

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

a {
  color: #000000;
}
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: 1200px;
  margin: 0 auto;
}
@media only screen and (max-width: 780px) {
  .inner {
    width: 88%;
  }
}

/*コンポーネント*/
.midashi01 {
  margin-bottom: 0.5em;
  font-size: 3.6rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .midashi01 {
    margin-bottom: 0.35em;
    font-size: 2.4rem;
  }
}
.midashi01 .en {
  margin-bottom: 0.4em;
  font-family: "Montserrat", sans-serif;
  font-size: 2rem;
  letter-spacing: 0.03em;
  color: #BBCFEF;
  display: block;
}
@media only screen and (max-width: 780px) {
  .midashi01 .en {
    font-size: 1.3rem;
  }
}
.midashi01.center {
  text-align: center;
}
.midashi01.white {
  color: #ffffff;
}
.midashi01.white .en {
  color: #ffffff;
}

.btn01 {
  width: 34.4rem;
  padding: 1.5rem 4.8rem;
  font-size: 1.8rem;
  font-weight: 500;
  text-align: center;
  color: #ffffff !important;
  background: linear-gradient(to right, #0086D9, #0086D9 50%, #0028AC);
  background-size: 200% 100%;
  background-position: 100% 0;
  border-radius: 99px;
  box-shadow: 0.3rem 0.3rem 1rem rgba(14, 52, 96, 0.36);
  display: inline-block;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .btn01 {
    width: 29.4rem;
    padding: 1.4rem 4rem;
    font-size: 1.6rem;
    box-shadow: 0.15rem 0.15rem 0.5rem rgba(14, 52, 96, 0.36);
  }
}
.btn01:after {
  width: 2.4rem;
  height: 2.4rem;
  margin-top: -1.2rem;
  content: "";
  background-image: url("../img/icon_arrow01.png");
  background-size: cover;
  position: absolute;
  top: 50%;
  right: 2.4rem;
}
@media only screen and (max-width: 780px) {
  .btn01:after {
    width: 2rem;
    height: 2rem;
    margin-top: -1rem;
    right: 2rem;
  }
}
@media only screen and (min-width: 781px) {
  .btn01 {
    transition: background-position 0.3s;
  }
  .btn01:hover {
    background-position: 0 0;
  }
}
.btn02 {
  width: 34.4rem;
  padding: 1.5rem 4.8rem;
  font-size: 1.8rem;
  font-weight: 500;
  text-align: center;
  color: #0028AC !important;
  background: linear-gradient(to right, #FFE201, #FFE201 50%, #ffffff 50%, #ffffff);
  background-size: 200% 100%;
  background-position: 100% 0;
  border-radius: 99px;
  box-shadow: 0.3rem 0.3rem 1rem rgba(14, 52, 96, 0.36);
  display: inline-block;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .btn02 {
    width: 29.4rem;
    padding: 1.4rem 4rem;
    font-size: 1.6rem;
    box-shadow: 0.15rem 0.15rem 0.5rem rgba(14, 52, 96, 0.36);
  }
}
.btn02:after {
  width: 2.4rem;
  height: 2.4rem;
  margin-top: -1.2rem;
  content: "";
  background-image: url("../img/icon_arrow02.png");
  background-size: cover;
  position: absolute;
  top: 50%;
  right: 2.4rem;
}
@media only screen and (max-width: 780px) {
  .btn02:after {
    width: 2rem;
    height: 2rem;
    margin-top: -1rem;
    right: 2rem;
  }
}
@media only screen and (min-width: 781px) {
  .btn02 {
    transition: background-position 0.3s;
  }
  .btn02:hover {
    background-position: 0 0;
  }
}
.btn03 {
  width: 34.4rem;
  padding: 1.5rem 4.8rem;
  font-size: 1.8rem;
  font-weight: 500;
  text-align: center;
  color: #0028AC !important;
  background: linear-gradient(to right, #FFE201, #FFE201 50%, #ffffff 50%, #ffffff);
  background-size: 200% 100%;
  background-position: 100% 0;
  border: solid 0.2rem #0028AC;
  border-radius: 99px;
  box-shadow: 0.3rem 0.3rem 1rem rgba(14, 52, 96, 0.36);
  display: inline-block;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .btn03 {
    width: 29.4rem;
    padding: 1.4rem 4rem;
    font-size: 1.6rem;
    box-shadow: 0.15rem 0.15rem 0.5rem rgba(14, 52, 96, 0.36);
  }
}
.btn03:after {
  width: 2.4rem;
  height: 2.4rem;
  margin-top: -1.2rem;
  content: "";
  background-image: url("../img/icon_arrow02.png");
  background-size: cover;
  position: absolute;
  top: 50%;
  right: 2.4rem;
}
@media only screen and (max-width: 780px) {
  .btn03:after {
    width: 2rem;
    height: 2rem;
    margin-top: -1rem;
    right: 2rem;
  }
}
@media only screen and (min-width: 781px) {
  .btn03 {
    transition: background-position 0.3s;
  }
  .btn03:hover {
    background-position: 0 0;
  }
}
.btn04 {
  width: 34.4rem;
  padding: 1.5rem 4.8rem;
  font-size: 1.8rem;
  font-weight: 500;
  text-align: center;
  color: #000000 !important;
  background: linear-gradient(to right, #FFE201, #FFE201 50%, #ffffff 50%, #ffffff);
  background-size: 200% 100%;
  background-position: 100% 0;
  border-radius: 99px;
  box-shadow: 0.3rem 0.3rem 1rem rgba(14, 52, 96, 0.36);
  display: inline-block;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .btn04 {
    width: 29.4rem;
    padding: 1.4rem 4rem;
    font-size: 1.6rem;
    box-shadow: 0.15rem 0.15rem 0.5rem rgba(14, 52, 96, 0.36);
  }
}
.btn04:after {
  width: 2.4rem;
  height: 2.4rem;
  margin-top: -1.2rem;
  content: "";
  background-image: url("../img/icon_arrow02.png");
  background-size: cover;
  position: absolute;
  top: 50%;
  right: 2.4rem;
}
@media only screen and (max-width: 780px) {
  .btn04:after {
    width: 2rem;
    height: 2rem;
    margin-top: -1rem;
    right: 2rem;
  }
}
@media only screen and (min-width: 781px) {
  .btn04 {
    transition: background-position 0.3s;
  }
  .btn04:hover {
    background-position: 0 0;
  }
}

/*フェードイン*/
.fadeIn {
  visibility: hidden;
  animation: fadeIn 1s ease-out 0.3s both;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
/*ページネーション*/
.pagination {
  text-align: center;
  letter-spacing: -0.4em;
}
.pagination > * {
  display: inline-block;
  letter-spacing: normal;
}
.pagination > * {
  width: 4.3rem;
  height: 4.3rem;
  margin: 0 0.4rem;
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  line-height: 4.3rem;
  text-align: center;
  background-color: #ffffff;
  vertical-align: top;
}
@media only screen and (max-width: 780px) {
  .pagination > * {
    width: 3.6rem;
    height: 3.6rem;
    margin: 0.4rem !important;
    line-height: 3.6rem;
  }
}
.pagination .current {
  color: #ffffff;
  background-color: #0028AC;
}
.pagination .dots {
  line-height: 3rem;
}
.pagination .prev, .pagination .next {
  background-color: #E2EDF2;
  background-image: url("../img/icon_arrow04.png");
  background-size: 1rem auto;
  background-repeat: no-repeat;
  background-position: center center;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
}
@media only screen and (max-width: 780px) {
  .pagination .prev, .pagination .next {
    background-size: 0.8rem auto;
  }
}
.pagination .prev {
  margin-right: 2rem;
  transform: scaleX(-1);
}
.pagination .next {
  margin-left: 2rem;
}
.pagination a:hover {
  opacity: 0.6;
}

/*ページャー*/
.post-navigation {
  display: flex;
}
@media only screen and (min-width: 781px) {
  .post-navigation {
    justify-content: space-between;
    align-items: center;
  }
}
@media only screen and (max-width: 780px) {
  .post-navigation {
    flex-wrap: wrap;
  }
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-list {
    width: 100%;
    padding-top: 2rem;
    text-align: center;
    order: 3;
  }
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-previous, .post-navigation .nav-next {
    width: 50%;
  }
}
.post-navigation .nav-previous a, .post-navigation .nav-next a {
  font-family: "Montserrat", sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-previous a, .post-navigation .nav-next a {
    font-size: 1.3rem;
  }
}
.post-navigation .nav-previous a:before, .post-navigation .nav-previous a:after, .post-navigation .nav-next a:before, .post-navigation .nav-next a:after {
  width: 2.4rem;
  height: 2.4rem;
  background-color: #E2EDF2;
  background-image: url("../img/icon_arrow04.png");
  background-size: 1rem auto;
  background-repeat: no-repeat;
  background-position: center center;
  border-radius: 50%;
  display: inline-block;
  vertical-align: -0.35em;
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-previous a:before, .post-navigation .nav-previous a:after, .post-navigation .nav-next a:before, .post-navigation .nav-next a:after {
    width: 2rem;
    height: 2rem;
    background-size: 0.8rem auto;
  }
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-previous {
    order: 1;
  }
}
.post-navigation .nav-previous a:before {
  margin-right: 1rem;
  content: "";
  transform: scale(-1, 1);
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-next {
    text-align: right;
    order: 2;
  }
}
.post-navigation .nav-next a:after {
  margin-left: 1rem;
  content: "";
}

/* ブロックエディタ用基本CSS */
.editor-area:after {
  content: "";
  display: block;
  clear: both;
}
.editor-area > *:last-child {
  margin-bottom: 0 !important;
}
.editor-area p {
  margin-bottom: 3em;
  line-height: 2.15;
}
.editor-area h3 {
  margin-bottom: 1em;
  padding: 0.7em 0;
  border-top: solid 1px #A4B6DB;
  border-bottom: solid 1px #A4B6DB;
  font-size: 1.5em;
  font-weight: 500;
}
.editor-area h4 {
  margin-bottom: 1.1em;
  padding-left: 0.5em;
  font-size: 1.237em;
  font-weight: 500;
  border-left: solid 0.2rem #0028AC;
}
.editor-area h5 {
  margin-bottom: 1.38em;
  font-size: 1.125em;
  font-weight: 700;
}
.editor-area ul {
  margin-bottom: 3em;
}
.editor-area ul li {
  margin-bottom: 0.5em;
  padding-left: 3rem;
}
.editor-area ul li:before {
  width: 1.6rem;
  height: 1.6rem;
  margin: 0 1.4rem 0 -3rem;
  content: "";
  background-image: url("../img/news/check.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.1em;
}
.editor-area ol {
  margin-bottom: 3em;
  counter-reset: num;
}
.editor-area ol li {
  margin-bottom: 0.5em;
  padding-left: 3rem;
  counter-increment: num;
}
.editor-area ol li:before {
  width: 2rem;
  margin: 0 1rem 0 -3rem;
  font-family: "Montserrat", sans-serif;
  content: counter(num) ".";
  color: #0028AC;
  font-weight: 700;
  display: inline-block;
  vertical-align: 0;
}
.editor-area .wp-block-image {
  margin-bottom: 3em;
}
.editor-area .alignleft {
  max-width: 50%;
  float: left;
  margin-right: 1.5em;
  margin-bottom: 3em;
}
.editor-area .alignright {
  max-width: 50%;
  float: right;
  margin-left: 1.5em;
  margin-bottom: 3em;
}
.editor-area .aligncenter {
  margin-bottom: 3em;
}
.editor-area .aligncenter img {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.editor-area .has-text-align-center {
  text-align: center;
}
.editor-area .has-text-align-right {
  text-align: right;
}
.editor-area blockquote {
  margin-bottom: 2.5em;
  margin-left: 0;
  padding: 1.2em 1.2em 1.2em 6rem;
  background-color: #F0F0F0;
  border-left: 0.25em solid #0028AC;
  position: relative;
  display: block;
}
@media only screen and (max-width: 780px) {
  .editor-area blockquote {
    padding-left: 4rem;
  }
}
.editor-area blockquote:before {
  width: 4rem;
  height: 4rem;
  content: "";
  background-image: url("../img/news/innyou.png");
  background-size: 2.4rem auto;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (max-width: 780px) {
  .editor-area blockquote:before {
    width: 3rem;
    height: 3rem;
    background-size: 2rem;
  }
}
.editor-area blockquote > *:last-child {
  margin-bottom: 0 !important;
}
.editor-area table {
  width: 100%;
  margin-bottom: 3em;
  background-color: #ffffff;
  border-collapse: collapse;
}
.editor-area table td, .editor-area table th {
  border: 1px solid #C4C4C4;
  padding: 0.5em;
}
.editor-area table th {
  background-color: #E2EDF2;
}
.editor-area .wp-block-columns {
  display: flex;
  margin-bottom: 3em;
}
.editor-area .wp-block-column {
  flex-grow: 1;
  margin-left: 0.625em;
  margin-right: 0.625em;
}
.editor-area .wp-block-media-text {
  display: grid;
}
.editor-area a {
  color: blue;
  text-decoration: underline;
  word-break: break-all;
}
.editor-area strong, .editor-area b {
  font-weight: bold;
}
.editor-area em, .editor-area i {
  font-style: italic;
}
.editor-area .wp-block-spacer {
  clear: both;
}

/*フォームベース*/
.wpcf7-text, .input-text {
  width: 100%;
  padding: 1em;
  border: solid 1px #E2EDF2;
}
.wpcf7-text::-moz-placeholder, .input-text::-moz-placeholder {
  color: #747474;
}
.wpcf7-text::placeholder, .input-text::placeholder {
  color: #747474;
}

.wpcf7-textarea, .input-textarea {
  width: 100%;
  height: 16em;
  padding: 1em;
  border: solid 1px #E2EDF2;
}
@media only screen and (max-width: 780px) {
  .wpcf7-textarea, .input-textarea {
    height: 8em;
  }
}
.wpcf7-textarea::-moz-placeholder, .input-textarea::-moz-placeholder {
  color: #747474;
}
.wpcf7-textarea::placeholder, .input-textarea::placeholder {
  color: #747474;
}

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

.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 #585858;
  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: #0028AC;
  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 #585858;
  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 #0028AC;
  border-bottom: solid 0.2rem #0028AC;
  position: absolute;
  top: 0.4rem;
  left: 0.4rem;
  transform: rotate(-45deg);
}

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

@media only screen and (min-width: 901px) {
  body.home .container {
    padding-top: 0;
  }
}

/****************************************************
 * 4.テンプレートスタイル
 ****************************************************/
/*ヘッダーブロック*/
#header {
  width: 100%;
  height: 9.6rem;
  padding: 0 2.4rem;
  background-color: #ffffff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media only screen and (max-width: 900px) {
  #header {
    height: 7.4rem;
    padding: 0 1.2rem;
  }
  #header:after {
    width: 0;
    height: calc(100vh - 7.4rem);
    content: "";
    background-color: rgba(0, 0, 0, 0.85);
    position: absolute;
    top: 7.4rem;
    left: 0;
    z-index: -1;
    opacity: 0;
    transition: opacity 0.5s;
  }
}
#header .header_left {
  display: flex;
}
@media only screen and (min-width: 901px) {
  #header .header_left {
    align-items: center;
    flex-direction: row-reverse;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_left {
    flex-direction: column;
  }
}
#header .header_left .company_name a {
  font-size: 2.7rem;
  font-weight: 700;
  display: flex;
  align-items: center;
}
@media only screen and (max-width: 900px) {
  #header .header_left .company_name a {
    font-size: 2rem;
  }
}
#header .header_left .company_name a:before {
  width: 7rem;
  height: 7rem;
  margin-right: 0.6em;
  content: "";
  background-image: url("../img/logo.png");
  background-size: cover;
  display: block;
}
@media only screen and (max-width: 900px) {
  #header .header_left .company_name a:before {
    width: 4rem;
    height: 4rem;
  }
}
#header .header_left h1 {
  margin-left: 1.6em;
  font-size: 0.9375em;
  font-weight: 500;
}
@media only screen and (max-width: 1279px) and (min-width: 901px) {
  #header .header_left h1 {
    display: none;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_left h1 {
    margin: 0;
    font-size: 1.2rem;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .sp_menu_btn {
    width: 4.8rem;
    height: 4.8rem;
    background-image: url("../img/sp_menu_open.png");
    background-size: cover;
  }
}
@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: 34.6rem;
    height: calc(100vh - 7.4rem);
    background-color: #0028AC;
    overflow: auto;
    position: absolute;
    top: 100%;
    right: -34.6rem;
    z-index: 2;
    transition: right 0.5s;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi nav {
    margin-bottom: 3.7rem;
  }
}
#header .header_right .navi nav ul {
  font-weight: 500;
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi nav ul {
    font-size: 0.9375em;
    letter-spacing: -0.4em;
  }
  #header .header_right .navi nav ul > * {
    display: inline-block;
    letter-spacing: normal;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi nav ul {
    font-size: 1.13em;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi nav ul li {
    border-bottom: solid 1px #2C50C6;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi nav ul li + li {
    margin-left: 2.6em;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi nav ul li a {
    padding: 2rem 2.3rem;
    display: block;
    color: #ffffff !important;
    background-image: url("../img/icon_arrow03.png");
    background-size: 2.4rem auto;
    background-repeat: no-repeat;
    background-position: calc(100% - 2.4rem) center;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi nav ul li a:hover {
    color: #0028AC;
  }
}
@media only screen and (max-width: 780px) {
  #header .header_right .navi .tel {
    margin-bottom: 2rem;
    text-align: center;
  }
  #header .header_right .navi .tel .time {
    margin-top: 0.3em;
    font-size: 1.2rem;
    font-weight: 500;
    color: #ffffff;
    display: block;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .mail {
    margin-left: 3.5rem;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi .mail {
    text-align: center;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .mail .btn01 {
    width: 23.4rem;
    padding: 1.5rem 3.5rem 1.5rem 1.5rem;
    font-size: 1.5rem;
    box-shadow: none;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .navi .mail .btn01 {
    width: 29.4rem;
    border: solid 1px #ffffff;
    box-shadow: none;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right .navi .mail .btn01:after {
    width: 2rem;
    height: 2rem;
    margin-top: -1rem;
    right: 1.5rem;
  }
}
@media only screen and (max-width: 900px) {
  #header.menu_open:after {
    width: 100%;
    opacity: 1;
  }
  #header.menu_open .header_right .sp_menu_btn {
    background-image: url("../img/sp_menu_close.png");
  }
  #header.menu_open .header_right .navi {
    right: 0;
  }
}

@media only screen and (min-width: 901px) {
  body.home #header:not(.scroll) {
    background-color: transparent;
    position: absolute;
  }
  body.home #header:not(.scroll) .header_left .company_name a {
    color: #ffffff;
  }
  body.home #header:not(.scroll) .header_left .company_name a:before {
    background-image: url("../img/logo_white.png");
  }
  body.home #header:not(.scroll) .header_left h1 {
    color: #ffffff;
  }
  body.home #header:not(.scroll) .header_right .navi nav ul li a {
    color: #ffffff;
  }
  body.home #header:not(.scroll) .header_right .navi nav ul li a:hover {
    color: #FFE201;
  }
}

/*フッターブロック*/
#footer {
  margin-top: 18.2rem;
  padding-top: 6.4rem;
  color: #ffffff;
  background-color: #353837;
}
@media only screen and (max-width: 900px) {
  #footer {
    margin-top: 0;
    padding-top: 4rem;
  }
}
#footer .pagetop {
  width: 6.4rem;
  display: none;
  position: fixed;
  bottom: 0;
  right: 0;
  z-index: 90;
}
@media only screen and (min-width: 901px) {
  #footer .inner {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
  }
}
#footer .footer_navi {
  display: flex;
  justify-content: space-between;
}
@media only screen and (min-width: 901px) {
  #footer .footer_navi {
    width: 50%;
  }
}
@media only screen and (max-width: 900px) {
  #footer .footer_navi {
    padding-bottom: 0.8rem;
    flex-wrap: wrap;
  }
}
@media only screen and (max-width: 900px) {
  #footer .footer_navi dl {
    width: 50%;
    margin-bottom: 4rem;
  }
}
#footer .footer_navi dl dt {
  margin-bottom: 1.38em;
  font-family: "Montserrat", sans-serif;
  font-size: 1.8rem;
  font-weight: 600;
}
@media only screen and (max-width: 900px) {
  #footer .footer_navi dl dt {
    margin-bottom: 0.65em;
    font-size: 2.1rem;
  }
}
#footer .footer_navi dl dd {
  font-weight: 500;
  letter-spacing: 0.04em;
}
#footer .footer_navi dl dd + dd {
  margin-top: 1em;
}
#footer .footer_navi dl dd a {
  color: #ffffff;
}
@media only screen and (min-width: 901px) {
  #footer .footer_navi dl dd a:hover {
    color: #FFE201;
  }
}
#footer .footer_contents .site_name {
  margin-bottom: 2rem;
}
@media only screen and (max-width: 900px) {
  #footer .footer_contents .site_name {
    margin-bottom: 1.2rem;
    text-align: center;
  }
}
#footer .footer_contents .site_name p {
  margin-bottom: 0.6em;
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0.04em;
}
#footer .footer_contents .site_name .company_name {
  font-size: 2.7rem;
  font-weight: 700;
  display: flex;
  align-items: center;
}
@media only screen and (max-width: 900px) {
  #footer .footer_contents .site_name .company_name {
    font-size: 2rem;
    justify-content: center;
  }
}
#footer .footer_contents .site_name .company_name:before {
  width: 7rem;
  height: 7rem;
  margin-right: 0.6em;
  content: "";
  background-image: url("../img/logo.png");
  background-size: cover;
  display: block;
}
@media only screen and (max-width: 900px) {
  #footer .footer_contents .site_name .company_name:before {
    width: 4rem;
    height: 4rem;
  }
}
#footer .footer_contents .address dt {
  margin-bottom: 0.25em;
  font-weight: 700;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 900px) {
  #footer .footer_contents .address dt {
    font-size: 1.3rem;
    text-align: center;
  }
}
#footer .footer_contents .address dd {
  font-size: 0.875em;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 900px) {
  #footer .footer_contents .address dd {
    font-size: 1.3rem;
    text-align: center;
  }
}
#footer .footer_contents .address dd a {
  color: #ffffff;
}
#footer .copyright {
  margin-top: 4.8rem;
  padding: 1.33em 0;
  font-size: 1.2rem;
  text-align: center;
  background-color: #282B29;
}
@media only screen and (max-width: 900px) {
  #footer .copyright {
    margin-top: 4rem;
  }
}

/*CTAブロック*/
.cta_block {
  max-width: 1600px;
  margin: 0 auto;
  padding-bottom: 6rem;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .cta_block {
    padding-bottom: 2.8rem;
  }
}
.cta_block:after {
  width: 100%;
  content: "";
  background-size: cover;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}
@media only screen and (min-width: 781px) {
  .cta_block:after {
    height: 33.6rem;
    background-image: url("../img/cta_bg.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .cta_block:after {
    height: 33.3rem;
    background-image: url("../img/cta_bg_sp.jpg");
  }
}
.cta_block .inner {
  max-width: 1080px;
  padding: 5.6rem 0;
  background-color: #ffffff;
  box-shadow: 0 0 3rem rgba(0, 0, 0, 0.1);
}
@media only screen and (max-width: 780px) {
  .cta_block .inner {
    padding: 3.2rem 0 4rem 0;
  }
}
.cta_block .midashi01 + p {
  margin-bottom: 1.5em;
  font-size: 2.2rem;
  font-weight: 700;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .cta_block .midashi01 + p {
    margin-bottom: 2em;
    font-size: 1.6rem;
  }
}
@media only screen and (min-width: 781px) {
  .cta_block ul {
    padding: 0 6.5rem;
    display: flex;
    align-items: center;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1099px) {
  .cta_block ul {
    padding: 0 3rem;
  }
}
.cta_block ul li {
  text-align: center;
}
@media only screen and (min-width: 781px) {
  .cta_block ul li {
    width: 50%;
  }
}
@media only screen and (min-width: 781px) {
  .cta_block ul li.tel {
    border-right: solid 1px #D1D1D1;
  }
}
@media only screen and (min-width: 781px) {
  .cta_block ul li.tel .num {
    font-family: "Montserrat", sans-serif;
    font-size: 2.1rem;
    font-weight: 600;
  }
  .cta_block ul li.tel .num span {
    margin-left: 0.25em;
    font-size: 2em;
    display: inline-block;
    vertical-align: -0.15em;
  }
}
.cta_block ul li.tel .time {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #7B7B7B;
  display: block;
}
@media only screen and (max-width: 780px) {
  .cta_block ul li.tel .time {
    margin-top: 0.5em;
    font-size: 1.2rem;
  }
}
@media only screen and (max-width: 780px) {
  .cta_block ul li.mail {
    margin-top: 2rem;
  }
}

/****************************************************
 * 5.コンテンツスタイル
 ****************************************************/
/*TOPページ*/
.p-top__mv {
  background-size: cover;
  background-position: center center;
  position: relative;
  z-index: 1;
}
@media only screen and (min-width: 781px) {
  .p-top__mv {
    margin-bottom: 14.4rem;
    padding-top: 16rem;
    background-image: url("../img/top/mv_bg.jpg");
  }
}
@media only screen and (min-width: 781px) and (max-width: 1599px) {
  .p-top__mv {
    padding-top: 10vw;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv {
    margin-bottom: 14.5rem;
    padding-top: 4rem;
    background-image: url("../img/top/mv_bg_sp.jpg");
  }
}
.p-top__mv .inner {
  max-width: 1600px;
}
@media only screen and (min-width: 781px) {
  .p-top__mv .inner {
    display: flex;
    align-items: flex-end;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .inner {
    width: 94%;
  }
}
.p-top__mv .text_area {
  text-align: center;
}
@media only screen and (min-width: 781px) {
  .p-top__mv .text_area {
    width: 66%;
  }
}
.p-top__mv .text_area h2 {
  font-weight: 700;
  line-height: 1.15;
  color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-top__mv .text_area h2 {
    font-size: 5.2rem;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1599px) {
  .p-top__mv .text_area h2 {
    font-size: 3.25vw;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .text_area h2 {
    font-size: 2.6rem;
  }
}
.p-top__mv .text_area h3 {
  margin-bottom: 0.2em;
  font-weight: 700;
  color: #EFEFC8;
}
@media only screen and (min-width: 781px) {
  .p-top__mv .text_area h3 {
    font-size: 5.2rem;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1599px) {
  .p-top__mv .text_area h3 {
    font-size: 3.25vw;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .text_area h3 {
    font-size: 3.2rem;
  }
}
.p-top__mv .text_area h3 span {
  font-size: 1.6em;
}
.p-top__mv .text_area p {
  margin-bottom: 1.17em;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-top__mv .text_area p {
    font-size: 2.8rem;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1599px) {
  .p-top__mv .text_area p {
    font-size: 1.75vw;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .text_area p {
    font-size: 1.9rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__mv .text_area ul {
    display: flex;
    justify-content: space-between;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .text_area ul {
    width: 100%;
    height: auto;
    margin-bottom: 2.5rem;
    aspect-ratio: 696/360;
    background-image: url("../img/top/mv_text_sp.png");
    background-size: cover;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__mv .text_area ul li:nth-child(1) {
    width: 34%;
  }
  .p-top__mv .text_area ul li:nth-child(2) {
    width: 27.5%;
  }
  .p-top__mv .text_area ul li:nth-child(3) {
    width: 32.6%;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__mv .img {
    width: 29%;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .img {
    width: 113.6%;
    margin: 0 -6.8%;
  }
}
.p-top__mv .contact_area {
  color: #ffffff;
  background: linear-gradient(to right, #0086D9, #0028AC);
}
@media only screen and (min-width: 781px) {
  .p-top__mv .contact_area {
    width: 90%;
    max-width: 1000px;
    margin: 5rem auto 0 auto;
    padding: 3.5rem 8.8rem;
    display: flex;
    align-items: center;
    transform: translateY(30%);
  }
}
@media only screen and (min-width: 781px) and (max-width: 1099px) {
  .p-top__mv .contact_area {
    margin-top: 3.5rem;
    padding: 3.5rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .contact_area {
    width: 93.8%;
    padding: 1.5rem 4rem;
    text-align: center;
    position: absolute;
    left: 3.1%;
    bottom: -10.5rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__mv .contact_area .text {
    width: 48.5%;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .contact_area .text {
    margin-bottom: 1.2rem;
  }
}
.p-top__mv .contact_area .text h4 {
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}
@media only screen and (max-width: 780px) {
  .p-top__mv .contact_area .text h4 {
    font-size: 1.8rem;
  }
}
.p-top__mv .contact_area .text p {
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 780px) {
  .p-top__mv .contact_area .text p {
    font-size: 1.3rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__mv .contact_area .btn {
    width: 51.5%;
  }
}
.p-top__mv .contact_area .btn .btn04 {
  width: 100%;
}
.p-top__nayami {
  margin-bottom: 7.3rem;
}
@media only screen and (max-width: 780px) {
  .p-top__nayami {
    margin-bottom: 4rem;
  }
}
.p-top__nayami .inner {
  position: relative;
}
@media only screen and (max-width: 900px) {
  .p-top__nayami .midashi01 {
    margin-bottom: 0.8em;
  }
}
.p-top__nayami .midashi01 i {
  font-style: normal;
  color: #0028AC;
}
@media only screen and (min-width: 901px) {
  .p-top__nayami .img {
    width: 46.7rem;
    position: absolute;
    top: 2.5rem;
    left: 72.5rem;
  }
}
@media only screen and (max-width: 900px) {
  .p-top__nayami .img {
    margin-bottom: 2.8rem;
    text-align: center;
  }
}
@media only screen and (min-width: 901px) {
  .p-top__nayami ul {
    width: 67.7rem;
  }
}
.p-top__nayami ul li {
  padding: 0.65em 0.65em 0.65em 2.8em;
  font-size: 2rem;
  font-weight: 700;
  background-color: #ffffff;
  background-image: url("../img/icon_check01.png");
  background-repeat: no-repeat;
  background-size: 2.4rem auto;
  background-position: 1.6rem 0.85em;
  border: solid 1px #EAEAEA;
  border-radius: 0.4rem;
}
@media only screen and (max-width: 900px) {
  .p-top__nayami ul li {
    padding: 0.7em 1em 0.7em 2.45em;
    font-size: 1.7rem;
    background-size: 1.6rem auto;
    background-position: 1.2rem 1em;
  }
}
.p-top__nayami ul li span {
  color: #0028AC;
  background-color: #FFE201;
}
.p-top__nayami ul li + li {
  margin-top: 0.8rem;
}
.p-top__nayami .bottom_text {
  margin-top: 5.6rem;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-top__nayami .bottom_text {
    margin-top: 2.4rem;
  }
}
.p-top__nayami .bottom_text p {
  font-size: 3rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-top__nayami .bottom_text p {
    font-size: 2.2rem;
  }
}
.p-top__nayami .bottom_text p strong {
  font-weight: 700;
  color: #0028AC;
}
.p-top__riyuu {
  padding: 8rem 0 11rem 0;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-top__riyuu {
    padding: 4.4rem 0 6.4rem 0;
  }
}
.p-top__riyuu:before {
  width: 1720px;
  height: 100%;
  content: "";
  background-color: #E2EDF2;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.p-top__riyuu .midashi01 {
  margin-bottom: 1.1em;
}
@media only screen and (max-width: 780px) {
  .p-top__riyuu .midashi01 {
    margin-bottom: 0.85em;
  }
}
.p-top__riyuu .midashi01 .ja span {
  padding: 0.2em 0.5em 0.2em 0;
  display: inline-block;
  position: relative;
}
.p-top__riyuu .midashi01 .ja span:after {
  width: 16rem;
  height: 1px;
  content: "";
  background-color: #A4B6DB;
  position: absolute;
  top: 51%;
  left: 100%;
}
@media only screen and (max-width: 780px) {
  .p-top__riyuu .midashi01 .ja span:after {
    width: 8.8rem;
  }
}
.p-top__riyuu .midashi01 .ja strong {
  margin-right: 0.25em;
  padding: 0 0.25em;
  font-weight: 700;
  color: #ffffff;
  background-color: #0028AC;
  display: inline-block;
}
@media only screen and (min-width: 781px) {
  .p-top__riyuu ol {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}
.p-top__riyuu ol li {
  background-color: #ffffff;
  position: relative;
  box-shadow: 1rem 1rem 3rem rgba(129, 182, 213, 0.1);
}
@media only screen and (min-width: 781px) {
  .p-top__riyuu ol li {
    width: 48.3%;
    margin-bottom: 3.2rem;
    padding: 1.6rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__riyuu ol li {
    margin-bottom: 1.2rem;
    padding: 0.8rem;
  }
}
.p-top__riyuu ol li .num {
  width: 4.8rem;
  height: 4.8rem;
  font-family: "Montserrat", sans-serif;
  font-size: 2.6rem;
  font-weight: 700;
  text-align: center;
  line-height: 4.8rem;
  color: #ffffff;
  background-color: #0028AC;
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (max-width: 780px) {
  .p-top__riyuu ol li .num {
    width: 4rem;
    height: 4rem;
    font-size: 2rem;
    line-height: 4rem;
  }
}
.p-top__riyuu ol li .img {
  margin-bottom: 1.6rem;
}
@media only screen and (min-width: 781px) {
  .p-top__riyuu ol li .text {
    padding: 0 0.8rem;
  }
}
.p-top__riyuu ol li .text h3 {
  margin-bottom: 0.4em;
  font-size: 2.2rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
  color: #0028AC;
}
@media only screen and (max-width: 780px) {
  .p-top__riyuu ol li .text h3 {
    font-size: 1.7rem;
  }
}
.p-top__riyuu ol li .text p {
  font-size: 1.8rem;
  letter-spacing: 0.04em;
  color: #585858;
}
@media only screen and (max-width: 780px) {
  .p-top__riyuu ol li .text p {
    font-size: 1.6rem;
  }
}
.p-top__choose {
  margin-bottom: 10.4rem;
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 780px) {
  .p-top__choose {
    margin-bottom: 5rem;
  }
}
.p-top__choose h2 {
  margin-bottom: 0.75em;
  font-size: 2.6rem;
  font-weight: 700;
  text-align: center;
  transform: translateY(-50%);
}
@media only screen and (max-width: 780px) {
  .p-top__choose h2 {
    font-size: 2rem;
  }
}
.p-top__choose h2 span {
  width: 70rem;
  max-width: 100%;
  padding: 0.6em 0 0.65em 0;
  color: #ffffff;
  background: linear-gradient(to right, #0086D9, #0028AC);
  border-radius: 0.8rem;
  display: inline-block;
  position: relative;
}
.p-top__choose h2 span:after {
  width: 2.6rem;
  height: 2.2rem;
  margin-left: -1.3rem;
  content: "";
  background-image: url("../img/top/choose_sankaku.png");
  background-size: cover;
  position: absolute;
  top: 100%;
  left: 50%;
}
@media only screen and (max-width: 780px) {
  .p-top__choose h2 span:after {
    width: 1.3rem;
    height: 1.1rem;
    margin-left: -0.65rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__choose ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}
.p-top__choose ul li {
  background-color: #ffffff;
  box-shadow: 0.6rem 0.6rem 2rem rgba(118, 142, 155, 0.2);
  display: flex;
  align-items: center;
  position: relative;
}
.p-top__choose ul li:before {
  content: "";
  background-image: url("../img/icon_check02.png");
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (min-width: 781px) {
  .p-top__choose ul li {
    width: 49%;
    margin-bottom: 2.4rem;
    padding: 1.6rem;
  }
  .p-top__choose ul li:before {
    width: 4rem;
    height: 4rem;
    margin: -1.6rem 0 0 -1.6rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__choose ul li {
    margin-bottom: 1.2rem;
    padding: 0.8rem 1.2rem 0.8rem 0.8rem;
  }
  .p-top__choose ul li:before {
    width: 2.4rem;
    height: 2.4rem;
    margin: -1rem 0 0 -1rem;
  }
}
.p-top__choose ul li .img {
  width: 12rem;
  margin-right: 2.4rem;
}
@media only screen and (max-width: 780px) {
  .p-top__choose ul li .img {
    width: 7.3rem;
    margin-right: 1.2rem;
  }
}
.p-top__choose ul li p {
  width: calc(100% - 14.4rem);
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.38;
}
@media only screen and (max-width: 780px) {
  .p-top__choose ul li p {
    width: calc(100% - 8.5rem);
    font-size: 1.6rem;
  }
}
.p-top__detail_headding {
  color: #ffffff;
  background-color: #0028AC;
  position: relative;
}
.p-top__detail_headding:after {
  content: "";
  background-image: url("../img/top/service_ttl_sankaku.png");
  background-size: cover;
  position: absolute;
  top: 100%;
  left: 50%;
}
@media only screen and (min-width: 781px) {
  .p-top__detail_headding {
    margin-top: 12.8rem;
    background-image: url("../img/top/service_ttl_bg.jpg");
    background-size: cover;
    background-position: center center;
  }
  .p-top__detail_headding:after {
    width: 5.2rem;
    height: 4.5rem;
    margin-left: -2.6rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__detail_headding {
    margin-top: 4.4rem;
  }
  .p-top__detail_headding:after {
    width: 2.6rem;
    height: 2.3rem;
    margin-left: -1.3rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__detail_headding .inner {
    max-width: 1000px;
    padding: 8.8rem 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__detail_headding .inner {
    width: 94%;
    padding: 2.8rem 0;
  }
}
.p-top__detail_headding .midashi01 {
  white-space: nowrap;
}
.p-top__detail_headding .midashi01 i {
  margin-left: 0.1em;
  padding: 0 0.2em;
  font-style: normal;
  color: #0028AC;
  background-color: #ffffff;
  display: inline-block;
}
.p-top__detail_headding p {
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 780px) {
  .p-top__detail_headding p {
    font-size: 1.6rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__detail_headding .img {
    width: 100%;
    height: 15.9rem;
    overflow: hidden;
  }
  .p-top__detail_headding .img > img,
  .p-top__detail_headding .img > video {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
}
.p-top__point {
  margin-bottom: 8rem;
  padding-top: 10rem;
  padding-bottom: 8rem;
  background-color: #E2EDF2;
}
@media only screen and (max-width: 780px) {
  .p-top__point {
    margin-bottom: 3.6rem;
    padding-top: 4.2rem;
    padding-bottom: 4.4rem;
  }
}
.p-top__point .inner {
  max-width: 1080px;
}
.p-top__point .midashi01 {
  margin-bottom: 1.6em;
}
.p-top__point ol li {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-top__point ol li {
    padding: 4rem;
    display: flex;
    justify-content: space-between;
  }
  .p-top__point ol li:nth-child(2n) {
    flex-direction: row-reverse;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__point ol li {
    width: 113.6%;
    margin: 0 -6.8%;
    padding: 6.5rem 1.2rem 2rem 1.2rem;
    position: relative;
  }
}
.p-top__point ol li + li {
  margin-top: 2.4rem;
}
@media only screen and (max-width: 780px) {
  .p-top__point ol li + li {
    margin-top: 0.8rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__point ol li .img {
    width: 35.5%;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__point ol li .img {
    margin-bottom: 1.6rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__point ol li .text {
    width: 58.9%;
  }
}
.p-top__point ol li .text .num {
  width: 37.3%;
}
@media only screen and (max-width: 780px) {
  .p-top__point ol li .text .num {
    width: 10.8rem;
    margin-left: -5.4rem;
    position: absolute;
    top: 1.2rem;
    left: 50%;
  }
}
.p-top__point ol li .text h3 {
  margin: 0.6em 0;
  font-size: 2.8rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-top__point ol li .text h3 {
    margin: 0 0 0.65em 0;
    font-size: 1.9rem;
    text-align: center;
  }
}
.p-top__point ol li .text p {
  font-size: 1.8rem;
  color: #585858;
}
@media only screen and (max-width: 780px) {
  .p-top__point ol li .text p {
    padding: 0 1.2rem;
    font-size: 1.5rem;
  }
}
.p-top__spec {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 780px) {
  .p-top__spec {
    margin-bottom: 3.8rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__spec .inner {
    max-width: 1000px;
  }
  .p-top__spec .inner:after {
    content: "";
    display: block;
    clear: both;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__spec .midashi01 {
    margin-bottom: 0.85em;
  }
}
.p-top__spec dl dt {
  margin-bottom: 1.45em;
  padding-bottom: 0.77em;
  font-size: 2.2rem;
  font-weight: 700;
  border-bottom: solid 1px #C4CAD9;
  position: relative;
}
.p-top__spec dl dt:after {
  width: 5em;
  height: 0.2rem;
  content: "";
  background-color: #0028AC;
  position: absolute;
  bottom: -1px;
  left: 0;
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl dt {
    font-size: 1.7rem;
  }
}
.p-top__spec dl dd ul {
  margin-bottom: -1em;
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl dd ul {
    font-size: 1.8rem;
  }
}
.p-top__spec dl dd ul li {
  margin-bottom: 1em;
  padding-left: 2em;
  font-weight: 500;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl dd ul li {
    padding-left: 1.5em;
  }
}
.p-top__spec dl dd ul li:before {
  width: 1em;
  height: 1em;
  content: "";
  background-color: #0028AC;
  border-radius: 50%;
  position: absolute;
  top: 0.25em;
  left: 0;
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl dd ul li:before {
    width: 0.8em;
    height: 0.8em;
    top: 0.35em;
  }
}
.p-top__spec dl dd table {
  width: 100%;
  margin-bottom: 1.5rem;
}
.p-top__spec dl dd table th {
  width: 23%;
  padding-bottom: 1rem;
  font-size: 1.8rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl dd table th {
    font-size: 1.9rem;
  }
}
.p-top__spec dl dd table td {
  padding-bottom: 1rem;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl dd table td {
    font-size: 1.8rem;
  }
}
.p-top__spec dl dd .box {
  margin-bottom: 0.5em;
  padding: 1em;
  font-weight: 500;
  text-align: center;
  color: #0028AC;
  background-color: #ffffff;
  border: solid 1px #D3E1E8;
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl dd .box {
    font-size: 1.8rem;
    text-align: left;
  }
}
.p-top__spec dl dd .annotation {
  font-size: 1.2rem;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl dd .annotation {
    font-size: 1.4rem;
  }
}
.p-top__spec dl.spec01 {
  margin-bottom: 5.6rem;
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl.spec01 {
    margin-bottom: 2.9rem;
  }
}
.p-top__spec dl.spec01 dd ul {
  display: grid;
  grid-template-columns: auto;
  grid-template-rows: repeat(4, auto);
  grid-auto-flow: column;
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl.spec01 dd ul {
    grid-template-rows: repeat(8, auto);
  }
}
@media only screen and (min-width: 781px) {
  .p-top__spec dl.spec02 {
    width: 47.2%;
    float: left;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl.spec02 {
    margin-bottom: 2.9rem;
  }
}
.p-top__spec dl.spec02 dd ul {
  display: grid;
  grid-template-columns: auto;
  grid-template-rows: repeat(4, auto);
  grid-auto-flow: column;
}
@media only screen and (max-width: 780px) {
  .p-top__spec dl.spec02 dd ul {
    grid-template-rows: repeat(8, auto);
  }
}
@media only screen and (min-width: 781px) {
  .p-top__spec dl.spec03 {
    width: 47.2%;
    float: right;
  }
}
.p-top__price {
  margin-bottom: 9.6rem;
}
@media only screen and (max-width: 780px) {
  .p-top__price {
    margin-bottom: 5.6rem;
  }
}
.p-top__price .inner {
  max-width: 1160px;
}
.p-top__price .headding {
  margin-bottom: 4rem;
  padding: 1em 0;
  color: #ffffff;
  background: linear-gradient(to right, #0086D9, #0028AC);
}
@media only screen and (max-width: 780px) {
  .p-top__price .headding {
    margin-bottom: 0;
    padding: 0.63em 0;
  }
}
.p-top__price .headding h2 {
  font-size: 3rem;
  font-weight: 700;
  text-align: center;
}
@media only screen and (min-width: 781px) {
  .p-top__price .headding h2 {
    max-width: 90%;
    margin: 0 auto;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__price .headding h2 {
    font-size: 1.9rem;
    white-space: nowrap;
  }
}
.p-top__price .headding h2 span {
  color: #FFE201;
}
.p-top__price .headding h2 small {
  font-size: 0.73em;
}
.p-top__price .box {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-top__price .box {
    margin-bottom: 4rem;
    padding: 4rem;
    display: flex;
    justify-content: space-between;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__price .box {
    width: 113.6%;
    margin: 0 -6.8% 2rem -6.8%;
    padding: 2.4rem 2.4rem 3.6rem 2.4rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__price .box dl {
    width: 48.8%;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__price .box dl:nth-child(1) {
    margin-bottom: 2rem;
  }
}
.p-top__price .box dl:nth-child(1) dt {
  background-color: #0092C7;
}
.p-top__price .box dl:nth-child(2) dt {
  background-color: #0028AC;
}
.p-top__price .box dl dt {
  padding: 0.6em;
  font-size: 2.6rem;
  font-weight: 700;
  text-align: center;
  color: #ffffff;
}
@media only screen and (max-width: 780px) {
  .p-top__price .box dl dt {
    padding: 0.4em;
    font-size: 2rem;
  }
}
.p-top__price .box dl dd {
  padding: 1em 1.5em;
  font-weight: 500;
  background-color: #F0F0F0;
}
@media only screen and (max-width: 780px) {
  .p-top__price .box dl dd {
    padding: 0.5em 0.8em;
  }
}
.p-top__price .box dl dd:nth-of-type(2n) {
  background-color: #FAFAFA;
}
.p-top__price .bottomtext {
  margin-bottom: 5rem;
  font-size: 3rem;
  font-weight: 700;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-top__price .bottomtext {
    margin-bottom: 3rem;
    font-size: 2rem;
    line-height: 1.225;
  }
}
.p-top__price .bottomtext span {
  color: #0028AC;
}
.p-top__price .btn {
  text-align: center;
}
.p-top__price .btn a {
  width: 55.4rem;
  padding: 2.4rem 0;
  font-size: 2.2rem;
  font-weight: 500;
  text-align: center;
  color: #ffffff !important;
  background: linear-gradient(to right, #0086D9, #0086D9 50%, #0028AC);
  background-size: 200% 100%;
  background-position: 100% 0;
  border-radius: 99px;
  box-shadow: 0.3rem 0.3rem 1rem rgba(14, 52, 96, 0.36);
  display: inline-block;
}
@media only screen and (max-width: 780px) {
  .p-top__price .btn a {
    width: 34.2rem;
    max-width: 100%;
    padding: 1.8rem 0;
    font-size: 1.6rem;
    box-shadow: 0.15rem 0.15rem 0.5rem rgba(14, 52, 96, 0.36);
    position: relative;
  }
}
.p-top__price .btn a:after {
  width: 2.4rem;
  height: 2.4rem;
  margin-left: 0.5em;
  content: "";
  background-image: url("../img/icon_arrow01.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.15em;
}
@media only screen and (max-width: 780px) {
  .p-top__price .btn a:after {
    width: 2rem;
    height: 2rem;
    margin: -1rem 0 0 0;
    position: absolute;
    top: 50%;
    right: 2rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__price .btn a {
    transition: background-position 0.3s;
  }
  .p-top__price .btn a:hover {
    background-position: 0 0;
  }
}
.p-top__price .btn a span {
  padding-left: 5rem;
  display: inline-block;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .p-top__price .btn a span {
    padding-left: 3rem;
  }
}
.p-top__price .btn a span:before {
  width: 8.7rem;
  height: 9.7rem;
  content: "";
  background-image: url("../img/top/btn_img01.png");
  background-size: cover;
  position: absolute;
  bottom: -2.4rem;
  left: -5rem;
}
@media only screen and (max-width: 780px) {
  .p-top__price .btn a span:before {
    width: 6.5rem;
    height: 7.3rem;
    bottom: -1.8rem;
    left: -4rem;
  }
}
.p-top__flow {
  background-size: cover;
  background-position: center center;
}
@media only screen and (min-width: 781px) {
  .p-top__flow {
    padding: 8.8rem 0;
    background-image: url("../img/top/flow_bg.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow {
    padding: 4rem 0;
    background-image: url("../img/top/flow_bg_sp.jpg");
  }
}
@media only screen and (min-width: 781px) {
  .p-top__flow .midashi01 {
    margin-bottom: 1.16em;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .midashi01 {
    margin-bottom: 0.85em;
  }
}
.p-top__flow .box {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-top__flow .box {
    display: flex;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .box {
    width: 113.6%;
    margin: 0 -6.8%;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__flow .headding {
    width: 28.25%;
    padding: 7.2rem 5.2rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .headding {
    padding: 2.4rem;
  }
}
.p-top__flow .headding ol {
  counter-reset: num;
}
@media only screen and (max-width: 780px) {
  .p-top__flow .headding ol {
    display: flex;
    flex-wrap: wrap;
  }
}
.p-top__flow .headding ol li {
  font-weight: 700;
  counter-increment: num;
  position: relative;
}
@media only screen and (min-width: 781px) {
  .p-top__flow .headding ol li {
    margin-bottom: 4.7rem;
    padding-left: 4.4rem;
    font-size: 2rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .headding ol li {
    width: 33.333%;
    padding: 1rem;
    text-align: center;
  }
}
.p-top__flow .headding ol li:before {
  content: counter(num);
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  color: #0028AC;
}
@media only screen and (min-width: 781px) {
  .p-top__flow .headding ol li:before {
    width: 4.4rem;
    margin-left: -4.4rem;
    font-size: 2.6rem;
    display: inline-block;
    vertical-align: -0.05em;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .headding ol li:before {
    font-size: 2.1rem;
    text-align: center;
    display: block;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__flow .headding ol li:after {
    width: 1px;
    height: 2.6rem;
    content: "";
    background-color: #C4C4C4;
    position: absolute;
    top: calc(100% + 1rem);
    left: 0.5rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .headding ol li:after {
    width: 1px;
    height: 88%;
    content: "";
    background-color: #CCCCCC;
    position: absolute;
    top: 6%;
    right: 0;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__flow .headding ol li:last-child:after {
    content: none;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .headding ol li:nth-child(-n+3) {
    border-bottom: solid 1px #CCCCCC;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .headding ol li:nth-child(3n):after {
    content: none;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__flow .content {
    width: 71.75%;
    padding: 6.4rem 5.6rem;
    border-left: solid 1px #DEDEDE;
  }
}
.p-top__flow .content ol {
  counter-reset: num;
}
.p-top__flow .content ol li {
  counter-increment: num;
  background-color: #F7F9FA;
}
@media only screen and (min-width: 781px) {
  .p-top__flow .content ol li {
    padding: 3.2rem;
    border-radius: 0.8rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .content ol li {
    padding: 2.4rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__flow .content ol li + li {
    margin-top: 1.7rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .content ol li + li {
    margin-top: 0.9rem;
  }
}
.p-top__flow .content ol li h3 {
  font-weight: 700;
}
@media only screen and (min-width: 781px) {
  .p-top__flow .content ol li h3 {
    margin-bottom: 1em;
    padding-left: 7.2rem;
    font-size: 2.4rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .content ol li h3 {
    margin-bottom: 0.75em;
    padding-left: 4.4rem;
    font-size: 1.8rem;
  }
}
.p-top__flow .content ol li h3:before {
  content: counter(num);
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  text-align: center;
  color: #ffffff;
  background-color: #0028AC;
  display: inline-block;
  vertical-align: 0.05em;
}
@media only screen and (min-width: 781px) {
  .p-top__flow .content ol li h3:before {
    width: 4.8rem;
    height: 4.8rem;
    margin: 0 2.4rem 0 -7.2rem;
    font-size: 2.6rem;
    line-height: 4.8rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .content ol li h3:before {
    width: 3.2rem;
    height: 3.2rem;
    margin: 0 1.2rem 0 -4.4rem;
    font-size: 1.7rem;
    line-height: 3.2rem;
  }
}
.p-top__flow .content ol li p {
  font-weight: 500;
  color: #585858;
}
@media only screen and (min-width: 781px) {
  .p-top__flow .content ol li p {
    font-size: 1.5rem;
    line-height: 1.86;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__flow .content ol li p {
    font-size: 1.4rem;
  }
}
.p-top__column {
  margin-bottom: 8rem;
  padding: 7.2rem 0 8rem 0;
  background-color: #E2EDF2;
}
@media only screen and (max-width: 780px) {
  .p-top__column {
    margin-bottom: 3.6rem;
    padding: 4rem 0;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__column .midashi01 {
    margin-bottom: 0.95em;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__column .midashi01 {
    margin-bottom: 0.85em;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__column .sp_scroll {
    width: 106.8%;
    margin-bottom: 2.5rem;
    margin-right: -6.8rem;
    padding-bottom: 2rem;
    overflow-x: auto;
  }
}
.p-top__column ul {
  display: flex;
}
@media only screen and (min-width: 781px) {
  .p-top__column ul {
    margin-bottom: 4.8rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__column ul {
    gap: 2rem;
  }
}
.p-top__column ul li {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-top__column ul li {
    width: 30.6%;
    margin-right: 4.1%;
  }
  .p-top__column ul li:last-child {
    margin-right: 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__column ul li {
    flex: 0 0 29.6rem;
  }
}
.p-top__column ul li a {
  display: block;
}
@media only screen and (min-width: 781px) {
  .p-top__column ul li a .img img {
    transition: filter 0.3s;
  }
  .p-top__column ul li a:hover .img img {
    filter: brightness(120%);
  }
}
.p-top__column ul li .img {
  width: 100%;
  height: 20rem;
  overflow: hidden;
}
.p-top__column ul li .img > img,
.p-top__column ul li .img > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (max-width: 780px) {
  .p-top__column ul li .img {
    height: 16rem;
  }
}
.p-top__column ul li p {
  padding: 1.6rem;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.27;
}
@media only screen and (max-width: 780px) {
  .p-top__column ul li p {
    padding: 1.2rem;
    font-size: 1.6rem;
  }
}
.p-top__column ul li .cate {
  padding: 0 1.6rem 1.6rem 1.6rem;
  display: block;
  letter-spacing: -0.4em;
}
.p-top__column ul li .cate > * {
  display: inline-block;
  letter-spacing: normal;
}
@media only screen and (max-width: 780px) {
  .p-top__column ul li .cate {
    padding: 0 1.2rem 1.2rem 1.2rem;
  }
}
.p-top__column ul li .cate span {
  margin-right: 0.8rem;
  padding: 0.1em 0.5em;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: #747474;
  border: solid 1px #C9C9C9;
}
.p-top__column .btn {
  text-align: center;
}
.p-top__achievements {
  margin-bottom: 9.5rem;
  padding-bottom: 4.8rem;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements {
    margin-bottom: 4rem;
    padding-bottom: 5rem;
  }
}
.p-top__achievements:after {
  width: 100%;
  content: "";
  background-size: cover;
  background-position: center center;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}
@media only screen and (min-width: 781px) {
  .p-top__achievements:after {
    height: 31.3rem;
    background-image: url("../img/top/jisseki_bg.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .p-top__achievements:after {
    height: 26rem;
    background-image: url("../img/top/jisseki_bg_sp.jpg");
  }
}
.p-top__achievements .midashi01 + p {
  margin-bottom: 5.2rem;
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .midashi01 + p {
    margin-bottom: 1.6rem;
    font-size: 1.5rem;
  }
}
.p-top__achievements .splide {
  margin-bottom: 3.6rem;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide {
    margin-bottom: 3rem;
  }
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide {
  background-color: #ffffff;
  border-radius: 0.8rem;
  box-shadow: 0.6rem 0.6rem 3rem rgba(118, 142, 155, 0.2);
}
@media only screen and (min-width: 781px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide a {
    padding: 3.2rem;
    display: flex;
  }
  .p-top__achievements .splide .splide__track .splide__list .splide__slide a .img img {
    transition: filter 0.3s;
  }
  .p-top__achievements .splide .splide__track .splide__list .splide__slide a:hover .img img {
    filter: brightness(120%);
  }
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide a {
    padding: 1.6rem;
    display: block;
  }
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide .img {
  overflow: hidden;
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide .img > img,
.p-top__achievements .splide .splide__track .splide__list .splide__slide .img > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (min-width: 781px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide .img {
    width: 43.4%;
    min-height: 23.6rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide .img {
    height: 13.2rem;
    margin-bottom: 1.2rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide .text {
    width: 56.6%;
    padding-left: 4rem;
  }
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide .text .en {
  margin-bottom: 1rem;
  padding-left: 4rem;
  font-family: "Montserrat", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #BBCFEF;
  display: block;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide .text .en {
    margin-bottom: 0;
    padding-left: 2.3rem;
    font-size: 1.2rem;
  }
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide .text .en:before {
  width: 3rem;
  height: 0.2rem;
  margin: 0 1rem 0 -4rem;
  content: "";
  background-color: #BBCFEF;
  display: inline-block;
  vertical-align: 0.25em;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide .text .en:before {
    width: 1.5rem;
    margin: 0 0.8rem 0 -2.3rem;
  }
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide .text h3 {
  margin-bottom: 0.6rem;
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide .text h3 {
    font-size: 1.7rem;
  }
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide .text .tag {
  margin-bottom: 2.5rem;
  letter-spacing: -0.4em;
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide .text .tag > * {
  display: inline-block;
  letter-spacing: normal;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide .text .tag {
    margin-bottom: 1.3rem;
  }
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide .text .tag span {
  margin-right: 0.5em;
  padding: 0.1em 0.5em;
  font-size: 1.2rem;
  font-weight: 500;
  background-color: #EBEBEB;
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide .text .attribute .area {
  font-size: 1.5rem;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide .text .attribute .area {
    font-size: 1.2rem;
  }
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide .text .attribute .client_name {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide .text .attribute .client_name {
    font-size: 1.5rem;
  }
}
.p-top__achievements .splide .splide__track .splide__list .splide__slide .text .attribute .business_type {
  margin-top: 1rem;
  font-size: 1.5rem;
  color: #585858;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__track .splide__list .splide__slide .text .attribute .business_type {
    margin-top: 0.5rem;
    font-size: 1.3rem;
  }
}
.p-top__achievements .splide .splide__arrows .splide__arrow {
  width: 4rem;
  height: 4rem;
  background: none;
  background-size: cover;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__arrows .splide__arrow {
    width: 3.6rem;
    height: 3.6rem;
  }
}
.p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--prev {
  background-image: url("../img/slider_arrow_prev.png");
  left: 28%;
}
@media only screen and (min-width: 1600px) {
  .p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--prev {
    left: 23.5%;
  }
}
@media only screen and (max-width: 1279px) {
  .p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--prev {
    left: 17%;
  }
}
@media only screen and (max-width: 1099px) {
  .p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--prev {
    left: 15.5%;
  }
}
@media only screen and (max-width: 900px) {
  .p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--prev {
    left: 8%;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--prev {
    left: 5%;
  }
}
.p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--next {
  background-image: url("../img/slider_arrow_next.png");
  right: 28%;
}
@media only screen and (max-width: 1599px) {
  .p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--next {
    right: 23.5%;
  }
}
@media only screen and (max-width: 1279px) {
  .p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--next {
    right: 17%;
  }
}
@media only screen and (max-width: 1099px) {
  .p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--next {
    right: 15.5%;
  }
}
@media only screen and (max-width: 900px) {
  .p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--next {
    right: 8%;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__arrows .splide__arrow.splide__arrow--next {
    right: 5%;
  }
}
.p-top__achievements .splide .splide__arrows .splide__arrow svg {
  display: none !important;
}
.p-top__achievements .splide .splide__pagination {
  position: static;
}
@media only screen and (max-width: 780px) {
  .p-top__achievements .splide .splide__pagination {
    margin-top: 1rem;
  }
}
.p-top__achievements .splide .splide__pagination li {
  margin: 0.4rem;
}
.p-top__achievements .splide .splide__pagination li .splide__pagination__page {
  transform: none;
  background-color: #ffffff;
}
.p-top__achievements .splide .splide__pagination li .splide__pagination__page.is-active {
  background-color: #0028AC;
  transform: none;
}
.p-top__achievements .btn {
  text-align: center;
}
.p-top__faq {
  margin-bottom: 13.6rem;
}
@media only screen and (max-width: 780px) {
  .p-top__faq {
    margin-bottom: 5.5rem;
  }
}
.p-top__faq .inner {
  max-width: 1080px;
}
@media only screen and (min-width: 781px) {
  .p-top__faq .midashi01 {
    margin-bottom: 1.16em;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__faq .midashi01 {
    margin-bottom: 1em;
  }
}
.p-top__faq ul li {
  padding-bottom: 4rem;
  border-bottom: solid 1px #D1D1D1;
}
@media only screen and (max-width: 780px) {
  .p-top__faq ul li {
    padding-bottom: 2rem;
  }
}
.p-top__faq ul li + li {
  margin-top: 4rem;
}
@media only screen and (max-width: 780px) {
  .p-top__faq ul li + li {
    margin-top: 2rem;
  }
}
.p-top__faq ul li .faq_q {
  min-height: 4.8rem;
  margin-bottom: 1.6rem;
  padding-top: 0.8rem;
  padding-left: 7.2rem;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  background-image: url("../img/top/faq_q.png");
  background-size: 4.8rem auto;
  background-repeat: no-repeat;
  background-position: 0 0;
}
@media only screen and (max-width: 780px) {
  .p-top__faq ul li .faq_q {
    min-height: 2.4rem;
    padding-top: 0;
    padding-left: 3.6rem;
    font-size: 1.7rem;
    background-size: 2.4rem auto;
  }
}
.p-top__faq ul li .faq_a {
  min-height: 4.8rem;
  padding-left: 7.2rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.68;
  background-image: url("../img/top/faq_a.png");
  background-size: 4.8rem auto;
  background-repeat: no-repeat;
  background-position: 0 0;
}
@media only screen and (max-width: 780px) {
  .p-top__faq ul li .faq_a {
    min-height: 2.4rem;
    padding-left: 3.6rem;
    background-size: 2.4rem auto;
  }
}

/*下層ページ*/
.pagetitle {
  margin-bottom: 1em;
  padding: 12rem 0;
  color: #ffffff;
  background-image: url("../img/pagetitle_bg.jpg");
  background-size: cover;
  background-position: center center;
}
@media only screen and (max-width: 780px) {
  .pagetitle {
    padding: 6rem 0;
  }
}
.pagetitle h2 {
  font-size: 3.6rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .pagetitle h2 {
    font-size: 2.4rem;
  }
}
.pagetitle h2 span {
  margin-left: 1.5em;
  font-family: "Montserrat", sans-serif;
  font-size: 0.55em;
  letter-spacing: 0.03em;
  display: inline-block;
  vertical-align: 0.2em;
}

.pankuzu {
  margin-bottom: 8.8rem;
  font-size: 1.4rem;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .pankuzu {
    margin-bottom: 4.4rem;
    font-size: 1.2rem;
  }
}
.pankuzu .inner {
  letter-spacing: -0.4em;
}
.pankuzu .inner > * {
  display: inline-block;
  letter-spacing: normal;
}
.pankuzu .inner a:after {
  width: 0.5em;
  height: 0.5em;
  margin: 0 1em;
  content: "";
  background-image: url("../img/icon_arrow04.png");
  background-size: cover;
  display: inline-block;
  vertical-align: 0.1em;
}
.pankuzu .inner span {
  color: #B1B1B1;
}

.p-achievements__list {
  margin-bottom: 16rem;
}
@media only screen and (max-width: 780px) {
  .p-achievements__list {
    margin-bottom: 8rem;
  }
}
.p-achievements__list .midashi01 {
  margin-bottom: 1.1em;
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .midashi01 {
    margin-bottom: 0.85em;
  }
}
.p-achievements__list .midashi01 .ja span {
  padding: 0.2em 0.5em 0.2em 0;
  display: inline-block;
  position: relative;
}
.p-achievements__list .midashi01 .ja span:after {
  width: 16rem;
  height: 1px;
  content: "";
  background-color: #A4B6DB;
  position: absolute;
  top: 51%;
  left: 100%;
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .midashi01 .ja span:after {
    width: 8.8rem;
  }
}
.p-achievements__list .midashi01 .ja strong {
  margin-right: 0.25em;
  padding: 0 0.25em;
  font-weight: 700;
  color: #ffffff;
  background-color: #0028AC;
  display: inline-block;
}
.p-achievements__list .list {
  padding-bottom: 1.5rem;
}
@media only screen and (min-width: 781px) {
  .p-achievements__list .list {
    display: flex;
    flex-wrap: wrap;
  }
}
.p-achievements__list .list li {
  background-color: #ffffff;
  border-radius: 0.8rem;
  box-shadow: 0.6rem 0.6rem 3rem rgba(118, 142, 155, 0.2);
}
@media only screen and (min-width: 781px) {
  .p-achievements__list .list li {
    width: 32%;
    margin: 0 2% 5.6rem 0;
  }
  .p-achievements__list .list li:nth-child(3n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .list li {
    margin-bottom: 3.5rem;
  }
}
.p-achievements__list .list li a {
  display: block;
}
@media only screen and (min-width: 781px) {
  .p-achievements__list .list li a {
    padding: 3.2rem;
  }
  .p-achievements__list .list li a .img img {
    transition: filter 0.3s;
  }
  .p-achievements__list .list li a:hover .img img {
    filter: brightness(120%);
  }
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .list li a {
    padding: 1.6rem;
  }
}
.p-achievements__list .list li a .headding {
  margin-bottom: 1em;
}
.p-achievements__list .list li a .headding .en {
  margin-bottom: 0.5rem;
  padding-left: 4rem;
  font-family: "Montserrat", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #BBCFEF;
  display: block;
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .list li a .headding .en {
    margin-bottom: 0;
    padding-left: 2.3rem;
    font-size: 1.2rem;
  }
}
.p-achievements__list .list li a .headding .en:before {
  width: 3rem;
  height: 0.2rem;
  margin: 0 1rem 0 -4rem;
  content: "";
  background-color: #BBCFEF;
  display: inline-block;
  vertical-align: 0.25em;
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .list li a .headding .en:before {
    width: 1.5rem;
    margin: 0 0.8rem 0 -2.3rem;
  }
}
.p-achievements__list .list li a .headding h3 {
  margin-bottom: 0.6rem;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .list li a .headding h3 {
    font-size: 1.7rem;
  }
}
.p-achievements__list .list li a .headding .tag {
  letter-spacing: -0.4em;
}
.p-achievements__list .list li a .headding .tag > * {
  display: inline-block;
  letter-spacing: normal;
}
.p-achievements__list .list li a .headding .tag span {
  margin-right: 0.5em;
  padding: 0.1em 0.5em;
  font-size: 1.2rem;
  font-weight: 500;
  background-color: #EBEBEB;
}
.p-achievements__list .list li a .img {
  overflow: hidden;
}
.p-achievements__list .list li a .img > img,
.p-achievements__list .list li a .img > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (min-width: 781px) {
  .p-achievements__list .list li a .img {
    height: 19.6rem;
    margin-bottom: 1.8rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .list li a .img {
    height: 15rem;
    margin-bottom: 1.2rem;
  }
}
.p-achievements__list .list li a .attribute .area {
  font-size: 1.3rem;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .p-achievements__list .list li a .attribute .area {
    font-size: 1.2rem;
  }
}
.p-achievements__list .list li a .attribute .client_name {
  font-weight: 700;
  letter-spacing: 0.04em;
}
.p-achievements__list .list li a .attribute .business_type {
  font-size: 1.2rem;
  color: #585858;
}
.p-achievements__post {
  margin-bottom: 16rem;
}
@media only screen and (max-width: 780px) {
  .p-achievements__post {
    margin-bottom: 8rem;
  }
}
.p-achievements__post .inner {
  max-width: 1160px;
}
.p-achievements__post .headding {
  margin-bottom: 2.5em;
}
@media only screen and (max-width: 780px) {
  .p-achievements__post .headding {
    margin-bottom: 2em;
  }
}
.p-achievements__post .headding .en {
  margin-bottom: 0.5rem;
  padding-left: 4rem;
  font-family: "Montserrat", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #BBCFEF;
  display: block;
}
@media only screen and (max-width: 780px) {
  .p-achievements__post .headding .en {
    margin-bottom: 0;
    padding-left: 2.3rem;
    font-size: 1.2rem;
  }
}
.p-achievements__post .headding .en:before {
  width: 3rem;
  height: 0.2rem;
  margin: 0 1rem 0 -4rem;
  content: "";
  background-color: #BBCFEF;
  display: inline-block;
  vertical-align: 0.25em;
}
@media only screen and (max-width: 780px) {
  .p-achievements__post .headding .en:before {
    width: 1.5rem;
    margin: 0 0.8rem 0 -2.3rem;
  }
}
.p-achievements__post .headding h3 {
  margin-bottom: 0.6rem;
  font-size: 3.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 780px) {
  .p-achievements__post .headding h3 {
    font-size: 2rem;
  }
}
.p-achievements__post .headding .client_name {
  font-weight: 500;
  letter-spacing: 0.04em;
}
@media only screen and (min-width: 781px) {
  .p-achievements__post .detail {
    margin-bottom: 10rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
@media only screen and (max-width: 780px) {
  .p-achievements__post .detail {
    margin-bottom: 5rem;
  }
}
.p-achievements__post .detail .img {
  background-color: #F0F0F0;
}
@media only screen and (min-width: 781px) {
  .p-achievements__post .detail .img {
    width: 50%;
    height: 35.5rem;
  }
  .p-achievements__post .detail .img img {
    width: auto;
    max-width: 100%;
    height: auto;
    max-height: 100%;
    margin: 0 auto;
    display: block;
  }
}
@media only screen and (max-width: 780px) {
  .p-achievements__post .detail .img {
    margin-bottom: 2.5rem;
    text-align: center;
  }
}
@media only screen and (min-width: 781px) {
  .p-achievements__post .detail .table {
    width: 44.5%;
  }
}
.p-achievements__post .detail .table table {
  width: 100%;
  border-top: solid 1px #CCCCCC;
}
.p-achievements__post .detail .table table th, .p-achievements__post .detail .table table td {
  padding: 1.5em;
  letter-spacing: 0.04em;
  border-bottom: solid 1px #CCCCCC;
}
@media only screen and (max-width: 780px) {
  .p-achievements__post .detail .table table th, .p-achievements__post .detail .table table td {
    padding: 1em;
  }
}
.p-achievements__post .detail .table table th {
  width: 15rem;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .p-achievements__post .detail .table table th {
    width: 10rem;
  }
}
.p-achievements__post dl {
  max-width: 1000px;
  margin: 0 auto 10rem auto;
}
@media only screen and (max-width: 780px) {
  .p-achievements__post dl {
    margin-bottom: 5rem;
  }
}
.p-achievements__post dl dt {
  margin-bottom: 0.7em;
  font-size: 2.4rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-achievements__post dl dt {
    font-size: 2rem;
  }
}
.p-achievements__post dl dd {
  line-height: 2.125;
}
.p-achievements__post dl dd + dt {
  margin-top: 3.3em;
}
@media only screen and (max-width: 780px) {
  .p-achievements__post dl dd + dt {
    margin-top: 2.5em;
  }
}
.p-achievements__post .btn {
  text-align: center;
}

.p-column__list {
  margin-bottom: 16rem;
}
@media only screen and (max-width: 780px) {
  .p-column__list {
    margin-bottom: 8rem;
  }
}
.p-column__list .inner {
  max-width: 1080px;
}
.p-column__list .cate_list {
  margin-bottom: 6.4rem;
  letter-spacing: -0.4em;
}
.p-column__list .cate_list > * {
  display: inline-block;
  letter-spacing: normal;
}
@media only screen and (max-width: 780px) {
  .p-column__list .cate_list {
    margin-bottom: 3rem;
  }
}
.p-column__list .cate_list li {
  width: 27rem;
  margin: 0 0.5rem 0.5rem 0;
}
@media only screen and (max-width: 780px) {
  .p-column__list .cate_list li {
    width: auto;
  }
}
.p-column__list .cate_list li a {
  padding: 0.5em;
  font-weight: 500;
  text-align: center;
  color: #ffffff;
  background-color: #0028AC;
  display: block;
}
@media only screen and (max-width: 780px) {
  .p-column__list .cate_list li a {
    padding: 0.5em 1em;
  }
}
.p-column__list .cate_list li.current a {
  background-color: #BBCFEF;
  pointer-events: none;
}
.p-column__list .cate_list li:not(.current) a:hover {
  background-color: #282B29;
}
.p-column__list .list {
  padding-bottom: 1.5rem;
}
@media only screen and (min-width: 781px) {
  .p-column__list .list {
    display: flex;
    flex-wrap: wrap;
  }
}
.p-column__list .list li {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-column__list .list li {
    width: 32%;
    margin: 0 2% 5.6rem 0;
  }
  .p-column__list .list li:nth-child(3n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-column__list .list li {
    margin-bottom: 3.5rem;
  }
}
.p-column__list .list li a {
  display: block;
}
@media only screen and (min-width: 781px) {
  .p-column__list .list li a .img img {
    transition: filter 0.3s;
  }
  .p-column__list .list li a:hover .img img {
    filter: brightness(120%);
  }
}
.p-column__list .list li .img {
  width: 100%;
  height: 20rem;
  overflow: hidden;
}
.p-column__list .list li .img > img,
.p-column__list .list li .img > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (max-width: 780px) {
  .p-column__list .list li .img {
    height: 16rem;
  }
}
.p-column__list .list li p {
  padding: 1.6rem;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.27;
}
@media only screen and (max-width: 780px) {
  .p-column__list .list li p {
    padding: 1.2rem;
    font-size: 1.6rem;
  }
}
.p-column__list .list li .cate {
  padding: 0 1.6rem 1.6rem 1.6rem;
  display: block;
  letter-spacing: -0.4em;
}
.p-column__list .list li .cate > * {
  display: inline-block;
  letter-spacing: normal;
}
@media only screen and (max-width: 780px) {
  .p-column__list .list li .cate {
    padding: 0 1.2rem 1.2rem 1.2rem;
  }
}
.p-column__list .list li .cate span {
  margin-right: 0.8rem;
  padding: 0.1em 0.5em;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: #747474;
  border: solid 1px #C9C9C9;
}
.p-column__post {
  margin-bottom: 16rem;
}
@media only screen and (max-width: 780px) {
  .p-column__post {
    margin-bottom: 8rem;
  }
}
.p-column__post .inner {
  max-width: 1000px;
}
.p-column__post .news_headding {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 780px) {
  .p-column__post .news_headding {
    margin-bottom: 3rem;
  }
}
.p-column__post .news_headding .cate {
  margin-bottom: 1em;
  letter-spacing: -0.4em;
}
.p-column__post .news_headding .cate > * {
  display: inline-block;
  letter-spacing: normal;
}
.p-column__post .news_headding .cate span {
  margin-right: 0.8rem;
  padding: 0.1em 0.5em;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: #ffffff;
  background-color: #BBCFEF;
}
.p-column__post .news_headding h2 {
  margin-bottom: 0.6em;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.2;
}
@media only screen and (max-width: 780px) {
  .p-column__post .news_headding h2 {
    font-size: 2.2rem;
  }
}
.p-column__post .date {
  padding-bottom: 2.4rem;
  border-bottom: solid 1px #CCCCCC;
  letter-spacing: -0.4em;
}
.p-column__post .date > * {
  display: inline-block;
  letter-spacing: normal;
}
@media only screen and (max-width: 780px) {
  .p-column__post .date {
    padding-bottom: 2rem;
  }
}
.p-column__post .date span {
  font-family: "Montserrat", sans-serif;
  font-size: 1.4rem;
  font-weight: 600;
  letter-spacing: 0.1em;
}
.p-column__post .date span:before {
  width: 1.6rem;
  height: 1.6rem;
  margin-right: 0.5em;
  content: "";
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 100% auto;
  display: inline-block;
  vertical-align: -0.1em;
}
.p-column__post .date span.post_date:before {
  background-image: url("../img/news/post_date.png");
}
.p-column__post .date span.update_post {
  margin-left: 1em;
}
.p-column__post .date span.update_post:before {
  background-image: url("../img/news/update_post.png");
}
.p-column__post .icatch {
  margin-top: 4rem;
}
@media only screen and (max-width: 780px) {
  .p-column__post .icatch {
    margin-top: 3rem;
  }
}

.p-contact__tel {
  margin-bottom: 2em;
}
.p-contact__tel .inner {
  max-width: 800px;
}
.p-contact__tel .box {
  border: solid 1px #A4B6DB;
}
@media only screen and (min-width: 781px) {
  .p-contact__tel .box {
    padding: 4rem 0;
    display: flex;
    align-items: center;
  }
}
@media only screen and (max-width: 780px) {
  .p-contact__tel .box {
    padding: 2rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-contact__tel .box > * {
    width: 50%;
  }
}
.p-contact__tel .box h3 {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-contact__tel .box h3 {
    margin-bottom: 1.5em;
    font-size: 1.6rem;
  }
}
.p-contact__tel .box > div {
  text-align: center;
}
@media only screen and (min-width: 781px) {
  .p-contact__tel .box > div {
    border-left: solid 1px #A4B6DB;
  }
}
@media only screen and (min-width: 781px) {
  .p-contact__tel .box > div .num {
    font-family: "Montserrat", sans-serif;
    font-size: 2.1rem;
    font-weight: 600;
    color: #0028AC;
  }
  .p-contact__tel .box > div .num span {
    margin-left: 0.25em;
    font-size: 2em;
    display: inline-block;
    vertical-align: -0.15em;
  }
}
.p-contact__tel .box > div .time {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #7B7B7B;
  display: block;
}
@media only screen and (max-width: 780px) {
  .p-contact__tel .box > div .time {
    margin-top: 1em;
    font-size: 1.2rem;
  }
}
.p-contact__mail {
  margin-bottom: 16rem;
}
@media only screen and (max-width: 780px) {
  .p-contact__mail {
    margin-bottom: 8rem;
  }
}
.p-contact__mail .inner {
  max-width: 1000px;
}
.p-contact__mail h3 {
  margin-bottom: 3em;
  font-weight: 500;
  line-height: 1.68;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-contact__mail h3 {
    margin-bottom: 2em;
    text-align: left;
  }
}
.p-contact__mail .form_area .input_field_area {
  margin-bottom: 6.4rem;
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-contact__mail .form_area .input_field_area {
    padding: 7.2rem 6.4rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-contact__mail .form_area .input_field_area {
    width: 113.6%;
    margin: 0 -6.8% 3rem -6.8%;
    padding: 3rem 2rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-contact__mail .form_area .input_field_area.table .input_field {
    width: 100%;
    margin-bottom: 0;
    display: table;
  }
  .p-contact__mail .form_area .input_field_area.table .input_field > * {
    display: table-cell;
  }
  .p-contact__mail .form_area .input_field_area.table .input_field .input_label {
    width: 30%;
    margin-bottom: 0;
    padding: 2.5em 0 2em 0;
    vertical-align: top;
    border-bottom: solid 1px #E2EDF2;
  }
  .p-contact__mail .form_area .input_field_area.table .input_field .input_label.pdt2 {
    padding-top: 2em;
  }
  .p-contact__mail .form_area .input_field_area.table .input_field .input_area {
    padding: 2em 0;
    vertical-align: top;
    border-bottom: solid 1px #E2EDF2;
  }
}
.p-contact__mail .form_area .input_field_area .input_field {
  margin-bottom: 2em;
}
@media only screen and (max-width: 780px) {
  .p-contact__mail .form_area .input_field_area .input_field:last-child {
    margin-bottom: 0;
  }
}
.p-contact__mail .form_area .input_field_area .input_field .input_label {
  margin-bottom: 0.75em;
  font-weight: 500;
}
.p-contact__mail .form_area .input_field_area .input_field .input_label span {
  margin-left: 1em;
  font-size: 0.7em;
  font-weight: 400;
  color: #0028AC;
  display: inline-block;
  vertical-align: 0;
}
.p-contact__mail .form_area .input_field_area .input_field .input_area {
  font-size: 0.9375em;
}
.p-contact__mail .form_area .input_field_area .input_field .input_area.row {
  display: flex;
  justify-content: space-between;
}
.p-contact__mail .form_area .input_field_area .input_field .input_area.row .col {
  width: 48%;
}
.p-contact__mail .form_area .input_field_area .input_field .input_area .label {
  margin-bottom: 0.5em;
}
.p-contact__mail .form_area .input_field_area .input_field .input_area * + .label {
  margin-top: 1em;
}
.p-contact__mail .form_area .input_field_area .input_field .input_area .annotation {
  margin-top: 1em;
  font-size: 0.8125em;
}
.p-contact__mail .form_area .privacy {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 780px) {
  .p-contact__mail .form_area .privacy {
    margin-bottom: 2.5rem;
  }
}
.p-contact__mail .form_area .privacy > p {
  margin-bottom: 4rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-contact__mail .form_area .privacy > p {
    margin-bottom: 3rem;
    text-align: left;
  }
}
.p-contact__mail .form_area .privacy .box {
  height: 36rem;
  margin-bottom: 4rem;
  padding: 2.5em;
  background-color: #ffffff;
  border: solid 1px #CCCCCC;
}
@media only screen and (max-width: 780px) {
  .p-contact__mail .form_area .privacy .box {
    height: 20rem;
    margin-bottom: 2.5rem;
    padding: 1.5em;
  }
}
.p-contact__mail .form_area .privacy .box .scroll {
  width: 100%;
  height: 100%;
  padding-right: 1em;
  overflow: auto;
}
.p-contact__mail .form_area .privacy .box h3 {
  margin-bottom: 0.5em;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-contact__mail .form_area .privacy .box h3 {
    font-size: 1.6rem;
  }
}
.p-contact__mail .form_area .privacy .box h4 {
  margin-bottom: 0.5em;
  font-size: 1.5rem;
  font-weight: 500;
  letter-spacing: 0.05em;
}
.p-contact__mail .form_area .privacy .box p {
  margin-bottom: 2em;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
}
.p-contact__mail .form_area .privacy .check {
  text-align: center;
}
.p-contact__mail .form_area .submit {
  text-align: center;
}
.p-contact__mail .form_area .submit .btn01 {
  height: 6rem;
  overflow: hidden;
}
@media only screen and (max-width: 780px) {
  .p-contact__mail .form_area .submit .btn01 {
    height: 4rem;
  }
}
.p-contact__mail .form_area .submit .btn01 input[type=submit] {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}
.p-contact__mail .form_area .submit .btn01 input[type=submit]:disabled {
  opacity: 0.5;
  background-color: #000000;
}

/****************************************************
 * 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;
  }
}