@charset "UTF-8";
@-webkit-keyframes scrolldown {
  0% {
    -webkit-transform: translateY(-12px);
    transform: translateY(-12px);
  }
  100% {
    -webkit-transform: translateY(76px);
    transform: translateY(76px);
  }
}
@keyframes scrolldown {
  0% {
    -webkit-transform: translateY(-12px);
    transform: translateY(-12px);
  }
  100% {
    -webkit-transform: translateY(76px);
    transform: translateY(76px);
  }
}
@-webkit-keyframes moveRight1 {
  0% {
    -webkit-transform: translateX(0) scale(1.2);
    transform: translateX(0) scale(1.2);
  }
  100% {
    -webkit-transform: translateX(70px) scale(1.2);
    transform: translateX(70px) scale(1.2);
  }
}
@keyframes moveRight1 {
  0% {
    -webkit-transform: translateX(0) scale(1.2);
    transform: translateX(0) scale(1.2);
  }
  100% {
    -webkit-transform: translateX(70px) scale(1.2);
    transform: translateX(70px) scale(1.2);
  }
}
@-webkit-keyframes moveRight2 {
  0% {
    -webkit-transform: translateX(0) scale(1.2);
    transform: translateX(0) scale(1.2);
  }
  100% {
    -webkit-transform: translateX(30px) scale(1.2);
    transform: translateX(30px) scale(1.2);
  }
}
@keyframes moveRight2 {
  0% {
    -webkit-transform: translateX(0) scale(1.2);
    transform: translateX(0) scale(1.2);
  }
  100% {
    -webkit-transform: translateX(30px) scale(1.2);
    transform: translateX(30px) scale(1.2);
  }
}
/*------------------------------------------------------------
    Reset
------------------------------------------------------------*/
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
dialog,
figure,
footer,
header,
nav,
section,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
  display: block;
}
html {
  font-size: 62.5%;
}
body,
table,
input,
textarea,
select,
option,
h1,
h2,
h3,
h4,
h5,
h6 {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
input,
textarea {
  font-family: "Noto Sans JP", "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: bold;
}
table,
input,
textarea,
select,
option {
  line-height: 1.1;
}
select {
  cursor: pointer;
  font-family: "Noto Sans JP", "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
input,
textarea {
  font-family: "Noto Sans JP", "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
ol,
ul {
  list-style: none;
}
blockquote,
q {
  quotes: none;
}
:focus {
  outline: 0;
}
ins {
  text-decoration: none;
}
del {
  text-decoration: line-through;
}
img {
  vertical-align: top;
}
a,
a img {
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
a {
  color: inherit;
  text-decoration: none;
}
@media only screen and (min-width: 1023px) {
  a:hover, a:hover img {
    opacity: 0.7;
    filter: alpha(opacity=70);
  }
}
button {
  cursor: pointer;
  font-family: "Noto Sans JP", "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  border: none;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
@media only screen and (min-width: 1023px) {
  button:hover {
    opacity: 0.7;
    filter: alpha(opacity=70);
  }
}
img {
  max-width: 100%;
}
/*≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡
// Layout .l-
≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡*/
/*------------------------------------------------------------
    Navigation
------------------------------------------------------------*/
.c-nav1__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.c-nav1__item {
  position: relative;
}
.c-nav1__item + .c-nav1__item {
  margin-left: 24px;
}
.c-nav1__link {
  display: inline-block;
  position: relative;
  color: #003673;
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: -0.02em;
  text-align: center;
}
.c-nav2__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.c-nav2__item {
  width: 100%;
}
.c-nav2__item + .c-nav2__item {
  margin-top: 4px;
}
.c-nav2__link {
  display: block;
  position: relative;
  width: 100%;
  min-height: 56px;
  padding: 14px 32px 13px 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
.c-nav2__link::after {
  content: "\e900";
  position: absolute;
  top: 50%;
  right: 13px;
  -webkit-transform: translateY(calc(-50% + 1px));
  transform: translateY(calc(-50% + 1px));
  color: #fff;
  font-family: "icomoon";
  font-size: 0.85rem;
  font-weight: 400;
  line-height: 1;
}
.c-nav2__link--simple,
span.c-nav2__link {
  padding-right: 0;
}
.c-nav2__link--simple::after,
span.c-nav2__link::after {
  content: none;
}
.c-nav2__sub {
  margin-top: 4px;
}
.c-nav2__sublist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.c-nav2__subitem {
  width: 100%;
}
.c-nav2__subitem + .c-nav2__subitem {
  margin-top: 4px;
}
.c-nav2__sublink {
  display: block;
  position: relative;
  width: 100%;
  min-height: 56px;
  padding: 14px 32px 13px 16px;
  background-color: #0058bd;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
.c-nav2__sublink::after {
  content: "\e900";
  position: absolute;
  top: 50%;
  right: 13px;
  -webkit-transform: translateY(calc(-50% + 1px));
  transform: translateY(calc(-50% + 1px));
  color: #fff;
  font-family: "icomoon";
  font-size: 0.85rem;
  font-weight: 400;
  line-height: 1;
}
.c-nav3__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}
.c-nav3__item {
  position: relative;
  width: 100%;
  border-bottom: 1px solid #e4e9f0;
}
.c-nav3__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 24px 0;
}
@media only screen and (min-width: 1023px) {
  .c-nav3__link:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
  .c-nav3__link:hover .c-arrow1 {
    background-color: #0a62c7;
  }
  .c-nav3__link:hover .c-arrow1 .c-arrow1__icon::before {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  .c-nav3__link:hover .c-arrow1 .c-arrow1__icon::after {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
  }
}
@media only screen and (max-width: 767px) {
  .c-nav3__link {
    padding: 16px 0;
  }
}
.c-nav3__text {
  -webkit-transform: translateY(-1px);
  transform: translateY(-1px);
  color: #0a62c7;
  font-size: 1.9rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-nav3__arrow {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  margin-left: 12px;
}
/*------------------------------------------------------------
    Header
------------------------------------------------------------*/
.c-header {
  position: relative;
}
.c-header__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 104px;
  padding: 24px;
  background-color: transparent;
  backdrop-filter: none;
  z-index: 12;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media only screen and (max-width: 767px) {
  .c-header__inner {
    min-height: 68px;
    padding: 16px 92px 16px 16px;
  }
}
.c-header__inner.is-sticky {
  background-color: rgba(245, 246, 247, 0);
  backdrop-filter: blur(10px) brightness(98%);
}
@media only screen and (max-width: 767px) {
  .c-header__inner.is-sticky {
    background-color: #fff;
    backdrop-filter: none;
  }
}
.c-header__inner.is-sticky .c-header__nav::before {
  opacity: 0;
}
.c-header__logowrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.c-header__logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.c-header__logo img {
  display: inline-block;
}
.c-header__logo img:nth-child(1) {
  width: 61px;
}
@media only screen and (max-width: 767px) {
  .c-header__logo img:nth-child(1) {
    width: 55px;
  }
}
@media only screen and (max-width: 374px) {
  .c-header__logo img:nth-child(1) {
    width: 45px;
  }
}
.c-header__logo img:nth-child(2) {
  width: 188px;
  margin-left: 16px;
}
@media only screen and (max-width: 767px) {
  .c-header__logo img:nth-child(2) {
    width: 169px;
    margin-left: 12px;
  }
}
@media only screen and (max-width: 374px) {
  .c-header__logo img:nth-child(2) {
    width: 136px;
    margin-left: 10px;
  }
}
.c-header__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  padding: 12px 76px 12px 12px;
  border-radius: 28px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  .c-header__nav {
    padding: 0;
    background-color: transparent;
    backdrop-filter: none;
  }
}
.c-header__nav::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(245, 246, 247, 0);
  backdrop-filter: blur(10px) brightness(98%);
  border-radius: 28px;
  opacity: 1;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media only screen and (max-width: 767px) {
  .c-header__nav::before {
    content: none;
  }
}
.c-header__nav .c-nav1 {
  -webkit-transform: translateY(-1px);
  transform: translateY(-1px);
  margin-left: 17px;
  margin-right: 29px;
}
.c-header__groupbtn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.c-header__menubtn {
  position: fixed;
  top: 36px;
  right: 36px;
  z-index: 20;
}
@media only screen and (max-width: 767px) {
  .c-header__menubtn {
    top: 20px;
    right: 15px;
  }
}
.c-header__menuouter {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 15;
  -webkit-transition: all 0.45s ease-in-out;
  transition: all 0.45s ease-in-out;
}
.c-header__menuouter.is-show {
  opacity: 1;
  visibility: visible;
  pointer-events: unset;
}
.c-header__menu {
  position: relative;
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 1023px) {
  .c-header__menu {
    background-color: #0a62c7;
  }
}
.c-header__menu::after {
  content: none;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 50%;
  background-color: #fff;
}
@media only screen and (max-width: 1023px) {
  .c-header__menu::after {
    content: "";
  }
}
.c-header__menuwrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}
@media only screen and (max-width: 1023px) {
  .c-header__menuwrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    overflow-x: hidden;
    overflow-y: auto;
  }
}
.c-header__menuleft {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  position: relative;
  width: 33.3333333333%;
  min-width: 400px;
  background-color: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(8px) brightness(105%);
}
@media only screen and (max-width: 1023px) {
  .c-header__menuleft {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-negative: unset;
    flex-shrink: unset;
    width: 100%;
    height: 100%;
    min-width: unset;
    background-color: #fff;
    backdrop-filter: none;
  }
}
.c-header__menuleftinner {
  width: 100%;
  max-width: 400px;
  margin: 0 auto;
  padding: 104px 40px;
}
@media only screen and (max-width: 1023px) {
  .c-header__menuleftinner {
    max-width: 480px;
    padding: 56px 80px 120px;
  }
}
@media only screen and (max-width: 767px) {
  .c-header__menuleftinner {
    max-width: 352px;
    padding: 56px 16px 120px;
  }
}
.c-header__menuheading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.c-header__menulogo {
  display: inline-block;
}
.c-header__menulogo img {
  width: 226px;
}
.c-header__menuaddress {
  margin-top: 16px;
  color: #0a62c7;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: -0.02em;
  text-align: center;
}
.c-header__menugroupbtn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 40px;
}
.c-header__linklist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 20px -24px -12px 0;
}
.c-header__linkitem {
  margin: 0 24px 12px 0;
}
.c-header__link {
  display: inline-block;
  color: #6f8194;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.538;
  letter-spacing: -0.02em;
}
.c-header__menuright {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  width: 66.6666666667%;
  background-color: #0a62c7;
}
@media only screen and (max-width: 1023px) {
  .c-header__menuright {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-flex: unset;
    -ms-flex-positive: unset;
    flex-grow: unset;
    width: 100%;
  }
}
.c-header__menurightinner {
  width: 100%;
  max-width: 720px;
  max-height: 100%;
  margin: 0 auto;
  padding: 104px 40px;
}
@media only screen and (max-width: 1023px) {
  .c-header__menurightinner {
    max-width: unset;
    max-height: unset;
    padding: 96px 80px;
  }
}
@media only screen and (max-width: 767px) {
  .c-header__menurightinner {
    padding: 80px 20px;
  }
}
.c-header__menunav {
  position: relative;
  max-height: 100%;
  padding-right: 20px;
  overflow-x: hidden;
  overflow-y: auto;
}
@media only screen and (min-width: 1023px) {
  .c-header__menunav::-webkit-scrollbar-track {
    background-color: #0058bd;
  }
  .c-header__menunav::-webkit-scrollbar {
    width: 4px;
    background-color: #0058bd;
  }
  .c-header__menunav::-webkit-scrollbar-thumb {
    background-color: #00c5cc;
  }
}
@media only screen and (max-width: 1023px) {
  .c-header__menunav {
    padding-right: 0;
  }
}
/*------------------------------------------------------------
    Footer
------------------------------------------------------------*/
@media only screen and (max-width: 1023px) {
  .c-footer__top {
    padding: 0 40px;
  }
}
@media only screen and (max-width: 767px) {
  .c-footer__top {
    padding: 0 16px;
  }
}
.c-footer__bottom {
  position: relative;
  padding: 64px 0 16px;
  overflow: hidden;
}
.c-footer__heading {
  margin: 6px 0 5px;
}
@media only screen and (max-width: 767px) {
  .c-footer__title .c-title1__en {
    margin-top: -7px;
    font-size: 7.1rem;
  }
}
@media only screen and (max-width: 374px) {
  .c-footer__title .c-title1__en {
    margin-top: -5px;
    font-size: 5.8rem;
  }
}
.c-footer__description {
  margin-top: 9px;
}
@media only screen and (max-width: 767px) {
  .c-footer__description {
    margin-top: 22px;
  }
}
.c-footer__logowrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}
.c-footer__logo {
  display: inline-block;
}
.c-footer__logo img {
  width: 265px;
}
.c-footer__address {
  margin-top: 8px;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-footer__linklist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  margin: 20px -24px -12px 0;
}
.c-footer__linkitem {
  margin: 0 24px 12px 0;
}
.c-footer__link {
  display: inline-block;
  color: #6f8194;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.538;
  letter-spacing: -0.02em;
}
.c-footer__copyright {
  margin-top: 63px;
  color: #6f8194;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
/*------------------------------------------------------------
    Layout
------------------------------------------------------------*/
body {
  position: relative;
  font-family: "Noto Sans JP", "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  word-break: break-word;
  scroll-behavior: smooth;
}
@media only screen and (max-width: 767px) {
  body {
    min-width: 320px;
  }
}
/*------------------------------------------------------------
    Container
------------------------------------------------------------*/
.l-container {
  width: 100%;
  max-width: 1360px;
  margin: 0 auto;
  padding: 0 40px;
}
@media only screen and (max-width: 767px) {
  .l-container {
    padding: 0 16px;
  }
}
.l-content--w1440 {
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
}
.l-content--w1360 {
  width: 100%;
  max-width: 1360px;
  margin: 0 auto;
}
.l-content--w720 {
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
}
@media only screen and (max-width: 767px) {
  .l-content--w720 {
    max-width: unset;
  }
}
/*------------------------------------------------------------
    Mainvisual
------------------------------------------------------------*/
.c-mv {
  position: relative;
  width: 100%;
  height: 100vh;
  padding-bottom: 60px;
  overflow: hidden;
}
.c-mv__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  position: relative;
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 1023px) {
  .c-mv__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.c-mv__left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 41.6666666667%;
  min-width: 580px;
  padding: 104px 35px 69px 47px;
}
@media only screen and (max-width: 1023px) {
  .c-mv__left {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    width: 100%;
    min-width: unset;
    padding: 39px 48px 63px;
  }
}
@media only screen and (max-width: 767px) {
  .c-mv__left {
    padding: 20px 16px 73px;
  }
}
.c-mv__content {
  position: relative;
  z-index: 2;
}
.c-mv__title {
  color: #003673;
  font-size: 4rem;
  font-weight: 900;
  line-height: 1.5;
  letter-spacing: 0.09em;
}
@media only screen and (max-width: 767px) {
  .c-mv__title {
    margin-right: -2px;
    font-size: 2.9rem;
    line-height: 1.48;
  }
}
.c-mv__subtitle {
  margin-top: 20px;
  padding-left: 33px;
  color: #003673;
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 2;
}
@media only screen and (max-width: 767px) {
  .c-mv__subtitle {
    margin-top: 12px;
    padding-left: 0;
    font-size: 1.5rem;
  }
}
.c-mv__subtitle[data-animation] {
  -webkit-transition-delay: 0.6s;
  transition-delay: 0.6s;
}
.c-mv__right {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  width: 58.3333333333%;
}
@media only screen and (max-width: 1023px) {
  .c-mv__right {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    width: 100%;
    min-height: 1px;
    padding-left: 80px;
  }
}
@media only screen and (max-width: 767px) {
  .c-mv__right {
    padding-left: 16px;
  }
}
.c-mv__slider {
  position: relative;
  width: 100%;
  height: 100%;
  -webkit-clip-path: polygon(min(280px, 33.3333333333%) 0, 100% 0, 100% max(100% - 880px, 6.3829787234%), max(100% - 440px, 52.380952381%) 100%, 0 100%, 0 min(616px, 65.5319148936%));
  clip-path: polygon(min(280px, 33.3333333333%) 0, 100% 0, 100% max(100% - 880px, 6.3829787234%), max(100% - 440px, 52.380952381%) 100%, 0 100%, 0 min(616px, 65.5319148936%));
}
@media only screen and (max-width: 1023px) {
  .c-mv__slider {
    -webkit-clip-path: polygon(min(240px, 33.3333333333%) 0, 100% 0, 100% max(100% - 616px, 9.4117647059%), max(100% - 280px, 61.1111111111%) 100%, 0 100%, 0 min(528px, 77.6470588235%));
    clip-path: polygon(min(240px, 33.3333333333%) 0, 100% 0, 100% max(100% - 616px, 9.4117647059%), max(100% - 280px, 61.1111111111%) 100%, 0 100%, 0 min(528px, 77.6470588235%));
  }
}
@media only screen and (max-width: 767px) {
  .c-mv__slider {
    -webkit-clip-path: polygon(min(120px, 33.426183844%) 0, 100% 0, 100% max(100% - 308px, 9.1445427729%), max(100% - 140px, 38.9972144847%) 100%, 0 100%, 0 min(264px, 77.8761061947%));
    clip-path: polygon(min(120px, 33.426183844%) 0, 100% 0, 100% max(100% - 308px, 9.1445427729%), max(100% - 140px, 38.9972144847%) 100%, 0 100%, 0 min(264px, 77.8761061947%));
  }
}
.c-mv__slide .c-mv__thumb img {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
}
.c-mv__slide.swiper-slide-prev .c-mv__thumb img, .c-mv__slide.swiper-slide-duplicate-active .c-mv__thumb img, .c-mv__slide.swiper-slide-active .c-mv__thumb img {
  -webkit-animation: moveRight1 8s linear 0s 1 normal both;
  animation: moveRight1 8s linear 0s 1 normal both;
}
@media only screen and (max-width: 767px) {
  .c-mv__slide.swiper-slide-prev .c-mv__thumb img, .c-mv__slide.swiper-slide-duplicate-active .c-mv__thumb img, .c-mv__slide.swiper-slide-active .c-mv__thumb img {
    -webkit-animation: moveRight2 8s linear 0s 1 normal both;
    animation: moveRight2 8s linear 0s 1 normal both;
  }
}
.c-mv__thumb {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.c-mv__thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
.c-mv__bgtext {
  position: absolute;
  top: 21%;
  left: 0;
  width: 100%;
  pointer-events: none;
  z-index: 1;
}
@media only screen and (max-width: 1023px) {
  .c-mv__bgtext {
    top: 9.9609375%;
    left: unset;
    right: -2px;
    width: 143px;
  }
}
@media only screen and (max-width: 767px) {
  .c-mv__bgtext {
    right: -1px;
    width: 109px;
  }
}
.c-mv__bgtext img {
  width: 100%;
  opacity: 0.05;
}
@media only screen and (max-width: 1023px) {
  .c-mv__bgtext img {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}
.c-mv__scroll {
  position: absolute;
  bottom: 0;
  right: 36px;
}
/*------------------------------------------------------------
    Breadcrumb
------------------------------------------------------------*/
.c-breadcrumb1 {
  color: #6f8194;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.54;
  letter-spacing: -0.02em;
  text-align: left;
}
.c-breadcrumb1 li {
  display: contents;
  position: relative;
}
.c-breadcrumb1 li + li::before {
  content: "／";
  display: inline-block;
  position: relative;
  margin-left: 6px;
  margin-right: 8px;
}
/*≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡
// Component .c-
≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡*/
/*------------------------------------------------------------
    Title
------------------------------------------------------------*/
.c-arrow1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background-color: transparent;
  border: 1px solid #0a62c7;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media only screen and (min-width: 1023px) {
  .c-arrow1:hover {
    opacity: 1;
    filter: alpha(opacity=100);
    background-color: #0a62c7;
  }
  .c-arrow1:hover .c-arrow1__icon::before {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  .c-arrow1:hover .c-arrow1__icon::after {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
  }
}
.c-arrow1--reverse {
  background-color: #fff;
  border-color: #fff;
}
@media only screen and (min-width: 1023px) {
  .c-arrow1--reverse:hover {
    opacity: 1;
    filter: alpha(opacity=100);
    background-color: #fff;
  }
  .c-arrow1--reverse:hover .c-arrow1__icon::before {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
  }
  .c-arrow1--reverse:hover .c-arrow1__icon::after {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}
.c-arrow1--white {
  border-color: #fff;
}
@media only screen and (min-width: 1023px) {
  .c-arrow1--white:hover {
    background-color: #fff;
  }
}
.c-arrow1--white .c-arrow1__icon::before {
  color: #0a62c7;
}
.c-arrow1--white .c-arrow1__icon::after {
  color: #fff;
}
.c-arrow1--back .c-arrow1__icon::before {
  content: "\e906";
}
.c-arrow1--back .c-arrow1__icon::after {
  content: "\e906";
}
.c-arrow1__icon {
  display: block;
  position: relative;
  width: 12px;
  height: 12px;
  overflow: hidden;
}
.c-arrow1__icon::before {
  content: "\e901";
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translateX(-100%);
  transform: translateX(-100%);
  color: #fff;
  font-family: "icomoon";
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.c-arrow1__icon::after {
  content: "\e901";
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translateX(0);
  transform: translateX(0);
  color: #0a62c7;
  font-family: "icomoon";
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
/*------------------------------------------------------------
    Box
------------------------------------------------------------*/
.c-box1 {
  position: relative;
  width: 100%;
  padding: 39px;
  border: 1px solid #fff;
  border-radius: 16px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
}
@media only screen and (max-width: 1023px) {
  .c-box1 {
    padding: 37px 39px 39px;
  }
}
@media only screen and (max-width: 767px) {
  .c-box1 {
    padding: 37px 15px 39px;
  }
}
.c-box1::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent -webkit-gradient(linear, left top, left bottom, from(#fff), to(#9bcaff)) 0% 0% no-repeat padding-box;
  background: transparent -webkit-linear-gradient(top, #fff 0%, #9bcaff 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(180deg, #fff 0%, #9bcaff 100%) 0% 0% no-repeat padding-box;
  backdrop-filter: blur(10px) brightness(102%);
  border-radius: 16px;
  opacity: 0.15;
}
.c-box1__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 1023px) {
  .c-box1__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
.c-box1__left {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 56.25%;
  min-width: 560px;
  padding-right: 40px;
}
@media only screen and (max-width: 1023px) {
  .c-box1__left {
    -ms-flex-negative: unset;
    flex-shrink: unset;
    width: 100%;
    min-width: unset;
    padding-right: 0;
  }
}
.c-box1__leftinner {
  width: 100%;
  max-width: 640px;
  margin-left: auto;
}
@media only screen and (max-width: 1023px) {
  .c-box1__leftinner {
    max-width: unset;
    margin-right: auto;
  }
}
.c-box1__right {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  width: 43.75%;
}
@media only screen and (max-width: 1023px) {
  .c-box1__right {
    -webkit-box-flex: unset;
    -ms-flex-positive: unset;
    flex-grow: unset;
    width: 100%;
    margin-top: 40px;
  }
}
.c-box1__thumb {
  position: relative;
  width: 100%;
  background-color: #e6e6e6;
  overflow: hidden;
}
.c-box1__thumb::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 75%;
}
@media only screen and (max-width: 1023px) {
  .c-box1__thumb::before {
    padding-top: 58.3333333333%;
  }
}
.c-box1__thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
.c-box2 {
  display: block;
  position: relative;
  width: 100%;
  padding: 40px 40px 45px;
  background: transparent -webkit-gradient(linear, right top, left top, from(#0dbeff), to(#0071f2)) 0% 0% no-repeat padding-box;
  background: transparent -webkit-linear-gradient(right, #0dbeff 0%, #0071f2 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(270deg, #0dbeff 0%, #0071f2 100%) 0% 0% no-repeat padding-box;
  border-radius: 16px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
}
@media only screen and (max-width: 1023px) {
  .c-box2 {
    padding: 40px 40px 46px;
  }
}
@media only screen and (max-width: 767px) {
  .c-box2 {
    padding: 16px 20px 21px;
  }
}
@media only screen and (min-width: 1023px) {
  .c-box2:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
  .c-box2:hover .c-arrow1 {
    background-color: #fff;
  }
  .c-box2:hover .c-arrow1 .c-arrow1__icon::before {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  .c-box2:hover .c-arrow1 .c-arrow1__icon::after {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
  }
}
.c-box2__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 767px) {
  .c-box2__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
.c-box2__left {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  padding-right: 40px;
}
@media only screen and (max-width: 767px) {
  .c-box2__left {
    -webkit-box-flex: unset;
    -ms-flex-positive: unset;
    flex-grow: unset;
    width: 100%;
    padding-right: 0;
  }
}
.c-box2__right {
  position: relative;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  margin-top: 74px;
  z-index: 1;
}
@media only screen and (max-width: 1023px) {
  .c-box2__right {
    position: absolute;
    top: 0;
    right: 0;
    max-width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .c-box2__right {
    position: relative;
    top: unset;
    right: unset;
    width: 100%;
    margin-top: 6px;
  }
}
.c-box3 {
  display: block;
  position: relative;
  padding: 80px 40px;
  background-color: #f0f5fc;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  .c-box3 {
    padding: 64px 16px;
  }
}
.c-box3__row {
  position: relative;
  width: 100%;
  padding: 40px 0;
  border-bottom: 1px solid #e4e9f0;
}
@media only screen and (max-width: 767px) {
  .c-box3__row {
    padding: 24px 0;
  }
}
.c-box3__row:first-child {
  padding-top: 0;
}
.c-box3__field {
  margin-top: 8px;
}
.c-box3__field .c-radio__group {
  margin-top: 16px;
}
.c-box3__accept .c-checkbox__group {
  margin-top: 20px;
}
.c-box3__groupbtn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 64px -10px 0;
}
@media only screen and (max-width: 767px) {
  .c-box3__groupbtn {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    margin: 40px 0 0;
  }
}
.c-box3__groupbtn button {
  width: calc(50% - 20px);
  max-width: 320px;
  margin: 0 10px;
}
@media only screen and (max-width: 767px) {
  .c-box3__groupbtn button {
    width: 100%;
    margin: 0;
  }
}
@media only screen and (max-width: 767px) {
  .c-box3__groupbtn button + button {
    margin-top: 8px;
  }
}
.c-box3__recaptcha {
  text-align: center;
}
.c-box4 {
  position: relative;
  width: 100%;
  padding: 22px 40px;
  background-color: #f0f5fc;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  .c-box4 {
    padding: 22px 20px;
  }
}
.c-box4__name {
  display: block;
  color: #333;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
.c-box4__name + .c-text1 {
  margin-top: 4px;
}
.c-box4__bottom {
  margin-top: 19px;
}
.c-box4__bottom .c-text1 {
  margin-top: 3px;
}
.c-box5 {
  position: relative;
  padding: 40px;
  background-color: #f0f5fc;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  .c-box5 {
    padding: 20px 16px;
  }
}
/*------------------------------------------------------------
    Button
------------------------------------------------------------*/
.c-btn1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-height: 32px;
  padding: 3px 16px 5px;
  border-radius: 16px;
  background-color: #0a62c7;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
}
.c-btn1::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background: transparent -webkit-gradient(linear, left top, right top, from(#004594), to(#0a62c7)) 0% 0% no-repeat padding-box;
  background: transparent -webkit-linear-gradient(left, #004594 0%, #0a62c7 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(90deg, #004594 0%, #0a62c7 100%) 0% 0% no-repeat padding-box;
  border-radius: 16px;
  opacity: 1;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media only screen and (min-width: 1023px) {
  .c-btn1:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
  .c-btn1:hover::after {
    opacity: 0;
  }
}
.c-btn1__text {
  position: relative;
  z-index: 1;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.6;
  text-align: center;
}
.c-btn2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
  width: 100%;
  min-height: 64px;
  padding: 12px;
  background-color: #0a62c7;
  border-radius: 32px;
  -webkit-box-shadow: none;
  box-shadow: none;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
}
.c-btn2::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background: transparent -webkit-gradient(linear, left top, right top, from(#004594), to(#0a62c7)) 0% 0% no-repeat padding-box;
  background: transparent -webkit-linear-gradient(left, #004594 0%, #0a62c7 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(90deg, #004594 0%, #0a62c7 100%) 0% 0% no-repeat padding-box;
  opacity: 0;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media only screen and (min-width: 1023px) {
  .c-btn2:hover {
    opacity: 1;
    filter: alpha(opacity=100);
    -webkit-box-shadow: 0 3px 6px rgba(38, 56, 77, 0.4);
    box-shadow: 0 3px 6px rgba(38, 56, 77, 0.4);
  }
  .c-btn2:hover::after {
    opacity: 1;
  }
}
.c-btn2__text {
  position: relative;
  -webkit-transform: translateY(-1px);
  transform: translateY(-1px);
  margin-left: 20px;
  z-index: 1;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: -0.02em;
}
@media only screen and (max-width: 374px) {
  .c-btn2__text {
    margin-left: 8px;
  }
}
.c-btn2__arrow {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  position: relative;
  margin-left: 12px;
  z-index: 1;
}
.c-btn3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media only screen and (min-width: 1023px) {
  .c-btn3:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
  .c-btn3:hover .c-arrow1 {
    background-color: #0a62c7;
  }
  .c-btn3:hover .c-arrow1 .c-arrow1__icon::before {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  .c-btn3:hover .c-arrow1 .c-arrow1__icon::after {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
  }
}
.c-btn3--white .c-btn3__text {
  color: #fff;
}
@media only screen and (min-width: 1023px) {
  .c-btn3--white:hover .c-arrow1 {
    background-color: #fff;
  }
}
.c-btn3__text {
  -webkit-transform: translateY(-1px);
  transform: translateY(-1px);
  color: #0a62c7;
  font-size: 1.9rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-btn3__arrow {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  margin-left: 12px;
}
.c-btnmap {
  display: block;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #0a62c7;
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1.54;
  letter-spacing: -0.02em;
}
.c-btnmap::after {
  content: "\e903";
  display: inline-block;
  -webkit-transform: translateY(1px);
  transform: translateY(1px);
  margin-left: 4px;
  color: #0a62c7;
  font-family: "icomoon";
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1;
}
/*------------------------------------------------------------
    Card
------------------------------------------------------------*/
.c-card1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  height: 100%;
}
@media only screen and (min-width: 1023px) {
  .c-card1:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
  .c-card1:hover .c-card1__thumb img {
    opacity: 1;
    filter: alpha(opacity=100);
    -webkit-transform: scale(1.06);
    transform: scale(1.06);
  }
  .c-card1:hover .c-arrow1 {
    background-color: #0a62c7;
  }
  .c-card1:hover .c-arrow1 .c-arrow1__icon::before {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  .c-card1:hover .c-arrow1 .c-arrow1__icon::after {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
  }
}
.c-card1__top {
  width: 100%;
}
.c-card1__thumb {
  position: relative;
  width: 100%;
  background-color: #e6e6e6;
  overflow: hidden;
}
.c-card1__thumb::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 53.3646322379%;
}
@media only screen and (max-width: 1023px) {
  .c-card1__thumb::before {
    padding-top: 47.3611111111%;
  }
}
.c-card1__thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  -webkit-transition: opacity 0.3s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 0.46s cubic-bezier(0.33, 1, 0.68, 1);
  transition: opacity 0.3s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 0.46s cubic-bezier(0.33, 1, 0.68, 1);
  transition: transform 0.46s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.3s cubic-bezier(0.3, 0.1, 0.2, 1);
  transition: transform 0.46s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.3s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 0.46s cubic-bezier(0.33, 1, 0.68, 1);
}
.c-card1__bottom {
  position: relative;
  width: 100%;
  padding: 28px 40px;
}
@media only screen and (max-width: 767px) {
  .c-card1__bottom {
    padding: 20px 18px 20px 20px;
  }
}
.c-card1__heading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.c-card1__title {
  color: #0a62c7;
  font-size: 1.9rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-card1__arrow {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  margin-left: 12px;
}
.c-card1__description {
  margin-top: 22px;
}
@media only screen and (max-width: 767px) {
  .c-card1__description {
    margin-top: 14px;
  }
}
.c-card2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 100%;
}
@media only screen and (min-width: 1023px) {
  .c-card2:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
  .c-card2:hover .c-card2__thumb img {
    opacity: 1;
    filter: alpha(opacity=100);
    -webkit-transform: scale(1.06);
    transform: scale(1.06);
  }
}
.c-card2__thumb {
  position: relative;
  width: 100%;
  background-color: #b3b3b3;
  overflow: hidden;
}
.c-card2__thumb::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 61.8497109827%;
}
@media only screen and (max-width: 767px) {
  .c-card2__thumb::before {
    padding-top: 62.0991253644%;
  }
}
.c-card2__thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  -webkit-transition: opacity 0.3s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 0.46s cubic-bezier(0.33, 1, 0.68, 1);
  transition: opacity 0.3s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 0.46s cubic-bezier(0.33, 1, 0.68, 1);
  transition: transform 0.46s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.3s cubic-bezier(0.3, 0.1, 0.2, 1);
  transition: transform 0.46s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.3s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 0.46s cubic-bezier(0.33, 1, 0.68, 1);
}
.c-card2__content {
  width: 100%;
  margin-top: 16px;
}
.c-card2__taglist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 -4px -4px 0;
}
.c-card2__taglist + .c-card2__title {
  margin-top: 16px;
}
.c-card2__tagitem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: calc(100% - 4px);
  margin-right: 4px;
  margin-bottom: 4px;
}
.c-card2__title {
  color: #003673;
  font-size: 1.9rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
.c-card2__description {
  margin-top: 0.35rem;
  margin-right: -1px;
  color: #6f8194;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.54;
  letter-spacing: -0.02em;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
.c-card2__price {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  position: relative;
  margin-top: 16px;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-card2__price::before {
  content: "¥";
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  -webkit-transform: translateY(2px);
  transform: translateY(2px);
  width: 20px;
  height: 20px;
  margin-right: 4px;
  padding: 2px 3px 4px;
  background-color: #003673;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.02em;
  text-align: center;
  white-space: nowrap;
}
.c-card3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
@media only screen and (max-width: 767px) {
  .c-card3 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.c-card3__left {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 31.25%;
  min-width: 400px;
}
@media only screen and (max-width: 1023px) {
  .c-card3__left {
    width: 34.3055555556%;
    min-width: 247px;
  }
}
@media only screen and (max-width: 767px) {
  .c-card3__left {
    width: 100%;
    min-width: unset;
  }
}
.c-card3__thumb {
  position: relative;
  width: 100%;
  background-color: #b3b3b3;
  overflow: hidden;
}
.c-card3__thumb::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 61.75%;
}
@media only screen and (max-width: 1023px) {
  .c-card3__thumb::before {
    padding-top: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .c-card3__thumb::before {
    padding-top: 72.0116618076%;
  }
}
.c-card3__thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
.c-card3__right {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  width: 68.75%;
  margin-top: 15px;
  padding-left: 40px;
}
@media only screen and (max-width: 1023px) {
  .c-card3__right {
    width: 65.6944444444%;
    margin-top: 16px;
  }
}
@media only screen and (max-width: 767px) {
  .c-card3__right {
    width: 100%;
    margin-top: 40px;
    padding-left: 0;
  }
}
.c-card3__title {
  color: #003673;
  font-size: 2.3rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-card3__description {
  margin-top: 22px;
}
@media only screen and (max-width: 1023px) {
  .c-card3__description {
    margin-top: 21px;
  }
}
@media only screen and (max-width: 767px) {
  .c-card3__description {
    margin-top: 22px;
  }
}
.c-card3__listcheck {
  margin: 35px 0 -4px;
}
@media only screen and (max-width: 1023px) {
  .c-card3__listcheck {
    margin: 35px 0 -2px;
  }
}
@media only screen and (max-width: 767px) {
  .c-card3__listcheck {
    margin: 19px 0 -3px;
  }
}
.c-card4 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  height: 100%;
}
.c-card4__thumb {
  position: relative;
  width: 100%;
  background-color: #b3b3b3;
  overflow: hidden;
}
.c-card4__thumb::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 61.724137931%;
}
@media only screen and (max-width: 767px) {
  .c-card4__thumb::before {
    padding-top: 62.0991253644%;
  }
}
.c-card4__thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
.c-card4__content {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  width: 100%;
  margin-top: 10px;
}
.c-card4__caption {
  color: #333;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
/*------------------------------------------------------------
    Checkbox
------------------------------------------------------------*/
.c-checkbox__group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  margin: 0 -4px -4px 0;
}
.c-checkbox__group .mwform-checkbox-field {
  margin: 0 4px 4px 0;
}
.c-checkbox__group .mwform-checkbox-field label {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
}
.c-checkbox__group .mwform-checkbox-field label input[type=checkbox] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  background-color: transparent;
  opacity: 0;
  -webkit-tap-highlight-color: transparent;
  z-index: 1;
  cursor: pointer;
}
.c-checkbox__group .mwform-checkbox-field label input[type=checkbox]:checked + .mwform-checkbox-field-text {
  background-color: #fff;
  border-color: #0a62c7;
}
.c-checkbox__group .mwform-checkbox-field label input[type=checkbox]:checked + .mwform-checkbox-field-text::before {
  background-color: #0a62c7;
}
.c-checkbox__group .mwform-checkbox-field label input[type=checkbox]:checked + .mwform-checkbox-field-text::after {
  opacity: 1;
}
.c-checkbox__group .mwform-checkbox-field label .mwform-checkbox-field-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  position: relative;
  width: 100%;
  min-height: 56px;
  padding: 14px 14px 14px 40px;
  background-color: #e6edf7;
  border: 2px solid #e6edf7;
  border-radius: 4px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
  cursor: pointer;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.c-checkbox__group .mwform-checkbox-field label .mwform-checkbox-field-text::before {
  content: "";
  display: block;
  position: absolute;
  top: 17px;
  left: 14px;
  width: 20px;
  height: 20px;
  background-color: #fff;
  border-radius: 4px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.c-checkbox__group .mwform-checkbox-field label .mwform-checkbox-field-text::after {
  content: "\e904";
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: absolute;
  top: 17px;
  left: 14px;
  width: 20px;
  height: 20px;
  opacity: 0;
  color: #fff;
  font-family: "icomoon";
  font-size: 2rem;
  font-weight: 400;
  line-height: 1;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.c-checkbox__group--vertical {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  margin: 0;
}
.c-checkbox__group--vertical .mwform-checkbox-field {
  width: 100%;
  margin: 0;
}
.c-checkbox__group--vertical .mwform-checkbox-field + .mwform-checkbox-field {
  margin-top: 8px;
}
/*------------------------------------------------------------
    Cube
------------------------------------------------------------*/
.c-cube {
  display: block;
  pointer-events: none;
}
.c-cube::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 100%;
}
.c-cube1 {
  background: transparent -webkit-linear-gradient(45deg, #c4e0ff 0%, #c7fffa 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(45deg, #c4e0ff 0%, #c7fffa 100%) 0% 0% no-repeat padding-box;
  -webkit-filter: blur(10px);
  filter: blur(10px);
}
.c-cube2 {
  background: transparent -webkit-linear-gradient(45deg, #e0e8ff 0%, #fbe8ff 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(45deg, #e0e8ff 0%, #fbe8ff 100%) 0% 0% no-repeat padding-box;
  -webkit-filter: blur(2px);
  filter: blur(2px);
}
.c-cube3 {
  background: transparent -webkit-linear-gradient(45deg, #b7fff9 0%, #f4ffc6 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(45deg, #b7fff9 0%, #f4ffc6 100%) 0% 0% no-repeat padding-box;
  -webkit-filter: blur(10px);
  filter: blur(10px);
}
.c-cube4 {
  background: transparent -webkit-linear-gradient(225deg, #fdffc7 0%, #fcc 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(225deg, #fdffc7 0%, #fcc 100%) 0% 0% no-repeat padding-box;
  -webkit-filter: blur(3px);
  filter: blur(3px);
}
.c-cube5 {
  background: transparent -webkit-linear-gradient(225deg, #fdffc7 0%, #fcc 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(225deg, #fdffc7 0%, #fcc 100%) 0% 0% no-repeat padding-box;
  -webkit-filter: blur(4px);
  filter: blur(4px);
}
.c-cube6 {
  background: transparent -webkit-linear-gradient(45deg, #91c5ff 0%, #b7fff9 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(45deg, #91c5ff 0%, #b7fff9 100%) 0% 0% no-repeat padding-box;
}
.c-cube7 {
  background: transparent -webkit-linear-gradient(45deg, #b7fff9 0%, #f4ffc6 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(45deg, #b7fff9 0%, #f4ffc6 100%) 0% 0% no-repeat padding-box;
  -webkit-filter: blur(20px);
  filter: blur(20px);
}
.c-cube8 {
  background: transparent -webkit-linear-gradient(45deg, #e0e8ff 0%, #fbe8ff 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(45deg, #e0e8ff 0%, #fbe8ff 100%) 0% 0% no-repeat padding-box;
  -webkit-filter: blur(20px);
  filter: blur(20px);
}
.c-cube9 {
  background: transparent -webkit-linear-gradient(225deg, #fdffc7 0%, #ffe7e2 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(225deg, #fdffc7 0%, #ffe7e2 100%) 0% 0% no-repeat padding-box;
  -webkit-filter: blur(4px);
  filter: blur(4px);
}
.c-cube10 {
  background: transparent -webkit-linear-gradient(45deg, #c4e0ff 0%, #c7fffa 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(45deg, #c4e0ff 0%, #c7fffa 100%) 0% 0% no-repeat padding-box;
  opacity: 0.8;
  -webkit-filter: blur(10px);
  filter: blur(10px);
}
.c-cube11 {
  background: transparent -webkit-linear-gradient(45deg, #e0e8ff 0%, #fbe8ff 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(45deg, #e0e8ff 0%, #fbe8ff 100%) 0% 0% no-repeat padding-box;
  -webkit-filter: blur(5px);
  filter: blur(5px);
}
.c-cube12 {
  background: transparent -webkit-linear-gradient(45deg, #b7fff9 0%, #f4ffc6 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(45deg, #b7fff9 0%, #f4ffc6 100%) 0% 0% no-repeat padding-box;
  opacity: 0.8;
  -webkit-filter: blur(20px);
  filter: blur(20px);
}
.c-cube13 {
  background: transparent -webkit-linear-gradient(45deg, #ffeee6 0%, #ffffdb 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(45deg, #ffeee6 0%, #ffffdb 100%) 0% 0% no-repeat padding-box;
  opacity: 0.8;
  -webkit-filter: blur(20px);
  filter: blur(20px);
}
/*------------------------------------------------------------
    Error
------------------------------------------------------------*/
.c-box3__error .error,
.mw_wp_form .c-box3__error .error,
.mw_wp_form .c-box3__recaptcha .error {
  display: block;
  margin-top: 5px;
  color: #bf0000;
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1.54;
  letter-spacing: -0.02em;
}
/*------------------------------------------------------------
    Heading
------------------------------------------------------------*/
.c-heading1 {
  position: relative;
  padding: 55px 0;
}
@media only screen and (max-width: 1023px) {
  .c-heading1 {
    padding: 55px 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .c-heading1 {
    padding: 20px 0 0;
  }
}
.c-heading1--style1 .c-heading1__heading {
  margin-top: -352px;
  padding-bottom: 103px;
}
@media only screen and (max-width: 1023px) {
  .c-heading1--style1 .c-heading1__heading {
    margin-top: -250px;
    padding-bottom: 56px;
  }
}
@media only screen and (max-width: 767px) {
  .c-heading1--style1 .c-heading1__heading {
    margin-top: -195px;
  }
}
.c-heading1--style2 {
  padding: 53px 0 0;
}
@media only screen and (max-width: 767px) {
  .c-heading1--style2 {
    padding: 45px 0 0;
  }
}
.c-heading1--style2 .c-heading1__heading {
  margin-top: 0;
  padding-bottom: 0;
}
.c-heading1--style2 .c-heading1__en {
  margin-top: 1px;
  font-size: 5.7rem;
  line-height: 0.886;
}
.c-heading1__breadcrumb {
  padding: 0 24px;
}
@media only screen and (max-width: 767px) {
  .c-heading1__breadcrumb {
    padding: 8px 16px;
  }
}
.c-heading1__heading {
  position: relative;
  margin-top: -298px;
  padding-bottom: 117px;
  z-index: 1;
}
@media only screen and (max-width: 1023px) {
  .c-heading1__heading {
    margin-top: -196px;
    padding-bottom: 81px;
  }
}
@media only screen and (max-width: 767px) {
  .c-heading1__heading {
    margin-top: -164px;
    padding-bottom: 66px;
  }
}
.c-heading1__ja {
  display: block;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.03em;
}
.c-heading1__en {
  display: block;
  margin-top: -3px;
  background: transparent -webkit-gradient(linear, left top, right top, from(#004594), to(#0a62c7)) 0% 0% no-repeat padding-box;
  background: transparent -webkit-linear-gradient(left, #004594 0%, #0a62c7 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(90deg, #004594 0%, #0a62c7 100%) 0% 0% no-repeat padding-box;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-size: 11.9rem;
  font-weight: 700;
  line-height: 0.94;
}
@media only screen and (max-width: 767px) {
  .c-heading1__en {
    margin-top: -4px;
    font-size: 7rem;
    line-height: 0.886;
  }
}
@media only screen and (max-width: 374px) {
  .c-heading1__en {
    margin-top: -5px;
    font-size: 5.8rem;
  }
}
/*------------------------------------------------------------
    Input
------------------------------------------------------------*/
.c-input {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  position: relative;
  width: 100%;
}
.c-input input[type=text],
.c-input input[type=email],
.c-input input[type=tel],
.c-input input[type=url] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  height: 56px;
  padding: 12px 15px;
  background-color: #fff;
  border: 1px solid #e4e9f0;
  border-radius: 4px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  outline: none;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-input textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  height: 280px;
  padding: 12px 15px;
  background-color: #fff;
  border: 1px solid #e4e9f0;
  border-radius: 4px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  outline: none;
  resize: none;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-input--tiny {
  width: min(234px, 100%);
}
.c-input__group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  margin: 0 -4px;
}
.c-input__group .c-input__item--tiny {
  width: calc(50% - 8px);
  max-width: 234px;
  margin: 0 4px;
}
.c-input__group--vertical {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin: 0;
}
.c-input__group--vertical .c-input__item {
  width: 100%;
}
.c-input__group--vertical .c-input__item + .c-input__item {
  margin-top: 20px;
}
.c-input__itemlabel {
  margin-top: -4px;
}
.c-input__itemlabel + .c-input__iteminput {
  margin-top: 3px;
}
/*------------------------------------------------------------
    Label
------------------------------------------------------------*/
.c-label1 {
  position: relative;
  display: inline-block;
  padding-left: 0;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-label1::before {
  content: none;
  display: block;
  position: absolute;
  top: 3px;
  left: 0;
  padding: 1px 4px 1px 3px;
  background-color: transparent;
  border: 1px solid #7c98b8;
  border-radius: 4px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #6b8cb3;
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1.23;
  letter-spacing: -0.02em;
  text-align: center;
}
.c-label1.is-required {
  padding-left: 40px;
}
.c-label1.is-required::before {
  content: "必須";
  background-color: #6b8cb3;
  border-color: #6b8cb3;
  color: #fff;
}
.c-label1.is-optional {
  padding-left: 40px;
}
.c-label1.is-optional::before {
  content: "任意";
}
.c-label2 {
  display: inline-block;
  color: #333;
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1.54;
  letter-spacing: -0.02em;
}
/*------------------------------------------------------------
    Link
------------------------------------------------------------*/
.c-link1 {
  color: #333;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-link1 .icon {
  display: inline-block;
  -webkit-transform: translateY(2px);
  transform: translateY(2px);
  color: #0a62c7;
  font-size: 1.6rem;
  line-height: 1;
  letter-spacing: 0;
}
.c-link2 {
  color: #003673;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-link2 .icon {
  display: inline-block;
  -webkit-transform: translateY(1px);
  transform: translateY(1px);
  margin-left: 3px;
  margin-right: 3px;
  color: #0a62c7;
  font-family: "icomoon";
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1;
}
/*------------------------------------------------------------
    List
------------------------------------------------------------*/
.c-list1 {
  color: #333;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
.c-list1 li {
  position: relative;
  padding-left: 20px;
}
.c-list1 li::before {
  content: "";
  position: absolute;
  top: 11px;
  left: 4px;
  width: 8px;
  height: 8px;
  background-color: #7c98b8;
  border-radius: 50%;
}
/*------------------------------------------------------------
    Listcheck
------------------------------------------------------------*/
.c-listcheck1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  color: #333;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
.c-listcheck1 li {
  position: relative;
  width: 100%;
  padding-left: 20px;
}
.c-listcheck1 li::before {
  content: "\e902";
  display: inline-block;
  position: absolute;
  top: 9px;
  left: 1px;
  color: #0a62c7;
  font-family: "icomoon";
  font-size: 1.38rem;
  font-weight: 400;
  line-height: 1;
}
.c-listcheck2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  color: #333;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
.c-listcheck2 li {
  position: relative;
  width: 100%;
  min-height: 56px;
  padding: 13px 16px 14px 40px;
  background-color: #f0f5fc;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.c-listcheck2 li + li {
  margin-top: 8px;
}
.c-listcheck2 li::before {
  content: "\e902";
  display: inline-block;
  position: absolute;
  top: 22px;
  left: 17px;
  color: #0a62c7;
  font-family: "icomoon";
  font-size: 1.38rem;
  font-weight: 400;
  line-height: 1;
}
/*------------------------------------------------------------
    Loading
------------------------------------------------------------*/
.c-loading1 {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-color: #fff;
  z-index: 9999;
}
/*------------------------------------------------------------
    Menu
------------------------------------------------------------*/
.c-menu1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 60px;
  height: 32px;
  background-color: #003673;
  border-radius: 16px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.c-menu1.is-open .c-menu1__inner span:nth-child(1) {
  -webkit-transform: translate(0, 3px) rotate(30deg);
  transform: translate(0, 3px) rotate(30deg);
  width: 20px;
}
.c-menu1.is-open .c-menu1__inner span:nth-child(2) {
  -webkit-transform: translate(0, -3px) rotate(-30deg);
  transform: translate(0, -3px) rotate(-30deg);
  width: 20px;
}
.c-menu1__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 20px;
  height: 7px;
}
.c-menu1__inner span {
  display: block;
  width: 20px;
  height: 1px;
  background-color: #fff;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.c-menu1__inner span:nth-child(1) {
  width: 20px;
}
.c-menu1__inner span:nth-child(2) {
  width: 12px;
}
/*------------------------------------------------------------
    Note
------------------------------------------------------------*/
.c-note1 {
  color: #333;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.538;
  letter-spacing: -0.02em;
}
/*------------------------------------------------------------
    Part
------------------------------------------------------------*/
.c-part1 .c-btnmap {
  margin-top: 13px;
}
@media only screen and (max-width: 767px) {
  .c-part1 .c-btnmap {
    margin-top: 14px;
  }
}
.c-part1__name {
  color: #333;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
.c-part1__address {
  margin-top: 4px;
  color: #333;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
@media only screen and (max-width: 1023px) {
  .c-part1__address {
    margin-top: 3px;
  }
}
/*------------------------------------------------------------
    Particle
------------------------------------------------------------*/
.c-particle1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.c-particle1__left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 50%;
  padding: 0 40px;
}
@media only screen and (max-width: 767px) {
  .c-particle1__left {
    width: 38.6666666667%;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    padding: 0 20px 0 0;
  }
}
.c-particle1__right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 50%;
  margin-top: 172px;
  padding: 0 40px;
}
@media only screen and (max-width: 1023px) {
  .c-particle1__right {
    margin-top: 87px;
  }
}
@media only screen and (max-width: 767px) {
  .c-particle1__right {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    width: 61.3333333333%;
    margin-top: 122px;
    padding: 0;
  }
}
.c-particle1__group1 {
  position: relative;
  width: 240px;
  height: 192px;
}
@media only screen and (max-width: 1023px) {
  .c-particle1__group1 {
    width: 133px;
    height: 107px;
  }
}
@media only screen and (max-width: 767px) {
  .c-particle1__group1 {
    width: 125px;
    height: 100px;
  }
}
.c-particle1__group1 .c-cube1 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 26.6666666667%;
  max-width: 64px;
}
.c-particle1__group1 .c-cube2 {
  position: absolute;
  top: 0;
  right: 0;
  width: 66.6666666667%;
  max-width: 160px;
}
.c-particle1__group2 {
  position: relative;
  width: 420px;
  height: 400px;
}
@media only screen and (max-width: 1023px) {
  .c-particle1__group2 {
    width: 233px;
    height: 222px;
  }
}
@media only screen and (max-width: 767px) {
  .c-particle1__group2 {
    width: 219px;
    height: 208px;
  }
}
.c-particle1__group2 .c-cube3 {
  position: absolute;
  top: 0;
  right: 4.7619047619%;
  width: 28.5714285714%;
  max-width: 120px;
}
.c-particle1__group2 .c-cube4 {
  position: absolute;
  top: 40%;
  right: 0;
  width: 9.5238095238%;
  max-width: 40px;
}
@media only screen and (max-width: 1023px) {
  .c-particle1__group2 .c-cube4 {
    top: 40.0900900901%;
  }
}
.c-particle1__group2 .c-thumb--round {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 76.1904761905%;
  max-width: 320px;
  z-index: 1;
}
.c-particle2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.c-particle2__left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  width: 50%;
  margin-right: auto;
  padding-right: 40px;
}
.c-particle2__right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  width: 50%;
  margin-left: auto;
  padding-left: 40px;
}
@media only screen and (max-width: 767px) {
  .c-particle2__right {
    width: 58.9333333333%;
    padding-left: 20px;
  }
}
.c-particle2__group1 {
  position: relative;
  width: 386px;
  height: 350px;
}
@media only screen and (max-width: 1023px) {
  .c-particle2__group1 {
    width: 215px;
    height: 195px;
  }
}
@media only screen and (max-width: 767px) {
  .c-particle2__group1 {
    width: 201px;
    height: 182px;
  }
}
.c-particle2__group1 .c-cube5 {
  position: absolute;
  top: 38.5714285714%;
  left: 0;
  width: 10.3626943005%;
  max-width: 40px;
}
.c-particle2__group1 .c-cube6 {
  position: absolute;
  top: 0;
  left: 7.7720207254%;
  width: 40.414507772%;
  max-width: 156px;
  z-index: 1;
}
.c-particle2__group1 .c-cube7 {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 62.1761658031%;
  max-width: 240px;
}
.c-particle2__group2 {
  position: relative;
  width: 240px;
  height: 240px;
}
@media only screen and (max-width: 1023px) {
  .c-particle2__group2 {
    width: 134px;
    height: 134px;
  }
}
.c-particle2__group2 .c-cube8 {
  position: absolute;
  top: 0;
  left: -40px;
  width: 100%;
  max-width: 240px;
}
@media only screen and (max-width: 1023px) {
  .c-particle2__group2 .c-cube8 {
    left: -21px;
  }
}
.c-particle3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.c-particle3__right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  width: 100%;
  max-width: 760px;
  margin-left: auto;
  padding-left: 40px;
}
@media only screen and (max-width: 1023px) {
  .c-particle3__right {
    max-width: 440px;
  }
}
@media only screen and (max-width: 767px) {
  .c-particle3__right {
    max-width: 350px;
    padding-left: 16px;
  }
}
.c-particle3__group1 {
  position: relative;
  width: 720px;
  height: 462px;
}
@media only screen and (max-width: 1023px) {
  .c-particle3__group1 {
    width: 400px;
    height: 257px;
  }
}
@media only screen and (max-width: 767px) {
  .c-particle3__group1 {
    width: 334px;
    height: 240px;
  }
}
.c-particle3__group1 .c-cube9 {
  position: absolute;
  top: 9.0909090909%;
  left: 0;
  width: 5.5555555556%;
  max-width: 40px;
}
@media only screen and (max-width: 1023px) {
  .c-particle3__group1 .c-cube9 {
    top: 9.3385214008%;
    width: 5.5%;
    max-width: 22px;
  }
}
@media only screen and (max-width: 767px) {
  .c-particle3__group1 .c-cube9 {
    top: 9.1666666667%;
    width: 6.2874251497%;
    max-width: 21px;
  }
}
.c-particle3__group1 .c-cube10 {
  position: absolute;
  bottom: 27.9220779221%;
  left: 17.2222222222%;
  width: 8.8888888889%;
  max-width: 64px;
}
@media only screen and (max-width: 1023px) {
  .c-particle3__group1 .c-cube10 {
    bottom: 28.0155642023%;
    left: 17.25%;
    width: 9%;
    max-width: 36px;
  }
}
@media only screen and (max-width: 767px) {
  .c-particle3__group1 .c-cube10 {
    top: 58.3333333333%;
    left: 19.1616766467%;
    width: 9.880239521%;
    max-width: 33px;
  }
}
.c-particle3__group1 .c-cube11 {
  position: absolute;
  top: 27.9220779221%;
  left: 23.3333333333%;
  width: 22.2222222222%;
  max-width: 160px;
  z-index: 1;
}
@media only screen and (max-width: 1023px) {
  .c-particle3__group1 .c-cube11 {
    top: 28.0155642023%;
    left: 23.25%;
    width: 22.25%;
    max-width: 89px;
  }
}
@media only screen and (max-width: 767px) {
  .c-particle3__group1 .c-cube11 {
    top: 27.9166666667%;
    left: 26.0479041916%;
    width: 24.8502994012%;
    max-width: 83px;
  }
}
.c-particle3__group1 .c-cube12 {
  position: absolute;
  bottom: 0;
  right: 11.1111111111%;
  width: 33.3333333333%;
  max-width: 240px;
}
@media only screen and (max-width: 1023px) {
  .c-particle3__group1 .c-cube12 {
    right: 11%;
    width: 33.25%;
    max-width: 133px;
  }
}
@media only screen and (max-width: 767px) {
  .c-particle3__group1 .c-cube12 {
    right: 0;
    width: 37.4251497006%;
    max-width: 125px;
  }
}
.c-particle3__group1 .c-cube13 {
  position: absolute;
  top: 0;
  right: 19.0277777778%;
  width: 17.3611111111%;
  max-width: 125px;
}
@media only screen and (max-width: 1023px) {
  .c-particle3__group1 .c-cube13 {
    right: 19%;
    width: 17.25%;
    max-width: 69px;
  }
}
@media only screen and (max-width: 767px) {
  .c-particle3__group1 .c-cube13 {
    right: 8.6826347305%;
    width: 19.4610778443%;
    max-width: 65px;
  }
}
/*------------------------------------------------------------
    Point
------------------------------------------------------------*/
.c-point1 {
  position: relative;
  padding-left: 20px;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-point1::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 4px;
  width: 8px;
  height: 8px;
  background-color: #003673;
  border-radius: 50%;
}
.c-point2 {
  position: relative;
  padding-left: 20px;
  color: #333;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
.c-point2::before {
  content: "";
  position: absolute;
  top: 11px;
  left: 4px;
  width: 8px;
  height: 8px;
  background-color: #7c98b8;
  border-radius: 50%;
}
/*------------------------------------------------------------
    Radio
------------------------------------------------------------*/
.c-radio__group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  margin: 0 -4px -4px 0;
}
.c-radio__group .mwform-radio-field {
  margin: 0 4px 4px 0;
}
.c-radio__group .mwform-radio-field label {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
}
.c-radio__group .mwform-radio-field label input[type=radio] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  background-color: transparent;
  opacity: 0;
  -webkit-tap-highlight-color: transparent;
  z-index: 1;
  cursor: pointer;
}
.c-radio__group .mwform-radio-field label input[type=radio]:checked + .mwform-radio-field-text {
  background-color: #fff;
  border-color: #0a62c7;
}
.c-radio__group .mwform-radio-field label input[type=radio]:checked + .mwform-radio-field-text::before {
  background-color: #0a62c7;
}
.c-radio__group .mwform-radio-field label input[type=radio]:checked + .mwform-radio-field-text::after {
  -webkit-transform: scale(1);
  transform: scale(1);
}
.c-radio__group .mwform-radio-field label .mwform-radio-field-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  position: relative;
  width: 100%;
  min-height: 56px;
  padding: 14px 14px 14px 40px;
  background-color: #e6edf7;
  border: 2px solid #e6edf7;
  border-radius: 4px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
  cursor: pointer;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.c-radio__group .mwform-radio-field label .mwform-radio-field-text::before {
  content: "";
  display: block;
  position: absolute;
  top: 17px;
  left: 14px;
  width: 20px;
  height: 20px;
  background-color: #fff;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.c-radio__group .mwform-radio-field label .mwform-radio-field-text::after {
  content: "";
  display: block;
  position: absolute;
  top: 23px;
  left: 20px;
  -webkit-transform: scale(0);
  transform: scale(0);
  width: 8px;
  height: 8px;
  background-color: #fff;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.c-radio__group--vertical {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  margin: 0;
}
.c-radio__group--vertical .mwform-radio-field {
  width: 100%;
  margin: 0;
}
.c-radio__group--vertical .mwform-radio-field + .mwform-radio-field {
  margin-top: 8px;
}
/*------------------------------------------------------------
    Scroll
------------------------------------------------------------*/
.c-scroll {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.c-scroll__text {
  -webkit-transform: translateX(1px);
  transform: translateX(1px);
  color: #6f8194;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  white-space: nowrap;
}
.c-scroll__bar {
  display: block;
  position: relative;
  width: 1px;
  height: 64px;
  margin-top: 4px;
  background-color: #e4e9f0;
  overflow: hidden;
}
.c-scroll__bar::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translateY(0);
  transform: translateY(0);
  width: 100%;
  height: 12px;
  background-color: #0a62c7;
  -webkit-animation: scrolldown 2s linear infinite;
  animation: scrolldown 2s linear infinite;
  z-index: 1;
}
/*------------------------------------------------------------
    Single
------------------------------------------------------------*/
.c-single1__catlist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 -4px -4px 0;
}
.c-single1__catlist + .c-single1__title {
  margin-top: 15px;
}
@media only screen and (max-width: 767px) {
  .c-single1__catlist + .c-single1__title {
    margin-top: 16px;
  }
}
.c-single1__catitem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: calc(100% - 4px);
  margin-right: 4px;
  margin-bottom: 4px;
}
.c-single1__title {
  color: #003673;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
@media only screen and (max-width: 767px) {
  .c-single1__title {
    font-size: 2.9rem;
  }
}
.c-single1__info {
  width: 100%;
  max-width: 720px;
  margin-top: 40px;
}
@media only screen and (max-width: 1023px) {
  .c-single1__info {
    max-width: unset;
  }
}
@media only screen and (max-width: 767px) {
  .c-single1__info {
    margin-top: 23px;
  }
}
.c-single1__infolist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}
.c-single1__infoitem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  position: relative;
  width: 100%;
  padding: 16px 0 15px;
  border-bottom: 1px solid #e4e9f0;
}
.c-single1__infoitem:first-child {
  padding-top: 0;
}
.c-single1__infoicon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  position: relative;
  -webkit-transform: translateY(5px);
  transform: translateY(5px);
  width: 20px;
  height: 20px;
  background-color: #003673;
  border-radius: 50%;
  overflow: hidden;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.c-single1__infoicon .icon {
  display: inline-block;
  color: #fff;
}
.c-single1__infoicon .icon.icon-map {
  font-size: 1.3rem;
}
.c-single1__infoicon .icon.icon-yen {
  -webkit-transform: translateY(1px);
  transform: translateY(1px);
  font-size: 1.15rem;
}
.c-single1__infotext {
  margin-left: 8px;
  color: #003673;
  font-size: 1.9rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-single1__infomap {
  display: inline-block;
  margin-left: 8px;
  margin-top: 3px;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
@media only screen and (max-width: 767px) {
  .c-single1__infomap {
    display: block;
    margin-top: 9px;
    margin-left: 0;
  }
}
.c-single1__taglist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 24px -4px -6px 0;
}
@media only screen and (max-width: 767px) {
  .c-single1__taglist {
    padding-right: 1px;
  }
}
.c-single1__tagitem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: calc(100% - 4px);
  margin-right: 4px;
  margin-bottom: 6px;
}
.c-single1__jobdesc {
  margin-top: 38px;
}
@media only screen and (max-width: 767px) {
  .c-single1__jobdesc {
    margin-top: 22px;
  }
}
.c-single1__subtitle {
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
.c-single1__content {
  margin-top: 3px;
}
.c-single1__content p + p {
  margin-top: 28.8px;
}
.c-single1__main {
  margin-top: 125px;
}
@media only screen and (max-width: 1023px) {
  .c-single1__main {
    margin-top: 61px;
  }
}
@media only screen and (max-width: 767px) {
  .c-single1__main {
    margin-top: 38px;
  }
}
.c-single1__box {
  margin-top: 8px;
}
@media only screen and (max-width: 1023px) {
  .c-single1__box {
    margin: 8px -40px 0;
  }
}
@media only screen and (max-width: 767px) {
  .c-single1__box {
    margin: 8px -16px 0;
  }
}
/*------------------------------------------------------------
    Slider
------------------------------------------------------------*/
.c-slider1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}
.c-slider1__btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  position: relative;
  width: 56px;
  height: 56px;
  padding: 4px;
  background-color: #f0f5fc;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  cursor: pointer;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.c-slider1__btn::before {
  content: "\e900";
  display: inline-block;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  -webkit-transform: translate(1px, 0);
  transform: translate(1px, 0);
  color: #0a62c7;
  font-family: "icomoon";
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media only screen and (min-width: 1023px) {
  .c-slider1__btn:hover {
    background-color: #0a62c7;
  }
  .c-slider1__btn:hover::before {
    color: #fff;
  }
}
.c-slider1__btn + .c-slider1__btn {
  margin-left: 8px;
}
.c-slider1__btn--prev::before {
  -webkit-transform: translate(-1px, 0) rotate(180deg);
  transform: translate(-1px, 0) rotate(180deg);
}
/*------------------------------------------------------------
    Table
------------------------------------------------------------*/
.c-table1 {
  width: 100%;
  border-collapse: collapse;
}
.c-table1--style1 .c-table1__field {
  width: 156px;
}
@media only screen and (max-width: 767px) {
  .c-table1--style1 .c-table1__field {
    width: 100%;
  }
}
.c-table1--style1 .c-table1__content {
  width: calc(100% - 156px);
}
@media only screen and (max-width: 767px) {
  .c-table1--style1 .c-table1__content {
    width: 100%;
  }
}
.c-table1__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  vertical-align: top;
  padding: 38px 0 37px;
  border-bottom: 1px solid #eef3f7;
}
@media only screen and (max-width: 1023px) {
  .c-table1__row {
    padding: 38px 0 3.75rem;
  }
}
@media only screen and (max-width: 767px) {
  .c-table1__row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    padding: 22px 0 21px;
  }
}
.c-table1__row:first-child {
  padding-top: 0;
}
.c-table1__row:last-child {
  padding-bottom: 0;
  border-bottom: none;
}
.c-table1__field {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 144px;
  padding-right: 28px;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.03em;
  text-align: left;
}
@media only screen and (max-width: 767px) {
  .c-table1__field {
    -ms-flex-negative: unset;
    flex-shrink: unset;
    width: 100%;
    padding-right: 0;
  }
}
.c-table1__content {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  width: calc(100% - 144px);
  color: #333;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
@media only screen and (max-width: 767px) {
  .c-table1__content {
    -webkit-box-flex: unset;
    -ms-flex-positive: unset;
    flex-grow: unset;
    width: 100%;
    margin-top: 3px;
  }
}
.c-table1__content .c-part1 {
  padding: 38px 0 39px;
  border-bottom: 1px solid #eef3f7;
}
@media only screen and (max-width: 767px) {
  .c-table1__content .c-part1 {
    padding: 22px 0 23px;
  }
}
.c-table1__content .c-part1:first-child {
  margin-top: 4px;
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .c-table1__content .c-part1:first-child {
    margin-top: 0;
  }
}
.c-table1__content .c-part1:last-child {
  margin-bottom: 2px;
  padding-bottom: 0;
  border-bottom: none;
}
.c-table1__content .c-btnmap {
  margin-top: 13px;
}
@media only screen and (max-width: 767px) {
  .c-table1__content .c-btnmap {
    margin-top: 14px;
  }
}
.c-table2 {
  width: 100%;
  border-collapse: collapse;
}
.c-table2__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  position: relative;
  width: 100%;
  min-height: 80px;
  vertical-align: top;
  padding: 26px 40px 25px;
  background-color: #fff;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  .c-table2__row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    min-height: unset;
    padding: 26px 20px 25px;
  }
}
.c-table2__row + .c-table2__row {
  margin-top: 4px;
}
.c-table2__field {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 156px;
  padding-right: 40px;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.03em;
  text-align: left;
}
@media only screen and (max-width: 767px) {
  .c-table2__field {
    -ms-flex-negative: unset;
    flex-shrink: unset;
    width: 100%;
    padding-right: 0;
  }
}
.c-table2__content {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  width: calc(100% - 156px);
  color: #333;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
@media only screen and (max-width: 767px) {
  .c-table2__content {
    -webkit-box-flex: unset;
    -ms-flex-positive: unset;
    flex-grow: unset;
    width: 100%;
    margin-top: 4px;
  }
}
.c-table2__content p + p {
  margin-top: 28.8px;
}
.c-table2__content p + p:has(.c-link2) {
  margin-top: 12px;
}
/*------------------------------------------------------------
    Tag
------------------------------------------------------------*/
.c-tag1 {
  display: inline-block;
  max-width: 100%;
  padding: 1px 3px 2px;
  background-color: transparent;
  border: 1px solid #003673;
  border-radius: 2px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #003673;
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1.31;
  letter-spacing: -0.02em;
  text-align: center;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.c-tag1--solid {
  background-color: var(--color);
  border-color: var(--color);
  color: #fff;
}
.c-tag1--solid.c-tag1--blue {
  background-color: #0a62c7;
  border-color: #0a62c7;
}
.c-tag1--solid.c-tag1--green {
  background-color: #00c5cc;
  border-color: #00c5cc;
}
.c-tag2 {
  display: inline-block;
  max-width: 100%;
  padding: 2px 3px 3px;
  background-color: transparent;
  border: 1px solid #003673;
  border-radius: 2px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: -0.02em;
  text-align: center;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.c-tag2--solid {
  background-color: var(--color);
  border-color: var(--color);
  color: #fff;
}
.c-tag2--solid.c-tag2--blue {
  background-color: #0a62c7;
  border-color: #0a62c7;
}
.c-tag2--solid.c-tag2--green {
  background-color: #00c5cc;
}
.c-tag2--new {
  padding: 3px 0.35rem 2px;
  background-color: #c70A44;
  border-color: #c70A44;
  color: #fff;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.11;
}
.c-tag3 {
  display: inline-block;
  position: relative;
  max-width: 100%;
  padding: 3px 4px 4px;
  background-color: #e6edf7;
  border-radius: 2px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: -0.02em;
  text-align: center;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
/*------------------------------------------------------------
    Text
------------------------------------------------------------*/
.c-text1 {
  color: #003673;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: -0.02em;
}
.c-text1--white {
  color: #fff;
}
.c-text1--black {
  color: #333;
}
.c-text2 {
  color: #333;
  font-size: 1.9rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-text3 {
  color: #333;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
/*------------------------------------------------------------
    Thumbnail
------------------------------------------------------------*/
.c-thumb--round {
  position: relative;
  width: 100%;
  background-color: #e6e6e6;
  overflow: hidden;
}
.c-thumb--round::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 100%;
}
.c-thumb--round img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
/*------------------------------------------------------------
    Timeline
------------------------------------------------------------*/
.c-timeline1__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  min-height: 48px;
}
@media only screen and (max-width: 767px) {
  .c-timeline1__row {
    min-height: 35px;
  }
}
.c-timeline1__row + .c-timeline1__row {
  margin-top: 26px;
}
@media only screen and (max-width: 767px) {
  .c-timeline1__row + .c-timeline1__row {
    margin-top: 24px;
  }
}
.c-timeline1__left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 228px;
}
@media only screen and (max-width: 767px) {
  .c-timeline1__left {
    width: 128px;
  }
}
.c-timeline1__year {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  position: relative;
  padding-right: 72px;
  color: #c2d0e0;
  font-size: 4.8rem;
  font-weight: 700;
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .c-timeline1__year {
    padding-right: 20px;
    font-size: 2.9rem;
    line-height: 1;
  }
}
.c-timeline1__year::after {
  content: "";
  position: absolute;
  top: 24px;
  right: 0;
  width: 64px;
  height: 1px;
  background-color: #c2d0e0;
}
@media only screen and (max-width: 767px) {
  .c-timeline1__year::after {
    top: 17px;
    width: 16px;
  }
}
.c-timeline1__month {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 44px;
  padding-left: 4px;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: -0.02em;
  text-align: right;
}
@media only screen and (max-width: 1023px) {
  .c-timeline1__month {
    -webkit-transform: translateY(1px);
    transform: translateY(1px);
  }
}
@media only screen and (max-width: 767px) {
  .c-timeline1__month {
    width: 40px;
  }
}
.c-timeline1__right {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  width: calc(100% - 228px);
  padding: 10px 0 0 16px;
}
@media only screen and (max-width: 767px) {
  .c-timeline1__right {
    width: calc(100% - 128px);
    padding: 1px 0 0 16px;
  }
}
.c-timeline2__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
.c-timeline2__row + .c-timeline2__row {
  margin-top: 16px;
}
@media only screen and (max-width: 767px) {
  .c-timeline2__row + .c-timeline2__row {
    margin-top: 14px;
  }
}
.c-timeline2__left {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 97px;
  padding-right: 8px;
}
.c-timeline2__time {
  display: inline-block;
  position: relative;
  width: 100%;
  padding: 3px 15px 5px;
  background-color: #7c98b8;
  border-radius: 16px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.03em;
  text-align: right;
}
.c-timeline2__right {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  position: relative;
  width: calc(100% - 97px);
  padding-left: 48px;
}
@media only screen and (max-width: 767px) {
  .c-timeline2__right {
    padding-left: 28px;
  }
}
.c-timeline2__right::before {
  content: "";
  position: absolute;
  top: 14px;
  left: 0;
  width: 40px;
  height: 1px;
  background-color: #c2d0e0;
}
@media only screen and (max-width: 767px) {
  .c-timeline2__right::before {
    width: 20px;
  }
}
/*------------------------------------------------------------
    Title
------------------------------------------------------------*/
.c-title1--white .c-title1__ja {
  color: #fff;
}
.c-title1--white .c-title1__en {
  background: unset;
  opacity: 0.5;
  color: transparent;
  -webkit-text-stroke: 1px #fff;
}
.c-title1__ja {
  display: block;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.03em;
}
.c-title1__en {
  display: block;
  margin-top: -7px;
  background: transparent -webkit-gradient(linear, left top, right top, from(#004594), to(#0a62c7)) 0% 0% no-repeat padding-box;
  background: transparent -webkit-linear-gradient(left, #004594 0%, #0a62c7 100%) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(90deg, #004594 0%, #0a62c7 100%) 0% 0% no-repeat padding-box;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-size: 11.9rem;
  font-weight: 700;
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .c-title1__en {
    margin-top: -8px;
    font-size: 7rem;
  }
}
@media only screen and (max-width: 374px) {
  .c-title1__en {
    margin-top: -5px;
    font-size: 5.8rem;
  }
}
.c-title1__en--small {
  margin-top: -2px;
  font-size: 5.7rem;
}
@media only screen and (max-width: 767px) {
  .c-title1__en--small {
    margin-top: -3px;
    font-size: 5.5rem;
  }
}
.c-title2 {
  color: #003673;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
@media only screen and (max-width: 767px) {
  .c-title2 {
    font-size: 2.9rem;
  }
}
.c-title3 {
  color: #003673;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.23;
  letter-spacing: -0.02em;
}
.c-title4 {
  color: #003673;
  font-size: 2.3rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-title5 {
  display: block;
  position: relative;
  width: 100%;
  padding: 7px 16px 9px 44px;
  background-color: #f0f5fc;
  border-radius: 20px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.c-title5::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 10px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background-color: #fff;
  border-radius: 50%;
}
@media only screen and (max-width: 767px) {
  .c-title5--style1 {
    padding: 7px 4px 9px 38px;
  }
}
/*≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡
// Project .p-
≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡*/
/*------------------------------------------------------------
    CSS of Top page
------------------------------------------------------------*/
/*------------------------------------------------------------
    CSS of Service section
------------------------------------------------------------*/
.top-service {
  position: relative;
  padding: 60px 0 0;
}
@media only screen and (max-width: 1023px) {
  .top-service {
    padding: 0;
  }
}
@media only screen and (max-width: 1023px) {
  .top-service .c-particle1 {
    margin-top: -88px;
  }
}
@media only screen and (max-width: 767px) {
  .top-service .c-particle1 {
    margin-top: -117px;
  }
}
.top-service__heading {
  position: relative;
  margin-top: -132px;
  z-index: 1;
}
@media only screen and (max-width: 1023px) {
  .top-service__heading {
    margin-top: -131px;
  }
}
@media only screen and (max-width: 767px) {
  .top-service__heading {
    margin-top: -85px;
  }
}
.top-service__description {
  margin-top: 13px;
}
@media only screen and (max-width: 767px) {
  .top-service__description {
    margin-top: 17px;
  }
}
.top-service__body {
  margin-top: 38px;
}
.top-service__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  margin: 0 -1px;
}
@media only screen and (max-width: 1023px) {
  .top-service__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin: 0;
  }
}
.top-service__item {
  width: calc(50% - 2px);
  margin: 0 1px;
}
@media only screen and (max-width: 1023px) {
  .top-service__item {
    width: 100%;
    margin: 0;
  }
}
@media only screen and (max-width: 1023px) {
  .top-service__item + .top-service__item {
    margin-top: 9px;
  }
}
@media only screen and (max-width: 767px) {
  .top-service__item + .top-service__item {
    margin-top: 18px;
  }
}
.top-service__item:nth-child(2) .c-card1 {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}
@media only screen and (max-width: 1023px) {
  .top-service__item:nth-child(2) .c-card1 {
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
  }
}
/*------------------------------------------------------------
    CSS of Company section
------------------------------------------------------------*/
.top-company {
  position: relative;
  padding: 169px 0 0;
  overflow: hidden;
}
@media only screen and (max-width: 1023px) {
  .top-company {
    padding: 97px 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .top-company {
    padding: 39px 0 0;
  }
}
.top-company__inner {
  position: relative;
}
.top-company__heading {
  position: relative;
  margin-top: -352px;
  z-index: 1;
}
@media only screen and (max-width: 1023px) {
  .top-company__heading {
    margin-top: -196px;
  }
}
@media only screen and (max-width: 767px) {
  .top-company__heading {
    margin-top: -85px;
  }
}
.top-company__body {
  margin-top: 38px;
}
@media only screen and (max-width: 1023px) {
  .top-company__body {
    margin-top: 37px;
  }
}
.top-company__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media only screen and (max-width: 1023px) {
  .top-company__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
.top-company__left {
  width: 56.25%;
  min-width: 560px;
  padding-right: 40px;
}
@media only screen and (max-width: 1023px) {
  .top-company__left {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    width: 100%;
    min-width: unset;
    margin-top: 16px;
    padding-right: 0;
  }
}
@media only screen and (max-width: 767px) {
  .top-company__left {
    margin-top: 24px;
  }
}
.top-company__left .c-nav3 {
  max-width: 640px;
  margin-right: auto;
}
@media only screen and (max-width: 1023px) {
  .top-company__left .c-nav3 {
    max-width: unset;
    margin-right: 0;
  }
}
.top-company__right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  width: 43.75%;
  margin-top: 24px;
}
@media only screen and (max-width: 1023px) {
  .top-company__right {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    width: 100%;
    margin-top: 0;
  }
}
.top-company__thumb {
  position: relative;
  width: 100%;
  background-color: #e6e6e6;
  overflow: hidden;
}
@media only screen and (max-width: 1023px) {
  .top-company__thumb {
    max-width: unset;
  }
}
.top-company__thumb::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 100%;
}
@media only screen and (max-width: 1023px) {
  .top-company__thumb::before {
    padding-top: 77.7777777778%;
  }
}
@media only screen and (max-width: 767px) {
  .top-company__thumb::before {
    padding-top: 78.1341107872%;
  }
}
.top-company__thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
/*------------------------------------------------------------
    CSS of Careers section
------------------------------------------------------------*/
.top-careers {
  position: relative;
  padding: 40px 0 0;
  overflow: hidden;
}
@media only screen and (max-width: 1023px) {
  .top-careers {
    padding: 64px 0 0;
  }
}
.top-careers__box {
  margin-top: -80px;
  z-index: 1;
}
@media only screen and (max-width: 1023px) {
  .top-careers__box {
    margin-top: -70px;
  }
}
.top-careers__heading {
  margin-top: 38px;
}
@media only screen and (max-width: 1023px) {
  .top-careers__heading {
    margin-top: 0;
  }
}
.top-careers__description {
  margin-top: 13px;
}
@media only screen and (max-width: 767px) {
  .top-careers__description {
    margin-top: 18px;
  }
}
.top-careers__btn {
  margin-top: 61px;
}
@media only screen and (max-width: 1023px) {
  .top-careers__btn {
    margin-top: 38px;
  }
}
@media only screen and (max-width: 767px) {
  .top-careers__btn {
    margin-top: 37px;
  }
}
/*------------------------------------------------------------
    CSS of Jobinfo section
------------------------------------------------------------*/
.top-jobinfo {
  position: relative;
  padding: 110px 0 200px;
}
@media only screen and (max-width: 1023px) {
  .top-jobinfo {
    padding: 62px 0 128px;
  }
}
.top-jobinfo__inner {
  margin-left: max(0px, (100% - 1360px) / 2);
  padding-left: 40px;
}
@media only screen and (max-width: 1023px) {
  .top-jobinfo__inner {
    margin: 0 auto;
    padding-right: 40px;
  }
}
@media only screen and (max-width: 767px) {
  .top-jobinfo__inner {
    padding: 0 16px;
  }
}
.top-jobinfo__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
@media only screen and (max-width: 1023px) {
  .top-jobinfo__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}
.top-jobinfo__left {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 440px;
  padding-right: 40px;
}
@media only screen and (max-width: 1023px) {
  .top-jobinfo__left {
    -ms-flex-negative: unset;
    flex-shrink: unset;
    width: 100%;
    padding-right: 0;
  }
}
.top-jobinfo__description {
  margin-top: 17px;
}
.top-jobinfo__btn {
  margin-top: 61px;
}
@media only screen and (max-width: 1023px) {
  .top-jobinfo__btn {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    margin-top: 0;
    margin-left: auto;
  }
}
@media only screen and (max-width: 374px) {
  .top-jobinfo__btn {
    margin-top: 24px;
    margin-left: auto;
  }
}
.top-jobinfo__right {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  margin-top: 34px;
  overflow: hidden;
}
@media only screen and (max-width: 1023px) {
  .top-jobinfo__right {
    -webkit-box-flex: unset;
    -ms-flex-positive: unset;
    flex-grow: unset;
    width: 100%;
    margin-top: 37px;
    overflow: unset;
  }
}
@media only screen and (max-width: 767px) {
  .top-jobinfo__right {
    margin-top: 38px;
  }
}
.top-jobinfo__rightinner {
  width: 100%;
  max-width: 880px;
  margin-right: auto;
  padding-right: 40px;
}
@media only screen and (max-width: 1023px) {
  .top-jobinfo__rightinner {
    max-width: unset;
    margin-right: 0;
    padding-right: 0;
  }
}
@media only screen and (max-width: 1023px) {
  .top-jobinfo__slider {
    margin: 0 -40px;
    padding: 0 40px;
  }
}
@media only screen and (max-width: 767px) {
  .top-jobinfo__slider {
    margin: 0 -16px;
    padding: 0 16px;
  }
}
.top-jobinfo__slider .swiper-wrapper {
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
}
.top-jobinfo__slide {
  width: 346px;
  height: auto;
  padding-bottom: 23px;
  border-bottom: 1px solid #e4e9f0;
}
@media only screen and (max-width: 767px) {
  .top-jobinfo__slide {
    width: auto;
    padding-bottom: 24px;
  }
}
.top-jobinfo__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
}
@media only screen and (max-width: 767px) {
  .top-jobinfo__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.top-jobinfo__item {
  width: 346px;
}
@media only screen and (max-width: 767px) {
  .top-jobinfo__item {
    width: 100%;
  }
}
.top-jobinfo__control {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  width: 100%;
  max-width: 920px;
  margin-top: 40px;
  margin-right: auto;
  padding-right: 40px;
}
@media only screen and (max-width: 1023px) {
  .top-jobinfo__control {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    max-width: unset;
    padding-right: 0;
  }
}
.top-jobinfo__control .c-slider1 {
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
@media only screen and (max-width: 1023px) {
  .top-jobinfo__control .c-slider1 {
    margin-right: 20px;
  }
}
/*------------------------------------------------------------
    CSS of Service page
------------------------------------------------------------*/
/*------------------------------------------------------------
    CSS of Heading section
------------------------------------------------------------*/
.service-heading {
  position: relative;
  padding: 104px 0 0;
}
@media only screen and (max-width: 767px) {
  .service-heading {
    padding: 68px 0 0;
  }
}
/*------------------------------------------------------------
    CSS of Building section
------------------------------------------------------------*/
.service-building {
  position: relative;
  padding: 43px 0 104px;
}
@media only screen and (max-width: 1023px) {
  .service-building {
    padding: 32px 0 104px;
  }
}
@media only screen and (max-width: 767px) {
  .service-building {
    padding: 41px 0 68px;
  }
}
.service-building__body {
  margin-top: 54px;
}
@media only screen and (max-width: 767px) {
  .service-building__body {
    margin-top: 37px;
  }
}
.service-building__description {
  margin-top: 38px;
}
@media only screen and (max-width: 767px) {
  .service-building__description {
    margin-top: 22px;
  }
}
.service-building__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.service-building__item {
  width: 100%;
  padding: 56px 0;
  border-bottom: 3px solid #eef3f7;
}
@media only screen and (max-width: 767px) {
  .service-building__item {
    padding: 40px 0;
  }
}
.service-building__item:first-child {
  border-top: 3px solid #eef3f7;
}
/*------------------------------------------------------------
    CSS of Cleaning section
------------------------------------------------------------*/
.service-cleaning {
  position: relative;
  padding: 95px 0 200px;
}
@media only screen and (max-width: 1023px) {
  .service-cleaning {
    padding: 22px 0 128px;
  }
}
@media only screen and (max-width: 767px) {
  .service-cleaning {
    padding: 60px 0 128px;
  }
}
.service-cleaning__description {
  margin-top: 38px;
}
@media only screen and (max-width: 767px) {
  .service-cleaning__description {
    margin-top: 22px;
  }
}
.service-cleaning__body {
  margin-top: 54px;
  padding: 56px 0 53px;
  border-top: 3px solid #eef3f7;
  border-bottom: 3px solid #eef3f7;
}
@media only screen and (max-width: 1023px) {
  .service-cleaning__body {
    padding: 56px 0 54px;
  }
}
@media only screen and (max-width: 767px) {
  .service-cleaning__body {
    margin-top: 37px;
    padding: 40px 0 37px;
  }
}
.service-cleaning__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  margin: 24px -20px -45px;
}
@media only screen and (max-width: 1023px) {
  .service-cleaning__list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
@media only screen and (max-width: 767px) {
  .service-cleaning__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin: 24px 0 0;
  }
}
.service-cleaning__item {
  width: calc(25% - 40px);
  margin: 0 20px 45px;
}
@media only screen and (max-width: 1023px) {
  .service-cleaning__item {
    width: calc(50% - 40px);
  }
}
@media only screen and (max-width: 767px) {
  .service-cleaning__item {
    width: 100%;
    margin: 0;
  }
}
@media only screen and (max-width: 767px) {
  .service-cleaning__item + .service-cleaning__item {
    margin-top: 37px;
  }
}
/*------------------------------------------------------------
    CSS of Company page
------------------------------------------------------------*/
/*------------------------------------------------------------
    CSS of Heading section
------------------------------------------------------------*/
.company-heading {
  position: relative;
  padding: 104px 0 0;
}
@media only screen and (max-width: 767px) {
  .company-heading {
    padding: 68px 0 0;
  }
}
/*------------------------------------------------------------
    CSS of Message section
------------------------------------------------------------*/
.company-message {
  position: relative;
  padding: 43px 0 0;
  overflow: hidden;
}
@media only screen and (max-width: 1023px) {
  .company-message {
    padding: 32px 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .company-message {
    padding: 41px 0 0;
  }
}
.company-message__description {
  margin-top: 16px;
}
.company-message__body {
  margin-top: 80px;
}
@media only screen and (max-width: 1023px) {
  .company-message__body {
    margin-top: 40px;
  }
}
.company-message__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
@media only screen and (max-width: 1023px) {
  .company-message__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.company-message__left {
  width: 56.25%;
  padding-right: 40px;
}
@media only screen and (max-width: 1023px) {
  .company-message__left {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    width: 100%;
    margin-top: 22px;
    padding-right: 0;
  }
}
@media only screen and (max-width: 767px) {
  .company-message__left {
    margin-top: 38px;
  }
}
.company-message__leftinner {
  width: 100%;
  max-width: 640px;
  margin-right: auto;
}
@media only screen and (max-width: 1023px) {
  .company-message__leftinner {
    max-width: unset;
    margin-right: 0;
  }
}
.company-message__text {
  margin-top: -2px;
}
@media only screen and (max-width: 1023px) {
  .company-message__text {
    margin-top: 0;
  }
}
.company-message__text p + p {
  margin-top: 28.8px;
}
.company-message__info {
  margin-top: 36px;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.03em;
}
@media only screen and (max-width: 1023px) {
  .company-message__info {
    margin-top: 20px;
  }
}
@media only screen and (max-width: 767px) {
  .company-message__info {
    margin-top: 19px;
  }
}
.company-message__right {
  width: 43.75%;
}
@media only screen and (max-width: 1023px) {
  .company-message__right {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    width: 100%;
  }
}
.company-message__thumb {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.company-message__thumb::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 100%;
}
@media only screen and (max-width: 1023px) {
  .company-message__thumb::before {
    padding-top: 77.7777777778%;
  }
}
@media only screen and (max-width: 767px) {
  .company-message__thumb::before {
    padding-top: 78.1341107872%;
  }
}
.company-message__thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
/*------------------------------------------------------------
    CSS of Outline section
------------------------------------------------------------*/
.company-outline {
  position: relative;
  padding: 203px 0 0;
}
@media only screen and (max-width: 1023px) {
  .company-outline {
    padding: 128px 0 0;
  }
}
.company-outline__body {
  margin-top: 59px;
  padding: 54px 0 53px;
  border-top: 3px solid #eef3f7;
  border-bottom: 3px solid #eef3f7;
}
@media only screen and (max-width: 1023px) {
  .company-outline__body {
    margin-top: 60px;
  }
}
@media only screen and (max-width: 767px) {
  .company-outline__body {
    margin-top: 44px;
    padding: 38px 0 37px;
  }
}
/*------------------------------------------------------------
    CSS of History section
------------------------------------------------------------*/
.company-history {
  position: relative;
  padding: 204px 0 200px;
}
@media only screen and (max-width: 1023px) {
  .company-history {
    padding: 131px 0 128px;
  }
}
.company-history__body {
  margin-top: 60px;
  padding: 61px 0;
  border-top: 3px solid #eef3f7;
  border-bottom: 3px solid #eef3f7;
}
@media only screen and (max-width: 767px) {
  .company-history__body {
    margin-top: 44px;
    padding: 43px 0 38px;
  }
}
/*------------------------------------------------------------
    CSS of Recruit page
------------------------------------------------------------*/
/*------------------------------------------------------------
    CSS of Heading section
------------------------------------------------------------*/
.recruit-heading {
  position: relative;
  padding: 104px 0 0;
}
@media only screen and (max-width: 767px) {
  .recruit-heading {
    padding: 68px 0 0;
  }
}
/*------------------------------------------------------------
    CSS of Greeting section
------------------------------------------------------------*/
.recruit-greeting {
  position: relative;
  padding: 43px 0 0;
}
@media only screen and (max-width: 1023px) {
  .recruit-greeting {
    padding: 32px 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .recruit-greeting {
    padding: 41px 0 0;
  }
}
.recruit-greeting__description {
  margin-top: 38px;
}
/*------------------------------------------------------------
    CSS of Jobdesc section
------------------------------------------------------------*/
.recruit-jobdesc {
  position: relative;
  padding: 200px 0 0;
}
@media only screen and (max-width: 1023px) {
  .recruit-jobdesc {
    padding: 128px 0 0;
  }
}
.recruit-jobdesc__description {
  margin-top: 28px;
}
.recruit-jobdesc__body {
  margin-top: 55px;
}
@media only screen and (max-width: 1023px) {
  .recruit-jobdesc__body {
    margin-top: 56px;
  }
}
@media only screen and (max-width: 767px) {
  .recruit-jobdesc__body {
    margin-top: 39px;
  }
}
.recruit-jobdesc__blockhead .c-note1 {
  margin-top: 24px;
}
.recruit-jobdesc__blockmain {
  margin-top: 55px;
}
@media only screen and (max-width: 767px) {
  .recruit-jobdesc__blockmain {
    margin-top: 39px;
  }
}
.recruit-jobdesc__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.recruit-jobdesc__item {
  width: 100%;
  padding: 56px 0;
  border-bottom: 3px solid #eef3f7;
}
@media only screen and (max-width: 767px) {
  .recruit-jobdesc__item {
    padding: 40px 0;
  }
}
.recruit-jobdesc__item:first-child {
  border-top: 3px solid #eef3f7;
}
@media only screen and (max-width: 1023px) {
  .recruit-jobdesc__item:first-child {
    padding-top: 0;
    border-top: none;
  }
}
/*------------------------------------------------------------
    CSS of Workstyle section
------------------------------------------------------------*/
.recruit-workstyle {
  position: relative;
  padding: 203px 0 0;
}
@media only screen and (max-width: 1023px) {
  .recruit-workstyle {
    padding: 131px 0 0;
  }
}
.recruit-workstyle__description {
  margin-top: 28px;
}
.recruit-workstyle__listcheck {
  margin-top: 23px;
}
@media only screen and (max-width: 767px) {
  .recruit-workstyle__listcheck {
    margin-top: 24px;
  }
}
.recruit-workstyle__body {
  margin-top: 56px;
}
@media only screen and (max-width: 767px) {
  .recruit-workstyle__body {
    margin-top: 40px;
  }
}
.recruit-workstyle__blockmain {
  margin-top: 24px;
}
.recruit-workstyle__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
@media only screen and (max-width: 1023px) {
  .recruit-workstyle__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.recruit-workstyle__left {
  width: 56.25%;
  margin-top: 1px;
  padding-right: 40px;
}
@media only screen and (max-width: 1023px) {
  .recruit-workstyle__left {
    width: 100%;
    padding-right: 0;
  }
}
@media only screen and (max-width: 767px) {
  .recruit-workstyle__left {
    margin-top: 0;
  }
}
.recruit-workstyle__leftinner {
  width: 100%;
  max-width: 640px;
  margin-right: auto;
}
@media only screen and (max-width: 1023px) {
  .recruit-workstyle__leftinner {
    max-width: unset;
    margin-right: 0;
  }
}
.recruit-workstyle__right {
  width: 43.75%;
}
@media only screen and (max-width: 1023px) {
  .recruit-workstyle__right {
    width: 100%;
    margin-top: 39px;
  }
}
@media only screen and (max-width: 767px) {
  .recruit-workstyle__right {
    margin-top: 40px;
  }
}
.recruit-workstyle__thumbgroup {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.recruit-workstyle__thumbgroup::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 100%;
}
@media only screen and (max-width: 1023px) {
  .recruit-workstyle__thumbgroup::before {
    content: none;
  }
}
.recruit-workstyle__thumbmain {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 78.5714285714%;
  height: 78.5714285714%;
}
@media only screen and (max-width: 1023px) {
  .recruit-workstyle__thumbmain {
    position: relative;
    bottom: unset;
    left: unset;
    width: 100%;
    height: auto;
  }
}
.recruit-workstyle__thumbsub {
  position: absolute;
  top: 0;
  right: 0;
  width: 35.7142857143%;
  height: 35.7142857143%;
  z-index: 1;
}
.recruit-workstyle__thumb {
  position: relative;
  width: 100%;
  background-color: #e6e6e6;
  overflow: hidden;
}
.recruit-workstyle__thumb::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 100%;
}
@media only screen and (max-width: 1023px) {
  .recruit-workstyle__thumb::before {
    padding-top: 77.7777777778%;
  }
}
@media only screen and (max-width: 767px) {
  .recruit-workstyle__thumb::before {
    padding-top: 78.1341107872%;
  }
}
.recruit-workstyle__thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
/*------------------------------------------------------------
    CSS of Main section
------------------------------------------------------------*/
.recruit-main {
  position: relative;
  padding: 203px 0 139px;
}
@media only screen and (max-width: 1023px) {
  .recruit-main {
    padding: 131px 0 126px;
  }
}
.recruit-main__body {
  margin-top: 60px;
  padding: 54px 0 53px;
  border-top: 3px solid #eef3f7;
  border-bottom: 3px solid #eef3f7;
}
@media only screen and (max-width: 1023px) {
  .recruit-main__body {
    margin-top: 60px;
  }
}
@media only screen and (max-width: 767px) {
  .recruit-main__body {
    margin-top: 44px;
    padding: 38px 0 37px;
  }
}
.recruit-main__block {
  margin-top: 56px;
}
@media only screen and (max-width: 767px) {
  .recruit-main__block {
    margin-top: 40px;
  }
}
.recruit-main__blockmain {
  margin-top: 22px;
}
.recruit-main__blockcontent p + p {
  margin-top: 28.8px;
}
/*------------------------------------------------------------
    CSS of Job page
------------------------------------------------------------*/
/*------------------------------------------------------------
    CSS of Heading section
------------------------------------------------------------*/
.job-heading {
  position: relative;
  padding: 104px 0 0;
}
@media only screen and (max-width: 767px) {
  .job-heading {
    padding: 68px 0 0;
  }
}
/*------------------------------------------------------------
    CSS of Archive section
------------------------------------------------------------*/
.job-archive {
  position: relative;
  padding: 127px 0 200px;
}
@media only screen and (max-width: 1023px) {
  .job-archive {
    padding: 63px 0 128px;
  }
}
@media only screen and (max-width: 767px) {
  .job-archive {
    padding: 39px 0 128px;
  }
}
.job-archive__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  margin: 0 -32px -80px;
}
@media only screen and (max-width: 1023px) {
  .job-archive__list {
    margin: 0 -32px -64px;
  }
}
@media only screen and (max-width: 767px) {
  .job-archive__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin: 0;
  }
}
.job-archive__item {
  width: calc(33.3333333333% - 64px);
  margin: 0 32px 80px;
  padding-bottom: 19px;
  border-bottom: 1px solid #e4e9f0;
}
@media only screen and (max-width: 1023px) {
  .job-archive__item {
    width: calc(50% - 64px);
    margin: 0 32px 64px;
  }
}
@media only screen and (max-width: 767px) {
  .job-archive__item {
    width: 100%;
    margin: 0;
  }
}
@media only screen and (max-width: 767px) {
  .job-archive__item + .job-archive__item {
    margin-top: 40px;
  }
}
.job-archive__item:nth-child(3n+2) {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}
@media only screen and (max-width: 1023px) {
  .job-archive__item:nth-child(3n+2) {
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
  }
}
.job-archive__item:nth-child(3n) {
  -webkit-transition-delay: 0.6s;
  transition-delay: 0.6s;
}
@media only screen and (max-width: 1023px) {
  .job-archive__item:nth-child(3n) {
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
  }
}
@media only screen and (max-width: 1023px) {
  .job-archive__item:nth-child(2n) {
    -webkit-transition-delay: 0.4s;
    transition-delay: 0.4s;
  }
}
@media only screen and (max-width: 767px) {
  .job-archive__item:nth-child(2n) {
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
  }
}
/*------------------------------------------------------------
    CSS of Single section
------------------------------------------------------------*/
.job-single {
  position: relative;
  padding: 127px 0 200px;
}
@media only screen and (max-width: 1023px) {
  .job-single {
    padding: 63px 0 128px;
  }
}
@media only screen and (max-width: 767px) {
  .job-single {
    padding: 39px 0 126px;
  }
}
.job-single__btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 128px;
}
@media only screen and (max-width: 1023px) {
  .job-single__btn {
    margin-top: 64px;
  }
}
@media only screen and (max-width: 767px) {
  .job-single__btn {
    margin-top: 40px;
  }
}
/*------------------------------------------------------------
    CSS of Contact page
------------------------------------------------------------*/
/*------------------------------------------------------------
    CSS of Heading section
------------------------------------------------------------*/
.contact-heading {
  position: relative;
  padding: 104px 0 0;
}
@media only screen and (max-width: 767px) {
  .contact-heading {
    padding: 68px 0 0;
  }
}
/*------------------------------------------------------------
    CSS of Form section
------------------------------------------------------------*/
.contact-form {
  position: relative;
  padding: 44px 0 200px;
}
@media only screen and (max-width: 1023px) {
  .contact-form {
    padding: 33px 0 128px;
  }
}
@media only screen and (max-width: 767px) {
  .contact-form {
    padding: 41px 0 128px;
  }
}
@media only screen and (max-width: 1023px) {
  .contact-form__box {
    margin: 0 -40px;
  }
}
@media only screen and (max-width: 767px) {
  .contact-form__box {
    margin: 0 -16px;
  }
}
.mw_wp_form .c-radio__group .horizontal-item + .horizontal-item {
  margin-left: 0;
}
.mw_wp_form .c-checkbox__group .horizontal-item + .horizontal-item {
  margin-left: 0;
}
.mw_wp_form_confirm .c-input,
.mw_wp_form_confirm .c-radio__group,
.mw_wp_form_confirm .c-checkbox__group {
  width: 100%;
  min-height: 24px;
  margin-top: 0;
  color: #003673;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
.mw_wp_form_confirm .c-box3__field {
  margin-top: 14px;
}
.mw_wp_form_confirm .c-box3__accept .c-checkbox__group {
  margin-top: 4px;
}
.mw_wp_form_confirm .c-box3__row6 .c-input__item:nth-child(2) {
  display: none;
}
.grecaptcha-badge {
  z-index: 2;
}
/*------------------------------------------------------------
    CSS of Privacy page
------------------------------------------------------------*/
/*------------------------------------------------------------
    CSS of Heading section
------------------------------------------------------------*/
.privacy-heading {
  position: relative;
  padding: 104px 0 0;
}
@media only screen and (max-width: 767px) {
  .privacy-heading {
    padding: 68px 0 0;
  }
}
/*------------------------------------------------------------
    CSS of Policy section
------------------------------------------------------------*/
.privacy-policy {
  position: relative;
  padding: 0 0 200px;
}
@media only screen and (max-width: 1023px) {
  .privacy-policy {
    padding: 0 0 128px;
  }
}
@media only screen and (max-width: 767px) {
  .privacy-policy {
    padding: 20px 0 128px;
  }
}
.privacy-policy__row {
  position: relative;
  width: 100%;
  padding: 56px 0;
  border-top: 3px solid #eef3f7;
}
@media only screen and (max-width: 767px) {
  .privacy-policy__row {
    padding: 28px 0;
  }
}
.privacy-policy__row:last-child {
  padding-bottom: 0;
}
.privacy-policy__content {
  margin-top: 22px;
}
.privacy-policy__content > p {
  margin-bottom: -3px;
}
.privacy-policy__content .c-box4 {
  margin-top: 12px;
}
/*≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡
// Utility .u-
≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡*/
/*------------------------------------------------------------
    Display
------------------------------------------------------------*/
.u-none {
  display: none;
}
/*------------------------------------------------------------
    Background
------------------------------------------------------------*/
/*------------------------------------------------------------
    Spacing
------------------------------------------------------------*/
/*------------------------------------------------------------
    Font
------------------------------------------------------------*/
.u-barlow {
  font-family: "Barlow", "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
.u-palt {
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
}
/*------------------------------------------------------------
    Text
------------------------------------------------------------*/
.u-medium {
  font-weight: 500;
}
.u-aligncenter {
  text-align: center;
}
/*------------------------------------------------------------
    Animation
------------------------------------------------------------*/
[data-animation] {
  -webkit-transition-duration: 1s;
  transition-duration: 1s;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}
[data-animation][data-animation-type=fadeIn] {
  -webkit-transition-property: opacity;
  transition-property: opacity;
  opacity: 0;
}
[data-animation=after][data-animation-type=fadeIn] {
  opacity: 1;
}
[data-animation][data-animation-type=fadeInRight] {
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transform: translateX(-20px);
  transform: translateX(-20px);
  opacity: 0;
}
[data-animation=after][data-animation-type=fadeInRight] {
  -webkit-transform: translateX(0);
  transform: translateX(0);
  opacity: 1;
}
[data-animation][data-animation-type=fadeInLeft] {
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transform: translateX(20px);
  transform: translateX(20px);
  opacity: 0;
}
[data-animation=after][data-animation-type=fadeInLeft] {
  -webkit-transform: translateX(0);
  transform: translateX(0);
  opacity: 1;
}
[data-animation][data-animation-type=fadeInUp] {
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transform: translateY(20px);
  transform: translateY(20px);
  opacity: 0;
}
[data-animation=after][data-animation-type=fadeInUp] {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  opacity: 1;
}
[data-animation][data-animation-type=fadeInScale] {
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transform: translateY(20px);
  transform: translateY(20px);
  opacity: 0;
}
[data-animation][data-animation-type=fadeInScale] img {
  opacity: 0;
  -webkit-transform: scale(1.04) translateY(13px);
  transform: scale(1.04) translateY(13px);
  -webkit-transition: opacity 0.8s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 1.2s cubic-bezier(0.33, 1, 0.68, 1);
  transition: opacity 0.8s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 1.2s cubic-bezier(0.33, 1, 0.68, 1);
  transition: transform 1.2s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.8s cubic-bezier(0.3, 0.1, 0.2, 1);
  transition: transform 1.2s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.8s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 1.2s cubic-bezier(0.33, 1, 0.68, 1);
}
[data-animation=after][data-animation-type=fadeInScale] {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  opacity: 1;
}
[data-animation=after][data-animation-type=fadeInScale] img {
  opacity: 1;
  -webkit-transform: scale(1) translateY(0);
  transform: scale(1) translateY(0);
}
[data-animation][data-animation-type=fadeInZoom] {
  -webkit-transition-property: opacity;
  transition-property: opacity;
  opacity: 0;
}
[data-animation][data-animation-type=fadeInZoom] img {
  opacity: 0;
  -webkit-transform: scale(1.04) translateY(13px);
  transform: scale(1.04) translateY(13px);
  -webkit-transition: opacity 0.8s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 1.2s cubic-bezier(0.33, 1, 0.68, 1);
  transition: opacity 0.8s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 1.2s cubic-bezier(0.33, 1, 0.68, 1);
  transition: transform 1.2s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.8s cubic-bezier(0.3, 0.1, 0.2, 1);
  transition: transform 1.2s cubic-bezier(0.33, 1, 0.68, 1), opacity 0.8s cubic-bezier(0.3, 0.1, 0.2, 1), -webkit-transform 1.2s cubic-bezier(0.33, 1, 0.68, 1);
}
[data-animation=after][data-animation-type=fadeInZoom] {
  opacity: 1;
}
[data-animation=after][data-animation-type=fadeInZoom] img {
  opacity: 1;
  -webkit-transform: scale(1) translateY(0);
  transform: scale(1) translateY(0);
}
[data-animation][data-animation-type=fadeZoomOut] {
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
  opacity: 0;
}
[data-animation=after][data-animation-type=fadeZoomOut] {
  -webkit-transform: scale(1);
  transform: scale(1);
  opacity: 1;
}
[data-animation][data-animation-type=fadeZoomIn] {
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transform: scale(0.85);
  transform: scale(0.85);
  opacity: 0;
}
[data-animation=after][data-animation-type=fadeZoomIn] {
  -webkit-transform: scale(1);
  transform: scale(1);
  opacity: 1;
}
[data-animation][data-animation-type=scaleImage] img {
  -webkit-transition-duration: 1.84s;
  transition-duration: 1.84s;
  -webkit-transition-timing-function: cubic-bezier(0.33, 1, 0.68, 1);
  transition-timing-function: cubic-bezier(0.33, 1, 0.68, 1);
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transform: scale(1.04) translateY(13px);
  transform: scale(1.04) translateY(13px);
  opacity: 0;
}
[data-animation=after][data-animation-type=scaleImage] img {
  -webkit-transform: scale(1) translateY(0);
  transform: scale(1) translateY(0);
  opacity: 1;
}
@media only screen and (max-width: 1023px) {
  .is-pc {
    display: none;
  }
}
.is-notpc {
  display: none;
}
@media only screen and (max-width: 1023px) {
  .is-notpc {
    display: block;
  }
}
.is-sp {
  display: none;
}
@media only screen and (max-width: 767px) {
  .is-sp {
    display: block;
  }
}
@media only screen and (max-width: 767px) {
  .is-notsp {
    display: none;
  }
}
.is-xsp {
  display: none;
}
@media only screen and (max-width: 374px) {
  .is-xsp {
    display: block;
  }
}
.is-phone {
  pointer-events: none;
}
@media only screen and (max-width: 1023px) {
  .is-phone {
    pointer-events: unset;
  }
}