@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700&family=Manrope:wght@500;600;700&display=swap");
html {
  font-size: 62.5%;
  overflow-y: scroll !important;
  -webkit-overflow-scrolling: touch;
  background: #fff;
}

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

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

fieldset,
img {
  border: 0;
}

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

ol,
ul {
  list-style: none;
}

caption,
th {
  text-align: left;
}

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

q:before,
q:after {
  content: "";
}

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

sup {
  vertical-align: text-top;
}

sub {
  vertical-align: text-bottom;
}

input,
textarea,
select {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  *font-size: 100%;
}

legend {
  color: #000;
}

option,
select,
textarea,
input[type="button"],
input[type="submit"],
input[type="text"],
input[type="select"],
input[type="option"],
input[type="checkbox"] {
  -webkit-appearance: none;
  border-radius: 0;
  outline: 0;
  background: transparent;
}

button {
  border: none;
  background: none;
}

table {
  font-size: inherit;
  font: 100%;
}

code,
kbd,
samp,
tt {
  font-family: monospace;
  *font-size: 108%;
  line-height: 100%;
}

ul,
li {
  list-style: none;
}

img {
  vertical-align: bottom;
}

*::after,
*::before,
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

button {
  cursor: pointer;
}

main {
  display: block;
}

body {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1;
  color: #33393B;
  background: #fff;
  -webkit-font-smoothing: antialiased;
  font-weight: 500;
  letter-spacing: 0.06em;
  word-wrap: break-word;
  overflow-wrap: break-word;
  font-feature-settings: "palt";
}

.clearfix:after {
  font-size: .1em;
  line-height: 0;
  display: block;
  visibility: hidden;
  clear: both;
  overflow: hidden;
  height: .1px;
  content: ' ';
}

.clearfix {
  /*\*/
    /*/
display: inline-table !important;
/**/
}

a {
  text-decoration: none;
  color: #33393B;
}

a:hover {
  text-decoration: none;
}

a {
  outline: none;
}

button:focus,
a:focus {
  outline: none;
}

:-moz-focusring {
  outline: 0 dotted #fff;
}

a:focus, *:focus {
  outline: none;
}

.f-bold {
  font-weight: 700 !important;
}

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

/*********************************************
form
*********************************************/
select {
  outline: none;
}

option {
  outline: none;
}

select {
  outline: 0;
}

option {
  outline: 0;
}

input:-webkit-autofill,
textarea:-webkit-autofill {
  background-color: #faffbd;
  background-image: none;
  color: black;
}

select:-moz-focusring * {
  text-shadow: none;
}

select:-moz-focusring {
  color: #fff;
  text-shadow: 0px 0px 0px #fff;
}

select::-moz-focus-inner,
option::-moz-focus-inner {
  border: 0px;
}

option,
select,
textarea,
input[type="number"],
input[type="button"],
input[type="submit"],
input[type="text"],
input[type="password"],
input[type="email"],
input[type="select"],
input[type="option"] {
  -webkit-appearance: none;
  border-radius: 0;
  outline: 0;
  background: #fff;
}

input[type="option"],
input[type="select"] {
  overflow: hidden;
  word-wrap: normal !important;
  white-space: normal;
  max-width: 100%;
}

input[type="select"] {
  font-size: 16px;
}

/* for firefox */
select {
  -moz-appearance: none;
  text-indent: 0.01px;
  text-overflow: '';
}

/* for ie10 ie11 */
select::-ms-expand {
  display: none;
}

/* Google Chrome, Safari, Opera 15+, Android, iOS */
input:-webkit-autofill,
textarea:-webkit-autofill,
select:-webkit-autofill {
  background-color: #fff;
  background-image: none;
  color: #999;
}

/* Google Chrome, Safari, Opera 15+, Android, iOS */
.search-form ::-webkit-input-placeholder {
  color: #A0A0A0;
  font-size: 14px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .search-form ::-webkit-input-placeholder {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .search-form ::-webkit-input-placeholder {
    font-size: 16px;
  }
}

::-webkit-input-placeholder {
  color: #A0A0A0;
  padding-top: 1px;
  line-height: normal !important;
  font-size: 16px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ::-webkit-input-placeholder {
    padding-top: 0.07143vw;
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  ::-webkit-input-placeholder {
    padding-top: 0.07143vw;
    font-size: 16px;
  }
}

body.user-os-iphone input::-webkit-input-placeholder {
  padding-top: 0px;
}

/* Firefox 18- */
.form-select,
.form-select select,
textarea,
input[type="number"],
input[type="tel"],
input[type="email"],
input[type="password"],
input[type=text] {
  width: 100%;
  padding: 0 16px;
  height: 56px;
  font-size: 16px;
  overflow: hidden;
  border: 1px solid #DDDDDD;
  line-height: 1;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .form-select,
  .form-select select,
  textarea,
  input[type="number"],
  input[type="tel"],
  input[type="email"],
  input[type="password"],
  input[type=text] {
    padding: 0 1.14286vw;
    height: 4vw;
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .form-select,
  .form-select select,
  textarea,
  input[type="number"],
  input[type="tel"],
  input[type="email"],
  input[type="password"],
  input[type=text] {
    padding: 0 3.73333vw;
    height: 14.93333vw;
    font-size: 16px;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .form-select,
  .form-select select,
  textarea,
  input[type="number"],
  input[type="tel"],
  input[type="email"],
  input[type="password"],
  input[type=text] {
    padding: 0 14px;
    height: 56px;
  }
}

.form-select,
.form-select select {
  overflow: visible;
}

.form-select {
  height: 58px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .form-select {
    height: 4.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .form-select {
    height: 15.46667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .form-select {
    height: 58px;
  }
}

/* button */
.button {
  border: 1px solid #007AAA;
  text-align: center;
  color: #007AAA;
  width: 230px;
  height: 48px;
  font-size: 16px;
  font-weight: 600;
  -webkit-transition: color 0.2s ease-out, background 0.2s ease-out;
  -moz-transition: color 0.2s ease-out, background 0.2s ease-out;
  -ms-transition: color 0.2s ease-out, background 0.2s ease-out;
  -o-transition: color 0.2s ease-out, background 0.2s ease-out;
  transition: color 0.2s ease-out, background 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .button {
    width: 16.42857vw;
    height: 3.42857vw;
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .button {
    width: 61.33333vw;
    height: 12.8vw;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .button {
    width: 230px;
    height: 48px;
    font-size: 16px;
  }
}
@media screen and (min-width: 1025px) {
  .button:hover {
    background: #007AAA;
    color: #fff;
    -webkit-transition: color 0.3s ease-out, background 0.3s ease-out;
    -moz-transition: color 0.3s ease-out, background 0.3s ease-out;
    -ms-transition: color 0.3s ease-out, background 0.3s ease-out;
    -o-transition: color 0.3s ease-out, background 0.3s ease-out;
    transition: color 0.3s ease-out, background 0.3s ease-out;
  }
}

#page-top {
  position: absolute;
  left: -1000px;
  top: 0;
}

@media screen and (min-width: 768px) {
  select:focus-visible,
  textarea:focus-visible,
  input:focus-visible,
  button:focus-visible,
  a:focus-visible {
    outline: solid 5px #ff0 !important;
    z-index: 100;
  }

  .header-btn__search a:focus-visible {
    border-radius: 50%;
    overflow: hidden;
  }

  /**************/
  select:focus:not(:focus-visible),
  textarea:focus:not(:focus-visible),
  input:focus:not(:focus-visible),
  button:focus:not(:focus-visible),
  a:focus:not(:focus-visible) {
    outline: 0 !important;
  }
}
body {
  width: 100%;
}
body::after {
  content: '';
  display: block;
  position: fixed;
  width: 100%;
  height: 100%;
  background: #000;
  top: 0;
  left: -100%;
  opacity: 0;
  z-index: 99;
  -webkit-transition: opacity 0.8s ease-out;
  -moz-transition: opacity 0.8s ease-out;
  -ms-transition: opacity 0.8s ease-out;
  -o-transition: opacity 0.8s ease-out;
  transition: opacity 0.8s ease-out;
}

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

html, body {
  width: 100%;
}

.wrap {
  position: relative;
}

@media screen and (max-width: 767px) {
  body.state-header-change .fixed-btn {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    -o-transform: translateY(0);
    transform: translateY(0);
  }
}

.fixed-btn {
  position: fixed;
  bottom: 0;
  right: 0;
  width: 520px;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  -o-justify-content: flex-start;
  justify-content: flex-start;
  z-index: 10;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .fixed-btn {
    width: 37.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .fixed-btn {
    border-top: 1px solid #75b5cc;
    width: 100%;
    -webkit-transform: translateY(100%);
    -moz-transform: translateY(100%);
    -ms-transform: translateY(100%);
    -o-transform: translateY(100%);
    transform: translateY(100%);
    -webkit-transition: transform 0.3s 0s ease-out;
    -moz-transition: transform 0.3s 0s ease-out;
    -ms-transition: transform 0.3s 0s ease-out;
    -o-transition: transform 0.3s 0s ease-out;
    transition: transform 0.3s 0s ease-out;
  }
}
.fixed-btn li {
  width: 50%;
}
.fixed-btn li.-doc {
  border-left: 1px solid #75b5cc;
}
@media screen and (max-width: 767px) {
  .fixed-btn li.-doc {
    border-left: none;
  }
}
.fixed-btn li.-doc a span.btn-txt {
  padding-left: 32px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .fixed-btn li.-doc a span.btn-txt {
    padding-left: 2.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .fixed-btn li.-doc a span.btn-txt {
    padding-left: 8.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .fixed-btn li.-doc a span.btn-txt {
    padding-left: 32px;
  }
}
.fixed-btn li.-doc a span.btn-txt::after {
  width: 20px;
  height: 24px;
  margin-top: -11px;
  background: url(../img/common/ico_doc.svg) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .fixed-btn li.-doc a span.btn-txt::after {
    width: 1.42857vw;
    height: 1.71429vw;
    margin-top: -0.78571vw;
  }
}
@media screen and (max-width: 767px) {
  .fixed-btn li.-doc a span.btn-txt::after {
    width: 5.33333vw;
    height: 6.4vw;
    margin-top: -2.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .fixed-btn li.-doc a span.btn-txt::after {
    width: 20px;
    height: 24px;
    margin-top: -11px;
  }
}
.fixed-btn li.-contact {
  border-left: 1px solid #75b5cc;
}
.fixed-btn li.-contact a span.btn-txt {
  padding-left: 34px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .fixed-btn li.-contact a span.btn-txt {
    padding-left: 2.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .fixed-btn li.-contact a span.btn-txt {
    padding-left: 9.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .fixed-btn li.-contact a span.btn-txt {
    padding-left: 34px;
  }
}
.fixed-btn li.-contact a span.btn-txt::after {
  width: 22px;
  height: 16px;
  margin-top: -7px;
  background: url(../img/common/ico_contact.svg) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .fixed-btn li.-contact a span.btn-txt::after {
    width: 1.57143vw;
    height: 1.14286vw;
    margin-top: -0.5vw;
  }
}
@media screen and (max-width: 767px) {
  .fixed-btn li.-contact a span.btn-txt::after {
    width: 5.86667vw;
    height: 4.26667vw;
    margin-top: -1.86667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .fixed-btn li.-contact a span.btn-txt::after {
    width: 22px;
    height: 16px;
    margin-top: -7px;
  }
}
.fixed-btn li a {
  text-align: center;
  display: grid;
  place-content: center;
  background: #007AAA;
  color: #fff;
  height: 80px;
  font-size: 16px;
  position: relative;
  overflow: hidden;
}
.fixed-btn li a::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.2;
  z-index: 2;
  -webkit-transform: translateX(-100%);
  -moz-transform: translateX(-100%);
  -ms-transform: translateX(-100%);
  -o-transform: translateX(-100%);
  transform: translateX(-100%);
  -webkit-transition: transform 0.3s 0s ease-out;
  -moz-transition: transform 0.3s 0s ease-out;
  -ms-transition: transform 0.3s 0s ease-out;
  -o-transition: transform 0.3s 0s ease-out;
  transition: transform 0.3s 0s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .fixed-btn li a {
    height: 5.71429vw;
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .fixed-btn li a {
    height: 70px;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .fixed-btn li a {
    font-size: 16px;
  }
}
@media screen and (max-width: 767px) {
  .fixed-btn li a span.icon {
    display: none;
  }
}
.fixed-btn li a span.btn-txt {
  display: inline-block;
  position: relative;
  z-index: 5;
}
.fixed-btn li a span.btn-txt::after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 3;
}
@media screen and (min-width: 1025px) {
  .fixed-btn li a:hover::before {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
}

/*******************************
contents
*******************************/
.contents-footer {
  position: relative;
  width: 100%;
  z-index: 1;
  overflow: hidden;
  padding-top: 80px;
}
.page-index .contents-footer {
  padding-top: 0;
}
.page-index .contents-footer::after {
  content: '';
  display: block;
  position: absolute;
  width: 3000px;
  height: 100%;
  top: 0;
  left: 50%;
  margin-left: 80px;
  background: #F2F4F7;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-index .contents-footer::after {
    margin-left: 5.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .page-index .contents-footer::after {
    margin-left: 0;
    left: 37.5%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-index .contents-footer {
    padding-top: 0;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .contents-footer {
    padding-top: 5.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .contents-footer {
    padding-top: 21.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .contents-footer {
    padding-top: 80px;
  }
}
.page-news-article .contents-footer {
  padding-top: 150px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .contents-footer {
    padding-top: 10.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .contents-footer {
    padding-top: 41.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .contents-footer {
    padding-top: 155px;
  }
}
.page-case_study-article .contents-footer {
  padding-top: 210px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .contents-footer {
    padding-top: 15vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .contents-footer {
    padding-top: 41.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .contents-footer {
    padding-top: 155px;
  }
}

.contents {
  position: relative;
  z-index: 10;
  padding-bottom: 65px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .contents {
    padding-bottom: 4.64286vw;
  }
}
@media screen and (max-width: 767px) {
  .contents {
    padding-bottom: 16vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .contents {
    padding-bottom: 60px;
  }
}
.page-under .contents {
  padding-bottom: 140px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-under .contents {
    padding-bottom: 10vw;
  }
}
@media screen and (max-width: 767px) {
  .page-under .contents {
    padding-bottom: 21.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-under .contents {
    padding-bottom: 80px;
  }
}
.page-under.page-request .contents, .page-under.page-contact .contents {
  padding-bottom: 100px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-under.page-request .contents, .page-under.page-contact .contents {
    padding-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .page-under.page-request .contents, .page-under.page-contact .contents {
    padding-bottom: 16vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-under.page-request .contents, .page-under.page-contact .contents {
    padding-bottom: 60px;
  }
}

.br-sp {
  display: none;
}

.br-pc {
  display: inline;
}

a.link-tel {
  pointer-events: none;
  text-decoration: none !important;
}

.sp-disp {
  display: none;
}

@media screen and (min-width: 1025px) {
  a.link-txt {
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
  a.link-txt:hover {
    opacity: 0.6;
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
}

@media screen and (max-width: 767px) {
  .sp-disp {
    display: block;
  }

  .pc-disp {
    display: none !important;
  }

  .hack-space-sp {
    display: inline-block;
    width: 0.5em;
  }

  .br-sp {
    display: inline;
  }

  .br-pc {
    display: none;
  }

  .link-tel {
    pointer-events: auto;
  }
}
/*******************************
megadrop
*******************************/
.megadrop {
  position: absolute;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  top: 80px;
  display: grid;
  grid-template-rows: 0fr;
  transition: 0.3s grid-template-rows ease;
  background: #fff;
}
.megadrop::after {
  display: block;
  position: absolute;
  content: '';
  width: 100%;
  height: 100%;
  z-index: 1;
  background: #F3F6F8;
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  -o-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
  opacity: 0;
}
.state-mega-li-active .megadrop::after {
  opacity: 1;
  -webkit-transition: opacity 0.3s 0s ease-out;
  -moz-transition: opacity 0.3s 0s ease-out;
  -ms-transition: opacity 0.3s 0s ease-out;
  -o-transition: opacity 0.3s 0s ease-out;
  transition: opacity 0.3s 0s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .megadrop {
    top: 5.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .megadrop {
    position: relative;
    top: 0;
    background: transparent;
  }
  .megadrop::after {
    display: none;
  }
}

.megadrop-hidden {
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .megadrop-hidden {
    overflow: visible;
  }
}

.megadrop-inner {
  position: relative;
  width: 1149px;
  width: 1360px;
  margin: 0 auto;
  text-align: left;
  z-index: 8;
  opacity: 0;
  padding: 40px 0 40px;
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  -o-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
.state-mega-li-active .megadrop-inner {
  opacity: 1;
  -webkit-transition: opacity 0.3s 0.1s ease-out;
  -moz-transition: opacity 0.3s 0.1s ease-out;
  -ms-transition: opacity 0.3s 0.1s ease-out;
  -o-transition: opacity 0.3s 0.1s ease-out;
  transition: opacity 0.3s 0.1s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .megadrop-inner {
    width: 82.07%;
    width: 94.28%;
    padding: 2.85714vw 0 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .megadrop-inner {
    width: 100%;
    opacity: 1;
    padding: 0 0 0;
  }
}
.megadrop-inner nav {
  width: 100%;
  padding: 20px 0 20px;
}
@media screen and (min-width: 768px) and (max-height: 800px) {
  .megadrop-inner nav {
    overflow-y: scroll;
    height: 500px;
  }
}
@media screen and (min-width: 768px) and (max-height: 660px) {
  .megadrop-inner nav {
    overflow-y: scroll;
    height: 400px;
  }
}
@media screen and (min-width: 768px) and (max-height: 560px) {
  .megadrop-inner nav {
    overflow-y: scroll;
    height: 300px;
  }
}
@media screen and (min-width: 768px) and (max-height: 460px) {
  .megadrop-inner nav {
    overflow-y: scroll;
    height: 200px;
  }
}
@media screen and (min-width: 768px) and (max-height: 330px) {
  .megadrop-inner nav {
    overflow-y: scroll;
    height: 150px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1400px) {
  .megadrop-inner nav {
    padding: 1.42857vw 0 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav {
    padding: 0 0 0;
  }
}
.megadrop-inner nav ul li {
  margin-bottom: 56px;
  margin-bottom: 30px;
  padding-left: 38px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .megadrop-inner nav ul li {
    margin-bottom: 4vw;
    margin-bottom: 2.14286vw;
    padding-left: 2.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li {
    margin-bottom: 0;
    padding-left: 0;
    border-bottom: 1px solid #71D8FF;
  }
}
.megadrop-inner nav ul li:last-child {
  margin-bottom: 0;
  border-bottom: none;
}
.megadrop-inner nav ul li a {
  position: relative;
  font-size: 20px;
  color: #1F2426;
  line-height: 1.6;
  -webkit-transition: color 0.2s ease-out;
  -moz-transition: color 0.2s ease-out;
  -ms-transition: color 0.2s ease-out;
  -o-transition: color 0.2s ease-out;
  transition: color 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .megadrop-inner nav ul li a {
    font-size: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li a {
    color: #fff;
    -webkit-display: flex;
    -moz-display: flex;
    -ms-display: flex;
    -o-display: flex;
    display: flex;
    -webkit-flex-direction: column;
    -moz-flex-direction: column;
    -ms-flex-direction: column;
    -o-flex-direction: column;
    flex-direction: column;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    -ms-justify-content: center;
    -o-justify-content: center;
    justify-content: center;
    text-align: left;
    height: 21.33333vw;
    font-size: 4.26667vw;
    padding: 0 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .megadrop-inner nav ul li a {
    height: 80px;
    font-size: 16px;
    padding: 0 10px;
  }
}
.megadrop-inner nav ul li a span {
  display: none;
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li a span {
    display: block;
    position: absolute;
    top: 50%;
    right: 5.33333vw;
    width: 4.26667vw;
    height: 4.26667vw;
    margin-top: -2.13333vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .megadrop-inner nav ul li a span {
    right: 20px;
    width: 16px;
    height: 16px;
    margin-top: -8px;
  }
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li a span::before {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: 0vw;
    margin-left: -1.86667vw;
    width: 4vw;
    height: 0.26667vw;
    background: #fff;
    content: "";
    z-index: 2;
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1);
    -webkit-transition: transform 0.3s 0s ease;
    -moz-transition: transform 0.3s 0s ease;
    -ms-transition: transform 0.3s 0s ease;
    -o-transition: transform 0.3s 0s ease;
    transition: transform 0.3s 0s ease;
    -webkit-border-radius: 1.06667vw;
    -moz-border-radius: 1.06667vw;
    -ms-border-radius: 1.06667vw;
    -o-border-radius: 1.06667vw;
    border-radius: 1.06667vw;
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .megadrop-inner nav ul li a span::before {
    margin-left: -7px;
    width: 15px;
    height: 1px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    -o-border-radius: 4px;
    border-radius: 4px;
  }
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li a span::after {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -1.86667vw;
    margin-left: 0vw;
    width: 0.26667vw;
    height: 4vw;
    background: #fff;
    content: "";
    z-index: 2;
    -webkit-transition: transform 0.3s 0s ease;
    -moz-transition: transform 0.3s 0s ease;
    -ms-transition: transform 0.3s 0s ease;
    -o-transition: transform 0.3s 0s ease;
    transition: transform 0.3s 0s ease;
    -webkit-border-radius: 1.06667vw;
    -moz-border-radius: 1.06667vw;
    -ms-border-radius: 1.06667vw;
    -o-border-radius: 1.06667vw;
    border-radius: 1.06667vw;
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .megadrop-inner nav ul li a span::after {
    margin-top: -7px;
    margin-left: 0px;
    width: 1px;
    height: 15px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    -o-border-radius: 4px;
    border-radius: 4px;
  }
}

.megadrop-inner nav ul li a::after {
  display: block;
  position: absolute;
  content: '';
  width: 22px;
  height: 1px;
  top: 15px;
  left: -38px;
  background: #A0A0A0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .megadrop-inner nav ul li a::after {
    width: 1.57143vw;
    top: 1.07143vw;
    left: -2.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li a::after {
    display: none;
  }
}
@media screen and (min-width: 1025px) {
  .megadrop-inner nav ul li a:hover {
    color: #00AEEF;
    -webkit-transition: color 0.3s ease-out;
    -moz-transition: color 0.3s ease-out;
    -ms-transition: color 0.3s ease-out;
    -o-transition: color 0.3s ease-out;
    transition: color 0.3s ease-out;
  }
}
.megadrop-inner nav ul li.is-active .toggle-con {
  grid-template-rows: 1fr;
  transition: 0.2s grid-template-rows ease;
}
.megadrop-inner nav ul li.is-active > a span::after {
  transform: rotate(90deg);
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li .toggle-con {
    display: grid;
    grid-template-rows: 0fr;
    transition: 0.3s grid-template-rows ease;
  }
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li .toggle-con__inner {
    overflow: hidden;
  }
}
.megadrop-inner nav ul li ul {
  margin-top: 20px;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  -o-justify-content: flex-start;
  justify-content: flex-start;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .megadrop-inner nav ul li ul {
    margin-top: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li ul {
    display: block;
    margin-top: 1.33333vw;
    padding-bottom: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .megadrop-inner nav ul li ul {
    margin-top: 5px;
    padding-bottom: 40px;
  }
}
.megadrop-inner nav ul li ul li {
  width: 25%;
  margin-bottom: 15px;
  margin-bottom: 12px;
  padding-left: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .megadrop-inner nav ul li ul li {
    margin-bottom: 1.07143vw;
    margin-bottom: 0.85714vw;
  }
}
.megadrop-inner nav ul li ul li.sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li ul li.sp {
    display: block;
  }
  .megadrop-inner nav ul li ul li.sp a {
    position: relative;
    font-weight: 500;
  }
  .megadrop-inner nav ul li ul li.sp a::after {
    display: block;
    position: absolute;
    content: '';
    width: 3.2vw;
    height: 1px;
    background: #fff;
    left: 2.66667vw;
    top: 2.93333vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .megadrop-inner nav ul li ul li.sp a::after {
    width: 12px;
    left: 10px;
    top: 11px;
  }
}

.megadrop-inner nav ul li ul li:last-child {
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li ul li {
    width: 100%;
    border-bottom: none;
    margin-bottom: 4vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .megadrop-inner nav ul li ul li {
    margin-bottom: 15px;
  }
}

.megadrop-inner nav ul li ul li a {
  font-size: 16px;
  color: #707070;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .megadrop-inner nav ul li ul li a {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li ul li a {
    color: #fff;
    display: block;
    text-align: left;
    height: auto;
    font-size: 3.73333vw;
    padding: 0 8vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .megadrop-inner nav ul li ul li a {
    font-size: 14px;
    padding: 0 30px;
  }
}

.megadrop-inner nav ul li ul li a::after {
  display: none;
}
.megadrop-inner nav ul li ul li a[target="_blank"] {
  padding-right: 18px;
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li ul li a[target="_blank"] {
    padding-right: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .megadrop-inner nav ul li ul li a[target="_blank"] {
    padding-right: 18px;
  }
}
.megadrop-inner nav ul li ul li a[target="_blank"] img {
  display: block;
  position: absolute;
  width: 12px;
  height: 12px;
  right: 0;
  bottom: 6px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .megadrop-inner nav ul li ul li a[target="_blank"] img {
    bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .megadrop-inner nav ul li ul li a[target="_blank"] img {
    width: 3.2vw;
    height: 3.2vw;
    bottom: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .megadrop-inner nav ul li ul li a[target="_blank"] img {
    width: 12px;
    height: 12px;
    bottom: 4px;
  }
}

/*******************************
header
*******************************/
body.state-mega-active {
  position: fixed;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 1;
}
body.state-mega-active .wrap {
  position: absolute;
  width: 100%;
  height: 100%;
}
body.state-mega-active::after {
  left: 0;
  opacity: 0.5;
  -webkit-transition: opacity 0.4s ease-out;
  -moz-transition: opacity 0.4s ease-out;
  -ms-transition: opacity 0.4s ease-out;
  -o-transition: opacity 0.4s ease-out;
  transition: opacity 0.4s ease-out;
}

@media screen and (max-width: 767px) {
  body.state-menu-active {
    position: fixed;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    z-index: 1;
  }
  body.state-menu-active .header-logo {
    opacity: 0;
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  body.state-menu-active .wrap {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 1;
  }
  body.state-menu-active .header::before {
    opacity: 1;
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  body.state-menu-active .header-assets {
    left: 0;
  }
  body.state-menu-active .header-assets::after {
    opacity: 0.98;
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  body.state-menu-active .header-btn a span {
    background: #fff !important;
  }
  body.state-menu-active .header-btn a span:nth-of-type(2) {
    opacity: 0;
  }
  body.state-menu-active .header-btn a span:nth-of-type(1) {
    margin-top: 0vw;
    -webkit-transform: translateY(0vw) rotate(-30deg);
    -moz-transform: translateY(0vw) rotate(-30deg);
    -ms-transform: translateY(0vw) rotate(-30deg);
    -o-transform: translateY(0vw) rotate(-30deg);
    transform: translateY(0vw) rotate(-30deg);
    /*9=10+8/2*/
  }
  body.state-menu-active .header-btn a span:nth-of-type(3) {
    margin-top: 0vw;
    -webkit-transform: translateY(0) rotate(30deg);
    -moz-transform: translateY(0) rotate(30deg);
    -ms-transform: translateY(0) rotate(30deg);
    -o-transform: translateY(0) rotate(30deg);
    transform: translateY(0) rotate(30deg);
  }
  body.state-menu-active .header-nav {
    opacity: 1;
    -webkit-transition: opacity 0.3s 0.2s ease-out;
    -moz-transition: opacity 0.3s 0.2s ease-out;
    -ms-transition: opacity 0.3s 0.2s ease-out;
    -o-transition: opacity 0.3s 0.2s ease-out;
    transition: opacity 0.3s 0.2s ease-out;
  }
}

.header-inner {
  position: relative;
  width: 100%;
  max-width: 1840px;
  margin: 0 auto;
  z-index: 2;
}
@media screen and (min-width: 1920px) {
  .header-inner {
    margin: 0 auto;
  }
}

.header {
  position: absolute;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 80px;
  z-index: 100;
  padding: 0 40px;
}
.header::after {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: #fff;
  -webkit-transition: transform 0.3s ease-out;
  -moz-transition: transform 0.3s ease-out;
  -ms-transition: transform 0.3s ease-out;
  -o-transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  -webkit-transform: translateY(-100%);
  -moz-transform: translateY(-100%);
  -ms-transform: translateY(-100%);
  -o-transform: translateY(-100%);
  transform: translateY(-100%);
}
.page-under .header::after, .state-header-change .header::after {
  -webkit-transform: translateY(0);
  -moz-transform: translateY(0);
  -ms-transform: translateY(0);
  -o-transform: translateY(0);
  transform: translateY(0);
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .header {
    height: 5.71429vw;
    padding: 0 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .header {
    height: 21.33333vw;
    padding: 0 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .header {
    height: 80px;
  }
}
.header .header-logo {
  position: absolute;
  width: 160px;
  top: 19px;
  left: 0;
  z-index: 20;
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  -o-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
.header .header-logo a {
  display: block;
}
.header .header-logo img {
  position: relative;
  z-index: 1;
}
.header .header-logo::after {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: url(../img/common/logo_col.svg) 0 0 no-repeat;
  background-size: 100% auto;
  z-index: 2;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  -o-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
.page-under .header .header-logo::after, .state-header-change .header .header-logo::after {
  opacity: 1;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .header .header-logo {
    width: 11.42857vw;
    top: 1.35714vw;
  }
}
@media screen and (max-width: 767px) {
  .header .header-logo {
    width: 40vw;
    top: 5.33333vw;
    left: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .header .header-logo {
    width: 150px;
    top: 20px;
    left: 20px;
  }
}
.header .header-btn__search {
  position: absolute;
  width: 50px;
  height: 50px;
  top: 15px;
  right: 0;
  z-index: 30;
}
.header .header-btn__search a {
  display: block;
  position: relative;
}
.header .header-btn__search a::after {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border: 1px solid #D9DCDE;
  border-radius: 50%;
  overflow: hidden;
  opacity: 0;
  z-index: 2;
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  -o-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
.page-under .header .header-btn__search a::after, .state-header-change .header .header-btn__search a::after {
  opacity: 1;
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  -o-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
.header .header-btn__search a img {
  display: block;
  position: relative;
  z-index: 1;
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  -o-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
  border-radius: 50%;
  overflow: hidden;
}
.header .header-btn__search a::before {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border-radius: 50%;
  overflow: hidden;
  opacity: 0;
  z-index: 3;
  background: url(../img/common/ico_search_on.png) 0 0 no-repeat;
  background-size: 100% auto;
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  -o-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
.state-search-active .header .header-btn__search a img {
  opacity: 0;
  -webkit-transition: opacity 0.2s 0.2s ease-out;
  -moz-transition: opacity 0.2s 0.2s ease-out;
  -ms-transition: opacity 0.2s 0.2s ease-out;
  -o-transition: opacity 0.2s 0.2s ease-out;
  transition: opacity 0.2s 0.2s ease-out;
}
.state-search-active .header .header-btn__search a::before {
  opacity: 1;
  -webkit-transition: opacity 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .header .header-btn__search {
    width: 3.57143vw;
    height: 3.57143vw;
    top: 1.07143vw;
  }
}
@media screen and (max-width: 767px) {
  .header .header-btn__search {
    display: none;
  }
}
.header .header-assets {
  position: relative;
  width: 100%;
  height: 80px;
  z-index: 1;
}
.header .header-assets .search-form {
  display: block;
  position: absolute;
  top: 0;
  width: 400px;
  height: 200px;
  z-index: 20;
  right: -2000px;
}
.state-search-active .header .header-assets .search-form {
  right: -40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .state-search-active .header .header-assets .search-form {
    right: -2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .state-search-active .header .header-assets .search-form {
    left: 0;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .header .header-assets .search-form {
    width: 28.57143vw;
    height: 14.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .header .header-assets .search-form {
    display: block;
    position: relative;
    z-index: 10;
    left: 0;
    width: 72vw;
    height: 13.33333vw;
    margin: 13.33333vw auto 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .header .header-assets .search-form {
    height: 50px;
    margin: 50px auto 0;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .header .header-assets {
    height: 5.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .header .header-assets {
    position: fixed;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    padding-top: 16vw;
    padding-bottom: 16vw;
    z-index: 1;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .header .header-assets {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .header .header-assets {
    overflow-y: scroll;
  }
}
@media screen and (max-width: 767px) {
  .header .header-assets::after {
    content: '';
    display: block;
    position: absolute;
    position: fixed;
    width: 100%;
    height: 100%;
    background: #007AAA;
    top: 0;
    left: 0;
    opacity: 0;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
    z-index: 1;
    pointer-events: none;
  }
}
.header .header-nav {
  position: absolute;
  top: 0;
  right: 100px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .header .header-nav {
    right: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .header .header-nav {
    position: relative;
    top: 0;
    right: 0;
  }
}
.header .header-nav > ul {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  -o-justify-content: flex-start;
  justify-content: flex-start;
  position: relative;
  padding-right: 50px;
  padding-left: 10px;
}
.header .header-nav > ul > li {
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .header .header-nav > ul {
    padding-right: 3.57143vw;
    padding-left: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .header .header-nav > ul {
    padding-right: 0;
    padding-left: 0;
  }
}
.header .header-nav > ul::after {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 50px;
  border-radius: 25px;
  top: 15px;
  left: 0;
  background: #fff;
  z-index: 1;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .header .header-nav > ul::after {
    top: 1.07143vw;
    height: 3.57143vw;
    padding-right: 1.78571vw;
  }
}
@media screen and (max-width: 767px) {
  .header .header-nav > ul::after {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .header .header-nav > ul {
    display: block;
    position: relative;
    z-index: 10;
    width: 89.33333vw;
    margin: 5.33333vw auto 0;
    border-top: 1px solid #51a2c1;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .header .header-nav > ul {
    margin: 20px auto 0;
  }
}
@media screen and (max-width: 767px) {
  .header .header-nav > ul li {
    border-bottom: 1px solid #51a2c1;
  }
  .header .header-nav > ul li li {
    border-bottom: none;
  }
  .header .header-nav > ul li .megadrop li {
    border-bottom: 1px solid #51a2c1;
  }
  .header .header-nav > ul li .megadrop li:last-child {
    border-bottom: none;
  }
  .header .header-nav > ul li .megadrop li li {
    border-bottom: none;
  }
}
.header .header-nav > ul > li {
  position: relative;
  margin-left: 40px;
}
@media screen and (min-width: 768px) {
  .page-service .header .header-nav > ul > li:nth-of-type(1) > a::after {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1);
  }
  .page-case_study .header .header-nav > ul > li:nth-of-type(2) > a::after {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1);
  }
  .page-aboutus .header .header-nav > ul > li:nth-of-type(3) > a::after {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1);
  }
  .page-recruit .header .header-nav > ul > li:nth-of-type(4) > a::after {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1);
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .header .header-nav > ul > li {
    margin-left: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .header .header-nav > ul > li {
    margin: 0;
    text-align: left;
  }
  .header .header-nav > ul > li.is-active .megadrop {
    grid-template-rows: 1fr;
    transition: 0.2s grid-template-rows ease;
  }
  .header .header-nav > ul > li.is-active > a span::after {
    transform: rotate(90deg);
  }
}
.header .header-nav > ul > li.state-mega-li-active .megadrop {
  z-index: 100;
  grid-template-rows: 1fr;
  transition: 0.2s grid-template-rows ease;
}
.state-mega-delay .header .header-nav > ul > li.state-mega-li-active .megadrop {
  transition: 0s grid-template-rows ease;
}
.header .header-nav > ul > li.state-mega-li-active > a {
  -webkit-transition: color 0.2s ease-out;
  -moz-transition: color 0.2s ease-out;
  -ms-transition: color 0.2s ease-out;
  -o-transition: color 0.2s ease-out;
  transition: color 0.2s ease-out;
}
.header .header-nav > ul > li.state-mega-li-active > a::after {
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -o-transform: scale(1);
  transform: scale(1);
}
.header .header-nav > ul > li > a {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  height: 80px;
  font-size: 16px;
  color: #33393B;
  padding: 0 0 0;
  position: relative;
  -webkit-transition: color 0.3s ease-out;
  -moz-transition: color 0.3s ease-out;
  -ms-transition: color 0.3s ease-out;
  -o-transition: color 0.3s ease-out;
  transition: color 0.3s ease-out;
}
.page-under .header .header-nav > ul > li > a, .state-header-change .header .header-nav > ul > li > a {
  color: #33393B;
}
@media screen and (max-width: 767px) {
  .page-under .header .header-nav > ul > li > a, .state-header-change .header .header-nav > ul > li > a {
    color: #fff;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .header .header-nav > ul > li > a {
    height: 5.71429vw;
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .header .header-nav > ul > li > a {
    color: #fff;
    text-align: left;
    height: 21.33333vw;
    font-size: 4.26667vw;
    padding: 0 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .header .header-nav > ul > li > a {
    height: 80px;
    font-size: 16px;
    padding: 0 10px;
  }
}
.header .header-nav > ul > li > a::after {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 1px;
  background: #00AEEF;
  border-radius: 50%;
  overflow: hidden;
  left: 0;
  bottom: 20px;
  bottom: 22px;
  -webkit-transform: scaleX(0);
  -moz-transform: scaleX(0);
  -ms-transform: scaleX(0);
  -o-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transition: transform 0.3s ease-out;
  -moz-transition: transform 0.3s ease-out;
  -ms-transition: transform 0.3s ease-out;
  -o-transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
}
.page-under .header .header-nav > ul > li > a::after, .state-header-change .header .header-nav > ul > li > a::after {
  background: #00AEEF;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .header .header-nav > ul > li > a::after {
    bottom: 1.57143vw;
  }
}
@media screen and (min-width: 1025px) {
  .header .header-nav > ul > li > a:hover {
    -webkit-transition: color 0.2s ease-out;
    -moz-transition: color 0.2s ease-out;
    -ms-transition: color 0.2s ease-out;
    -o-transition: color 0.2s ease-out;
    transition: color 0.2s ease-out;
  }
  .header .header-nav > ul > li > a:hover::after {
    -webkit-transition: transform 0.2s ease-out;
    -moz-transition: transform 0.2s ease-out;
    -ms-transition: transform 0.2s ease-out;
    -o-transition: transform 0.2s ease-out;
    transition: transform 0.2s ease-out;
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1);
  }
}
.header .header-nav > ul > li > a span {
  display: none;
}
@media screen and (max-width: 767px) {
  .header .header-nav > ul > li > a span {
    display: block;
    position: absolute;
    top: 50%;
    right: 0;
    width: 4.26667vw;
    height: 4.26667vw;
    margin-top: -2.13333vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .header .header-nav > ul > li > a span {
    width: 16px;
    height: 16px;
    margin-top: -8px;
  }
}
@media screen and (max-width: 767px) {
  .header .header-nav > ul > li > a span::before {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -0.26667vw;
    margin-left: -2.13333vw;
    width: 4.26667vw;
    height: 0.53333vw;
    background: #54C1F0;
    content: "";
    z-index: 2;
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1);
    -webkit-transition: transform 0.3s 0s ease;
    -moz-transition: transform 0.3s 0s ease;
    -ms-transition: transform 0.3s 0s ease;
    -o-transition: transform 0.3s 0s ease;
    transition: transform 0.3s 0s ease;
    -webkit-border-radius: 1.06667vw;
    -moz-border-radius: 1.06667vw;
    -ms-border-radius: 1.06667vw;
    -o-border-radius: 1.06667vw;
    border-radius: 1.06667vw;
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .header .header-nav > ul > li > a span::before {
    margin-top: -1px;
    margin-left: -8px;
    width: 16px;
    height: 2px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    -o-border-radius: 4px;
    border-radius: 4px;
  }
}
@media screen and (max-width: 767px) {
  .header .header-nav > ul > li > a span::after {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -2.13333vw;
    margin-left: -0.26667vw;
    width: 0.53333vw;
    height: 4.26667vw;
    background: #54C1F0;
    content: "";
    z-index: 2;
    -webkit-transition: transform 0.3s 0s ease;
    -moz-transition: transform 0.3s 0s ease;
    -ms-transition: transform 0.3s 0s ease;
    -o-transition: transform 0.3s 0s ease;
    transition: transform 0.3s 0s ease;
    -webkit-border-radius: 1.06667vw;
    -moz-border-radius: 1.06667vw;
    -ms-border-radius: 1.06667vw;
    -o-border-radius: 1.06667vw;
    border-radius: 1.06667vw;
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .header .header-nav > ul > li > a span::after {
    margin-top: -8px;
    margin-left: -1px;
    width: 2px;
    height: 16px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    -o-border-radius: 4px;
    border-radius: 4px;
  }
}

.header-btn {
  display: none;
}
@media screen and (max-width: 767px) {
  .header-btn {
    display: block;
    position: absolute;
    z-index: 20;
    top: 4.26667vw;
    right: 2.93333vw;
    width: 11.73333vw;
    height: 11.73333vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .header-btn {
    top: 16px;
    right: 11px;
    width: 44px;
    height: 44px;
  }
}
@media screen and (max-width: 767px) {
  .header-btn a {
    display: block;
    position: absolute;
    right: 0;
    width: 100%;
    height: 100%;
    z-index: 3;
  }
  .header-btn a span {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 8vw;
    height: 1px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    -o-border-radius: 4px;
    border-radius: 4px;
    overflow: hidden;
    margin-left: -4vw;
    background: #fff;
    -webkit-transition: height 0.3s ease-out, transform 0.3s ease-out, background 0.3s ease-out;
    -moz-transition: height 0.3s ease-out, transform 0.3s ease-out, background 0.3s ease-out;
    -ms-transition: height 0.3s ease-out, transform 0.3s ease-out, background 0.3s ease-out;
    -o-transition: height 0.3s ease-out, transform 0.3s ease-out, background 0.3s ease-out;
    transition: height 0.3s ease-out, transform 0.3s ease-out, background 0.3s ease-out;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .header-btn a span {
    width: 30px;
    margin-left: -15px;
  }
}
@media screen and (max-width: 767px) {
  .page-under .header-btn a span, .state-header-change .header-btn a span {
    background: #707070;
  }
  .header-btn a span:nth-of-type(1) {
    margin-top: -7px;
  }
  .header-btn a span:nth-of-type(2) {
    margin-top: 0;
  }
  .header-btn a span:nth-of-type(2) {
    margin-top: 7px;
  }
}

/*******************************
footer
*******************************/
body.page-contact .footer {
  z-index: 10;
}
body.page-contact .footer-pagetop {
  bottom: 28px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  body.page-contact .footer-pagetop {
    bottom: 2vw;
  }
}
@media screen and (max-width: 767px) {
  body.page-contact .footer-pagetop {
    bottom: auto;
    top: -8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  body.page-contact .footer-pagetop {
    top: -30px;
  }
}

.footer {
  position: relative;
  width: 100%;
  z-index: 5;
  text-align: center;
  background: #fff;
  border-top: 1px solid #D9D8D8;
}

.footer-assets {
  padding: 120px 0 120px;
  max-width: 1140px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
  -webkit-flex-direction: row-reverse;
  -moz-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  -o-flex-direction: row-reverse;
  flex-direction: row-reverse;
  text-align: left;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-assets {
    width: 81.42%;
    padding: 8.57143vw 0 8.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-assets {
    display: block;
    padding: 16vw 0 14.4vw;
    max-width: 91.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-assets {
    padding: 60px 0 54px;
  }
}

.footer-pagetop {
  position: absolute;
  width: 60px;
  height: 60px;
  bottom: 112px;
  left: 50%;
  margin-left: 510px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-pagetop {
    width: 4.28571vw;
    height: 4.28571vw;
    bottom: 8vw;
    margin-left: 36.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-pagetop {
    width: 16vw;
    height: 16vw;
    top: -8vw;
    margin-left: 0;
    left: auto;
    right: 4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-pagetop {
    width: 60px;
    height: 60px;
    top: -30px;
    right: 15px;
  }
}
.footer-pagetop a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
}
.footer-pagetop a::before {
  display: block;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #bee9fc;
  border-radius: 50%;
  overflow: hidden;
  z-index: 1;
  -webkit-transition: background 0.2s ease-out;
  -moz-transition: background 0.2s ease-out;
  -ms-transition: background 0.2s ease-out;
  -o-transition: background 0.2s ease-out;
  transition: background 0.2s ease-out;
}
.footer-pagetop a::after {
  display: block;
  content: '';
  position: absolute;
  top: 5px;
  left: 5px;
  width: 50px;
  height: 50px;
  background: #fff;
  border-radius: 50%;
  overflow: hidden;
  z-index: 2;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-pagetop a::after {
    top: 0.35714vw;
    left: 0.35714vw;
    width: 3.57143vw;
    height: 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-pagetop a::after {
    top: 1.33333vw;
    left: 1.33333vw;
    width: 13.33333vw;
    height: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-pagetop a::after {
    top: 5px;
    left: 5px;
    width: 50px;
    height: 50px;
  }
}
.footer-pagetop a img {
  position: absolute;
  z-index: 3;
  top: 20px;
  left: 20px;
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  overflow: hidden;
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-pagetop a img {
    top: 1.42857vw;
    left: 1.42857vw;
    width: 1.42857vw;
    height: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-pagetop a img {
    top: 5.33333vw;
    left: 5.33333vw;
    width: 5.33333vw;
    height: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-pagetop a img {
    top: 20px;
    left: 20px;
    width: 20px;
    height: 20px;
  }
}
@media screen and (min-width: 1025px) {
  .footer-pagetop a:hover img {
    -webkit-transform: translateY(-5px);
    -moz-transform: translateY(-5px);
    -ms-transform: translateY(-5px);
    -o-transform: translateY(-5px);
    transform: translateY(-5px);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
  .footer-pagetop a:hover::before {
    background: #00AEEF;
    -webkit-transition: background 0.3s ease-out;
    -moz-transition: background 0.3s ease-out;
    -ms-transition: background 0.3s ease-out;
    -o-transition: background 0.3s ease-out;
    transition: background 0.3s ease-out;
  }
}

.footer-logo {
  position: absolute;
  top: 120px;
  left: 0;
  width: 220px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-logo {
    top: 8.57143vw;
    width: 15.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-logo {
    position: relative;
    top: 0;
    left: 0;
    width: 42.66667vw;
    margin-bottom: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-logo {
    width: 160px;
    margin-bottom: 40px;
  }
}

.footer-nav {
  width: 730px;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav {
    width: 64.03%;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav {
    width: 100%;
  }
}
.footer-nav nav {
  width: 325px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav nav {
    width: 44.52%;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav nav {
    width: 100%;
    margin-bottom: 8vw;
  }
  .footer-nav nav:last-child {
    margin-bottom: 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-nav nav {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav nav ul {
    -webkit-display: flex;
    -moz-display: flex;
    -ms-display: flex;
    -o-display: flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    -o-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -ms-justify-content: space-between;
    -o-justify-content: space-between;
    justify-content: space-between;
  }
}
.footer-nav nav ul li {
  margin-bottom: 56px;
  padding-left: 38px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav nav ul li {
    margin-bottom: 4vw;
    padding-left: 2.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav nav ul li {
    margin-bottom: 8vw;
    padding-left: 10.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-nav nav ul li {
    margin-bottom: 30px;
    padding-left: 38px;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav nav ul li {
    width: 100%;
  }
  .footer-nav nav ul li.-sp-half {
    width: 50%;
  }
}
.footer-nav nav ul li.-adjust-pc {
  position: relative;
  top: 2px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav nav ul li.-adjust-pc {
    top: 0.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav nav ul li.-adjust-pc {
    top: 0;
  }
}
.footer-nav nav ul li:last-child {
  margin-bottom: 0;
}
.footer-nav nav ul li a {
  position: relative;
  font-size: 20px;
  color: #1F2426;
  line-height: 1.6;
  -webkit-transition: color 0.2s ease-out;
  -moz-transition: color 0.2s ease-out;
  -ms-transition: color 0.2s ease-out;
  -o-transition: color 0.2s ease-out;
  transition: color 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav nav ul li a {
    font-size: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav nav ul li a {
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-nav nav ul li a {
    font-size: 16px;
  }
}
.footer-nav nav ul li a::after {
  display: block;
  position: absolute;
  content: '';
  width: 22px;
  height: 1px;
  top: 15px;
  left: -38px;
  background: #A0A0A0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav nav ul li a::after {
    width: 1.57143vw;
    top: 1.07143vw;
    left: -2.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav nav ul li a::after {
    width: 5.86667vw;
    top: 3.2vw;
    left: -10.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-nav nav ul li a::after {
    width: 22px;
    top: 12px;
    left: -38px;
  }
}
@media screen and (min-width: 1025px) {
  .footer-nav nav ul li a:hover {
    color: #00AEEF;
    -webkit-transition: color 0.3s ease-out;
    -moz-transition: color 0.3s ease-out;
    -ms-transition: color 0.3s ease-out;
    -o-transition: color 0.3s ease-out;
    transition: color 0.3s ease-out;
  }
}
.footer-nav nav ul li ul {
  margin-top: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav nav ul li ul {
    margin-top: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav nav ul li ul {
    display: block;
    margin-top: 4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-nav nav ul li ul {
    margin-top: 15px;
  }
}
.footer-nav nav ul li ul li {
  margin-bottom: 15px;
  padding-left: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav nav ul li ul li {
    margin-bottom: 1.07143vw;
  }
}
.footer-nav nav ul li ul li:last-child {
  margin-bottom: 0;
}
.footer-nav nav ul li ul li a {
  font-size: 16px;
  color: #707070;
  font-weight: 400;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav nav ul li ul li a {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav nav ul li ul li a {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-nav nav ul li ul li a {
    font-size: 14px;
  }
}
.footer-nav nav ul li ul li a::after {
  display: none;
}
.footer-nav nav ul li ul li a[target="_blank"] {
  padding-right: 18px;
}
@media screen and (max-width: 767px) {
  .footer-nav nav ul li ul li a[target="_blank"] {
    padding-right: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-nav nav ul li ul li a[target="_blank"] {
    padding-right: 18px;
  }
}
.footer-nav nav ul li ul li a[target="_blank"] img {
  display: block;
  position: absolute;
  width: 12px;
  height: 12px;
  right: 0;
  bottom: 6px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav nav ul li ul li a[target="_blank"] img {
    bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav nav ul li ul li a[target="_blank"] img {
    width: 3.2vw;
    height: 3.2vw;
    bottom: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-nav nav ul li ul li a[target="_blank"] img {
    width: 12px;
    height: 12px;
    bottom: 4px;
  }
}

.footer-other {
  padding-top: 510px;
  width: 315px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-other {
    width: 27.63%;
    padding-top: 36.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-other {
    width: 100%;
    padding-top: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-other {
    padding-top: 50px;
  }
}
.footer-other section {
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-other section {
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-other section {
    margin-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-other section {
    margin-bottom: 50px;
  }
}
.footer-other section:last-child {
  margin-bottom: 0;
}

.footer-other__ttl {
  font-size: 16px;
  color: #007AAA;
  margin-bottom: 16px;
  font-weight: 500;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-other__ttl {
    font-size: 1.14286vw;
    margin-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-other__ttl {
    font-size: 4.26667vw;
    margin-bottom: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-other__ttl {
    font-size: 16px;
    margin-bottom: 16px;
  }
}

.footer-other__links {
  margin-left: 5px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-other__links {
    margin-left: 0.35714vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-other__links {
    text-align: center;
    margin-left: 0;
  }
}
.footer-other__links li {
  margin-bottom: 14px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-other__links li {
    margin-bottom: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-other__links li {
    width: 81.06667vw;
    margin: 0 auto 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-other__links li {
    width: 304px;
    margin: 0 auto 14px;
  }
}
.footer-other__links li:last-child {
  margin-bottom: 0;
}
.footer-other__links li a {
  display: block;
  background: #fff;
  position: relative;
}
.footer-other__links li a img {
  -webkit-transition: opacity 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
}
.footer-other__links li a span.icon {
  right: 24px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-other__links li a span.icon {
    right: 1.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-other__links li a span.icon {
    right: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-other__links li a span.icon {
    right: 20px;
  }
}
@media screen and (min-width: 1025px) {
  .footer-other__links li a:hover img {
    opacity: 0.7;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
}

@media screen and (max-width: 767px) {
  .footer-other__assets {
    -webkit-display: flex;
    -moz-display: flex;
    -ms-display: flex;
    -o-display: flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    -o-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -ms-justify-content: space-between;
    -o-justify-content: space-between;
    justify-content: space-between;
    width: 82.66667vw;
    margin: 0 auto;
    margin-top: -2.13333vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .footer-other__assets {
    margin-top: -8px;
  }
}

.footer-other__sns {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  -o-justify-content: flex-start;
  justify-content: flex-start;
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-other__sns {
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-other__sns {
    padding-top: 2.13333vw;
    margin-bottom: 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-other__sns {
    padding-top: 8px;
  }
}
.footer-other__sns li {
  width: 40px;
  margin-right: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-other__sns li {
    width: 2.85714vw;
    margin-right: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-other__sns li {
    width: 10.66667vw;
    margin-right: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-other__sns li {
    width: 40px;
    margin-right: 20px;
  }
}
.footer-other__sns li a {
  display: block;
  border-radius: 50%;
  overflow: hidden;
}
@media screen and (min-width: 1025px) {
  .footer-other__sns li a {
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  .footer-other__sns li a:hover {
    opacity: 0.8;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
}

.footer-other__pmark {
  width: 55px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-other__pmark {
    width: 3.92857vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-other__pmark {
    width: 14.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-other__pmark {
    width: 55px;
  }
}

.footer-nav__sub {
  padding: 36px 0 36px;
  background: #F1F4F7;
  text-align: center;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav__sub {
    padding: 2.57143vw 0 2.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav__sub {
    padding: 5.86667vw 0 2.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-nav__sub {
    padding: 22px 0 8px;
  }
}
.footer-nav__sub nav ul {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
}
.footer-nav__sub nav ul li {
  padding: 0 12px 0 11px;
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav__sub nav ul li {
    padding: 0 0.85714vw 0 0.78571vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav__sub nav ul li {
    padding: 0 3.2vw 0 2.93333vw;
    margin-bottom: 3.73333vw;
  }
  .footer-nav__sub nav ul li:nth-of-type(3) {
    width: 100%;
  }
  .footer-nav__sub nav ul li:nth-of-type(3)::after, .footer-nav__sub nav ul li:nth-of-type(2)::after {
    display: none;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-nav__sub nav ul li {
    padding: 0 12px 0 11px;
    margin-bottom: 14px;
  }
}
.footer-nav__sub nav ul li::after {
  content: '';
  display: block;
  position: absolute;
  width: 1px;
  height: 100%;
  background: #1F2426;
  top: 1px;
  right: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav__sub nav ul li::after {
    top: 0.07143vw;
  }
}
.footer-nav__sub nav ul li:last-child::after {
  display: none;
}
.footer-nav__sub nav ul li a {
  font-size: 14px;
  color: #1F2426;
  font-weight: 400;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-nav__sub nav ul li a {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-nav__sub nav ul li a {
    font-size: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-nav__sub nav ul li a {
    font-size: 12px;
  }
}
@media screen and (min-width: 1025px) {
  .footer-nav__sub nav ul li a {
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  .footer-nav__sub nav ul li a:hover {
    opacity: 0.7;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
}

.footer-copy {
  text-align: center;
  font-size: 12px;
  padding: 22px 0 22px;
  background: #007AAA;
  color: #fff;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .footer-copy {
    font-size: 0.85714vw;
    padding: 1.57143vw 0 1.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .footer-copy {
    border-bottom: 1px solid #75b5cc;
    font-size: 3.2vw;
    line-height: 1.6;
    padding: 3.73333vw 0 24.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .footer-copy {
    font-size: 12px;
    padding: 14px 0 92px;
  }
}

.-underline {
  text-decoration: underline;
  text-underline-offset: 4px;
}

/* tab */
.tab-btn__trial {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0 12px;
  border-bottom: 1px solid #DDDDDD;
  margin-bottom: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .tab-btn__trial {
    gap: 0 0.85714vw;
    margin-bottom: 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .tab-btn__trial {
    gap: 0 1.06667vw;
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .tab-btn__trial {
    gap: 0 4px;
    margin-bottom: 30px;
  }
}
.tab-btn__trial li {
  position: relative;
  background: #fff;
  border-top: 1px solid #DDDDDD;
  border-right: 1px solid #DDDDDD;
  border-left: 1px solid #DDDDDD;
}
.tab-btn__trial li.is-active::after {
  position: absolute;
  content: '';
  display: block;
  width: 100%;
  height: 8px;
  top: 0;
  left: 0;
  background: #007AAA;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .tab-btn__trial li.is-active::after {
    height: 0.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .tab-btn__trial li.is-active::after {
    height: 2.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .tab-btn__trial li.is-active::after {
    height: 8px;
  }
}
.tab-btn__trial li.is-active::before {
  position: absolute;
  content: '';
  display: block;
  width: 100%;
  height: 4px;
  bottom: -2px;
  left: 0;
  background: #fff;
}
.tab-btn__trial li.is-active .txt {
  color: #33393B;
}
.tab-btn__trial li a {
  display: table;
  width: 100%;
  padding: 16px 16px 16px 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .tab-btn__trial li a {
    padding: 1.14286vw 1.14286vw 1.14286vw 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .tab-btn__trial li a {
    display: block;
    padding: 5.33333vw 0 3.2vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .tab-btn__trial li a {
    padding: 20px 0 12px 0;
  }
}
.tab-btn__trial li .txt {
  display: table-cell;
  vertical-align: middle;
  margin-bottom: 0;
  line-height: 1.6;
  color: #777777;
}
@media screen and (max-width: 767px) {
  .tab-btn__trial li .txt {
    display: block;
    text-align: center;
    margin-bottom: 2.66667vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .tab-btn__trial li .txt {
    margin-bottom: 10px;
  }
}

.tab-btn__trial-img {
  display: table-cell;
  vertical-align: middle;
  width: 100px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .tab-btn__trial-img {
    width: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .tab-btn__trial-img {
    width: 26.66667vw;
    display: block;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .tab-btn__trial-img {
    width: 100px;
  }
}

.tab-btn {
  display: table;
  width: 100%;
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .tab-btn {
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .tab-btn {
    margin-bottom: 9.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .tab-btn {
    margin-bottom: 36px;
  }
}
.tab-btn li {
  width: 33.33%;
  display: table-cell;
  vertical-align: middle;
  border-top: 1px solid #DDDDDD;
  border-left: 1px solid #DDDDDD;
  border-bottom: 1px solid #007AAA;
  position: relative;
}
.tab-btn li.is-active {
  border-top: 1px solid #007AAA;
  border-left: 1px solid #007AAA;
  border-bottom: 1px solid #fff;
}
.tab-btn li.is-active a {
  color: #007AAA;
  background: #fff;
}
.tab-btn li.is-active a:hover {
  opacity: 1;
}
.tab-btn li.is-active::after {
  display: block;
  background: #007AAA;
}
.tab-btn li:last-child::after {
  display: block;
  right: 0;
}
.tab-btn li::after {
  display: block;
  position: absolute;
  content: '';
  top: 0;
  right: -1px;
  width: 1px;
  height: 100%;
  background: #DDDDDD;
  display: none;
  z-index: 10;
}
.tab-btn li a {
  display: block;
  position: relative;
  background: #F2F4F7;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  text-align: center;
  color: #666666;
  font-size: 16px;
  height: 72px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .tab-btn li a {
    font-size: 1.14286vw;
    height: 5.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .tab-btn li a {
    font-size: 3.73333vw;
    line-height: 1.4;
    height: 18.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .tab-btn li a {
    font-size: 14px;
    height: 70px;
  }
}
@media screen and (min-width: 1025px) {
  .tab-btn li a {
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  .tab-btn li a:hover {
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
    opacity: 0.7;
  }
}

.tab-con__item {
  display: none;
}
.tab-con__item.is-active {
  display: block;
}

/* icon */
span.icon {
  display: block;
  position: absolute;
  z-index: 10;
  /* L size 58 10 */
  /* M size 32 6 */
}
span.icon.-blank_img {
  width: 12px;
  height: 12px;
  top: 50%;
  margin-top: -6px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-blank_img {
    margin-top: -0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-blank_img {
    width: 3.2vw;
    height: 3.2vw;
    margin-top: -1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-blank_img {
    width: 12px;
    height: 12px;
    margin-top: -6px;
  }
}
span.icon.-blank {
  width: 12px;
  height: 12px;
  top: 50%;
  margin-top: -6px;
  background: url(../img/common/ico_blank_w.png) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-blank {
    margin-top: -0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-blank {
    width: 3.2vw;
    height: 3.2vw;
    margin-top: -1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-blank {
    width: 12px;
    height: 12px;
    margin-top: -6px;
  }
}
span.icon.-arrow {
  display: block;
  position: absolute;
  width: 32px;
  height: 5px;
  margin-top: -3px;
  top: 50%;
  left: 0;
  -webkit-transition: transform 0.1s ease-out;
  -moz-transition: transform 0.1s ease-out;
  -ms-transition: transform 0.1s ease-out;
  -o-transition: transform 0.1s ease-out;
  transition: transform 0.1s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow {
    width: 2.28571vw;
    height: 0.35714vw;
    margin-top: -0.21429vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow {
    width: 8.53333vw;
    height: 1.33333vw;
    margin-top: -0.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow {
    width: 32px;
    height: 5px;
    margin-top: -3px;
  }
}
span.icon.-arrow.-r-20 {
  left: auto;
  right: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-r-20 {
    right: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-r-20 {
    right: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-r-20 {
    right: 20px;
  }
}
span.icon.-arrow.-r-20::after {
  width: 36px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-r-20::after {
    width: 2.57143vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-r-20::after {
    width: 9.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-r-20::after {
    width: 36px;
  }
}
span.icon.-arrow.-r-40 {
  left: auto;
  right: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-r-40 {
    right: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-r-40 {
    right: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-r-40 {
    right: 40px;
  }
}
span.icon.-arrow.-l-40 {
  left: 40px;
  right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-l-40 {
    left: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-l-40 {
    left: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-l-40 {
    left: 40px;
  }
}
span.icon.-arrow.-r-50 {
  left: auto;
  right: 50px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-r-50 {
    right: 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-r-50 {
    right: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-r-50 {
    right: 50px;
  }
}
span.icon.-arrow.-r-60 {
  left: auto;
  right: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-r-60 {
    right: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-r-60 {
    right: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-r-60 {
    right: 20px;
  }
}
span.icon.-arrow.-btm {
  bottom: 0;
  top: auto;
  margin-top: 0 !important;
}
span.icon.-arrow.-size-m {
  width: 46px;
  height: 7px;
  margin-top: -5px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-size-m {
    width: 3.28571vw;
    height: 0.5vw;
    margin-top: -0.35714vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-size-m {
    width: 12.26667vw;
    height: 1.86667vw;
    margin-top: -1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-size-m {
    width: 46px;
    height: 7px;
    margin-top: -5px;
  }
}
span.icon.-arrow.-size-m::after, span.icon.-arrow.-size-m::before {
  width: 42px;
  top: 3px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-size-m::after, span.icon.-arrow.-size-m::before {
    width: 3vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-size-m::after, span.icon.-arrow.-size-m::before {
    width: 12.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-size-m::after, span.icon.-arrow.-size-m::before {
    width: 46px;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-size-m::after, span.icon.-arrow.-size-m::before {
    top: 0.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-size-m::after, span.icon.-arrow.-size-m::before {
    top: 3px;
  }
}
span.icon.-arrow.-size-m::after {
  width: 50px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-size-m::after {
    width: 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-size-m::after {
    width: 12.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-size-m::after {
    width: 46px;
  }
}
span.icon.-arrow.-size-m span {
  width: 7px;
  height: 7px;
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-size-m span {
    width: 1.86667vw;
    height: 1.86667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-size-m span {
    width: 7px;
    height: 7px;
  }
}
span.icon.-arrow.-size-l {
  width: 58px;
  height: 7px;
  margin-top: -5px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-size-l {
    width: 4.14286vw;
    height: 0.5vw;
    margin-top: -0.35714vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-size-l {
    width: 14.93333vw;
    height: 1.86667vw;
    margin-top: -1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-size-l {
    width: 56px;
    height: 7px;
    margin-top: -5px;
  }
}
span.icon.-arrow.-size-l::after, span.icon.-arrow.-size-l::before {
  width: 54px;
  top: 3px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-size-l::after, span.icon.-arrow.-size-l::before {
    width: 3.85714vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-size-l::after, span.icon.-arrow.-size-l::before {
    width: 14.4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-size-l::after, span.icon.-arrow.-size-l::before {
    width: 54px;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-size-l::after, span.icon.-arrow.-size-l::before {
    top: 0.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-size-l::after, span.icon.-arrow.-size-l::before {
    top: 3px;
  }
}
span.icon.-arrow.-size-l::after {
  width: 62px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow.-size-l::after {
    width: 4.42857vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-size-l::after {
    width: 17.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-size-l::after {
    width: 66px;
  }
}
span.icon.-arrow.-size-l span {
  width: 7px;
  height: 7px;
}
@media screen and (max-width: 767px) {
  span.icon.-arrow.-size-l span {
    width: 1.86667vw;
    height: 1.86667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow.-size-l span {
    width: 7px;
    height: 7px;
  }
}
span.icon.-arrow::after, span.icon.-arrow::before {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 28px;
  height: 1px;
  top: 2px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow::after, span.icon.-arrow::before {
    width: 2vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow::after, span.icon.-arrow::before {
    width: 7.46667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow::after, span.icon.-arrow::before {
    width: 28px;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow::after, span.icon.-arrow::before {
    top: 0.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow::after, span.icon.-arrow::before {
    top: 2px;
  }
}
.-back span.icon.-arrow::after, .-back span.icon.-arrow::before {
  left: 4px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-back span.icon.-arrow::after, .-back span.icon.-arrow::before {
    left: 0.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .-back span.icon.-arrow::after, .-back span.icon.-arrow::before {
    left: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-back span.icon.-arrow::after, .-back span.icon.-arrow::before {
    left: 4px;
  }
}
span.icon.-arrow::before {
  -webkit-transform-origin: 100% 50%;
  transform-origin: 100% 50%;
  z-index: 1;
  -webkit-transition: transform 0.3s ease-out, color 0s ease-out, opacitty 0s ease-out;
  -moz-transition: transform 0.3s ease-out, color 0s ease-out, opacitty 0s ease-out;
  -ms-transition: transform 0.3s ease-out, color 0s ease-out, opacitty 0s ease-out;
  -o-transition: transform 0.3s ease-out, color 0s ease-out, opacitty 0s ease-out;
  transition: transform 0.3s ease-out, color 0s ease-out, opacitty 0s ease-out;
}
.-back span.icon.-arrow::before {
  -webkit-transform-origin: 0 50%;
  transform-origin: 0 50%;
}
span.icon.-arrow::after {
  width: 40px;
  -webkit-transform-origin: 0 50%;
  transform-origin: 0 50%;
  -webkit-transform: scaleX(0);
  -moz-transform: scaleX(0);
  -ms-transform: scaleX(0);
  -o-transform: scaleX(0);
  transform: scaleX(0);
  z-index: 2;
  -webkit-transition: transform 0s ease-out, color 0s ease-out, opacitty 0s ease-out;
  -moz-transition: transform 0s ease-out, color 0s ease-out, opacitty 0s ease-out;
  -ms-transition: transform 0s ease-out, color 0s ease-out, opacitty 0s ease-out;
  -o-transition: transform 0s ease-out, color 0s ease-out, opacitty 0s ease-out;
  transition: transform 0s ease-out, color 0s ease-out, opacitty 0s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  span.icon.-arrow::after {
    width: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  span.icon.-arrow::after {
    width: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow::after {
    width: 40px;
  }
}
.-back span.icon.-arrow::after {
  width: 40px;
  left: -8px;
  -webkit-transform-origin: 100% 50%;
  transform-origin: 100% 50%;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-back span.icon.-arrow::after {
    width: 2.85714vw;
    left: -0.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .-back span.icon.-arrow::after {
    width: 10.66667vw;
    left: -2.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-back span.icon.-arrow::after {
    width: 40px;
    left: -8px;
  }
}
span.icon.-arrow span {
  background: url(../img/common/ico_triangle_w.svg) 0 center no-repeat;
  background-size: 100% auto;
  display: block;
  position: absolute;
  width: 5px;
  height: 5px;
  top: 0;
  right: 0;
  z-index: 3;
  -webkit-transition: transform 0.3s ease-out;
  -moz-transition: transform 0.3s ease-out;
  -ms-transition: transform 0.3s ease-out;
  -o-transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
}
@media screen and (max-width: 767px) {
  span.icon.-arrow span {
    width: 1.33333vw;
    height: 1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  span.icon.-arrow span {
    width: 5px;
    height: 5px;
  }
}
.-back span.icon.-arrow span {
  right: auto;
  left: 0;
}
span.icon.-arrow.-arrow-w::after, span.icon.-arrow.-arrow-w::before {
  background: #fff;
}
span.icon.-arrow.-arrow-g::after, span.icon.-arrow.-arrow-g::before {
  background: #707070;
}
span.icon.-arrow.-arrow-g span {
  background: url(../img/common/ico_triangle_g.svg) 0 center no-repeat;
  background-size: 100% auto;
}
span.icon.-arrow.-arrow-b::after, span.icon.-arrow.-arrow-b::before {
  background: #00aeef;
}
span.icon.-arrow.-arrow-b span {
  background: url(../img/common/ico_triangle_b.svg) 0 center no-repeat;
  background-size: 100% auto;
}
.-back span.icon.-arrow.-arrow-b span {
  background: url(../img/common/ico_triangle_b_l.svg) 0 center no-repeat;
  background-size: 100% auto;
}

@media screen and (min-width: 1025px) {
  button:hover span.icon.-arrow::before,
  a:hover span.icon.-arrow::before {
    -webkit-transform: scaleX(0) translateX(10px);
    -moz-transform: scaleX(0) translateX(10px);
    -ms-transform: scaleX(0) translateX(10px);
    -o-transform: scaleX(0) translateX(10px);
    transform: scaleX(0) translateX(10px);
    -webkit-transition: transform 0.1s ease-out;
    -moz-transition: transform 0.1s ease-out;
    -ms-transition: transform 0.1s ease-out;
    -o-transition: transform 0.1s ease-out;
    transition: transform 0.1s ease-out;
  }
  .-back button:hover span.icon.-arrow::before, .-back
  a:hover span.icon.-arrow::before {
    -webkit-transform: scaleX(0) translateX(-10px);
    -moz-transform: scaleX(0) translateX(-10px);
    -ms-transform: scaleX(0) translateX(-10px);
    -o-transform: scaleX(0) translateX(-10px);
    transform: scaleX(0) translateX(-10px);
  }
  button:hover span.icon.-arrow::after,
  a:hover span.icon.-arrow::after {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1);
    -webkit-transition: transform 0.2s 0.2s ease-out, color 0.2s 0.2s ease-out, opacitty 0.2s 0.2s ease-out;
    -moz-transition: transform 0.2s 0.2s ease-out, color 0.2s 0.2s ease-out, opacitty 0.2s 0.2s ease-out;
    -ms-transition: transform 0.2s 0.2s ease-out, color 0.2s 0.2s ease-out, opacitty 0.2s 0.2s ease-out;
    -o-transition: transform 0.2s 0.2s ease-out, color 0.2s 0.2s ease-out, opacitty 0.2s 0.2s ease-out;
    transition: transform 0.2s 0.2s ease-out, color 0.2s 0.2s ease-out, opacitty 0.2s 0.2s ease-out;
  }
  button:hover span.icon.-arrow span,
  a:hover span.icon.-arrow span {
    -webkit-transform: translateX(10px);
    -moz-transform: translateX(10px);
    -ms-transform: translateX(10px);
    -o-transform: translateX(10px);
    transform: translateX(10px);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
  .-back button:hover span.icon.-arrow span, .-back
  a:hover span.icon.-arrow span {
    -webkit-transform: translateX(-10px);
    -moz-transform: translateX(-10px);
    -ms-transform: translateX(-10px);
    -o-transform: translateX(-10px);
    transform: translateX(-10px);
  }
  button:hover span.icon.-arrow.-r-20 span,
  a:hover span.icon.-arrow.-r-20 span {
    -webkit-transform: translateX(6px);
    -moz-transform: translateX(6px);
    -ms-transform: translateX(6px);
    -o-transform: translateX(6px);
    transform: translateX(6px);
  }
  .-back button:hover span.icon.-arrow.-r-20 span, .-back
  a:hover span.icon.-arrow.-r-20 span {
    -webkit-transform: translateX(-6px);
    -moz-transform: translateX(-6px);
    -ms-transform: translateX(-6px);
    -o-transform: translateX(-6px);
    transform: translateX(-6px);
  }
}
/* bnr */
.btm-bnr {
  padding-top: 100px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btm-bnr {
    padding-top: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .btm-bnr {
    padding-top: 18.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btm-bnr {
    padding-top: 70px;
  }
}

.bnr-img {
  width: 700px;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-img {
    width: 61.4%;
  }
}
@media screen and (max-width: 767px) {
  .bnr-img {
    width: 100%;
  }
}
.bnr-img a {
  display: block;
  position: relative;
  padding-bottom: 28.58%;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .bnr-img a {
    padding-bottom: 50.88%;
  }
}
.bnr-img a::after {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: #007AAA;
  opacity: 0.6;
  z-index: 2;
  -webkit-transition: opacity 0.2s ease-out, background 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out, background 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out, background 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out, background 0.2s ease-out;
  transition: opacity 0.2s ease-out, background 0.2s ease-out;
}
.bnr-img a .icon {
  right: 60px;
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-img a .icon {
    right: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .bnr-img a .icon {
    right: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bnr-img a .icon {
    right: 20px;
  }
}
@media screen and (min-width: 1025px) {
  .bnr-img a {
    -webkit-transition: color 0.2s ease-out;
    -moz-transition: color 0.2s ease-out;
    -ms-transition: color 0.2s ease-out;
    -o-transition: color 0.2s ease-out;
    transition: color 0.2s ease-out;
  }
  .bnr-img a:hover {
    -webkit-transition: color 0.3s ease-out;
    -moz-transition: color 0.3s ease-out;
    -ms-transition: color 0.3s ease-out;
    -o-transition: color 0.3s ease-out;
    transition: color 0.3s ease-out;
  }
  .bnr-img a:hover::after {
    background: #007AAA;
    opacity: 0.86;
    -webkit-transition: opacity 0.3s ease-out, background 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out, background 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out, background 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out, background 0.3s ease-out;
    transition: opacity 0.3s ease-out, background 0.3s ease-out;
  }
  .bnr-img a:hover .icon {
    -webkit-transform: translateX(10px);
    -moz-transform: translateX(10px);
    -ms-transform: translateX(10px);
    -o-transform: translateX(10px);
    transform: translateX(10px);
  }
  .bnr-img a:hover .bnr-img__img img {
    -webkit-transition: transform 0.2s ease-out;
    -moz-transition: transform 0.2s ease-out;
    -ms-transition: transform 0.2s ease-out;
    -o-transition: transform 0.2s ease-out;
    transition: transform 0.2s ease-out;
    -webkit-transform: scale(1.04);
    -moz-transform: scale(1.04);
    -ms-transform: scale(1.04);
    -o-transform: scale(1.04);
    transform: scale(1.04);
  }
}

.bnr-img__img {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1;
  overflow: hidden;
}
.bnr-img__img img {
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}

.bnr-img__txt {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 3;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.bnr-img__txt span {
  display: block;
  position: relative;
  left: 60px;
  font-weight: 500;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-img__txt span {
    left: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .bnr-img__txt span {
    left: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bnr-img__txt span {
    left: 18px;
  }
}
.bnr-img__txt span.-en {
  font-family: "Manrope", sans-serif;
  font-size: 14px;
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-img__txt span.-en {
    font-size: 1vw;
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .bnr-img__txt span.-en {
    font-size: 3.73333vw;
    margin-bottom: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bnr-img__txt span.-en {
    font-size: 14px;
    margin-bottom: 16px;
  }
}
.bnr-img__txt span.-ja {
  font-size: 26px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-img__txt span.-ja {
    font-size: 1.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .bnr-img__txt span.-ja {
    font-size: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bnr-img__txt span.-ja {
    font-size: 20px;
  }
}

a.bnr-rich {
  margin: 0 auto;
  position: relative;
  z-index: 2;
  max-width: 1020px;
  width: 100%;
  display: table;
  background: #fff;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.bnr-rich {
    width: 72.85%;
  }
}
@media screen and (max-width: 767px) {
  a.bnr-rich {
    display: block;
    width: 79.16%;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.bnr-rich {
    width: 304px;
    width: 480px;
  }
}
@media screen and (min-width: 1025px) {
  a.bnr-rich:hover .bnr-rich__con {
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
    opacity: 0.9;
  }
  a.bnr-rich:hover .bnr-rich__img img {
    opacity: 0.8;
    -webkit-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -o-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -webkit-transform: scale(1.08);
    -moz-transform: scale(1.08);
    -ms-transform: scale(1.08);
    -o-transform: scale(1.08);
    transform: scale(1.08);
  }
}

.bnr-rich__img {
  display: table-cell;
  vertical-align: middle;
  width: 620px;
  overflow: hidden;
  background: #fff;
}
.bnr-rich__img img {
  -webkit-transition: transform 0.2s ease-out, opacity 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out, opacity 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out, opacity 0.2s ease-out;
  -o-transition: transform 0.2s ease-out, opacity 0.2s ease-out;
  transition: transform 0.2s ease-out, opacity 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-rich__img {
    width: 60.78%;
  }
}
@media screen and (max-width: 767px) {
  .bnr-rich__img {
    display: block;
    width: 100%;
    position: relative;
    z-index: 1;
  }
}

.bnr-rich__con {
  -webkit-transition: opacity 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
  color: #fff;
  display: table-cell;
  vertical-align: middle;
  width: 400px;
  padding: 50px 90px 80px 80px;
  background: #007AAA;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-rich__con {
    width: 39.21%;
    padding: 2.85714vw 6.42857vw 5.71429vw 5.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .bnr-rich__con {
    -webkit-display: flex;
    -moz-display: flex;
    -ms-display: flex;
    -o-display: flex;
    display: flex;
    -webkit-flex-direction: column;
    -moz-flex-direction: column;
    -ms-flex-direction: column;
    -o-flex-direction: column;
    flex-direction: column;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    -ms-justify-content: center;
    -o-justify-content: center;
    justify-content: center;
    width: 100%;
    position: absolute;
    width: 100%;
    height: 100%;
    padding: 6.66667vw 8.8vw 11.2vw 8.8vw;
    z-index: 2;
    background: transparent;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bnr-rich__con {
    padding: 25px 33px 42px 33px;
  }
}

.bnr-rich__inner {
  position: relative;
}
.bnr-rich__inner span.icon {
  top: auto;
  bottom: -30px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-rich__inner span.icon {
    bottom: -2.14286vw !important;
  }
}
@media screen and (max-width: 767px) {
  .bnr-rich__inner span.icon {
    bottom: -8vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bnr-rich__inner span.icon {
    bottom: -30px !important;
  }
}

.bnr-rich__ttl {
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-rich__ttl {
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .bnr-rich__ttl {
    margin-bottom: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bnr-rich__ttl {
    margin-bottom: 16px;
  }
}
.bnr-rich__ttl span {
  display: block;
}
.bnr-rich__ttl span.-en {
  font-weight: 600;
  font-family: "Manrope", sans-serif;
  font-size: 14px;
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-rich__ttl span.-en {
    font-size: 1vw;
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .bnr-rich__ttl span.-en {
    font-size: 3.73333vw;
    margin-bottom: 1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bnr-rich__ttl span.-en {
    font-size: 14px;
    margin-bottom: 6px;
  }
}
.bnr-rich__ttl span.-ja {
  position: relative;
  width: 116%;
  font-weight: 700;
  font-size: 28px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-rich__ttl span.-ja {
    font-size: 2vw;
  }
}
@media screen and (max-width: 767px) {
  .bnr-rich__ttl span.-ja {
    font-size: 7.46667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bnr-rich__ttl span.-ja {
    font-size: 28px;
  }
}

.bnr-rich__txt {
  font-weight: 400;
  line-height: 1.6;
  font-size: 16px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bnr-rich__txt {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .bnr-rich__txt {
    font-weight: 500;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bnr-rich__txt {
    font-size: 16px;
  }
}

/* service */
.bg-items {
  margin-bottom: 100px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-items {
    margin-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-items {
    margin-bottom: 16vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-items {
    margin-bottom: 60px;
  }
}
.bg-items a.bg-item {
  padding: 50px 70px 50px;
  background: #F2F4F7;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-items a.bg-item {
    padding: 3.57143vw 5vw 3.57143vw;
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-items a.bg-item {
    padding: 8vw 8vw 8vw;
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-items a.bg-item {
    padding: 30px 30px 30px;
    margin-bottom: 20px;
  }
}
.bg-items a.bg-item:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 1025px) {
  .bg-items a.bg-item:hover {
    opacity: 0.8;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
  .bg-items a.bg-item:hover .bg-item__img img {
    -webkit-transform: scale(1.08);
    -moz-transform: scale(1.08);
    -ms-transform: scale(1.08);
    -o-transform: scale(1.08);
    transform: scale(1.08);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
}
.bg-items .bg-item__con {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  position: relative;
  position: relative;
  top: -20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-items .bg-item__con {
    top: -1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-items .bg-item__con {
    top: 0;
  }
}
.bg-items a.bg-item {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .bg-items a.bg-item {
    display: block;
  }
}

.bg-item__img {
  overflow: hidden;
  width: 278px;
}
.bg-item__img img {
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-item__img {
    width: 27.8%;
  }
}
@media screen and (max-width: 767px) {
  .bg-item__img {
    width: 100%;
    margin-bottom: 6.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-item__img {
    margin-bottom: 25px;
  }
}

.bg-item__con {
  width: 668px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-item__con {
    width: 66.8%;
  }
}
@media screen and (max-width: 767px) {
  .bg-item__con {
    width: 100%;
    padding-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-item__con {
    padding-bottom: 30px;
  }
}

.bg-item__ttl {
  font-size: 20px;
  line-height: 1.4;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-item__ttl {
    font-size: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-item__ttl {
    line-height: 1.4;
    font-size: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-item__ttl {
    font-size: 20px;
  }
}

.bg-item__txt {
  font-weight: 400;
  font-size: 16px;
  line-height: 1.6;
  margin-top: 14px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-item__txt {
    font-size: 1.14286vw;
    margin-top: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-item__txt {
    line-height: 1.6;
    font-size: 4.26667vw;
    margin-top: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-item__txt {
    font-size: 16px;
    margin-top: 10px;
  }
}

.anchor-link {
  padding-top: 100px;
  margin-top: -100px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .anchor-link {
    padding-top: 7.14286vw;
    margin-top: -7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .anchor-link {
    padding-top: 26.66667vw;
    margin-top: -26.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .anchor-link {
    padding-top: 100px;
    margin-top: -100px;
  }
}

/* section */
.content-bg {
  padding-top: 100px;
  padding-bottom: 100px;
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .content-bg {
    padding-top: 7.14286vw;
    padding-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .content-bg {
    padding-top: 16vw;
    padding-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .content-bg {
    padding-top: 60px;
    padding-bottom: 50px;
  }
}
.content-bg::before {
  content: '';
  display: block;
  position: absolute;
  width: 3000px;
  height: 100%;
  top: 0;
  left: 50%;
  margin-left: -60px;
  background: #F2F4F7;
  z-index: 1;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .content-bg::before {
    margin-left: -4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .content-bg::before {
    margin-left: 0;
    left: 39%;
  }
}
@media screen and (max-width: 767px) {
  .content-bg .content-inner {
    width: 100%;
  }
}

.content-bg__con * {
  position: relative;
  z-index: 5;
}

.content-bg__con {
  padding-top: 100px;
  padding-bottom: 100px;
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .content-bg__con {
    padding-top: 7.14286vw;
    padding-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .content-bg__con {
    padding-top: 16vw;
    padding-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .content-bg__con {
    padding-top: 60px;
    padding-bottom: 50px;
  }
}
.content-bg__con::after {
  display: block;
  content: '';
  position: absolute;
  width: 1330px;
  height: 100%;
  background: #fff;
  z-index: 2;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
  margin-left: -35px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .content-bg__con::after {
    width: 95vw;
    margin-left: -2.5vw;
  }
}
@media screen and (max-width: 767px) {
  .content-bg__con::after {
    left: -11.62%;
    left: -9%;
    margin-left: 0;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
    width: 111.62%;
  }
}

.bg-layouts .toggle-q {
  display: none;
}
@media screen and (max-width: 767px) {
  .bg-layouts .toggle-q {
    display: block;
    background: #F2F4F7;
    padding: 3.73333vw 11.73333vw 3.73333vw 3.73333vw;
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layouts .toggle-q {
    padding: 14px 44px 14px 14px;
    font-size: 14px;
  }
}
.bg-layouts .toggle-a {
  display: block;
}
@media screen and (max-width: 767px) {
  .bg-layouts .toggle-a {
    display: grid;
    grid-template-rows: 0fr;
    transition: 300ms grid-template-rows ease;
  }
}
.bg-layouts .toggle-a__hidden {
  overflow: visible;
}
@media screen and (max-width: 767px) {
  .bg-layouts .toggle-a__hidden {
    overflow: hidden;
  }
}
.bg-layouts .toggle-a__inner {
  padding: 0 0 0 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layouts .toggle-a__inner {
    padding: 0 0 0 0;
  }
}
@media screen and (max-width: 767px) {
  .bg-layouts .toggle-a__inner {
    padding: 0 0 0 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layouts .toggle-a__inner {
    padding: 0 0 0 0;
  }
}

/* toggle */
.toggle-items .toggle-item {
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .toggle-items .toggle-item {
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .toggle-items .toggle-item {
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .toggle-items .toggle-item {
    margin-bottom: 10px;
  }
}
.toggle-items .toggle-item:last-child {
  margin-bottom: 0;
}

.toggle-item.is-active a.toggle-q .toggle-icon:before {
  transform: rotate(90deg);
}
.toggle-item.is-active .toggle-a {
  grid-template-rows: 1fr;
}

.toggle-q {
  padding: 30px 80px 30px 40px;
  position: relative;
  font-size: 18px;
  line-height: 1.5;
  background: #EDFAFF;
  color: #33393B;
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex-wrap: wrap;
  text-align: left;
}
.-faq .toggle-q {
  padding: 30px 80px 30px 82px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-faq .toggle-q {
    padding: 2.14286vw 5.71429vw 2.14286vw 5.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .-faq .toggle-q {
    padding: 5.33333vw 14.4vw 5.33333vw 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-faq .toggle-q {
    padding: 20px 54px 20px 50px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .toggle-q {
    padding: 2.14286vw 5.71429vw 2.14286vw 2.85714vw;
    font-size: 1.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .toggle-q {
    padding: 5.33333vw 14.4vw 5.33333vw 5.33333vw;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .toggle-q {
    padding: 20px 54px 20px 20px;
    font-size: 16px;
  }
}
.toggle-q div {
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  -o-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
@media screen and (min-width: 1025px) {
  .toggle-q:hover div {
    opacity: 0.7;
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
}
.-faq .toggle-q::after {
  display: block;
  content: 'Q.';
  position: absolute;
  font-family: "Manrope", sans-serif;
  color: #0096DF;
  font-weight: 600;
  font-size: 26px;
  top: 24px;
  left: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-faq .toggle-q::after {
    font-size: 1.85714vw;
    top: 1.71429vw;
    left: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .-faq .toggle-q::after {
    font-size: 5.33333vw;
    top: 4.8vw;
    left: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-faq .toggle-q::after {
    font-size: 20px;
    top: 18px;
    left: 20px;
  }
}

.toggle-icon {
  display: block;
  position: absolute;
  top: 50%;
  right: 29px;
  margin-top: -10px;
  width: 20px;
  height: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .toggle-icon {
    right: 2.07143vw;
  }
}
@media screen and (max-width: 767px) {
  .toggle-icon {
    right: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .toggle-icon {
    right: 18px;
  }
}
.toggle-icon::before, .toggle-icon::after {
  display: block;
  content: '';
  position: absolute;
  background: #33393B;
}
.toggle-icon::after {
  width: 19px;
  height: 1px;
  top: 9px;
  left: 0;
}
@media screen and (max-width: 767px) {
  .toggle-icon::after {
    width: 17px;
    height: 1px;
    top: 8px;
  }
}
.toggle-icon::before {
  height: 19px;
  width: 1px;
  left: 9px;
  top: 0;
  -webkit-transition: transform 0.3s ease-out;
  -moz-transition: transform 0.3s ease-out;
  -ms-transition: transform 0.3s ease-out;
  -o-transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
}
@media screen and (max-width: 767px) {
  .toggle-icon::before {
    height: 17px;
    width: 1px;
    left: 8px;
  }
}

.toggle-a {
  padding: 0 0 0 0;
  display: grid;
  grid-template-rows: 0fr;
  transition: 300ms grid-template-rows ease;
}

.toggle-a__hidden {
  overflow: hidden;
}

.toggle-a__inner {
  padding: 44px 0 44px 0;
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .toggle-a__inner {
    padding: 3.14286vw 0 3.14286vw 0;
  }
}
@media screen and (max-width: 767px) {
  .toggle-a__inner {
    padding: 6.4vw 0 6.4vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .toggle-a__inner {
    padding: 24px 0 24px 0;
  }
}
.-faq .toggle-a__inner {
  background: #F7FDFF;
  padding: 44px 80px 44px 82px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-faq .toggle-a__inner {
    padding: 3.14286vw 5.71429vw 3.14286vw 5.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .-faq .toggle-a__inner {
    padding: 6.4vw 13.33333vw 6.4vw 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-faq .toggle-a__inner {
    padding: 24px 50px 24px 50px;
  }
}
.-faq .toggle-a__inner::after {
  display: block;
  content: 'A.';
  position: absolute;
  font-family: "Manrope", sans-serif;
  color: #0096DF;
  font-weight: 600;
  font-size: 26px;
  top: 48px;
  left: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-faq .toggle-a__inner::after {
    font-size: 1.85714vw;
    top: 3.42857vw;
    left: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .-faq .toggle-a__inner::after {
    font-size: 5.33333vw;
    top: 8.53333vw;
    left: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-faq .toggle-a__inner::after {
    font-size: 20px;
    top: 32px;
    left: 20px;
  }
}

.toggle-a___txt {
  font-size: 18px;
  line-height: 1.8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .toggle-a___txt {
    font-size: 1.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .toggle-a___txt {
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .toggle-a___txt {
    font-size: 16px;
  }
}

.mlr-auto {
  margin-left: auto;
  margin-right: auto;
}

.flex-pc {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .flex-pc {
    display: block;
  }
}

.flex-pc__inner {
  margin: 0 0;
}

.-w-242-188 {
  width: 242px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-w-242-188 {
    width: 17.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .-w-242-188 {
    width: 50.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-w-242-188 {
    width: 188px;
  }
}

.-w-583-100per {
  width: 583px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-w-583-100per {
    width: 41.64286vw;
  }
}
@media screen and (max-width: 767px) {
  .-w-583-100per {
    width: 100%;
  }
}

.-w-360-100per {
  width: 360px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-w-360-100per {
    width: 25.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .-w-360-100per {
    width: 100%;
  }
}

.-w-1020-100per {
  width: 1020px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-w-1020-100per {
    width: 72.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .-w-1020-100per {
    width: 100%;
  }
}

figure figcaption {
  display: block;
  font-weight: 400;
  font-size: 16px;
  margin-top: 16px;
  text-align: center;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  figure figcaption {
    font-size: 1.14286vw;
    margin-top: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  figure figcaption {
    margin-top: 4.26667vw;
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  figure figcaption {
    margin-top: 16px;
    font-size: 14px;
  }
}

/* message */
.message-sign {
  text-align: right;
}

/* box-contact */
.box-contact {
  width: 900px;
  margin-left: auto;
  margin-right: auto;
  background: #EDFAFF;
  padding: 60px 0 60px;
  margin-top: 100px !important;
}
.box-contact.-trial {
  background: #F2F4F7;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .box-contact {
    margin-top: 7.14286vw;
    padding: 4.28571vw 0 4.28571vw;
    width: 78.94%;
  }
}
@media screen and (max-width: 767px) {
  .box-contact {
    width: 100%;
    margin-top: 13.33333vw !important;
    padding: 10.66667vw 0 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .box-contact {
    margin-top: 50px !important;
    padding: 40px 0 40px;
  }
}

.box-contact + section {
  margin-top: 100px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .box-contact + section {
    margin-top: 7.14286vw !important;
  }
}
@media screen and (max-width: 767px) {
  .box-contact + section {
    margin-top: 16vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .box-contact + section {
    margin-top: 60px !important;
  }
}

.box-contact__ttl {
  font-size: 26px;
  margin-bottom: 16px;
  line-height: 1;
  text-align: center;
  color: #007AAA;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .box-contact__ttl {
    font-size: 1.85714vw;
    margin-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .box-contact__ttl {
    font-size: 5.33333vw;
    margin-bottom: 4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .box-contact__ttl {
    font-size: 20px;
    margin-bottom: 15px;
  }
}

.box-contact__txt {
  font-size: 16px;
  margin-bottom: 35px;
  line-height: 1.8;
  text-align: center;
  font-weight: 400;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .box-contact__txt {
    font-size: 1.14286vw;
    margin-bottom: 2.5vw;
  }
}
@media screen and (max-width: 767px) {
  .box-contact__txt {
    font-size: 3.73333vw;
    margin-bottom: 6.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .box-contact__txt {
    font-size: 14px;
    margin-bottom: 25px;
  }
}

/* faq */
.faq-items .faq-item {
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .faq-items .faq-item {
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .faq-items .faq-item {
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .faq-items .faq-item {
    margin-bottom: 20px;
  }
}
.faq-items .faq-item:last-child {
  margin-bottom: 0;
}

.faq-item__q {
  font-size: 16px;
  margin-bottom: 6px;
  line-height: 1.8;
  position: relative;
  padding-left: 1.5em;
  font-weight: 400;
}
.faq-item__q .faq-qa {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .faq-item__q {
    font-size: 1.14286vw;
    margin-bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .faq-item__q {
    font-size: 4.26667vw;
    margin-bottom: 1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .faq-item__q {
    font-size: 16px;
    margin-bottom: 6px;
  }
}

.faq-item__a {
  font-size: 16px;
  line-height: 1.8;
  position: relative;
  padding-left: 1.5em;
  font-weight: 400;
}
.faq-item__a .faq-qa {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .faq-item__a {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .faq-item__a {
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .faq-item__a {
    font-size: 16px;
  }
}

/* sitemap */
.sitemap-links li {
  margin-bottom: 100px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links li {
    margin-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links li {
    margin-bottom: 13.33333vw;
  }
}
.sitemap-links li.-has-child {
  margin-bottom: 50px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links li.-has-child {
    margin-bottom: 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links li.-has-child {
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links li.-has-child {
    margin-bottom: 30px;
  }
}
.sitemap-links li:last-child {
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links li:last-child {
    margin-bottom: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links li:last-child {
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links li:last-child {
    margin-bottom: 30px;
  }
}
.sitemap-links li a {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  -o-justify-content: flex-start;
  justify-content: flex-start;
  padding: 0 0 30px 0;
  border-bottom: 1px solid #D9D8D8;
  position: relative;
  font-size: 26px;
  -webkit-transition: color 0.2s ease-out;
  -moz-transition: color 0.2s ease-out;
  -ms-transition: color 0.2s ease-out;
  -o-transition: color 0.2s ease-out;
  transition: color 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links li a {
    font-size: 1.85714vw;
    padding: 0 0 2.14286vw 0vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links li a {
    font-size: 5.33333vw;
    line-height: 1.4;
    padding: 0 0 4.26667vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links li a {
    font-size: 20px;
    padding: 0 0 16px 0;
  }
}
.sitemap-links li a::before {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 1px;
  background: #00AEEF;
  left: 0;
  bottom: 0;
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
  -webkit-transform: scaleX(0);
  -moz-transform: scaleX(0);
  -ms-transform: scaleX(0);
  -o-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
@media screen and (min-width: 1025px) {
  .sitemap-links li a:hover {
    color: #00AEEF;
    -webkit-transition: color 0.3s ease-out;
    -moz-transition: color 0.3s ease-out;
    -ms-transition: color 0.3s ease-out;
    -o-transition: color 0.3s ease-out;
    transition: color 0.3s ease-out;
  }
  .sitemap-links li a:hover::after {
    -webkit-transform: translateX(8px);
    -moz-transform: translateX(8px);
    -ms-transform: translateX(8px);
    -o-transform: translateX(8px);
    transform: translateX(8px);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
  .sitemap-links li a:hover::before {
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1);
  }
}
.sitemap-links li ul {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 40px 0;
  margin-top: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links li ul {
    margin-top: 2.14286vw;
    gap: 2.85714vw 0;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links li ul {
    display: block;
    margin-top: 8vw;
    margin-bottom: 8vw;
    gap: 5.33333vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links li ul {
    margin-top: 30px;
    margin-bottom: 30px;
    gap: 20px 0;
  }
}
.sitemap-links li ul li {
  gap: 0 0;
  margin-bottom: 0px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links li ul li {
    margin-bottom: 0vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links li ul li {
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links li ul li {
    margin-bottom: 30px;
  }
}
.sitemap-links li ul li a {
  display: inline-block;
  font-size: 18px;
  border-bottom: none;
  line-height: 1.6;
  -webkit-transition: opacity 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
  padding: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links li ul li a {
    font-size: 1.28571vw;
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links li ul li a {
    font-size: 4.8vw;
    padding: 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links li ul li a {
    font-size: 18px;
  }
}
.sitemap-links li ul li a::before {
  display: none;
}
@media screen and (min-width: 1025px) {
  .sitemap-links li ul li a:hover {
    opacity: 0.6;
  }
}
.sitemap-links li ul li a[target="_blank"] {
  position: relative;
  padding-right: 20px;
}
@media screen and (max-width: 767px) {
  .sitemap-links li ul li a[target="_blank"] {
    padding-right: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links li ul li a[target="_blank"] {
    padding-right: 20px;
  }
}
.sitemap-links li ul li a[target="_blank"]::before {
  content: '';
  display: block;
  position: absolute;
  width: 12px;
  height: 12px;
  left: auto;
  right: 0;
  bottom: 6px;
  background: url(../img/common/ico_blank_g.png) 0 0 no-repeat;
  background-size: 100% auto;
  -webkit-transform: scaleX(1);
  -moz-transform: scaleX(1);
  -ms-transform: scaleX(1);
  -o-transform: scaleX(1);
  transform: scaleX(1);
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links li ul li a[target="_blank"]::before {
    bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links li ul li a[target="_blank"]::before {
    width: 3.2vw;
    height: 3.2vw;
    bottom: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links li ul li a[target="_blank"]::before {
    width: 12px;
    height: 12px;
    bottom: 4px;
  }
}

.sitemap-links__layouts {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts {
    display: block;
  }
}
.sitemap-links__layouts .sitemap-links__layout {
  width: 33.3%;
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout {
    width: 100%;
    margin-bottom: 12.26667vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout {
    margin-bottom: 46px;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout:last-child {
    margin-bottom: 0;
  }
}
.sitemap-links__layouts .sitemap-links__layout ul {
  display: block;
  gap: 0 0;
}
.sitemap-links__layouts .sitemap-links__layout ul li {
  margin-bottom: 80px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links__layouts .sitemap-links__layout ul li {
    margin-bottom: 5.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li {
    margin-bottom: 12.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li {
    margin-bottom: 46px;
  }
}
.sitemap-links__layouts .sitemap-links__layout ul li:last-child {
  margin-bottom: 0;
}
.sitemap-links__layouts .sitemap-links__layout ul li a {
  font-size: 16px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links__layouts .sitemap-links__layout ul li a {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li a {
    font-size: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li a {
    font-size: 18px;
  }
}
.sitemap-links__layouts .sitemap-links__layout ul li ul {
  margin-top: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul {
    margin-top: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul {
    margin-top: 6.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul {
    margin-top: 25px;
  }
}
.sitemap-links__layouts .sitemap-links__layout ul li ul li {
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li {
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li {
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li {
    margin-bottom: 20px;
  }
}
.sitemap-links__layouts .sitemap-links__layout ul li ul li:last-child {
  margin-bottom: 0;
}
.sitemap-links__layouts .sitemap-links__layout ul li ul li a {
  position: relative;
  padding-left: 22px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li a {
    padding-left: 1.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li a {
    padding-left: 5.86667vw;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li a {
    padding-left: 22px;
    font-size: 16px;
  }
}
.sitemap-links__layouts .sitemap-links__layout ul li ul li a::after {
  display: block;
  position: absolute;
  content: '';
  width: 12px;
  height: 1px;
  top: 13px;
  left: 0;
  background: #A0A0A0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li a::after {
    width: 0.85714vw;
    top: 0.92857vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li a::after {
    width: 3.2vw;
    top: 3.46667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li a::after {
    width: 12px;
    top: 13px;
  }
}
@media screen and (min-width: 1025px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li a:hover::after {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
}
.sitemap-links__layouts .sitemap-links__layout ul li ul li ul li {
  margin-left: 14px;
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li ul li {
    margin-left: 1vw;
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li ul li {
    margin-left: 3.2vw;
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li ul li {
    margin-left: 12px;
    margin-bottom: 10px;
  }
}
.sitemap-links__layouts .sitemap-links__layout ul li ul li ul li a::after {
  display: none;
}
.sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul {
  margin-left: 14px;
  margin-top: 20px;
  margin-bottom: 20px;
  display: block;
  gap: 10px 2px;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  -o-justify-content: flex-start;
  justify-content: flex-start;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul {
    margin-left: 1vw;
    margin-top: 1.42857vw;
    margin-bottom: 1.42857vw;
    gap: 0.71429vw 0.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul {
    margin-top: 4vw;
    margin-bottom: 5.33333vw;
    gap: 2.66667vw 0.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul {
    margin-top: 15px;
    margin-bottom: 20px;
    gap: 10px 2px;
  }
}
.sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul li {
  margin-bottom: 0;
  position: relative;
}
.sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul li:nth-child(3n)::before {
  display: none;
}
.sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul li::before {
  display: block;
  position: absolute;
  content: '/';
  top: 50%;
  right: -1em;
  -webkit-transform: translateY(-44%);
  -moz-transform: translateY(-44%);
  -ms-transform: translateY(-44%);
  -o-transform: translateY(-44%);
  transform: translateY(-44%);
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul li::before {
    top: 45%;
  }
}
.sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul li a {
  font-size: 14px;
  text-decoration: underline;
  padding-left: 0;
  position: relative;
  line-height: 1;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul li a {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul li a {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul li a {
    font-size: 14px;
  }
}
@media screen and (min-width: 1025px) {
  .sitemap-links__layouts .sitemap-links__layout ul li ul li ul li ul li a:hover {
    text-decoration: none;
  }
}

/***********/
.content-inner {
  margin: 0 auto;
  position: relative;
  z-index: 2;
  max-width: 1140px;
  width: 100%;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .content-inner {
    width: 81.42%;
  }
}
@media screen and (max-width: 767px) {
  .content-inner {
    width: 89.58%;
  }
}
.content-inner.-flex-pc {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
.content-inner.-flex-pc .article-wrap {
  padding-top: 40px;
  width: 900px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .content-inner.-flex-pc .article-wrap {
    width: 78.94%;
    padding-top: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .content-inner.-flex-pc .article-wrap {
    width: 100%;
    padding-top: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .content-inner.-flex-pc .article-wrap {
    padding-top: 50px;
  }
}
.content-inner.-flex-pc .article-aside {
  width: 160px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .content-inner.-flex-pc .article-aside {
    width: 14.03%;
  }
}
@media screen and (max-width: 767px) {
  .content-inner.-flex-pc .article-aside {
    position: absolute;
    top: 0;
    right: 0;
    width: 34.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .content-inner.-flex-pc .article-aside {
    width: 130px;
  }
}
.page-wabpage .content-inner section {
  margin-bottom: 90px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-wabpage .content-inner section {
    margin-bottom: 6.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .page-wabpage .content-inner section {
    margin-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-wabpage .content-inner section {
    margin-bottom: 50px;
  }
}
.page-wabpage .content-inner section:last-child {
  margin-bottom: 0;
}
.page-wabpage .content-inner section section {
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-wabpage .content-inner section section {
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .page-wabpage .content-inner section section {
    margin-bottom: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-wabpage .content-inner section section {
    margin-bottom: 40px;
  }
}
.page-wabpage .content-inner section section:last-child {
  margin-bottom: 0;
}
.page-wabpage .content-inner section section .sec-block {
  margin-bottom: 90px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-wabpage .content-inner section section .sec-block {
    margin-bottom: 6.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .page-wabpage .content-inner section section .sec-block {
    margin-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-wabpage .content-inner section section .sec-block {
    margin-bottom: 50px;
  }
}
.page-wabpage .content-inner section section .sec-block:last-child {
  margin-bottom: 0;
}
.page-wabpage .content-inner section section section {
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-wabpage .content-inner section section section {
    margin-bottom: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .page-wabpage .content-inner section section section {
    margin-bottom: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-wabpage .content-inner section section section {
    margin-bottom: 40px;
  }
}
.page-wabpage .content-inner section section section:last-child {
  margin-bottom: 0;
}

.w-1140-400 {
  max-width: 400px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .w-1140-400 {
    width: 35.08%;
  }
}
@media screen and (max-width: 767px) {
  .w-1140-400 {
    width: 100%;
  }
}

.txt-caption {
  text-align: center;
  display: block;
  margin-top: 20px;
  font-size: 16px;
  font-weight: 400;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .txt-caption {
    margin-top: 1.42857vw;
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .txt-caption {
    margin-top: 5.33333vw;
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .txt-caption {
    margin-top: 20px;
    font-size: 14px;
  }
}
.txt-caption span {
  position: relative;
  display: inline-block;
}

.-ico-finger {
  position: relative;
  padding-left: 28px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-ico-finger {
    padding-left: 2vw;
  }
}
@media screen and (max-width: 767px) {
  .-ico-finger {
    padding-left: 7.46667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-ico-finger {
    padding-left: 28px;
  }
}
.-ico-finger::after {
  display: block;
  position: absolute;
  content: '';
  width: 19px;
  height: 32px;
  top: 50%;
  left: 0;
  margin-top: -16px;
  background: url(../img/common/ico_finger.png) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-ico-finger::after {
    width: 1.35714vw;
    height: 2.28571vw;
    margin-top: -1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .-ico-finger::after {
    width: 5.06667vw;
    height: 8.53333vw;
    margin-top: -4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-ico-finger::after {
    width: 19px;
    height: 32px;
    margin-top: -16px;
  }
}

.w-1140-640 {
  max-width: 640px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .w-1140-640 {
    width: 56.14%;
  }
}
@media screen and (max-width: 767px) {
  .w-1140-640 {
    width: 100%;
  }
}

.w-1140-760 {
  max-width: 760px;
  margin: 0 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .w-1140-760 {
    width: 66.66%;
  }
}
@media screen and (max-width: 767px) {
  .w-1140-760 {
    width: 100%;
  }
}

.w-1140-800 {
  max-width: 800px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .w-1140-800 {
    width: 70.17%;
  }
}
@media screen and (max-width: 767px) {
  .w-1140-800 {
    width: 100%;
  }
}

.w-1140-900 {
  max-width: 900px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .w-1140-900 {
    width: 78.94%;
  }
}
@media screen and (max-width: 767px) {
  .w-1140-900 {
    width: 100%;
  }
}

.w-1140-960 {
  max-width: 960px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .w-1140-960 {
    width: 84.21%;
  }
}
@media screen and (max-width: 767px) {
  .w-1140-960 {
    width: 100%;
  }
}

.content-offset {
  padding: 0 20px;
  max-width: 1140px;
  max-width: 1180px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.-w-pc-1020 {
  max-width: 1020px;
  margin-left: auto;
  margin-right: auto;
}

/*********************************************
common
*********************************************/
strong {
  font-weight: 500 !important;
}

.mail-indent {
  position: relative;
  padding-left: 3.2em;
}
.mail-indent span.-indent {
  position: absolute;
  top: 0;
  left: 0;
}

.-w-pc-160 {
  display: inline-block;
  width: 160px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-w-pc-160 {
    width: 11.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .-w-pc-160 {
    display: block;
    width: 100%;
  }
}

.-ta-c {
  text-align: center !important;
}
.-ta-c img {
  margin-left: auto;
  margin-right: auto;
}

.-ta-c-pc {
  text-align: center !important;
}
@media screen and (max-width: 767px) {
  .-ta-c-pc {
    text-align: left !important;
  }
}

.-ta-l {
  text-align: left !important;
}

.-ta-r {
  text-align: right !important;
}

/* txt */
.-fw-b {
  font-weight: 700 !important;
}

.-fw-m {
  font-weight: 500 !important;
}

.-fw-r {
  font-weight: 400 !important;
}

.-fs-12 {
  font-size: 12px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-fs-12 {
    font-size: 0.85714vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-fs-12 {
    font-size: 3.2vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-fs-12 {
    font-size: 12px !important;
  }
}

.-fs-16 {
  font-size: 16px !important;
  line-height: 2;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-fs-16 {
    font-size: 1.14286vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-fs-16 {
    font-size: 4.26667vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-fs-16 {
    font-size: 16px !important;
  }
}

.-fs-14 {
  font-size: 14px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-fs-14 {
    font-size: 1vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-fs-14 {
    font-size: 3.73333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-fs-14 {
    font-size: 14px !important;
  }
}

.-fs-18 {
  font-size: 18px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-fs-18 {
    font-size: 1.28571vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-fs-18 {
    font-size: 4.26667vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-fs-18 {
    font-size: 16px !important;
  }
}

.-fs-20 {
  font-size: 20px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-fs-20 {
    font-size: 1.42857vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-fs-20 {
    font-size: 4.8vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-fs-20 {
    font-size: 18px !important;
  }
}

.-fs-24 {
  font-size: 24px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-fs-24 {
    font-size: 1.71429vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-fs-24 {
    font-size: 4.8vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-fs-24 {
    font-size: 18px !important;
  }
}

.-fs-28 {
  font-size: 28px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-fs-28 {
    font-size: 2vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-fs-28 {
    font-size: 5.86667vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-fs-28 {
    font-size: 22px !important;
  }
}

.-fs-36 {
  font-size: 36px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-fs-36 {
    font-size: 2.57143vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-fs-36 {
    font-size: 6.4vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-fs-36 {
    font-size: 24px !important;
  }
}

@media screen and (max-width: 767px) {
  .-fs-14-sp {
    font-size: 3.73333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-fs-14-sp {
    font-size: 14px !important;
  }
}

@media screen and (max-width: 767px) {
  .-fs-16-sp {
    font-size: 4.26667vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-fs-16-sp {
    font-size: 16px !important;
  }
}

@media screen and (max-width: 767px) {
  .-fs-20-sp {
    font-size: 5.33333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-fs-20-sp {
    font-size: 20px !important;
  }
}

@media screen and (max-width: 767px) {
  .-sp-parentheses {
    padding-left: 0.75em;
  }

  .-sp-w-hack {
    position: relative;
    width: 120%;
    left: -10%;
  }
}
a.link-blank.-lh-1::after {
  bottom: 2px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-blank.-lh-1::after {
    bottom: 0.14286vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-blank.-lh-1::after {
    bottom: 0.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-blank.-lh-1::after {
    bottom: 1px;
  }
}

.-lh-1 {
  line-height: 1 !important;
}

.-lh-l {
  line-height: 3 !important;
}
@media screen and (max-width: 767px) {
  .-lh-l {
    line-height: 2.5 !important;
  }
}

.-lh-m {
  line-height: 2.2 !important;
}
@media screen and (max-width: 767px) {
  .-lh-m {
    line-height: 2.2 !important;
  }
}

.-col-red {
  color: #b50000 !important;
}
.-col-red a {
  color: #b50000 !important;
}

.-col-blue {
  color: #007AAA !important;
}
.-col-blue a {
  color: #007AAA !important;
}

.-scale-08 {
  -webkit-transform: scale(0.8);
  -moz-transform: scale(0.8);
  -ms-transform: scale(0.8);
  -o-transform: scale(0.8);
  transform: scale(0.8);
}

.txt {
  font-size: 16px;
  line-height: 2.0;
  font-weight: 400;
  letter-spacing: 0.08em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .txt {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .txt {
    line-height: 2.0;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .txt {
    font-size: 16px;
  }
}
@media screen and (max-width: 767px) {
  .txt.-ls-s-sp {
    letter-spacing: 0.06em;
  }
}
@media screen and (max-width: 767px) {
  .txt.-ls-0-sp {
    position: relative;
    width: 110%;
    letter-spacing: -0.01em !important;
  }
}
.txt.-fs-14 {
  font-size: 14px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .txt.-fs-14 {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .txt.-fs-14 {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .txt.-fs-14 {
    font-size: 14px;
  }
}
.txt.-fs-18 {
  font-size: 18px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .txt.-fs-18 {
    font-size: 1.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .txt.-fs-18 {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .txt.-fs-18 {
    font-size: 14px;
  }
}
.txt.-fs-20 {
  font-size: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .txt.-fs-20 {
    font-size: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .txt.-fs-20 {
    font-size: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .txt.-fs-20 {
    font-size: 20px;
  }
}
.txt.-fs-22 {
  font-size: 22px;
  line-height: 1.7;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .txt.-fs-22 {
    font-size: 1.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .txt.-fs-22 {
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .txt.-fs-22 {
    font-size: 16px;
  }
}

/* margin */
.-ml-15 {
  margin-left: 15px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-ml-15 {
    margin-left: 1.07143vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-ml-15 {
    margin-left: 2.66667vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-ml-15 {
    margin-left: 10px !important;
  }
}

.-mt-05 {
  margin-top: 5px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mt-05 {
    margin-top: 0.35714vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mt-05 {
    margin-top: 1.33333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mt-05 {
    margin-top: 5px !important;
  }
}

.-mt-10 {
  margin-top: 10px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mt-10 {
    margin-top: 0.71429vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mt-10 {
    margin-top: 2.66667vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mt-10 {
    margin-top: 10px !important;
  }
}

.-mt-15 {
  margin-top: 15px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mt-15 {
    margin-top: 1.07143vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mt-15 {
    margin-top: 4vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mt-15 {
    margin-top: 15px !important;
  }
}

.-mt-20 {
  margin-top: 20px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mt-20 {
    margin-top: 1.42857vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mt-20 {
    margin-top: 5.33333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mt-20 {
    margin-top: 20px !important;
  }
}

.-mt-30 {
  margin-top: 30px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mt-30 {
    margin-top: 2.14286vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mt-30 {
    margin-top: 8vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mt-30 {
    margin-top: 30px !important;
  }
}

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

.-mb-03 {
  margin-bottom: 3px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-03 {
    margin-bottom: 0.21429vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-03 {
    margin-bottom: 0.8vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-03 {
    margin-bottom: 3px !important;
  }
}

.-mb-05 {
  margin-bottom: 5px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-05 {
    margin-bottom: 0.35714vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-05 {
    margin-bottom: 1.33333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-05 {
    margin-bottom: 5px !important;
  }
}

.-mb-10 {
  margin-bottom: 10px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-10 {
    margin-bottom: 0.71429vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-10 {
    margin-bottom: 2.66667vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-10 {
    margin-bottom: 10px !important;
  }
}

.-mb-12 {
  margin-bottom: 12px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-12 {
    margin-bottom: 0.85714vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-12 {
    margin-bottom: 3.2vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-12 {
    margin-bottom: 12px !important;
  }
}

.-mb-15 {
  margin-bottom: 15px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-15 {
    margin-bottom: 1.07143vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-15 {
    margin-bottom: 4vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-15 {
    margin-bottom: 15px !important;
  }
}

.-mb-20 {
  margin-bottom: 20px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-20 {
    margin-bottom: 1.42857vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-20 {
    margin-bottom: 5.33333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-20 {
    margin-bottom: 20px !important;
  }
}

.-mb-25 {
  margin-bottom: 25px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-25 {
    margin-bottom: 1.78571vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-25 {
    margin-bottom: 6.66667vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-25 {
    margin-bottom: 25px !important;
  }
}

.-mb-30 {
  margin-bottom: 30px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-30 {
    margin-bottom: 2.14286vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-30 {
    margin-bottom: 8vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-30 {
    margin-bottom: 30px !important;
  }
}

.-mb-35 {
  margin-bottom: 35px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-35 {
    margin-bottom: 2.5vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-35 {
    margin-bottom: 9.33333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-35 {
    margin-bottom: 35px !important;
  }
}

.-mb-40 {
  margin-bottom: 40px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-40 {
    margin-bottom: 2.85714vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-40 {
    margin-bottom: 10.66667vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-40 {
    margin-bottom: 40px !important;
  }
}

/* 50 以上で　差が出る*/
.-mb-50 {
  margin-bottom: 50px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-50 {
    margin-bottom: 3.57143vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-50 {
    margin-bottom: 8vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-50 {
    margin-bottom: 30px !important;
  }
}

.-mb-55 {
  margin-bottom: 55px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-55 {
    margin-bottom: 3.92857vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-55 {
    margin-bottom: 7.46667vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-55 {
    margin-bottom: 28px !important;
  }
}

.-mb-60 {
  margin-bottom: 60px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-60 {
    margin-bottom: 4.28571vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-60 {
    margin-bottom: 10.66667vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-60 {
    margin-bottom: 40px !important;
  }
}

.-mb-70 {
  margin-bottom: 70px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-70 {
    margin-bottom: 5vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-70 {
    margin-bottom: 13.33333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-70 {
    margin-bottom: 50px !important;
  }
}

.-mb-80 {
  margin-bottom: 80px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-80 {
    margin-bottom: 5.71429vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-80 {
    margin-bottom: 16vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-80 {
    margin-bottom: 60px !important;
  }
}

.-mb-90 {
  margin-bottom: 90px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-90 {
    margin-bottom: 6.42857vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-90 {
    margin-bottom: 21.33333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-90 {
    margin-bottom: 80px !important;
  }
}

.-mb-100 {
  margin-bottom: 100px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-mb-100 {
    margin-bottom: 7.14286vw !important;
  }
}
@media screen and (max-width: 767px) {
  .-mb-100 {
    margin-bottom: 21.33333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-mb-100 {
    margin-bottom: 80px !important;
  }
}

@media screen and (max-width: 767px) {
  .-pb-5-sp {
    padding-bottom: 1.33333vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-pb-5-sp {
    padding-bottom: 5px !important;
  }
}

@media screen and (max-width: 767px) and (max-width: 767px) {
  .-mt-15-sp {
    margin-top: 4vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mt-15-sp {
    margin-top: 15px !important;
  }
}

@media screen and (max-width: 767px) and (max-width: 767px) {
  .-mt-40-sp {
    margin-top: 10.66667vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mt-40-sp {
    margin-top: 40px !important;
  }
}

@media screen and (max-width: 767px) and (max-width: 767px) {
  .-mt-50-sp {
    margin-top: 13.33333vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mt-50-sp {
    margin-top: 50px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-05-sp {
    margin-bottom: 1.33333vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-05-sp {
    margin-bottom: 5px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-10-sp {
    margin-bottom: 2.66667vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-10-sp {
    margin-bottom: 10px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-12-sp {
    margin-bottom: 3.2vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-12-sp {
    margin-bottom: 12px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-15-sp {
    margin-bottom: 4vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-15-sp {
    margin-bottom: 15px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-20-sp {
    margin-bottom: 5.33333vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-20-sp {
    margin-bottom: 20px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-25-sp {
    margin-bottom: 6.66667vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-25-sp {
    margin-bottom: 25px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-30-sp {
    margin-bottom: 8vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-30-sp {
    margin-bottom: 30px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-40-sp {
    margin-bottom: 10.66667vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-40-sp {
    margin-bottom: 40px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-45-sp {
    margin-bottom: 12vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-45-sp {
    margin-bottom: 45px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-50-sp {
    margin-bottom: 13.33333vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-50-sp {
    margin-bottom: 50px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-55-sp {
    margin-bottom: 14.66667vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-55-sp {
    margin-bottom: 55px !important;
  }
}

@media screen and (max-width: 767px) {
  .-mb-60-sp {
    margin-bottom: 16vw !important;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-mb-60-sp {
    margin-bottom: 60px !important;
  }
}

/* link */
@media screen and (min-width: 1025px) {
  a.hover-opacity {
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  a.hover-opacity:hover {
    opacity: 0.7;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
}

a.link-blank_img {
  position: relative;
  display: inline-block;
  padding-right: 18px;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  a.link-blank_img {
    padding-right: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-blank_img {
    padding-right: 18px;
  }
}
a.link-blank_img img {
  display: block;
  position: absolute;
  width: 12px;
  height: 12px;
  right: 0;
  bottom: 7px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-blank_img img {
    bottom: 0.5vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-blank_img img {
    width: 3.2vw;
    height: 3.2vw;
    bottom: 1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-blank_img img {
    width: 12px;
    height: 12px;
    bottom: 5px;
  }
}

a.link-blank {
  position: relative;
  display: inline-block;
  padding-right: 18px;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  a.link-blank {
    padding-right: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-blank {
    padding-right: 18px;
  }
}
a.link-blank::after {
  content: '';
  display: block;
  position: absolute;
  width: 12px;
  height: 12px;
  right: 0;
  bottom: 7px;
  background: url(../img/common/ico_blank_g.png) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-blank::after {
    bottom: 0.5vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-blank::after {
    width: 3.2vw;
    height: 3.2vw;
    bottom: 1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-blank::after {
    width: 12px;
    height: 12px;
    bottom: 5px;
  }
}

a.link-url {
  word-break: break-all;
  letter-spacing: 0;
  font-weight: 400;
}
@media screen and (min-width: 1025px) {
  a.link-url {
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  a.link-url:hover {
    opacity: 0.7;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
}

@media screen and (min-width: 1025px) {
  a.link-hover {
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  a.link-hover:hover {
    opacity: 0.7;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
}

a.link-col {
  color: #00AEEF;
  color: #007AAA;
}

a.link-bnr-90 {
  display: inline-block;
  position: relative;
  padding-left: 104px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-bnr-90 {
    padding-left: 7.42857vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-bnr-90 {
    padding-left: 27.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-bnr-90 {
    padding-left: 104px;
  }
}
a.link-bnr-90 img.img-bnr-90 {
  position: absolute;
  display: block;
  width: 90px;
  height: auto;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-bnr-90 img.img-bnr-90 {
    width: 6.42857vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-bnr-90 img.img-bnr-90 {
    width: 24vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-bnr-90 img.img-bnr-90 {
    width: 90px;
  }
}

a.link-pdf_img {
  display: inline-block;
  position: relative;
  padding-right: 32px;
}
@media screen and (max-width: 767px) {
  a.link-pdf_img {
    padding-right: 8.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-pdf_img {
    padding-right: 32px;
  }
}
a.link-pdf_img img {
  display: block;
  position: absolute;
  width: 25px;
  height: 13px;
  right: 0;
  bottom: 8px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-pdf_img img {
    bottom: 0.28571vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-pdf_img img {
    width: 6.66667vw;
    height: 3.46667vw;
    bottom: 2.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-pdf_img img {
    width: 25px;
    height: 13px;
    bottom: 8px;
  }
}

a.link-pdf {
  position: relative;
  padding-right: 32px;
}
@media screen and (max-width: 767px) {
  a.link-pdf {
    padding-right: 8.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-pdf {
    padding-right: 32px;
  }
}
a.link-pdf::after {
  content: '';
  display: block;
  position: absolute;
  width: 25px;
  height: 13px;
  right: 0;
  bottom: 4px;
  background: url(../img/common/ico_pdf_g.png) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-pdf::after {
    bottom: 0.28571vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-pdf::after {
    width: 6.66667vw;
    height: 3.46667vw;
    bottom: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-pdf::after {
    width: 25px;
    height: 13px;
    bottom: 4px;
  }
}

a.link-underline {
  text-decoration: underline;
}
@media screen and (min-width: 1025px) {
  a.link-underline:hover {
    text-decoration: none;
  }
}

a.link-movie {
  display: block;
  text-align: center;
}
@media screen and (min-width: 1025px) {
  a.link-movie:hover .link-movie__txt span.-main {
    text-decoration: none;
  }
  a.link-movie:hover .link-movie__img::before {
    opacity: 0.0;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
  a.link-movie:hover .link-movie__img span::before {
    -webkit-transform: scale(1.1);
    -moz-transform: scale(1.1);
    -ms-transform: scale(1.1);
    -o-transform: scale(1.1);
    transform: scale(1.1);
    -webkit-transition: transform 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    -moz-transition: transform 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    -ms-transition: transform 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    -o-transition: transform 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transition: transform 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  }
}
a.link-movie .link-movie__img {
  position: relative;
  margin-bottom: 16px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-movie .link-movie__img {
    margin-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-movie .link-movie__img {
    margin-bottom: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-movie .link-movie__img {
    margin-bottom: 16px;
  }
}
a.link-movie .link-movie__img img {
  position: relative;
  z-index: 1;
}
a.link-movie .link-movie__img.has-border::after {
  display: block;
  position: absolute;
  content: '';
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 3;
  border: 1px solid #C8C8C8;
}
a.link-movie .link-movie__img::before {
  display: block;
  position: absolute;
  content: '';
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: #33393B;
  opacity: 0.2;
  z-index: 2;
  -webkit-transition: opacity 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
}
a.link-movie .link-movie__img span {
  display: block;
  width: 70px;
  height: 70px;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -35px;
  margin-left: -35px;
  z-index: 10;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-movie .link-movie__img span {
    width: 5vw;
    height: 5vw;
    margin-top: -2.5vw;
    margin-left: -2.5vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-movie .link-movie__img span {
    width: 10.66667vw;
    height: 10.66667vw;
    margin-top: -5.33333vw;
    margin-left: -5.33333vw;
  }
}
a.link-movie .link-movie__img span::before {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
  background: #4fc8f5;
  background: linear-gradient(315deg, #4fc8f5 0%, #0077ef 100%);
  border-radius: 50%;
  overflow: hidden;
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
a.link-movie .link-movie__img span::after {
  display: block;
  content: '';
  position: absolute;
  width: 10px;
  height: 18px;
  background: url(../img/common/ico_arrow_fff.svg) center center no-repeat;
  background-size: 100% auto;
  left: 50%;
  top: 50%;
  margin-left: -4px;
  margin-top: -9px;
  z-index: 2;
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-movie .link-movie__img span::after {
    width: 0.71429vw;
    height: 1.28571vw;
    margin-left: -0.28571vw;
    margin-top: -0.64286vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-movie .link-movie__img span::after {
    width: 1.6vw;
    height: 3.2vw;
    margin-top: -1.6vw;
    margin-left: -0.8vw;
  }
}
a.link-movie .link-movie__txt span {
  display: block;
}
a.link-movie .link-movie__txt span.-main {
  font-size: 16px;
  text-decoration: underline;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-movie .link-movie__txt span.-main {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-movie .link-movie__txt span.-main {
    font-size: 4.26667vw;
    line-height: 1.5;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-movie .link-movie__txt span.-main {
    font-size: 16px;
  }
}
a.link-movie .link-movie__txt span.-sub {
  font-size: 12px;
  margin-top: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  a.link-movie .link-movie__txt span.-sub {
    font-size: 0.85714vw;
    margin-top: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  a.link-movie .link-movie__txt span.-sub {
    font-size: 3.2vw;
    margin-top: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  a.link-movie .link-movie__txt span.-sub {
    font-size: 12px;
    margin-top: 10px;
  }
}

.img-per-100 {
  width: 100%;
}

.img-haken-ho {
  width: 690px;
  margin: 60px 0 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-haken-ho {
    width: 60.52%;
    margin: 4.28571vw 0 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .img-haken-ho {
    width: 100%;
    margin: 8vw 0 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .img-haken-ho {
    margin: 30px 0 30px;
  }
}

.img-sign {
  display: inline-block;
  width: 150px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-sign {
    width: 13.15%;
  }
}
@media screen and (max-width: 767px) {
  .img-sign {
    width: 37.33333vw;
  }
}

.imgs-case_study {
  width: 840px;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .imgs-case_study {
    width: 73.68%;
  }
}
@media screen and (max-width: 767px) {
  .imgs-case_study {
    display: block;
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
}
.imgs-case_study img {
  display: block;
  width: 400px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .imgs-case_study img {
    width: 47.61%;
  }
}
@media screen and (max-width: 767px) {
  .imgs-case_study img {
    width: 100%;
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .imgs-case_study img {
    margin-bottom: 20px;
  }
}

.img-case_study {
  display: block;
  width: 400px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-case_study {
    width: 35.08%;
  }
}
@media screen and (max-width: 767px) {
  .img-case_study {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
}
.img-case_study.-w-480 {
  width: 480px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-case_study.-w-480 {
    width: 42.1%;
  }
}
@media screen and (max-width: 767px) {
  .img-case_study.-w-480 {
    width: 100%;
  }
}
.img-case_study.-w-610 {
  width: 610px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-case_study.-w-610 {
    width: 53.5%;
  }
}
@media screen and (max-width: 767px) {
  .img-case_study.-w-610 {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}
.img-case_study.-w-720 {
  width: 720px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-case_study.-w-720 {
    width: 63.15%;
  }
}
@media screen and (max-width: 767px) {
  .img-case_study.-w-720 {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}
.img-case_study.-w-896 {
  width: 896px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-case_study.-w-896 {
    width: 78.59%;
  }
}
@media screen and (max-width: 767px) {
  .img-case_study.-w-896 {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

.img-news-150 {
  width: 150px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-news-150 {
    width: 16.66%;
  }
}
@media screen and (max-width: 767px) {
  .img-news-150 {
    width: 40vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .img-news-150 {
    width: 150px;
  }
}

.img-96 {
  width: 96px;
}
@media screen and (max-width: 767px) {
  .img-96 {
    width: 25.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .img-96 {
    width: 96px;
  }
}

.img-176 {
  width: 176px;
}
@media screen and (max-width: 767px) {
  .img-176 {
    width: 46.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .img-176 {
    width: 176px;
  }
}

.img-200 {
  width: 200px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-200 {
    width: 17.54%;
  }
}
@media screen and (max-width: 767px) {
  .img-200 {
    width: 53.33333vw;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .img-200 {
    width: 200px;
  }
}

.img-378 {
  width: 378px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-378 {
    width: 33.15%;
  }
}
@media screen and (max-width: 767px) {
  .img-378 {
    width: 70%;
  }
}

.img-300 {
  width: 300px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-300 {
    width: 26.31%;
  }
}
@media screen and (max-width: 767px) {
  .img-300 {
    width: 70%;
  }
}

.img-500 {
  width: 500px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-500 {
    width: 43.85%;
  }
}
@media screen and (max-width: 767px) {
  .img-500 {
    width: 100%;
  }
}

.img-560 {
  width: 560px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-560 {
    width: 49.12%;
  }
}
@media screen and (max-width: 767px) {
  .img-560 {
    width: 100%;
  }
}

.img-600 {
  width: 600px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-600 {
    width: 52.63%;
  }
}
@media screen and (max-width: 767px) {
  .img-600 {
    width: 100%;
  }
}

.img-800 {
  width: 800px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-800 {
    width: 70.17%;
  }
}
@media screen and (max-width: 767px) {
  .img-800 {
    width: 100%;
  }
}

.img-880 {
  width: 880px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-880 {
    width: 77.19%;
  }
}
@media screen and (max-width: 767px) {
  .img-880 {
    width: 100%;
  }
}

.img-900 {
  width: 900px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-900 {
    width: 78.94%;
  }
}
@media screen and (max-width: 767px) {
  .img-900 {
    width: 100%;
  }
}

.img-960 {
  width: 960px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-960 {
    width: 84.21%;
  }
}
@media screen and (max-width: 767px) {
  .img-960 {
    width: 100%;
  }
}

.img-1020 {
  width: 1020px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-1020 {
    width: 89.47%;
  }
}
@media screen and (max-width: 767px) {
  .img-1020 {
    width: 100%;
  }
}

.img-442 {
  width: 442px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-442 {
    width: 38.77%;
  }
}
@media screen and (max-width: 767px) {
  .img-442 {
    width: 100%;
  }
}

/*********************************************
table dl
*********************************************/
.-plr-0 {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.-td-w-2em {
  width: 2em !important;
}

.-w-per-10 {
  width: 10% !important;
}

.-w-per-12 {
  width: 12% !important;
}

.-w-per-15 {
  width: 15% !important;
}

.-w-per-16 {
  width: 16% !important;
}

.-w-per-18 {
  width: 18% !important;
}

.-w-per-20 {
  width: 20% !important;
}

.-w-per-22 {
  width: 22% !important;
}

.-w-per-24 {
  width: 24% !important;
}

.-w-per-26 {
  width: 26% !important;
}

.-w-per-30 {
  width: 30% !important;
}

.-w-per-34 {
  width: 34% !important;
}

.-w-per-36 {
  width: 36% !important;
}

.-w-per-40 {
  width: 40% !important;
}

.-w-per-42 {
  width: 42% !important;
}

.-w-per-45 {
  width: 45% !important;
}

.-w-per-50 {
  width: 50% !important;
}

.-w-per-55 {
  width: 55% !important;
}

.-w-per-58 {
  width: 58% !important;
}

.-w-per-60 {
  width: 60% !important;
}

.-w-per-70 {
  width: 70% !important;
}

.-w-per-80 {
  width: 80% !important;
}

.-td-w-258 {
  width: 258px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-td-w-258 {
    width: 18.42857vw;
  }
}

.-td-w-220 {
  width: 220px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-td-w-220 {
    width: 15.71429vw;
  }
}

.-td-w-per-20 {
  width: 20%;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.dl-plan dl {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  -o-justify-content: flex-start;
  justify-content: flex-start;
  font-size: 16px;
  line-height: 2.0;
  margin-bottom: 10px;
  font-weight: 400;
}
.dl-plan dl:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-plan dl {
    font-size: 1.14286vw;
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .dl-plan dl {
    display: block;
    font-size: 4.26667vw;
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-plan dl {
    font-size: 16px;
    margin-bottom: 10px;
  }
}
.dl-plan dl dt {
  padding-right: 2em;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .dl-plan dl dt {
    padding-right: 0;
  }
}

.dl-table {
  border-bottom: 1px solid #C8C8C8;
}
.dl-table dl {
  border-right: 1px solid #C8C8C8;
  width: 100%;
  display: table;
}
@media screen and (max-width: 767px) {
  .dl-table dl {
    display: block;
  }
}
.dl-table dt,
.dl-table dd {
  width: 50%;
  font-weight: 400;
  font-size: 16px;
  padding-top: 26px;
  padding-bottom: 26px;
  border-top: 1px solid #C8C8C8;
  border-left: 1px solid #C8C8C8;
  line-height: 1.8;
  display: table-cell;
  vertical-align: middle;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-table dt,
  .dl-table dd {
    font-size: 1.14286vw;
    padding-top: 1.85714vw;
    padding-bottom: 1.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .dl-table dt,
  .dl-table dd {
    width: 100%;
    display: block;
    font-size: 4.26667vw;
    padding-top: 4.8vw;
    padding-bottom: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-table dt,
  .dl-table dd {
    font-size: 16px;
    padding-top: 18px;
    padding-bottom: 18px;
  }
}
.dl-table dt {
  text-align: center;
  background: #F2F4F7;
}
@media screen and (max-width: 767px) {
  .dl-table dt {
    padding-left: 3.73333vw;
    padding-right: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-table dt {
    padding-left: 14px;
    padding-right: 14px;
  }
}
.dl-table dd {
  text-align: left;
  padding-left: 2.85714vw;
  padding-right: 2.85714vw;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-table dd {
    padding-left: 2.85714vw;
    padding-right: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .dl-table dd {
    text-align: center;
    padding-left: 3.73333vw;
    padding-right: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-table dd {
    padding-left: 14px;
    padding-right: 14px;
  }
}
.dl-table.-table-01 dt {
  width: 220px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-table.-table-01 dt {
    width: 15.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .dl-table.-table-01 dt {
    width: 100%;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-table.-table-01 dt {
    width: 100%;
  }
}
.dl-table.-table-01 dd {
  width: auto;
}
@media screen and (max-width: 767px) {
  .dl-table.-table-01 dd {
    width: 100%;
  }
}

.table-02,
.table-01 {
  border-bottom: 1px solid #C8C8C8;
  border-right: 1px solid #C8C8C8;
  width: 100%;
}
.table-02.-no-border,
.table-01.-no-border {
  border-bottom: none;
  border-right: none;
}
.table-02.-no-border th,
.table-02.-no-border td,
.table-01.-no-border th,
.table-01.-no-border td {
  border-top: none;
  border-left: none;
  padding-left: 0;
  padding-right: 0;
}
.table-02.-per-50 th,
.table-02.-per-50 td,
.table-01.-per-50 th,
.table-01.-per-50 td {
  width: 50%;
}
.table-02.-per-33 th,
.table-02.-per-33 td,
.table-01.-per-33 th,
.table-01.-per-33 td {
  width: 33.33%;
}
.table-02 thead th,
.table-01 thead th {
  background: #E0E0E0;
  width: auto;
  font-weight: 500;
}
.table-02.-td-center td,
.table-01.-td-center td {
  text-align: center;
}
.table-02 th,
.table-02 td,
.table-01 th,
.table-01 td {
  font-weight: 400;
  font-size: 16px;
  padding-top: 26px;
  padding-bottom: 26px;
  border-top: 1px solid #C8C8C8;
  border-left: 1px solid #C8C8C8;
}
.table-02 th.-td-r-border,
.table-02 td.-td-r-border,
.table-01 th.-td-r-border,
.table-01 td.-td-r-border {
  border-right: 1px solid #C8C8C8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .table-02 th.-td-download,
  .table-02 td.-td-download,
  .table-01 th.-td-download,
  .table-01 td.-td-download {
    padding-left: 1.42857vw !important;
    padding-right: 1.42857vw !important;
  }
}
@media screen and (max-width: 767px) {
  .table-02 th.-td-download,
  .table-02 td.-td-download,
  .table-01 th.-td-download,
  .table-01 td.-td-download {
    padding-left: 3.73333vw !important;
    padding-right: 3.73333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .table-02 th.-td-download,
  .table-02 td.-td-download,
  .table-01 th.-td-download,
  .table-01 td.-td-download {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .table-02 th,
  .table-02 td,
  .table-01 th,
  .table-01 td {
    font-size: 1.14286vw;
    padding-top: 1.85714vw;
    padding-bottom: 1.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .table-02 th,
  .table-02 td,
  .table-01 th,
  .table-01 td {
    font-size: 4.26667vw;
    padding-top: 4.8vw;
    padding-bottom: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .table-02 th,
  .table-02 td,
  .table-01 th,
  .table-01 td {
    font-size: 16px;
    padding-top: 18px;
    padding-bottom: 18px;
  }
}
.table-02 th.no-border,
.table-02 td.no-border,
.table-01 th.no-border,
.table-01 td.no-border {
  border-left: none;
  position: relative;
  padding-top: 10px;
  padding-left: 14px;
  padding-right: 14px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .table-02 th.no-border,
  .table-02 td.no-border,
  .table-01 th.no-border,
  .table-01 td.no-border {
    padding-top: 0.71429vw;
    padding-left: 1vw;
    padding-right: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .table-02 th.no-border,
  .table-02 td.no-border,
  .table-01 th.no-border,
  .table-01 td.no-border {
    padding-left: 3.73333vw;
    padding-right: 3.73333vw;
    padding-top: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .table-02 th.no-border,
  .table-02 td.no-border,
  .table-01 th.no-border,
  .table-01 td.no-border {
    padding-top: 18px;
    padding-left: 14px;
    padding-right: 14px;
  }
}
.table-02 th.no-border::after,
.table-02 td.no-border::after,
.table-01 th.no-border::after,
.table-01 td.no-border::after {
  content: '';
  display: block;
  position: absolute;
  width: 2px;
  height: 100%;
  background: #fff;
  top: 0;
  right: -1px;
}
@media screen and (max-width: 767px) {
  .table-02 th.no-border::after,
  .table-02 td.no-border::after,
  .table-01 th.no-border::after,
  .table-01 td.no-border::after {
    display: none;
  }
}
.table-02 th.no-border-btm,
.table-02 td.no-border-btm,
.table-01 th.no-border-btm,
.table-01 td.no-border-btm {
  position: relative;
}
.table-02 th.no-border-btm::before,
.table-02 td.no-border-btm::before,
.table-01 th.no-border-btm::before,
.table-01 td.no-border-btm::before {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 1px;
  background: #fff;
  bottom: -1px;
  left: 0;
}
@media screen and (max-width: 767px) {
  .table-02 th.no-border-btm::before,
  .table-02 td.no-border-btm::before,
  .table-01 th.no-border-btm::before,
  .table-01 td.no-border-btm::before {
    display: none;
  }
}
.table-02.th-l th,
.table-01.th-l th {
  text-align: left;
  padding-left: 40px;
  padding-right: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .table-02.th-l th,
  .table-01.th-l th {
    padding-left: 2.85714vw;
    padding-right: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .table-02.th-l th,
  .table-01.th-l th {
    padding-left: 3.73333vw;
    padding-right: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .table-02.th-l th,
  .table-01.th-l th {
    padding-left: 14px;
    padding-right: 14px;
  }
}
.table-02 td,
.table-01 td {
  text-align: left;
  padding-left: 40px;
  padding-right: 40px;
  line-height: 1.8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .table-02 td,
  .table-01 td {
    padding-left: 2.85714vw;
    padding-right: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .table-02 td,
  .table-01 td {
    line-height: 1.6;
    padding-left: 3.73333vw;
    padding-right: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .table-02 td,
  .table-01 td {
    padding-left: 14px;
    padding-right: 14px;
  }
}
.table-02 td.-bg-f2f4f7,
.table-01 td.-bg-f2f4f7 {
  background: #F2F4F7;
}
.table-02 td.-td-l-no-border,
.table-01 td.-td-l-no-border {
  border-left: none;
}
.table-02 td.-td-t-no-border,
.table-01 td.-td-t-no-border {
  border-top: none;
}
.table-02 td.-pl-70,
.table-01 td.-pl-70 {
  padding-left: 70px;
}
@media screen and (max-width: 767px) {
  .table-02 td.-pl-70,
  .table-01 td.-pl-70 {
    padding-left: 5vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .table-02 td.-pl-70,
  .table-01 td.-pl-70 {
    padding-left: 70px;
  }
}
.table-02 td.-pa-tr-0,
.table-01 td.-pa-tr-0 {
  padding-left: 0;
  padding-right: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .table-02 td.-pa-tr-0,
  .table-01 td.-pa-tr-0 {
    padding-left: 0;
    padding-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .table-02 td.-pa-tr-0,
  .table-01 td.-pa-tr-0 {
    padding-left: 0;
    padding-right: 0;
  }
}
.table-02 th,
.table-01 th {
  line-height: 1.8;
  text-align: center;
  background: #F2F4F7;
  width: 220px;
}
.table-02 th.has-date,
.table-01 th.has-date {
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .table-02 th.has-date,
  .table-01 th.has-date {
    line-height: 1.2;
    width: 42.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .table-02 th.has-date,
  .table-01 th.has-date {
    width: 160px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .table-02 th,
  .table-01 th {
    width: 15.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .table-02 th,
  .table-01 th {
    width: 24vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .table-02 th,
  .table-01 th {
    width: 90px;
  }
}
@media screen and (max-width: 767px) {
  .table-02.-lh-s-sp td,
  .table-02.-lh-s-sp th,
  .table-01.-lh-s-sp td,
  .table-01.-lh-s-sp th {
    line-height: 1.4;
  }
}

.table-02 td {
  padding-left: 20px;
  padding-right: 20px;
  text-align: center;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .table-02 td {
    padding-left: 1.42857vw;
    padding-right: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .table-02 td {
    padding-left: 3.73333vw;
    padding-right: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .table-02 td {
    padding-left: 14px;
    padding-right: 14px;
  }
}

.dl-address {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 40px 110px;
}
.dl-address.-column-01 {
  grid-template-columns: 1fr;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-address {
    gap: 2.85714vw 7.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .dl-address {
    grid-template-columns: 1fr;
    gap: 8vw 0vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-address {
    gap: 30px 0px;
  }
}
.dl-address dl dt {
  font-size: 18px;
  line-height: 1.6;
  margin-bottom: 12px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-address dl dt {
    font-size: 1.28571vw;
    margin-bottom: 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .dl-address dl dt {
    font-size: 4.26667vw;
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-address dl dt {
    font-size: 16px;
    margin-bottom: 10px;
  }
}
.dl-address dl dd {
  font-size: 16px;
  line-height: 1.8;
  font-weight: 400;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-address dl dd {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .dl-address dl dd {
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-address dl dd {
    font-size: 16px;
  }
}

.dl-01 {
  display: grid;
  grid-template-columns: 114px 1fr;
  gap: 16px 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-01 {
    grid-template-columns: 8.14286vw 1fr;
    gap: 1.14286vw 0;
  }
}
@media screen and (max-width: 767px) {
  .dl-01 {
    grid-template-columns: 21.33333vw 1fr;
    gap: 4.26667vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-01 {
    grid-template-columns: 80px 1fr;
    gap: 16px 0;
  }
}
.dl-01 dt {
  font-size: 16px;
  line-height: 2.0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-01 dt {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .dl-01 dt {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-01 dt {
    font-size: 14px;
  }
}
.dl-01 dd {
  font-size: 16px;
  line-height: 2.0;
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-01 dd {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .dl-01 dd {
    letter-spacing: 0.06em;
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-01 dd {
    font-size: 14px;
  }
}

.dl-02 dt {
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 3px;
  font-weight: 500;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-02 dt {
    font-size: 1.14286vw;
    margin-bottom: 0.21429vw;
  }
}
@media screen and (max-width: 767px) {
  .dl-02 dt {
    font-size: 4.26667vw;
    margin-bottom: 1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-02 dt {
    font-size: 16px;
    margin-bottom: 5px;
  }
}
.dl-02 dd {
  letter-spacing: 0.06em;
  font-size: 16px;
  line-height: 1.8;
  font-weight: 400;
  margin-bottom: 22px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .dl-02 dd {
    font-size: 1.14286vw;
    margin-bottom: 1.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .dl-02 dd {
    font-size: 4.26667vw;
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .dl-02 dd {
    font-size: 16px;
    margin-bottom: 20px;
  }
}
.dl-02 dd:last-child {
  margin-bottom: 0;
}

/*********************************************
ul ol
*********************************************/
.rabel-list {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  -o-justify-content: flex-start;
  justify-content: flex-start;
  gap: 0 15px;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .rabel-list {
    gap: 0 1.07143vw;
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .rabel-list {
    gap: 0 3.2vw;
    margin-bottom: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .rabel-list {
    gap: 0 12px;
    margin-bottom: 16px;
  }
}
.rabel-list li {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  padding: 0 10px;
  height: 30px;
  text-align: center;
  font-size: 14px;
  font-weight: 400;
  background: #F1F4F7;
  line-height: 1.8;
}
.rabel-list li.-yellow {
  background: #faf2cc;
}
.rabel-list li.-pink {
  background: #ffdcdc;
}
.rabel-list li.-blue {
  background: #EDFAFF;
  color: #007AAA;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .rabel-list li {
    padding: 0 0.71429vw;
    height: 2.14286vw;
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .rabel-list li {
    padding: 0 2.66667vw;
    height: 6.13333vw;
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .rabel-list li {
    padding: 0 10px;
    height: 23px;
    font-size: 14px;
  }
}

.link-list.-mb-l li {
  margin-bottom: 36px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .link-list.-mb-l li {
    margin-bottom: 2.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .link-list.-mb-l li {
    margin-bottom: 6.4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .link-list.-mb-l li {
    margin-bottom: 24px;
  }
}
.link-list.-mb-l li:last-child {
  margin-bottom: 0;
}
.link-list.-mb-s li {
  margin-bottom: 16px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .link-list.-mb-s li {
    margin-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .link-list.-mb-s li {
    margin-bottom: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .link-list.-mb-s li {
    margin-bottom: 12px;
  }
}
.link-list.-mb-s li:last-child {
  margin-bottom: 0;
}
.link-list.-column li {
  display: inline-block;
  margin-right: 30px;
}
.link-list li {
  font-size: 16px;
  margin-bottom: 6px;
  font-weight: 400;
  line-height: 1.6;
  padding-left: 0 !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .link-list li {
    font-size: 1.14286vw;
    margin-bottom: 0.42857vw;
    padding-right: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .link-list li {
    font-size: 4.26667vw;
    margin-bottom: 1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .link-list li {
    font-size: 16px;
    margin-bottom: 6px;
  }
}
.link-list li:last-child {
  margin-bottom: 0;
}
.link-list li span.hack-a,
.link-list li a {
  display: inline;
  position: relative;
  text-decoration: underline;
}
.link-list li span.hack-a::after,
.link-list li a::after {
  display: block;
  position: absolute;
  content: '';
  right: 0;
}
@media screen and (min-width: 1025px) {
  .link-list li a:hover {
    text-decoration: none;
  }
}
.link-list li::after {
  display: none !important;
}
.link-list li.-blank_img span.hack-a,
.link-list li.-blank_img a {
  padding-right: 17px;
}
@media screen and (max-width: 767px) {
  .link-list li.-blank_img span.hack-a,
  .link-list li.-blank_img a {
    padding-right: 4.53333vw;
  }
}
.link-list li.-blank_img span.hack-a img,
.link-list li.-blank_img a img {
  display: block;
  position: absolute;
  right: 0;
  width: 12px;
  height: 12px;
  bottom: 6px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .link-list li.-blank_img span.hack-a img,
  .link-list li.-blank_img a img {
    bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .link-list li.-blank_img span.hack-a img,
  .link-list li.-blank_img a img {
    width: 3.2vw;
    height: 3.2vw;
    bottom: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .link-list li.-blank_img span.hack-a img,
  .link-list li.-blank_img a img {
    width: 12px;
    height: 12px;
    bottom: 4px;
  }
}
.link-list li.-blank span.hack-a,
.link-list li.-blank a {
  padding-right: 17px;
}
@media screen and (max-width: 767px) {
  .link-list li.-blank span.hack-a,
  .link-list li.-blank a {
    padding-right: 4.53333vw;
  }
}
.link-list li.-blank span.hack-a::after,
.link-list li.-blank a::after {
  width: 12px;
  height: 12px;
  bottom: 6px;
  background: url(../img/common/ico_blank_g.png) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .link-list li.-blank span.hack-a::after,
  .link-list li.-blank a::after {
    bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .link-list li.-blank span.hack-a::after,
  .link-list li.-blank a::after {
    width: 3.2vw;
    height: 3.2vw;
    bottom: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .link-list li.-blank span.hack-a::after,
  .link-list li.-blank a::after {
    width: 12px;
    height: 12px;
    bottom: 4px;
  }
}
.link-list li.-pdf_img span.hack-a,
.link-list li.-pdf_img a {
  position: relative;
  padding-right: 32px;
}
@media screen and (max-width: 767px) {
  .link-list li.-pdf_img span.hack-a,
  .link-list li.-pdf_img a {
    padding-right: 8.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .link-list li.-pdf_img span.hack-a,
  .link-list li.-pdf_img a {
    padding-right: 32px;
  }
}
.link-list li.-pdf_img span.hack-a img,
.link-list li.-pdf_img a img {
  display: block;
  position: absolute;
  right: 0;
  width: 25px;
  height: 13px;
  bottom: 4px;
  z-index: 10;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .link-list li.-pdf_img span.hack-a img,
  .link-list li.-pdf_img a img {
    bottom: 0.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .link-list li.-pdf_img span.hack-a img,
  .link-list li.-pdf_img a img {
    width: 6.66667vw;
    height: 3.46667vw;
    bottom: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .link-list li.-pdf_img span.hack-a img,
  .link-list li.-pdf_img a img {
    width: 25px;
    height: 13px;
    bottom: 4px;
  }
}
.link-list li.-pdf span.hack-a,
.link-list li.-pdf a {
  padding-right: 32px;
}
@media screen and (max-width: 767px) {
  .link-list li.-pdf span.hack-a,
  .link-list li.-pdf a {
    padding-right: 8.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .link-list li.-pdf span.hack-a,
  .link-list li.-pdf a {
    padding-right: 32px;
  }
}
.link-list li.-pdf span.hack-a::after,
.link-list li.-pdf a::after {
  width: 25px;
  height: 13px;
  bottom: 4px;
  background: url(../img/common/ico_pdf_g.png) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .link-list li.-pdf span.hack-a::after,
  .link-list li.-pdf a::after {
    bottom: 0.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .link-list li.-pdf span.hack-a::after,
  .link-list li.-pdf a::after {
    width: 6.66667vw;
    height: 3.46667vw;
    bottom: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .link-list li.-pdf span.hack-a::after,
  .link-list li.-pdf a::after {
    width: 25px;
    height: 13px;
    bottom: 4px;
  }
}

ol li {
  list-style-type: none;
  counter-increment: cnt;
}

ol.-num.-under10 li {
  padding-left: 1.4em;
}
ol.-num.-under10 li::after {
  width: 1.0em;
}
ol.-num.-over10 li {
  padding-left: 2.6em;
}
ol.-num.-over10 li::after {
  width: 2.0em;
}
ol.-num.-notice li {
  padding-left: 2.6em;
}
ol.-num.-notice li::after {
  content: "※" counter(cnt) "";
  width: 2.0em;
}
ol.-num.-fs-14 li {
  font-size: 14px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ol.-num.-fs-14 li {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  ol.-num.-fs-14 li {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ol.-num.-fs-14 li {
    font-size: 14px;
  }
}
ol.-num.-mb-s li {
  margin-bottom: 6px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ol.-num.-mb-s li {
    margin-bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  ol.-num.-mb-s li {
    margin-bottom: 1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ol.-num.-mb-s li {
    margin-bottom: 6px;
  }
}
ol.-num.-mb-s li:last-child {
  margin-bottom: 0;
}
ol.-num li {
  counter-increment: cnt;
  font-size: 16px;
  margin-bottom: 12px;
  font-weight: 400;
  font-weight: 400;
  line-height: 1.8;
  position: relative;
  padding-left: 1.2em;
  padding-left: 2.2em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ol.-num li {
    font-size: 1.14286vw;
    margin-bottom: 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  ol.-num li {
    font-size: 4.26667vw;
    margin-bottom: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ol.-num li {
    font-size: 16px;
    margin-bottom: 12px;
  }
}
ol.-num li:last-child {
  margin-bottom: 0;
}
.article-body.-news ol.-num li {
  margin-bottom: 6px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-body.-news ol.-num li {
    margin-bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .article-body.-news ol.-num li {
    margin-bottom: 1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-body.-news ol.-num li {
    margin-bottom: 6px;
  }
}
.article-body.-news ol.-num li:last-child {
  margin-bottom: 0;
}
ol.-num li::after {
  text-align: right;
  position: absolute;
  display: block;
  content: "" counter(cnt) ".";
  top: 0;
  left: 0;
  width: 1.8em;
}

ul.-indent-num li,
ol.-indent-num li {
  padding-left: 1.5em;
  text-indent: -1.5em;
}
ul.-indent-num__comma li,
ol.-indent-num__comma li {
  position: relative;
  padding-left: 1.5em;
  text-indent: 0;
  margin-left: 0em;
}
ul.-indent-num__comma li span.indent,
ol.-indent-num__comma li span.indent {
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  width: 1.5em;
}
ul.-indent-num__comma li::after,
ol.-indent-num__comma li::after {
  display: none !important;
}
ul.-indent-num__parentheses li,
ol.-indent-num__parentheses li {
  position: relative;
  padding-left: 3.5em;
  text-indent: 0;
  margin-left: -0.8em;
}
ul.-indent-num__parentheses li span.indent,
ol.-indent-num__parentheses li span.indent {
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  text-align: right;
  width: 3em;
}
@media screen and (max-width: 767px) {
  ul.-indent-num__parentheses li,
  ol.-indent-num__parentheses li {
    margin-left: -1.6em;
  }
}
ul.-indent-num__parentheses li::after,
ol.-indent-num__parentheses li::after {
  display: none !important;
}

ul.-circle.-mb-l li, ul.-notice.-mb-l li {
  margin-bottom: 36px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-circle.-mb-l li, ul.-notice.-mb-l li {
    margin-bottom: 2.57143vw;
  }
}
@media screen and (max-width: 767px) {
  ul.-circle.-mb-l li, ul.-notice.-mb-l li {
    margin-bottom: 6.4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-circle.-mb-l li, ul.-notice.-mb-l li {
    margin-bottom: 24px;
  }
}
ul.-circle.-mb-l li:last-child, ul.-notice.-mb-l li:last-child {
  margin-bottom: 0;
}
ul.-circle.-mb-m li, ul.-notice.-mb-m li {
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-circle.-mb-m li, ul.-notice.-mb-m li {
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  ul.-circle.-mb-m li, ul.-notice.-mb-m li {
    margin-bottom: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-circle.-mb-m li, ul.-notice.-mb-m li {
    margin-bottom: 16px;
  }
}
ul.-circle.-mb-m li:last-child, ul.-notice.-mb-m li:last-child {
  margin-bottom: 0;
}
ul.-circle.-mb-s li, ul.-notice.-mb-s li {
  margin-bottom: 0px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-circle.-mb-s li, ul.-notice.-mb-s li {
    margin-bottom: 0vw;
  }
}
@media screen and (max-width: 767px) {
  ul.-circle.-mb-s li, ul.-notice.-mb-s li {
    margin-bottom: 0vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-circle.-mb-s li, ul.-notice.-mb-s li {
    margin-bottom: 0px;
  }
}
ul.-circle.-mb-s li:last-child, ul.-notice.-mb-s li:last-child {
  margin-bottom: 0;
}
ul.-circle.-fs-16 li, ul.-notice.-fs-16 li {
  font-size: 16px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-circle.-fs-16 li, ul.-notice.-fs-16 li {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  ul.-circle.-fs-16 li, ul.-notice.-fs-16 li {
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-circle.-fs-16 li, ul.-notice.-fs-16 li {
    font-size: 16px;
  }
}
ul.-circle.-fs-14 li, ul.-notice.-fs-14 li {
  font-size: 14px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-circle.-fs-14 li, ul.-notice.-fs-14 li {
    font-size: 1vw !important;
  }
}
@media screen and (max-width: 767px) {
  ul.-circle.-fs-14 li, ul.-notice.-fs-14 li {
    font-size: 3.73333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-circle.-fs-14 li, ul.-notice.-fs-14 li {
    font-size: 14px !important;
  }
}
@media screen and (max-width: 767px) {
  ul.-circle.-fs-14-sp li, ul.-notice.-fs-14-sp li {
    font-size: 3.73333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-circle.-fs-14-sp li, ul.-notice.-fs-14-sp li {
    font-size: 14px !important;
  }
}
ul.-circle li, ul.-notice li {
  font-size: 14px;
  margin-bottom: 6px;
  font-weight: 400;
  line-height: 1.8;
  position: relative;
  padding-left: 0.9em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-circle li, ul.-notice li {
    font-size: 1vw;
    margin-bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  ul.-circle li, ul.-notice li {
    font-size: 3.73333vw;
    margin-bottom: 1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-circle li, ul.-notice li {
    font-size: 14px;
    margin-bottom: 6px;
  }
}
ul.-circle li:last-child, ul.-notice li:last-child {
  margin-bottom: 0;
}
ul.-circle li::after {
  text-align: right;
  position: absolute;
  display: block;
  content: "・";
  top: 0;
  left: 0;
}
.-indent ul.-circle {
  padding-top: 0.8em;
  padding-bottom: 1em;
}
.-indent ul.-circle li {
  padding-left: 1em !important;
}
.-indent ul.-circle li::after {
  display: block !important;
}
ul.-circle-ex li {
  padding-left: 1.2em;
}
ul.-circle-ex li::after {
  text-align: right;
  position: absolute;
  display: block;
  content: "";
  top: 11px;
  left: 0;
  width: 10px;
  height: 10px;
  background: #00AEEF;
  border-radius: 50%;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-circle-ex li::after {
    width: 0.71429vw;
    height: 0.71429vw;
    top: 0.78571vw;
  }
}
@media screen and (max-width: 767px) {
  ul.-circle-ex li::after {
    width: 2.66667vw;
    height: 2.66667vw;
    top: 2.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-circle-ex li::after {
    width: 10px;
    height: 10px;
    top: 11px;
  }
}
ul.-notice li {
  padding-left: 1em !important;
}
ul.-notice li::after {
  text-align: right;
  position: absolute;
  display: block;
  content: "※" !important;
  top: 0;
  left: 0;
}
.-indent ul.-notice li::after {
  display: block !important;
}

ul.-check li {
  position: relative;
  padding-left: 50px;
  margin-bottom: 12px;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-check li {
    padding-left: 3.57143vw;
    margin-bottom: 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  ul.-check li {
    padding-left: 13.33333vw;
    margin-bottom: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-check li {
    padding-left: 50px;
    margin-bottom: 12px;
  }
}
ul.-check li::after {
  content: '';
  position: absolute;
  display: block;
  background: url(../img/common/icon_check.svg) center center no-repeat;
  background-size: 100% auto;
  top: 3px;
  left: 0;
  width: 33px;
  height: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-check li::after {
    top: 0.21429vw;
    width: 2.35714vw;
    height: 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  ul.-check li::after {
    top: 0.8vw;
    width: 8.53333vw;
    height: 6.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-check li::after {
    top: 3px;
    width: 32px;
    height: 26px;
  }
}
ul.-indent .txt {
  padding-top: 0.8em;
  padding-bottom: 1em;
}
ul.-indent.-mb-l li {
  margin-bottom: 36px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-indent.-mb-l li {
    margin-bottom: 2.57143vw !important;
  }
}
@media screen and (max-width: 767px) {
  ul.-indent.-mb-l li {
    margin-bottom: 6.4vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-indent.-mb-l li {
    margin-bottom: 24px !important;
  }
}
ul.-indent.-mb-l li:last-child {
  margin-bottom: 0 !important;
}
ul.-indent.-mb-s li {
  margin-bottom: 16px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-indent.-mb-s li {
    margin-bottom: 1.14286vw !important;
  }
}
@media screen and (max-width: 767px) {
  ul.-indent.-mb-s li {
    margin-bottom: 3.2vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-indent.-mb-s li {
    margin-bottom: 12px !important;
  }
}
ul.-indent.-mb-s li:last-child {
  margin-bottom: 0 !important;
}
ul.-indent.-w-5em li {
  padding-left: 5.5em;
}
ul.-indent.-w-2em li {
  padding-left: 2em;
}
ul.-indent.-w-2_5em li {
  padding-left: 2.5em;
}
ul.-indent.-w-2_8em li {
  padding-left: 2.8em;
}
ul.-indent.-w-3em li {
  padding-left: 3em;
}
ul.-indent.-w-1em li {
  padding-left: 1.2em;
}
ul.-indent.-fs-14 li {
  font-size: 14px;
  margin-bottom: 2px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-indent.-fs-14 li {
    font-size: 1vw;
    margin-bottom: 0.14286vw;
  }
}
@media screen and (max-width: 767px) {
  ul.-indent.-fs-14 li {
    font-size: 3.73333vw;
    margin-bottom: 0.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-indent.-fs-14 li {
    font-size: 14px;
    margin-bottom: 2px;
  }
}
ul.-indent.-fs-16 li {
  font-size: 16px;
  margin-bottom: 2px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-indent.-fs-16 li {
    font-size: 1.14286vw;
    margin-bottom: 0.14286vw;
  }
}
@media screen and (max-width: 767px) {
  ul.-indent.-fs-16 li {
    font-size: 4.26667vw;
    margin-bottom: 0.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-indent.-fs-16 li {
    font-size: 16px;
    margin-bottom: 2px;
  }
}
ul.-indent li {
  font-size: 14px;
  margin-bottom: 6px;
  font-weight: 400;
  font-weight: 400;
  line-height: 1.8;
  position: relative;
  padding-left: 1.2em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  ul.-indent li {
    font-size: 1vw;
    margin-bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  ul.-indent li {
    font-size: 3.2vw;
    margin-bottom: 1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  ul.-indent li {
    font-size: 12px;
    margin-bottom: 6px;
  }
}
ul.-indent li:last-child {
  margin-bottom: 0;
}
ul.-indent li span.indent {
  position: absolute;
  top: 0;
  left: 0;
}
ul.-indent li::after {
  display: none !important;
}

.layout-pc {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .layout-pc {
    display: block;
  }
}

.layout-pc__l {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .layout-pc__l {
    width: 100%;
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .layout-pc__l {
    margin-bottom: 20px;
  }
}

.layout-pc__r {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .layout-pc__r {
    width: 100%;
  }
}

/*********************************************
bg-layout
*********************************************/
.bg-layouts .toggle-item {
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layouts .toggle-item {
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-layouts .toggle-item {
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layouts .toggle-item {
    margin-bottom: 10px;
  }
}
.bg-layouts .toggle-item:last-child {
  margin-bottom: 0;
}
.bg-layouts .bg-layout {
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layouts .bg-layout {
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-layouts .bg-layout {
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layouts .bg-layout {
    margin-bottom: 10px;
  }
}
.bg-layouts .bg-layout:last-child {
  margin-bottom: 0;
}
.bg-layouts .toggle-icon {
  top: 50%;
  right: 4.26667vw;
  margin-top: -6px;
  width: 12px;
  height: 12px;
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layouts .toggle-icon {
    right: 16px;
  }
}
.bg-layouts .toggle-icon::after {
  width: 11px;
  height: 1px;
  top: 5px;
  left: 0;
}
.bg-layouts .toggle-icon::before {
  height: 11px;
  width: 1px;
  left: 5px;
  top: 0;
}
@media screen and (max-width: 767px) {
  .bg-layouts .bg-layout__l {
    padding: 3.73333vw 0 4.26667vw 2.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layouts .bg-layout__l {
    padding: 14px 0 16px 8px;
  }
}
@media screen and (max-width: 767px) {
  .bg-layouts .bg-layout__l::after {
    top: auto;
    bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  .bg-layouts .bg-layout__r {
    padding-left: 6.93333vw;
    padding-right: 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layouts .bg-layout__r {
    padding-left: 26px;
    padding-right: 0;
  }
}

.bg-layout {
  display: table;
  width: 100%;
  background: #F2F4F7;
  padding: 26px 0 26px;
}
.bg-layout.-bg-edfaff {
  background: #EDFAFF;
}
.bg-layout.-bg-edfaff .bg-layout__l {
  width: 284px;
}
.bg-layout.-bg-edfaff .bg-layout__l .txt {
  position: relative;
  left: -1em;
  margin-bottom: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layout.-bg-edfaff .bg-layout__l {
    width: 20.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-layout.-bg-edfaff .bg-layout__l {
    width: 100%;
  }
  .bg-layout.-bg-edfaff .bg-layout__l .txt {
    left: 0;
  }
}
.bg-layout.-bg-edfaff .bg-layout__l,
.bg-layout.-bg-edfaff .bg-layout__r {
  padding-top: 4px;
  padding-bottom: 4px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layout.-bg-edfaff .bg-layout__l,
  .bg-layout.-bg-edfaff .bg-layout__r {
    padding-top: 0.28571vw;
    padding-bottom: 0.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-layout.-bg-edfaff .bg-layout__l,
  .bg-layout.-bg-edfaff .bg-layout__r {
    padding: 5.33333vw 0 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layout.-bg-edfaff .bg-layout__l,
  .bg-layout.-bg-edfaff .bg-layout__r {
    padding: 20px 0 20px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layout {
    padding: 1.85714vw 0 1.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-layout {
    display: block;
    padding: 0.53333vw 4vw 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layout {
    padding: 2px 15px 10px;
  }
}
.bg-layout.-article {
  padding: 50px 0 50px;
  margin-bottom: 100px;
}
.bg-layouts .bg-layout.-article {
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layouts .bg-layout.-article {
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-layouts .bg-layout.-article {
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layouts .bg-layout.-article {
    margin-bottom: 20px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layout.-article {
    padding: 3.57143vw 0 3.57143vw;
    margin-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-layout.-article {
    display: block;
    padding: 2.66667vw 8vw 2.66667vw;
    margin-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layout.-article {
    padding: 10px 30px 10px;
    margin-bottom: 50px;
  }
}

.bg-layout__r,
.bg-layout__l {
  display: table-cell;
  vertical-align: middle;
  padding-left: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layout__r,
  .bg-layout__l {
    padding-left: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-layout__r,
  .bg-layout__l {
    width: 100%;
    display: block;
    padding-left: 0;
    padding: 3.73333vw 0 3.73333vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .bg-layout__r,
  .bg-layout__l {
    padding: 14px 0 14px;
  }
}
@media screen and (max-width: 767px) {
  .-article .bg-layout__r, .-article
  .bg-layout__l {
    padding: 5.33333vw 0 5.33333vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .-article .bg-layout__r, .-article
  .bg-layout__l {
    padding: 20px 0 20px;
  }
}

.bg-layout__r {
  padding-right: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layout__r {
    padding-right: 2.85714vw;
  }
}

.bg-layout__l {
  width: 216px;
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layout__l {
    width: 15.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-layout__l {
    width: 100%;
  }
}
.-article .bg-layout__l {
  width: 250px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-article .bg-layout__l {
    width: 17.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .-article .bg-layout__l {
    width: 100%;
  }
}
.bg-layout__l::after {
  content: '';
  display: block;
  position: absolute;
  width: 1px;
  height: 100%;
  top: 0;
  right: 0;
  background: #DDDDDD;
}
@media screen and (max-width: 767px) {
  .bg-layout__l::after {
    width: 100%;
    height: 1px;
    top: 100%;
  }
}

/*********************************************
breadcrumb
*********************************************/
body.page-news-article .breadcrumb .breadcrumb-inner ol li::after,
body.page-case_study-article .breadcrumb .breadcrumb-inner ol li::after {
  background: url(../img/common/ico_arrow_breadcrumb_g.svg) 0 center no-repeat;
  background-size: 100% auto;
}
body.page-news-article .breadcrumb .breadcrumb-inner ol li a,
body.page-news-article .breadcrumb .breadcrumb-inner ol li span,
body.page-case_study-article .breadcrumb .breadcrumb-inner ol li a,
body.page-case_study-article .breadcrumb .breadcrumb-inner ol li span {
  color: #33393B;
}
body.page-news-article .breadcrumb .breadcrumb-inner ol li a,
body.page-case_study-article .breadcrumb .breadcrumb-inner ol li a {
  color: #33393B;
}
@media screen and (min-width: 1025px) {
  body.page-news-article .breadcrumb .breadcrumb-inner ol li a,
  body.page-case_study-article .breadcrumb .breadcrumb-inner ol li a {
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  body.page-news-article .breadcrumb .breadcrumb-inner ol li a:hover,
  body.page-case_study-article .breadcrumb .breadcrumb-inner ol li a:hover {
    opacity: 1;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
}

.breadcrumb {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.breadcrumb::-webkit-scrollbar {
  height: 1px;
}

.breadcrumb::-webkit-scrollbar-track {
  border-radius: 1px;
}

.breadcrumb::-webkit-scrollbar-thumb {
  border-radius: 1px;
  background: #eaf9ff;
}

.breadcrumb {
  white-space: nowrap;
  position: absolute;
  max-width: 1400px;
  width: 100%;
  height: 30px;
  z-index: 5;
  left: 50%;
  top: 94px;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .breadcrumb {
    top: 6.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .breadcrumb {
    top: 25.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .breadcrumb {
    top: 94px;
  }
}
.breadcrumb .breadcrumb-inner {
  width: 94.28%;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .breadcrumb .breadcrumb-inner {
    width: 94.79%;
  }
}
.breadcrumb .breadcrumb-inner ol {
  display: table;
  width: auto;
}
.breadcrumb .breadcrumb-inner ol li {
  font-size: 12px;
  width: auto;
  display: table-cell;
  vertical-align: middle;
  padding-right: 22px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .breadcrumb .breadcrumb-inner ol li {
    font-size: 2.66667vw;
    padding-right: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .breadcrumb .breadcrumb-inner ol li {
    font-size: 10px;
    padding-right: 18px;
  }
}
.breadcrumb .breadcrumb-inner ol li:last-child {
  padding-right: 0;
}
.breadcrumb .breadcrumb-inner ol li:last-child:after {
  display: none;
}
.breadcrumb .breadcrumb-inner ol li::after {
  content: '';
  position: absolute;
  display: block;
  background: url(../img/common/ico_arrow_breadcrumb.svg) 0 center no-repeat;
  background-size: 100% auto;
  top: 50%;
  right: 7px;
  width: 4px;
  height: 12px;
  margin-top: -6px;
}
@media screen and (max-width: 767px) {
  .breadcrumb .breadcrumb-inner ol li::after {
    right: 1.6vw;
    width: 1.06667vw;
    height: 3.2vw;
    margin-top: -1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .breadcrumb .breadcrumb-inner ol li::after {
    right: 6px;
    width: 4px;
    height: 12px;
    margin-top: -6px;
  }
}
.breadcrumb .breadcrumb-inner ol li a,
.breadcrumb .breadcrumb-inner ol li span {
  position: relative;
  display: block;
  color: #fff;
  padding: 4px 0;
  opacity: 1;
}
.breadcrumb .breadcrumb-inner ol li a {
  color: #fff;
  position: relative;
}
@media screen and (min-width: 1025px) {
  .breadcrumb .breadcrumb-inner ol li a {
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  .breadcrumb .breadcrumb-inner ol li a:hover {
    opacity: 1;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
}

/*********************************************
btn
*********************************************/
@media screen and (min-width: 1025px) {
  a:hover .hack-a::before {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
  a:hover .hack-a::after {
    -webkit-transform: translateX(6px);
    -moz-transform: translateX(6px);
    -ms-transform: translateX(6px);
    -o-transform: translateX(6px);
    transform: translateX(6px);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
}

.btn-items {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  gap: 0 40px;
  margin: 0 auto;
}
.btn-items.-flex-reverse {
  -webkit-flex-direction: row-reverse;
  -moz-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  -o-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btn-items {
    gap: 0 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .btn-items {
    display: block;
    gap: 5.33333vw 0;
  }
}
@media screen and (max-width: 767px) {
  .btn-items .btn {
    margin-bottom: 5.33333vw;
  }
  .btn-items .btn:last-child {
    margin-bottom: 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btn-items .btn {
    margin-bottom: 20px;
  }
}

.btn {
  position: relative;
  z-index: 5;
  text-align: center;
}
.btn.-ta-l {
  text-align: left;
}
.btn.-ta-l .hack-a,
.btn.-ta-l a {
  margin: 0 0;
}
.btn.-more .hack-a,
.btn.-more a {
  font-family: "Manrope", sans-serif;
  letter-spacing: 0.1em;
}
.btn.-no-bg .hack-a,
.btn.-no-bg a {
  position: relative;
  left: -20px;
  background: transparent;
  color: #33393B;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btn.-no-bg .hack-a,
  .btn.-no-bg a {
    left: -1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .btn.-no-bg .hack-a,
  .btn.-no-bg a {
    left: -5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btn.-no-bg .hack-a,
  .btn.-no-bg a {
    left: -20px;
  }
}
.btn.-no-bg .hack-a::before,
.btn.-no-bg a::before {
  display: none;
}
.btn.-contact, .btn.-back {
  margin-top: 90px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btn.-contact, .btn.-back {
    margin-top: 6.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .btn.-contact, .btn.-back {
    margin-top: 14.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btn.-contact, .btn.-back {
    margin-top: 55px;
  }
}
.btn.-contact.-history-back, .btn.-back.-history-back {
  margin-top: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btn.-contact.-history-back, .btn.-back.-history-back {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .btn.-contact.-history-back, .btn.-back.-history-back {
    margin-top: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btn.-contact.-history-back, .btn.-back.-history-back {
    margin-top: 30px;
  }
}
.btn.-contact.-history-back button,
.btn.-contact.-history-back .hack-a,
.btn.-contact.-history-back a, .btn.-back.-history-back button,
.btn.-back.-history-back .hack-a,
.btn.-back.-history-back a {
  text-indent: 2em;
  width: 200px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btn.-contact.-history-back button,
  .btn.-contact.-history-back .hack-a,
  .btn.-contact.-history-back a, .btn.-back.-history-back button,
  .btn.-back.-history-back .hack-a,
  .btn.-back.-history-back a {
    width: 14.28571vw;
  }
}
.btn.-contact button,
.btn.-contact a, .btn.-back button,
.btn.-back a {
  border: 1px solid #00AEEF;
  background: #fff;
  color: #007AAA;
}
.btn.-contact button::before,
.btn.-contact a::before, .btn.-back button::before,
.btn.-back a::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #EDFAFF;
  opacity: 1;
  z-index: 2;
  -webkit-transform: translateX(-100%);
  -moz-transform: translateX(-100%);
  -ms-transform: translateX(-100%);
  -o-transform: translateX(-100%);
  transform: translateX(-100%);
  -webkit-transition: transform 0.2s 0s ease-out;
  -moz-transition: transform 0.2s 0s ease-out;
  -ms-transition: transform 0.2s 0s ease-out;
  -o-transition: transform 0.2s 0s ease-out;
  transition: transform 0.2s 0s ease-out;
}
.btn.-contact.-back-top, .btn.-back.-back-top {
  margin-top: 140px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btn.-contact.-back-top, .btn.-back.-back-top {
    margin-top: 10vw;
  }
}
@media screen and (max-width: 767px) {
  .btn.-contact.-back-top, .btn.-back.-back-top {
    margin-top: 21.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btn.-contact.-back-top, .btn.-back.-back-top {
    margin-top: 80px;
  }
}
.btn.-contact.-back-top button,
.btn.-contact.-back-top a, .btn.-back.-back-top button,
.btn.-back.-back-top a {
  text-indent: 2em;
}
.btn button {
  text-align: center;
  display: block;
}
.btn button span.btn-txt {
  text-align: center;
  width: 100%;
}
.btn button,
.btn .hack-a,
.btn a {
  text-align: center;
  position: relative;
  width: 302px;
  height: 60px;
  margin: 0 auto;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  background: #007AAA;
  color: #fff;
  font-size: 16px;
  overflow: hidden;
  text-decoration: none !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btn button,
  .btn .hack-a,
  .btn a {
    width: 21.57143vw;
    height: 4.28571vw;
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .btn button,
  .btn .hack-a,
  .btn a {
    width: 100%;
    max-width: 79.16667vw;
    height: 16vw;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btn button,
  .btn .hack-a,
  .btn a {
    max-width: 304px;
    height: 60px;
    font-size: 16px;
  }
}
.btn button::before,
.btn .hack-a::before,
.btn a::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.2;
  z-index: 2;
  -webkit-transform: translateX(-100%);
  -moz-transform: translateX(-100%);
  -ms-transform: translateX(-100%);
  -o-transform: translateX(-100%);
  transform: translateX(-100%);
  -webkit-transition: transform 0.2s 0s ease-out;
  -moz-transition: transform 0.2s 0s ease-out;
  -ms-transition: transform 0.2s 0s ease-out;
  -o-transition: transform 0.2s 0s ease-out;
  transition: transform 0.2s 0s ease-out;
}
.btn button span.btn-txt,
.btn .hack-a span.btn-txt,
.btn a span.btn-txt {
  position: relative;
  z-index: 5;
}
@media screen and (max-width: 767px) {
  .btn .hack-a {
    width: 79.16667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btn .hack-a {
    width: 304px;
  }
}
@media screen and (min-width: 1025px) {
  .btn button:hover::before,
  .btn a:hover::before {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
}

/*********************************************
box
*********************************************/
.-bg-edfaff {
  background: #edfaff;
}

.-bg-f2f4f7 {
  background: #F2F4F7;
}

.box {
  padding: 45px 50px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .box {
    padding: 3.21429vw 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .box {
    padding: 10.66667vw 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .box {
    padding: 40px 20px;
  }
}
.box.-type-padd-s {
  padding: 20px 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .box.-type-padd-s {
    padding: 1.42857vw 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .box.-type-padd-s {
    padding: 8vw 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .box.-type-padd-s {
    padding: 30px 20px;
  }
}

/*********************************************
ttl
*********************************************/
.sec-ttl__assets {
  position: relative;
  z-index: 5;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
  max-width: 1140px;
  margin: 0 auto;
  width: 81.42%;
}
@media screen and (max-width: 767px) {
  .sec-ttl__assets {
    width: 73.95833vw;
    margin-bottom: 10.66667vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .sec-ttl__assets {
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 767px) {
  .sec-ttl__assets.-sp-w-l {
    width: 89.58333vw;
  }
}
.sec-ttl__assets .sec-ttl {
  width: 47.36%;
}
@media screen and (max-width: 767px) {
  .sec-ttl__assets .sec-ttl {
    width: 100%;
  }
}
.btm-contact .sec-ttl__assets .sec-ttl {
  width: 24.56%;
}
@media screen and (max-width: 767px) {
  .btm-contact .sec-ttl__assets .sec-ttl {
    width: 100%;
  }
}

.sec-ttl__txt {
  margin-top: 7px;
  font-size: 16px;
  line-height: 1.8;
  line-height: 2.0;
  font-weight: 400;
  color: #33393B;
  letter-spacing: 0.06em;
  width: 45.61%;
}
.btm-contact .sec-ttl__txt {
  padding-top: 62px;
  width: 63.15%;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btm-contact .sec-ttl__txt {
    padding-top: 4.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .btm-contact .sec-ttl__txt {
    padding-top: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sec-ttl__txt {
    margin-top: 0.5vw;
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-ttl__txt {
    letter-spacing: 0.04em;
    width: 100%;
    margin-top: 8vw;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sec-ttl__txt {
    margin-top: 30px;
    font-size: 16px;
  }
}
.index-other .sec-ttl__txt {
  padding-right: 5.27%;
}
@media print, screen and (min-width: 568px) and (max-width: 750px) {
  .index-other .sec-ttl__txt {
    padding-right: 30px;
  }
}
@media screen and (max-width: 767px) {
  .index-other .sec-ttl__txt {
    padding-right: 0;
  }
}

.sec-ttl {
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sec-ttl {
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-ttl {
    margin-bottom: 0vw;
  }
}
.sec-ttl span {
  display: block;
}
.sec-ttl span.-en {
  font-size: 64px;
  font-family: "Manrope", sans-serif;
  color: #1F2426;
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sec-ttl span.-en {
    font-size: 4.57143vw;
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-ttl span.-en {
    font-size: 9.6vw;
    margin-bottom: 2.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sec-ttl span.-en {
    font-size: 36px;
    margin-bottom: 8px;
  }
}
.sec-ttl span.-ja {
  font-size: 22px;
  letter-spacing: 0.02em;
  color: #666666;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .sec-ttl span.-ja {
    font-size: 1.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-ttl span.-ja {
    font-size: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .sec-ttl span.-ja {
    font-size: 18px;
  }
}

.ttl-line {
  font-size: 28px;
  margin-bottom: 40px;
  padding-bottom: 16px;
  position: relative;
  font-weight: 500;
  line-height: 1.6;
}
.ttl-line.-inline-block {
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .ttl-line.-inline-block {
    letter-spacing: -0.05em;
  }
}
.ttl-line.-line-b0d6e3 {
  color: #007AAA;
}
.ttl-line.-line-b0d6e3::after {
  background: #b0d6e3;
}
.ttl-line.-btm-notxt {
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-line.-btm-notxt {
    margin-bottom: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-line.-btm-notxt {
    margin-bottom: 6.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-line.-btm-notxt {
    margin-bottom: 25px;
  }
}
.ttl-line::after {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 1px;
  bottom: 0;
  background: #4fc8f5;
  background: linear-gradient(315deg, #4fc8f5 0%, #0077ef 100%);
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-line {
    font-size: 2vw;
    margin-bottom: 2.5vw;
    padding-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-line {
    letter-spacing: 0.0em;
    font-size: 5.33333vw;
    margin-bottom: 5.33333vw;
    padding-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-line {
    font-size: 20px;
    margin-bottom: 20px;
    padding-bottom: 10px;
  }
}
.ttl-line.-line-gray {
  font-size: 22px;
  margin-bottom: 45px;
  padding-bottom: 14px;
  position: relative;
  font-weight: 500;
  line-height: 1.6;
}
.ttl-line.-line-gray.-btm-notxt {
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-line.-line-gray.-btm-notxt {
    margin-bottom: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-line.-line-gray.-btm-notxt {
    margin-bottom: 6.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-line.-line-gray.-btm-notxt {
    margin-bottom: 25px;
  }
}
.ttl-line.-line-gray::after {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 1px;
  bottom: 0;
  background: #C8C8C8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-line.-line-gray {
    font-size: 1.57143vw;
    margin-bottom: 3.21429vw;
    padding-bottom: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-line.-line-gray {
    letter-spacing: 0.0em;
    font-size: 4.8vw;
    margin-bottom: 5.33333vw;
    padding-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-line.-line-gray {
    font-size: 18px;
    margin-bottom: 20px;
    padding-bottom: 10px;
  }
}

.ttl-line + section,
.ttl-line + ul,
.ttl-line + .txt {
  padding-top: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-line + section,
  .ttl-line + ul,
  .ttl-line + .txt {
    padding-top: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-line + section,
  .ttl-line + ul,
  .ttl-line + .txt {
    padding-top: 0.71429vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-line + section,
  .ttl-line + ul,
  .ttl-line + .txt {
    padding-top: 10px;
  }
}

.ttl-blue {
  color: #007AAA;
  font-size: 20px;
  margin-bottom: 16px;
  font-weight: 500;
  line-height: 1.5;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-blue {
    font-size: 1.42857vw;
    margin-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-blue {
    font-size: 4.8vw;
    margin-bottom: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-blue {
    font-size: 18px;
    margin-bottom: 12px;
  }
}
@media screen and (max-width: 767px) {
  .ttl-blue.-indent {
    position: relative;
    padding-left: 1.2em;
  }
  .ttl-blue.-indent span {
    position: absolute;
    width: 1.2em;
    top: 0;
    left: 0;
  }
}
.ttl-blue.-fs-32 {
  font-size: 32px;
  margin-bottom: 25px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-blue.-fs-32 {
    font-size: 2.28571vw;
    margin-bottom: 1.78571vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-blue.-fs-32 {
    font-size: 5.33333vw;
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-blue.-fs-32 {
    font-size: 20px;
    margin-bottom: 20px;
  }
}

sup {
  position: relative;
  top: -0.2em;
}

.ttl-line__side {
  font-size: 18px;
  padding-left: 30px;
  margin-bottom: 20px;
  position: relative;
  line-height: 1.4;
  font-weight: 500;
}
.ttl-line__side a.link-blank {
  line-height: 1;
}
.ttl-line__side a.link-blank::after {
  bottom: 3px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-line__side a.link-blank::after {
    bottom: 0.21429vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-line__side a.link-blank::after {
    bottom: 0.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-line__side a.link-blank::after {
    bottom: 1px;
  }
}
.ttl-line__side::after {
  content: '';
  display: block;
  position: absolute;
  width: 18px;
  top: 13px;
  height: 1px;
  left: 0;
  background: #33393B;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-line__side::after {
    width: 1.28571vw;
    top: 0.92857vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-line__side::after {
    width: 4.8vw;
    top: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-line__side::after {
    width: 18px;
    top: 12px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-line__side {
    font-size: 1.28571vw;
    padding-left: 2.14286vw;
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-line__side {
    font-size: 4.26667vw;
    padding-left: 8vw;
    margin-bottom: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-line__side {
    font-size: 16px;
    padding-left: 30px;
    margin-bottom: 16px;
  }
}

.ttl-bold {
  font-size: 26px;
  margin-bottom: 30px;
  font-weight: 500;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-bold {
    font-size: 1.85714vw;
    margin-bottom: 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-bold {
    font-size: 5.33333vw;
    margin-bottom: 5.86667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-bold {
    font-size: 20px;
    margin-bottom: 22px;
  }
}
.ttl-bold.-fs-28 {
  font-size: 28px;
  margin-bottom: 25px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-bold.-fs-28 {
    font-size: 2vw;
    margin-bottom: 1.78571vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-bold.-fs-28 {
    font-size: 5.33333vw;
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-bold.-fs-28 {
    font-size: 20px;
    margin-bottom: 20px;
  }
}
.ttl-bold.-fs-18 {
  font-size: 18px;
  margin-bottom: 10px;
  line-height: 1.8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-bold.-fs-18 {
    font-size: 1.28571vw;
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-bold.-fs-18 {
    font-size: 4.8vw;
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-bold.-fs-18 {
    font-size: 18px;
    margin-bottom: 10px;
  }
}
.ttl-bold.-fs-16 {
  font-size: 16px;
  margin-bottom: 16px;
  line-height: 1.8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-bold.-fs-16 {
    font-size: 1.14286vw;
    margin-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-bold.-fs-16 {
    font-size: 4.26667vw;
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-bold.-fs-16 {
    font-size: 16px;
    margin-bottom: 10px;
  }
}
@media screen and (max-width: 767px) {
  .ttl-bold.-fs-20-sp {
    font-size: 5.33333vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-bold.-fs-20-sp {
    font-size: 20px !important;
  }
}

/*********************************************
grid
*********************************************/
.grid-items {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 0 30px;
  max-width: 1140px;
  margin: 0 auto;
}
.grid-items.-grid-03 {
  grid-template-columns: 1fr 1fr 1fr;
  gap: 90px 75px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-items.-grid-03 {
    gap: 6.42857vw 5.35714vw;
  }
}
@media screen and (max-width: 767px) {
  .grid-items.-grid-03 {
    grid-template-columns: 1fr;
    width: 89.58333vw;
    gap: 18.22917vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .grid-items.-grid-03 {
    grid-template-columns: 1fr 1fr;
    width: auto;
    gap: 50px 30px;
  }
}
.grid-items.-grid-03 .grid-item {
  width: 330px;
  padding-bottom: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-items.-grid-03 .grid-item {
    width: auto;
  }
}
@media screen and (max-width: 767px) {
  .grid-items.-grid-03 .grid-item {
    width: 100%;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .grid-items.-grid-03 .grid-item {
    width: auto;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-items.-grid-03 .grid-item {
    padding-bottom: 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .grid-items.-grid-03 .grid-item {
    padding-bottom: 6.4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .grid-items.-grid-03 .grid-item {
    padding-bottom: 24px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-items {
    gap: 0 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .grid-items {
    grid-template-columns: 1fr 1fr;
    gap: 10.41667vw 5.98958vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .grid-items {
    gap: 40px 23px;
  }
}
.grid-items .grid-item {
  width: 262px;
  display: block;
  padding-bottom: 40px;
  position: relative;
  -webkit-transition: opacity 0.3s ease-in;
  -moz-transition: opacity 0.3s ease-in;
  -ms-transition: opacity 0.3s ease-in;
  -o-transition: opacity 0.3s ease-in;
  transition: opacity 0.3s ease-in;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-items .grid-item {
    width: auto;
  }
}
@media screen and (max-width: 767px) {
  .grid-items .grid-item {
    width: auto;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-items .grid-item {
    padding-bottom: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .grid-items .grid-item {
    padding-bottom: 6.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .grid-items .grid-item {
    padding-bottom: 26px;
  }
}
.grid-items .grid-item.-coming {
  padding-bottom: 0 !important;
}
.grid-items .grid-item.-coming .grid-item__ttl span.-ja {
  color: #666;
}
.grid-items .grid-item.-coming .icon {
  display: none;
}
@media screen and (min-width: 1025px) {
  .grid-items a.grid-item:hover {
    opacity: 0.7;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
  .grid-items a.grid-item:hover .grid-item__img img {
    -webkit-transform: scale(1.08);
    -moz-transform: scale(1.08);
    -ms-transform: scale(1.08);
    -o-transform: scale(1.08);
    transform: scale(1.08);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
}

.grid-item__img {
  margin-bottom: 20px;
  overflow: hidden;
}
.grid-item__img img {
  -webkit-transition: transform 0.3s ease-in;
  -moz-transition: transform 0.3s ease-in;
  -ms-transition: transform 0.3s ease-in;
  -o-transition: transform 0.3s ease-in;
  transition: transform 0.3s ease-in;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-item__img {
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .grid-item__img {
    margin-bottom: 4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .grid-item__img {
    margin-bottom: 15px;
  }
}

.grid-item__ttl span {
  display: block;
}
.grid-item__ttl span.-en {
  font-size: 12px;
  font-family: "Manrope", sans-serif;
  color: #666666;
  font-weight: 700;
  margin-bottom: 14px;
  line-height: 1.4;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-item__ttl span.-en {
    font-size: 0.85714vw;
    margin-bottom: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .grid-item__ttl span.-en {
    font-size: 2.66667vw;
    margin-bottom: 2.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .grid-item__ttl span.-en {
    font-size: 10px;
    margin-bottom: 8px;
  }
}
.grid-item__ttl span.-ja {
  font-size: 18px;
  letter-spacing: 0.00em;
  color: #33393B;
  line-height: 1.4;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-item__ttl span.-ja {
    font-size: 1.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .grid-item__ttl span.-ja {
    line-height: 1.4;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .grid-item__ttl span.-ja {
    font-size: 16px;
  }
}
.-grid-03 .grid-item__ttl span.-ja {
  font-size: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-grid-03 .grid-item__ttl span.-ja {
    font-size: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .-grid-03 .grid-item__ttl span.-ja {
    font-size: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .-grid-03 .grid-item__ttl span.-ja {
    font-size: 20px;
  }
}

.grid-item__txt {
  font-weight: 400;
  font-size: 16px;
  letter-spacing: 0.00em;
  line-height: 1.6;
  margin-top: 14px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-item__txt {
    font-size: 1.14286vw;
    margin-top: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .grid-item__txt {
    line-height: 1.6;
    font-size: 4.26667vw;
    margin-top: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .grid-item__txt {
    font-size: 16px;
    margin-top: 10px;
  }
}

.services-items {
  position: relative;
  z-index: 2;
  max-width: 1019px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 30px 33px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .services-items {
    width: 72.78%;
    gap: 2.14286vw 2.35714vw;
  }
}
@media screen and (max-width: 767px) {
  .services-items {
    width: 73.95833vw;
    grid-template-columns: 1fr 1fr;
    gap: 5.33333vw 4.16667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .services-items {
    gap: 20px 16px;
  }
}
.services-items.-type1140 {
  max-width: 1140px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .services-items.-type1140 {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .services-items.-type1140 {
    width: 100%;
  }
}
.services-items.-type1140 a.services-item {
  border: 1px solid #C8C8C8;
  padding: 20px 20px 22px;
  gap: 12px 0px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .services-items.-type1140 a.services-item {
    gap: 0.85714vw 0px;
    padding: 1.42857vw 1.42857vw 1.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .services-items.-type1140 a.services-item {
    gap: 2.66667vw 0px;
    padding: 3.73333vw 3.73333vw 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .services-items.-type1140 a.services-item {
    gap: 10px 0px;
    padding: 14px 14px 16px;
  }
}
.services-items.-type1140 .services-item__img {
  margin-bottom: 15px;
}
.services-items.-type1140 .services-item__img::after {
  display: none;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .services-items.-type1140 .services-item__img {
    margin-bottom: 1.07143vw;
  }
}
@media screen and (max-width: 767px) {
  .services-items.-type1140 .services-item__img {
    margin-bottom: 4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .services-items.-type1140 .services-item__img {
    margin-bottom: 15px;
  }
}
.services-items.-type1140 .services-item__ttl {
  font-size: 18px;
  line-height: 1.4;
  margin-bottom: 12px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .services-items.-type1140 .services-item__ttl {
    font-size: 1.28571vw;
    margin-bottom: 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .services-items.-type1140 .services-item__ttl {
    font-size: 4.26667vw;
    margin-bottom: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .services-items.-type1140 .services-item__ttl {
    font-size: 16px;
    margin-bottom: 12px;
  }
}
.services-items a.services-item {
  display: block;
  gap: 0 0px;
  -webkit-transition: opacity 0.2s ease-out, border 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out, border 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out, border 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out, border 0.2s ease-out;
  transition: opacity 0.2s ease-out, border 0.2s ease-out;
}
@media screen and (min-width: 1025px) {
  .services-items a.services-item:hover {
    opacity: 0.7;
    -webkit-transition: opacity 0.3s ease-out, border 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out, border 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out, border 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out, border 0.3s ease-out;
    transition: opacity 0.3s ease-out, border 0.3s ease-out;
  }
  .services-items a.services-item:hover .services-item__img img {
    -webkit-transform: scale(1.08);
    -moz-transform: scale(1.08);
    -ms-transform: scale(1.08);
    -o-transform: scale(1.08);
    transform: scale(1.08);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
  .services-items a.services-item:hover::after {
    -webkit-transform: translateX(10px);
    -moz-transform: translateX(10px);
    -ms-transform: translateX(10px);
    -o-transform: translateX(10px);
    transform: translateX(10px);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
}

.services-item__img {
  position: relative;
  margin-bottom: 16px;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .services-item__img {
    margin-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .services-item__img {
    margin-bottom: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .services-item__img {
    margin-bottom: 12px;
  }
}
.services-item__img::after {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border: 1px solid #D6D5D5;
  z-index: 2;
}
.services-item__img img {
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
  position: relative;
  z-index: 1;
}

.services-item__label {
  margin-bottom: 12px;
  position: relative;
  display: inline-block;
  font-size: 12px;
  background: #E2E3E5;
  padding: 5px 12px 5px;
  line-height: 1.4;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .services-item__label {
    margin-bottom: 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .services-item__label {
    margin-bottom: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .services-item__label {
    margin-bottom: 12px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .services-item__label {
    font-size: 0.85714vw;
    padding: 0.35714vw 0.85714vw 0.35714vw;
  }
}
@media screen and (max-width: 767px) {
  .services-item__label {
    font-size: 3.2vw;
    padding: 1.33333vw 3.2vw 1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .services-item__label {
    font-size: 12px;
    padding: 5px 12px 5px;
  }
}

.services-item__ttl {
  font-size: 16px;
  line-height: 1.4;
  margin-bottom: 8px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .services-item__ttl {
    font-size: 1.14286vw;
    margin-bottom: 0.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .services-item__ttl {
    font-size: 4.26667vw;
    margin-bottom: 2.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .services-item__ttl {
    font-size: 16px;
    margin-bottom: 8px;
  }
}

.services-item__txt {
  font-size: 14px;
  line-height: 1.7;
  font-weight: 400;
  margin-bottom: 0 !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .services-item__txt {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .services-item__txt {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .services-item__txt {
    font-size: 14px;
  }
}

.deluxe-items {
  margin: 0 auto;
  max-width: 1400px;
}
.deluxe-items .deluxe-item {
  position: relative;
}

.deluxe-item__img {
  position: relative;
  z-index: 1;
  width: 932px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .deluxe-item__img {
    width: 66.57%;
  }
}
@media screen and (max-width: 767px) {
  .deluxe-item__img {
    width: 100%;
  }
}

.deluxe-item__con {
  position: absolute;
  z-index: 2;
  width: 605px;
  padding: 74px 75px 75px;
  background: #fff;
  left: 50%;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  margin-left: 25px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .deluxe-item__con {
    width: 43.21%;
    margin-left: 1.79%;
    padding: 5.28571vw 5.35714vw 5.35714vw;
  }
}
@media screen and (max-width: 767px) {
  .deluxe-item__con {
    position: relative;
    top: 0;
    left: 0;
    width: 89.58333vw;
    padding: 14.4vw 5.33333vw 13.33333vw;
    margin: -34.66667vw auto 0;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    -o-transform: translateY(0);
    transform: translateY(0);
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .deluxe-item__con {
    padding: 54px 20px 50px;
    margin: -130px auto 0;
  }
}

.deluxe-ttl {
  margin-bottom: 48px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .deluxe-ttl {
    margin-bottom: 3.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .deluxe-ttl {
    margin: 0 2.66667vw 6.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .deluxe-ttl {
    margin: 0 10px 26px;
  }
}
.deluxe-ttl span {
  display: block;
}
.deluxe-ttl span.-en {
  font-size: 14px;
  font-family: "Manrope", sans-serif;
  color: #007AAA;
  font-weight: 700;
  margin-bottom: 8px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .deluxe-ttl span.-en {
    font-size: 1vw;
    margin-bottom: 0.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .deluxe-ttl span.-en {
    font-size: 3.2vw;
    margin-bottom: 1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .deluxe-ttl span.-en {
    font-size: 12px;
    margin-bottom: 6px;
  }
}
.deluxe-ttl span.-ja {
  font-size: 28px;
  letter-spacing: 0.00em;
  color: #33393B;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .deluxe-ttl span.-ja {
    font-size: 2vw;
  }
}
@media screen and (max-width: 767px) {
  .deluxe-ttl span.-ja {
    font-size: 6.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .deluxe-ttl span.-ja {
    font-size: 26px;
  }
}

.deluxe-txt {
  font-size: 16px;
  line-height: 2.0;
  letter-spacing: 0.1em;
  margin-bottom: 62px;
  color: #33393B;
  font-weight: 400;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .deluxe-txt {
    font-size: 1.14286vw;
    margin-bottom: 4.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .deluxe-txt {
    letter-spacing: 0.06em;
    font-size: 4.26667vw;
    margin: 0 2.66667vw 9.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .deluxe-txt {
    font-size: 16px;
    margin: 0 10px 36px;
  }
}

/*********************************************
case
*********************************************/
.case-result {
  font-size: 16px;
  margin-bottom: 32px;
  font-weight: 400;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .case-result {
    font-size: 1.14286vw;
    margin-bottom: 2.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .case-result {
    font-size: 3.2vw;
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .case-result {
    font-size: 12px;
    margin-bottom: 20px;
  }
}
.case-result span {
  font-size: 16px;
  font-weight: 500;
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .case-result span {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .case-result span {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .case-result span {
    font-size: 14px;
  }
}
.case-result span span {
  font-weight: 700;
  font-size: 26px;
  padding-right: 0.1em;
  padding-left: 0.2em;
  top: 2px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .case-result span span {
    font-size: 1.85714vw;
    top: 0.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .case-result span span {
    font-size: 5.33333vw;
    top: 0.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .case-result span span {
    font-size: 20px;
    top: 1px;
  }
}

_::-webkit-full-page-media, _:future, :root .case-item__ttl {
  min-height: 3em;
}

_::-webkit-full-page-media, _:future, :root .case-item__txt {
  min-height: 6.5em;
  margin-bottom: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  _::-webkit-full-page-media, _:future, :root .case-item__txt {
    margin-bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  _::-webkit-full-page-media, _:future, :root .case-item__txt {
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  _::-webkit-full-page-media, _:future, :root .case-item__txt {
    margin-bottom: 20px;
  }
}

.case-items {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 30px 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .case-items {
    gap: 2.14286vw 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .case-items {
    grid-template-columns: 1fr;
    border-top: 1px solid #C8C8C8;
    gap: 0 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .case-items {
    grid-template-columns: 1fr 1fr;
    gap: 30px 30px;
  }
}
.case-items a.case-item {
  gap: 0 0;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 6;
  padding: 30px 30px 25px;
  height: 100%;
  position: relative;
  color: #33393B;
  -webkit-transition: opacity 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .case-items a.case-item {
    padding: 2.14286vw 2.14286vw 1.78571vw;
  }
}
@media screen and (max-width: 767px) {
  .case-items a.case-item {
    border-bottom: 1px solid #C8C8C8;
    padding: 8vw 0 4vw;
    display: grid;
    grid-template-rows: none;
    grid-template-areas: "areaTtl areaTtl" "areaImg areaLabel" "areaImg areaComp" "areaImg areaTxt" "areaBtn areaBtn";
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .case-items a.case-item {
    padding: 30px 0 15px;
  }
  .case-items a.case-item .btn .hack-a {
    width: auto;
  }
}
.case-items a.case-item::after {
  position: absolute;
  display: block;
  content: '';
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border: 1px solid #C8C8C8;
  -webkit-transition: border 0.2s ease-out;
  -moz-transition: border 0.2s ease-out;
  -ms-transition: border 0.2s ease-out;
  -o-transition: border 0.2s ease-out;
  transition: border 0.2s ease-out;
}
@media screen and (max-width: 767px) {
  .case-items a.case-item::after {
    display: none;
  }
}
@media screen and (min-width: 1025px) {
  .case-items a.case-item:hover {
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
    opacity: 0.7;
  }
  .case-items a.case-item:hover .case-item__img img {
    -webkit-transform: scale(1.08);
    -moz-transform: scale(1.08);
    -ms-transform: scale(1.08);
    -o-transform: scale(1.08);
    transform: scale(1.08);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
}

.case-item__ttl {
  font-size: 18px;
  margin-bottom: 16px;
  line-height: 1.4;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .case-item__ttl {
    font-size: 1.28571vw;
    margin-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .case-item__ttl {
    display: grid;
    font-size: 4.8vw;
    margin-bottom: 4.8vw;
    grid-area: areaTtl;
    min-height: auto;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .case-item__ttl {
    font-size: 18px;
    margin-bottom: 18px;
  }
}

.case-item__img {
  margin-bottom: 26px;
  height: 216px;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .case-item__img {
    margin-bottom: 1.85714vw;
    height: 15.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .case-item__img {
    width: 32vw;
    margin-bottom: 0;
    grid-area: areaImg;
    margin-right: 4.8vw;
    height: auto;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .case-item__img {
    width: 120px;
    margin-right: 18px;
  }
}
.case-item__img img {
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
  display: block;
}

.case-item__label {
  margin-bottom: 8px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .case-item__label {
    margin-bottom: 1.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .case-item__label {
    margin-bottom: 2.66667vw;
    grid-area: areaLabel;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .case-item__label {
    margin-bottom: 10px;
  }
}
.case-item__label span {
  display: inline-block;
  font-size: 12px;
  background: #E2E3E5;
  padding: 5px 12px 5px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .case-item__label span {
    font-size: 0.85714vw;
    padding: 0.35714vw 0.85714vw 0.35714vw;
  }
}
@media screen and (max-width: 767px) {
  .case-item__label span {
    font-size: 3.2vw;
    padding: 1.33333vw 3.2vw 1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .case-item__label span {
    font-size: 12px;
    padding: 5px 12px 5px;
  }
}

.case-item__comp {
  font-size: 20px;
  margin-bottom: 16px;
  line-height: 1.4;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .case-item__comp {
    font-size: 1.42857vw;
    margin-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .case-item__comp {
    font-size: 4.26667vw;
    margin-bottom: 4.26667vw;
    grid-area: areaComp;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .case-item__comp {
    font-size: 16px;
    margin-bottom: 16px;
  }
}

.case-item__txt {
  font-size: 14px;
  line-height: 1.6;
  font-weight: 400;
  letter-spacing: 0.08em;
  margin-bottom: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .case-item__txt {
    font-size: 1vw;
    margin-bottom: 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .case-item__txt {
    min-height: auto;
    font-size: 3.73333vw;
    margin-bottom: 5.33333vw;
    grid-area: areaTxt;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .case-item__txt {
    font-size: 14px;
    margin-bottom: 20px;
  }
}

@media screen and (max-width: 767px) {
  a.case-item .btn {
    grid-area: areaBtn;
  }
}
/* service */
.ttl-dl {
  display: table;
  margin-bottom: 30px;
}
.ttl-dl dt {
  font-size: 20px;
  color: #007AAA;
  margin-right: 50px;
  margin-bottom: 5px;
  line-height: 1.6;
  float: left;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-dl dt {
    font-size: 1.42857vw;
    margin-right: 3.57143vw;
    margin-bottom: 0.35714vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-dl dt {
    float: none;
    font-size: 4.8vw;
    margin-right: 0;
    margin-bottom: 1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-dl dt {
    font-size: 18px;
    margin-bottom: 5px;
  }
}
.ttl-dl dd {
  float: left;
  padding-top: 5px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-dl dd {
    padding-top: 0.35714vw;
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-dl dd {
    float: none;
    padding-top: 0;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-dl dd {
    font-size: 16px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .ttl-dl {
    margin-bottom: 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .ttl-dl {
    margin-bottom: 6.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .ttl-dl {
    margin-bottom: 26px;
  }
}

.service-items {
  width: 100%;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
  gap: 70px 0;
  margin-bottom: 100px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-items {
    gap: 5vw 0;
    margin-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .service-items {
    gap: 10.66667vw 0;
    margin-bottom: 16vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-items {
    gap: 40px 0;
    margin-bottom: 60px;
  }
}
.service-items a.service-item {
  width: 550px;
  display: table;
  position: relative;
  padding-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-items a.service-item {
    width: 48.24%;
    padding-bottom: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .service-items a.service-item {
    width: 46.51%;
    display: block;
    padding-bottom: 0;
  }
}
.service-items a.service-item .icon {
  left: 270px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-items a.service-item .icon {
    left: 19.28571vw !important;
  }
}
@media screen and (max-width: 767px) {
  .service-items a.service-item .icon {
    left: 0 !important;
  }
}
@media screen and (min-width: 1025px) {
  .service-items a.service-item {
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  .service-items a.service-item:hover {
    opacity: 0.7;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
  .service-items a.service-item:hover .service-item__img img {
    -webkit-transition: transform 0.2s ease-out;
    -moz-transition: transform 0.2s ease-out;
    -ms-transition: transform 0.2s ease-out;
    -o-transition: transform 0.2s ease-out;
    transition: transform 0.2s ease-out;
    -webkit-transform: scale(1.04);
    -moz-transform: scale(1.04);
    -ms-transform: scale(1.04);
    -o-transform: scale(1.04);
    transform: scale(1.04);
  }
}

.service-item__con {
  display: table-cell;
  vertical-align: top;
  position: relative;
  width: 310px;
  padding-left: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-item__con {
    width: 22.14286vw;
    padding-left: 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .service-item__con {
    display: block;
    width: 100%;
    padding-left: 0;
    padding-bottom: 6.4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-item__con {
    padding-bottom: 24px;
  }
}

.service-item__img {
  display: table-cell;
  vertical-align: top;
  width: 240px;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-item__img {
    width: 17.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .service-item__img {
    display: block;
    width: 100%;
    margin-bottom: 3.73333vw;
    padding-bottom: 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-item__img {
    margin-bottom: 14px;
  }
}
.service-item__img img {
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
  display: block;
}

.service-item__label {
  margin-bottom: 14px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-item__label {
    margin-bottom: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .service-item__label {
    margin-bottom: 2.66667vw;
    grid-area: areaLabel;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-item__label {
    margin-bottom: 10px;
  }
}
.service-item__label span {
  display: inline-block;
  font-size: 12px;
  background: #E2E3E5;
  padding: 5px 12px 5px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-item__label span {
    font-size: 0.85714vw;
    padding: 0.35714vw 0.85714vw 0.35714vw;
  }
}
@media screen and (max-width: 767px) {
  .service-item__label span {
    font-size: 3.2vw;
    padding: 1.33333vw 3.2vw 1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-item__label span {
    font-size: 12px;
    padding: 5px 12px 5px;
  }
}

.service-item__ttl {
  font-size: 20px;
  margin-bottom: 12px;
  line-height: 1.4;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-item__ttl {
    font-size: 1.42857vw;
    margin-bottom: 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .service-item__ttl {
    font-size: 4.26667vw;
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-item__ttl {
    font-size: 16px;
    margin-bottom: 10px;
  }
}

.service-item__txt {
  font-size: 16px;
  line-height: 1.6;
  font-weight: 400;
  letter-spacing: 0.08em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-item__txt {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .service-item__txt {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-item__txt {
    font-size: 14px;
  }
}

.location-map {
  position: relative;
  margin-bottom: 80px;
  padding-bottom: 48.25%;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .location-map {
    margin-bottom: 5.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .location-map {
    -webkit-transform: scale(1.14);
    -moz-transform: scale(1.14);
    -ms-transform: scale(1.14);
    -o-transform: scale(1.14);
    transform: scale(1.14);
    padding-bottom: 62.5%;
    margin-bottom: 21.33333vw;
    -webkit-transform-origin: 50% 0%;
    transform-origin: 50% 0%;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .location-map {
    margin-bottom: 80px;
  }
}

.location-map__img {
  position: relative;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.location-map__link {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
}
.location-map__link li {
  position: absolute;
}
.location-map__link li:nth-of-type(1) {
  top: 72%;
  left: 60.53%;
}
@media screen and (max-width: 767px) {
  .location-map__link li:nth-of-type(1) {
    top: 71.91%;
    left: 63.84%;
  }
}
.location-map__link li:nth-of-type(2) {
  top: 49.28%;
  left: 67.02%;
}
@media screen and (max-width: 767px) {
  .location-map__link li:nth-of-type(2) {
    top: 49.29%;
    left: 72.48%;
  }
}
.location-map__link li:nth-of-type(3) {
  top: 21.46%;
  left: 42.99%;
}
@media screen and (max-width: 767px) {
  .location-map__link li:nth-of-type(3) {
    top: 21.43%;
    left: 41.97%;
  }
}
.location-map__link li:nth-of-type(4) {
  top: 21.46%;
  left: 25.44%;
}
@media screen and (max-width: 767px) {
  .location-map__link li:nth-of-type(4) {
    top: 21.43%;
    left: 19.05%;
  }
}
.location-map__link li:nth-of-type(5) {
  top: 77.1%;
  left: 42.64%;
}
@media screen and (max-width: 767px) {
  .location-map__link li:nth-of-type(5) {
    top: 77.15%;
    left: 41.08%;
  }
}
.location-map__link li:nth-of-type(6) {
  top: 43.64%;
  left: 19.13%;
}
@media screen and (max-width: 767px) {
  .location-map__link li:nth-of-type(6) {
    top: 43.81%;
    left: 9.98%;
  }
}
.location-map__link li a {
  display: block;
  width: 100px;
  height: 100px;
  background: #e8e8e8;
  text-align: center;
  border-radius: 50%;
  overflow: hidden;
  font-weight: 600;
  font-size: 17px;
  padding-top: 34px;
  position: relative;
  -webkit-transition: opacity 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .location-map__link li a {
    width: 7.14286vw;
    height: 7.14286vw;
    font-size: 1.21429vw;
    padding-top: 2.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .location-map__link li a {
    width: 10.13333vw;
    height: 10.13333vw;
    text-indent: -9999px;
    opacity: 0;
  }
}
.location-map__link li a::after {
  content: '';
  display: block;
  position: absolute;
  width: 28px;
  height: 16px;
  top: 64px;
  left: 50%;
  margin-left: -14px;
  background: url(../img/common/ico_arrow_b_btm.png) center center no-repeat;
  background-size: 100% auto;
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .location-map__link li a::after {
    width: 2vw;
    height: 1.14286vw;
    top: 4.57143vw;
    margin-left: -1vw;
  }
}
@media screen and (max-width: 767px) {
  .location-map__link li a::after {
    display: none;
  }
}
@media screen and (min-width: 1025px) {
  .location-map__link li a {
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
  .location-map__link li a:hover {
    opacity: 0.7;
  }
  .location-map__link li a:hover::after {
    -webkit-transform: translateY(4px);
    -moz-transform: translateY(4px);
    -ms-transform: translateY(4px);
    -o-transform: translateY(4px);
    transform: translateY(4px);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
}

.map-location {
  position: relative;
  padding-bottom: 44.45%;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .map-location {
    margin-bottom: 1.42857vw;
  }
}
.map-location iframe {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

/*********************************************
photo
*********************************************/
.photo-items .photo-item {
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .photo-items .photo-item {
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .photo-items .photo-item {
    margin-bottom: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .photo-items .photo-item {
    margin-bottom: 40px;
  }
}
.photo-items .photo-item:last-child {
  margin-bottom: 0;
}

.photo-item__inner {
  display: table;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .photo-item__inner {
    display: block;
  }
  .photo-item__inner.-column-sp {
    display: table;
  }
  .photo-item__inner.-column-sp .photo-item__img-inner img {
    width: 48%;
    display: block;
  }
}

.-has-border {
  position: relative;
}
.-has-border::after {
  display: block;
  position: absolute;
  content: '';
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 3;
  border: 1px solid #C8C8C8;
}

.photo-item__img {
  display: table-cell;
  vertical-align: top;
  width: 40%;
}
.-case .photo-item__img {
  width: 450px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-case .photo-item__img {
    width: 32.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .-case .photo-item__img {
    width: 100%;
  }
}
.-va-m .photo-item__img {
  vertical-align: middle;
}
.-img-02 .photo-item__img {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .-img-02 .photo-item__img {
    width: 100%;
  }
}
.-img-02 .photo-item__img img {
  width: 275px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-img-02 .photo-item__img img {
    width: 48.24%;
  }
}
@media screen and (max-width: 767px) {
  .-img-02 .photo-item__img img {
    width: 100%;
  }
}
.-ph-01 .photo-item__img img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .photo-item__img {
    display: block;
    width: 100%;
    margin-bottom: 6.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .photo-item__img {
    margin-bottom: 25px;
  }
}

.photo-item__img-inner {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
  gap: 20px 0;
}
.photo-item__img-inner.line-gray {
  position: relative;
}
.photo-item__img-inner.line-gray img {
  position: relative;
  z-index: 1;
  display: block;
}
.photo-item__img-inner.line-gray::after {
  display: block;
  position: absolute;
  content: '';
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 1px solid #D9D8D8;
  z-index: 10;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .photo-item__img-inner {
    gap: 1.42857vw 0;
  }
}
@media screen and (max-width: 767px) {
  .photo-item__img-inner {
    gap: 4vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .photo-item__img-inner {
    gap: 15px 0;
  }
}

.photo-item__con {
  display: table-cell;
  vertical-align: top;
  width: 60%;
  padding-left: 40px;
}
.-case .photo-item__con {
  width: auto;
  padding-left: 0 !important;
  padding-right: 80px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-case .photo-item__con {
    width: auto;
    padding-right: 5.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .-case .photo-item__con {
    width: 100%;
    padding-right: 0;
  }
}
.-va-m .photo-item__con {
  vertical-align: middle;
}
.-img-02 .photo-item__con {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .-img-02 .photo-item__con {
    width: 100%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .photo-item__con {
    padding-left: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .photo-item__con {
    display: block;
    width: 100%;
    padding-left: 0;
  }
}

@media screen and (max-width: 767px) {
  .table-scroll {
    width: 100%;
    position: relative;
    border-right: 1px solid #C8C8C8;
    border-left: 1px solid #C8C8C8;
  }
  .table-scroll::after {
    content: '';
    display: block;
    position: absolute;
    z-index: 3;
    width: 58.66667vw;
    height: 58.66667vw;
    top: 29.33333vw;
    left: 50%;
    margin-left: -29.33333vw;
    background: url(../img/common/ico_scroll_finger.png) 0 0 no-repeat;
    background-size: 100% auto;
    pointer-events: none;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
  .table-scroll::after {
    width: 37.33333vw;
    height: 37.33333vw;
    top: 5.33333vw;
    margin-left: -18.66667vw;
  }
  .table-scroll.is-active::after {
    opacity: 0;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
  .table-scroll::before {
    display: block;
    position: absolute;
    content: '';
    bottom: -2px;
    left: -5%;
    width: 110%;
    height: 14px;
    background: #fff;
    z-index: 1;
  }

  .table-scroll__inner::-webkit-scrollbar {
    height: 4px;
  }

  .table-scroll__inner::-webkit-scrollbar-track {
    background-color: #fff;
  }

  .table-scroll__inner::-webkit-scrollbar-thumb {
    background-color: #00AEEF;
    background-color: #43b9ee;
  }

  .table-scroll__inner {
    position: relative;
    overflow: hidden;
    overflow-x: scroll;
    padding-bottom: 8px;
    z-index: 2;
  }
  .table-scroll__inner table {
    position: relative;
    z-index: 1;
    width: 170.66667vw;
  }
  .table-scroll__inner table.table-sp-900 {
    width: 240vw;
  }
  .table-scroll__inner .table-02,
  .table-scroll__inner .table-01 {
    border-bottom: 1px solid #C8C8C8;
    border-right: none;
  }
  .table-scroll__inner .table-02 th:first-child, .table-scroll__inner .table-02 td:first-child,
  .table-scroll__inner .table-01 th:first-child,
  .table-scroll__inner .table-01 td:first-child {
    border-left: none;
  }
}
.flow-items .flow-item {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
  margin-bottom: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .flow-items .flow-item {
    margin-bottom: 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .flow-items .flow-item {
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .flow-items .flow-item {
    margin-bottom: 30px;
  }
}
.flow-items .flow-item:last-child {
  margin-bottom: 0;
}

.flow-item__txt {
  width: 770px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .flow-item__txt {
    width: 67.54%;
  }
}
@media screen and (max-width: 767px) {
  .flow-item__txt {
    width: 100%;
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .flow-item__txt {
    margin-bottom: 20px;
  }
}

.flow-item__img {
  width: 330px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .flow-item__img {
    width: 28.94%;
  }
}
@media screen and (max-width: 767px) {
  .flow-item__img {
    width: 100%;
  }
}
.flow-item__img span {
  display: block;
  position: relative;
}
.flow-item__img span img {
  display: block;
  position: relative;
  z-index: 1;
}
.flow-item__img span::after {
  position: absolute;
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border: 1px solid #D6D5D5;
  z-index: 2;
}

.layout-column {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  -o-justify-content: flex-start;
  justify-content: flex-start;
}
.layout-column.-jc-between {
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
.layout-column.-column-02 {
  gap: 40px 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .layout-column.-column-02 {
    gap: 2.85714vw 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .layout-column.-column-02 {
    gap: 8vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .layout-column.-column-02 {
    gap: 30px 0;
  }
}
.layout-column.-column-03 {
  gap: 40px 42px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .layout-column.-column-03 {
    gap: 2.85714vw 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .layout-column.-column-03 {
    gap: 8vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .layout-column.-column-03 {
    gap: 30px 0;
  }
}
.layout-column.-subgrid {
  display: grid;
  grid-template-columns: 530px 530px;
  gap: 0 0;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .layout-column.-subgrid {
    grid-template-columns: 37.85714vw 37.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .layout-column.-subgrid {
    display: grid;
    grid-template-columns: 100%;
  }
}
.layout-column.-subgrid .layout-column__inner {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 4;
  gap: 0 0 !important;
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .layout-column.-subgrid .layout-column__inner {
    width: 100%;
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .layout-column.-subgrid .layout-column__inner {
    width: 100%;
    margin-bottom: 16vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .layout-column.-subgrid .layout-column__inner {
    margin-bottom: 60px;
  }
}

.-column-02 .layout-column__inner {
  width: 530px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-column-02 .layout-column__inner {
    width: 46.49%;
  }
}
@media screen and (max-width: 767px) {
  .-column-02 .layout-column__inner {
    width: 100%;
  }
}
.-column-03 .layout-column__inner {
  width: 352px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-column-03 .layout-column__inner {
    width: 30.87%;
  }
}
@media screen and (max-width: 767px) {
  .-column-03 .layout-column__inner {
    width: 100%;
  }
}
.layout-column__inner.-column-w-270 {
  width: 270px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .layout-column__inner.-column-w-270 {
    width: 23.68%;
  }
}
@media screen and (max-width: 767px) {
  .layout-column__inner.-column-w-270 {
    width: 46.76%;
  }
}
.layout-column__inner.-column-w-520 {
  width: 520px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .layout-column__inner.-column-w-520 {
    width: 45.61%;
  }
}
@media screen and (max-width: 767px) {
  .layout-column__inner.-column-w-520 {
    width: 100%;
  }
}

.movie-youtube {
  width: 800px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .movie-youtube {
    width: 70.17%;
  }
}
@media screen and (max-width: 767px) {
  .movie-youtube {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

.movie-youtube__inner {
  position: relative;
  padding-bottom: 56.25%;
}
.movie-youtube__inner iframe {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border: 0;
}

@media screen and (max-width: 767px) {
  .adress-imgs {
    border-top: 1px solid #D9D8D8;
  }
}
.adress-imgs .adress-img {
  display: grid;
  grid-template-areas: "areaImg adressTtl" "areaImg adressTxts" "areaImg adressTxts";
  gap: 0 0;
  width: 100%;
  margin-bottom: 60px;
  grid-template-columns: 275px 1fr;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .adress-imgs .adress-img {
    margin-bottom: 4.28571vw;
    grid-template-columns: 19.64286vw 1fr;
  }
}
@media screen and (max-width: 767px) {
  .adress-imgs .adress-img {
    margin-bottom: 0;
    grid-template-columns: 32vw 1fr;
    border-bottom: 1px solid #D9D8D8;
    padding-top: 8vw;
    padding-bottom: 8vw;
    grid-template-areas: "areaImg adressTtl" "adressTxts adressTxts";
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .adress-imgs .adress-img {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}
.adress-imgs .adress-img:last-child {
  margin-bottom: 0;
}

.adress-img__img {
  grid-area: areaImg;
}

.adress-img__ttl {
  grid-area: adressTtl;
  font-size: 18px;
  font-weight: 500;
  padding-left: 40px;
  line-height: 1.8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .adress-img__ttl {
    font-size: 1.28571vw;
    padding-left: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .adress-img__ttl {
    line-height: 1.7;
    font-size: 4.26667vw;
    padding-left: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .adress-img__ttl {
    font-size: 16px;
    padding-left: 20px;
  }
}

.adress-img__txts {
  grid-area: adressTxts;
  padding-left: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .adress-img__txts {
    padding-left: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .adress-img__txts {
    padding-left: 0;
    margin-top: 5.33333vw;
  }
}

.logo-asset {
  width: auto;
  display: table;
}

.logo-asset__txt {
  display: table-cell;
  vertical-align: middle;
  padding-right: 24px;
  font-size: 18px;
  font-weight: 500;
  text-align: left;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .logo-asset__txt {
    font-size: 1.28571vw;
    padding-right: 1.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .logo-asset__txt {
    font-size: 4.26667vw;
    padding-right: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .logo-asset__txt {
    font-size: 16px;
    padding-right: 20px;
  }
}

.logo-asset__img {
  display: table-cell;
  vertical-align: middle;
  width: 140px;
  width: 80px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .logo-asset__img {
    width: 5.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .logo-asset__img {
    width: 17.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .logo-asset__img {
    width: 66px;
  }
}

.bg-layout__l label {
  display: block;
  position: relative;
  padding-left: 26px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layout__l label {
    padding-left: 1.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-layout__l label {
    padding-left: 6.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layout__l label {
    padding-left: 26px;
  }
}
.bg-layout__l label .form-checkbox {
  position: absolute;
  top: 4px;
  left: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bg-layout__l label .form-checkbox {
    top: 0.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .bg-layout__l label .form-checkbox {
    top: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bg-layout__l label .form-checkbox {
    top: 4px;
  }
}
.bg-layout__l .checkbox-txt {
  font-weight: 500;
}

.checkbox-txt {
  display: inline-block;
  position: relative;
  font-size: 14px;
  line-height: 1.6;
  font-weight: 400;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .checkbox-txt {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .checkbox-txt {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .checkbox-txt {
    font-size: 14px;
  }
}

/* checkbox */
.form-checkbox {
  border: 1px solid #DDDDDD;
  width: 16px;
  height: 16px;
  position: relative;
  background: #fff !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .form-checkbox {
    width: 1.14286vw;
    height: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .form-checkbox {
    width: 4.26667vw;
    height: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .form-checkbox {
    width: 16px;
    height: 16px;
  }
}

.form-checkbox:after {
  position: absolute;
  content: "";
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/common/ico_form_check.png) 0 0 no-repeat;
  background-size: 100% auto;
  display: none;
}

.form-checkbox:checked:after {
  display: block;
}

.form-checkbox__list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .form-checkbox__list {
    gap: 1vw 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .form-checkbox__list {
    grid-template-columns: 1fr;
    margin: 0 2.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .form-checkbox__list {
    margin: 0 8px;
  }
}
.form-checkbox__list.-no-grid {
  display: block;
  gap: 0 0;
}
.form-checkbox__list.-no-grid li {
  margin-bottom: 14px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .form-checkbox__list.-no-grid li {
    margin-bottom: 14px;
  }
}
.form-checkbox__list.-no-grid li:last-child {
  margin-bottom: 0;
}
.form-checkbox__list.-no-grid label span {
  font-size: 16px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .form-checkbox__list.-no-grid label span {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .form-checkbox__list.-no-grid label span {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .form-checkbox__list.-no-grid label span {
    font-size: 14px;
  }
}
.form-checkbox__list label {
  display: block;
  position: relative;
  padding-left: 26px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .form-checkbox__list label {
    padding-left: 1.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .form-checkbox__list label {
    padding-left: 6.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .form-checkbox__list label {
    padding-left: 26px;
  }
}
.form-checkbox__list label .form-checkbox {
  position: absolute;
  top: 4px;
  left: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .form-checkbox__list label .form-checkbox {
    top: 0.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .form-checkbox__list label .form-checkbox {
    top: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .form-checkbox__list label .form-checkbox {
    top: 4px;
  }
}

/* add */
.contents-main {
  display: grid;
  justify-content: space-between;
  align-items: start;
  grid-template-columns: auto auto;
  gap: 0 40px;
  margin-bottom: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .contents-main {
    gap: 0 2.85714vw;
    margin-bottom: 2.14286vw;
  }
}
.contents-main.-align-c {
  align-items: center;
}
@media screen and (max-width: 767px) {
  .contents-main {
    display: block;
    gap: 0 0;
  }
}
.contents-main .contents-main__txts {
  width: 660px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .contents-main .contents-main__txts {
    width: 47.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .contents-main .contents-main__txts {
    width: 100%;
    margin-bottom: 6.4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .contents-main .contents-main__txts {
    margin-bottom: 24px;
  }
}
.contents-main .contents-main__img {
  width: 382px;
}
.contents-main .contents-main__img.-w-412 {
  width: 412px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .contents-main .contents-main__img.-w-412 {
    width: 29.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .contents-main .contents-main__img.-w-412 {
    width: 100%;
  }
}
.contents-main .contents-main__img.-w-408 {
  width: 408px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .contents-main .contents-main__img.-w-408 {
    width: 29.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .contents-main .contents-main__img.-w-408 {
    width: 100%;
  }
}
.contents-main .contents-main__img.-w-450 {
  width: 450px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .contents-main .contents-main__img.-w-450 {
    width: 32.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .contents-main .contents-main__img.-w-450 {
    width: 100%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .contents-main .contents-main__img {
    width: 27.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .contents-main .contents-main__img {
    width: 100%;
  }
}

.column03-items {
  display: grid;
  grid-template-columns: repeat(3, 344px);
  justify-content: space-between;
  gap: 60px 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .column03-items.-assignment {
    padding-bottom: 62.66667vw;
  }
}
.column03-items.-assignment::after {
  content: '';
  display: block;
  position: absolute;
  width: 518px;
  height: 277px;
  right: 90px;
  bottom: -30px;
  background: url(../img/service/img_assignment.png) center center no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .column03-items.-assignment::after {
    width: 37vw;
    height: 19.78571vw;
    right: 6.42857vw;
    bottom: -2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .column03-items.-assignment::after {
    width: 100%;
    height: 49.33333vw;
    right: 0;
    bottom: 0;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .column03-items {
    grid-template-columns: repeat(3, 24.57143vw);
    gap: 4.28571vw 0;
  }
}
@media screen and (max-width: 767px) {
  .column03-items {
    grid-template-columns: repeat(1, 100%);
    gap: 10.66667vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .column03-items {
    gap: 40px 0;
  }
}
.column03-items .ttl-blue {
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .column03-items .ttl-blue {
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .column03-items .ttl-blue {
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .column03-items .ttl-blue {
    margin-bottom: 10px;
  }
}
.column03-items.-ttl-subgrid .column03-item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  gap: 0 0;
}
@media screen and (max-width: 767px) {
  .column03-items.-ttl-subgrid .column03-item {
    display: block;
  }
}

.column03-item__img {
  width: 200px;
  margin: 0 auto 16px;
}
.column03-item__img.-moja {
  width: 80px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .column03-item__img.-moja {
    width: 5.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .column03-item__img.-moja {
    width: 21.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .column03-item__img.-moja {
    width: 5.71429vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .column03-item__img {
    width: 14.28571vw;
    margin-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .column03-item__img {
    width: 53.33333vw;
    margin-bottom: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .column03-item__img {
    width: 200px;
    margin-bottom: 16px;
  }
}

.clamp-con.is-active .txt-line-clamp {
  overflow: auto;
  text-overflow: clip;
  -webkit-box-orient: inline-axis;
  box-orient: inline-axis;
  -webkit-line-clamp: none;
  line-clamp: none;
}
.clamp-con.is-active .toggle-icon::before {
  opacity: 0;
}

.txt-line-clamp {
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  text-align: left;
}

.more-clamp {
  position: relative;
  display: inline-block;
  color: #007AAA;
  text-decoration: none;
  font-size: 14px;
  margin-top: 20px;
  -webkit-transition: opacity 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
}
.more-clamp::after {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 1px;
  left: 0;
  bottom: -8px;
  background: #007AAA;
  -webkit-transform: scaleX(1);
  -moz-transform: scaleX(1);
  -ms-transform: scaleX(1);
  -o-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .more-clamp {
    font-size: 1vw;
    margin-top: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .more-clamp {
    font-size: 3.73333vw;
    margin-top: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .more-clamp {
    font-size: 14px;
    margin-top: 20px;
  }
}
.more-clamp .toggle-icon {
  top: 12px;
  right: -28px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .more-clamp .toggle-icon {
    top: 0.85714vw;
    right: -2vw;
  }
}
@media screen and (max-width: 767px) {
  .more-clamp .toggle-icon {
    top: 3.2vw;
    right: -7.46667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .more-clamp .toggle-icon {
    top: 12px;
    right: -28px;
  }
}
.more-clamp .toggle-icon::before, .more-clamp .toggle-icon::after {
  background: #007AAA;
}
.more-clamp .toggle-icon::after {
  width: 11px;
  height: 1px;
  top: 5px;
}
@media screen and (max-width: 767px) {
  .more-clamp .toggle-icon::after {
    width: 11px;
    height: 1px;
    top: 5px;
  }
}
.more-clamp .toggle-icon::before {
  height: 11px;
  width: 1px;
  left: 5px;
}
@media screen and (max-width: 767px) {
  .more-clamp .toggle-icon::before {
    height: 11px;
    width: 1px;
    left: 5px;
  }
}
.more-clamp:hover {
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  -o-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
  opacity: 0.7;
}
.more-clamp:hover::after {
  -webkit-transform: scaleX(0);
  -moz-transform: scaleX(0);
  -ms-transform: scaleX(0);
  -o-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transition: transform 0.3s ease-out;
  -moz-transition: transform 0.3s ease-out;
  -ms-transition: transform 0.3s ease-out;
  -o-transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
}

.img-grids {
  display: grid;
  justify-content: space-between;
  gap: 60px 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-grids {
    gap: 4.28571vw 0;
  }
}
@media screen and (max-width: 767px) {
  .img-grids {
    gap: 10.66667vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .img-grids {
    gap: 40px 0;
  }
}
.img-grids.-btm-border {
  border-bottom: 1px solid #C8C8C8;
  padding-bottom: 60px;
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-grids.-btm-border {
    padding-bottom: 4.28571vw;
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .img-grids.-btm-border {
    padding-bottom: 13.33333vw;
    margin-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .img-grids.-btm-border {
    padding-bottom: 50px;
    margin-bottom: 50px;
  }
}

.img-grid {
  display: grid;
  grid-template-areas: "areaTtl areaImg" "areaTxt areaImg";
  align-items: start;
  grid-template-rows: auto 1fr;
  gap: 0 60px;
  margin-bottom: 0 !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-grid {
    gap: 0 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .img-grid {
    display: block;
    gap: 0 0;
  }
}
.img-grid .img-grid__ttl {
  grid-area: areaTtl;
}
.img-grid .img-grid__txt {
  grid-area: areaTxt;
}
@media screen and (max-width: 767px) {
  .img-grid .img-grid__txt {
    margin-bottom: 4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .img-grid .img-grid__txt {
    margin-bottom: 15px;
  }
}
.img-grid .img-grid__img {
  width: 450px;
  grid-area: areaImg;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .img-grid .img-grid__img {
    width: 32.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .img-grid .img-grid__img {
    width: 100%;
  }
}

.page-link__arrow {
  display: grid;
  grid-template-columns: repeat(5, 212px);
  justify-content: space-between;
  gap: 24px 0;
  margin: 0 auto 100px;
  text-align: left;
}
.page-link__arrow.-center-pc {
  justify-content: center;
  grid-template-columns: repeat(auto-fit, 212px);
  gap: 0 20px;
}
@media screen and (max-width: 767px) {
  .page-link__arrow.-center-pc {
    justify-content: space-between;
    grid-template-columns: repeat(2, 43.2vw);
    gap: 5.33333vw 0;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-link__arrow {
    grid-template-columns: repeat(5, 15.14286vw);
    gap: 1.71429vw 0;
    margin-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .page-link__arrow {
    grid-template-columns: repeat(2, 43.2vw);
    gap: 5.33333vw 0;
    margin-bottom: 16vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-link__arrow {
    margin-bottom: 60px;
  }
}
.page-link__arrow li {
  display: grid;
  grid-template-rows: subgrid;
  /* 追加 */
  grid-row: span 1;
}
.page-link__arrow li a {
  display: grid;
  align-items: center;
  color: #007AAA;
  font-size: 14px;
  padding: 12px 4px 12px;
  border-bottom: 1px solid #007AAA;
  position: relative;
  line-height: 1.4;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-link__arrow li a {
    font-size: 1vw;
    padding: 0.85714vw 0.28571vw 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .page-link__arrow li a {
    font-size: 3.73333vw;
    padding: 2.66667vw 1.06667vw 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-link__arrow li a {
    font-size: 14px;
    padding: 10px 4px 10px;
  }
}
.page-link__arrow li a::after {
  content: '';
  display: block;
  position: absolute;
  width: 12px;
  height: 6px;
  top: 50%;
  margin-top: -3px;
  right: 4px;
  background: url(../img/common/ico_arrow_page_link_arrow.svg) center center no-repeat;
  background-size: 100% auto;
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-link__arrow li a::after {
    width: 0.85714vw;
    height: 0.42857vw;
    margin-top: -0.21429vw;
    right: 0.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .page-link__arrow li a::after {
    width: 3.2vw;
    height: 1.6vw;
    margin-top: -0.8vw;
    right: 1.06667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-link__arrow li a::after {
    width: 12px;
    height: 6px;
    margin-top: -3px;
    right: 4px;
  }
}
@media screen and (min-width: 1025px) {
  .page-link__arrow li a {
    -webkit-transition: opacity 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out;
    transition: opacity 0.2s ease-out;
  }
  .page-link__arrow li a:hover {
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
    opacity: 0.7;
  }
  .page-link__arrow li a:hover::after {
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
    -webkit-transform: translateY(4px);
    -moz-transform: translateY(4px);
    -ms-transform: translateY(4px);
    -o-transform: translateY(4px);
    transform: translateY(4px);
  }
}

.service-con__bg,
.service-case {
  padding: 32px 40px 38px;
  display: grid;
  grid-template-columns: repeat(2, 500px);
  justify-content: space-between;
  gap: 24px 0;
  position: relative;
}
.service-con__bg.-single,
.service-case.-single {
  display: block;
  padding: 30px 40px 30px;
  width: 100%;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-con__bg.-single,
  .service-case.-single {
    padding: 2.14286vw 2.85714vw 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .service-con__bg.-single,
  .service-case.-single {
    padding: 5.33333vw 5.33333vw 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-con__bg.-single,
  .service-case.-single {
    padding: 20px 20px 20px;
  }
}
.service-con__bg.-single section,
.service-case.-single section {
  margin-bottom: 24px !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-con__bg.-single section,
  .service-case.-single section {
    margin-bottom: 1.71429vw !important;
  }
}
@media screen and (max-width: 767px) {
  .service-con__bg.-single section,
  .service-case.-single section {
    margin-bottom: 6.4vw !important;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-con__bg.-single section,
  .service-case.-single section {
    margin-bottom: 24px !important;
  }
}
.service-con__bg.-single section:last-child,
.service-case.-single section:last-child {
  margin-bottom: 0 !important;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-con__bg,
  .service-case {
    grid-template-columns: repeat(2, 35.71429vw);
    padding: 2.28571vw 2.85714vw 2.71429vw;
    gap: 1.71429vw 0;
  }
}
@media screen and (max-width: 767px) {
  .service-con__bg,
  .service-case {
    grid-template-columns: repeat(1, 100%);
    padding: 6.4vw 5.33333vw 6.4vw;
    gap: 12.26667vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-con__bg,
  .service-case {
    padding: 24px 20px 24px;
    gap: 46px 0;
  }
}
.service-con__bg::after,
.service-case::after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: #74D9FF;
  background: linear-gradient(180deg, #74d9ff 0%, #3c9eff 100%) !important;
  z-index: -1;
  opacity: 0.2 !important;
}

.service-con__bg {
  display: block;
}

.service-case__sec {
  position: relative;
  z-index: 2;
  margin-bottom: 0 !important;
}
.service-case__sec .txt {
  position: relative;
  width: 110%;
  left: -5%;
}

.service-case__ttl {
  font-size: 18px;
  margin-bottom: 30px;
  padding-bottom: 12px;
  border-bottom: 1px solid #B0D6E3;
  color: #007AAA;
  line-height: 1.6;
  font-weight: 600;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-case__ttl {
    font-size: 1.28571vw;
    margin-bottom: 2.14286vw;
    padding-bottom: 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .service-case__ttl {
    font-size: 4.26667vw;
    margin-bottom: 5.33333vw;
    padding-bottom: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-case__ttl {
    font-size: 16px;
    margin-bottom: 20px;
    padding-bottom: 12px;
  }
}

.service-case__icons {
  width: 438px;
  display: grid;
  grid-template-columns: repeat(3, 120px);
  justify-content: space-between;
  margin: 0 auto 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-case__icons {
    width: 31.28571vw;
    grid-template-columns: repeat(3, 8.57143vw);
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .service-case__icons {
    width: 66.13333vw;
    grid-template-columns: repeat(1, 100%);
    margin-bottom: 2.66667vw;
    gap: 5.33333vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-case__icons {
    width: 248px;
    margin-bottom: 10px;
    gap: 20px 0;
  }
}
@media screen and (max-width: 767px) {
  .service-case__icons li {
    display: grid;
    grid-template-columns: repeat(2, auto);
    justify-content: space-between;
    align-items: center;
  }
  .service-case__icons li img {
    width: 26.66667vw;
    display: block;
  }
}
.service-case__icons .txt {
  margin-top: 10px;
  text-align: center;
  height: 3em;
  display: grid;
  place-items: center;
  line-height: 1.5;
  font-weight: 500;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-case__icons .txt {
    margin-top: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .service-case__icons .txt {
    width: 39.46667vw;
    height: 100%;
    margin-top: 0;
    text-align: left;
    place-items: inherit;
    align-items: center;
    padding-left: 7.46667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-case__icons .txt {
    width: 148px;
    padding-left: 28px;
  }
}

.service-case__txt-bg {
  background: #EDFAFF;
  text-align: center;
  color: #007AAA;
  font-size: 16px;
  font-weight: 500;
  padding: 16px;
  line-height: 1.5;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-case__txt-bg {
    font-size: 1.14286vw;
    padding: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .service-case__txt-bg {
    font-size: 4.26667vw;
    padding: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-case__txt-bg {
    font-size: 16px;
    padding: 14px;
  }
}

.service-case__lists {
  display: grid;
  gap: 6px 0;
}
.service-case__lists:has(.-fs-18) li::after {
  top: 52%;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-case__lists:has(.-fs-18) li::after {
    top: 52%;
  }
}
@media screen and (max-width: 767px) {
  .service-case__lists:has(.-fs-18) li::after {
    top: 52%;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-case__lists:has(.-fs-18) li::after {
    top: 52%;
  }
}
.service-case__lists.-no-center li::after {
  top: 27px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-case__lists.-no-center li::after {
    top: 1.92857vw;
  }
}
@media screen and (max-width: 767px) {
  .service-case__lists.-no-center li::after {
    top: 7.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-case__lists.-no-center li::after {
    top: 27px;
  }
}
.service-case__lists li {
  font-size: 16px;
  font-weight: 500;
  padding: 14px 20px 14px 36px;
  line-height: 1.6;
  background: #fff;
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-case__lists li {
    font-size: 1.14286vw;
    padding: 1vw 1.42857vw 1vw 2.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .service-case__lists li {
    font-size: 4.26667vw;
    padding: 3.73333vw 5.33333vw 3.73333vw 9.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-case__lists li {
    font-size: 16px;
    padding: 14px 20px 14px 36px;
  }
}
.service-case__lists li::after {
  content: "";
  display: block;
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  top: 50%;
  margin-top: -4px;
  left: 14px;
  background: #007AAA;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-case__lists li::after {
    width: 0.57143vw;
    height: 0.57143vw;
    border-radius: 50%;
    margin-top: -0.28571vw;
    left: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .service-case__lists li::after {
    width: 2.13333vw;
    height: 2.13333vw;
    border-radius: 50%;
    margin-top: -1.06667vw;
    left: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-case__lists li::after {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-top: -4px;
    left: 14px;
  }
}

.service-flows .service-flow {
  padding: 40px 40px;
  display: grid;
  grid-template-columns: 330px 665px;
  justify-content: space-between;
  align-items: center;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-flows .service-flow {
    padding: 2.85714vw 2.85714vw;
    grid-template-columns: 23.57143vw 47.5vw;
  }
}
@media screen and (max-width: 767px) {
  .service-flows .service-flow {
    padding: 6.4vw 5.33333vw;
    display: block;
    grid-template-columns: 100% 100%;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-flows .service-flow {
    padding: 24px 20px;
  }
}
.service-flows .service-flow:nth-child(even) {
  background: #F7FDFF;
}
.service-flows .service-flow:nth-child(odd) {
  background: #EDFAFF;
}

.service-flow__ttl {
  font-size: 20px;
  font-weight: 600;
  color: #007AAA;
  margin-bottom: 0;
  line-height: 1.5;
  position: relative;
  padding-left: 2.7em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-flow__ttl {
    font-size: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .service-flow__ttl {
    font-size: 4.8vw;
    margin-bottom: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-flow__ttl {
    font-size: 18px;
    margin-bottom: 16px;
  }
}
@media screen and (max-width: 767px) {
  .service-flow__ttl {
    padding-left: 2.4em;
  }
}
.service-flow__ttl span {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 0;
  display: inline-block;
  width: 40px;
  height: 40px;
  background: #007AAA;
  color: #fff;
  font-family: "Manrope", sans-serif;
  font-size: 22px;
  margin-right: 10px;
  border-radius: 50%;
  text-align: center;
  padding-top: 9px;
  line-height: 1;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .service-flow__ttl span {
    width: 2.85714vw;
    height: 2.85714vw;
    font-size: 1.57143vw;
    margin-right: 0.71429vw;
    padding-top: 0.64286vw;
  }
}
@media screen and (max-width: 767px) {
  .service-flow__ttl span {
    top: 52%;
    width: 8vw;
    height: 8vw;
    font-size: 4.26667vw;
    margin-right: 2.66667vw;
    padding-top: 1.86667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-flow__ttl span {
    font-size: 18px;
    width: 30px;
    height: 30px;
    font-size: 16px;
    margin-right: 10px;
    padding-top: 7px;
  }
}

.service-flow__txt {
  position: relative;
}
@media screen and (max-width: 767px) {
  .service-flow__txt {
    padding-top: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .service-flow__txt {
    padding-top: calcvwSpLandscap4(20);
  }
}
.service-flow__txt::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: -60px;
  width: 1px;
  height: 100%;
  background: #B0D6E3;
}
@media screen and (max-width: 767px) {
  .service-flow__txt::after {
    left: 0;
    width: 100%;
    height: 1px;
  }
}

.product-items {
  display: grid;
  grid-template-columns: repeat(3, 360px);
  justify-content: flex-start;
  gap: 60px 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .product-items {
    grid-template-columns: repeat(3, 25.71429vw);
    gap: 4.28571vw 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .product-items {
    grid-template-columns: repeat(1, 100%);
    gap: 12vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .product-items {
    gap: 45px 0;
  }
}

.product-item__img {
  position: relative;
  margin-bottom: 16px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .product-item__img {
    margin-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .product-item__img {
    margin-bottom: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .product-item__img {
    margin-bottom: 16px;
  }
}
.product-item__img::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 1px solid #C8C8C8;
  z-index: 10;
}
.product-item__img img {
  position: relative;
  z-index: 1;
}
.product-item__img span {
  display: inline-block;
  position: absolute;
  top: 1px;
  right: 1px;
  font-size: 12px;
  background: #E2E3E5;
  z-index: 9;
  padding: 4px 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .product-item__img span {
    font-size: 0.85714vw;
    padding: 0.28571vw 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .product-item__img span {
    font-size: 3.2vw;
    padding: 1.06667vw 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .product-item__img span {
    font-size: 12px;
    padding: 4px 10px;
  }
}

.product-item__label {
  display: inline-block;
  font-size: 14px;
  padding: 4px 12px;
  color: #007AAA;
  background: #EDFAFF;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .product-item__label {
    font-size: 1vw;
    padding: 0.28571vw 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .product-item__label {
    font-size: 3.73333vw;
    padding: 1.06667vw 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .product-item__label {
    font-size: 14px;
    padding: 4px 12px;
  }
}

.compare-table {
  width: 100%;
  font-size: 16px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .compare-table {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .compare-table {
    font-size: 4.26667vw;
  }
  .compare-table.is-active {
    position: relative;
  }
  .compare-table.is-active .td-ttl {
    background: #007AAA;
    color: #fff;
  }
  .compare-table.is-active::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 5px solid #007AAA;
    z-index: 10;
  }
  .compare-table .td-ttl img {
    display: block;
    width: 60.8vw;
    margin-inline: auto;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .compare-table {
    font-size: calcvwSpLandscap4(16);
  }
}
.compare-table th, .compare-table td {
  border-bottom: 1px solid #C8C8C8;
}
.compare-table td {
  padding: 30px 0;
  text-align: center;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .compare-table td {
    padding: 2.14286vw 0;
  }
}
.compare-table td.is-active {
  background: #EDFAFF;
  position: relative;
  border-left: 5px solid #007AAA;
  border-right: 5px solid #007AAA;
}
.compare-table th {
  padding: 38px 0 30px 28px;
  text-align: left;
  background: #F2F4F7;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .compare-table th {
    padding: 2.71429vw 0 2.14286vw 2vw;
  }
}
@media screen and (max-width: 767px) {
  .compare-table th {
    padding: 8vw 0 8vw 5.33333vw;
    width: 48%;
  }
}
.compare-table.-hiraishin tr {
  border-right: 1px solid #C8C8C8;
  border-left: 1px solid #C8C8C8;
}
.compare-table.-hiraishin tr:first-child {
  border-right: none;
  border-left: none;
}
@media screen and (max-width: 767px) {
  .compare-table.-hiraishin th {
    padding: 8vw 0 6.4vw 4.26667vw;
    width: 44%;
  }
}
.compare-table tr:first-child td.is-active {
  background: #007AAA;
  color: #fff;
}
.compare-table tr:last-child td.is-active {
  position: relative;
}
.compare-table tr:last-child td.is-active::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 5px;
  background: #007AAA;
}
.compare-table .td-txt {
  font-weight: 400;
  font-size: 16px;
  line-height: 1.8;
  text-align: left;
  padding-left: 24px;
  padding-right: 24px;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .compare-table .td-txt {
    font-size: 1.14286vw;
    padding-left: 1.71429vw;
    padding-right: 1.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .compare-table .td-txt {
    font-size: 4.26667vw;
    padding-left: 4.26667vw;
    padding-right: 4.26667vw;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}

.compare-table__td {
  width: 222px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .compare-table__td {
    width: 15.85714vw;
  }
}
.-td-03 .compare-table__td {
  width: 290px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-td-03 .compare-table__td {
    width: 20.71429vw;
  }
}
.-td-04 .compare-table__td {
  width: 228px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .-td-04 .compare-table__td {
    width: 16.28571vw;
  }
}

.icon-maru {
  width: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .icon-maru {
    width: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .icon-maru {
    width: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .icon-maru {
    width: 40px;
  }
}

.icon-peke {
  width: 28px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .icon-peke {
    width: 2vw;
  }
}
@media screen and (max-width: 767px) {
  .icon-peke {
    width: 7.46667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .icon-peke {
    width: 28px;
  }
}

.column02-items {
  display: grid;
  grid-template-columns: repeat(2, 540px);
  justify-content: space-between;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .column02-items {
    grid-template-columns: repeat(2, 38.57143vw);
  }
}
@media screen and (max-width: 767px) {
  .column02-items {
    grid-template-columns: repeat(1, 100%);
    gap: 9.33333vw 0;
  }
}

.showrooms {
  display: grid;
  grid-template-columns: repeat(2, 540px);
  justify-content: space-between;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .showrooms {
    grid-template-columns: repeat(2, 38.57143vw);
  }
}
@media screen and (max-width: 767px) {
  .showrooms {
    grid-template-columns: repeat(1, 100%);
    gap: 9.33333vw 0;
  }
}
.showrooms .showroom {
  display: grid;
  grid-template-columns: repeat(2, auto);
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .showrooms .showroom {
    grid-template-columns: repeat(1, 100%);
    gap: 5.33333vw 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .showrooms .showroom {
    gap: 20px 0;
  }
}

.showroom-img {
  width: 275px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .showroom-img {
    width: 19.64286vw;
  }
}
@media screen and (max-width: 767px) {
  .showroom-img {
    width: 100%;
  }
}

.showroom-con {
  padding-top: 24px;
  width: 225px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .showroom-con {
    padding-top: 1.71429vw;
    width: 16.07143vw;
  }
}
@media screen and (max-width: 767px) {
  .showroom-con {
    padding-top: 0;
    width: 100%;
  }
}
.showroom-con .txt {
  position: relative;
  width: 105%;
}
@media screen and (max-width: 767px) {
  .showroom-con .txt {
    width: 100%;
  }
}

/**************/
.introduction-item {
  position: relative;
  padding: 32px 48px 32px;
  text-align: center;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .introduction-item {
    padding: 2.28571vw 3.42857vw 2.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .introduction-item {
    padding: 8.53333vw 5.86667vw 8.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .introduction-item {
    padding: 32px 22px 32px;
  }
}
.introduction-item::after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: #74D9FF;
  background: linear-gradient(180deg, #74d9ff 0%, #3c9eff 100%);
  z-index: -1;
  opacity: 0.2;
}
.introduction-item .-circle {
  display: inline-block;
}

.introduction-item__icon {
  width: 150px;
  margin: 0 auto 15px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .introduction-item__icon {
    width: 10.71429vw;
    margin: 0 auto 1.07143vw;
  }
}
@media screen and (max-width: 767px) {
  .introduction-item__icon {
    width: 40vw;
    margin-bottom: 4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .introduction-item__icon {
    width: 150px;
    margin-bottom: 15px;
  }
}

.introduction-item__label {
  line-height: 1;
  display: inline-block;
  padding: 11px 26px;
  background: #fff;
  color: #007AAA;
  font-size: 14px;
  margin: 0 auto 15px;
  border-radius: 18px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .introduction-item__label {
    padding: 0.78571vw 1.85714vw;
    font-size: 1vw;
    margin: 0 auto 1.07143vw;
    border-radius: 1.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .introduction-item__label {
    padding: 2.93333vw 6.93333vw;
    font-size: 3.73333vw;
    margin: 0 auto 4vw;
    border-radius: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .introduction-item__label {
    padding: 11px 26px;
    font-size: 14px;
    margin: 0 auto 15px;
    border-radius: 18px;
  }
}

.introduction-item__arrow {
  width: 20px;
  margin: 12px auto 12px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .introduction-item__arrow {
    width: 1.42857vw;
    margin: 0.85714vw auto 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .introduction-item__arrow {
    width: 5.33333vw;
    margin: 3.2vw auto 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .introduction-item__arrow {
    width: 20px;
    margin: 12px auto 12px;
  }
}

.introduction-item__reduction {
  line-height: 1;
  width: 256px;
  padding: 16px 0;
  background: #F1FBFF;
  color: #007AAA;
  font-size: 18px;
  font-weight: 500;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .introduction-item__reduction {
    width: 18.28571vw;
    padding: 1.14286vw 0;
    font-size: 1.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .introduction-item__reduction {
    width: 100%;
    padding: 4.26667vw 0;
    font-size: 4.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .introduction-item__reduction {
    padding: 16px 0;
    font-size: 18px;
  }
}

.bl-blue {
  position: relative;
  padding: 80px 0 100px;
  text-align: center;
  width: calc(100vw - 15px);
  left: 50%;
  background: #EDFAFF;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bl-blue {
    padding: 5.71429vw 0 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .bl-blue {
    width: 100%;
    left: 0;
    background: transparent;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
    padding: 10.66667vw 0 13.33333vw;
  }
  .bl-blue::after {
    display: block;
    position: absolute;
    content: "";
    background: #EDFAFF;
    width: 2000px;
    height: 100%;
    top: 0;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%);
    left: 50%;
    z-index: -1;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bl-blue {
    padding: 40px 0 50px;
  }
}

.bl-blue__fff {
  margin: 0 auto;
  position: relative;
  z-index: 2;
  max-width: 1260px;
  width: 100%;
  text-align: left;
  background: #fff;
  padding: 70px 60px 80px;
  margin-bottom: 100px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .bl-blue__fff {
    width: 90%;
    padding: 5vw 4.28571vw 5.71429vw;
    margin-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .bl-blue__fff {
    max-width: 91.73333vw;
    padding: 8vw 5.33333vw 8vw;
    margin-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .bl-blue__fff {
    max-width: getPercent(384, 344, "width");
    padding: 30px 20px 30px;
    margin-bottom: 50px;
  }
}

.grid-columns {
  position: relative;
  display: grid;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .grid-columns.-columns-img {
    gap: 8vw 0;
  }
  .grid-columns.-columns-img img {
    display: block;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .grid-columns.-columns-img {
    gap: 30px 0;
  }
}
.grid-columns.-columns03 {
  grid-template-columns: repeat(auto-fit, 353px);
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-columns.-columns03 {
    grid-template-columns: repeat(auto-fit, 25.21429vw);
  }
}
@media screen and (max-width: 767px) {
  .grid-columns.-columns03 {
    grid-template-columns: 100%;
  }
}
.grid-columns.-columns02 {
  grid-template-columns: repeat(auto-fit, 540px);
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-columns.-columns02 {
    grid-template-columns: repeat(auto-fit, 37.14286vw);
  }
}
@media screen and (max-width: 767px) {
  .grid-columns.-columns02 {
    grid-template-columns: 100%;
  }
  .grid-columns.-columns02:has(.grid-arrow__left) {
    gap: 20vw 0;
  }
}
.grid-columns.-columns02__490-585 {
  grid-template-columns: 490px 585px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-columns.-columns02__490-585 {
    grid-template-columns: 35vw 41.78571vw;
  }
}
@media screen and (max-width: 767px) {
  .grid-columns.-columns02__490-585 {
    grid-template-columns: 100%;
  }
}
.grid-columns.-columns02__450 {
  width: 960px;
  grid-template-columns: 450px 450px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-columns.-columns02__450 {
    width: 68.57143vw;
    grid-template-columns: 32.14286vw 32.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .grid-columns.-columns02__450 {
    width: 100%;
    grid-template-columns: 100%;
  }
}

.grid-column {
  position: relative;
}
.grid-column .grid-arrow__left {
  position: absolute;
  top: 128px;
  right: -54px;
  width: 26px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .grid-column .grid-arrow__left {
    top: 9.14286vw;
    right: -3.85714vw;
    width: 1.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .grid-column .grid-arrow__left {
    top: auto;
    right: auto;
    left: 50%;
    width: 6.93333vw;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%);
    bottom: -8vw;
  }
}

.box-gradient {
  position: relative;
  padding: 40px 48px 50px;
  text-align: center;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .box-gradient {
    padding: 2.85714vw 3.42857vw 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .box-gradient {
    padding: 7.46667vw 5.33333vw 6.4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .box-gradient {
    padding: 28px 20px 24px;
  }
}
.box-gradient.-pad-s {
  padding: 35px 48px 35px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .box-gradient.-pad-s {
    padding: 2.5vw 3.42857vw 2.5vw;
  }
}
@media screen and (max-width: 767px) {
  .box-gradient.-pad-s {
    padding: 7.46667vw 0 6.4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .box-gradient.-pad-s {
    padding: 28px 0 24px;
  }
}
.box-gradient::after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: #74D9FF;
  background: linear-gradient(180deg, #74d9ff 0%, #3c9eff 100%);
  z-index: -1;
  opacity: 0.2;
}

.box-border {
  border: 1px solid #C8C8C8;
  padding: 24px 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .box-border {
    padding: 1.71429vw 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .box-border {
    padding: 4.8vw 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .box-border {
    padding: 18px 20px;
  }
}

.txt-round {
  font-size: 16px;
  line-height: 1;
  padding: 12px 0;
  color: #007AAA;
  font-weight: 500;
  background: #fff;
  display: inline-block;
  width: 160px;
  border-radius: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .txt-round {
    font-size: 1.14286vw;
    padding: 0.85714vw 0;
    width: 11.42857vw;
    border-radius: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .txt-round {
    font-size: 3.73333vw;
    padding: 2.13333vw 0;
    width: 32vw;
    border-radius: 4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .txt-round {
    font-size: 14px;
    padding: 8px 0;
    width: 120px;
    border-radius: 15px;
  }
}

.peke-list {
  position: relative;
  display: grid;
  justify-content: center;
  grid-template-columns: repeat(auto-fit, 160px);
  gap: 0 50px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .peke-list {
    grid-template-columns: repeat(auto-fit, 11.42857vw);
    gap: 0 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .peke-list {
    grid-template-columns: repeat(auto-fit, 32vw);
    gap: 0 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .peke-list {
    grid-template-columns: repeat(auto-fit, 120px);
    gap: 0 30px;
  }
}
.peke-list li {
  position: relative;
}
.peke-list li:last-child::after {
  display: none;
}
.peke-list li::after {
  content: '';
  display: block;
  position: absolute;
  width: 16px;
  height: 16px;
  right: -32px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/common/ico_peke_b.svg) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .peke-list li::after {
    width: 1.14286vw;
    height: 1.14286vw;
    right: -2.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .peke-list li::after {
    width: 3.2vw;
    height: 3.2vw;
    right: -5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .peke-list li::after {
    width: 12px;
    height: 12px;
    right: -20px;
  }
}

.robots-lists {
  position: relative;
  display: grid;
  justify-content: center;
  grid-template-columns: auto auto;
}
@media screen and (max-width: 767px) {
  .robots-lists {
    display: block;
  }
}
.robots-lists .robots-list:nth-of-type(1) {
  width: 147px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-lists .robots-list:nth-of-type(1) {
    width: 10.5vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-lists .robots-list:nth-of-type(1) {
    width: 100%;
  }
}
.robots-lists .robots-list:nth-of-type(1) .robots-list__ttl {
  background: #78B4E5;
}
.robots-lists .robots-list:nth-of-type(1) .robots-list__cons {
  background: #EDFAFF;
}
.robots-lists .robots-list:nth-of-type(1) .robots-list__con-ttl {
  position: relative;
  width: calc(100% + 18px);
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-lists .robots-list:nth-of-type(1) .robots-list__con-ttl {
    width: calc(100% + 18px);
  }
}
@media screen and (max-width: 767px) {
  .robots-lists .robots-list:nth-of-type(1) .robots-list__con-ttl {
    width: 100%;
  }
}
.robots-lists .robots-list:nth-of-type(2) {
  width: 993px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-lists .robots-list:nth-of-type(2) {
    width: 70.92857vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-lists .robots-list:nth-of-type(2) {
    width: 100%;
  }
}
.robots-lists .robots-list:nth-of-type(2) .robots-list__ttl {
  background: #92CBFA;
}
.robots-lists .robots-list:nth-of-type(2) .robots-list__cons {
  background: #F7FDFF;
}
@media screen and (max-width: 767px) {
  .robots-lists .robots-list:nth-of-type(2) .robots-list__cons {
    display: block;
    width: 100%;
    padding: 5.33333vw 5.33333vw 0.53333vw;
  }
}

.robots-list__cons {
  padding: 30px 18px 16px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-list__cons {
    padding: 2.14286vw 1.28571vw 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-list__cons {
    display: grid;
    justify-content: space-between;
    grid-template-columns: auto auto;
    padding: 5.33333vw 5.33333vw 5.33333vw;
  }
}
.robots-list__cons .robots-list__con {
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-list__cons .robots-list__con {
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-list__cons .robots-list__con {
    margin-bottom: 0;
  }
}
.robots-list__cons .robots-list__con:last-child {
  margin-bottom: 0;
}
.robots-list__cons .robots-list__con:has(.robots-list__con-grid) {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 0 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-list__cons .robots-list__con:has(.robots-list__con-grid) {
    gap: 0 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-list__cons .robots-list__con:has(.robots-list__con-grid) {
    display: block;
  }
}

.robots-list__con-min {
  display: block !important;
  width: auto !important;
}

.robots-list__ttl {
  font-size: 18px;
  line-height: 1.4;
  height: 70px;
  display: grid;
  width: 100%;
  place-content: center;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-list__ttl {
    font-size: 1.28571vw;
    height: 5vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-list__ttl {
    font-size: 4.26667vw;
    height: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .robots-list__ttl {
    font-size: 16px;
    height: 40px;
  }
}

.robots-list__con-ttl {
  font-size: 16px;
  padding-bottom: 10px;
  margin-bottom: 10px;
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-list__con-ttl {
    font-size: 1.14286vw;
    padding-bottom: 0.71429vw;
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-list__con-ttl {
    font-size: 3.73333vw;
    padding-bottom: 2.66667vw;
    margin-bottom: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .robots-list__con-ttl {
    font-size: 14px;
    padding-bottom: 10px;
    margin-bottom: 16px;
  }
}
.robots-list__con-ttl::after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 1px;
  background: #B0D6E3;
  bottom: 0;
  left: 0;
}
.robots-list__con-ttl span {
  display: block;
  position: relative;
  width: 180%;
  font-weight: 500;
}
.robots-list__con-ttl.-hack span {
  visibility: hidden;
}
@media screen and (max-width: 767px) {
  .robots-list__con-ttl.-hack span {
    visibility: visible;
  }
}
.robots-list__con-ttl.-hack::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 1px;
  background: #B0D6E3;
  bottom: 0;
  left: -18px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-list__con-ttl.-hack::before {
    left: -1.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-list__con-ttl.-hack::before {
    left: 0;
  }
}

.robots-list__items {
  display: flex;
  justify-content: flex-start;
  gap: 0 30px;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-list__items {
    gap: 0 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-list__items {
    justify-content: space-between;
    gap: 5.33333vw 0;
    margin-bottom: 0;
  }
}

@media screen and (max-width: 767px) {
  .robots-list .robots-list__con-grid {
    margin-bottom: 6.66667vw;
  }
}

.robots-list__item {
  width: 111px;
  min-height: 126px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-list__item {
    width: 7.92857vw;
    min-height: 9vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-list__item {
    width: 100%;
    width: 37.86667vw;
    min-height: auto;
  }
}
.robots-list__item .txt {
  position: relative;
  width: 110%;
  letter-spacing: -0.02em;
  line-height: 1.6;
}

.robots-list__item-img {
  margin-bottom: 8px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-list__item-img {
    margin-bottom: 0.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-list__item-img {
    margin-bottom: 2.13333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .robots-list__item-img {
    margin-bottom: 8px;
  }
}

.robots-list__item-label {
  position: relative;
  display: inline-block;
  font-size: 12px;
  background: #E2E3E5;
  padding: 4px 10px 4px;
  line-height: 1;
  margin-bottom: 6px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .robots-list__item-label {
    font-size: 0.85714vw;
    padding: 0.28571vw 0.71429vw 0.28571vw;
    margin-bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .robots-list__item-label {
    font-size: 3.2vw;
    padding: 1.33333vw 2.66667vw 1.33333vw;
    margin-bottom: 0.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .robots-list__item-label {
    font-size: 12px;
    padding: 5px 10px 5px;
    margin-bottom: 3px;
  }
}

body {
  color: #33393B;
}

@-webkit-keyframes scroll-line-out {
  0% {
    -webkit-transform: scaleY(1);
    -moz-transform: scaleY(1);
    -ms-transform: scaleY(1);
    -o-transform: scaleY(1);
    transform: scaleY(1);
  }
  20% {
    -webkit-transform: scaleY(1);
    -moz-transform: scaleY(1);
    -ms-transform: scaleY(1);
    -o-transform: scaleY(1);
    transform: scaleY(1);
  }
  60% {
    -webkit-transform: scaleY(0);
    -moz-transform: scaleY(0);
    -ms-transform: scaleY(0);
    -o-transform: scaleY(0);
    transform: scaleY(0);
  }
  100% {
    -webkit-transform: scaleY(0);
    -moz-transform: scaleY(0);
    -ms-transform: scaleY(0);
    -o-transform: scaleY(0);
    transform: scaleY(0);
  }
}
@keyframes scroll-line-out {
  0% {
    -webkit-transform: scaleY(1);
    -moz-transform: scaleY(1);
    -ms-transform: scaleY(1);
    -o-transform: scaleY(1);
    transform: scaleY(1);
  }
  20% {
    -webkit-transform: scaleY(1);
    -moz-transform: scaleY(1);
    -ms-transform: scaleY(1);
    -o-transform: scaleY(1);
    transform: scaleY(1);
  }
  60% {
    -webkit-transform: scaleY(0);
    -moz-transform: scaleY(0);
    -ms-transform: scaleY(0);
    -o-transform: scaleY(0);
    transform: scaleY(0);
  }
  100% {
    -webkit-transform: scaleY(0);
    -moz-transform: scaleY(0);
    -ms-transform: scaleY(0);
    -o-transform: scaleY(0);
    transform: scaleY(0);
  }
}
@-webkit-keyframes scroll-line-in {
  0% {
    -webkit-transform: scaleY(0);
    -moz-transform: scaleY(0);
    -ms-transform: scaleY(0);
    -o-transform: scaleY(0);
    transform: scaleY(0);
  }
  70% {
    -webkit-transform: scaleY(0);
    -moz-transform: scaleY(0);
    -ms-transform: scaleY(0);
    -o-transform: scaleY(0);
    transform: scaleY(0);
  }
  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
  }
}
@keyframes scroll-line-in {
  0% {
    -webkit-transform: scaleY(0);
    -moz-transform: scaleY(0);
    -ms-transform: scaleY(0);
    -o-transform: scaleY(0);
    transform: scaleY(0);
  }
  70% {
    -webkit-transform: scaleY(0);
    -moz-transform: scaleY(0);
    -ms-transform: scaleY(0);
    -o-transform: scaleY(0);
    transform: scaleY(0);
  }
  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
  }
}
.mv-sctoll {
  display: none;
}
@media screen and (max-width: 767px) {
  .mv-sctoll {
    display: block;
    position: absolute;
    right: 20px;
    bottom: 0;
    height: 96px;
    z-index: 5;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-sctoll {
    display: none;
  }
}

.mv-sctoll__txt {
  position: absolute;
  top: 0;
  left: -3px;
  width: 8px;
}

.mv-sctoll__line {
  position: absolute;
  width: 1px;
  height: 44px;
  bottom: 0;
}
.mv-sctoll__line::after {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
  background: #fff;
  -webkit-transform: scaleY(1);
  -moz-transform: scaleY(1);
  -ms-transform: scaleY(1);
  -o-transform: scaleY(1);
  transform: scaleY(1);
  z-index: 1;
  animation: scroll-line-out 1.4s forwards infinite ease-out;
}
.mv-sctoll__line::before {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  -webkit-transform-origin: 100% 0;
  transform-origin: 100% 0;
  background: #fff;
  -webkit-transform: scaleY(0);
  -moz-transform: scaleY(0);
  -ms-transform: scaleY(0);
  -o-transform: scaleY(0);
  transform: scaleY(0);
  z-index: 2;
  animation: scroll-line-in 1.4s forwards infinite ease-in;
}

/*********************************************
mv
*********************************************/
.index-mv {
  position: relative;
  z-index: 1;
}

@media screen and (min-width: 768px) {
  body.state-mv-hover-01 .mv-items .mv-item:nth-of-type(1) {
    width: 50%;
    -webkit-transition: width 0.3s ease-out;
    -moz-transition: width 0.3s ease-out;
    -ms-transition: width 0.3s ease-out;
    -o-transition: width 0.3s ease-out;
    transition: width 0.3s ease-out;
  }
  body.state-mv-hover-01 .mv-items .mv-item:nth-of-type(1) a::before {
    opacity: 0.64;
    -webkit-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -o-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    transition: transform 0.3s ease-out, opacity 0.3s ease-out;
  }
  body.state-mv-hover-01 .mv-items .mv-item:nth-of-type(2) {
    width: 25%;
    -webkit-transition: width 0.3s ease-out;
    -moz-transition: width 0.3s ease-out;
    -ms-transition: width 0.3s ease-out;
    -o-transition: width 0.3s ease-out;
    transition: width 0.3s ease-out;
  }
  body.state-mv-hover-01 .mv-items .mv-item:nth-of-type(3) {
    width: 25%;
    -webkit-transition: width 0.3s ease-out;
    -moz-transition: width 0.3s ease-out;
    -ms-transition: width 0.3s ease-out;
    -o-transition: width 0.3s ease-out;
    transition: width 0.3s ease-out;
  }

  body.state-mv-hover-02 .mv-items .mv-item:nth-of-type(2) {
    width: 50%;
  }
  body.state-mv-hover-02 .mv-items .mv-item:nth-of-type(2) a::before {
    opacity: 0.64;
    -webkit-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -o-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    transition: transform 0.3s ease-out, opacity 0.3s ease-out;
  }
  body.state-mv-hover-02 .mv-items .mv-item:nth-of-type(1) {
    width: 25%;
    -webkit-transition: width 0.3s ease-out;
    -moz-transition: width 0.3s ease-out;
    -ms-transition: width 0.3s ease-out;
    -o-transition: width 0.3s ease-out;
    transition: width 0.3s ease-out;
  }
  body.state-mv-hover-02 .mv-items .mv-item:nth-of-type(3) {
    width: 25%;
    -webkit-transition: width 0.3s ease-out;
    -moz-transition: width 0.3s ease-out;
    -ms-transition: width 0.3s ease-out;
    -o-transition: width 0.3s ease-out;
    transition: width 0.3s ease-out;
  }

  body.state-mv-hover-03 .mv-items .mv-item:nth-of-type(3) {
    width: 50%;
  }
  body.state-mv-hover-03 .mv-items .mv-item:nth-of-type(3) a::before {
    opacity: 0.64;
    -webkit-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    -o-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    transition: transform 0.3s ease-out, opacity 0.3s ease-out;
  }
  body.state-mv-hover-03 .mv-items .mv-item:nth-of-type(1) {
    width: 25%;
    -webkit-transition: width 0.3s ease-out;
    -moz-transition: width 0.3s ease-out;
    -ms-transition: width 0.3s ease-out;
    -o-transition: width 0.3s ease-out;
    transition: width 0.3s ease-out;
  }
  body.state-mv-hover-03 .mv-items .mv-item:nth-of-type(2) {
    width: 25%;
    -webkit-transition: width 0.3s ease-out;
    -moz-transition: width 0.3s ease-out;
    -ms-transition: width 0.3s ease-out;
    -o-transition: width 0.3s ease-out;
    transition: width 0.3s ease-out;
  }
}
.mv-items {
  display: table;
  width: 100%;
  margin: 0 auto;
  max-width: 1920px;
  background: #0077EF;
}
@media screen and (max-width: 767px) {
  .mv-items {
    display: block;
    height: 100vh;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-items {
    height: auto;
  }
}
.mv-items .mv-item {
  display: table-cell;
  width: 33.4%;
  -webkit-transition: width 0.3s ease-out;
  -moz-transition: width 0.3s ease-out;
  -ms-transition: width 0.3s ease-out;
  -o-transition: width 0.3s ease-out;
  transition: width 0.3s ease-out;
}
@media screen and (max-width: 767px) {
  .mv-items .mv-item {
    display: block;
    width: 100%;
  }
}
.mv-items .mv-item:last-child, .mv-items .mv-item:first-child {
  width: 33.3%;
}
@media screen and (max-width: 767px) {
  .mv-items .mv-item:last-child, .mv-items .mv-item:first-child {
    width: 100%;
  }
}
.mv-items .mv-item a {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  height: 900px;
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-items .mv-item a {
    height: 64.28571vw;
  }
}
.mv-items .mv-item a::after {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 2;
  background: #cfeffc;
  background: linear-gradient(315deg, #cfeffc 0%, #2398c5 100%);
  opacity: 0.9;
  mix-blend-mode: multiply;
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}
.mv-items .mv-item a::before {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 3;
  background: #71d8ff;
  background: linear-gradient(315deg, #71d8ff 0%, #0077ef 100%);
  opacity: 0.64;
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
  opacity: 0;
  -webkit-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
  -moz-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
  -ms-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
  -o-transition: transform 0.3s ease-out, opacity 0.3s ease-out;
  transition: transform 0.3s ease-out, opacity 0.3s ease-out;
}
@media screen and (max-width: 767px) {
  .mv-items .mv-item a::before {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .mv-items .mv-item {
    position: relative;
  }
  .mv-items .mv-item a {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
  }
  .mv-items .mv-item:nth-of-type(1) {
    height: 38vh;
  }
}
@media screen and (max-width: 767px) and (max-height: 700px) {
  .mv-items .mv-item:nth-of-type(1) {
    height: 41vh;
  }
}
@media screen and (max-width: 767px) {
  .mv-items .mv-item:nth-of-type(1) .mv-item__assets {
    position: relative;
    top: 10.66667vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .mv-items .mv-item:nth-of-type(1) .mv-item__assets {
    top: 40px;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .mv-items .mv-item:nth-of-type(1) {
    height: 298px;
  }
}
@media screen and (max-width: 767px) {
  .mv-items .mv-item:nth-of-type(1) .mv-item__cover::after {
    height: 66%;
    -webkit-transform: translateY(-29%);
    -moz-transform: translateY(-29%);
    -ms-transform: translateY(-29%);
    -o-transform: translateY(-29%);
    transform: translateY(-29%);
  }
  .mv-items .mv-item:nth-of-type(2) {
    height: 31vh;
  }
}
@media screen and (max-width: 767px) and (max-height: 700px) {
  .mv-items .mv-item:nth-of-type(2) {
    height: 29.5vh;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .mv-items .mv-item:nth-of-type(2) {
    height: 238px;
  }
}
@media screen and (max-width: 767px) {
  .mv-items .mv-item:nth-of-type(2) .mv-item__cover::after {
    height: 82%;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
  }
  .mv-items .mv-item:nth-of-type(3) {
    height: 31vh;
  }
}
@media screen and (max-width: 767px) and (max-height: 700px) {
  .mv-items .mv-item:nth-of-type(3) {
    height: 29.5vh;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .mv-items .mv-item:nth-of-type(3) {
    height: 238px;
  }
}
@media screen and (max-width: 767px) {
  .mv-items .mv-item:nth-of-type(3) .mv-item__cover::after {
    height: 82%;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
  }
}

.mv-item__cover {
  position: absolute;
  width: 90%;
  height: 100%;
  z-index: 4;
  left: 10px;
  max-width: 575px;
  min-width: 420px;
  mix-blend-mode: multiply;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-item__cover {
    max-width: 41.07143vw;
    min-width: 30vw;
    left: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-item__cover {
    width: 80%;
    min-width: auto;
    left: 1.33333vw;
  }
}
.mv-item__cover::after {
  display: block;
  position: absolute;
  content: '';
  width: 100%;
  height: 44.44%;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  background: #007AAA;
  opacity: 0.9;
  z-index: 2;
}

.mv-item__img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
}
.mv-item__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  object-fit: cover;
}

.mv-item__assets {
  position: relative;
  z-index: 5;
  color: #fff;
  padding-left: 50px;
  min-height: 294px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-item__assets {
    padding-left: 3.57143vw;
    min-height: 21vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-item__assets {
    min-height: auto;
    padding-left: 7.46667vw;
    padding-bottom: 6.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-item__assets {
    padding-left: 28px;
    padding-bottom: 26px;
  }
}
.mv-item__assets span.icon {
  left: 50px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-item__assets span.icon {
    left: 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-item__assets span.icon {
    left: 7.46667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-item__assets span.icon {
    left: 28px;
  }
}

.mv-item__ttl {
  margin-bottom: 32px;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-item__ttl {
    margin-bottom: 2.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-item__ttl {
    margin-bottom: 1.86667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-item__ttl {
    margin-bottom: 7px;
  }
}
.mv-item__ttl::after {
  content: '';
  display: block;
  position: absolute;
  width: 20px;
  height: 100%;
  top: 0;
  left: -50px;
  z-index: 2;
  background: #fff;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-item__ttl::after {
    width: 1.42857vw;
    left: -3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-item__ttl::after {
    width: 2.13333vw;
    left: -7.46667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-item__ttl::after {
    width: 8px;
    left: -28px;
  }
}
.mv-item__ttl span {
  display: block;
}
.mv-item__ttl span.-en {
  font-size: 16px;
  margin-bottom: 15px;
  font-family: "Manrope", sans-serif;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-item__ttl span.-en {
    font-size: 1.14286vw;
    margin-bottom: 1.07143vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-item__ttl span.-en {
    font-size: 2.66667vw;
    margin-bottom: 1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-item__ttl span.-en {
    font-size: 10px;
    margin-bottom: 5px;
  }
}
.mv-item__ttl span.-ja {
  position: relative;
  width: 120%;
  font-size: 30px;
  line-height: 1.4;
  font-weight: 700;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-item__ttl span.-ja {
    font-size: 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-item__ttl span.-ja {
    font-size: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-item__ttl span.-ja {
    font-size: 20px;
  }
}

.mv-item__txt {
  position: relative;
  z-index: 2;
  font-size: 18px;
  line-height: 1.8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-item__txt {
    font-size: 1.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-item__txt {
    font-size: 3.73333vw;
    line-height: 1.6;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-item__txt {
    font-size: 14px;
  }
}

/*********************************************
service
*********************************************/
.index-service {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-service {
    padding-top: 7.14286vw;
    padding-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .index-service {
    padding-top: 26.66667vw;
    padding-bottom: 26.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-service {
    padding-top: 100px;
    padding-bottom: 100px;
  }
}

/*********************************************
future
*********************************************/
.index-future {
  position: relative;
  width: 100%;
  height: 738px;
  background: url(../img/index/future_bg_pc.jpg) center center no-repeat;
  background-size: auto 100%;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  text-align: center;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-future {
    height: 52.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .index-future {
    background: url(../img/index/future_bg_sp.jpg) 0 0 no-repeat;
    background-size: 100% auto;
    height: 169.86667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-future {
    height: 637px;
  }
}

.item-cube {
  position: absolute;
  left: 50%;
  z-index: 10;
  pointer-events: none;
}
.item-cube.-index-future {
  top: -90px;
  margin-left: 570px;
  width: 129px;
  height: 165px;
  background: url(../img/common/cube_01.png) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .item-cube.-index-future {
    top: -6.42857vw;
    margin-left: 40.71429vw;
    width: 9.21429vw;
    height: 11.78571vw;
  }
}
@media screen and (max-width: 767px) {
  .item-cube.-index-future {
    display: none;
  }
}
.item-cube.-index-news {
  bottom: -70px;
  margin-left: -700px;
  width: 227px;
  height: 191px;
  background: url(../img/common/cube_02.png) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .item-cube.-index-news {
    bottom: -5vw;
    margin-left: -50vw;
    width: 16.21429vw;
    height: 13.64286vw;
  }
}
@media screen and (max-width: 767px) {
  .item-cube.-index-news {
    background: url(../img/common/cube_01.png) 0 0 no-repeat;
    background-size: 100% auto;
    top: -12vw;
    margin-left: 28.26667vw;
    width: 16.26667vw;
    height: 20.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .item-cube.-index-news {
    top: -45px;
    margin-left: 106px;
    width: 61px;
    height: 77px;
  }
}
.item-cube.-index-recruitment {
  display: none;
}
@media screen and (max-width: 767px) {
  .item-cube.-index-recruitment {
    display: block;
    background: url(../img/common/cube_02.png) 0 0 no-repeat;
    background-size: 100% auto;
    top: -2.13333vw;
    left: 0;
    margin-left: 0;
    width: 28.8vw;
    height: 24.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .item-cube.-index-recruitment {
    top: -8px;
    width: 108px;
    height: 92px;
  }
}
.item-cube.-index-other {
  bottom: -50px;
  margin-left: 450px;
  width: 129px;
  height: 165px;
  background: url(../img/common/cube_01.png) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .item-cube.-index-other {
    bottom: -3.57143vw;
    margin-left: 32.14286vw;
    width: 9.21429vw;
    height: 11.78571vw;
  }
}
@media screen and (max-width: 767px) {
  .item-cube.-index-other {
    bottom: -5.33333vw;
    margin-left: 28.26667vw;
    width: 16.26667vw;
    height: 20.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .item-cube.-index-other {
    bottom: -20px;
    margin-left: 106px;
    width: 61px;
    height: 77px;
  }
}

.index-future__ttl {
  position: relative;
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-future__ttl {
    margin-bottom: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .index-future__ttl {
    margin-bottom: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-future__ttl {
    margin-bottom: 40px;
  }
}
.index-future__ttl span {
  display: block;
}
.index-future__ttl span.-en {
  position: absolute;
  z-index: 1;
  width: 806px;
  left: 50%;
  top: -40px;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-future__ttl span.-en {
    width: 57.57143vw;
    top: -2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .index-future__ttl span.-en {
    width: 78.64583vw;
    top: -5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-future__ttl span.-en {
    width: 302px;
    top: -20px;
  }
}
.index-future__ttl span.-ja {
  position: relative;
  font-size: 40px;
  line-height: 1.8;
  z-index: 2;
  font-weight: 500;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-future__ttl span.-ja {
    font-size: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .index-future__ttl span.-ja {
    line-height: 1.5;
    font-size: 7.46667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-future__ttl span.-ja {
    font-size: 28px;
  }
}

.index-future__txt.-main {
  font-size: 24px;
  line-height: 1.8;
  letter-spacing: 0.1em;
  margin-bottom: 50px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-future__txt.-main {
    font-size: 1.71429vw;
    margin-bottom: 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .index-future__txt.-main {
    line-height: 1.4;
    font-size: 5.86667vw;
    margin-bottom: 6.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-future__txt.-main {
    font-size: 22px;
    margin-bottom: 26px;
  }
}
.index-future__txt.-main img {
  display: block;
  width: 44px;
  margin: 12px auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-future__txt.-main img {
    width: 3.14286vw;
    margin: 0.85714vw auto;
  }
}
@media screen and (max-width: 767px) {
  .index-future__txt.-main img {
    width: 8.53333vw;
    margin: 2.13333vw auto;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-future__txt.-main img {
    width: 32px;
    margin: 8px auto;
  }
}
.index-future__txt.-sub {
  font-size: 16px;
  line-height: 2.0;
  font-weight: 400;
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-future__txt.-sub {
    font-size: 1.14286vw;
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .index-future__txt.-sub {
    font-size: 4.26667vw;
    margin-bottom: 12.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-future__txt.-sub {
    font-size: 16px;
    margin-bottom: 36px;
  }
}

/*********************************************
achievements
*********************************************/
.index-achievements {
  padding-top: 160px;
  padding-bottom: 140px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-achievements {
    padding-top: 11.42857vw;
    padding-bottom: 10vw;
  }
}
@media screen and (max-width: 767px) {
  .index-achievements {
    padding-top: 26.66667vw;
    padding-bottom: 21.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-achievements {
    padding-top: 100px;
    padding-bottom: 80px;
  }
}

/*********************************************
information
*********************************************/
.index-news {
  padding-top: 100px;
  padding-bottom: 100px;
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-news {
    padding-top: 7.14286vw;
    padding-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .index-news {
    padding-top: 16vw;
    padding-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-news {
    padding-top: 60px;
    padding-bottom: 50px;
  }
}
.index-news::after {
  display: block;
  content: '';
  position: absolute;
  width: 1330px;
  height: 100%;
  background: #fff;
  z-index: 1;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
  margin-left: -35px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-news::after {
    width: 95%;
    margin-left: -2.5%;
  }
}
@media screen and (max-width: 767px) {
  .index-news::after {
    left: 0;
    margin-left: 0;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
    width: 94.79%;
  }
}

/*********************************************
recruitment
*********************************************/
.index-recruitment {
  position: relative;
  padding-top: 140px;
  padding-bottom: 214px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-recruitment {
    padding-top: 10vw;
    padding-bottom: 15.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .index-recruitment {
    padding-top: 16vw;
    padding-bottom: 16vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-recruitment {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

/*********************************************
other
*********************************************/
.index-other {
  padding-top: 76px;
  padding-bottom: 120px;
  position: relative;
}
.index-other::after {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 50%;
  background: #fff;
  width: 1350px;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
  margin-left: -20px;
  z-index: 1;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-other::after {
    width: 96.42%;
    margin-left: -1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .index-other::after {
    left: 0;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
    margin-left: 0;
    width: 94.79%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-other {
    padding-top: 5.42857vw;
    padding-bottom: 8.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .index-other {
    padding-top: 16vw;
    padding-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-other {
    padding-top: 60px;
    padding-bottom: 50px;
  }
}

/*********************************************
mv
*********************************************/
.mv {
  position: relative;
  width: 100%;
  max-width: 1920px;
  background: #007AAA;
  margin: 0 auto 100px;
  z-index: 1;
  padding-bottom: 25.72%;
}
@media only screen and (min-width: 1920px) {
  .mv {
    padding-bottom: 0;
    height: 494px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv {
    margin-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .mv {
    margin-bottom: 16vw;
    height: 68.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv {
    margin-bottom: 60px;
    height: 257px;
  }
}

.mv-img {
  position: relative;
  position: absolute;
  z-index: 1;
  max-width: 1920px;
  top: 0;
  width: 100%;
  height: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .mv-img {
    left: 0;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
  }
}
.mv-img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  object-fit: cover;
}

.mv-assets {
  position: absolute;
  max-width: 1140px;
  height: 100%;
  width: 81.42%;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  z-index: 2;
  color: #fff;
  top: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-assets {
    top: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-assets {
    width: 89.58333vw;
    left: 5.20833vw;
    top: 3.73333vw;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-assets {
    left: 20px;
    top: 14px;
  }
}

.mv-ttl span {
  display: block;
  letter-spacing: 0.07em;
}
.mv-ttl span.-en {
  font-family: "Manrope", sans-serif;
  font-size: 14px;
  margin-bottom: 6px;
  font-weight: 500;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-ttl span.-en {
    font-size: 1vw;
    margin-bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-ttl span.-en {
    font-size: 2.66667vw;
    margin-bottom: 1.6vw;
    line-height: 1.6;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-ttl span.-en {
    font-size: 10px;
    margin-bottom: 6px;
  }
}
.mv-ttl span.-ja {
  font-size: 32px;
  line-height: 1.4;
  font-weight: 500;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-ttl span.-ja {
    font-size: 2.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-ttl span.-ja {
    line-height: 1.4;
    font-size: 6.93333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-ttl span.-ja {
    font-size: 26px;
  }
}
.mv-ttl span.-ja span {
  display: inline;
}
@media screen and (max-width: 767px) {
  .mv-ttl span.-ja span {
    font-size: 5.86667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-ttl span.-ja span {
    font-size: 22px;
  }
}

.mv-txt {
  margin-top: 20px;
  font-size: 14px;
  line-height: 1.6;
  font-weight: 400;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-txt {
    margin-top: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-txt {
    margin-top: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-txt {
    margin-top: 12px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .mv-txt {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .mv-txt {
    line-height: 1.7;
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .mv-txt {
    font-size: 14px;
  }
}

/*********************************************
btm-contact
*********************************************/
.btm-contact {
  border-top: 1px solid #D9D8D8;
  padding-top: 94px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btm-contact {
    padding-top: 6.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .btm-contact {
    padding-top: 17.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btm-contact {
    padding-top: 65px;
  }
}

.btm-contact__items {
  max-width: 1400px;
  margin: 0 auto;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .btm-contact__items {
    display: block;
  }
}
.btm-contact__items .btm-contact__item {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .btm-contact__items .btm-contact__item {
    width: 100%;
  }
}
.btm-contact__items .btm-contact__item a {
  display: block;
  position: relative;
  padding-bottom: 41.43%;
  text-align: center;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .btm-contact__items .btm-contact__item a {
    padding-bottom: 67.71%;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btm-contact__items .btm-contact__item a {
    padding-bottom: 41.67%;
  }
}
.btm-contact__items .btm-contact__item a::after, .btm-contact__items .btm-contact__item a::before {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.btm-contact__items .btm-contact__item a::before {
  z-index: 1;
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
.btm-contact__items .btm-contact__item a::after {
  z-index: 2;
  background: #cfeffc;
  background: linear-gradient(18deg, #cfeffc 0%, #2398c5 100%);
  opacity: 0;
  -webkit-transition: opacity 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
  mix-blend-mode: multiply;
}
@media screen and (min-width: 1025px) {
  .btm-contact__items .btm-contact__item a:hover::after {
    opacity: 0.3;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
  .btm-contact__items .btm-contact__item a:hover::before {
    -webkit-transform: scale(1.1);
    -moz-transform: scale(1.1);
    -ms-transform: scale(1.1);
    -o-transform: scale(1.1);
    transform: scale(1.1);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
}
.btm-contact__items .btm-contact__item.-doc a::before {
  background: url(../img/common/contact_bg_doc_pc.jpg) 0 0 no-repeat;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .btm-contact__items .btm-contact__item.-doc a::before {
    background: url(../img/common/contact_bg_doc_sp.jpg) 0 0 no-repeat;
    background-size: cover;
  }
}
.btm-contact__items .btm-contact__item.-inq a::before {
  background: url(../img/common/contact_bg_inq_pc.jpg) 0 0 no-repeat;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .btm-contact__items .btm-contact__item.-inq a::before {
    background: url(../img/common/contact_bg_inq_sp.jpg) 0 0 no-repeat;
    background-size: cover;
  }
}

.btm-contact__assets {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: grid;
  place-content: center;
  place-items: center;
  z-index: 5;
}

.btm-contact__ttl {
  margin-bottom: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btm-contact__ttl {
    margin-bottom: 2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .btm-contact__ttl {
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btm-contact__ttl {
    margin-bottom: 30px;
  }
}
.btm-contact__ttl span {
  display: block;
  color: #1F2426;
}
.btm-contact__ttl span.-en {
  font-family: "Manrope", sans-serif;
  font-size: 36px;
  margin-bottom: 10px;
  font-weight: 500;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btm-contact__ttl span.-en {
    font-size: 2.57143vw;
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .btm-contact__ttl span.-en {
    font-size: 8vw;
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btm-contact__ttl span.-en {
    font-size: 30px;
    margin-bottom: 10px;
  }
}
.btm-contact__ttl span.-ja {
  letter-spacing: 0.07em;
  font-size: 16px;
  font-weight: 500;
  text-shadow: 1px 1px 0 #f2f2f2,-1px 1px 0 #f2f2f2,1px -1px 0 #f2f2f2,-1px -1px 0 #f2f2f2;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .btm-contact__ttl span.-ja {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .btm-contact__ttl span.-ja {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .btm-contact__ttl span.-ja {
    font-size: 14px;
  }
}

.article-ttl {
  margin-bottom: 50px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-ttl {
    margin-bottom: 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .article-ttl {
    margin-bottom: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-ttl {
    margin-bottom: 40px;
  }
}

.article-ttl + .article-body {
  padding-top: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-ttl + .article-body {
    padding-top: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .article-ttl + .article-body {
    padding-top: 4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-ttl + .article-body {
    padding-top: 15px;
  }
}

.article-ttl__label {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 26px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-ttl__label {
    font-size: 1.14286vw;
    margin-bottom: 1.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .article-ttl__label {
    font-size: 3.73333vw;
    margin-bottom: 6.4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-ttl__label {
    font-size: 14px;
    margin-bottom: 24px;
  }
}

.article-ttl__ttl {
  font-size: 36px;
  margin-bottom: 6px;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-ttl__ttl {
    font-size: 2.57143vw;
    margin-bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .article-ttl__ttl {
    line-height: 1.3;
    font-size: 7.46667vw;
    margin-bottom: 3.2vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .article-ttl__ttl {
    font-size: 28px;
    margin-bottom: 12px;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-ttl__ttl {
    line-height: 1.5;
    font-size: 6.4vw;
    margin-bottom: 0;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-ttl__ttl {
    font-size: 24px;
  }
}

.article-ttl__time-cat {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  -o-justify-content: flex-start;
  justify-content: flex-start;
  margin: 30px 0 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-ttl__time-cat {
    margin: 2.14286vw 0 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .article-ttl__time-cat {
    margin: 5.33333vw 0 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-ttl__time-cat {
    margin: 20px 0 30px;
  }
}

.article-ttl__time {
  width: 95px;
  text-align: left;
  font-size: 14px;
  color: #1F2426;
  font-family: "Manrope", sans-serif;
  line-height: 1.8;
  position: relative;
  top: 2px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-ttl__time {
    width: 6.78571vw;
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .article-ttl__time {
    width: 21.33333vw;
    font-size: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-ttl__time {
    width: 80px;
    font-size: 12px;
  }
}

.article-ttl__cat {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  width: 90px;
  height: 30px;
  text-align: center;
  font-size: 12px;
  font-weight: 400;
  background: #F1F4F7;
  line-height: 1.8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-ttl__cat {
    width: 7.89%;
    height: 2.14286vw;
    font-size: 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .article-ttl__cat {
    position: relative;
    top: 0.53333vw;
    width: 28.33%;
    height: 6.13333vw;
    font-size: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-ttl__cat {
    width: 68px;
    top: 2px;
    height: 23px;
    font-size: 12px;
  }
}

.article-ttl__comp {
  font-size: 18px;
  font-weight: 400;
  line-height: 1.4;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-ttl__comp {
    font-size: 1.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .article-ttl__comp {
    line-height: 1.6;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-ttl__comp {
    font-size: 16px;
  }
}

.article-txt__tr {
  font-size: 16px;
  font-weight: 400;
  line-height: 2.0;
  margin-bottom: 90px;
  text-align: right;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-txt__tr {
    font-size: 1.14286vw;
    margin-bottom: 6.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .article-txt__tr {
    line-height: 1.8;
    font-size: 3.73333vw;
    margin-bottom: 14.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-txt__tr {
    font-size: 14px;
    margin-bottom: 55px;
  }
}

.article-main {
  margin-bottom: 100px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-main {
    margin-bottom: 7.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .article-main {
    margin-bottom: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-main {
    margin-bottom: 40px;
  }
}

.article-main__img {
  max-width: 800px;
  width: 100%;
  margin: 0 auto 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-main__img {
    width: 70.17%;
    margin-bottom: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .article-main__img {
    width: 100%;
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-main__img {
    margin-bottom: 30px;
  }
}

.article-main__txt {
  max-width: 800px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-main__txt {
    width: 70.17%;
  }
}
@media screen and (max-width: 767px) {
  .article-main__txt {
    width: 100%;
  }
}
.article-main__txt p {
  font-size: 16px;
  line-height: 2.0;
  font-weight: 400;
  letter-spacing: 0.08em;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-main__txt p {
    font-size: 1.14286vw;
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .article-main__txt p {
    font-size: 4.26667vw;
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-main__txt p {
    font-size: 16px;
    margin-bottom: 20px;
  }
}
.article-main__txt p:last-child {
  margin-bottom: 0;
}

.article-img__main {
  width: 800px;
  max-width: 800px;
  width: 100%;
  margin: 0 auto 100px;
  margin: 0 auto 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-img__main {
    width: 70.17%;
    margin-bottom: 7.14286vw;
    margin-bottom: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .article-img__main {
    width: 100%;
    margin-bottom: 10.66667vw;
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-img__main {
    margin-bottom: 40px;
    margin-bottom: 30px;
  }
}

.page-news-article .article-body {
  font-size: 16px;
  line-height: 2.0;
  font-weight: 400;
  letter-spacing: 0.08em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body {
    line-height: 2.0;
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body {
    font-size: 16px;
  }
}
.page-news-article .article-body a {
  text-decoration: underline;
}
@media screen and (min-width: 1025px) {
  .page-news-article .article-body a:hover {
    text-decoration: none;
  }
}
.page-news-article .article-body section {
  margin-bottom: 90px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body section {
    margin-bottom: 6.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body section {
    margin-bottom: 14.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body section {
    margin-bottom: 55px;
  }
}
.page-news-article .article-body section:last-child {
  margin-bottom: 0;
}
.page-news-article .article-body section section {
  margin-bottom: 50px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body section section {
    margin-bottom: 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body section section {
    margin-bottom: 12vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body section section {
    margin-bottom: 45px;
  }
}
.page-news-article .article-body section section:last-child {
  margin-bottom: 0;
}
.page-news-article .article-body section section section {
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body section section section {
    margin-bottom: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body section section section {
    margin-bottom: 9.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body section section section {
    margin-bottom: 35px;
  }
}
.page-news-article .article-body section section section:last-child {
  margin-bottom: 0;
}
.page-news-article .article-body > h2 {
  font-weight: 500;
  font-size: 28px;
  margin-bottom: 40px;
  padding-bottom: 16px;
  position: relative;
  line-height: 1.6;
}
.page-news-article .article-body > h2::after {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 1px;
  bottom: 0;
  background: #C8C8C8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body > h2 {
    font-size: 2vw;
    margin-bottom: 2.85714vw;
    padding-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body > h2 {
    font-size: 4.8vw;
    margin-bottom: 8vw;
    padding-bottom: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body > h2 {
    font-size: 18px;
    margin-bottom: 30px;
    padding-bottom: 14px;
  }
}
.page-news-article .article-body > section h2, .page-news-article .article-body > section h3 {
  font-weight: 500;
  font-size: 28px;
  margin-bottom: 40px;
  padding-bottom: 16px;
  position: relative;
  line-height: 1.6;
}
.page-news-article .article-body > section h2::after, .page-news-article .article-body > section h3::after {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 1px;
  bottom: 0;
  background: #4fc8f5;
  background: linear-gradient(315deg, #4fc8f5 0%, #0077ef 100%);
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body > section h2, .page-news-article .article-body > section h3 {
    font-size: 2vw;
    margin-bottom: 2.85714vw;
    padding-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body > section h2, .page-news-article .article-body > section h3 {
    font-size: 5.86667vw;
    margin-bottom: 8vw;
    padding-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body > section h2, .page-news-article .article-body > section h3 {
    font-size: 22px;
    margin-bottom: 30px;
    padding-bottom: 10px;
  }
}
.page-news-article .article-body > section h3 {
  color: #1F2426;
}
.page-news-article .article-body > section section h3 {
  margin-bottom: 40px;
  font-size: 20px;
  padding-bottom: 0;
  color: #007AAA;
}
.page-news-article .article-body > section section h3::after {
  display: none;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body > section section h3 {
    font-size: 1.42857vw;
    padding-bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body > section section h3 {
    font-size: 4.8vw;
    margin-bottom: 8vw;
    padding-bottom: 0;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body > section section h3 {
    font-size: 18px;
    padding-bottom: 0;
  }
}
.page-news-article .article-body h2 + ul,
.page-news-article .article-body h2 + p,
.page-news-article .article-body h3 + ul,
.page-news-article .article-body h3 + p {
  padding-top: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body h2 + ul,
  .page-news-article .article-body h2 + p,
  .page-news-article .article-body h3 + ul,
  .page-news-article .article-body h3 + p {
    padding-top: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body h2 + ul,
  .page-news-article .article-body h2 + p,
  .page-news-article .article-body h3 + ul,
  .page-news-article .article-body h3 + p {
    padding-top: 0.71429vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body h2 + ul,
  .page-news-article .article-body h2 + p,
  .page-news-article .article-body h3 + ul,
  .page-news-article .article-body h3 + p {
    padding-top: 10px;
  }
}
.page-news-article .article-body p + section {
  padding-top: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body p + section {
    padding-top: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body p + section {
    padding-top: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body p + section {
    padding-top: 20px;
  }
}
.page-news-article .article-body > p + section {
  margin-top: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body > p + section {
    margin-top: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body > p + section {
    margin-top: 6.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body > p + section {
    margin-top: 25px;
  }
}
.page-news-article .article-body p + h2,
.page-news-article .article-body ul + h2 {
  padding-top: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body p + h2,
  .page-news-article .article-body ul + h2 {
    padding-top: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body p + h2,
  .page-news-article .article-body ul + h2 {
    padding-top: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body p + h2,
  .page-news-article .article-body ul + h2 {
    padding-top: 20px;
  }
}
.page-news-article .article-body h3 {
  font-weight: 500;
  color: #007AAA;
  font-size: 20px;
  margin-bottom: 12px;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body h3 {
    font-size: 1.42857vw;
    margin-bottom: 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body h3 {
    font-size: 4.8vw;
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body h3 {
    font-size: 18px;
    margin-bottom: 10px;
  }
}
.page-news-article .article-body h4 {
  font-weight: 500;
  font-size: 18px;
  margin-bottom: 10px;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body h4 {
    font-size: 1.28571vw;
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body h4 {
    font-size: 4.26667vw;
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body h4 {
    font-size: 16px;
    margin-bottom: 10px;
  }
}
.page-news-article .article-body h5 {
  font-weight: 500;
  font-size: 16px;
  margin-bottom: 10px;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body h5 {
    font-size: 1.14286vw;
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body h5 {
    font-size: 4.26667vw;
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body h5 {
    font-size: 16px;
    margin-bottom: 10px;
  }
}
.page-news-article .article-body h3 + .-ta-c img,
.page-news-article .article-body h4 + .-ta-c img,
.page-news-article .article-body h3 + img,
.page-news-article .article-body h4 + img,
.page-news-article .article-body p + img {
  padding-top: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body h3 + .-ta-c img,
  .page-news-article .article-body h4 + .-ta-c img,
  .page-news-article .article-body h3 + img,
  .page-news-article .article-body h4 + img,
  .page-news-article .article-body p + img {
    padding-top: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body h3 + .-ta-c img,
  .page-news-article .article-body h4 + .-ta-c img,
  .page-news-article .article-body h3 + img,
  .page-news-article .article-body h4 + img,
  .page-news-article .article-body p + img {
    padding-top: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body h3 + .-ta-c img,
  .page-news-article .article-body h4 + .-ta-c img,
  .page-news-article .article-body h3 + img,
  .page-news-article .article-body h4 + img,
  .page-news-article .article-body p + img {
    padding-top: 10px;
  }
}
.page-news-article .article-body p {
  margin-bottom: 22px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body p {
    margin-bottom: 1.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body p {
    margin-bottom: 5.86667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body p {
    margin-bottom: 22px;
  }
}
.page-news-article .article-body img {
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news-article .article-body img {
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news-article .article-body img {
    margin-bottom: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news-article .article-body img {
    margin-bottom: 40px;
  }
}
.page-case_study-article .article-body {
  margin-bottom: 90px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body {
    margin-bottom: 6.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body {
    margin-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body {
    margin-bottom: 50px;
  }
}
.page-case_study-article .article-body img {
  padding-top: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body img {
    padding-top: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body img {
    padding-top: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body img {
    padding-top: 10px;
  }
}
.page-case_study-article .article-body section {
  margin-bottom: 90px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body section {
    margin-bottom: 6.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body section {
    margin-bottom: 13.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body section {
    margin-bottom: 50px;
  }
}
.page-case_study-article .article-body section:last-child {
  margin-bottom: 0;
}
.page-case_study-article .article-body section section {
  margin-bottom: 50px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body section section {
    margin-bottom: 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body section section {
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body section section {
    margin-bottom: 30px;
  }
}
.page-case_study-article .article-body section section:last-child {
  margin-bottom: 0;
}
.page-case_study-article .article-body section .section-items .section-item {
  border-bottom: 1px solid #DDDDDD;
  padding-bottom: 50px;
  margin-bottom: 50px;
}
.page-case_study-article .article-body section .section-items .section-item p:last-child {
  margin-bottom: 0;
}
.page-case_study-article .article-body section .section-items .section-item ul:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body section .section-items .section-item {
    padding-bottom: 3.57143vw;
    margin-bottom: 3.57143vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body section .section-items .section-item {
    padding-bottom: 8vw;
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body section .section-items .section-item {
    padding-bottom: 30px;
    margin-bottom: 30px;
  }
}
.page-case_study-article .article-body section .section-items .section-item:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}
.page-case_study-article .article-body section .section-items .section-item .img-case_study {
  padding-bottom: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body section .section-items .section-item .img-case_study {
    padding-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body section .section-items .section-item .img-case_study {
    padding-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body section .section-items .section-item .img-case_study {
    padding-bottom: 10px;
  }
}
.page-case_study-article .article-body h2 {
  font-weight: 500;
  font-size: 28px;
  margin-bottom: 40px;
  padding-bottom: 16px;
  position: relative;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body h2 {
    font-size: 2vw;
    margin-bottom: 2.85714vw;
    padding-bottom: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body h2 {
    font-size: 5.86667vw;
    margin-bottom: 8vw;
    padding-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body h2 {
    font-size: 22px;
    margin-bottom: 30px;
    padding-bottom: 10px;
  }
}
.page-case_study-article .article-body h2::after {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 1px;
  bottom: 0;
  background: #4fc8f5;
  background: linear-gradient(315deg, #4fc8f5 0%, #0077ef 100%);
}
.page-case_study-article .article-body h2 + .section-items,
.page-case_study-article .article-body h2 + ul,
.page-case_study-article .article-body h2 + p {
  padding-top: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body h2 + .section-items,
  .page-case_study-article .article-body h2 + ul,
  .page-case_study-article .article-body h2 + p {
    padding-top: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body h2 + .section-items,
  .page-case_study-article .article-body h2 + ul,
  .page-case_study-article .article-body h2 + p {
    padding-top: 0.71429vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body h2 + .section-items,
  .page-case_study-article .article-body h2 + ul,
  .page-case_study-article .article-body h2 + p {
    padding-top: 10px;
  }
}
.page-case_study-article .article-body h3 {
  font-weight: 500;
  color: #007AAA;
  font-size: 20px;
  margin-bottom: 15px;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body h3 {
    font-size: 1.42857vw;
    margin-bottom: 1.07143vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body h3 {
    font-size: 4.8vw;
    margin-bottom: 4vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body h3 {
    font-size: 18px;
    margin-bottom: 15px;
  }
}
.page-case_study-article .article-body h4 {
  font-weight: 500;
  color: #007AAA;
  font-size: 16px;
  margin-bottom: 10px;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body h4 {
    font-size: 1.14286vw;
    margin-bottom: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body h4 {
    font-size: 3.73333vw;
    margin-bottom: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body h4 {
    font-size: 14px;
    margin-bottom: 10px;
  }
}
.page-case_study-article .article-body p {
  margin-bottom: 35px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body p {
    margin-bottom: 2.5vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body p {
    margin-bottom: 6.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body p {
    margin-bottom: 25px;
  }
}
.page-case_study-article .article-body p + .imgs-case_study,
.page-case_study-article .article-body p + .img-case_study,
.page-case_study-article .article-body p + img {
  margin-top: -5px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body p + .imgs-case_study,
  .page-case_study-article .article-body p + .img-case_study,
  .page-case_study-article .article-body p + img {
    margin-top: -0.35714vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body p + .imgs-case_study,
  .page-case_study-article .article-body p + .img-case_study,
  .page-case_study-article .article-body p + img {
    margin-top: 1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body p + .imgs-case_study,
  .page-case_study-article .article-body p + .img-case_study,
  .page-case_study-article .article-body p + img {
    margin-top: 5px;
  }
}
.page-case_study-article .article-body ul + .imgs-case_study,
.page-case_study-article .article-body ul + .img-case_study,
.page-case_study-article .article-body ul + img {
  margin-top: -30px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-case_study-article .article-body ul + .imgs-case_study,
  .page-case_study-article .article-body ul + .img-case_study,
  .page-case_study-article .article-body ul + img {
    margin-top: -2.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .page-case_study-article .article-body ul + .imgs-case_study,
  .page-case_study-article .article-body ul + .img-case_study,
  .page-case_study-article .article-body ul + img {
    margin-top: -1.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-case_study-article .article-body ul + .imgs-case_study,
  .page-case_study-article .article-body ul + .img-case_study,
  .page-case_study-article .article-body ul + img {
    margin-top: -5px;
  }
}
.article-body table + ol,
.article-body table + ul {
  margin-top: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-body table + ol,
  .article-body table + ul {
    margin-top: 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .article-body table + ol,
  .article-body table + ul {
    margin-top: 2.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-body table + ol,
  .article-body table + ul {
    margin-top: 10px;
  }
}
.article-body table td *:last-child {
  margin-bottom: 0 !important;
}
.article-body table td ul {
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-body table td ul {
    margin-bottom: 1.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .article-body table td ul {
    margin-bottom: 5.33333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-body table td ul {
    margin-bottom: 20px;
  }
}
.article-body table td ul li {
  margin-bottom: 0px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-body table td ul li {
    margin-bottom: 0vw;
  }
}
@media screen and (max-width: 767px) {
  .article-body table td ul li {
    margin-bottom: 0vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-body table td ul li {
    margin-bottom: 0px;
  }
}
.article-body table td ul li:last-child {
  margin-bottom: 0;
}
.article-body figure {
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-body figure {
    margin-bottom: 2.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .article-body figure {
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-body figure {
    margin-bottom: 30px;
  }
}
.article-body figure img {
  margin-bottom: 0;
}
.article-body figure figcaption {
  display: block;
  font-weight: 400;
  font-size: 12px;
  margin-top: 16px;
  text-align: left;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-body figure figcaption {
    font-size: 0.85714vw;
    margin-top: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .article-body figure figcaption {
    font-size: 3.2vw;
    margin-top: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-body figure figcaption {
    font-size: 12px;
    margin-top: 12px;
  }
}
.article-body p {
  font-size: 16px;
  font-weight: 400;
  line-height: 2.0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-body p {
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .article-body p {
    font-size: 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-body p {
    font-size: 16px;
  }
}
.article-body .-img {
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-body .-img {
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .article-body .-img {
    margin-bottom: 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-body .-img {
    margin-bottom: 40px;
  }
}
.article-body .-img img {
  width: auto;
  height: auto;
}
.article-body img {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
}
.article-body ul {
  margin-bottom: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-body ul {
    margin-bottom: 4.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .article-body ul {
    margin-bottom: 8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-body ul {
    margin-bottom: 30px;
  }
}
.article-body ul li {
  font-size: 16px;
  margin-bottom: 6px;
  font-weight: 400;
  line-height: 1.8;
  position: relative;
  padding-left: 1em;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .article-body ul li {
    font-size: 1.14286vw;
    margin-bottom: 0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .article-body ul li {
    font-size: 4.26667vw;
    margin-bottom: 1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .article-body ul li {
    font-size: 16px;
    margin-bottom: 6px;
  }
}
.article-body ul li:last-child {
  margin-bottom: 0;
}
.article-body ul li::after {
  position: absolute;
  display: block;
  content: '・';
  top: 0;
  left: 0;
}

.page-news .content-inner .section {
  margin-bottom: 80px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-news .content-inner .section {
    margin-bottom: 5.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .page-news .content-inner .section {
    margin-bottom: 16vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-news .content-inner .section {
    margin-bottom: 60px;
  }
}
.page-news .content-inner .section:last-child {
  margin-bottom: 0;
}

.page-link {
  width: 960px;
  margin: 0 auto 90px;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  gap: 20px 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-link {
    width: 84.21%;
    margin-bottom: 6.42857vw;
    gap: 1.42857vw 0;
  }
}
@media screen and (max-width: 767px) {
  .page-link {
    position: relative;
    width: 100%;
    gap: 5.33333vw 0;
    left: -3.73333vw;
    margin-bottom: 13.33333vw;
    -webkit-justify-content: flex-start;
    -moz-justify-content: flex-start;
    -ms-justify-content: flex-start;
    -o-justify-content: flex-start;
    justify-content: flex-start;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-link {
    gap: 20px 0;
    left: -14px;
    margin-bottom: 50px;
  }
}
.page-link.-column-04 li:nth-child(9n) {
  border-right: none;
}
@media screen and (max-width: 767px) {
  .page-link.-column-04 li:nth-child(9n) {
    border-right: 1px solid #C8C8C8;
  }
}
.page-link.-column-04 li:nth-child(4n) {
  border-right: none;
}
@media screen and (max-width: 767px) {
  .page-link.-column-04 li:nth-child(4n) {
    border-right: 1px solid #C8C8C8;
  }
}
.page-link li {
  border-right: 1px solid #C8C8C8;
  padding: 0 26px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-link li {
    padding: 0 1.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .page-link li {
    padding: 0 4.26667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-link li {
    padding: 0 16px;
  }
}
.page-link li:last-child {
  border-right: none;
}
@media screen and (max-width: 767px) {
  .page-link li:last-child {
    border-right: 1px solid #C8C8C8;
  }
}
.page-link li a {
  display: block;
  text-align: center;
  font-size: 14px;
  font-weight: 400;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .page-link li a {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .page-link li a {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .page-link li a {
    font-size: 14px;
  }
}
@media screen and (min-width: 1025px) {
  .page-link li a {
    -webkit-transition: opacity 0.2s ease-out, color 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out, color 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out, color 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out, color 0.2s ease-out;
    transition: opacity 0.2s ease-out, color 0.2s ease-out;
  }
  .page-link li a:hover {
    -webkit-transition: opacity 0.3s ease-out, color 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out, color 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out, color 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out, color 0.3s ease-out;
    transition: opacity 0.3s ease-out, color 0.3s ease-out;
    color: #00AEEF;
  }
}

.news-year__list {
  width: 1060px;
  margin: 0 auto 90px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
  gap: 18px 0;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .news-year__list {
    width: 92.98%;
    margin-bottom: 6.42857vw;
    gap: 1.28571vw 0;
  }
}
@media screen and (max-width: 767px) {
  .news-year__list {
    position: relative;
    width: 104%;
    left: -2%;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
    gap: 4.26667vw 0;
    margin-bottom: 16vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .news-year__list {
    gap: 16px 0;
    margin-bottom: 60px;
  }
}
.news-year__list li {
  border-right: 1px solid #C8C8C8;
}
.news-year__list li:nth-child(9n) {
  border-right: none;
}
@media screen and (max-width: 767px) {
  .news-year__list li:nth-child(9n) {
    border-right: 1px solid #C8C8C8;
  }
}
@media screen and (max-width: 767px) {
  .news-year__list li:nth-child(5n) {
    border-right: none;
  }
}
.news-year__list li a {
  display: block;
  text-align: center;
  font-size: 14px;
  font-weight: 400;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .news-year__list li a {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .news-year__list li a {
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .news-year__list li a {
    font-size: 14px;
  }
}
@media screen and (min-width: 1025px) {
  .news-year__list li a {
    -webkit-transition: opacity 0.2s ease-out, color 0.2s ease-out;
    -moz-transition: opacity 0.2s ease-out, color 0.2s ease-out;
    -ms-transition: opacity 0.2s ease-out, color 0.2s ease-out;
    -o-transition: opacity 0.2s ease-out, color 0.2s ease-out;
    transition: opacity 0.2s ease-out, color 0.2s ease-out;
  }
  .news-year__list li a:hover {
    -webkit-transition: opacity 0.3s ease-out, color 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out, color 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out, color 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out, color 0.3s ease-out;
    transition: opacity 0.3s ease-out, color 0.3s ease-out;
    color: #00AEEF;
  }
}

/*********************************************
news
*********************************************/
.news-items {
  position: relative;
  z-index: 5;
}
.index-news .news-items {
  margin: 0 auto 60px;
  border-top: 1px solid #D9D8D8;
  max-width: 1140px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-news .news-items {
    margin-bottom: 4.28571vw;
    width: 81.42%;
  }
}
@media screen and (max-width: 767px) {
  .index-news .news-items {
    width: 79.16667vw;
    margin: -2.66667vw auto 10.66667vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-news .news-items {
    margin: -10px auto 40px;
  }
}
.news-items li.-pdf_img .news-item__txt span {
  display: inline;
  position: relative;
  padding-right: 32px;
}
@media screen and (max-width: 767px) {
  .news-items li.-pdf_img .news-item__txt span {
    padding-right: 8.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .news-items li.-pdf_img .news-item__txt span {
    padding-right: 32px;
  }
}
.news-items li.-pdf_img .news-item__txt span img {
  content: '';
  display: block;
  position: absolute;
  right: 0;
  width: 25px;
  height: 13px;
  bottom: 4px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .news-items li.-pdf_img .news-item__txt span img {
    bottom: 0vw;
  }
}
@media screen and (max-width: 767px) {
  .news-items li.-pdf_img .news-item__txt span img {
    width: 6.66667vw;
    height: 3.46667vw;
    bottom: 0.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .news-items li.-pdf_img .news-item__txt span img {
    width: 25px;
    height: 13px;
    bottom: 3px;
  }
}
.news-items li.-pdf .news-item__txt span {
  display: inline;
  position: relative;
  padding-right: 32px;
}
@media screen and (max-width: 767px) {
  .news-items li.-pdf .news-item__txt span {
    padding-right: 8.53333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .news-items li.-pdf .news-item__txt span {
    padding-right: 32px;
  }
}
.news-items li.-pdf .news-item__txt span::after {
  content: '';
  display: block;
  position: absolute;
  right: 0;
  width: 25px;
  height: 13px;
  bottom: 4px;
  background: url(../img/common/ico_pdf_g.png) 0 0 no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .news-items li.-pdf .news-item__txt span::after {
    bottom: 0.28571vw;
  }
}
@media screen and (max-width: 767px) {
  .news-items li.-pdf .news-item__txt span::after {
    width: 6.66667vw;
    height: 3.46667vw;
    bottom: 0.8vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .news-items li.-pdf .news-item__txt span::after {
    width: 25px;
    height: 13px;
    bottom: 3px;
  }
}
.news-items li div,
.news-items li a {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  -o-justify-content: flex-start;
  justify-content: flex-start;
  border-bottom: 1px solid #D9D8D8;
  position: relative;
  -webkit-transition: opacity 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
  padding: 30px 20px 30px 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .news-items li div,
  .news-items li a {
    padding: 2.14286vw 1.42857vw 2.14286vw 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .news-items li div,
  .news-items li a {
    padding: 5.33333vw 3.73333vw 4.26667vw 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .news-items li div,
  .news-items li a {
    padding: 20px 14px 16px 14px;
  }
}
.news-items li div::before,
.news-items li a::before {
  display: block;
  content: '';
  position: absolute;
  width: 100%;
  height: 1px;
  background: #00AEEF;
  left: 0;
  bottom: 0;
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
  -webkit-transform: scaleX(0);
  -moz-transform: scaleX(0);
  -ms-transform: scaleX(0);
  -o-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
.index-news .news-items li div, .index-news
.news-items li a {
  padding: 30px 50px 30px 10px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-news .news-items li div, .index-news
  .news-items li a {
    padding: 2.14286vw 3.57143vw 2.14286vw 0.71429vw;
  }
}
@media screen and (max-width: 767px) {
  .index-news .news-items li div, .index-news
  .news-items li a {
    padding: 5.33333vw 12.26667vw 4.26667vw 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-news .news-items li div, .index-news
  .news-items li a {
    padding: 20px 46px 16px 14px;
  }
}
.index-news .news-items li div::after, .index-news
.news-items li a::after {
  display: block;
  content: '';
  position: absolute;
  width: 6px;
  height: 12px;
  background: url(../img/common/ico_arrow_707070.svg) 0 center no-repeat;
  background-size: 100% auto;
  right: 40px;
  top: 50%;
  margin-top: -6px;
  -webkit-transition: transform 0.2s ease-out;
  -moz-transition: transform 0.2s ease-out;
  -ms-transition: transform 0.2s ease-out;
  -o-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .index-news .news-items li div::after, .index-news
  .news-items li a::after {
    width: 0.42857vw;
    height: 0.85714vw;
    right: 2.85714vw;
    margin-top: -0.42857vw;
  }
}
@media screen and (max-width: 767px) {
  .index-news .news-items li div::after, .index-news
  .news-items li a::after {
    width: 1.6vw;
    height: 3.2vw;
    right: 5.33333vw;
    margin-top: -1.6vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .index-news .news-items li div::after, .index-news
  .news-items li a::after {
    width: 6px;
    height: 12px;
    right: 20px;
    margin-top: -6px;
  }
}
@media screen and (min-width: 1025px) {
  .news-items li a:hover {
    opacity: 0.7;
    -webkit-transition: opacity 0.3s ease-out;
    -moz-transition: opacity 0.3s ease-out;
    -ms-transition: opacity 0.3s ease-out;
    -o-transition: opacity 0.3s ease-out;
    transition: opacity 0.3s ease-out;
  }
  .news-items li a:hover::after {
    -webkit-transform: translateX(8px);
    -moz-transform: translateX(8px);
    -ms-transform: translateX(8px);
    -o-transform: translateX(8px);
    transform: translateX(8px);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
  .news-items li a:hover::before {
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1);
  }
}

.news-item__time {
  width: 150px;
  text-align: center;
  font-size: 16px;
  color: #1F2426;
  font-family: "Manrope", sans-serif;
  line-height: 1.8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .news-item__time {
    width: 13.15%;
    font-size: 1.14286vw;
  }
}
@media screen and (max-width: 767px) {
  .news-item__time {
    text-align: left;
    width: 32.5%;
    font-size: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .news-item__time {
    width: 78px;
    font-size: 12px;
  }
}

.news-item__cat {
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  width: 90px;
  height: 30px;
  text-align: center;
  font-size: 12px;
  font-weight: 400;
  background: #F1F4F7;
  line-height: 1.8;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .news-item__cat {
    width: 7.89%;
    height: 2.14286vw;
    font-size: 0.85714vw;
  }
}
@media screen and (max-width: 767px) {
  .news-item__cat {
    position: relative;
    top: -1px;
    width: 28.33%;
    height: 6.13333vw;
    font-size: 3.2vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .news-item__cat {
    width: 68px;
    height: 23px;
    font-size: 12px;
  }
}

.news-item__txt {
  width: 860px;
  padding-left: 30px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.8;
}
.index-news .news-item__txt {
  width: 760px;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .news-item__txt {
    width: 72.8%;
    padding-left: 2.14286vw;
    font-size: 1.14286vw;
  }
  .index-news .news-item__txt {
    width: 66.66%;
  }
}
@media screen and (max-width: 767px) {
  .news-item__txt {
    margin-top: 2.66667vw;
    padding-left: 0;
    font-size: 3.73333vw;
  }
}
@media (orientation: landscape) and (max-width: 767px) {
  .news-item__txt {
    margin-top: 10px;
    font-size: 14px;
  }
}

/* aside */
.news-years__select {
  display: none;
}
@media screen and (max-width: 767px) {
  .news-years__select {
    display: block;
    position: relative;
    top: -5.33333vw;
    height: 6.93333vw;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .news-years__select {
    top: -20px;
    height: 26px;
  }
}
@media screen and (max-width: 767px) {
  .news-years__select select {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 1;
    background: #fff;
    border-bottom: 1px solid #C8C8C8;
    text-align: center;
    font-size: 3.73333vw;
    font-weight: 700;
    opacity: 0;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .news-years__select select {
    font-size: 14px;
  }
}
@media screen and (max-width: 767px) {
  .news-years__select label {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 2;
    background: transparent;
    border-bottom: 1px solid #C8C8C8;
    text-align: left;
    font-size: 3.73333vw;
    padding-top: 0vw;
    padding-left: 0.53333vw;
    font-weight: 400;
    pointer-events: none;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .news-years__select label {
    font-size: 14px;
    padding-top: 0px;
    padding-left: 2px;
  }
}
@media screen and (max-width: 767px) {
  .news-years__select span.icon {
    position: absolute;
    width: 2.13333vw;
    height: 1.6vw;
    top: 50%;
    margin-top: -2.13333vw;
    right: 2.66667vw;
    display: block;
    background: url(../img/common/ico_pulldown_year.png) 0 0 no-repeat;
    background-size: 100% auto;
    pointer-events: none;
    z-index: 3;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) and (max-width: 767px) {
  .news-years__select span.icon {
    width: 8px;
    height: 6px;
    margin-top: -8px;
    right: 10px;
  }
}
@media screen and (max-width: 767px) and (min-width: 768px) and (max-width: 1400px) {
  .news-years__select {
    display: none;
  }
}

.news-years__list {
  border-top: 1px solid #00AEEF;
  border-left: 1px solid #00AEEF;
}
@media screen and (max-width: 767px) {
  .news-years__list {
    display: none;
  }
}
.news-years__list li {
  border-bottom: 1px solid #00AEEF;
  border-right: 1px solid #00AEEF;
}
.news-years__list li a {
  display: block;
  font-size: 14px;
  padding: 12px 50px 12px 24px;
  color: #007AAA;
  font-weight: 400;
  overflow: hidden;
  position: relative;
  position: relative;
}
.news-years__list li a::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #eaf9ff;
  z-index: 2;
  -webkit-transform: translateX(-100%);
  -moz-transform: translateX(-100%);
  -ms-transform: translateX(-100%);
  -o-transform: translateX(-100%);
  transform: translateX(-100%);
  -webkit-transition: transform 0.2s 0s ease-out;
  -moz-transition: transform 0.2s 0s ease-out;
  -ms-transition: transform 0.2s 0s ease-out;
  -o-transition: transform 0.2s 0s ease-out;
  transition: transform 0.2s 0s ease-out;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .news-years__list li a {
    font-size: 1vw;
    padding: 0.85714vw 3.57143vw 0.85714vw 1.71429vw;
  }
}
.news-years__list li a span.btn-txt {
  position: relative;
  z-index: 2;
  -webkit-transition: opacity 0.2s ease-out;
  -moz-transition: opacity 0.2s ease-out;
  -ms-transition: opacity 0.2s ease-out;
  -o-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
}
@media screen and (min-width: 1025px) {
  .news-years__list li a:hover::before {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
    -webkit-transition: transform 0.3s ease-out;
    -moz-transition: transform 0.3s ease-out;
    -ms-transition: transform 0.3s ease-out;
    -o-transition: transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
}
