@charset "UTF-8";

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

* {
  margin: 0;
  padding: 0;
}

html {
  font-size: 62.5%;
  /* 10px */
}

body {
  width: 100%;
  color: #383838;
  font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "Hiragino Sans", "ヒラギノ角ゴシック", Meiryo, sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.75;
  word-break: break-word;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
}

/*----------------------------------------
	HTML5
----------------------------------------*/
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

section {
  margin-bottom: 2em;
}

/*----------------------------------------
	Text
----------------------------------------*/
h1, h2, h3, h4, h5, h6 {
  margin: 0 auto 1.6rem;
  padding: 0;
  line-height: 1.4;
}

pre {
  margin: 1.5em 25px;
  padding: 1em;
  overflow: scroll;
  font-family: "Yu Gothic medium", YuGothic Medium, "游ゴシック", "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
  line-height: 1.9;
}

blockquote {
  margin: 1.5em 1px;
  border: 5px solid #9f998f;
  color: #77471c;
  background-color: #f5f5f5;
  background-repeat: repeat-x;
  background-position: left bottom;
}

blockquote[title]::before {
  padding: 0.2em 10px 0.4em 10px;
  content: attr(title);
  display: block;
  color: #fff;
  background-color: #9f998f;
  font-weight: bold;
}

blockquote[cite]::after {
  margin: 0.5em 10px;
  content: attr(cite);
  display: block;
  text-align: right;
  font-size: 85%;
}

blockquote * {
  color: #333 !important;
}

em {
  color: #000;
}

pre {
  background: #eee;
  font-family: "Courier 10 Pitch", Courier, monospace;
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 1.6;
  margin-bottom: 1.6em;
  max-width: 100%;
  overflow: auto;
  padding: 1.6em;
}

pre em {
  font-weight: bold;
  background-image: none;
}

q {
  text-decoration: underline;
}

b,
strong {
  font-weight: bold;
}

cite {
  display: block;
  text-align: right;
}

dfn,
cite,
em,
i {
  font-style: italic;
}

kbd {
  background-color: #f5f5f5;
  font-family: "Osaka|", monospace;
  text-transform: uppercase;
  padding: 0 0.4em;
  border: 1px solid #6a8eaa;
}

del {
  text-decoration: line-through;
}

ins {
  border-top: 10px solid #3cadd6;
  border-bottom: 10px solid #3cadd6;
  border: 7px solid #3cadd6;
  margin: 2em 1px;
  padding: 1px 0;
  display: block;
  text-decoration: none;
}

mark {
  background: #fff9c0;
  text-decoration: none;
}

ins * {
  color: #666 !important;
  background: #fff9c0;
  text-decoration: none;
}

abbr,
acronym {
  border-bottom: 1px dotted #666;
  cursor: help;
}

address {
  margin: 0 0 1.5em;
}

sup,
sub {
  font-size: 75%;
  height: 0;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  bottom: 1ex;
}

sub {
  top: 0.5ex;
}

small {
  font-size: 75%;
}

big {
  font-size: 125%;
}

hr {
  background-color: #ccc;
  border: 0;
  height: 1px;
  margin-bottom: 1.5em;
}

/*----------------------------------------
	List
----------------------------------------*/
ul,
ol,
dl {
  margin: 0;
  padding: 0;
}

ul,
ol {
  list-style: none;
}

li,
dt,
dd {
  list-style-type: none;
  list-style-position: outside;
}

ul li,
ol li,
dd {
  margin-left: 1.5em;
}

ul li,
ol li {
  list-style: none;
}

li>ul,
li>ol {
  margin-bottom: 0;
  margin-left: 1.5em;
}

dt {
  font-weight: bold;
}

dd {
  margin: 0 1.5em 1.5em;
}

/*----------------------------------------
	Image
----------------------------------------*/
figure {
  margin: 0;
  width: 100%;
  line-height: 1;
}

img {
  display: block;
  margin: 0 auto;
  height: auto;
  /* Make sure images are scaled correctly. */
  max-width: 100%;
  border: none;
  vertical-align: baseline;
  -webkit-backface-visibility: hidden;
}

/*----------------------------------------
	Anchor
----------------------------------------*/
a {
  color: #333;
  text-decoration: none;
  transition: 0.3s;
}

a:hover,
a:focus,
a:active {
  color: #404040;
  outline: none;
  text-decoration: underline;
}

a img {
  transition: 0.3s;
}

a:hover img {
  opacity: 0.7;
}

@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
    text-decoration: none;
  }
}

/*----------------------------------------
	Table
----------------------------------------*/
table {
  margin: 0 0 2em;
  width: 100%;
  border-collapse: collapse;
}

/*----------------------------------------
	Form
----------------------------------------*/
fieldset,
legend {
  border: none;
}

legend {
  display: none;
}

input[type=text],
textarea {
  padding: 0.2em;
  border: 1px solid #d1d1d1;
  background-color: #fff;
}

input {
  line-height: 1.2;
}

select, input, textarea, button {
  vertical-align: middle;
  font-family: "Yu Gothic medium", YuGothic Medium, "游ゴシック", "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
  position: relative;
  margin-right: 3px;
  top: 0;
}

input[type=checkbox],
input[type=radio] {
  border: none;
  top: -1px;
  margin-right: 2px;
}

input[type=text]:focus,
textarea:focus {
  border: 1px solid #069;
  background-color: #fff;
}

input.button {
  padding: 0;
  border: none;
  background-image: none;
  vertical-align: top;
}

/* iOSでのデフォルトスタイルをリセット */
input[type=submit],
input[type=button] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}

input[type=submit]:focus,
input[type=button]:focus {
  outline-offset: -2px;
}

.tac {
  text-align: center;
}

.tal {
  text-align: left;
}

.tar {
  text-align: right;
}

/*余白*/
.mx-auto {
  margin-right: auto !important;
  margin-left: auto !important;
}

.m-0 {
  margin: 0px !important;
}

.m-5 {
  margin: 5px !important;
}

.m-10 {
  margin: 10px !important;
}

.m-15 {
  margin: 15px !important;
}

.m-20 {
  margin: 20px !important;
}

.m-25 {
  margin: 25px !important;
}

.m-30 {
  margin: 30px !important;
}

.m-35 {
  margin: 35px !important;
}

.m-40 {
  margin: 40px !important;
}

.m-45 {
  margin: 45px !important;
}

.m-50 {
  margin: 50px !important;
}

.m-55 {
  margin: 55px !important;
}

.m-60 {
  margin: 60px !important;
}

.m-65 {
  margin: 65px !important;
}

.m-70 {
  margin: 70px !important;
}

.m-75 {
  margin: 75px !important;
}

.m-80 {
  margin: 80px !important;
}

.m-85 {
  margin: 85px !important;
}

.m-90 {
  margin: 90px !important;
}

.m-95 {
  margin: 95px !important;
}

.m-100 {
  margin: 100px !important;
}

.mt-0 {
  margin-top: 0px !important;
}

.mt-5 {
  margin-top: 5px !important;
}

.mt-10 {
  margin-top: 10px !important;
}

.mt-15 {
  margin-top: 15px !important;
}

.mt-20 {
  margin-top: 20px !important;
}

.mt-25 {
  margin-top: 25px !important;
}

.mt-30 {
  margin-top: 30px !important;
}

.mt-35 {
  margin-top: 35px !important;
}

.mt-40 {
  margin-top: 40px !important;
}

.mt-45 {
  margin-top: 45px !important;
}

.mt-50 {
  margin-top: 50px !important;
}

.mt-55 {
  margin-top: 55px !important;
}

.mt-60 {
  margin-top: 60px !important;
}

.mt-65 {
  margin-top: 65px !important;
}

.mt-70 {
  margin-top: 70px !important;
}

.mt-75 {
  margin-top: 75px !important;
}

.mt-80 {
  margin-top: 80px !important;
}

.mt-85 {
  margin-top: 85px !important;
}

.mt-90 {
  margin-top: 90px !important;
}

.mt-95 {
  margin-top: 95px !important;
}

.mt-100 {
  margin-top: 100px !important;
}

.mb-0 {
  margin-bottom: 0px !important;
}

.mb-5 {
  margin-bottom: 5px !important;
}

.mb-10 {
  margin-bottom: 10px !important;
}

.mb-15 {
  margin-bottom: 15px !important;
}

.mb-20 {
  margin-bottom: 20px !important;
}

.mb-25 {
  margin-bottom: 25px !important;
}

.mb-30 {
  margin-bottom: 30px !important;
}

.mb-35 {
  margin-bottom: 35px !important;
}

.mb-40 {
  margin-bottom: 40px !important;
}

.mb-45 {
  margin-bottom: 45px !important;
}

.mb-50 {
  margin-bottom: 50px !important;
}

.mb-55 {
  margin-bottom: 55px !important;
}

.mb-60 {
  margin-bottom: 60px !important;
}

.mb-65 {
  margin-bottom: 65px !important;
}

.mb-70 {
  margin-bottom: 70px !important;
}

.mb-75 {
  margin-bottom: 75px !important;
}

.mb-80 {
  margin-bottom: 80px !important;
}

.mb-85 {
  margin-bottom: 85px !important;
}

.mb-90 {
  margin-bottom: 90px !important;
}

.mb-95 {
  margin-bottom: 95px !important;
}

.mb-100 {
  margin-bottom: 100px !important;
}

.ml-0 {
  margin-left: 0px !important;
}

.ml-5 {
  margin-left: 5px !important;
}

.ml-10 {
  margin-left: 10px !important;
}

.ml-15 {
  margin-left: 15px !important;
}

.ml-20 {
  margin-left: 20px !important;
}

.ml-25 {
  margin-left: 25px !important;
}

.ml-30 {
  margin-left: 30px !important;
}

.ml-35 {
  margin-left: 35px !important;
}

.ml-40 {
  margin-left: 40px !important;
}

.ml-45 {
  margin-left: 45px !important;
}

.ml-50 {
  margin-left: 50px !important;
}

.ml-55 {
  margin-left: 55px !important;
}

.ml-60 {
  margin-left: 60px !important;
}

.ml-65 {
  margin-left: 65px !important;
}

.ml-70 {
  margin-left: 70px !important;
}

.ml-75 {
  margin-left: 75px !important;
}

.ml-80 {
  margin-left: 80px !important;
}

.ml-85 {
  margin-left: 85px !important;
}

.ml-90 {
  margin-left: 90px !important;
}

.ml-95 {
  margin-left: 95px !important;
}

.ml-100 {
  margin-left: 100px !important;
}

.mr-0 {
  margin-right: 0px !important;
}

.mr-5 {
  margin-right: 5px !important;
}

.mr-10 {
  margin-right: 10px !important;
}

.mr-15 {
  margin-right: 15px !important;
}

.mr-20 {
  margin-right: 20px !important;
}

.mr-25 {
  margin-right: 25px !important;
}

.mr-30 {
  margin-right: 30px !important;
}

.mr-35 {
  margin-right: 35px !important;
}

.mr-40 {
  margin-right: 40px !important;
}

.mr-45 {
  margin-right: 45px !important;
}

.mr-50 {
  margin-right: 50px !important;
}

.mr-55 {
  margin-right: 55px !important;
}

.mr-60 {
  margin-right: 60px !important;
}

.mr-65 {
  margin-right: 65px !important;
}

.mr-70 {
  margin-right: 70px !important;
}

.mr-75 {
  margin-right: 75px !important;
}

.mr-80 {
  margin-right: 80px !important;
}

.mr-85 {
  margin-right: 85px !important;
}

.mr-90 {
  margin-right: 90px !important;
}

.mr-95 {
  margin-right: 95px !important;
}

.mr-100 {
  margin-right: 100px !important;
}

.p-0 {
  padding: 0px !important;
}

.p-5 {
  padding: 5px !important;
}

.p-10 {
  padding: 10px !important;
}

.p-15 {
  padding: 15px !important;
}

.p-20 {
  padding: 20px !important;
}

.p-25 {
  padding: 25px !important;
}

.p-30 {
  padding: 30px !important;
}

.p-35 {
  padding: 35px !important;
}

.p-40 {
  padding: 40px !important;
}

.p-45 {
  padding: 45px !important;
}

.p-50 {
  padding: 50px !important;
}

.p-55 {
  padding: 55px !important;
}

.p-60 {
  padding: 60px !important;
}

.p-65 {
  padding: 65px !important;
}

.p-70 {
  padding: 70px !important;
}

.p-75 {
  padding: 75px !important;
}

.p-80 {
  padding: 80px !important;
}

.p-85 {
  padding: 85px !important;
}

.p-90 {
  padding: 90px !important;
}

.p-95 {
  padding: 95px !important;
}

.p-100 {
  padding: 100px !important;
}

.pt-0 {
  padding-top: 0px !important;
}

.pt-5 {
  padding-top: 5px !important;
}

.pt-10 {
  padding-top: 10px !important;
}

.pt-15 {
  padding-top: 15px !important;
}

.pt-20 {
  padding-top: 20px !important;
}

.pt-25 {
  padding-top: 25px !important;
}

.pt-30 {
  padding-top: 30px !important;
}

.pt-35 {
  padding-top: 35px !important;
}

.pt-40 {
  padding-top: 40px !important;
}

.pt-45 {
  padding-top: 45px !important;
}

.pt-50 {
  padding-top: 50px !important;
}

.pt-55 {
  padding-top: 55px !important;
}

.pt-60 {
  padding-top: 60px !important;
}

.pt-65 {
  padding-top: 65px !important;
}

.pt-70 {
  padding-top: 70px !important;
}

.pt-75 {
  padding-top: 75px !important;
}

.pt-80 {
  padding-top: 80px !important;
}

.pt-85 {
  padding-top: 85px !important;
}

.pt-90 {
  padding-top: 90px !important;
}

.pt-95 {
  padding-top: 95px !important;
}

.pt-100 {
  padding-top: 100px !important;
}

.pb-0 {
  padding-bottom: 0px !important;
}

.pb-5 {
  padding-bottom: 5px !important;
}

.pb-10 {
  padding-bottom: 10px !important;
}

.pb-15 {
  padding-bottom: 15px !important;
}

.pb-20 {
  padding-bottom: 20px !important;
}

.pb-25 {
  padding-bottom: 25px !important;
}

.pb-30 {
  padding-bottom: 30px !important;
}

.pb-35 {
  padding-bottom: 35px !important;
}

.pb-40 {
  padding-bottom: 40px !important;
}

.pb-45 {
  padding-bottom: 45px !important;
}

.pb-50 {
  padding-bottom: 50px !important;
}

.pb-55 {
  padding-bottom: 55px !important;
}

.pb-60 {
  padding-bottom: 60px !important;
}

.pb-65 {
  padding-bottom: 65px !important;
}

.pb-70 {
  padding-bottom: 70px !important;
}

.pb-75 {
  padding-bottom: 75px !important;
}

.pb-80 {
  padding-bottom: 80px !important;
}

.pb-85 {
  padding-bottom: 85px !important;
}

.pb-90 {
  padding-bottom: 90px !important;
}

.pb-95 {
  padding-bottom: 95px !important;
}

.pb-100 {
  padding-bottom: 100px !important;
}

.pl-0 {
  padding-left: 0px !important;
}

.pl-5 {
  padding-left: 5px !important;
}

.pl-10 {
  padding-left: 10px !important;
}

.pl-15 {
  padding-left: 15px !important;
}

.pl-20 {
  padding-left: 20px !important;
}

.pl-25 {
  padding-left: 25px !important;
}

.pl-30 {
  padding-left: 30px !important;
}

.pl-35 {
  padding-left: 35px !important;
}

.pl-40 {
  padding-left: 40px !important;
}

.pl-45 {
  padding-left: 45px !important;
}

.pl-50 {
  padding-left: 50px !important;
}

.pl-55 {
  padding-left: 55px !important;
}

.pl-60 {
  padding-left: 60px !important;
}

.pl-65 {
  padding-left: 65px !important;
}

.pl-70 {
  padding-left: 70px !important;
}

.pl-75 {
  padding-left: 75px !important;
}

.pl-80 {
  padding-left: 80px !important;
}

.pl-85 {
  padding-left: 85px !important;
}

.pl-90 {
  padding-left: 90px !important;
}

.pl-95 {
  padding-left: 95px !important;
}

.pl-100 {
  padding-left: 100px !important;
}

.pr-0 {
  padding-right: 0px !important;
}

.pr-5 {
  padding-right: 5px !important;
}

.pr-10 {
  padding-right: 10px !important;
}

.pr-15 {
  padding-right: 15px !important;
}

.pr-20 {
  padding-right: 20px !important;
}

.pr-25 {
  padding-right: 25px !important;
}

.pr-30 {
  padding-right: 30px !important;
}

.pr-35 {
  padding-right: 35px !important;
}

.pr-40 {
  padding-right: 40px !important;
}

.pr-45 {
  padding-right: 45px !important;
}

.pr-50 {
  padding-right: 50px !important;
}

.pr-55 {
  padding-right: 55px !important;
}

.pr-60 {
  padding-right: 60px !important;
}

.pr-65 {
  padding-right: 65px !important;
}

.pr-70 {
  padding-right: 70px !important;
}

.pr-75 {
  padding-right: 75px !important;
}

.pr-80 {
  padding-right: 80px !important;
}

.pr-85 {
  padding-right: 85px !important;
}

.pr-90 {
  padding-right: 90px !important;
}

.pr-95 {
  padding-right: 95px !important;
}

.pr-100 {
  padding-right: 100px !important;
}

@media screen and (max-width: 767px) {
  .pc_only {
    display: none !important;
  }
}

@media screen and (min-width: 768px) {
  .sp_only {
    display: none !important;
  }
}

h2,
h3,
h4,
h5,
h6 {
  clear: both;
  line-height: 1.2;
  margin: 0 0 10px;
}

h1 {
  font-size: 30px;
}

h2 {
  margin-bottom: 14px;
  padding: 10px 38px;
  font-size: 18px;
  font-weight: 700;
  background-color: rgba(38, 183, 188, 0.1);
  border-bottom: 1px solid #26B7BC;
  position: relative;
  z-index: 0;
}

h2::before {
  content: "";
  display: block;
  width: 11px;
  height: 11px;
  background-color: #26B7BC;
  transform: rotate(45deg);
  position: absolute;
  left: 15px;
  top: 15px;
  z-index: 0;
}

h3 {
  margin: 16px 0 10px;
  padding-left: 30px;
  color: #26B7BC;
  font-size: 19px;
  font-weight: 500;
  line-height: 1.526;
  position: relative;
  z-index: 0;
}

h3::before {
  content: "";
  display: block;
  width: 15px;
  height: 15px;
  background-image: url(../images/common/icon_h3.svg);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  position: absolute;
  left: 3px;
  top: 8px;
  z-index: 0;
}

h4 {
  font-size: 20px;
}

h5 {
  font-size: 18px;
}

h6 {
  font-size: 16px;
}

@media screen and (min-width: 768px) {
  h2 {
    padding: 16px 54px;
    font-size: 30px;
  }

  h2::before {
    width: 20px;
    height: 20px;
    left: 22px;
    top: 25px;
  }

  h3 {
    margin: 24px 0 10px;
    font-size: 24px;
  }

  h3::before {
    width: 18px;
    height: 18px;
    left: 3px;
    top: 8px;
  }
}

ul {
  margin: 0;
  padding: 0;
}

ul li {
  margin: 0;
  padding: 0;
}

ul li::before {
  content: "■";
  display: inline-block;
  padding-right: 5px;
  color: #26B7BC;
  line-height: 1.5;
  vertical-align: middle;
}

ul li span {
  display: inline-block;
  width: 40%;
  vertical-align: top;
}

@media screen and (min-width: 768px) {
  ul li span:nth-of-type(1) {
    width: 32%;
  }

  ul li span:nth-of-type(2) {
    width: 64%;
  }

  ul.tb02 {
    margin-top: 14px;
  }
}

/*-- anchorLink --*/
.anchorLink {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: center;
  margin: 6px auto 36px;
  width: 100%;
  max-width: 600px;
  height: 100%;
}

.anchorLink a {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: -1px 0 0 -1px;
  padding: 0;
  width: 50%;
  height: 34px;
  color: #26B7BC;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.5;
  border: 1px solid #DCDDDD;
}

.anchorLink a span {
  display: block;
  padding: 0 5px 0 10px;
  background-image: url(../images/common/icon_arw3.svg);
  background-repeat: no-repeat;
  background-position: 0 8px;
  background-size: 7px 4px;
}

.anchorLink a:hover {
  text-decoration: none;
  opacity: 0.8;
}

@media screen and (min-width: 768px) {
  .anchorLink {
    margin-bottom: 60px;
  }

  .anchorLink a {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: -1px 0 0 -1px;
    padding: 0 20px;
    width: 50%;
    height: 60px;
    font-size: 16px;
  }

  .anchorLink a span {
    padding: 0 10px 0 20px;
    background-position: 0 9px;
  }
}

/*-- anchorLink --*/
/*-- dlTable --*/
.dlTable__wrap {
  margin: 30px 0 50px;
  border-top: 1px solid #DCDDDD;
}

.dlTable__wrap dl, .dlTable__wrap dt, .dlTable__wrap dd {
  margin: 0;
  padding: 0;
}

.dlTable__wrap dl {
  border-bottom: 1px solid #DCDDDD;
}

.dlTable__wrap dt, .dlTable__wrap dd {
  padding: 10px 16px;
}

.dlTable__wrap dt {
  margin-bottom: 5px;
  font-weight: 700;
  text-align: center;
  background-color: #F9F9F9;
  border-bottom: 1px solid #DCDDDD;
}

.dlTable__wrap dd {
  padding-bottom: 20px;
}

.dlTable__wrap dd span {
  display: inline-block;
  margin-right: 1em;
  word-break: break-all;
}

.dlTable__wrap dd .btn_access {
  margin-top: 10px;
  padding: 0;
}

.dlTable__wrap dd .btn_access a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 50px;
  max-width: 400px;
  color: #26B7BC;
  font-size: 15px;
  font-weight: 700;
  line-height: 1;
  border: 1px solid #DCDDDD;
}

.dlTable__wrap dd .btn_access a:hover {
  color: #fff;
  text-decoration: none;
  background-color: #26B7BC;
}

@media screen and (min-width: 768px) {
  .dlTable__wrap {
    margin: 30px 0 65px;
  }

  .dlTable__wrap dl {
    display: flex;
    margin: 0;
    padding: 0;
  }

  .dlTable__wrap dt, .dlTable__wrap dd {
    margin: 0;
    padding: 28px 35px;
  }

  .dlTable__wrap dt {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    width: 23%;
    text-align: left;
    border: 0;
  }

  .dlTable__wrap dt span {
    text-align: center;
  }

  .dlTable__wrap dd {
    padding-left: 4%;
    width: 77%;
  }

  .dlTable__wrap dd .btn_access {
    margin: 0;
    width: 140px;
  }
}

@media screen and (min-width: 1000px) {
  .dlTable__wrap dd {
    position: relative;
    z-index: 0;
  }

  .dlTable__wrap dd .btn_access {
    padding: 0;
    position: absolute;
    right: 18px;
    top: 20px;
  }
}

/*-- dlTable --*/
/*-- nes-grad-wrap --*/
.nes-grad-wrap {
  position: relative;
}

.nes-grad-item {
  margin-bottom: 100px;
  position: relative;
  overflow: hidden;
}

.nes-grad-item.nes-is-hide {
  margin-bottom: 30px;
  height: 625px !important;
}

.nes-grad-item.nes-is-hide::before {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  width: 100%;
  height: 190px;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.7) 50%, rgb(255, 255, 255) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#00ffffff", endColorstr="#ffffff", GradientType=0);
  z-index: 2;
}

.nes-grad-trigger {
  z-index: 2;
  position: absolute;
  bottom: 0;
  left: calc(50% - 95px);
  text-align: center;
  margin: 0 !important;
}

.nes-grad-trigger span {
  display: inline-block;
  padding: 0 20px;
  line-height: 44px;
  border: 1px solid #595757;
  color: #595757;
  font-size: 1.4rem;
  text-align: center;
  cursor: pointer;
  transition: 0.2s ease;
  min-width: 190px;
  background: #FFF;
}

.nes-grad-trigger span::before {
  content: "続きを見る";
}

.nes-grad-trigger span::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  margin: 0 0 3px 10px;
  border-right: 1px solid #595757;
  border-bottom: 1px solid #595757;
  transform: rotate(45deg);
}

.nes-grad-trigger.nes-is-show {
  position: static;
}

.nes-grad-trigger.nes-is-show {
  FONT-VARIANT: JIS83;
  position: absolute;
  top: 100%;
}

.nes-grad-trigger.nes-is-show span {
  color: #FFF;
  background: #595757;
  border: 1px solid #595757;
}

.nes-grad-trigger.nes-is-show span::before {
  content: "閉じる";
}

.nes-grad-trigger.nes-is-show span::after {
  transform: rotate(225deg);
  margin: 0 0 -2px 10px;
  border-right: 1px solid #FFF;
  border-bottom: 1px solid #FFF;
}

@media screen and (min-width: 768px) {
  .nes-grad-item.nes-is-hide {
    margin-bottom: 30px;
    height: 530px !important;
  }
}

/*-- nes-grad-wrap --*/
/*--- body ---*/
body.fixed {
  position: fixed;
}

/*--- body ---*/
/*--- wrapper ---*/
.wrapper {
  width: 100%;
  margin: 0 auto;
  padding: 60px 0 0;
  overflow: hidden;
}

@media screen and (min-width: 768px) {
  .wrapper {
    padding: 128px 0 0;
  }
}

/*--- wrapper ---*/
/*--- site-header ---*/
.site-header {
  display: block;
  padding: 0;
  width: 100%;
  background-color: #fff;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 999;
}

@media screen and (min-width: 768px) {
  .site-header {
    position: absolute;
  }
}

/*--- site-header ---*/
/*--- site-footer ---*/
.site-footer {
  margin: 0;
  padding: 0;
  background-color: #F9F9F9;
  border-top: 1px solid #DCDDDD;
}

/*--- site-footer ---*/
/*--- 固定ページ ---*/
.page-header__in {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 139px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}

.page-header__in h1 {
  margin: 0;
}

.page-header__in h1 span {
  display: block;
  padding: 6px 0;
  color: #fff;
  text-align: center;
  line-height: 1;
}

.page-header__in h1 span.ja {
  font-size: 24px;
  font-weight: 700;
}

.page-header__in h1 span.en {
  font-size: 12px;
  font-weight: 400;
}

.page-content {
  margin: 0 auto;
  padding: 30px 15px;
  width: 100%;
  max-width: 970px;
}

@media screen and (min-width: 768px) {
  .page-header__in {
    width: 100%;
    height: 224px;
  }

  .page-header__in h1 span {
    padding: 14px 0;
  }

  .page-header__in h1 span.ja {
    font-size: 38px;
    font-weight: 700;
  }

  .page-header__in h1 span.en {
    font-size: 13px;
    font-weight: 400;
  }

  .page-content {
    padding: 45px 20px;
  }
}

/*--- 固定ページ ---*/
@media screen and (max-width: 767px) {
  .logoWrap {
    display: flex;
    align-items: center;
    padding: 4px 10px 0;
    width: 100%;
    height: 60px;
  }

  .logoWrap img {
    width: 210px;
  }

  .naviWrap {
    display: block;
    width: 100%;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.4);
    position: fixed;
    left: 0;
    top: 0;
    opacity: 0;
    transition: all 0.6s ease;
    pointer-events: none;
  }

  .menu-open .naviWrap {
    opacity: 1;
    pointer-events: all;
  }

  nav.sp_only {
    margin: 0 0 0 auto;
    width: 73%;
    height: 100%;
    background-color: #fff;
    position: fixed;
    right: -100%;
    top: 0;
    z-index: 0;
    transition: all 0.6s ease;
  }

  .menu-open nav.sp_only {
    right: 0;
  }

  .closeButton {
    width: 100%;
    height: 60px;
    background-color: #3BBEC3;
  }

  .headerNavigation_sp {
    margin: 0 auto;
    padding: 0;
    width: 100%;
    height: calc(100% - 60px);
    overflow-y: auto;
    position: absolute;
    left: 0;
    top: 60px;
    z-index: 0;
  }

  .headerNavigation_sp li {
    margin: 0;
    padding: 0;
  }

  .headerNavigation_sp li::before, .headerNavigation_sp li::after {
    content: none;
  }

  .headerNavigation_sp li span, .headerNavigation_sp li a {
    display: block;
    margin: 0;
    padding: 14px 28px;
    width: 100%;
    color: #3BBEC3;
    font-size: 18px;
    font-weight: 700;
    background-color: #fff;
    border-bottom: 1px solid #DCDDDD;
    position: relative;
    z-index: 0;
  }

  .headerNavigation_sp li span::after, .headerNavigation_sp li a::after {
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    border-right: 2px solid #505050;
    border-bottom: 2px solid #505050;
    position: absolute;
    right: 25px;
    top: calc(50% - 4px);
    transform: rotate(-45deg);
  }

  .headerNavigation_sp li span.js-accordion-btn::after, .headerNavigation_sp li a.js-accordion-btn::after {
    transform: rotate(45deg);
  }

  .headerNavigation_sp li span.js-accordion-btn.open::after, .headerNavigation_sp li a.js-accordion-btn.open::after {
    transform: rotate(225deg);
  }

  .headerNavigation_sp .children {
    display: none;
    margin: 0;
    padding: 0;
  }

  .headerNavigation_sp .children li {
    margin: 0;
    padding: 0;
  }

  .headerNavigation_sp .children li.children_child span {
    font-weight: bold;
    color: #333;
  }

  .headerNavigation_sp .children li.children_child span:before {
    display: none;
  }

  .headerNavigation_sp .children li.children_child a {
    padding: 15px 28px 15px 64px;
  }

  .headerNavigation_sp .children li.children_child a:before {
    left: 50px;
  }

  .headerNavigation_sp .children li span, .headerNavigation_sp .children li a {
    padding: 15px 28px 15px 45px;
    color: #383838;
    font-size: 16px;
    font-weight: 700;
    background-color: rgba(59, 190, 195, 0.1);
    border-bottom: 1px solid #DCDDDD;
  }

  .headerNavigation_sp .children li span::before, .headerNavigation_sp .children li a::before {
    content: "";
    display: block;
    margin: 0;
    padding: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 5px 0 5px 5px;
    border-color: transparent transparent transparent #808080;
    position: absolute;
    left: 32px;
    top: calc(50% - 3px);
    z-index: 0;
  }

  .headerNavigation_sp .children li span::after, .headerNavigation_sp .children li a::after {
    content: none;
  }

  .headerNavigation_sp li.sp_style {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    padding: 30px;
  }

  .headerNavigation_sp li.sp_style a {
    display: block;
    margin: 0 0 14px;
    padding: 0;
    color: #383838;
    font-size: 12px;
    font-weight: 400;
    line-height: 1;
    background-color: #fff;
    border: 0;
  }

  .headerNavigation_sp li.sp_style a::before {
    content: none;
  }

  .headerNavigation_sp li.sp_style a::after {
    content: none;
  }

  .headerNavigation_sp li.sp_style a:nth-of-type(1) {
    width: 40%;
  }

  .headerNavigation_sp li.sp_style a:nth-of-type(2) {
    width: 60%;
  }

  .headerNavigation_sp li.sp_style a:nth-of-type(3) {
    width: 100%;
  }
}

@media screen and (min-width: 768px) {
  .site-header {
    padding: 6px 26px;
  }

  .headerDescription {
    margin-bottom: 16px;
    font-size: 13px;
    margin-top: 5px;
    color: #808080;
  }

  .site-header__in {
    display: flex;
    align-items: center;
  }

  .logoWrap {
    padding: 0;
    width: 100%;
  }

  .logoWrap img {
    display: block;
    margin: 0;
    width: 250px;
  }

  nav.pc_only {
    padding: 12px 8px 0 0;
  }

  nav.pc_only ul, nav.pc_only li {
    margin: 0;
    padding: 0;
  }

  nav.pc_only ul {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 400px;
  }

  nav.pc_only li::before, nav.pc_only li::after {
    content: none;
  }

  nav.pc_only a {
    display: block;
    padding: 0 3px 13px;
    text-align: center;
    line-height: 1;
    border-bottom: 1px solid #fff;
  }

  nav.pc_only a .ja {
    display: block;
    width: 100%;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.1em;
  }

  nav.pc_only a .en {
    display: block;
    margin-top: 6px;
    width: 100%;
    font-size: 12px;
    font-weight: 400;
  }

  nav.pc_only a:hover {
    color: #3BBEC3;
    text-decoration: none;
    border-bottom: 1px solid #3BBEC3;
  }
}

@media screen and (min-width: 992px) {
  .site-header {
    padding: 30px 56px 24px;
  }

  .logoWrap img {
    width: 340px;
  }

  .naviWrap {
    padding-top: 5px;
  }

  nav.pc_only ul {
    width: 475px;
  }
}

.footerNavigation {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  max-width: 1220px;
}

.footerNavigation li {
  margin: 0 !important;
  padding: 0 !important;
}

.footerNavigation li::before, .footerNavigation li::after {
  content: none !important;
}

.footerNavigation li span,
.footerNavigation li a {
  display: block;
  margin: 0;
  padding: 14px 28px;
  width: 100%;
  color: #3bbec3;
  font-size: 18px;
  font-weight: 700;
  background-color: #fff;
  border-bottom: 1px solid #dcdddd;
  position: relative;
  z-index: 0;
}

.footerNavigation li span::after,
.footerNavigation li a::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-right: 2px solid #505050;
  border-bottom: 2px solid #505050;
  position: absolute;
  right: 25px;
  top: calc(50% - 4px);
  transform: rotate(-45deg);
}

.footerNavigation li span.js-accordion-btn::after,
.footerNavigation li a.js-accordion-btn::after {
  transform: rotate(45deg);
}

.footerNavigation li span.js-accordion-btn.open::after,
.footerNavigation li a.js-accordion-btn.open::after {
  transform: rotate(225deg);
}

.footerNavigation li a:hover {
  text-decoration: none;
  opacity: 0.7;
}

.footerNavigation .children {
  display: none;
  margin: 0;
  padding: 0;
}

.footerNavigation .children li {
  margin: 0;
  padding: 0;
}

.footerNavigation .children li::before, .footerNavigation .children li::after {
  content: none;
}

.footerNavigation .children li span,
.footerNavigation .children li a {
  padding: 15px 28px 15px 48px;
  color: #383838;
  font-size: 16px;
  font-weight: 400;
  background-color: rgba(59, 190, 195, 0.1);
  border-bottom: 1px solid #dcdddd;
}

.footerNavigation .children li span::before,
.footerNavigation .children li a::before {
  content: "";
  display: block;
  margin: 0;
  padding: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 0 5px 5px;
  border-color: transparent transparent transparent #808080;
  position: absolute;
  left: 34px;
  top: calc(50% - 3px);
  z-index: 0;
}

.footerNavigation .children li span::after,
.footerNavigation .children li a::after {
  content: none;
}

.footer02 {
  padding: 36px 30px 30px;
}

.footer02 .logo {
  display: block;
  margin: auto;
}

.footer02 .logo img {
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 25px;
  width: 225px;
  height: 36px;
}

.footer02 .nj {
  display: block;
  margin: auto;
  margin-bottom: 25px;
}

.footer02 .nj_sp img {
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 25px;
}

.footer02 .list {
  line-height: 1.7;
}

#copyright {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  height: 77px;
  color: #fff;
  font-size: 13px;
  text-align: center;
  background-color: #3bbec3;
}

@media screen and (max-width: 767px) {
  .footerNavigation li li.children_child span {
    font-weight: bold;
    color: #333;
  }

  .footerNavigation li li.children_child span:before {
    display: none;
  }

  .footerNavigation li li.children_child a {
    padding: 15px 28px 15px 64px;
  }

  .footerNavigation li li.children_child a:before {
    left: 50px;
  }

  .footerNavigation li.sp_style {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 30px !important;
  }

  .footerNavigation li.sp_style span,
  .footerNavigation li.sp_style a {
    display: block;
    margin: 0;
    padding: 8px 0;
    width: auto;
    color: #383838;
    font-size: 12px;
    font-weight: 400;
    align-items: center;
    background-color: transparent;
    border: 0;
  }

  .footerNavigation li.sp_style span::before,
  .footerNavigation li.sp_style a::before {
    content: none;
  }

  .footerNavigation li.sp_style span::after,
  .footerNavigation li.sp_style a::after {
    content: none;
  }
}

@media screen and (min-width: 768px) {
  .footer01 {
    margin: 0 auto;
    padding: 40px 20px 0;
    width: 100%;
    max-width: 1040px;
  }

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

  .footerNavigation li:nth-of-type(1) {
    width: 13%;
  }

  .footerNavigation li:nth-of-type(2) {
    width: 23%;
  }

  .footerNavigation li:nth-of-type(3) {
    width: 18%;
  }

  .footerNavigation li:nth-of-type(4) {
    width: 18%;
  }

  .footerNavigation li:nth-of-type(5) {
    width: 11%;
  }

  .footerNavigation li:nth-of-type(6) {
    flex: 1;
  }

  .footerNavigation li li.children_child span {
    width: 100%;
    padding: 0;
  }

  .footerNavigation li li.children_child span:before {
    display: none;
  }

  .footerNavigation li span,
  .footerNavigation li a {
    margin-bottom: 24px;
    padding: 0;
    font-size: 14px;
    line-height: 1;
    background: none;
    border: 0;
  }

  .footerNavigation li span:before, .footerNavigation li span::after,
  .footerNavigation li a:before,
  .footerNavigation li a::after {
    content: none;
  }

  .footerNavigation .children {
    display: block !important;
  }

  .footerNavigation .children li {
    display: block;
    width: auto !important;
  }

  .footerNavigation .children li span,
  .footerNavigation .children li a {
    margin-bottom: 14px;
    padding: 0 0 0 16px;
    font-size: 12px;
    line-height: 1;
    background: none;
    border: 0;
  }

  .footerNavigation .children li span:before,
  .footerNavigation .children li a:before {
    content: "";
    left: 0;
    top: 2px;
  }

  .footer02 {
    display: flex;
    align-items: center;
    margin: 0 auto;
    padding: 40px 20px 30px;
    width: 100%;
    max-width: 1040px;
  }

  .footer02 .logo img {
    width: 270px;
    height: 43px;
  }

  .footer02 .address {
    padding: 0 0 0 30px;
  }
}

@media screen and (min-width: 992px) {
  .footer01 {
    padding: 90px 20px 0;
  }

  .footerNavigation li span,
  .footerNavigation li a {
    font-size: 16px;
  }

  .footerNavigation .children li span,
  .footerNavigation .children li a {
    font-size: 15px;
  }

  .footer02 {
    padding: 70px 20px 75px;
  }
}

/* -------------------------------------------------
ページトップ
------------------------------------------------- */
#pagetop {
  position: fixed;
  right: 10px;
  bottom: 40px;
  z-index: 99;
}

#pagetop a {
  display: block;
}

#pagetop a img {
  display: block;
  width: 150px;
  height: 60px;
  transition: all 0.6s ease;
}

#pagetop a:hover {
  opacity: 1;
}

#pagetop a:hover img {
  opacity: 1;
  animation: mover 1s 1 alternate;
}

@media screen and (min-width: 768px) {
  #pagetop {
    right: 40px;
    bottom: 40px;
  }

  #pagetop a img {
    width: 220px;
    height: 80px;
  }
}

@keyframes mover {
  0% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-10px);
  }

  100% {
    transform: translateY(0);
  }
}

#hamburger_button {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin: 0;
  padding: 0 0 5px;
  width: 60px;
  height: 60px;
  color: #fff;
  font-size: 10px;
  background-color: #3BBEC3;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 100;
  cursor: pointer;
}

#hamburger_button span {
  display: block;
  width: 49%;
  height: 2px;
  background-color: #fff;
  position: absolute;
  left: 25%;
  top: 42%;
  transform: translateY(-50%);
}

#hamburger_button span::before, #hamburger_button span::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-color: #fff;
  position: absolute;
  left: 0;
  transition: 0.6s;
}

#hamburger_button span::before {
  top: -7px;
}

#hamburger_button span::after {
  top: 7px;
}

.menu-open #hamburger_button span {
  background-color: transparent;
}

.menu-open #hamburger_button span::before {
  top: 0;
  transform: rotate(45deg);
}

.menu-open #hamburger_button span::after {
  top: 0;
  transform: rotate(-45deg);
}

#breadcrumb {
  margin: 0 auto;
  padding: 8px 0;
  background-color: #F9F9F9;
}

#breadcrumb .breadcrumb__in {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  margin: 0 auto;
  padding: 0 15px;
  width: 100%;
  max-width: 1230px;
  line-height: 1.2;
}

#breadcrumb span, #breadcrumb a {
  display: block;
  margin: 0;
  padding: 0 19px;
  color: #111;
  font-size: 12px;
  font-weight: 400;
  position: relative;
  z-index: 0;
}

#breadcrumb span::after, #breadcrumb a::after {
  content: "";
  display: block;
  width: 7px;
  height: 7px;
  border-right: 1px solid #898989;
  border-bottom: 1px solid #898989;
  transform: rotate(-45deg);
  position: absolute;
  left: calc(100% - 3px);
  top: calc(50% - 4px);
}

#breadcrumb a {
  color: #00B4FD;
}

#breadcrumb a.home {
  padding-left: 0;
}

#breadcrumb span.current {
  padding-right: 0;
}

#breadcrumb span.current::after {
  content: none;
}

@media screen and (min-width: 768px) {
  #breadcrumb {
    margin-top: 0;
    padding: 8px 0;
  }

  #breadcrumb .breadcrumb__in {
    padding: 0 20px;
  }

  #breadcrumb span, #breadcrumb a {
    font-size: 13px;
  }
}

button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
}

.button_green {
  position: relative;
  display: block;
  background: #43b6bc;
  width: 100%;
  max-width: 380px;
  padding: 30px;
  font-family: inherit;
  font-size: 24px;
  font-weight: bold;
  color: #fff;
  margin: 50px auto 0;
  cursor: pointer;
  z-index: 1;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .button_green {
    width: calc(100% - 30px);
    font-size: 20px;
  }
}

.button_green:hover {
  opacity: 0.4;
  text-decoration: none;
  color: #fff;
}

.button_green::before {
  position: absolute;
  content: "";
  bottom: -5px;
  right: -5px;
  width: 3px;
  height: 100%;
  background: #43b6bc;
}

.button_green::after {
  position: absolute;
  content: "";
  bottom: -5px;
  right: -5px;
  width: 100%;
  height: 3px;
  background: #43b6bc;
}

.button_green span {
  width: 100%;
  display: block;
}

.button_green span.arrow {
  position: relative;
  color: #fff;
}

.button_green span.arrow::before {
  content: "";
  width: 24px;
  height: 24px;
  background-image: url(../images/common/icon_arw2.svg);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  position: absolute;
  right: -15px;
  top: 50%;
  transform: translateY(-50%);
}

.button_green_radius {
  position: relative;
  display: block;
  background: #43b6bc;
  width: 100%;
  max-width: 335px;
  padding: 10px 30px;
  margin: 10px auto 0;
  font-family: inherit;
  font-size: 18px;
  font-weight: bold;
  color: #fff;
  cursor: pointer;
  z-index: 1;
  border-radius: 30px;
  text-align: center;
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
}

.button_green_radius:hover {
  opacity: 0.4;
  text-decoration: none;
  color: #fff;
}

.button_green_radius span {
  width: 100%;
  display: block;
}

.button_green_radius span.arrow {
  position: relative;
}

.button_green_radius span.arrow::before {
  content: "";
  width: 24px;
  height: 24px;
  background-image: url(../images/common/icon_arw2.svg);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  position: absolute;
  right: -15px;
  top: 50%;
  transform: translateY(-50%);
}

.button_gray {
  position: relative;
  display: block;
  background: #adadad;
  width: 100%;
  max-width: 300px;
  padding: 20px 30px;
  font-family: inherit;
  font-size: clamp(1.8rem, 2vw + 1rem, 2rem);
  font-weight: bold;
  color: #fff;
  margin: 50px auto 0;
  cursor: pointer;
  z-index: 1;
}

.button_gray span {
  width: 100%;
  display: block;
}

.button_gray span.arrow {
  position: relative;
}

.button_gray span.arrow::before {
  content: "";
  width: 24px;
  height: 24px;
  background-image: url(../images/common/icon_arw4.svg);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  position: absolute;
  left: -15px;
  top: 50%;
  transform: translateY(-50%);
}

.button_gray:hover {
  opacity: 0.4;
}

/*--------------------------------------------------------------
PAGES
--------------------------------------------------------------*/
.mainVisual ul, .mainVisual li {
  margin: 0;
  padding: 0;
}

.mainVisual li {
  position: relative;
  z-index: 0;
}

.mainVisual li::before, .mainVisual li::after {
  content: none;
}

.mainVisual span {
  display: block;
  margin: 0;
  padding: 20px;
  width: 100%;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.423;
  position: absolute;
}

.mainVisual span.msg01 {
  color: #fff;
  text-align: center;
  left: 0;
  bottom: 25px;
}

.mainVisual span.msg02 {
  color: #fff;
  text-align: left;
  left: 6px;
  top: 3px;
}

.mainVisual span.msg03 {
  color: #000;
  text-align: center;
  left: 0;
  bottom: 27px;
}

.mainVisual .slick-dotted.slick-slider {
  margin: 0;
}

.mainVisual .slick-dots {
  position: absolute;
  bottom: 13px;
  left: 0;
  z-index: 100;
}

.mainVisual .slick-dots li {
  margin: 0 8px;
}

.mainVisual .slick-dots li button:before {
  color: #fff;
  font-size: 15px;
  opacity: 1;
}

.mainVisual .slick-dots li.slick-active button:before {
  color: #898989;
  opacity: 1;
}

.toppage .page-content {
  padding: 0;
  max-width: none;
}

.toppage__information .corporateinfo, .toppage__information .business {
  padding: 0;
  overflow: hidden;
  transition: all 1s ease;
}

.toppage__information .corporateinfo__in, .toppage__information .business__in {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}

.toppage__information .corporateinfo img, .toppage__information .business img {
  display: block;
}

.toppage__information .corporateinfo:hover img, .toppage__information .business:hover img {
  transform: scale(1.1);
}

.toppage__information .corporateinfo a, .toppage__information .business a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 0;
}

.toppage__information .corporateinfo a:hover, .toppage__information .business a:hover {
  text-decoration: none;
  opacity: 0.7;
}

.toppage__information .corporateinfo .box, .toppage__information .business .box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin: 0;
  width: 335px;
  height: 335px;
  color: #fff;
  text-align: center;
  background-image: url(../images/toppage/infoBox_bg.svg);
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
}

.toppage__information .corporateinfo .box .title, .toppage__information .business .box .title {
  margin: 0 auto 15px;
  padding: 0;
  width: 160px;
  background: none;
  border: 0;
}

.toppage__information .corporateinfo .box .title::before, .toppage__information .business .box .title::before {
  content: none;
}

.toppage__information .corporateinfo .box .title .ja, .toppage__information .business .box .title .ja {
  display: block;
  font-size: 27px;
}

.toppage__information .corporateinfo .box .title .en, .toppage__information .business .box .title .en {
  display: block;
  font-size: 12px;
}

.toppage__information .corporateinfo .box .msg, .toppage__information .business .box .msg {
  margin: 0 auto;
  width: 160px;
  font-size: 12px;
}

.toppage__concept {
  background-image: url(../images/toppage/sp/concept_bg.jpg);
  background-repeat: no-repeat;
  background-position: 50% 100%;
  background-size: cover;
}

.toppage__concept__wrap {
  padding: 50px 25px 255px;
}

.toppage__concept__wrap>div {
  box-shadow: 8px 8px 6px rgba(71, 71, 71, 0.15);
}

.toppage__concept__wrap>div:not(:last-child) {
  margin-bottom: 27px;
}

.toppage__concept a {
  display: block;
  margin: 0 auto;
  padding: 0;
  width: 100%;
  background-color: #fff;
}

.toppage__concept a:hover {
  text-decoration: none;
}

.toppage__concept a:hover img {
  transform: scale(1.1);
}

.toppage__concept figure {
  overflow: hidden;
}

.toppage__concept img {
  display: block;
  width: 100%;
  transition: all 0.6s ease;
}

.toppage__concept .meta {
  padding: 16px 50px 16px 20px;
  background-image: url(../images/common/icon_arw1.svg);
  background-repeat: no-repeat;
  background-position: 93% 50%;
  background-size: 26px 26px;
}

.toppage__concept .title {
  margin: 0 0 5px;
  padding: 0;
  color: #3BBEC3;
  font-size: 17px;
  font-weight: 700;
}

.toppage__concept .title::before {
  content: none;
}

.toppage__concept .excerpt {
  margin: 0;
  color: #898989;
  font-size: 14px;
}

@media screen and (min-width: 768px) {
  .mainVisual li {
    height: 665px;
    background-repeat: no-repeat;
    background-position: 50% 0;
    background-size: auto 100%;
    position: relative;
    z-index: 0;
  }

  .mainVisual li.slideItem_01 {
    background-image: url(../images/toppage/mv1.jpg);
  }

  .mainVisual li.slideItem_02 {
    background-image: url(../images/toppage/mv2.jpg);
  }

  .mainVisual li.slideItem_03 {
    background-image: url(../images/toppage/mv3.jpg);
  }

  .mainVisual span {
    display: block;
    margin: 0;
    padding: 20px;
    width: 100% !important;
    font-size: 44px;
    font-weight: 700;
    line-height: 1.423;
    position: absolute;
  }

  .mainVisual span.msg01 {
    color: #fff;
    text-align: center;
    left: 50%;
    bottom: 62px;
    transform: translateX(-50%);
  }

  .mainVisual span.msg02 {
    color: #fff;
    text-align: left;
    left: 50px;
    top: 128px;
  }

  .mainVisual span.msg03 {
    color: #000;
    text-align: center;
    left: 50%;
    top: 57%;
    transform: translate(-50%, -50%);
  }

  .mainVisual .slick-dots li {
    margin: 0 8px;
    height: auto;
  }

  .toppage__information {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: space-between;
    margin: 0 auto;
    padding: 88px 0 88px;
    max-width: 1220px;
  }

  .toppage__information .corporateinfo, .toppage__information .business {
    padding: 0;
  }

  .toppage__information .corporateinfo .box, .toppage__information .business .box {
    width: 320px;
    height: 320px;
  }

  .toppage__information .corporateinfo .box .title, .toppage__information .business .box .title {
    margin: 0 auto 30px;
    width: auto;
  }

  .toppage__information .corporateinfo .box .title .ja, .toppage__information .business .box .title .ja {
    font-size: 28px;
  }

  .toppage__information .corporateinfo .box .title .en, .toppage__information .business .box .title .en {
    font-size: 14px;
  }

  .toppage__information .corporateinfo .box .msg, .toppage__information .business .box .msg {
    width: auto;
    font-size: 12px;
  }

  .toppage__information .corporateinfo {
    width: 50%;
  }

  .toppage__information .business {
    width: 50%;
  }

  .toppage__concept {
    background-image: url(../images/toppage/concept_bg.jpg);
  }

  .toppage__concept__wrap {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: space-between;
    margin: 0 auto;
    padding: 90px 30px 406px;
    max-width: 1280px;
  }

  .toppage__concept__wrap>div {
    margin: 0 !important;
    width: 32%;
  }

  .toppage__concept .meta {
    padding: 30px 50px 24px 20px;
  }
}

@media screen and (min-width: 992px) {
  .toppage .site-header .headerDescription {
    position: absolute;
    left: 56px;
    top: 0;
    margin-top: 5px;
    color: #808080;
  }

  .toppage__information .corporateinfo .box, .toppage__information .business .box {
    width: 420px;
    height: 420px;
  }

  .toppage__information .corporateinfo .box .title .ja, .toppage__information .business .box .title .ja {
    font-size: 34px;
  }

  .toppage__information .corporateinfo .box .title .en, .toppage__information .business .box .title .en {
    font-size: 16px;
  }

  .toppage__information .corporateinfo .box .msg, .toppage__information .business .box .msg {
    font-size: 14px;
  }
}

@media screen and (min-width: 1200px) {
  .toppage__information .corporateinfo .box, .toppage__information .business .box {
    width: 486px;
    height: 486px;
  }
}

.advantage .page-header__in {
  background-image: url(../images/advantage/mv.jpg);
}

.advantage figcaption {
  margin: 0;
  padding: 3px 0;
  font-size: 13px;
  text-align: center;
  line-height: 1.5;
}

.advantage p {
  font-size: 16px;
  line-height: 1.75;
}

.advantage .intro {
  margin-bottom: 36px;
  padding: 6px 0;
}

.advantage .intro__Title {
  margin-bottom: 20px;
  text-align: center;
}

.advantage .intro__Title span {
  display: inline-block;
  color: #26B7BC;
  font-size: 37px;
  line-height: 1;
  position: relative;
  z-index: 0;
}

.advantage .intro__Title span:not(:last-child) {
  margin-right: 45px;
}

.advantage .intro__Title span:not(:last-child)::after {
  content: "";
  display: block;
  width: 25px;
  height: 25px;
  background-image: url(../images/advantage/icon01.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  position: absolute;
  left: calc(100% + 15px);
  top: 50%;
  transform: translateY(-50%);
}

.advantage .intro__Text {
  color: #26B7BC;
  font-size: 16px;
}

.advantage .block__Number {
  padding-left: 20px;
  color: #26B7BC;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.1em;
  background-image: url(../images/advantage/icon02.svg);
  background-repeat: no-repeat;
  background-position: 0 60%;
  background-size: 10px auto;
}

.advantage .block__Number .num {
  padding-left: 5px;
  font-size: 20px;
  font-weight: 700;
}

.advantage .block__Title {
  margin: 0 0 6px;
  padding: 0;
  color: #26B7BC;
  font-size: 21px;
  font-weight: 500;
  line-height: 1.5;
  background: none;
  border: 0;
}

.advantage .block__Title::before, .advantage .block__Title::after {
  content: none;
}

.advantage .block.bl01 {
  margin-bottom: 50px;
}

.advantage .block.bl01 .txtBox {
  margin-bottom: -8px;
}

.advantage .block.bl01 .imgBox figure:nth-of-type(1) {
  margin: 0 -40px;
  width: calc(100% + 80px);
}

.advantage .block.bl01 .imgBox figure:nth-of-type(2) {
  margin-top: -30px;
}

.advantage .block.bl02 {
  margin-bottom: 25px;
}

.advantage .block.bl02 .imgBox {
  margin-bottom: 10px;
}

.advantage .block.bl02 .imgBox__in {
  display: flex;
}

.advantage .block.bl02 .imgBox__in>div {
  width: 50%;
}

.advantage .block.bl02 .txtBox {
  margin-bottom: 7px;
}

@media screen and (min-width: 768px) {
  .advantage .intro {
    margin-bottom: 40px;
    padding: 22px 0;
  }

  .advantage .intro__Title span {
    font-size: 102px;
  }

  .advantage .intro__Title span:not(:last-child) {
    margin-right: 154px;
  }

  .advantage .intro__Title span:not(:last-child)::after {
    width: 70px;
    height: 70px;
    left: calc(100% + 40px);
  }

  .advantage .intro__Text {
    text-align: center;
    font-size: 23px;
  }

  .advantage .block__Number {
    font-size: 13px;
  }

  .advantage .block__Title {
    margin-bottom: 14px;
    font-size: 42px;
  }

  .advantage .block.bl01 {
    margin-bottom: 70px;
  }

  .advantage .block.bl01 .flexBox {
    display: flex;
    flex-wrap: wrap;
    position: relative;
    z-index: 0;
  }

  .advantage .block.bl01 .txtBox {
    width: 53%;
  }

  .advantage .block.bl01 .txtBox p {
    margin-bottom: 30px;
  }

  .advantage .block.bl01 .txtBox figure {
    height: 160px;
    position: relative;
    z-index: 0;
  }

  .advantage .block.bl01 .txtBox figure img {
    width: 52vw;
    max-width: 660px;
    position: absolute;
    right: 0;
    top: 0;
  }

  .advantage .block.bl01 .imgBox {
    width: 47%;
    padding-left: 10px;
  }

  .advantage .block.bl01 .imgBox figure:nth-of-type(1) {
    margin: 0;
    width: 100%;
    height: 500px;
    position: relative;
    z-index: 0;
  }

  .advantage .block.bl01 .imgBox img {
    width: 48vw;
    max-width: 660px;
    position: absolute;
    left: -22px;
    top: -14px;
  }

  .advantage .block.bl02 {
    display: flex;
    flex-direction: row-reverse;
    margin-bottom: 205px;
  }

  .advantage .block.bl02 .in {
    width: 80%;
  }

  .advantage .block.bl02 .imgBox {
    margin-bottom: 24px;
  }

  .advantage .block.bl02 .pictBox {
    width: 20%;
    position: relative;
    z-index: 0;
  }

  .advantage .block.bl02 .pictBox picture {
    display: block;
    width: 23vw;
    max-width: 294px;
    position: absolute;
    right: 29%;
    top: 0;
  }
}

.businessinformation .page-header__in {
  background-image: url(../images/businessinformation/mv.jpg);
}

.businessinformation .lead {
  margin-bottom: 14px;
  font-size: 16px;
}

.businessinformation .listBox {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 -15px 50px;
}

.businessinformation .listBox .elem {
  margin: 10px 15px;
  padding: 0;
  width: 100%;
  box-shadow: 3px 3px 8px #999;
}

.businessinformation .listBox .elem a {
  display: block;
  padding: 0;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 0;
  overflow: hidden;
}

.businessinformation .listBox .elem a:hover {
  text-decoration: none;
}

.businessinformation .listBox .elem a:hover img {
  transform: scale(1.1);
}

.businessinformation .listBox .elem a:hover .textBox::after {
  right: 17px;
}

.businessinformation .listBox .elem img {
  display: block;
  transition: all 0.3s ease;
}

.businessinformation .listBox .elem .innerBox {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: calc(100% - 60px);
  height: calc(100% - 60px);
  position: absolute;
  left: 30px;
  top: 30px;
}

.businessinformation .listBox .textBox {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 50px 30px;
  width: 100%;
  height: 100%;
  color: #fff;
  background-color: rgba(0, 128, 128, 0.8);
  position: relative;
  z-index: 0;
}

.businessinformation .listBox .textBox::after {
  content: "";
  display: block;
  width: 19px;
  height: 19px;
  background-image: url(../images/businessinformation/icon_arw.png);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  position: absolute;
  right: 20px;
  bottom: 20px;
  transition: all 0.3s ease;
}

.businessinformation .listBox .title {
  margin: 0 0 20px;
  padding: 0;
  color: #fff;
  font-size: 19px;
  letter-spacing: 0.01em;
}

.businessinformation .listBox .title::before {
  content: none;
}

.businessinformation .listBox .description {
  font-size: 14px;
  line-height: 1.785;
  letter-spacing: 0.01em;
}

@media screen and (min-width: 768px) {
  .businessinformation .lead {
    margin-top: 46px;
    margin-bottom: 54px;
  }

  .businessinformation .listBox .elem.businessBlock {
    width: 100%;
  }

  .businessinformation .listBox .elem.printingBlock {
    width: 100%;
  }

  .businessinformation .listBox .elem.temporarystaffingBlock {
    width: calc(50% - 40px);
  }

  .businessinformation .listBox .elem.businessBlock .textBox {
    padding: 50px;
    width: 55%;
  }

  .businessinformation .listBox .textBox {
    padding: 50px;
  }

  .businessinformation .listBox .textBox::after {
    width: 24px;
    height: 24px;
  }

  .businessinformation .listBox .title {
    font-size: 28px;
  }

  .businessinformation .listBox .description {
    font-size: 16px;
  }
}

@media screen and (min-width: 970px) {
  .businessinformation .listBox {
    margin: 0 0 105px;
  }

  .businessinformation .listBox .elem {
    margin: 0 0 40px;
  }

  .businessinformation .listBox .elem.printingBlock {
    width: calc(50% - 20px);
  }

  .businessinformation .listBox .elem.temporarystaffingBlock {
    width: calc(50% - 20px);
  }

  .businessinformation .listBox .elem .innerBox {
    width: calc(100% - 100px);
    height: calc(100% - 100px);
    left: 50px;
    top: 50px;
  }
}

.business .page-header__in {
  background-image: url(../images/business/mv.jpg);
}

.business .page-content section:nth-of-type(1) {
  margin-bottom: 28px;
}

.business .page-content section:nth-of-type(2) {
  margin-bottom: 60px;
}

.business .page-content p {
  font-size: 16px;
  line-height: 1.75;
}

.business .page-content h4 {
  font-size: 11px;
  font-weight: 400;
}

.business .page-content ul,
.business .page-content li {
  margin: 0;
}

.business .page-content li {
  font-size: 12px;
  font-weight: 400;
  line-height: 1.9;
  position: relative;
  z-index: 0;
}

.business .page-content li a {
  text-decoration: underline;
}

.business .page-content li::before {
  display: none;
}

.business .page-content figure {
  margin-top: 16px;
}

.business .listBox {
  margin-top: 14px;
  padding: 12px;
  background-color: rgb(227, 228, 228);
  border-radius: 5px;
}

.business .listBox__in {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.business .sec01_picture {
  display: block;
  margin-top: 20px;
}

@media screen and (max-width: 767px) {
  .business .anchorLink a {
    height: 55px;
  }

  .business .page-content li {
    font-size: 14px;
  }
}

@media screen and (min-width: 768px) {
  .business .page-content {
    padding: 45px 20px 138px;
  }

  .business .page-content section {
    margin-bottom: 112px;
  }

  .business .page-content h4 {
    font-size: 14px;
  }

  .business .page-content li {
    font-size: 14px;
  }

  .business .page-content figure {
    margin: 0;
  }

  .business .listBox {
    padding: 16px;
  }

  .business .blockContent {
    margin-bottom: 120px;
  }

  .business .sec01_picture {
    margin-top: 40px;
  }

  .business__flexBox {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 30px;
    margin-bottom: 62px;
  }

  .business__flexBox>div {
    width: 47%;
  }

  .business__flexBox>div:nth-of-type(2) {
    display: flex;
    align-items: flex-end;
  }

  .business__flexBox h3 {
    margin: 0 0 14px;
  }
}

.businessintro {
  font-size: 62.5%;
}

.businessintro .page-container {
  background: #5caace;
}

.businessintro .page-title {
  font-size: 1em;
}

.businessintro .page-title img {
  display: block;
  width: 100%;
  max-width: 92.2em;
  margin: 0 auto;
  margin-bottom: 4em;
}

.businessintro .page-title2 {
  font-size: 1em;
  border: none;
}

.businessintro .page-title2 img {
  display: block;
  width: 100%;
  max-width: 74.3em;
  margin: 0 auto;
}

.businessintro .page-title2:before {
  display: none;
}

.businessintro .page-content {
  max-width: 108em;
}

.businessintro .page-content .sec {
  padding: 5em 6em;
  width: 100%;
  margin-bottom: 4em;
  background-repeat: no-repeat;
  position: relative;
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec {
    background-image: none !important;
    background-color: #fff;
  }

  .businessintro .page-content .sec::before {
    content: "";
    width: 0;
    height: 0;
    border: 3.5em solid transparent;
    border-top-color: #5caace;
    border-left-color: #5caace;
    position: absolute;
    top: 0;
    left: 0;
  }

  .businessintro .page-content .sec::after {
    content: "";
    width: 0;
    height: 0;
    border: 3.5em solid transparent;
    border-top-color: #5caace;
    border-right-color: #5caace;
    position: absolute;
    top: 0;
    right: 0;
  }
}

@media screen and (max-width: 599px) {
  .businessintro .page-content .sec {
    background-image: none !important;
    background-color: #fff;
    padding: 3em !important;
  }

  .businessintro .page-content .sec::before {
    content: "";
    width: 0;
    height: 0;
    border: 2em solid transparent;
    border-top-color: #5caace;
    border-left-color: #5caace;
    position: absolute;
    top: 0;
    left: 0;
  }

  .businessintro .page-content .sec::after {
    content: "";
    width: 0;
    height: 0;
    border: 2em solid transparent;
    border-top-color: #5caace;
    border-right-color: #5caace;
    position: absolute;
    top: 0;
    right: 0;
  }
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec .blockContent::before {
    content: "";
    width: 0;
    height: 0;
    border: 3.5em solid transparent;
    border-bottom-color: #5caace;
    border-left-color: #5caace;
    position: absolute;
    bottom: 0;
    left: 0;
  }

  .businessintro .page-content .sec .blockContent::after {
    content: "";
    width: 0;
    height: 0;
    border: 3.5em solid transparent;
    border-bottom-color: #5caace;
    border-right-color: #5caace;
    position: absolute;
    bottom: 0;
    right: 0;
  }
}

@media screen and (max-width: 599px) {
  .businessintro .page-content .sec .blockContent::before {
    content: "";
    width: 0;
    height: 0;
    border: 2em solid transparent;
    border-bottom-color: #5caace;
    border-left-color: #5caace;
    position: absolute;
    bottom: 0;
    left: 0;
  }

  .businessintro .page-content .sec .blockContent::after {
    content: "";
    width: 0;
    height: 0;
    border: 2em solid transparent;
    border-bottom-color: #5caace;
    border-right-color: #5caace;
    position: absolute;
    bottom: 0;
    right: 0;
  }
}

.businessintro .page-content .sec .row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec .row {
    margin-bottom: 3em !important;
  }
}

.businessintro .page-content .sec .row .sec_title {
  width: 100%;
  max-width: 38em;
  display: block;
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec .row .sec_title {
    max-width: 100% !important;
    margin-bottom: 3em;
  }
}

.businessintro .page-content .sec .row .sec_body {
  width: 100%;
  max-width: 46.5em;
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec .row .sec_body {
    max-width: 100% !important;
    margin-bottom: 0;
  }
}

.businessintro .page-content .sec .row .sec_subtitle {
  display: flex;
  align-items: center;
  margin-bottom: 10px;
  color: #036eb3;
  font-size: 3.2em;
  background: #ffec00;
  line-height: 1.2;
  font-weight: bold;
  font-family: "Yu Gothic medium", YuGothic Medium, "游ゴシック", "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
}

.businessintro .page-content .sec .row .sec_subtitle p {
  padding-right: 0.5em;
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec .row .sec_subtitle {
    font-size: 2.4em;
    max-width: 100% !important;
    margin-bottom: 0.5em;
  }
}

.businessintro .page-content .sec .row .sec_subtitle:before {
  content: "";
  flex-grow: 1;
  height: 1px;
  display: block;
  margin-left: 0.4em;
  background: #036eb3;
}

.businessintro .page-content .sec .row .sec_text {
  font-size: 1.5em;
  margin-bottom: 0.5em;
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec .row .sec_text {
    margin-bottom: 1em !important;
  }
}

.businessintro .page-content .sec .row .sec_box {
  padding: 0.5em;
  font-size: 1.3em;
  border-bottom: solid 1px #333;
  color: #525252;
}

.businessintro .page-content .sec .row .sec_box:first-of-type {
  border-top: solid 1px #333;
}

.businessintro .page-content .sec .row .sec_box dd {
  margin: 0;
}

.businessintro .page-content .sec .sec_picture {
  display: block;
  width: 100%;
  max-width: 88.7em;
  margin: 0 auto;
}

.businessintro .page-content .sec01 {
  background-image: url(../images/businessintro/sec01_bg.svg);
}

.businessintro .page-content .sec01 .row {
  flex-direction: row-reverse;
  margin-bottom: 3em;
}

.businessintro .page-content .sec01 .row .sec_body {
  max-width: 46.5em;
}

.businessintro .page-content .sec01 .sec_picture {
  max-width: 93em;
}

.businessintro .page-content .sec02 {
  background-image: url(../images/businessintro/sec02_bg.svg);
}

.businessintro .page-content .sec02 .sec_body {
  margin-bottom: 2em;
}

.businessintro .page-content .sec03 {
  padding: 5em 4em;
  background-image: url(../images/businessintro/sec03_bg.svg);
}

.businessintro .page-content .sec03 .row {
  flex-direction: row-reverse;
  align-items: center;
  margin-bottom: 0.5em;
}

.businessintro .page-content .sec03 .row .sec_body {
  max-width: 48em;
}

.businessintro .page-content .sec03 .row .sec_box {
  letter-spacing: -0.05em;
}

.businessintro .page-content .sec03 .sec_picture {
  max-width: 80em;
}

.businessintro .page-content .sec04 {
  padding: 6em 4em;
  background-image: url(../images/businessintro/sec04_bg.svg);
}

.businessintro .page-content .sec04 .row {
  margin-bottom: 2em;
}

.businessintro .page-content .sec04 .row .sec_title {
  width: 100%;
  max-width: 39.3em;
  display: block;
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec04 .row .sec_title {
    max-width: 100% !important;
    margin-bottom: 3em;
  }
}

.businessintro .page-content .sec04 .sec_picture {
  max-width: 88.7em;
}

.businessintro .page-content .sec05 {
  padding: 5em 5em;
  background-image: url(../images/businessintro/sec05_bg.svg);
}

.businessintro .page-content .sec05 .row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  flex-direction: row-reverse;
  margin-bottom: 2em;
}

.businessintro .page-content .sec05 .row .sec_title {
  width: 100%;
  max-width: 44.6em;
  display: block;
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec05 .row .sec_title {
    max-width: 100% !important;
    margin-bottom: 3em;
  }
}

.businessintro .page-content .sec05 .row2 {
  flex-direction: row;
  justify-content: center;
}

.businessintro .page-content .sec05 .row2 .card {
  display: block;
  max-width: 28.7em;
  margin-top: 3em;
  margin-right: 3em;
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec05 .row2 .card {
    max-width: 100% !important;
    margin: 0 0 3em 0;
  }
}

.businessintro .page-content .sec05 .row2 .card .card_title {
  font-size: 2.2em;
  line-height: 1;
  font-weight: bold;
  text-decoration: underline;
  margin-bottom: 0.5em;
  margin-top: 2em;
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec05 .row2 .card .card_title {
    font-size: 1.8em;
    max-width: 100% !important;
    margin-top: 0;
    margin-bottom: 0.5em;
  }
}

.businessintro .page-content .sec05 .row2 .card .card_text {
  margin: 0;
  font-size: 1.5em;
}

.businessintro .page-content .sec05 .row2 .sec_picture {
  display: block;
  width: 100%;
  max-width: 49em;
  margin: 0;
}

.businessintro .page-content .sec06 {
  padding: 6em 4em;
  background-image: url(../images/businessintro/sec06_bg.svg);
}

.businessintro .page-content .sec06 .row {
  margin-bottom: 2em;
}

.businessintro .page-content .sec06 .sec_picture {
  max-width: 70.4em;
}

.businessintro .page-content .sec07 {
  padding: 5em 4em;
  background-image: url(../images/businessintro/sec07_bg.svg);
}

.businessintro .page-content .sec07 .row {
  flex-direction: row-reverse;
  align-items: center;
  margin-bottom: 0.5em;
}

.businessintro .page-content .sec07 .row .sec_title_area {
  max-width: 42.5em;
}

@media screen and (max-width: 767px) {
  .businessintro .page-content .sec07 .row .sec_title_area {
    max-width: 100% !important;
    margin-bottom: 3em;
  }
}

.businessintro .page-content .sec07 .row .sec_title_area .sec_title {
  margin-bottom: 4em;
  max-width: 42.5em;
}

.businessintro .page-content .sec07 .row .sec_title_area P {
  margin-top: 0.5em;
  font-size: 1.4em;
}

.businessintro .page-content .sec07 .row .sec_text {
  font-size: 1.5em;
  margin-bottom: 3em;
}

.businessintro .page-content .sec08 {
  padding: 5.5em 6em;
  background-image: url(../images/businessintro/sec08_bg.svg);
}

.businessintro .page-content .sec08 .row .sec_title {
  max-width: 33.3em;
}

.businessintro .page-content .sec08 .row .sec_body {
  margin-top: 3em;
}

.businessintro .page-content .sec08 .row .sec_text {
  margin-bottom: 2em;
}

/*==================================
1040px以下
===================================*/
@media screen and (min-width: 768px) and (max-width: 1080px) {
  .businessintro {
    font-size: 0.9259259259vw;
  }
}

@media screen and (max-width: 599) {
  html {
    font-size: 62.5%;
  }
}

.printing .page-header__in {
  background-image: url(../images/printing/mv.jpg);
  background-position: 100% 0;
}

.printing .page-header__in h1 span {
  color: #383838;
}

.printing p {
  font-size: 16px;
}

.printing figure {
  margin-top: 20px;
  text-align: center;
}

.printing img {
  display: block;
}

@media screen and (min-width: 768px) {
  .printing .page-header__in {
    background-image: url(../images/printing/mv.jpg);
    background-position: center center;
  }

  .printing .page-content {
    padding: 105px 20px 200px;
  }

  .printing__flexBox {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 35px 0;
  }

  .printing__flexBox.d-md-reverse {
    flex-direction: row-reverse;
  }

  .printing__flexBox>div {
    width: 47%;
  }

  .printing__flexBox:nth-of-type(1)>div:nth-of-type(1) {
    padding-top: 20px;
  }

  .printing__flexBox:nth-of-type(2)>div:nth-of-type(1) {
    padding-top: 27px;
  }

  .printing figure {
    margin: 0;
  }

  .printing h3 {
    margin: 20px 0 42px;
  }
}

.temporarystaffing .page-header__in {
  background-image: url(../images/temporarystaffing/sp/mv.jpg);
}

.temporarystaffing .page-header__in h1 span {
  color: #383838;
}

.temporarystaffing .page-content.pgc01 {
  padding-bottom: 0;
}

.temporarystaffing .page-content.pgc02 {
  padding-top: 10px;
  padding-bottom: 38px;
  max-width: 100%;
  background-color: #F9F9F9;
}

.temporarystaffing .page-content.pgc03 {
  padding-top: 0;
}

.temporarystaffing__intro {
  margin-bottom: 30px;
}

.temporarystaffing__intro p {
  font-size: 16px;
  line-height: 1.75;
}

.temporarystaffing__motto {
  margin: 0 auto;
  width: 100%;
  max-width: 930px;
}

.temporarystaffing__motto figure {
  margin-top: 10px;
}

.temporarystaffing__motto img {
  display: block;
  margin: 0 auto;
  width: 94%;
}

.temporarystaffing .anchorLink {
  margin-top: 37px;
  max-width: 778px;
}

.temporarystaffing .anchorLink a {
  margin-top: -1px;
  padding: 6px;
  height: auto;
}

.temporarystaffing .anchorLink a:nth-of-type(3) {
  width: calc(100% - 1px);
}

.temporarystaffing .sectionLeadtxt {
  margin-bottom: 20px;
}

.temporarystaffing section {
  margin-bottom: 55px;
}

.temporarystaffing .dlTable {
  display: flex;
  justify-content: space-between;
  margin: 0;
  border-top: 1px solid #DCDDDD;
}

.temporarystaffing .dlTable.last {
  border-bottom: 1px solid #DCDDDD;
}

.temporarystaffing .dlTable dt, .temporarystaffing .dlTable dd {
  margin: 0;
  padding: 0;
}

.temporarystaffing .dlTable dt {
  padding: 28px 20px;
  width: 36%;
  text-align: center;
  background-color: #F9F9F9;
}

.temporarystaffing .dlTable dd {
  padding: 28px 0;
  width: 55%;
}

.temporarystaffing .dlTable dd a {
  color: #00B4FD;
}

.temporarystaffing .dlTable.style02 {
  padding: 0;
}

.temporarystaffing .dlTable.style02 dt {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 30px 10px;
  width: 55%;
}

.temporarystaffing .dlTable.style02 dd {
  display: flex;
  align-items: center;
  padding: 30px 10px;
  width: 37%;
}

.temporarystaffing .contactBlock {
  display: flex;
  flex-wrap: wrap;
  margin-top: 35px;
}

.temporarystaffing .contactBlock__ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 10px;
  width: 100%;
  height: 37px;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  background-color: #26B7BC;
}

.temporarystaffing .contactBlock__ttl .t1 {
  font-size: 16px;
}

.temporarystaffing .contactBlock__ttl .t2 {
  padding-left: 1em;
  font-size: 12px;
}

.temporarystaffing .contactBlock__tel {
  margin: 0;
  width: 100%;
  text-align: center;
}

.temporarystaffing .contactBlock__tel a {
  display: block;
  padding: 6px 30px;
}

.temporarystaffing .contactBlock__tel a:hover {
  text-decoration: none;
  opacity: 0.8;
}

.temporarystaffing .contactBlock__tel img {
  width: 100%;
}

.temporarystaffing .faqWrap {
  margin-top: 14px;
  padding: 20px 15px;
  background-color: #F9F9F9;
  border-radius: 10px;
}

.temporarystaffing .faq {
  margin: 0;
  padding: 0;
}

.temporarystaffing .faq:not(:first-child) {
  margin-top: 35px;
}

.temporarystaffing .faq h4 {
  margin-bottom: 10px;
  font-size: 17px;
}

.temporarystaffing .faq dl, .temporarystaffing .faq dt, .temporarystaffing .faq dd {
  margin: 0;
  padding: 0;
}

.temporarystaffing .faq dl {
  padding: 8px 0;
  border-bottom: 1px solid #DCDDDD;
}

.temporarystaffing .faq dt, .temporarystaffing .faq dd {
  padding: 3px 20px 3px 35px;
  font-size: 14px;
}

.temporarystaffing .faq dt {
  font-weight: 700;
  background-image: url(../images/common/icon_q.svg);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: 30px 30px;
  position: relative;
  z-index: 0;
  cursor: pointer;
}

.temporarystaffing .faq dt::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background-image: url(../images/common/icon_open.svg);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  position: absolute;
  right: 0;
  top: 4px;
}

.temporarystaffing .faq dt.open::after {
  background-image: url(../images/common/icon_close.svg);
}

.temporarystaffing .faq dd {
  display: none;
  padding-top: 12px;
  font-weight: 400;
  background-image: url(../images/common/icon_a.svg);
  background-repeat: no-repeat;
  background-position: 0 8px;
  background-size: 30px 30px;
}

.temporarystaffing .blockContent .nes-grad-item h3 {
  margin: 0 0 15px;
}

.accordion_type02:not(:first-child) {
  margin-top: 28px;
}

.accordion_type02 h4 {
  margin-top: 20px;
  font-size: 18px;
  font-weight: 400;
}

.accordion_type02 table thead {
  background-color: #F9F9F9;
}

.accordion_type02 table th, .accordion_type02 table td {
  padding: 5px;
  font-size: 12px;
  text-align: center;
  line-height: 1.625;
  vertical-align: middle;
  border: 1px solid #DCDDDD;
}

.accordion_type02 .cap1 {
  font-size: 18px;
}

.accordion_type02 .cap2 {
  padding-bottom: 30px;
  font-size: 16px;
}

@media screen and (min-width: 768px) {
  .temporarystaffing .page-header__in {
    background-image: url(../images/temporarystaffing/mv.jpg);
  }

  .temporarystaffing .page-content {
    padding: 100px 20px 190px;
  }

  .temporarystaffing .page-content.pgc02 {
    padding-top: 40px;
    padding-bottom: 40px;
  }

  .temporarystaffing__motto .flexBox {
    display: flex;
    justify-content: space-between;
  }

  .temporarystaffing__motto .flexBox>div:nth-of-type(1) {
    width: 54%;
  }

  .temporarystaffing__motto .flexBox>div:nth-of-type(2) {
    width: 40%;
  }

  .temporarystaffing__motto h3 {
    margin-bottom: 30px;
  }

  .temporarystaffing__motto h4 {
    margin-bottom: 15px;
  }

  .temporarystaffing .anchorLink {
    margin-top: 56px;
  }

  .temporarystaffing .anchorLink a {
    padding-left: 20px;
    width: 33.3333% !important;
    height: 60px;
  }

  .temporarystaffing .anchorLink a span {
    background-size: 12px 6px;
  }

  .temporarystaffing .sectionLeadtxt {
    margin-bottom: 22px;
  }

  .temporarystaffing section.sec01 {
    margin-bottom: 120px;
  }

  .temporarystaffing section.sec02 {
    margin-bottom: 118px;
  }

  .temporarystaffing section.sec03 h2 {
    margin-bottom: 34px;
  }

  .temporarystaffing .dlTable {
    padding: 0;
  }

  .temporarystaffing .dlTable dt {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 23%;
  }

  .temporarystaffing .dlTable dd {
    padding: 30px 15px 30px 0;
    width: 73%;
  }

  .temporarystaffing .dlTable.style02 {
    padding: 0;
  }

  .temporarystaffing .dlTable.style02 dt, .temporarystaffing .dlTable.style02 dd {
    padding: 25px 10px;
  }

  .temporarystaffing .dlTable.style02 dt {
    width: 39%;
  }

  .temporarystaffing .dlTable.style02 dd {
    width: 58%;
  }

  .temporarystaffing .contactBlock {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 25px;
  }

  .temporarystaffing .contactBlock>div {
    margin: 0;
    width: 47%;
  }

  .temporarystaffing .contactBlock__ttl {
    height: 76px;
  }

  .temporarystaffing .contactBlock__ttl .t1 {
    font-size: 22px;
  }

  .temporarystaffing .contactBlock__ttl .t2 {
    font-size: 16px;
  }

  .temporarystaffing .contactBlock__tel a {
    padding: 6px 60px 6px 0;
  }

  .temporarystaffing .faqBlock {
    padding: 30px 0 0;
  }

  .temporarystaffing .faqWrap {
    margin-top: 20px;
    padding: 32px 40px;
  }

  .temporarystaffing .faq {
    margin: 0;
    padding: 0;
  }

  .temporarystaffing .faq:not(:first-child) {
    margin-top: 54px;
  }

  .temporarystaffing .faq h4 {
    margin-bottom: 5px;
    font-size: 22px;
  }

  .temporarystaffing .faq dl {
    padding: 14px 0;
  }

  .temporarystaffing .faq dt, .temporarystaffing .faq dd {
    padding: 8px 70px 8px 60px;
  }

  .temporarystaffing .faq dt {
    font-size: 18px;
    background-position: 0 3px;
    background-size: 40px 40px;
  }

  .temporarystaffing .faq dt::after {
    width: 26px;
    height: 26px;
    right: 40px;
    top: 5px;
  }

  .temporarystaffing .faq dd {
    padding: 12px 70px 12px 60px;
    font-size: 16px;
    background-position: 0 8px;
    background-size: 40px 40px;
  }

  .accordion_type02:not(:first-child) {
    margin-top: 64px;
  }

  .accordion_type02 h4 {
    margin-top: 28px;
  }

  .accordion_type02 table {
    margin-bottom: 20px;
  }

  .accordion_type02 table thead tr th:nth-of-type(1) {
    width: 24%;
  }

  .accordion_type02 table thead tr th:nth-of-type(2) {
    width: 28%;
  }

  .accordion_type02 table thead tr th:nth-of-type(3) {
    width: 24%;
  }

  .accordion_type02 table thead tr th:nth-of-type(4) {
    width: 24%;
  }

  .accordion_type02 table th, .accordion_type02 table td {
    padding: 20px 10px;
    font-size: 16px;
  }

  .accordion_type02 .cap1 {
    margin-bottom: 10px;
  }

  .accordion_type02 .nes-grad-trigger.nes-is-show .damy {
    margin-top: 30px;
  }
}

@media screen and (min-width: 1000px) {
  .temporarystaffing .contactBlock__tel a {
    font-size: 55px;
  }
}

.copyright .page-header__in {
  background-image: url(../images/copyright/mv.jpg);
}

.copyright .page-header__in h1 span {
  color: #383838;
}

.copyright .page-content {
  padding: 80px 15px;
}

.copyright .page-content h3 {
  margin: 54px 0 10px;
}

.copyright .page-content ul, .copyright .page-content li {
  margin: 0;
  padding: 0;
}

.copyright .page-content ul {
  margin-top: 20px;
}

.copyright .page-content ul>li {
  margin-bottom: 6px;
  padding-left: 24px;
  line-height: 1.75;
  position: relative;
  z-index: 0;
}

.copyright .page-content ul>li::before {
  content: "";
  display: block;
  padding: 0;
  width: 6px;
  height: 6px;
  background-color: #26B7BC;
  border-radius: 50%;
  position: absolute;
  left: 8px;
  top: 11px;
}

.copyright .page-content ol, .copyright .page-content li {
  margin: 0;
  padding: 0;
}

.copyright .page-content ol {
  margin-left: 24px;
}

.copyright .page-content ol>li {
  margin-bottom: 0;
  line-height: 1.75;
  list-style-type: decimal;
}

.copyright .page-content ol>li::before, .copyright .page-content ol>li::after {
  content: none;
}

@media screen and (min-width: 768px) {
  .copyright .page-content {
    padding: 100px 15px;
  }
}

.corporateinfo .page-header__in {
  background-image: url(../images/corporateinfo/mv.jpg);
}

.corporateinfo p {
  font-size: 16px;
  line-height: 1.75;
}

.corporateinfo .intro {
  margin-bottom: 40px;
}

.corporateinfo .corporateinfo__Block {
  padding-bottom: 40px;
}

.corporateinfo .corporateinfo__Block .company, .corporateinfo .corporateinfo__Block .organization {
  margin-bottom: 20px;
  padding: 0;
  overflow: hidden;
  transition: all 1s ease;
  box-shadow: 3px 3px 8px #ddd;
}

.corporateinfo .corporateinfo__Block .company__in, .corporateinfo .corporateinfo__Block .organization__in {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}

.corporateinfo .corporateinfo__Block .company img, .corporateinfo .corporateinfo__Block .organization img {
  display: block;
}

.corporateinfo .corporateinfo__Block .company:hover img, .corporateinfo .corporateinfo__Block .organization:hover img {
  transform: scale(1.1);
}

.corporateinfo .corporateinfo__Block .company a, .corporateinfo .corporateinfo__Block .organization a {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 0;
}

.corporateinfo .corporateinfo__Block .company a:hover, .corporateinfo .corporateinfo__Block .organization a:hover {
  text-decoration: none;
  opacity: 0.7;
}

.corporateinfo .corporateinfo__Block .company .box, .corporateinfo .corporateinfo__Block .organization .box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin: 0;
  padding: 0 34px;
  width: 285px;
  height: 285px;
  color: #fff;
  background-color: rgba(0, 128, 128, 0.8);
  position: relative;
  z-index: 0;
}

.corporateinfo .corporateinfo__Block .company .box::after, .corporateinfo .corporateinfo__Block .organization .box::after {
  content: "";
  width: 24px;
  height: 24px;
  background-image: url(../images/common/icon_arw2.svg);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  position: absolute;
  right: 24px;
  bottom: 24px;
}

.corporateinfo .corporateinfo__Block .company .box .title, .corporateinfo .corporateinfo__Block .organization .box .title {
  margin: 0 auto 20px;
  padding: 0;
  font-size: 19px;
  font-weight: 500;
  background: none;
  border: 0;
}

.corporateinfo .corporateinfo__Block .company .box .title::before, .corporateinfo .corporateinfo__Block .organization .box .title::before {
  content: none;
}

.corporateinfo .corporateinfo__Block .company .box .msg, .corporateinfo .corporateinfo__Block .organization .box .msg {
  margin: 0 auto;
  font-size: 14px;
}

.corporateinfo .listBox {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 -15px 50px;
}

.corporateinfo .listBox .elem {
  margin: 10px 15px;
  padding: 0;
  width: 100%;
  box-shadow: 3px 3px 8px #999;
}

.corporateinfo .listBox .elem a {
  display: block;
  padding: 0;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 0;
  overflow: hidden;
}

.corporateinfo .listBox .elem a:hover {
  text-decoration: none;
}

.corporateinfo .listBox .elem a:hover img {
  transform: scale(1.1);
}

.corporateinfo .listBox .elem a:hover .textBox::after {
  right: 17px;
}

.corporateinfo .listBox .elem img {
  display: block;
  transition: all 0.3s ease;
}

.corporateinfo .listBox .elem .innerBox {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: calc(100% - 60px);
  height: calc(100% - 60px);
  position: absolute;
  left: 30px;
  top: 30px;
}

.corporateinfo .listBox .textBox {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 50px 30px;
  width: 100%;
  height: 100%;
  color: #fff;
  background-color: rgba(0, 128, 128, 0.8);
  position: relative;
  z-index: 0;
}

.corporateinfo .listBox .textBox::after {
  content: "";
  display: block;
  width: 19px;
  height: 19px;
  background-image: url(../images/businessinformation/icon_arw.png);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  position: absolute;
  right: 20px;
  bottom: 20px;
  transition: all 0.3s ease;
}

.corporateinfo .listBox .title {
  margin: 0 0 20px;
  padding: 0;
  color: #fff;
  font-size: 19px;
  letter-spacing: 0.01em;
}

.corporateinfo .listBox .title::before {
  content: none;
}

.corporateinfo .listBox .description {
  font-size: 14px;
  line-height: 1.785;
  letter-spacing: 0.01em;
}

@media screen and (min-width: 768px) {
  .corporateinfo .intro {
    margin-top: 54px;
    margin-bottom: 52px;
  }

  .corporateinfo .corporateinfo__Block {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: space-between;
    margin: 0 auto 160px;
    padding: 0;
    max-width: 1220px;
  }

  .corporateinfo .corporateinfo__Block .company, .corporateinfo .corporateinfo__Block .organization {
    margin-bottom: 40px;
  }

  .corporateinfo .corporateinfo__Block .company__in, .corporateinfo .corporateinfo__Block .organization__in {
    justify-content: flex-start;
    padding: 0 54px;
  }

  .corporateinfo .corporateinfo__Block .company .box, .corporateinfo .corporateinfo__Block .organization .box {
    padding: 0 54px;
    width: 400px;
    height: 280px;
  }

  .corporateinfo .corporateinfo__Block .company .box .title, .corporateinfo .corporateinfo__Block .organization .box .title {
    margin: 0 auto 30px;
    width: auto;
    font-size: 28px;
  }

  .corporateinfo .corporateinfo__Block .company .box .msg, .corporateinfo .corporateinfo__Block .organization .box .msg {
    width: auto;
    font-size: 16px;
  }

  .corporateinfo .listBox .elem.businessBlock {
    width: 100%;
  }

  .corporateinfo .listBox .elem.printingBlock {
    width: calc(50% - 40px);
  }

  .corporateinfo .listBox .elem.temporarystaffingBlock {
    width: calc(50% - 40px);
  }

  .corporateinfo .listBox .elem.businessBlock .textBox {
    padding: 50px;
    width: 55%;
  }

  .corporateinfo .listBox .textBox {
    padding: 50px;
  }

  .corporateinfo .listBox .textBox::after {
    width: 24px;
    height: 24px;
  }

  .corporateinfo .listBox .title {
    font-size: 28px;
  }

  .corporateinfo .listBox .description {
    font-size: 16px;
  }
}

@media screen and (min-width: 992px) {
  .corporateinfo .corporateinfo__Block .company .box, .corporateinfo .corporateinfo__Block .organization .box {
    width: 460px;
    height: 345px;
  }

  .corporateinfo .listBox {
    margin: 0 0 105px;
  }

  .corporateinfo .listBox .elem {
    margin: 0 0 40px;
  }

  .corporateinfo .listBox .elem.printingBlock {
    width: calc(50% - 20px);
  }

  .corporateinfo .listBox .elem.temporarystaffingBlock {
    width: calc(50% - 20px);
  }

  .corporateinfo .listBox .elem .innerBox {
    width: calc(100% - 100px);
    height: calc(100% - 100px);
    left: 50px;
    top: 50px;
  }
}

.company .page-header__in {
  background-image: url(../images/company/mv.jpg);
}

.company section {
  margin-bottom: 28px;
}

.company .anchorLink {
  max-width: 435px;
}

.company .dlTable__wrap dl {
  padding: 0;
}

.company .dlTable__wrap dt {
  padding: 10px 16px;
  background-color: #F9F9F9;
}

.company .dlTable__wrap dd {
  padding: 10px 16px 20px;
}

@media screen and (min-width: 768px) {
  .company .anchorLink {
    margin-top: 16px;
  }

  .company section {
    margin-bottom: 125px;
  }

  .company section:nth-of-type(2) {
    margin-bottom: 203px;
  }

  .company .dlTable__wrap dl {
    padding: 0;
  }

  .company .dlTable__wrap dt,
  .company .dlTable__wrap dd {
    margin: 0;
    padding: 28px 35px;
  }

  .company .dlTable__wrap.tb02 {
    margin-top: 10px;
  }

  .company .dlTable__wrap.tb02 dd ul li::before {
    padding-right: 0;
  }

  .company .dlTable__wrap.tb02 dd ul li span:nth-of-type(1) {
    width: 28%;
  }
}

.message .page-header__in {
  background-image: url(../images/message/mv.jpg);
}

.message .page-content {
  padding: 0;
  max-width: none;
  background-image: url(../images/message/sp/img01.png);
  background-repeat: no-repeat;
  background-size: cover;
  padding: 0 15px;
}

.message .message_top {
  max-width: 930px;
  margin: 0 auto;
  padding: 50px 0;
}

.message .message_flexBox {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column-reverse;
  margin-bottom: 20px;
}

.message .message_flexBox .txtBox h2 {
  font-size: 34px;
  color: #008080;
  border-bottom: none;
  background: none;
  padding: 10px 0;
  margin-bottom: 0;
  font-feature-settings: "palt";
  line-height: 1.75;
}

.message .message_flexBox .txtBox h2:before {
  display: none;
}

.message .message_flexBox .txtBox p {
  font-size: 24px;
}

.message .message_flexBox .txtBox p span {
  margin-right: 15px;
  font-size: 12px;
}

.message .message_flexBox .imgBox {
  margin-bottom: 20px;
}

.message .message_Box {
  padding: 20px 15px;
  background: rgba(255, 255, 255, 0.8);
}

.message section {
  margin-bottom: 52px;
}

.message p {
  font-size: 16px;
  line-height: 1.75;
}

.message .anchorLink {
  max-width: 435px;
}

.message .sec01 .img {
  margin: 0 auto;
  padding: 7px 3px;
  width: 100%;
  max-width: 500px;
}

.message .sec02 .map {
  margin: 8px auto 0;
  width: 100%;
  max-width: 500px;
}

.message .sec02 .dlTable__wrap {
  margin: -5px 0 33px;
}

.message .sec02 .dlTable__wrap dt {
  background-color: #F9F9F9;
}

@media screen and (min-width: 768px) {
  .message .page-content {
    background-image: url(../images/message/img01.png);
    background-repeat: no-repeat;
    background-size: cover;
  }

  .message .message_top {
    padding: 100px 0;
  }

  .message .message_flexBox {
    margin-bottom: 50px;
    align-items: center;
    flex-direction: row;
  }

  .message .message_flexBox>div {
    width: 50%;
  }

  .message .message_flexBox.fb01 .txtBox {
    padding-right: 30px;
  }

  .message .message_flexBox.fb02 .txtBox {
    width: 56%;
    padding-right: 30px;
  }

  .message .message_flexBox.fb02 .imgBox {
    width: 44%;
  }

  .message .message_flexBox.fb03 .txtBox {
    width: 56%;
    padding-right: 30px;
  }

  .message .message_flexBox.fb03 .imgBox {
    width: 44%;
  }

  .message .message_Box {
    padding: 50px 40px;
  }

  /*  .organization{

      section{
        margin-bottom: 106px;
      }

      .anchorLink{
        margin: 14px auto 58px;
      }

      .sec01{

        h2{
          margin-bottom: 34px;
        }

        .img{
          max-width: 730px;
        }

      }

      .sec02{

        h2{
          margin-bottom: 34px;
        }

        h3{
          margin-bottom: 18px;
        }

        .map{
          margin: 15px auto 0;
          max-width: 800px;
        }

        .dlTable__wrap{
          margin: -5px 0 70px;

          dl{
            padding: 0;
          }

          dt, dd{
            margin: 0;
            padding: 30px 35px;
          }

          dd{

            .btn_access{
              top: 30px;
            }

          }

        }

      }

    }*/
}

.organization .page-header__in {
  background-image: url(../images/organization/mv.jpg);
}

.organization section {
  margin-bottom: 52px;
}

.organization p {
  font-size: 16px;
  line-height: 1.75;
}

.organization .anchorLink {
  max-width: 435px;
}

.organization .sec01 .img {
  margin: 0 auto;
  padding: 7px 3px;
  width: 100%;
  max-width: 500px;
}

.organization .sec02 .map {
  margin: 8px auto 0;
  width: 100%;
  max-width: 500px;
}

.organization .sec02 .dlTable__wrap {
  margin: -5px 0 33px;
}

.organization .sec02 .dlTable__wrap dt {
  background-color: #F9F9F9;
}

@media screen and (min-width: 768px) {
  .organization section {
    margin-bottom: 106px;
  }

  .organization .anchorLink {
    margin: 14px auto 58px;
  }

  .organization .sec01 h2 {
    margin-bottom: 34px;
  }

  .organization .sec01 .img {
    max-width: 730px;
  }

  .organization .sec02 h2 {
    margin-bottom: 34px;
  }

  .organization .sec02 h3 {
    margin-bottom: 18px;
  }

  .organization .sec02 .map {
    margin: 15px auto 0;
    max-width: 800px;
  }

  .organization .sec02 .dlTable__wrap {
    margin: -5px 0 70px;
  }

  .organization .sec02 .dlTable__wrap dl {
    padding: 0;
  }

  .organization .sec02 .dlTable__wrap dt, .organization .sec02 .dlTable__wrap dd {
    margin: 0;
    padding: 30px 35px;
  }

  .organization .sec02 .dlTable__wrap dd .btn_access {
    top: 30px;
  }
}

.csr .page-header__in {
  background-image: url(../images/csr/mv.jpg);
}

.csr .page-header__in h1 span {
  color: #383838;
}

.csr .page-content {
  max-width: none;
}

.csr .page-container section {
  counter-reset: number;
  margin: 0 auto 28px;
  padding: 0;
  width: 100%;
  max-width: 970px;
}

.csr .page-container h2 {
  margin-bottom: 14px;
}

.csr .page-container p {
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.01em;
}

.csr .page-container dl, .csr .page-container dt, .csr .page-container dd {
  margin: 0;
}

.csr .page-container dl {
  margin: 14px 0 34px;
}

.csr .page-container dt {
  padding: 0 0 0 35px;
  font-size: 19px;
  font-weight: 700;
  line-height: 1.64;
  position: relative;
  z-index: 0;
}

.csr .page-container dt::before {
  counter-increment: number;
  content: counter(number);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  background-color: #26B7BC;
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: 0;
}

.csr .page-container dt .sdgsIcon {
  display: flex;
  justify-content: center;
  margin-top: 10px;
  padding-right: 30px;
}

.csr .page-container dt .sdgsIcon figure {
  margin: 0 5px;
  width: 126px;
}

.csr .page-container ul, .csr .page-container li {
  margin: 0;
}

.csr .page-container li {
  padding-left: 20px;
  position: relative;
  z-index: 0;
}

.csr .page-container li::before {
  content: "■";
  color: rgba(38, 183, 188, 0.71);
  position: absolute;
  left: 0;
  top: 2px;
}

.csr .page-container li .text-list::before {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  background-color: #26B7BC;
  border-radius: 50%;
  position: absolute;
  left: 8px;
  top: 12px;
}

.csr .page-container .intro {
  margin-top: 10px;
  margin-bottom: 64px;
}

.csr .page-container .intro figure {
  margin: 0 auto 16px;
  width: 36%;
  max-width: 250px;
}

.csr .page-container .intro .leadTxt {
  color: #26B7BC;
  font-size: 18px;
  font-weight: 700;
  text-align: center;
}

.csr .page-container .intro .charter {
  margin: 30px -15px 0;
  padding: 30px 15px;
  color: #fff;
  background-image: url(../images/csr/ph01.jpg);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: cover;
}

.csr .page-container .intro .charter .title {
  margin-bottom: 12px;
  font-size: 18px;
  font-weight: 700;
  text-align: center;
}

.csr .page-container .sdgsWrap {
  margin-top: 60px;
}

.csr .page-container .cap {
  margin-top: 18px;
  padding: 15px;
  border: 1px solid #26B7BC;
}

.csr .page-container .cap p {
  font-size: 14px;
}

@media screen and (min-width: 768px) {
  .csr .page-content {
    padding: 45px 0;
  }

  .csr .page-container section {
    margin-bottom: 160px;
    padding: 0 20px;
  }

  .csr .page-container h2 {
    margin-bottom: 40px;
  }

  .csr .page-container h3 {
    margin: 20px 0 5px;
  }

  .csr .page-container dl {
    margin: 14px 0 77px;
  }

  .csr .page-container dt {
    margin-bottom: -18px;
    padding: 22px 0 0 60px;
    min-height: 126px;
    font-size: 28px;
  }

  .csr .page-container dt.sdgs-2 {
    padding: 0 340px 0 60px;
  }

  .csr .page-container dt:before {
    width: 50px;
    height: 50px;
    font-size: 28px;
    top: 22px;
  }

  .csr .page-container dt span {
    display: block;
    width: calc(100% - 150px);
  }

  .csr .page-container dt span.icon-2 {
    width: calc(100% - 330px);
  }

  .csr .page-container dt span.icon-3 {
    width: calc(100% - 480px);
  }

  .csr .page-container dt .sdgsIcon {
    display: flex;
    justify-content: flex-end;
    margin: 0;
    padding: 0 0 0 30px;
    position: absolute;
    right: 0;
    top: 0;
  }

  .csr .page-container dt .sdgsIcon figure {
    margin: 0 0 0 24px;
    width: 126px;
  }

  .csr .page-container .intro {
    margin-top: 48px;
    margin-bottom: 136px;
  }

  .csr .page-container .intro figure {
    margin-bottom: 32px;
  }

  .csr .page-container .intro .leadTxt {
    font-size: 32px;
  }

  .csr .page-container .intro .charter {
    margin: 82px 0 0;
    padding: 132px 0;
  }

  .csr .page-container .intro .charter .title {
    margin-bottom: 30px;
    font-size: 30px;
  }

  .csr .page-container .intro .charter .message {
    margin: 0 auto;
    padding: 0 20px;
    width: 100%;
    max-width: 970px;
  }

  .csr .page-container .cap {
    margin-top: 28px;
  }
}

.privacy .page-header__in {
  background-image: url(../images/privacy/mv.jpg);
}

.privacy .page-header__in h1 span {
  color: #383838;
}

.privacy .page-content {
  padding: 80px 15px;
}

.privacy .page-content h3 {
  margin: 54px 0 10px;
}

.privacy .page-content ul, .privacy .page-content li {
  margin: 0;
  padding: 0;
}

.privacy .page-content ul {
  margin-top: 20px;
}

.privacy .page-content li {
  margin-bottom: 6px;
  padding-left: 24px;
  line-height: 1.75;
  position: relative;
  z-index: 0;
}

.privacy .page-content li::before {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  background-color: #26B7BC;
  border-radius: 50%;
  position: absolute;
  left: 8px;
  top: 12px;
}

@media screen and (min-width: 768px) {
  .privacy .page-content {
    padding: 100px 15px;
  }
}

.recruit .page-header__in {
  background-image: url(../images/recruit/mv.jpg);
}

.recruit p {
  font-size: 16px;
  line-height: 1.75;
}

.recruit .intro {
  margin-bottom: 40px;
}

.recruit .listBox {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 -15px 50px;
}

.recruit .listBox .recruitBlock {
  margin: 10px 15px;
  padding: 0;
  width: 100%;
  box-shadow: 3px 3px 8px #999;
}

.recruit .listBox .recruitBlock a {
  display: block;
  padding: 0;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 0;
  overflow: hidden;
}

.recruit .listBox .recruitBlock a:hover {
  text-decoration: none;
}

.recruit .listBox .recruitBlock a:hover img {
  transform: scale(1.1);
}

.recruit .listBox .recruitBlock a:hover .textBox::after {
  right: 17px;
}

.recruit .listBox .recruitBlock img {
  display: block;
  transition: all 0.3s ease;
}

.recruit .listBox .recruitBlock .innerBox {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: calc(100% - 60px);
  height: calc(100% - 60px);
  position: absolute;
  left: 30px;
  top: 30px;
}

.recruit .listBox .textBox {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 50px 30px;
  width: 100%;
  height: 100%;
  color: #fff;
  background-color: rgba(0, 128, 128, 0.8);
  position: relative;
  z-index: 0;
}

.recruit .listBox .textBox::after {
  content: "";
  display: block;
  width: 19px;
  height: 19px;
  background-image: url(../images/businessinformation/icon_arw.png);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  position: absolute;
  right: 20px;
  bottom: 20px;
  transition: all 0.3s ease;
}

.recruit .listBox .title {
  margin: 0 0 20px;
  padding: 0;
  color: #fff;
  font-size: 19px;
  letter-spacing: 0.01em;
}

.recruit .listBox .title::before {
  content: none;
}

.recruit .listBox .description {
  font-size: 14px;
  line-height: 1.785;
  letter-spacing: 0.01em;
}

@media screen and (min-width: 768px) {
  .recruit .intro {
    margin-top: 47px;
    margin-bottom: 52px;
  }

  .recruit .listBox .recruitBlock {
    width: calc(50% - 40px);
  }

  .recruit .listBox .recruitBlock .textBox {
    padding: 40px;
  }

  .recruit .listBox .recruitBlock .textBox::after {
    width: 24px;
    height: 24px;
  }

  .recruit .listBox .recruitBlock .title {
    font-size: 28px;
  }

  .recruit .listBox .recruitBlock .description {
    font-size: 16px;
  }
}

@media screen and (min-width: 992px) {
  .recruit .intro {
    margin-top: 47px;
    margin-bottom: 52px;
  }

  .recruit .listBox {
    margin: 40px 0 70px;
  }

  .recruit .listBox .recruitBlock {
    margin: 0 0 40px;
    width: calc(50% - 20px);
  }

  .recruit .listBox .recruitBlock .innerBox {
    width: calc(100% - 100px);
    height: calc(100% - 100px);
    left: 50px;
    top: 50px;
  }
}

/*

-- recruit_career --

-- recruit_new --


*/
.sec_job {
  margin-bottom: 55px;
}

.sec_support {
  margin-bottom: 55px;
}

.sec_guide {
  margin-bottom: 24px;
}

.sec_recruit_contact {
  margin-bottom: 66px;
}

@media screen and (min-width: 768px) {
  .sec_job {
    margin-bottom: 110px;
  }

  .sec_job h2 {
    margin-bottom: 30px;
  }

  .sec_support {
    margin-bottom: 122px;
  }

  .sec_support h2 {
    margin-bottom: 40px;
  }

  .sec_guide {
    margin-bottom: 40px;
  }

  .sec_recruit_contact {
    margin-bottom: 190px;
  }
}

/* anchorLink */
.recruit .anchorLink a:nth-of-type(3) {
  width: calc(100% - 1px);
}

@media screen and (min-width: 768px) {
  .recruit .anchorLink {
    max-width: 733px;
  }

  .recruit .anchorLink a {
    width: 33.3333% !important;
  }
}

/* anchorLink */
/* recruit_flexBox */
.recruit_flexBox {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.recruit_flexBox .txtBox {
  padding: 0 0 10px;
}

.recruit_flexBox .txtBox h3 {
  margin-top: 0;
}

@media screen and (min-width: 768px) {
  .recruit_flexBox {
    margin-bottom: 70px;
  }

  .recruit_flexBox>div {
    width: 50%;
  }

  .recruit_flexBox.fb01 .txtBox {
    padding-right: 30px;
  }

  .recruit_flexBox.fb02 .txtBox {
    width: 56%;
    padding-right: 30px;
  }

  .recruit_flexBox.fb02 .imgBox {
    width: 44%;
  }

  .recruit_flexBox.fb03 .txtBox {
    width: 56%;
    padding-right: 30px;
  }

  .recruit_flexBox.fb03 .imgBox {
    width: 44%;
  }
}

/* recruit_flexBox */
/* recruit_work */
.recruit_work .nes-grad-item {
  margin-bottom: 58px;
}

@media screen and (min-width: 768px) {
  .recruit_work {
    margin-bottom: 10px;
  }
}

/* recruit_work */
/* work_flow */
.work_flow {
  margin: 15px 0;
}

.work_flow>div {
  position: relative;
}

.work_flow>div:nth-of-type(1) {
  z-index: 5;
}

.work_flow>div:nth-of-type(2) {
  z-index: 4;
}

.work_flow>div:nth-of-type(3) {
  z-index: 3;
}

.work_flow>div:nth-of-type(4) {
  z-index: 2;
}

.work_flow>div:nth-of-type(5) {
  z-index: 1;
}

.work_flow>div>div {
  margin-bottom: 14px;
  padding: 15px 20px;
  border-radius: 22px;
  position: relative;
}

.work_flow>div>div::before {
  content: "";
  display: block;
  width: 35px;
  height: 25px;
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: contain;
  position: absolute;
  left: calc(50% - 18px);
  top: 94%;
  z-index: -1;
  transform: rotate(90deg);
}

.work_flow>div>div.flow05 {
  margin-bottom: 0;
}

.work_flow h4 {
  margin: 0 0 6px;
  padding: 0;
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  background: none;
  border: 0;
}

.work_flow h4:before, .work_flow h4::after {
  content: none;
}

.work_flow p {
  color: #231815;
  font-size: 14px;
}

.work_flow .flow01 {
  background-color: #8dc21f;
}

.work_flow .flow02 {
  background-color: #00b8ee;
}

.work_flow .flow03 {
  background-color: #e85377;
}

.work_flow .flow04 {
  background-color: #deb500;
}

.work_flow .flow05 {
  background-color: #ec6c00;
}

.work_flow .flow01::before {
  background-image: url(../images/recruit_new/arw01.png);
}

.work_flow .flow02::before {
  background-image: url(../images/recruit_new/arw02.png);
}

.work_flow .flow03::before {
  background-image: url(../images/recruit_new/arw03.png);
}

.work_flow .flow04::before {
  background-image: url(../images/recruit_new/arw04.png);
}

@media screen and (min-width: 768px) {
  .work_flow {
    display: flex;
    justify-content: space-between;
    margin: 25px 0 8px;
  }

  .work_flow>div {
    width: 18.27%;
  }

  .work_flow>div>div {
    padding: 34px 20px;
    height: 253px;
  }

  .work_flow>div>div::before {
    width: 37px;
    height: 26px;
    left: calc(100% - 5px);
    top: 23%;
    transform: rotate(0);
  }

  .work_flow h4 {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 24px;
    padding: 0;
    height: 52px;
    font-size: 18px;
    text-align: center;
    line-height: 1.6;
  }
}

/* work_flow */
/* recruit__dlTable-style-01 */
.recruit__dlTable-style-01 {
  margin: 10px 0 40px;
}

.recruit__dlTable-style-01 dl {
  display: flex;
  padding: 0;
}

.recruit__dlTable-style-01 dt,
.recruit__dlTable-style-01 dd {
  margin: 0;
  border: 0;
}

.recruit__dlTable-style-01 dt {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40%;
}

.recruit__dlTable-style-01 dd {
  padding-right: 0;
  width: 60%;
}

@media screen and (min-width: 768px) {
  .recruit__dlTable-style-01 {
    margin: 10px 0;
  }

  .recruit__dlTable-style-01 dt {
    width: 215px;
  }

  .recruit__dlTable-style-01 dd {
    width: calc(100% - 215px);
  }
}

/* recruit__dlTable-style-01 */
/* recruit__nes-grad-wrap */
.recruit__nes-grad-wrap .nes-grad-item.nes-is-hide {
  margin-bottom: 30px;
  height: 300px !important;
}

@media screen and (min-width: 768px) {
  .recruit__nes-grad-wrap .nes-grad-item.nes-is-hide {
    margin: 0;
    padding: 0;
    height: auto !important;
  }

  .recruit__nes-grad-wrap .nes-grad-item.nes-is-hide::before {
    content: none;
  }

  .recruit__nes-grad-wrap .nes-grad-trigger {
    display: none;
  }
}

/* recruit__nes-grad-wrap */
/* btn_pagetop */
.btn_pagetop {
  text-align: right;
}

.btn_pagetop a {
  color: #00b4fd;
}

.btn_pagetop a:hover {
  text-decoration: none;
  opacity: 0.8;
}

/* btn_pagetop */
/* recruit_boxStyle_01 */
.recruit_boxStyle_01__wrap {
  margin-top: -4px;
  margin-bottom: 24px;
}

.recruit_boxStyle_01 {
  margin: 10px 0;
}

.recruit_boxStyle_01 dl,
.recruit_boxStyle_01 dt,
.recruit_boxStyle_01 dd {
  margin: 0;
  padding: 0;
}

.recruit_boxStyle_01 dl {
  width: 100%;
  height: 100%;
  border: 2px solid rgba(38, 183, 188, 0.4);
  border-radius: 10px;
}

.recruit_boxStyle_01 dt {
  padding: 4px 16px;
  background-color: rgba(38, 183, 188, 0.1);
}

.recruit_boxStyle_01 dd {
  padding: 10px 16px;
}

@media screen and (min-width: 768px) {
  .recruit_boxStyle_01__wrap {
    display: flex;
    justify-content: space-between;
    margin-bottom: 50px;
  }

  .recruit_boxStyle_01 {
    margin: 16px 0;
    width: 49%;
  }

  .recruit_boxStyle_01 dt {
    padding: 10px 20px;
  }

  .recruit_boxStyle_01 dd {
    padding: 15px 16px;
  }
}

/* recruit_boxStyle_01 */
/* recruit_boxStyle_02 */
.recruit_boxStyle_02 {
  margin: 10px 0 16px;
}

.recruit_boxStyle_02 dl,
.recruit_boxStyle_02 dt,
.recruit_boxStyle_02 dd {
  margin: 0;
  padding: 0;
}

.recruit_boxStyle_02 dl {
  padding: 4px 16px;
  border: 3px solid #dcdddd;
}

.recruit_boxStyle_02 dt {
  margin-bottom: 10px;
  padding-bottom: 6px;
  color: #26b7bc;
  font-size: 20px;
  line-height: 1.5;
  border-bottom: 2px dotted #26b7bc;
}

.recruit_boxStyle_02 .nes-grad-item {
  margin-bottom: 60px;
  padding-bottom: 30px;
}

.recruit_boxStyle_02 .content {
  padding-bottom: 32px;
}

.recruit_boxStyle_02 .listBox {
  padding: 28px 20px;
  background-color: #f9f9f9;
}

.recruit_boxStyle_02 .listBox li {
  margin-bottom: 4px;
}

@media screen and (min-width: 768px) {
  .recruit_boxStyle_02 {
    margin: 12px 0 16px;
  }

  .recruit_boxStyle_02:last-child {
    margin-bottom: 60px;
  }

  .recruit_boxStyle_02 dl {
    padding: 20px 25px 25px;
  }

  .recruit_boxStyle_02 dl small {
    font-size: 100%;
  }

  .recruit_boxStyle_02 dt {
    margin-bottom: 23px;
    padding-bottom: 12px;
  }

  .recruit_boxStyle_02 .content {
    padding-bottom: 0;
  }

  .recruit_boxStyle_02 .listBox {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
    padding: 32px 42px;
  }

  .recruit_boxStyle_02 .listBox>div {
    width: 49%;
  }

  .recruit_boxStyle_02 .listBox li {
    margin-bottom: 10px;
  }
}

/* recruit_boxStyle_02 */
/* recruit_boxStyle_03 */
.recruit_boxStyle_03 {
  margin: 10px 0 0;
}

.recruit_boxStyle_03 p.lead {
  margin-bottom: 2px;
  padding: 10px;
  color: #26b7bc;
  font-size: 15px;
  font-weight: 700;
  text-align: center;
  background-color: #fff;
  border: 1px solid #dcdddd;
  position: relative;
}

.recruit_boxStyle_03 p.lead::before, .recruit_boxStyle_03 p.lead::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 25px 11.5px 0 11.5px;
  position: absolute;
  left: calc(50% - 15px);
}

.recruit_boxStyle_03 p.lead::before {
  top: calc(100% - 1px);
  border-color: #dcdddd transparent transparent transparent;
  z-index: -1;
}

.recruit_boxStyle_03 p.lead::after {
  top: calc(100% - 4px);
  border-color: #fff transparent transparent transparent;
  z-index: 1;
}

.recruit_boxStyle_03 .listBox {
  display: flex;
  flex-wrap: wrap;
}

.recruit_boxStyle_03 .listBox>div {
  padding: 5px;
  width: 50%;
}

.recruit_boxStyle_03 .listBox p {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 160px;
  color: rgb(38, 183, 188);
  font-size: 19px;
  font-weight: 700;
  text-align: center;
  line-height: 1.27;
  background-color: rgba(38, 183, 188, 0.4);
  border-radius: 50%;
}

@media screen and (min-width: 768px) {
  .recruit_boxStyle_03 {
    margin: 35px 0 0;
  }

  .recruit_boxStyle_03 p.lead {
    margin-bottom: 16px;
    font-size: 24px;
  }

  .recruit_boxStyle_03 .listBox {
    justify-content: space-between;
  }

  .recruit_boxStyle_03 .listBox>div {
    width: 24%;
  }

  .recruit_boxStyle_03 .listBox p {
    width: 160px;
    height: 160px;
    font-size: 18px;
  }
}

@media screen and (min-width: 992px) {
  .recruit_boxStyle_03 .listBox p {
    width: 218px;
    height: 218px;
    font-size: 26px;
  }
}

/* recruit_boxStyle_03 */
/* guide__accordion */
.guide__accordion .nes-grad-item.nes-is-hide {
  margin-bottom: 48px;
  height: 600px !important;
}

@media screen and (min-width: 768px) {
  .guide__accordion .recruit__dlTbl {
    margin: 0 0 16px;
  }

  .guide__accordion .nes-grad-item.nes-is-hide {
    margin: 0;
    height: auto !important;
  }
}

/* guide__accordion */
/* recruit__dlTbl */
.recruit__dlTbl {
  margin: 0 0 38px;
}

.recruit__dlTbl dl {
  display: flex;
  padding: 0;
}

.recruit__dlTbl dt {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 30px 0;
  width: 37%;
  text-align: center;
  background-color: #f9f9f9;
  border: 0;
}

.recruit__dlTbl dd {
  padding: 30px 0 30px 28px;
  width: 63%;
}

@media screen and (min-width: 768px) {
  .recruit__dlTbl dt {
    width: 23%;
  }

  .recruit__dlTbl dd {
    width: 77%;
  }

  .recruit__dlTbl dd .btn_access {
    right: 50px;
    top: calc(50% - 25px);
  }

  .recruit__dlTbl__flex__pc {
    display: flex;
  }

  .recruit__dlTbl__flex__pc:not(:last-child) {
    margin-bottom: 25px;
  }

  .recruit__dlTbl__flex__pc .left {
    width: 9em;
  }

  .recruit__dlTbl__flex__pc .right {
    width: calc(100% - 9em);
  }
}

/* recruit__dlTbl */
/* contactBlock */
.contactBlock {
  border: 1px solid #26b7bc;
}

.contactBlock h3 {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 10px;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  background-color: #26b7bc;
}

.contactBlock h3::before, .contactBlock h3::after {
  content: none;
}

.contactBlock h3 small {
  padding-left: 10px;
  font-size: 14px;
}

.contactBlock .flexBox {
  display: flex;
  flex-wrap: wrap;
  padding: 10px 24px 20px;
  text-align: center;
}

.contactBlock .flexBox>div {
  margin: 10px 0;
}

.contactBlock .flexBox>div figure {
  margin: 0 auto;
}

.contactBlock .flexBox .tel {
  width: 100%;
}

.contactBlock .flexBox .tel figure {
  width: 80%;
}

.contactBlock .flexBox .email {
  width: 100%;
}

.contactBlock .flexBox .email figure {
  width: 100%;
}

.contactBlock .flexBox .title {
  margin-bottom: 6px;
}

@media screen and (min-width: 768px) {
  .contactBlock h3 {
    padding: 20px 10px;
    font-size: 22px;
  }

  .contactBlock .flexBox {
    justify-content: space-between;
    padding: 25px 37px 18px;
  }

  .contactBlock .flexBox .tel {
    width: 44%;
  }

  .contactBlock .flexBox .email {
    padding-right: 5%;
    width: 51%;
  }

  .contactBlock .flexBox .title {
    margin-bottom: 10px;
    font-size: 18px;
  }
}

/* contactBlock */
.recruit_career .page-header__in {
  background-image: url(../images/recruit_career/mv.jpg);
}

.recruit_new .page-header__in {
  background-image: url(../images/recruit_new/mv.jpg);
}

.recruit_new .page-header h1 span {
  color: #383838;
}

@media screen and (min-width: 768px) {
  .recruit_new .page-content {
    padding: 54px 20px;
  }
}

.recruit_career_manage .page-header__in {
  background-image: url(../images/recruit_career_manage/sp/mv.jpg);
}

.recruit_career_manage .page-header h1 span {
  color: #383838;
}

@media screen and (min-width: 768px) {
  .recruit_career_manage .page-header__in {
    background-image: url(../images/recruit_career_manage/mv.jpg);
  }
}

.recruit_new_manage .page-header__in {
  background-image: url(../images/recruit_new_manage/sp/mv.jpg);
}

.recruit_new_manage .page-header h1 span {
  color: #383838;
}

@media screen and (min-width: 768px) {
  .recruit_new_manage .page-header__in {
    background-image: url(../images/recruit_new_manage/mv.jpg);
  }

  .recruit_new_manage .page-content {
    padding: 54px 20px;
  }
}

.sitemap .page-header__in {
  background-image: url(../images/sitemap/mv.jpg);
}

.sitemap .page-header__in h1 span {
  color: #383838;
}

.sitemap .page-content {
  padding: 80px 15px;
}

.sitemap .page-content .sitemap__wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.sitemap .page-content .sitemap__Navigation {
  margin: 0;
  width: 100%;
}

.sitemap .page-content .sitemap__Navigation li {
  margin-bottom: 30px;
}

.sitemap .page-content .sitemap__Navigation li::before, .sitemap .page-content .sitemap__Navigation li::after {
  content: none;
}

.sitemap .page-content .sitemap__Navigation a {
  display: block;
  margin-bottom: 8px;
  padding: 0 0 0;
  width: 100%;
  color: #3BBEC3;
  font-size: 22px;
  font-weight: 700;
  border-bottom: 1px solid #26B7BC;
}

.sitemap .page-content .sitemap__Navigation a:hover {
  text-decoration: none;
  opacity: 0.8;
}

.sitemap .page-content .sitemap__Navigation .children {
  margin: 0;
}

.sitemap .page-content .sitemap__Navigation .children li {
  margin-bottom: 5px;
}

.sitemap .page-content .sitemap__Navigation .children a {
  margin: 0;
  padding: 0 0 0 20px;
  color: #383838;
  font-size: 18px;
  font-weight: 400;
  border: 0;
  position: relative;
  z-index: 0;
}

.sitemap .page-content .sitemap__Navigation .children a::before {
  content: "▶";
  display: inline-block;
  font-size: 13px;
  position: absolute;
  left: 0;
  top: 4px;
}

@media screen and (min-width: 768px) {
  .sitemap .page-content {
    padding: 115px 20px 136px;
    max-width: 920px;
  }

  .sitemap .page-content .sitemap__Navigation {
    width: 43%;
  }

  .sitemap .page-content .sitemap__Navigation li {
    margin-bottom: 75px;
  }

  .sitemap .page-content .sitemap__Navigation li.mb_add {
    margin-bottom: 148px;
  }
}

/* 20250616　news追加 */
.news .page-header__in {
  background-image: url(../images/news/mv.jpg);
}

.news__contents {
  margin: 50px 0 150px;
}

@media screen and (max-width: 767px) {
  .news__contents {
    margin: 10px 0 60px;
  }
}

.news__list {
  margin-bottom: 50px;
}

@media screen and (max-width: 767px) {
  .news__list {
    margin-bottom: 30px;
  }
}

.news__list li {
  padding: 20px 0;
  border-top: 1px solid #dcdddd;
}

@media screen and (max-width: 767px) {
  .news__list li {
    padding: 15px 0;
  }
}

.news__list li:last-child {
  border-bottom: 1px solid #dcdddd;
}

.news__list li::before {
  display: none;
}

.news__list li a {
  display: flex;
  align-items: flex-start;
}

@media screen and (max-width: 767px) {
  .news__list li a {
    display: block;
  }
}

.news__list li a .date {
  font-size: 14px;
  width: 13%;
  padding-top: 2px;
}

@media screen and (max-width: 767px) {
  .news__list li a .date {
    font-size: 13px;
    display: inline-block;
    width: 24%;
    padding-top: 1px;
  }
}

.news__list li a .category {
  font-size: 14px;
  width: 13%;
  margin-right: 30px;
  padding: 1px 0 0;
  text-align: center;
  color: #fff;
  background: #333;
}

@media screen and (max-width: 767px) {
  .news__list li a .category {
    font-size: 12px;
    display: inline-block;
    width: 20%;
    margin-right: 0;
  }
}

.news__list li a .category.news {
  background: #26b7bc;
}

.news__list li a .category.event {
  background: #13a37e;
}

.news__list li a .category.guidance {
  background: #95c315;
}

.news__list li a .category.case {
  background: #a39313;
}

.news__list li a .category.important {
  background: #bd22a9;
}

.news__list li a .category.recruit {
  background: #226cc1;
}

.news__list li a .category.others {
  background: #22a1c1;
}

.news__list li a .txt {
  flex: 1;
}

@media screen and (max-width: 767px) {
  .news__list li a .txt {
    display: block;
    width: 100%;
    margin-top: 3px;
  }
}

.news__list li a:hover {
  text-decoration: none;
  opacity: .8;
}

.news .pager .pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}

.news .pager li {
  margin: 0 8px;
}

.news .pager li::before {
  display: none;
}

.news .pager li a:hover {
  text-decoration: none;
  color: #26b7bc;
}

.news .pager li .active {
  pointer-events: none;
  color: #26b7bc;
}

.news .pager li.pre,
.news .pager li.next {
  width: 40px;
  margin: 0;
  cursor: pointer;
}

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

  .news .pager li.pre,
  .news .pager li.next {
    width: 30px;
  }
}

.news .pager li.pre {
  margin-right: 20px;
  transform: scale(-1, 1);
}

.news .pager li.next {
  margin-left: 20px;
}

.news .pager li:hover {
  opacity: .8;
}

.news__ttl {
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .news__ttl {
    margin-bottom: 25px;
  }
}

.news__ttl .datebox {
  display: flex;
  align-items: center;
}

.news__ttl .datebox .date {
  font-size: 14px;
  line-height: 1;
  padding-right: 25px;
}

@media screen and (max-width: 767px) {
  .news__ttl .datebox .date {
    font-size: 13px;
    padding-right: 20px;
  }
}

.news__ttl .datebox .category {
  padding: 1px 20px;
  color: #fff;
}

@media screen and (max-width: 767px) {
  .news__ttl .datebox .category {
    font-size: 14px;
    padding: 1px 15px 0;
  }
}

.news__ttl .datebox .category.news {
  background: #26b7bc;
}

.news__ttl .datebox .category.event {
  background: #13a37e;
}

.news__ttl .datebox .category.guidance {
  background: #95c315;
}

.news__ttl .datebox .category.case {
  background: #a39313;
}

.news__ttl .datebox .category.important {
  background: #bd22a9;
}

.news__ttl .datebox .category.recruit {
  background: #226cc1;
}

.news__ttl .datebox .category.others {
  background: #22a1c1;
}

.news__ttl h3 {
  margin-top: 10px;
}

.news__txt {
  margin-bottom: 50px;
}

@media screen and (max-width: 767px) {
  .news__txt {
    margin-bottom: 30px;
  }
}

.news__btn01 {
  margin-bottom: 50px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .news__btn01 {
    margin-bottom: 30px;
  }
}

.news__btn01 a {
  font-weight: 500;
  display: inline-block;
  padding: 20px 40px;
  color: #26b7bc;
  border: 1px solid #dcdddd;
}

@media screen and (max-width: 767px) {
  .news__btn01 a {
    padding: 15px 30px;
  }
}

.news__btn01 a:hover {
  text-decoration: none;
  color: #fff;
  background: #26b7bc;
}

.news__pic {
  display: flex;
  margin-bottom: 50px;
}

@media screen and (max-width: 767px) {
  .news__pic {
    display: block;
    margin-bottom: 30px;
  }
}

.news__pic li {
  width: calc(33% - 20px);
  margin-right: 40px;
}

@media screen and (max-width: 767px) {
  .news__pic li {
    width: 100%;
    margin: 0 0 15px;
  }
}

.news__pic li:last-child {
  margin-right: 0;
}

@media screen and (max-width: 767px) {
  .news__pic li:last-child {
    margin: 0;
  }
}

.news__pic li::before {
  display: none;
}

.news__btn02 {
  font-weight: 500;
  position: relative;
  display: block;
  width: 300px;
  margin: 0 auto;
  padding: 20px;
  text-align: center;
  color: #26b7bc;
  border: 1px solid #dcdddd;
}

@media screen and (max-width: 767px) {
  .news__btn02 {
    width: 100%;
    padding: 15px;
  }
}

.news__btn02::before {
  position: absolute;
  top: 50%;
  left: 25px;
  display: inline-block;
  width: 10PX;
  height: 6PX;
  content: '';
  transform: translate(0, -50%) rotate(90deg);
  background: url(../images/common/icon_arw3.svg) 0 0 no-repeat;
  background-size: auto;
}

.news__btn02:hover {
  text-decoration: none;
  opacity: .8;
  color: #26b7bc;
}

/* 20250616 top news追加 */
.toppage__concept__wrap {
  padding-bottom: 80px;
}

@media screen and (max-width: 767px) {
  .toppage__concept__wrap {
    padding-bottom: 50px;
  }
}

.toppage__concept__news {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 35px 406px;
}

@media screen and (max-width: 767px) {
  .toppage__concept__news {
    padding: 0 25px 255px;
  }
}

.toppage__concept__news_flbox {
  display: flex;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .toppage__concept__news_flbox {
    display: block;
    margin-bottom: 15px;
  }
}

.toppage__concept__news_flbox .ttl {
  display: flex;
  width: 250px;
}

@media screen and (max-width: 767px) {
  .toppage__concept__news_flbox .ttl {
    display: block;
    width: 100%;
    margin-bottom: 10px;
  }
}

.toppage__concept__news_flbox .ttl h2 {
  margin: 0;
  padding-right: 20px;
  border-bottom: none;
  background-color: unset;
}

@media screen and (max-width: 767px) {
  .toppage__concept__news_flbox .ttl h2 {
    padding: 10px 30px;
  }

  .toppage__concept__news_flbox .ttl h2::before {
    left: 5px;
    top: 14px;
  }
}

.toppage__concept__news_flbox .news__list {
  margin: 0;
  flex: 1;
}

.toppage__concept__news_flbox .news__list li a {
  background: transparent;
}

.toppage__concept__news_next {
  text-align: right;
}

.toppage__concept__news_next a {
  font-weight: 500;
  position: relative;
  display: inline-block;
  width: auto;
  width: 200px;
  padding: 10px 25px;
  text-align: left;
  color: #26b7bc;
  border: 1px solid #dcdddd;
}

@media screen and (max-width: 767px) {
  .toppage__concept__news_next a {
    width: 50%;
  }
}

.toppage__concept__news_next a::before {
  position: absolute;
  top: 50%;
  right: 20px;
  display: inline-block;
  width: 10PX;
  height: 6PX;
  content: '';
  transform: translate(0, -50%) rotate(270deg);
  background: url(../images/common/icon_arw3.svg) 0 0 no-repeat;
  background-size: auto;
}

.toppage__concept__news_next a:hover {
  text-decoration: none;
  opacity: .8;
  color: #26b7bc;
}
