@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Quantico:wght@400;700&display=swap");
/**************
Sass Mixin
**************/
/**************
Basic Setting
**************/
html {
  font-size: 62.5%;
}
html * {
  box-sizing: border-box;
  word-wrap: break-word;
}

body {
  color: #191718;
  font-size: 1.6em;
  font-family: -apple-system-body, BlinkMacSystemFont, "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.8;
  padding: 0;
  margin: 0;
  vertical-align: baseline;
  font-feature-settings: "palt";
  letter-spacing: 0.08em;
}
body.admin-bar {
  position: relative;
}

select,
input,
button,
textarea {
  font: 99% sans-serif;
}

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

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

img {
  max-width: 100%;
}

#pagetop {
  background: url(../images/common/pagetop2.png);
  background-size: contain;
  position: fixed;
  right: 8px;
  text-indent: -9999px;
  outline: none;
  opacity: 0.7;
  z-index: 3;
}
@media (min-width: 560px) {
  #pagetop {
    width: 60px;
    height: 60px;
    bottom: -60px;
  }
}
@media (max-width: 820.9px) {
  #pagetop {
    width: 40px;
    height: 40px;
    bottom: -50px;
  }
}
#pagetop a {
  display: block;
  width: 100%;
  height: 100%;
  text-indent: -9999px;
}

a {
  text-decoration: none;
  color: #1d56c6;
  outline: none;
  font-weight: bold;
}
a:hover {
  color: #5f79ad;
}

/**************
Layout Set
**************/
.wrap {
  width: 84%;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 1160px) {
  .wrap {
    max-width: 1040px;
  }
  .wrap.w1300 {
    max-width: 1300px;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .wrap {
    width: 92%;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .wrap {
    width: 92%;
  }
}
@media (max-width: 559.9px) {
  .wrap {
    width: 88%;
  }
}

.middlewrap {
  width: 92%;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 559.9px) {
  .middlewrap {
    width: 88%;
  }
}

.shortwrap {
  width: 92%;
  max-width: 856px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 559.9px) {
  .shortwrap {
    width: 88%;
  }
}

.page_section {
  padding: 48px 0 80px;
  width: 100%;
  position: relative;
}
@media (max-width: 820.9px) {
  .page_section {
    padding: 40px 0 40px;
  }
}
.page_section__white {
  background-color: #fff;
}
.page_section__gray {
  background-color: #f3f3f3;
}
.page_section__blue {
  background-color: #C5DAF1;
}
.page_section__grad {
  background: linear-gradient(93deg, #d4f21a 14.4%, #f786b6 100.34%);
}

/**************
Header
**************/
#header {
  z-index: 10;
  width: calc(100% - 120px);
  height: 86px;
  padding: 0;
  transition: all 0.6s cubic-bezier(0.445, 0.05, 0.55, 0.95);
  background-color: white;
  position: absolute;
  right: 24px;
  top: 16px;
  border-radius: 8px;
}
@media (max-width: 1159.9px) {
  #header {
    display: none;
  }
}

.header_inner {
  position: relative;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media (min-width: 1160px) {
  .header_inner {
    padding: 0 24px;
  }
}
@media (max-width: 1159.9px) {
  .header_inner {
    width: 100%;
    padding-left: 16px;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .header_inner {
    padding-right: 128px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .header_inner {
    padding-right: 88px;
  }
}

.header_logo {
  text-align: center;
  transition: all 0.2s cubic-bezier(0.445, 0.05, 0.55, 0.95);
}
@media (min-width: 821px) {
  .header_logo {
    width: 155px;
  }
}
@media (max-width: 820.9px) {
  .header_logo {
    position: relative;
    z-index: 4;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .header_logo {
    width: 120px;
  }
}
@media (max-width: 559.9px) {
  .header_logo {
    width: 100px;
  }
}
.header_logo img {
  display: block;
  max-width: 100%;
  transition: opacity 0.2s cubic-bezier(0.445, 0.05, 0.55, 0.95);
  opacity: 1;
  padding-top: 10px;
}
.header_logo .logo_address {
  font-size: 1rem;
  color: #14A5F4;
  margin-top: 3px;
}
.fixed .header_logo {
  background: url(../images/common/logo.png) no-repeat center;
  background-size: contain;
}
.fixed .header_logo img {
  opacity: 0;
}

@media (min-width: 1160px) {
  .global_navi {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    transition: all 0.2s cubic-bezier(0.445, 0.05, 0.55, 0.95);
  }
  .fixed .global_navi {
    margin-top: 0;
  }
}
@media (max-width: 1159.9px) {
  .global_navi {
    display: none;
  }
}

.navi_ul {
  position: relative;
}
@media (min-width: 1440px) {
  .navi_ul {
    gap: 6px;
    margin: 0 32px 0 auto;
  }
}
@media (min-width: 1160px) {
  .navi_ul {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
  }
}
@media (min-width: 1160px) and (max-width: 1439.9px) {
  .navi_ul {
    margin: 0 10px 0 auto;
  }
}
@media (max-width: 1159.9px) {
  .navi_ul {
    text-align: center;
    width: 80%;
    margin: 0 auto;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .navi_ul {
    margin-top: 120px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .navi_ul {
    margin-top: 120px;
  }
}
@media (max-width: 559.9px) {
  .navi_ul {
    padding-bottom: 10px;
  }
}
@media (min-width: 1160px) {
  .navi_ul > li {
    position: relative;
    height: 100%;
    margin: 0 4px;
  }
  .navi_ul > li::after {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 0;
    height: 4px;
    background: #14A5F4;
    content: "";
    transition: all 0.3s;
    z-index: 100;
  }
  .navi_ul > li:hover::after, .navi_ul > li.selected::after {
    left: 0;
    width: 100%;
  }
}
@media (max-width: 1159.9px) {
  .navi_ul > li {
    margin-bottom: 8px;
  }
}
.navi_ul > li.toggle {
  position: relative;
  font-weight: bold;
}
@media (max-width: 1159.9px) {
  .navi_ul > li.toggle::after {
    position: absolute;
    top: 26px;
    right: 10px;
    transform: translate(-50%, -50%);
    font-family: "Font Awesome 5 Free";
    content: "\f107";
    color: #191718;
  }
}
@media (min-width: 560px) {
  .navi_ul > li.toggle:hover .megamenu {
    max-height: 9999px;
    opacity: 1;
  }
}
@media (min-width: 1160px) {
  .fixed .navi_ul > li::after {
    background: #3795D5;
  }
}

.header-nav-item {
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s cubic-bezier(0.445, 0.05, 0.55, 0.95);
  letter-spacing: 0.04em;
  font-size: 1.5rem;
}
@media (min-width: 1160px) {
  .header-nav-item {
    width: 100%;
    height: 100%;
    position: relative;
    font-weight: 500;
    padding: 0 4px;
    cursor: pointer;
    color: #191718;
  }
  .header-nav-item:hover {
    color: #14A5F4;
  }
}
@media (max-width: 1159.9px) {
  .header-nav-item {
    color: #444;
    text-align: center;
    padding: 16px 0;
    display: block;
    width: 100%;
    line-height: 1.3;
    background-color: white;
    border-radius: 8px;
  }
}
@media (min-width: 1160px) {
  .fixed .header-nav-item {
    color: #1b1b1b;
  }
  .fixed .header-nav-item:hover {
    color: #3795D5;
  }
}
.header-nav-item i {
  margin: 0 2px;
}

@media (min-width: 1160px) {
  .megamenu {
    transition: all 0.2s ease-in;
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    width: calc(100vw - 72px);
    left: 72px;
    top: 122px;
    position: fixed;
    background: #3795D5;
    z-index: 4;
    box-shadow: 0 6px 6px rgba(0, 0, 0, 0.08);
  }
  .fixed .megamenu {
    top: 94px;
  }
}
@media (max-width: 1159.9px) {
  .megamenu {
    display: none;
    margin-top: 8px;
  }
}
.megamenu .megamenu_inner {
  max-width: 1000px;
  margin: 0 auto;
}
@media (min-width: 1160px) {
  .megamenu .megamenu_inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 40px 0;
  }
}
@media (max-width: 1159.9px) {
  .megamenu .megamenu_inner {
    background-color: white;
    border-radius: 12px;
    overflow: hidden;
  }
}
.megamenu .megamenu_inner .megamenu_tit {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
}
@media (min-width: 1160px) {
  .megamenu .megamenu_inner .megamenu_tit {
    width: 300px;
  }
}
@media (max-width: 1159.9px) {
  .megamenu .megamenu_inner .megamenu_tit {
    background-color: #3795D5;
    padding: 14px 10px 8px;
    align-items: center;
    justify-content: center;
  }
}
.megamenu .megamenu_inner .megamenu_tit .jp {
  color: white;
  font-size: 1.5rem;
}
@media (max-width: 1159.9px) {
  .megamenu .megamenu_inner .megamenu_tit .jp {
    font-size: 1.5rem;
    color: white;
  }
}
.megamenu .megamenu_inner .megamenu_tit .eng {
  color: white;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 2.4rem;
  font-weight: 400;
  line-height: 1.5;
  line-height: 1;
  margin-bottom: 5px;
}
@media (max-width: 1159.9px) {
  .megamenu .megamenu_inner .megamenu_tit .eng {
    font-size: 1.2rem;
    color: white;
    margin-bottom: 2px;
  }
}
.megamenu .megamenu_inner .megamenu_tit .index_link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 40px;
  border-radius: 8px;
  background-color: white;
  color: #333;
  line-height: 1.6;
  font-size: 1.4rem;
  margin-top: 10px;
}
.megamenu .megamenu_inner .megamenu_tit .index_link:hover {
  background-color: #eee;
}
@media (min-width: 1160px) {
  .megamenu .inner_ul {
    width: calc(100% - 320px);
    display: inline-flex;
    flex-wrap: wrap;
    align-items: flex-start;
    align-content: flex-start;
  }
}
@media (max-width: 1159.9px) {
  .megamenu .inner_ul {
    margin-top: 16px;
    padding: 0 24px 12px;
  }
}
@media (min-width: 1160px) {
  .megamenu .inner_ul li {
    width: 32%;
  }
  .megamenu .inner_ul li:not(:nth-child(3n)) {
    margin-right: 2%;
  }
  .megamenu .inner_ul li:nth-child(n+4) {
    margin-top: 10px;
  }
}
.megamenu .inner_ul li a {
  color: #333;
  line-height: 1.6;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
}
@media (min-width: 1160px) {
  .megamenu .inner_ul li a {
    border: 1px #ddd solid;
    background-color: white;
    height: 56px;
    width: 100%;
    transition: all 0.3s ease;
    text-align: center;
    font-size: 1.4rem;
  }
}
@media (max-width: 1159.9px) {
  .megamenu .inner_ul li a {
    display: block;
    position: relative;
    font-size: 1.3rem;
    justify-content: flex-start;
    text-align: left;
    padding: 5px 0 5px 12px;
    color: #191718;
  }
  .megamenu .inner_ul li a::before {
    display: inline-block;
    position: absolute;
    left: 0;
    top: 16px;
    transform: translate(-50%, -50%);
    font-family: "Font Awesome 5 Free";
    content: "\f105";
  }
  .megamenu .inner_ul li a br {
    display: none;
  }
}
.megamenu .inner_ul li a:hover {
  background-color: #eee;
}

.head_contact {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #3795D5;
  color: white;
  height: 56px;
  transition: all 0.3s ease;
  border-radius: 8px;
  padding: 0 24px;
}
@media (min-width: 1160px) {
  .head_contact {
    margin-left: 5px;
  }
}
@media (max-width: 1159.9px) {
  .head_contact {
    height: 64px;
    width: 240px;
    border-radius: 8px;
    margin: 16px auto 0;
  }
}
.head_contact i {
  display: block;
  width: 22px;
  margin-right: 5px;
}
.head_contact:hover {
  color: white;
  background-color: #14A5F4;
}

/**************
WordPressログイン時
**************/
@media (min-width: 560px) {
  .admin-bar #header {
    top: 32px;
  }
}
@media (min-width: 1160px) {
  .admin-bar .fixed-header .megamenu {
    top: 108px;
  }
}
@media (min-width: 1160px) {
  .admin-bar .megamenu {
    top: 152px;
  }
}
@media (min-width: 1160px) {
  .admin-bar .fixed .megamenu {
    top: 126px;
  }
}
.admin-bar #side_header {
  top: 32px;
}

/**************
Side Header
**************/
#side_header {
  position: fixed;
  height: 100vh;
  width: 72px;
  top: 0;
  left: 0;
  background-color: white;
  z-index: 10;
  border-right: 1px #ddd solid;
  transition: all 0.3s ease;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  #side_header {
    width: 100%;
    height: 80px;
  }
}
@media (max-width: 820.9px) {
  #side_header {
    width: 100vw;
    height: 60px;
  }
}
@media (min-width: 1160px) {
  #side_header .side_header_logo {
    display: none;
  }
}
@media (max-width: 1159.9px) {
  #side_header .side_header_logo {
    display: block;
    width: 136px;
    margin-left: 16px;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  #side_header .side_header_logo {
    width: 160px;
    margin-left: 32px;
  }
}
#side_header .side_header_inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  position: relative;
}
@media (min-width: 1160px) {
  #side_header .side_header_inner {
    flex-direction: column;
    padding: 32px 0;
  }
}
@media (min-width: 1160px) {
  #side_header .side_header_inner .side_catch {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    left: 50%;
    bottom: 20%;
    transform: translateX(-50%) rotate(90deg);
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  #side_header .side_header_inner .side_catch {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 0 80px;
  }
}
@media (max-width: 820.9px) {
  #side_header .side_header_inner .side_catch {
    display: none;
  }
}
#side_header .side_header_inner .side_catch .eng {
  width: 320px;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.9rem;
  font-weight: 400;
  line-height: 1.5;
  margin-left: 16px;
  color: #3795D5;
  transition: all 0.3s ease;
}
#side_header.opened {
  background-color: #3795D5;
  border: 0;
}
@media (max-width: 820.9px) {
  #side_header.opened {
    background-color: transparent;
  }
}
#side_header.opened .side_header_inner .side_catch .jp {
  background-color: white;
  color: #3795D5;
}
#side_header.opened .side_header_inner .side_catch .wellbe {
  color: white;
}

.menuBtn {
  cursor: pointer;
  transition: all 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
  text-align: center;
}
.menuBtn .txt {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #3795D5;
}
@media (max-width: 1159.9px) {
  .menuBtn {
    position: absolute;
    right: 14px;
    top: 12px;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .menuBtn {
    top: 20px;
  }
}
@media (max-width: 1159.9px) {
  .opened .menuBtn {
    right: 40px;
  }
}
.opened .menuBtn .txt {
  display: none;
}

.bento {
  width: 26px;
  height: 26px;
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  padding: 0;
  margin: 0;
  border-color: transparent;
  background: transparent;
  cursor: pointer;
  padding: 0;
  margin: 0 auto;
  position: relative;
}
.bento .bento-box {
  display: block;
  width: 6px;
  height: 6px;
  background: #3795D5;
}
.bento .bento-box:first-child, .bento .bento-box:last-child {
  transition: all 0.3s ease;
}
.opened .bento {
  position: fixed;
  z-index: 9;
}
.opened .bento .bento-box {
  background-color: transparent;
}
.opened .bento .bento-box:first-child, .opened .bento .bento-box:last-child {
  width: 24px;
  height: 2px;
  background-color: white;
  position: absolute;
}
.opened .bento .bento-box:first-child {
  transform: rotate(45deg);
  top: 50%;
  left: -16px;
}
.opened .bento .bento-box:last-child {
  transform: rotate(315deg);
  top: 50%;
  left: -16px;
}

#sp_menu {
  width: auto;
  height: 100vh;
  position: fixed;
  top: 0;
  left: -600px;
  z-index: 11;
  transition: left 0.5s ease, visibility 0.5s ease-in-out, opacity 0.5s ease-in-out;
  visibility: hidden;
  opacity: 0;
  display: flex;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  #sp_menu {
    width: 80vw;
  }
}
@media (max-width: 559.9px) {
  #sp_menu {
    width: calc(100vw - 72px);
  }
}
#sp_menu.opened {
  visibility: visible;
  opacity: 1;
  left: 0;
}
@media (min-width: 1160px) {
  #sp_menu.opened {
    left: 72px;
  }
}
@media (max-width: 559.9px) {
  #sp_menu.opened {
    box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.1);
  }
}

.sp_menu {
  height: 100%;
  top: 0;
  left: 0;
  overflow-y: auto;
  background: #F0FBFF;
}
@media (min-width: 560px) {
  .sp_menu {
    width: 587px;
  }
}
@media (max-width: 559.9px) {
  .sp_menu {
    width: 100%;
  }
}
.sp_menu .inner {
  padding: 80px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .sp_menu .inner {
    padding: 64px 20px 20px 64px;
  }
}
@media (max-width: 559.9px) {
  .sp_menu .inner {
    padding: 32px 24px;
  }
}
.sp_menu .inner header {
  width: 100%;
  max-width: 1160px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0 auto 24px;
}
.sp_menu .inner header .header_logo {
  width: 240px;
}
@media (max-width: 559.9px) {
  .sp_menu .inner header .header_logo {
    width: 144px;
  }
}
.sp_menu .inner header .header_logo img {
  display: block;
}
.sp_menu .inner header .btn_close {
  display: block;
  width: 24px;
}
.sp_menu .inner .slide_navi_buttons {
  width: 100%;
  margin-top: 80px;
}
@media (min-width: 1160px) {
  .sp_menu .inner .slide_navi_buttons {
    display: flex;
    justify-content: space-between;
  }
}
@media (max-width: 1159.9px) {
  .sp_menu .inner .slide_navi_buttons {
    width: 100%;
    margin-top: 40px;
  }
}
.sp_menu .inner .slide_navi_buttons .item {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  flex-direction: column;
  background-color: white;
  border-radius: 8px;
}
@media (min-width: 1160px) {
  .sp_menu .inner .slide_navi_buttons .item {
    width: 49%;
    height: 100px;
  }
}
@media (max-width: 1159.9px) {
  .sp_menu .inner .slide_navi_buttons .item {
    width: 100%;
    max-width: 280px;
    height: 88px;
    margin-bottom: 12px;
  }
}
.sp_menu .inner .slide_navi_buttons .item .c_text {
  font-size: 1.3rem;
  font-weight: 500;
  transition: color 0.3s ease;
}
@media (max-width: 559.9px) {
  .sp_menu .inner .slide_navi_buttons .item .c_text {
    font-size: 1.1rem;
  }
}
.sp_menu .inner .slide_navi_buttons .item .e_text {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.3s ease;
}
.sp_menu .inner .slide_navi_buttons .item .e_text .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.5;
}
@media (max-width: 559.9px) {
  .sp_menu .inner .slide_navi_buttons .item .e_text .num {
    font-size: 2rem;
  }
}
.sp_menu .inner .slide_navi_buttons .item .e_text i {
  display: block;
  width: 16px;
  height: 16px;
  margin-right: 8px;
}
.sp_menu .inner .slide_navi_buttons .item .e_text i.icon_mail {
  background: url(../images/icon/icon_mail.png) no-repeat center;
  background-size: cover;
}
.sp_menu .inner .slide_navi_buttons .item .e_text i.icon_phone {
  background: url(../images/icon/icon_phone.png) no-repeat center;
  background-size: cover;
}
.sp_menu .inner .slide_navi_buttons .item .time_text {
  font-size: 1.2rem;
  font-weight: 500;
  transition: color 0.3s ease;
  line-height: 1;
  margin-top: 4px;
}
@media (max-width: 559.9px) {
  .sp_menu .inner .slide_navi_buttons .item .time_text {
    font-size: 1.1rem;
  }
}
.sp_menu .inner .slide_navi_buttons .item:hover .c_text,
.sp_menu .inner .slide_navi_buttons .item:hover .time_text, .sp_menu .inner .slide_navi_buttons .item:active .c_text,
.sp_menu .inner .slide_navi_buttons .item:active .time_text {
  color: #3795D5;
}
.sp_menu .inner .slide_navi_buttons .item:hover .e_text, .sp_menu .inner .slide_navi_buttons .item:active .e_text {
  color: #3795D5;
}

@media (min-width: 1160px) {
  .menu_bg_img {
    width: calc(28vw + 87px);
    position: relative;
    overflow: hidden;
  }
}
@media (max-width: 1159.9px) {
  .menu_bg_img {
    display: none;
  }
}
.menu_bg_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

.slide_navi {
  width: 100%;
  max-width: 800px;
  margin-top: 80px;
  display: flex;
}
@media (max-width: 559.9px) {
  .slide_navi {
    margin-top: 64px;
  }
}
.slide_navi .column {
  width: 50%;
}
.slide_navi .column ul li:not(:last-child) {
  margin-bottom: 8px;
}
.slide_navi .column ul li a {
  padding-left: 20px;
  position: relative;
  color: #191718;
  font-weight: 500;
  transition: all 0.3s ease;
}
@media (max-width: 559.9px) {
  .slide_navi .column ul li a {
    padding-left: 18px;
    font-size: 1.3rem;
  }
}
.slide_navi .column ul li a::before {
  content: "";
  display: block;
  background: url(../images/common/arrow_next_black.png) no-repeat;
  width: 13px;
  height: 13px;
  background-size: cover;
  position: absolute;
  left: 0;
  top: 3px;
}
.slide_navi .column ul li a:hover {
  color: #3795D5;
}

#overlay {
  position: relative;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: fixed;
  left: 0;
  top: 0;
  background: rgba(0, 0, 0, 0.7);
  z-index: 8;
  opacity: 0;
  visibility: hidden;
}
#overlay.opened {
  opacity: 1;
  visibility: visible;
}

/**************
Footer
**************/
#footer {
  bottom: 0;
  background-color: #3A4B63;
}

.foot_cta {
  background: url(../images/common/cta_bg.jpg) no-repeat;
  background-size: cover;
}
.foot_cta .foot_cta_items {
  width: 100%;
  max-width: 1160px;
  margin: 0 auto;
}
@media (min-width: 560px) {
  .foot_cta .foot_cta_items {
    display: flex;
  }
}
.foot_cta .foot_cta_items .item {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  flex-direction: column;
  transition: all 0.3s ease;
}
@media (min-width: 560px) {
  .foot_cta .foot_cta_items .item {
    width: 50%;
    height: 216px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .foot_cta .foot_cta_items .item {
    height: 136px;
  }
}
@media (max-width: 559.9px) {
  .foot_cta .foot_cta_items .item {
    width: 100%;
    height: 96px;
  }
}
.foot_cta .foot_cta_items .item:not(:last-child)::after {
  content: "";
  display: block;
  background-color: white;
  position: absolute;
}
@media (min-width: 560px) {
  .foot_cta .foot_cta_items .item:not(:last-child)::after {
    width: 1px;
    height: 80%;
    right: -1px;
    top: 10%;
  }
}
@media (max-width: 559.9px) {
  .foot_cta .foot_cta_items .item:not(:last-child)::after {
    width: 90%;
    left: 5%;
    bottom: 0;
    height: 1px;
  }
}
.foot_cta .foot_cta_items .item .c_text {
  font-size: 1.7rem;
  font-weight: bold;
  transition: color 0.3s ease;
  margin-bottom: 4px;
  color: white;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .foot_cta .foot_cta_items .item .c_text {
    font-size: 1.3rem;
  }
}
@media (max-width: 559.9px) {
  .foot_cta .foot_cta_items .item .c_text {
    font-size: 1.1rem;
  }
}
.foot_cta .foot_cta_items .item .e_text {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.3s ease;
  color: white;
  gap: 8px;
}
.foot_cta .foot_cta_items .item .e_text .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 3.4rem;
  font-weight: 400;
  line-height: 1.5;
  color: white;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .foot_cta .foot_cta_items .item .e_text .num {
    font-size: 2.4rem;
  }
}
@media (max-width: 559.9px) {
  .foot_cta .foot_cta_items .item .e_text .num {
    font-size: 2rem;
  }
}
.foot_cta .foot_cta_items .item .e_text i {
  display: block;
  width: 32px;
  height: 32px;
  margin-right: 8px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .foot_cta .foot_cta_items .item .e_text i {
    width: 24px;
    height: 24px;
  }
}
@media (max-width: 559.9px) {
  .foot_cta .foot_cta_items .item .e_text i {
    width: 20px;
    height: 20px;
  }
}
.foot_cta .foot_cta_items .item .e_text i.icon_phone {
  background: url(../images/icon/icon_phone.png) no-repeat center;
  background-size: cover;
}
.foot_cta .foot_cta_items .item .e_text i.icon_mail {
  background: url(../images/icon/icon_mail.png) no-repeat center;
  background-size: cover;
}
.foot_cta .foot_cta_items .item .e_text i.icon_download {
  background: url(../images/common/file-download.png) no-repeat center;
  background-size: cover;
}
.foot_cta .foot_cta_items .item .timeTxt {
  color: white;
  font-size: 1.4rem;
}
.foot_cta .foot_cta_items .item:hover, .foot_cta .foot_cta_items .item:active {
  opacity: 0.7;
}

.footer_under {
  padding: 40px 0;
  position: relative;
}

.footer_inner {
  width: 92%;
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
@media (min-width: 821px) {
  .footer_inner {
    padding: 40px 0;
    display: flex;
  }
}
@media (max-width: 820.9px) {
  .footer_inner {
    height: auto;
    padding: 32px 0;
  }
}
@media (max-width: 559.9px) {
  .footer_inner {
    padding-bottom: 0;
    width: 88%;
  }
}
.footer_inner .footer_left {
  width: 50%;
}
@media (max-width: 820.9px) {
  .footer_inner .footer_left {
    width: 100%;
    text-align: center;
  }
}
.footer_inner .footer_left .footlogo {
  display: block;
  width: 330px;
}
@media (max-width: 820.9px) {
  .footer_inner .footer_left .footlogo {
    width: 200px;
    margin: 0 auto;
  }
}
.footer_inner .footer_left .foot_c_name {
  color: white;
  font-size: 1.7rem;
  margin: 40px 0 8px;
}
.footer_inner .footer_left > p {
  color: white;
}
.footer_inner .footer_right {
  flex: 1;
}

.emidas {
  display: block;
  margin-top: 30px;
}

.foot_button {
  width: 240px;
  height: 120px;
  border-radius: 8px;
  overflow: hidden;
  margin: 60px 0 0 5px;
}
@media (max-width: 820.9px) {
  .foot_button {
    margin: 30px auto 0;
  }
}
.foot_button a {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
}
.foot_button a .foot_btn_bg {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
.foot_button a .inner {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
}
.foot_button a .inner p {
  color: white;
}
.foot_button a .inner .circle {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background-color: white;
  display: flex;
  align-items: center;
  justify-content: center;
}
.foot_button a .inner .circle img {
  display: block;
  width: 12px;
}

.footer_navi {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 80px;
}
@media (max-width: 820.9px) {
  .footer_navi {
    display: none;
  }
}
.footer_navi .foot_navi_column .head {
  margin-bottom: 15px;
  color: white;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.04em;
}
.footer_navi .foot_navi_column ul li {
  padding-left: 10px;
  margin-left: 8px;
  position: relative;
}
.footer_navi .foot_navi_column ul li:not(:last-child) {
  margin-bottom: 4px;
}
.footer_navi .foot_navi_column ul li a {
  display: flex;
  font-size: 1.4rem;
  color: white;
  font-weight: 500;
  transition: all 0.3s ease;
}
.footer_navi .foot_navi_column ul li a:hover {
  color: #14A5F4;
}

.footer_bottom {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  margin-top: 48px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .footer_bottom {
    margin: 40px auto 0;
    max-width: 480px;
  }
}
@media (max-width: 559.9px) {
  .footer_bottom {
    margin-top: 32px;
    flex-direction: column;
  }
}
.footer_bottom .nc-logo {
  display: block;
  width: 200px;
  margin-top: 10px;
}
@media (max-width: 559.9px) {
  .footer_bottom .nc-logo {
    width: 160px;
  }
}

.copyright {
  text-align: center;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.06em;
  color: #d9d9d9;
}
@media (max-width: 820.9px) {
  .copyright {
    font-size: 1.2rem;
  }
}

/**************
Common Parts
**************/
/* Titles */
.navy-title {
  display: flex;
  flex-direction: column;
}
.navy-title .txt {
  display: inline-block;
  background-color: transparent;
  color: white;
  font-weight: 700;
  font-size: 2.4rem;
  padding: 4px 24px;
  line-height: 1.5;
  position: relative;
  background-image: linear-gradient(90deg, #1A2D74, #1A2D74 50%, white 50%, white);
  background-image: linear-gradient(90deg, rgb(26, 45, 116), rgb(26, 45, 116) 50%, rgba(26, 45, 116, 0) 50%, rgba(26, 45, 116, 0));
  background-position: 100% 0;
  background-size: 200% 100%;
  transition: background-position 1s ease-in-out;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.navy-title .txt:not(:last-child) {
  margin-bottom: 16px;
}
@media (max-width: 559.9px) {
  .navy-title .txt:not(:last-child) {
    margin-bottom: 8px;
  }
}
@media (max-width: 559.9px) {
  .navy-title .txt {
    font-size: 1.7rem;
    padding: 4px 16px;
  }
}
.navy-title .innerTxt {
  opacity: 0;
  letter-spacing: 4px;
}
@media (max-width: 559.9px) {
  .navy-title .innerTxt {
    letter-spacing: 0.08em;
  }
}
.navy-title.moved .txt {
  background-position: 0 0;
}
.navy-title.moved .innerTxt {
  -webkit-animation: slideIn 0.4s ease 1s forwards;
          animation: slideIn 0.4s ease 1s forwards;
}

.title1 {
  font-size: 3.2rem;
  position: relative;
  margin-bottom: 24px;
  line-height: 1.5;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .title1 {
    font-size: 2.4rem;
  }
}
@media (max-width: 559.9px) {
  .title1 {
    margin-bottom: 20px;
    font-size: 1.8rem;
  }
}

.title2 {
  font-size: 3.2rem;
  position: relative;
  margin-bottom: 32px;
  line-height: 1.3;
  letter-spacing: 0.03em;
  padding-bottom: 16px;
}
.title2::before, .title2::after {
  content: "";
  display: block;
  height: 2px;
  position: absolute;
  left: 0;
  bottom: 0;
}
.title2::before {
  width: 100%;
  background-color: #e5e5e5;
}
.title2::after {
  width: 160px;
  background-color: #3795D5;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .title2 {
    font-size: 2.8rem;
  }
}
@media (max-width: 820.9px) {
  .title2 {
    margin-bottom: 20px;
    font-size: 1.8rem;
  }
}

.title3 {
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 20px;
  position: relative;
  padding: 6px 0 6px 20px;
  border-bottom: 1px #ccc solid;
  line-height: 1.5;
}
@media (max-width: 820.9px) {
  .title3 {
    font-size: 1.7rem;
  }
}
.title3::before {
  display: inline-block;
  content: "";
  width: 5px;
  height: 90%;
  background-color: #3795D5;
  margin-right: 13px;
  position: absolute;
  left: 0;
  top: 5%;
}

.title4 {
  font-size: 1.7rem;
  font-weight: bold;
  color: #666;
  position: relative;
  padding: 4px 0 4px 16px;
  line-height: 1.6;
  margin-bottom: 16px;
}
.title4::before {
  display: inline-block;
  content: "";
  width: 4px;
  height: 80%;
  background-color: #3795D5;
  position: absolute;
  left: 0;
  top: 10%;
}

.big-title {
  position: relative;
  display: flex;
  flex-direction: column-reverse;
}
@media (max-width: 820.9px) {
  .big-title {
    margin-bottom: 20px;
  }
}
.big-title .eng {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 4rem;
  font-weight: 400;
  line-height: 1.5;
  line-height: 1;
  text-transform: capitalize;
  color: #191718;
  letter-spacing: 2px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .big-title .eng {
    font-size: 3.6rem;
  }
}
@media (max-width: 559.9px) {
  .big-title .eng {
    font-size: 2.8rem;
  }
}
.big-title .jp {
  font-weight: bold;
  font-size: 4rem;
  color: #191718;
  letter-spacing: 4px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .big-title .jp {
    font-size: 2rem;
  }
}
@media (max-width: 559.9px) {
  .big-title .jp {
    font-size: 1.5rem;
  }
}
.big-title.center {
  justify-content: center;
  align-items: center;
  text-align: center;
}
.big-title.white {
  color: white;
}
.big-title.white .jp,
.big-title.white .eng {
  color: white;
}
.big-title.animation .eng, .big-title.animation .jp {
  opacity: 0;
}
.big-title.animation.moved .jp {
  -webkit-animation: slideIn 0.4s ease 0.3s forwards;
          animation: slideIn 0.4s ease 0.3s forwards;
}
.big-title.animation.moved .eng {
  -webkit-animation: slideIn 0.4s ease forwards;
          animation: slideIn 0.4s ease forwards;
}

.small-title {
  position: relative;
  display: flex;
  flex-direction: column-reverse;
  margin-bottom: 40px;
}
@media (max-width: 820.9px) {
  .small-title {
    margin-bottom: 20px;
  }
}
.small-title .eng {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 5.6rem;
  font-weight: 400;
  line-height: 1.5;
  line-height: 1;
  text-transform: uppercase;
  color: #3795D5;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .small-title .eng {
    font-size: 5rem;
  }
}
@media (max-width: 559.9px) {
  .small-title .eng {
    font-size: 3.6rem;
  }
}
.small-title .jp {
  font-weight: bold;
  font-size: 1.8rem;
  color: #191718;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .small-title .jp {
    font-size: 1.6rem;
  }
}
@media (max-width: 559.9px) {
  .small-title .jp {
    font-size: 1.5rem;
  }
}
.small-title.center {
  justify-content: center;
  align-items: center;
  text-align: center;
}
.small-title.white {
  color: white;
}
.small-title.white .jp,
.small-title.white .eng {
  color: white;
}

@media (min-width: 560px) {
  .horizontal_tit {
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
  }
}
@media (max-width: 559.9px) {
  .horizontal_tit {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    margin-bottom: 20px;
  }
}
@media (min-width: 560px) {
  .horizontal_tit.end {
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    flex-direction: row-reverse;
    margin-left: auto;
  }
}
.horizontal_tit .jp {
  position: relative;
  color: #191718;
  font-size: 2.4rem;
  letter-spacing: 0.04em;
  line-height: 1.5;
  font-weight: bold;
  top: 2px;
}
@media (max-width: 559.9px) {
  .horizontal_tit .jp {
    display: block;
    font-size: 1.8rem;
  }
}
.horizontal_tit .eng {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.5;
  color: #3795D5;
  position: relative;
}
@media (min-width: 560px) {
  .horizontal_tit .eng {
    margin-left: 20px;
    padding-left: 20px;
  }
}
@media (max-width: 559.9px) {
  .horizontal_tit .eng {
    font-size: 1.5rem;
  }
}
@media (min-width: 560px) {
  .horizontal_tit .eng::before {
    width: 2px;
    height: 70%;
    content: "";
    display: block;
    background-color: #3795D5;
    position: absolute;
    left: 0;
    top: 12%;
  }
}

.center-title {
  font-size: 2.8rem;
  text-align: center;
  font-weight: bold;
}
.center-title span {
  color: #3795D5;
}
@media (max-width: 820.9px) {
  .center-title {
    font-size: 2.1rem;
    margin-bottom: 20px;
  }
}
.center-title .eng {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
}
.center-title.white {
  color: #fff;
}
.center-title.white::after {
  background-color: #fff;
}
.center-title.animation .eng, .center-title.animation .jp {
  opacity: 0;
}
.center-title.animation.moved .jp {
  -webkit-animation: slideIn 0.4s ease 0.3s forwards;
          animation: slideIn 0.4s ease 0.3s forwards;
}
.center-title.animation.moved .eng {
  -webkit-animation: slideIn 0.4s ease forwards;
          animation: slideIn 0.4s ease forwards;
}

.center-title2 {
  font-size: 2.4rem;
  text-align: center;
  margin-bottom: 24px;
  font-weight: bold;
}
@media (max-width: 559.9px) {
  .center-title2 {
    font-size: 2rem;
  }
}

.number-title {
  display: flex;
  align-items: center;
  gap: 20px;
  padding-bottom: 30px;
}
@media (max-width: 559.9px) {
  .number-title {
    padding-bottom: 20px;
  }
}
.number-title .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 4rem;
  font-weight: 400;
  line-height: 1.5;
  position: relative;
  letter-spacing: 0.2rem;
  line-height: 1.2;
  color: #1A2D74;
}
.number-title .num::after {
  content: "";
  display: block;
  width: 56px;
  height: 1px;
  background-color: #1A2D74;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
.number-title .jp {
  font-size: 2.3rem;
  font-weight: 700;
}

.tit_404 {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 5vw;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  color: #3795D5;
}

/* Buttons */
.btn-circle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 240px;
  background-color: white;
  border: 2px #00EDD5 solid;
  height: 64px;
  border-radius: 32px;
  padding-right: 7px;
  position: relative;
  overflow: hidden;
  transition: all 0.4s ease;
}
@media (max-width: 559.9px) {
  .btn-circle {
    height: 56px;
  }
}
.btn-circle.long {
  width: 280px;
}
.btn-circle .circle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background-color: #00EDD5;
  position: relative;
  z-index: 1;
  transition: all 0.4s ease;
}
@media (max-width: 559.9px) {
  .btn-circle .circle {
    width: 46px;
    height: 46px;
  }
}
.btn-circle .circle i {
  color: white;
}
.btn-circle .txt {
  font-size: 1.6rem;
  color: #191718;
  font-weight: bold;
  padding-left: 24px;
  position: relative;
  z-index: 1;
  transition: color 0.4s ease;
}
@media (max-width: 559.9px) {
  .btn-circle .txt {
    font-size: 1.4rem;
  }
}
.btn-circle:hover {
  border: 2px #3795D5 solid;
}
.btn-circle:hover .txt {
  color: #3795D5;
}
.btn-circle:hover .circle {
  background-color: #3795D5;
  transform: scale(1.1);
}

.lined_link {
  width: 280px;
  color: #3795D5;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px #3795D5 solid;
  height: 60px;
  padding: 0 32px 0 8px;
  position: relative;
}
.lined_link::after {
  content: "";
  display: block;
  width: 100%;
  max-width: 0;
  height: 1px;
  position: absolute;
  left: 0;
  bottom: -1px;
  background-color: #14A5F4;
  transition: all 0.4s ease-in-out;
}
.lined_link i {
  position: absolute;
  right: 8px;
  top: 50%;
  margin-top: -8px;
}
.lined_link:hover::after {
  max-width: 100%;
}

.btn-with-arrow {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.btn-with-arrow .arrow {
  width: 48px;
  height: 48px;
  border-radius: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #3795D5;
  margin-right: 12px;
  transition: all 0.3s cubic-bezier(0.445, 0.05, 0.55, 0.95);
}
.btn-with-arrow .arrow i {
  color: white;
}
.btn-with-arrow .txt {
  display: inline-block;
  position: relative;
  padding: 10px 4px 8px;
  color: #191718;
}
.btn-with-arrow .txt::before {
  content: "";
  display: block;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: 0;
  height: 1px;
  background-color: #191718;
}
.btn-with-arrow:hover .arrow {
  transform: scale(1.1);
}
.btn-with-arrow.white .arrow {
  background-color: white;
}
.btn-with-arrow.white .arrow i {
  color: #3795D5;
}
.btn-with-arrow.white .txt {
  color: white;
}
.btn-with-arrow.white .txt::before {
  background-color: white;
}

/* Tables */
.table-s1 {
  width: 100%;
}
.table-s1 th {
  padding: 12px 24px;
  text-align: left;
}
@media (min-width: 560px) {
  .table-s1 th {
    border-bottom: 1px #14A5F4 solid;
    width: 200px;
  }
}
@media (max-width: 820.9px) {
  .table-s1 th {
    width: 100%;
    display: block;
    background-color: #f3f3f3;
    padding: 8px;
  }
}
.table-s1 td {
  background-color: #fff;
  padding: 12px 24px;
}
@media (min-width: 560px) {
  .table-s1 td {
    border-bottom: 1px #ddd solid;
  }
}
@media (max-width: 820.9px) {
  .table-s1 td {
    width: 100%;
    display: block;
    padding: 10px 0;
  }
}

.table-s2 {
  width: 100%;
}
@media (max-width: 820.9px) {
  .table-s2 {
    font-size: 1.4rem;
  }
}
.table-s2 th {
  width: 180px;
  padding: 5px 0;
  border: 1px #ddd solid;
  text-align: center;
  background-color: #f3f3f3;
}
@media (min-width: 560px) {
  .table-s2 th {
    text-align: left;
    padding: 8px 32px;
  }
}
@media (max-width: 559.9px) {
  .table-s2 th {
    display: block;
    padding: 5px 8px;
    width: 100%;
    border-bottom: none;
  }
}
.table-s2 td {
  border: 1px #ddd solid;
  background-color: white;
}
@media (min-width: 560px) {
  .table-s2 td {
    text-align: left;
    padding: 8px 32px;
  }
}
@media (max-width: 559.9px) {
  .table-s2 td {
    display: block;
    padding: 10px 8px;
    width: 100%;
    margin-bottom: 4px;
  }
}

.table-c1 {
  width: 100%;
}
.table-c1 th {
  width: 28%;
  font-weight: 600;
  text-align: left;
  border-bottom: #14A5F4 1px solid;
  padding: 30px 5px;
}
@media (max-width: 820.9px) {
  .table-c1 th {
    padding: 20px 5px;
    width: 25%;
  }
}
@media (max-width: 559.9px) {
  .table-c1 th {
    display: block;
    width: 100%;
    border-bottom: 0;
    padding: 10px 0 2px;
    font-size: 1.4rem;
  }
}
.table-c1 td {
  padding: 30px 24px;
  border-bottom: #d9d9d9 1px solid;
}
@media (max-width: 820.9px) {
  .table-c1 td {
    padding: 20px 24px;
  }
}
@media (max-width: 559.9px) {
  .table-c1 td {
    display: block;
    width: 100%;
    padding: 0 0 10px;
    font-size: 1.4rem;
  }
}
.table-c1 td dl {
  margin-bottom: 20px;
}
.table-c1 td dl:last-child {
  margin-bottom: 0;
}
.table-c1 td dl dt {
  display: flex;
  align-items: center;
}
@media (max-width: 820.9px) {
  .table-c1 td dl dt {
    display: block;
  }
}
.table-c1 td dl dt::before {
  content: "";
  width: 15px;
  height: 15px;
  display: inline-flex;
  background-color: #3795D5;
  border-radius: 2px;
}
@media (max-width: 820.9px) {
  .table-c1 td dl dt::before {
    width: 10px;
    height: 10px;
  }
}
.table-c1 td dl dt .access {
  margin-left: 30px;
  color: #fff;
  font-size: 1.4rem;
  background-color: #1A2D74;
  border-radius: 16px;
  padding: 4px 26px;
}
@media (max-width: 820.9px) {
  .table-c1 td dl dt .access {
    font-size: 1.3rem;
    display: block;
    width: 200px;
    margin: 5px 0;
    padding: 2px 26px;
  }
}
.table-c1 td dl dt .access i {
  margin-left: 15px;
}

/* Parts */
.sq1, .sq_black {
  padding-left: 15px;
  position: relative;
  font-weight: bold;
  line-height: 1.5;
}
.sq1::before, .sq_black::before {
  width: 10px;
  height: 10px;
  background-color: #F4DF35;
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 7px;
}

.sq_white {
  padding-left: 15px;
  position: relative;
  font-weight: bold;
  line-height: 1.5;
  color: white;
}
.sq_white::before {
  width: 10px;
  height: 10px;
  background-color: white;
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 7px;
}

/* Lists */
.list-disc {
  margin-left: 19px;
}
.list-disc li {
  list-style: disc;
}
.list-disc li b {
  display: inline-block;
  margin-right: 10px;
}

.list-decimal {
  margin-left: 24px;
}
.list-decimal li {
  list-style: decimal;
}
.list-decimal li b {
  display: inline-block;
  margin-right: 10px;
}

.list-decimal2 {
  counter-reset: number;
  list-style-type: none !important;
  padding: 0.5em;
}
.list-decimal2 li {
  position: relative;
  padding-left: 30px;
  line-height: 1.5em;
  padding: 0.5em 0.5em 0.5em 30px;
}
.list-decimal2 li::before {
  position: absolute;
  counter-increment: number;
  content: counter(number);
  /*以下数字のデザイン変える*/
  display: flex;
  align-items: center;
  justify-content: center;
  background: #5c9ee7;
  color: white;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  border-radius: 50%;
  left: 0;
  width: 25px;
  height: 25px;
  line-height: 25px;
  text-align: center;
  top: 50%;
  transform: translateY(-50%);
}

.list-check li {
  position: relative;
  padding: 2px 0 2px 28px;
}
.list-check li::before {
  content: "";
  display: block;
  background: url(../images/common/icon_check_black.png) no-repeat center;
  background-size: contain;
  width: 20px;
  height: 18px;
  position: absolute;
  left: 0;
  top: 6px;
}
.list-check li span {
  font-weight: bold;
  color: #3795D5;
}

.list-sq > li {
  position: relative;
  padding-left: 18px;
}
.list-sq > li::before {
  content: "";
  display: block;
  background-color: #D8DAE5;
  width: 11px;
  height: 11px;
  position: absolute;
  left: 0;
  top: 9px;
}

/* Boxes */
.borderBox {
  background-color: #fff6f9;
  border: #ccc solid 1px;
  padding: 24px 40px;
}
@media (max-width: 820.9px) {
  .borderBox {
    padding: 16px;
  }
}

.blueBox {
  background-color: #C5DAF1;
  padding: 40px;
  border-radius: 16px;
}
@media (max-width: 820.9px) {
  .blueBox {
    padding: 16px;
  }
}

/* Texts */
@media (min-width: 1160px) {
  .strong_text {
    font-size: 1.8rem;
    text-align: center;
  }
}

.page_top_text {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 500;
}
.page_top_text.lot {
  margin-top: 30px;
}
@media (max-width: 820.9px) {
  .page_top_text {
    text-align: left;
    font-size: 1.7rem;
  }
}

.white_text {
  color: white;
}

.blue_text {
  color: #3795D5;
  font-weight: bold;
}

/* Others */
.anchor {
  padding-top: 100px;
  margin-top: -100px;
}
@media (max-width: 820.9px) {
  .anchor {
    padding-top: 120px;
    margin-top: -120px;
  }
}

.sp-scroll {
  width: 100%;
  overflow-x: auto;
}

.underconst {
  background-color: #fff;
  text-align: center;
  margin: 50px auto;
  padding: 80px 0;
  border: 1px #ddd solid;
  border-radius: 5px;
}

@media (max-width: 559.9px) {
  .sp_none {
    display: none;
  }
}

@media (min-width: 560px) and (max-width: 820.9px) {
  .pc_only {
    display: none;
  }
}
@media (max-width: 820.9px) {
  .pc_only {
    display: none;
  }
}

@media (min-width: 560px) {
  .sp_only {
    display: none;
  }
}

.float_link {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
}

/* Animations */
@-webkit-keyframes blurIn {
  0% {
    opacity: 0;
    filter: blur(1.5rem);
    transform: scale(1.3);
  }
  100% {
    opacity: 1;
    filter: blur(0);
    transform: scale(1);
  }
}
@keyframes blurIn {
  0% {
    opacity: 0;
    filter: blur(1.5rem);
    transform: scale(1.3);
  }
  100% {
    opacity: 1;
    filter: blur(0);
    transform: scale(1);
  }
}
@-webkit-keyframes slideIn {
  0% {
    transform: translateX(40px);
    filter: blur(1.5rem);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
    filter: blur(0);
    opacity: 1;
  }
}
@keyframes slideIn {
  0% {
    transform: translateX(40px);
    filter: blur(1.5rem);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
    filter: blur(0);
    opacity: 1;
  }
}
@-webkit-keyframes slideInR {
  0% {
    transform: translateX(-40px);
    filter: blur(1.5rem);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
    opacity: 1;
  }
}
@keyframes slideInR {
  0% {
    transform: translateX(-40px);
    filter: blur(1.5rem);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    transform: translateY(20px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
@-webkit-keyframes fadeIn {
  0% {
    transform: translateY(20px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
@-webkit-keyframes cubeIn {
  0% {
    opacity: 0;
    transform: rotate(-145deg);
  }
  10% {
    opacity: 1;
    transform: rotate(-145deg);
  }
  100% {
    opacity: 1;
    transform: rotate(0);
  }
}
@keyframes cubeIn {
  0% {
    opacity: 0;
    transform: rotate(-145deg);
  }
  10% {
    opacity: 1;
    transform: rotate(-145deg);
  }
  100% {
    opacity: 1;
    transform: rotate(0);
  }
}
@-webkit-keyframes zoom-in {
  0% {
    transform: translate(20px);
    opacity: 0;
  }
  100% {
    transform: none;
    opacity: 1;
  }
}
@keyframes zoom-in {
  0% {
    transform: translate(20px);
    opacity: 0;
  }
  100% {
    transform: none;
    opacity: 1;
  }
}
@-webkit-keyframes popup {
  0% {
    transform: translateY(40px) scale(0.8);
    opacity: 0;
  }
  100% {
    transform: translateY(0) scale(1);
  }
  80%, 100% {
    opacity: 1;
  }
}
@keyframes popup {
  0% {
    transform: translateY(40px) scale(0.8);
    opacity: 0;
  }
  100% {
    transform: translateY(0) scale(1);
  }
  80%, 100% {
    opacity: 1;
  }
}
/**************
HOME
**************/
#main_wrap {
  width: 100%;
  position: relative;
  z-index: 1;
  background-color: white;
}
@media (min-width: 1160px) {
  #main_wrap {
    padding-left: 72px;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  #main_wrap {
    padding-top: 80px;
  }
}
@media (max-width: 820.9px) {
  #main_wrap {
    padding-top: 60px;
  }
}

#mainVisual {
  width: 100%;
  display: block;
  position: relative;
  background-color: white;
}
#mainVisual::after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.4);
}
@media (min-width: 821px) {
  #mainVisual {
    height: 100vh;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  #mainVisual {
    max-height: 720px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  #mainVisual {
    height: 560px;
  }
}
@media (max-width: 559.9px) {
  #mainVisual {
    height: 400px;
  }
}

.main_inner {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .main_inner {
    justify-content: center;
  }
}
@media (max-width: 559.9px) {
  .main_inner {
    align-items: center;
    justify-content: center;
  }
}
.main_inner .textArea {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 1;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-direction: column;
}
@media (min-width: 821px) {
  .main_inner .textArea {
    padding-left: 46vw;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .main_inner .textArea {
    padding-left: 4vw;
  }
}
@media (max-width: 559.9px) {
  .main_inner .textArea {
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    padding-bottom: 20px;
  }
}
.main_inner .textArea .mainCatchText {
  color: white;
  line-height: 1.4;
}
@media (max-width: 559.9px) {
  .main_inner .textArea .mainCatchText {
    text-align: center;
  }
}
.main_inner .textArea .mainCatchText.mainCatch01 {
  font-size: 4vw;
  font-weight: bold;
  opacity: 0;
  -webkit-animation: slideIn 0.4s ease 0.5s forwards;
          animation: slideIn 0.4s ease 0.5s forwards;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .main_inner .textArea .mainCatchText.mainCatch01 {
    font-size: 5.6rem;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .main_inner .textArea .mainCatchText.mainCatch01 {
    font-size: 5rem;
  }
}
@media (max-width: 559.9px) {
  .main_inner .textArea .mainCatchText.mainCatch01 {
    font-size: 3rem;
  }
}
.main_inner .textArea .mainCatchText.mainCatch02 {
  font-size: 2.4vw;
  font-weight: 500;
  opacity: 0;
  -webkit-animation: slideIn 0.4s ease 0.8s forwards;
          animation: slideIn 0.4s ease 0.8s forwards;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .main_inner .textArea .mainCatchText.mainCatch02 {
    font-size: 2.4rem;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .main_inner .textArea .mainCatchText.mainCatch02 {
    font-size: 2.8rem;
  }
}
@media (max-width: 559.9px) {
  .main_inner .textArea .mainCatchText.mainCatch02 {
    font-size: 2.3rem;
  }
}
@media (min-width: 560px) {
  .main_inner .textArea .mainCatchText.mainCatch02 br {
    display: none;
  }
}
.main_inner .main_image {
  width: 100%;
  height: 100%;
}
.main_inner .main_image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
.main_inner .main_video {
  width: 100%;
  height: 100%;
}
.main_inner .main_video video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

.main_topics {
  position: absolute;
  z-index: 6;
  background: var(--white, #FFF);
  box-shadow: 0px 4px 32px 0px rgba(0, 0, 0, 0.08);
  background-color: white;
  bottom: 40px;
  right: 40px;
  opacity: 0;
  -webkit-animation: slideIn 0.4s ease 1s forwards;
          animation: slideIn 0.4s ease 1s forwards;
}
@media (min-width: 560px) {
  .main_topics {
    width: 528px;
    border-radius: 24px;
    padding: 30px;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .main_topics {
    right: 24px;
    bottom: 24px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .main_topics {
    padding: 20px 24px 18px;
    bottom: 24px;
    right: 16px;
  }
}
@media (max-width: 559.9px) {
  .main_topics {
    width: 90vw;
    padding: 18px 24px 12px;
    bottom: 5vw;
    left: 5vw;
  }
}
.main_topics .main_topics_header {
  display: flex;
  justify-content: flex-start;
  gap: 24px;
}
.main_topics .main_topics_header .eng {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
.main_topics .main_topics_header .topic_date {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  position: relative;
  color: #14A5F4;
}
.main_topics .inner-box {
  height: 100%;
  position: relative;
  padding: 8px 100px 0 0;
}
@media (max-width: 559.9px) {
  .main_topics .inner-box {
    padding: 0;
  }
}
.main_topics .inner-box .topic_tit a {
  font-size: 1.5rem;
  font-weight: 500;
  color: #191718;
}
@media (max-width: 559.9px) {
  .main_topics .inner-box .topic_tit a {
    font-size: 1.4rem;
    line-height: 1.6;
  }
}
.main_topics .inner-box:hover .topic_tit a {
  color: #14A5F4;
}
.main_topics .news_link {
  width: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  position: absolute;
  right: 0;
  bottom: 32px;
  color: #191718;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .main_topics .news_link {
    width: 128px;
  }
}
.main_topics .news_link i {
  font-size: 1.2rem;
}
@media (max-width: 559.9px) {
  .main_topics .news_link {
    display: none;
  }
}

.top_tec_section {
  width: 100%;
  background: url(../images/top/top_main_under.jpg) no-repeat center top;
  background-size: contain;
  padding: 80px 0;
  overflow: hidden;
}
@media (max-width: 559.9px) {
  .top_tec_section {
    padding: 64px 0;
  }
}

.top_tec_head .eng {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.5;
  color: #1A2D74;
  letter-spacing: 4px;
  opacity: 0;
}
@media (max-width: 559.9px) {
  .top_tec_head .eng {
    font-size: 2.3rem;
  }
}
.top_tec_head .eng.moved {
  -webkit-animation: slideIn 0.4s ease 0.1s forwards;
          animation: slideIn 0.4s ease 0.1s forwards;
}
.top_tec_head .top_tec_head_inner {
  width: 100%;
  padding: 30px 0;
}
@media (min-width: 821px) {
  .top_tec_head .top_tec_head_inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
}
.top_tec_head .top_tec_head_inner .navy-title .txt {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 4rem;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .top_tec_head .top_tec_head_inner .navy-title .txt {
    font-size: 3rem;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_tec_head .top_tec_head_inner .navy-title .txt {
    font-size: 4rem;
  }
}
@media (max-width: 559.9px) {
  .top_tec_head .top_tec_head_inner .navy-title .txt {
    font-size: 2.6rem;
  }
}
.top_tec_head .top_tec_head_inner .navy-title .txt:nth-child(2) {
  margin: 8px 0 0 48px;
}
@media (max-width: 559.9px) {
  .top_tec_head .top_tec_head_inner .navy-title .txt:nth-child(2) {
    margin-top: 8px;
  }
}
@media (min-width: 1160px) {
  .top_tec_head .top_tec_head_inner .textSide {
    padding-right: 50px;
    max-width: 500px;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .top_tec_head .top_tec_head_inner .textSide {
    width: calc(100% - 390px);
  }
}
@media (max-width: 820.9px) {
  .top_tec_head .top_tec_head_inner .textSide {
    margin-top: 30px;
  }
}
.top_tec_head .top_tec_head_inner .textSide p {
  font-weight: 500;
}
@media (min-width: 1160px) {
  .top_tec_head .top_tec_head_inner .textSide p {
    font-size: 2rem;
    line-height: 2;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .top_tec_head .top_tec_head_inner .textSide p {
    font-size: 1.7rem;
  }
}

.top_tec_images {
  width: 100%;
  max-width: 900px;
  margin: 40px auto;
}
@media (min-width: 560px) {
  .top_tec_images {
    display: flex;
    justify-content: space-between;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_tec_images {
    margin: 30px auto;
  }
}
@media (max-width: 559.9px) {
  .top_tec_images {
    margin-top: 24px;
  }
}
.top_tec_images .item {
  width: 47%;
  padding: 0 32px 32px 0;
  position: relative;
  opacity: 0;
}
@media (max-width: 559.9px) {
  .top_tec_images .item {
    padding: 0 20px 20px 0;
    width: 100%;
    margin-bottom: 24px;
  }
}
.top_tec_images .item::after {
  width: calc(100% - 32px);
  height: calc(100% - 32px);
  content: "";
  background-color: #1A2D74;
  position: absolute;
  right: 0;
  bottom: 0;
  border-radius: 8px;
}
@media (max-width: 559.9px) {
  .top_tec_images .item::after {
    width: calc(100% - 20px);
    height: calc(100% - 20px);
  }
}
.top_tec_images .item .thumb {
  position: relative;
  z-index: 1;
  transition: all 0.4s ease;
}
.top_tec_images .item .thumb img {
  border-radius: 8px;
}
.top_tec_images .item .tit {
  position: absolute;
  z-index: 2;
  background-color: #1A2D74;
  color: white;
  padding: 8px 20px;
  right: 0;
  bottom: 20px;
  border-radius: 8px;
  font-size: 2rem;
}
@media (max-width: 559.9px) {
  .top_tec_images .item .tit {
    bottom: 0px;
  }
}
.top_tec_images .item .float_link {
  z-index: 3;
}
.top_tec_images.moved .item {
  -webkit-animation: fadeIn 0.4s ease 0.1s forwards;
          animation: fadeIn 0.4s ease 0.1s forwards;
}
.top_tec_images.moved .item:nth-child(2) {
  -webkit-animation: fadeIn 0.4s ease 0.4s forwards;
          animation: fadeIn 0.4s ease 0.4s forwards;
}

.top_tec_slider {
  opacity: 0;
  transform: translate(20px);
  transition: opacity 1s cubic-bezier(0.23, 1, 0.32, 1), transform 1s cubic-bezier(0.23, 1, 0.32, 1);
  overflow: visible;
}
@media (min-width: 1160px) {
  .top_tec_slider {
    margin-left: -30px;
  }
}
@media (min-width: 821px) {
  .top_tec_slider {
    margin-top: 110px;
  }
}
@media (max-width: 820.9px) {
  .top_tec_slider {
    margin-top: 40px;
  }
}
.top_tec_slider.moved {
  opacity: 1;
  transform: translate(0);
}
.top_tec_slider.moved .news_slide-image-inner img {
  opacity: 1;
  transform: scale(1);
}
.top_tec_slider .swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
}
.top_tec_slider .swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
  transform: translateZ(0);
}
.top_tec_slider .top_tec_slide_inner {
  display: block;
  position: relative;
  padding-top: 48px;
}
.top_tec_slider .top_tec_slide_inner .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 8rem;
  font-weight: 400;
  line-height: 1.5;
  color: #1A2D74;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  line-height: 1;
}
.top_tec_slider .top_tec_slide_inner .thumb {
  width: 100%;
  position: relative;
  aspect-ratio: 5/4;
  overflow: hidden;
}
.top_tec_slider .top_tec_slide_inner .thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  border-radius: 8px;
  transition: all 0.3s ease;
}
.top_tec_slider .top_tec_slide_inner .titArea {
  padding: 10px;
  display: flex;
  justify-content: space-between;
}
.top_tec_slider .top_tec_slide_inner .titArea .ttl {
  font-size: 2.4rem;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .top_tec_slider .top_tec_slide_inner .titArea .ttl {
    font-size: 2.2rem;
  }
}
@media (max-width: 559.9px) {
  .top_tec_slider .top_tec_slide_inner .titArea .ttl {
    font-size: 1.8rem;
  }
}
.top_tec_slider .top_tec_slide_inner .titArea span {
  background-color: #1A2D74;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  transition: all 0.3s ease;
}
.top_tec_slider .top_tec_slide_inner .titArea span img {
  display: block;
  width: 12px;
}
.top_tec_slider .top_tec_slide_inner .textArea {
  padding: 0 10px;
}
.top_tec_slider .top_tec_slide_inner .textArea p {
  color: #4B505A;
}
.top_tec_slider .top_tec_slide_inner:hover .thumb img {
  transform: scale(1.1);
}
.top_tec_slider .top_tec_slide_inner:hover .titArea span {
  background-color: #3795D5;
}
.top_tec_slider .swiper-button-prev,
.top_tec_slider .swiper-button-next {
  position: absolute;
  z-index: 2;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 0;
  background-color: #B3B1B9;
  border-radius: 8px;
}
.top_tec_slider .swiper-button-prev i,
.top_tec_slider .swiper-button-next i {
  color: white;
}
@media (min-width: 560px) {
  .top_tec_slider .swiper-button-prev,
.top_tec_slider .swiper-button-next {
    width: 48px;
    height: 48px;
  }
}
@media (max-width: 820.9px) {
  .top_tec_slider .swiper-button-prev,
.top_tec_slider .swiper-button-next {
    width: 32px;
    height: 32px;
    top: 40%;
  }
}
@media (max-width: 559.9px) {
  .top_tec_slider .swiper-button-prev,
.top_tec_slider .swiper-button-next {
    display: none;
  }
}
.top_tec_slider .swiper-button-prev::after,
.top_tec_slider .swiper-button-next::after {
  display: none;
}
@media (min-width: 821px) {
  .top_tec_slider .swiper-button-prev {
    left: auto;
    right: 56px;
    top: -72px;
    padding: 0;
  }
}
@media (max-width: 820.9px) {
  .top_tec_slider .swiper-button-prev {
    left: -10px;
  }
}
.top_tec_slider .swiper-button-prev.swiper-button-disabled {
  background-color: #ccc;
}
@media (min-width: 821px) {
  .top_tec_slider .swiper-button-next {
    right: 0;
    top: -72px;
    padding: 0;
  }
}
@media (max-width: 820.9px) {
  .top_tec_slider .swiper-button-next {
    right: -10px;
  }
}
.top_tec_slider .swiper-button-next.swiper-button-disabled {
  background-color: #ccc;
}

.top_reason_section {
  width: 100%;
  background: url(../images/top/top_rect_bg.jpg) no-repeat;
  background-size: cover;
  padding: 80px 0;
}
@media (max-width: 559.9px) {
  .top_reason_section {
    padding: 64px 0;
  }
}
.top_reason_section .headTit .eng {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 4rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 4px;
  opacity: 0;
}
@media (max-width: 559.9px) {
  .top_reason_section .headTit .eng {
    font-size: 1.8rem;
  }
}
.top_reason_section .headTit .jp {
  font-size: 4rem;
  opacity: 0;
}
@media (max-width: 559.9px) {
  .top_reason_section .headTit .jp {
    font-size: 2.3rem;
  }
}
.top_reason_section .headTit.moved .eng {
  -webkit-animation: slideIn 0.4s ease 0.1s forwards;
          animation: slideIn 0.4s ease 0.1s forwards;
}
.top_reason_section .headTit.moved .jp {
  -webkit-animation: slideIn 0.4s ease 0.4s forwards;
          animation: slideIn 0.4s ease 0.4s forwards;
}

.top_reason_wrap {
  width: 100%;
  display: flex;
}
@media (max-width: 820.9px) {
  .top_reason_wrap {
    flex-direction: column;
  }
}
.top_reason_wrap .textSide {
  width: 440px;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .top_reason_wrap .textSide {
    width: 400px;
  }
}
@media (max-width: 820.9px) {
  .top_reason_wrap .textSide {
    width: 100%;
  }
}
.top_reason_wrap .textSide .leadTexts {
  margin-top: 50px;
}
@media (max-width: 559.9px) {
  .top_reason_wrap .textSide .leadTexts {
    margin-top: 30px;
  }
}
.top_reason_wrap .textSide .leadTexts > p {
  display: inline-block;
  background-color: transparent;
  color: #191718;
  font-weight: 700;
  font-size: 2.2rem;
  padding: 4px 24px;
  line-height: 1.5;
  position: relative;
  background-image: linear-gradient(90deg, rgb(255, 255, 255), rgb(255, 255, 255) 50%, rgba(255, 255, 255, 0) 50%, rgba(255, 255, 255, 0));
  background-position: 100% 0;
  background-size: 200% 100%;
  transition: background-position 1s ease-in-out;
  margin-bottom: 16px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_reason_wrap .textSide .leadTexts > p {
    font-size: 4rem;
  }
}
@media (max-width: 559.9px) {
  .top_reason_wrap .textSide .leadTexts > p {
    font-size: 1.7rem;
    padding: 2px 8px;
    margin-bottom: 8px;
  }
}
.top_reason_wrap .textSide .leadTexts .innerTxt {
  opacity: 0;
  letter-spacing: 4px;
}
.top_reason_wrap .textSide .leadTexts.moved > p {
  background-position: 0 0;
}
.top_reason_wrap .textSide .leadTexts.moved .innerTxt {
  -webkit-animation: slideIn 0.4s ease 1s forwards;
          animation: slideIn 0.4s ease 1s forwards;
}
.top_reason_wrap .contSide {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 48px 24px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_reason_wrap .contSide {
    margin-top: 80px;
  }
}
@media (max-width: 559.9px) {
  .top_reason_wrap .contSide {
    gap: 48px 16px;
    margin-top: 48px;
  }
}
.top_reason_wrap .contSide .item {
  width: calc(50% - 12px);
  position: relative;
  opacity: 0;
}
@media (max-width: 559.9px) {
  .top_reason_wrap .contSide .item {
    width: calc(50% - 8px);
  }
}
.top_reason_wrap .contSide .item .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 6.4rem;
  font-weight: 400;
  line-height: 1.5;
  line-height: 1;
  color: #1A2D74;
  position: absolute;
  left: -10px;
  top: -32px;
}
@media (max-width: 559.9px) {
  .top_reason_wrap .contSide .item .num {
    font-size: 4rem;
    top: -20px;
  }
}
.top_reason_wrap .contSide .item .image {
  border-radius: 8px;
  overflow: hidden;
}
.top_reason_wrap .contSide .item .caption {
  font-size: 1.6rem;
  font-weight: bold;
  padding: 4px 8px 0;
  text-align: left;
}
@media (max-width: 559.9px) {
  .top_reason_wrap .contSide .item .caption {
    font-size: 1.4rem;
  }
}
.top_reason_wrap .contSide.moved .item {
  -webkit-animation: fadeIn 0.5s ease 0.1s forwards;
          animation: fadeIn 0.5s ease 0.1s forwards;
}
.top_reason_wrap .contSide.moved .item:nth-child(2) {
  -webkit-animation: fadeIn 0.5s ease 0.3s forwards;
          animation: fadeIn 0.5s ease 0.3s forwards;
}
.top_reason_wrap .contSide.moved .item:nth-child(3) {
  -webkit-animation: fadeIn 0.5s ease 0.5s forwards;
          animation: fadeIn 0.5s ease 0.5s forwards;
}
.top_reason_wrap .contSide.moved .item:nth-child(4) {
  -webkit-animation: fadeIn 0.5s ease 0.7s forwards;
          animation: fadeIn 0.5s ease 0.7s forwards;
}

.top_sp_section {
  background: url(../images/top/top_sm_bg.jpg) no-repeat center bottom;
  background-size: cover;
  padding: 3vw;
}
@media (min-width: 1160px) {
  .top_sp_section {
    height: 100vh;
    max-height: 960px;
  }
}
.top_sp_section .inner {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .top_sp_section .inner {
    padding: 80px 40px;
  }
}
.top_sp_section .inner::before, .top_sp_section .inner::after {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  background-color: white;
}
.top_sp_section .inner::before {
  width: 100%;
  height: 2px;
  top: 0;
  left: -100%;
  transition: all 0.5s ease;
}
.top_sp_section .inner::after {
  height: 100%;
  width: 2px;
  top: -100%;
  right: 0;
  transition: all 0.5s ease 0.5s;
}
.top_sp_section .inner .moveline {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 100%;
  height: 100%;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_sp_section .inner .moveline {
    padding: 96px 40px;
  }
}
@media (max-width: 559.9px) {
  .top_sp_section .inner .moveline {
    padding: 56px 24px;
  }
}
.top_sp_section .inner .moveline::after, .top_sp_section .inner .moveline::before {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  background-color: white;
}
.top_sp_section .inner .moveline::before {
  width: 100%;
  height: 2px;
  bottom: 0;
  right: -100%;
  transition: all 0.5s ease 1s;
}
.top_sp_section .inner .moveline::after {
  height: 100%;
  width: 2px;
  bottom: -100%;
  left: 0;
  transition: all 0.5s ease 1.5s;
}
.top_sp_section .inner .moveline .headArea {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 40px;
}
@media (max-width: 820.9px) {
  .top_sp_section .inner .moveline .headArea {
    margin-bottom: 24px;
  }
}
.top_sp_section .inner .moveline .headArea .titText {
  font-size: max(3.2rem, 4.8vw);
  color: white;
  font-weight: 900;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_sp_section .inner .moveline .headArea .titText {
    font-size: 5rem;
  }
}
@media (max-width: 559.9px) {
  .top_sp_section .inner .moveline .headArea .titText {
    font-size: 3rem;
  }
}
.top_sp_section .inner .moveline .headArea .cross {
  width: 7vw;
  aspect-ratio: 1/1;
  position: relative;
}
.top_sp_section .inner .moveline .headArea .cross::before, .top_sp_section .inner .moveline .headArea .cross::after {
  content: "";
  display: block;
  width: 5vw;
  height: 1vw;
  position: absolute;
  left: 50%;
  top: 50%;
  max-width: 0;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_sp_section .inner .moveline .headArea .cross::before, .top_sp_section .inner .moveline .headArea .cross::after {
    width: 80%;
    height: 7px;
  }
}
@media (max-width: 559.9px) {
  .top_sp_section .inner .moveline .headArea .cross::before, .top_sp_section .inner .moveline .headArea .cross::after {
    width: 80%;
    height: 4px;
  }
}
.top_sp_section .inner .moveline .headArea .cross::before {
  background-color: #00EDD5;
  transform: translate(-50%, -50%) rotate(45deg);
  -webkit-animation: mainCross 0.8s ease 1.5s forwards;
          animation: mainCross 0.8s ease 1.5s forwards;
}
.top_sp_section .inner .moveline .headArea .cross::after {
  background-color: #00EDD5;
  transform: translate(-50%, -50%) rotate(315deg);
  -webkit-animation: mainCross 0.8s ease 2.2s forwards;
          animation: mainCross 0.8s ease 2.2s forwards;
}
.top_sp_section .inner .moveline .subTit {
  font-size: max(4rem, 3vw);
  color: white;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_sp_section .inner .moveline .subTit {
    font-size: 3rem;
  }
}
@media (max-width: 559.9px) {
  .top_sp_section .inner .moveline .subTit {
    font-size: 2.2rem;
    text-align: center;
    line-height: 1.5;
  }
}
.top_sp_section .inner .moveline .innerText {
  font-size: max(1.6rem, 1.2vw);
  color: white;
  text-align: center;
  margin: 20px auto 64px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_sp_section .inner .moveline .innerText {
    font-size: 1.5rem;
    margin-bottom: 10px;
  }
}
@media (max-width: 559.9px) {
  .top_sp_section .inner .moveline .innerText {
    font-size: 1.4rem;
    margin: 30px auto 0;
  }
}
.top_sp_section.moved .inner::before {
  left: 0;
}
.top_sp_section.moved .inner::after {
  top: 0;
}
.top_sp_section.moved .inner .moveline::before {
  right: 0;
}
.top_sp_section.moved .inner .moveline::after {
  bottom: 0;
}

@-webkit-keyframes mainCross {
  0% {
    max-width: 0;
  }
  100% {
    max-width: 100px;
  }
}

@keyframes mainCross {
  0% {
    max-width: 0;
  }
  100% {
    max-width: 100px;
  }
}
.top_faq_section {
  background-color: #7BCCEA;
  padding: 80px 0;
  width: 100%;
  overflow: hidden;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_faq_section {
    padding: 64px 0;
  }
}
@media (max-width: 559.9px) {
  .top_faq_section {
    padding: 40px 0;
  }
}
.top_faq_section.aSection {
  background-color: #566E90;
}
.top_faq_section .faqHead {
  width: 100%;
  position: relative;
  margin-bottom: 50px;
}
.top_faq_section .faqHead .faqHeadTxt {
  color: white;
  font-size: 2.4rem;
  letter-spacing: 2px;
  position: relative;
  z-index: 3;
  opacity: 0;
}
@media (min-width: 560px) {
  .top_faq_section .faqHead .faqHeadTxt {
    display: flex;
    align-items: center;
    justify-content: flex-start;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_faq_section .faqHead .faqHeadTxt {
    font-size: 2rem;
  }
}
@media (max-width: 559.9px) {
  .top_faq_section .faqHead .faqHeadTxt {
    padding-top: 96px;
    text-align: center;
    line-height: 1.5;
  }
}
.top_faq_section .faqHead .faqHeadTxt .alpha {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 6rem;
  font-weight: 700;
  line-height: 1.5;
  margin-right: 20px;
}
@media (max-width: 559.9px) {
  .top_faq_section .faqHead .faqHeadTxt .alpha {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
  }
}
.top_faq_section .faqHead .faqHeadTxt .color {
  color: #4B505A;
}
.top_faq_section .faqHead .engTxt {
  color: white;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.5;
  width: 244px;
  letter-spacing: 5px;
  opacity: 0.6;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_faq_section .faqHead .engTxt {
    width: 200px;
    font-size: 1.5rem;
    letter-spacing: 2px;
  }
}
@media (max-width: 559.9px) {
  .top_faq_section .faqHead .engTxt {
    font-size: 1.3rem;
    width: 100%;
    margin-top: 10px;
    letter-spacing: 1px;
    text-align: center;
  }
}
.top_faq_section .faqHead.qZone .engTxt {
  opacity: 0;
}
@media (min-width: 560px) {
  .top_faq_section .faqHead.qZone .engTxt {
    position: absolute;
    right: 36px;
    top: -3px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_faq_section .faqHead.qZone .engTxt {
    right: 0;
    top: 4px;
  }
}
.top_faq_section .faqHead.qZone::before {
  content: "";
  display: block;
  border-radius: 50%;
  width: 0px;
  height: 0px;
  background-color: #3795D5;
  position: absolute;
  right: 170px;
  top: 0px;
  transform: translate(20%, -40%);
  transition: all 0.6s cubic-bezier(0.445, 0.05, 0.55, 0.95) 0.3s;
}
.top_faq_section .faqHead.qZone::after {
  content: "";
  display: block;
  border-radius: 50%;
  width: 0px;
  height: 0px;
  background-color: #F0FBFF;
  position: absolute;
  right: 170px;
  top: 0px;
  opacity: 0.2;
  transform: translate(15%, -38%);
  transition: all 0.6s cubic-bezier(0.445, 0.05, 0.55, 0.95) 0.7s;
}
@media (min-width: 821px) {
  .top_faq_section .faqHead.aZone {
    padding-left: 400px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_faq_section .faqHead.aZone {
    padding-left: 240px;
  }
}
.top_faq_section .faqHead.aZone .engTxt {
  opacity: 0;
}
@media (min-width: 560px) {
  .top_faq_section .faqHead.aZone .engTxt {
    position: absolute;
    left: 0;
    top: -3px;
    z-index: 3;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_faq_section .faqHead.aZone .engTxt {
    top: 4px;
  }
}
.top_faq_section .faqHead.aZone::before {
  content: "";
  display: block;
  border-radius: 50%;
  width: 0px;
  height: 0px;
  background-color: #00A094;
  position: absolute;
  left: 90px;
  top: 0;
  transform: translate(-33%, -40%);
  transition: all 0.6s cubic-bezier(0.445, 0.05, 0.55, 0.95) 0.3s;
}
.top_faq_section .faqHead.aZone::after {
  content: "";
  display: block;
  border-radius: 50%;
  width: 0px;
  height: 0px;
  background-color: #06E8D2;
  position: absolute;
  left: 90px;
  top: 0;
  opacity: 0.7;
  transform: translate(-30%, -38%);
  transition: all 0.6s cubic-bezier(0.445, 0.05, 0.55, 0.95) 0.7s;
}
.top_faq_section .faqHead.moved .faqHeadTxt {
  -webkit-animation: slideIn 0.4s ease forwards;
          animation: slideIn 0.4s ease forwards;
}
.top_faq_section .faqHead.moved.qZone .engTxt {
  -webkit-animation: slideIn 0.4s ease 1.2s forwards;
          animation: slideIn 0.4s ease 1.2s forwards;
}
.top_faq_section .faqHead.moved.qZone::before {
  width: 560px;
  height: 560px;
  right: 0px;
  top: 0px;
  transform: translate(20%, -40%);
}
.top_faq_section .faqHead.moved.qZone::after {
  width: 480px;
  height: 480px;
  right: 0px;
  top: 0px;
  transform: translate(15%, -38%);
}
.top_faq_section .faqHead.moved.aZone .engTxt {
  -webkit-animation: slideIn 0.4s ease 1.2s forwards;
          animation: slideIn 0.4s ease 1.2s forwards;
}
.top_faq_section .faqHead.moved.aZone::before {
  width: 560px;
  height: 560px;
  left: 0;
  top: 0;
  transform: translate(-33%, -40%);
}
.top_faq_section .faqHead.moved.aZone::after {
  width: 480px;
  height: 480px;
  left: 0;
  top: 0;
  transform: translate(-30%, -38%);
}
.top_faq_section.page {
  background-color: #566E90;
}
.top_faq_section.page .faqHead .faqHeadTxt .color {
  color: #F4DF35;
}
.top_faq_section.page .faqHead.qZone::before {
  background-color: #D8DAE5;
  opacity: 0.2;
}

.q-list {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 12px 12px;
  position: relative;
}
.q-list > li {
  background-color: white;
  width: calc(33.3333333333% - 8px);
  border-radius: 8px;
  padding-bottom: 12px;
  opacity: 0;
}
@media (max-width: 559.9px) {
  .q-list > li {
    width: 100%;
  }
}
.q-list > li .q-text {
  padding: 24px 24px 16px;
  text-align: center;
  font-weight: 500;
  letter-spacing: 2px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .q-list > li .q-text br {
    display: none;
  }
}
.q-list > li .q-text span {
  color: #CD0491;
}
.q-list > li .tagArea {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
}
.q-list > li .tagArea span {
  border: 1px #191718 solid;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3px 10px;
  font-size: 1.1rem;
  font-weight: 500;
  border-radius: 30px;
}
.q-list > li .tagArea span::before {
  content: "#";
}
.q-list.moved > li {
  -webkit-animation: fadeIn 0.4s ease 0.2s forwards;
          animation: fadeIn 0.4s ease 0.2s forwards;
}
.q-list.moved > li:nth-child(2) {
  -webkit-animation: fadeIn 0.4s ease 0.4s forwards;
          animation: fadeIn 0.4s ease 0.4s forwards;
}
.q-list.moved > li:nth-child(3) {
  -webkit-animation: fadeIn 0.4s ease 0.6s forwards;
          animation: fadeIn 0.4s ease 0.6s forwards;
}
.q-list.moved > li:nth-child(4) {
  -webkit-animation: fadeIn 0.4s ease 0.8s forwards;
          animation: fadeIn 0.4s ease 0.8s forwards;
}
.q-list.moved > li:nth-child(5) {
  -webkit-animation: fadeIn 0.4s ease 1s forwards;
          animation: fadeIn 0.4s ease 1s forwards;
}
.q-list.moved > li:nth-child(6) {
  -webkit-animation: fadeIn 0.4s ease 1.2s forwards;
          animation: fadeIn 0.4s ease 1.2s forwards;
}

.top_solition_slider {
  opacity: 0;
  transform: translate(20px);
  transition: opacity 1s cubic-bezier(0.23, 1, 0.32, 1), transform 1s cubic-bezier(0.23, 1, 0.32, 1);
  overflow: visible;
}
@media (max-width: 559.9px) {
  .top_solition_slider {
    margin-top: 40px;
  }
}
.top_solition_slider.moved {
  opacity: 1;
  transform: translate(0);
}
.top_solition_slider.moved .news_slide-image-inner img {
  opacity: 1;
  transform: scale(1);
}
.top_solition_slider .swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
}
.top_solition_slider .swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
  transform: translateZ(0);
}
.top_solition_slider .item {
  display: block;
  position: relative;
}
.top_solition_slider .item .thumb {
  width: 100%;
  position: relative;
  aspect-ratio: 2/1;
}
.top_solition_slider .item .thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  border-radius: 8px;
}
.top_solition_slider .item .inner {
  padding: 10px 10px 0;
}
.top_solition_slider .item .inner .sol_eng {
  display: inline-block;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  color: white;
  letter-spacing: 2px;
  border-bottom: 2px white solid;
  padding: 0 10px 6px 0;
}
.top_solition_slider .item .inner .innerText {
  width: 280px;
  color: white;
  font-weight: 500;
  letter-spacing: 2px;
  margin-top: 12px;
}
.top_solition_slider .swiper-button-prev,
.top_solition_slider .swiper-button-next {
  position: absolute;
  z-index: 2;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 0;
  background-color: #00EDD5;
  border-radius: 50%;
}
.top_solition_slider .swiper-button-prev i,
.top_solition_slider .swiper-button-next i {
  color: white;
}
@media (min-width: 560px) {
  .top_solition_slider .swiper-button-prev,
.top_solition_slider .swiper-button-next {
    width: 56px;
    height: 56px;
  }
}
@media (max-width: 820.9px) {
  .top_solition_slider .swiper-button-prev,
.top_solition_slider .swiper-button-next {
    width: 32px;
    height: 32px;
    top: 40%;
  }
}
@media (max-width: 559.9px) {
  .top_solition_slider .swiper-button-prev,
.top_solition_slider .swiper-button-next {
    display: none;
  }
}
.top_solition_slider .swiper-button-prev::after,
.top_solition_slider .swiper-button-next::after {
  display: none;
}
@media (min-width: 821px) {
  .top_solition_slider .swiper-button-prev {
    left: -30px;
    top: 32%;
    padding: 0;
  }
}
@media (max-width: 820.9px) {
  .top_solition_slider .swiper-button-prev {
    left: -10px;
  }
}
.top_solition_slider .swiper-button-prev.swiper-button-disabled {
  background-color: #ccc;
}
@media (min-width: 821px) {
  .top_solition_slider .swiper-button-next {
    right: -30px;
    top: 32%;
    padding: 0;
  }
}
@media (max-width: 820.9px) {
  .top_solition_slider .swiper-button-next {
    right: -10px;
  }
}
.top_solition_slider .swiper-button-next.swiper-button-disabled {
  background-color: #ccc;
}

.top_product_section {
  padding: 80px 0;
}
.top_product_section .bd {
  opacity: 0;
}
.top_product_section .bd.moved {
  -webkit-animation: slideIn 0.4s ease 0.6s forwards;
          animation: slideIn 0.4s ease 0.6s forwards;
}

.top_product_list {
  width: 100%;
  margin: 50px auto 0;
}
.top_product_list > li {
  display: flex;
  justify-content: space-between;
  opacity: 0;
  position: relative;
}
.top_product_list > li.moved {
  -webkit-animation: fadeIn 0.4s ease forwards;
          animation: fadeIn 0.4s ease forwards;
}
@media (max-width: 559.9px) {
  .top_product_list > li {
    flex-direction: column;
  }
}
.top_product_list > li:not(:last-child) {
  margin-bottom: 16px;
}
.top_product_list > li .thumb {
  width: 326px;
  aspect-ratio: 4/3;
  position: relative;
  overflow: hidden;
  border-radius: 8px;
}
@media (max-width: 559.9px) {
  .top_product_list > li .thumb {
    width: 100%;
  }
}
.top_product_list > li .thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  border-radius: 8px;
  transition: all 0.3s ease;
}
.top_product_list > li:hover .thumb img {
  transform: scale(1.1);
}
.top_product_list > li .inner {
  width: calc(100% - 342px);
  background-color: #f5f5f5;
  border-radius: 8px;
}
@media (min-width: 560px) {
  .top_product_list > li .inner {
    padding: 20px 48px;
  }
}
@media (max-width: 559.9px) {
  .top_product_list > li .inner {
    width: 100%;
    margin-top: 5px;
    padding: 20px;
  }
}
.top_product_list > li .inner .product_list_title {
  font-size: 2rem;
}
.top_product_list > li .inner .cat_tag {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 2px 2px;
  margin-top: 8px;
}
@media (max-width: 559.9px) {
  .top_product_list > li .inner .cat_tag {
    margin-top: 5px;
  }
}
.top_product_list > li .inner .cat_tag .cat_tag_item {
  display: inline-block;
  padding: 1px 12px;
  background-color: white;
  color: #3795D5;
  font-size: 1.2rem;
  border: 1px #3795D5 solid;
}
@media (max-width: 559.9px) {
  .top_product_list > li .inner .cat_tag .cat_tag_item {
    font-size: 1.1rem;
    line-height: 1.5;
  }
}
.top_product_list > li .inner dl {
  border-top: 1px #191718 solid;
  margin-top: 20px;
}
.top_product_list > li .inner dl dt {
  padding-top: 16px;
  font-weight: bold;
}
.top_product_list > li .inner dl dd {
  padding: 2px 0 0;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_product_list > li .inner dl dd {
    font-size: 1.4rem;
  }
}

.top_panel_section {
  background-color: #f5f5f5;
  padding: 80px 0;
}

.top_panels {
  width: 100%;
  display: flex;
  gap: 20px;
}
@media (max-width: 559.9px) {
  .top_panels {
    flex-direction: column;
  }
}
.top_panels .top_panel {
  width: calc(50% - 10px);
  position: relative;
  opacity: 0;
}
@media (max-width: 559.9px) {
  .top_panels .top_panel {
    width: 100%;
  }
}
.top_panels .top_panel .img {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
}
.top_panels .top_panel .img img {
  transition: all 0.4s ease;
}
.top_panels .top_panel .textArea {
  position: relative;
  top: -24px;
  display: flex;
  justify-content: space-between;
  padding: 0 10px 0 24px;
}
.top_panels .top_panel .textArea .tit .eng {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 5.6rem;
  font-weight: 400;
  line-height: 1.5;
  color: #1A2D74;
  line-height: 1;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_panels .top_panel .textArea .tit .eng {
    font-size: 4.8rem;
  }
}
@media (max-width: 559.9px) {
  .top_panels .top_panel .textArea .tit .eng {
    font-size: 3.4rem;
  }
}
.top_panels .top_panel .textArea .tit .jp {
  font-size: 2.2rem;
  font-weight: bold;
  padding-left: 3px;
}
@media (max-width: 820.9px) {
  .top_panels .top_panel .textArea .tit .jp {
    font-size: 2rem;
  }
}
.top_panels .top_panel .textArea .circle {
  width: 51px;
  height: 51px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #1A2D74;
  border-radius: 50%;
  transition: all 0.4s ease;
}
.top_panels .top_panel .textArea .circle i {
  color: white;
}
.top_panels .top_panel:hover .img img {
  transform: scale(1.05);
}
.top_panels .top_panel:hover .circle {
  background-color: #3795D5;
}
.top_panels.moved .top_panel {
  -webkit-animation: fadeIn 0.4s ease forwards;
          animation: fadeIn 0.4s ease forwards;
}
.top_panels.moved .top_panel:nth-child(2) {
  -webkit-animation: fadeIn 0.4s ease 0.3s forwards;
          animation: fadeIn 0.4s ease 0.3s forwards;
}

.top_recruit {
  width: 100%;
  position: relative;
  margin-top: 40px;
}
@media (min-width: 560px) {
  .top_recruit {
    padding-top: 56px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_recruit {
    padding-top: 160px;
  }
}
.top_recruit .textArea {
  background-color: #7BCCEA;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-radius: 8px;
  z-index: 10;
  opacity: 0;
}
@media (min-width: 560px) {
  .top_recruit .textArea {
    width: 432px;
    height: 320px;
    position: absolute;
    left: 0;
    top: 0;
    padding: 0 40px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_recruit .textArea {
    height: 200px;
  }
}
@media (max-width: 559.9px) {
  .top_recruit .textArea {
    width: 100%;
    height: auto;
    padding: 24px;
    border-radius: 8px 8px 0 0;
  }
}
.top_recruit .textArea .big-title {
  margin-bottom: 0;
}
.top_recruit .textArea .innerTxt {
  color: white;
  margin-top: 20px;
}
@media (max-width: 559.9px) {
  .top_recruit .textArea .innerTxt {
    margin-top: 10px;
  }
}
.top_recruit .imgArea {
  width: 720px;
  height: 480px;
  position: relative;
  margin-left: auto;
  border-radius: 8px;
  overflow: hidden;
  opacity: 0;
}
@media (max-width: 559.9px) {
  .top_recruit .imgArea {
    width: 100%;
    height: auto;
    border-radius: 0 0 8px 8px;
  }
}
.top_recruit .imgArea .btn-circle {
  position: absolute;
  right: 40px;
  bottom: 24px;
  z-index: 10;
}
.top_recruit.moved .textArea {
  -webkit-animation: slideIn 0.4s ease 0.1s forwards;
          animation: slideIn 0.4s ease 0.1s forwards;
}
.top_recruit.moved .imgArea {
  -webkit-animation: slideIn 0.4s ease 0.4s forwards;
          animation: slideIn 0.4s ease 0.4s forwards;
}

.top_news_section {
  padding: 96px 0;
  background-color: #F0FBFF;
  position: relative;
  overflow: hidden;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_news_section {
    padding: 48px 3vw;
  }
}
@media (max-width: 559.9px) {
  .top_news_section {
    padding: 48px 0;
  }
}
.top_news_section .wrap {
  position: relative;
}
@media (min-width: 821px) {
  .top_news_section .wrap {
    display: flex;
    justify-content: space-between;
  }
}
@media (max-width: 820.9px) {
  .top_news_section .wrap {
    padding-bottom: 100px;
  }
}
@media (min-width: 821px) {
  .top_news_section .wrap .tit_side {
    width: 200px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_news_section .wrap .tit_side {
    width: 100%;
  }
}
.top_news_section .wrap .tit_side .t_news_eng {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 6rem;
  font-weight: 400;
  line-height: 1.5;
  color: #1A2D74;
}
@media (min-width: 821px) {
  .top_news_section .wrap .tit_side .btn-circle {
    width: 100%;
  }
}
@media (max-width: 820.9px) {
  .top_news_section .wrap .tit_side .btn-circle {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 821px) {
  .top_news_section .wrap .news_side {
    width: calc(100% - 320px);
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_news_section .wrap .news_side {
    width: 100%;
  }
}

.top_news_cats {
  margin-top: 24px;
}
@media (max-width: 820.9px) {
  .top_news_cats {
    display: flex;
    align-items: center;
    justify-content: flex-start;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_news_cats {
    margin-bottom: 32px;
  }
}
.top_news_cats li {
  font-weight: bold;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
@media (min-width: 821px) {
  .top_news_cats li:not(:last-child) {
    margin-bottom: 8px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_news_cats li:not(:last-child) {
    margin-right: 15px;
  }
}
@media (max-width: 559.9px) {
  .top_news_cats li:not(:last-child) {
    margin-right: 6px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .top_news_cats li {
    padding-bottom: 10px;
  }
}
@media (max-width: 559.9px) {
  .top_news_cats li {
    font-size: 1.4rem;
    padding-bottom: 10px;
  }
}
.top_news_cats li.current {
  color: #1A2D74;
}
.top_news_cats li.current::after {
  content: "";
  display: block;
  width: 7px;
  height: 7px;
  border-radius: 8px;
  background-color: #1A2D74;
}
@media (min-width: 821px) {
  .top_news_cats li.current::after {
    margin-left: 10px;
  }
}
@media (max-width: 820.9px) {
  .top_news_cats li.current::after {
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
  }
}
.top_news_cats li:not(.top_news_cats li.current) {
  cursor: pointer;
}
.top_news_cats li a {
  color: #1A2D74;
}

@media (max-width: 559.9px) {
  .top_news_wrap {
    margin-top: 40px;
  }
}
.top_news_wrap .item {
  border-bottom: 1px #ddd solid;
  padding: 24px 0;
  position: relative;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 559.9px) {
  .top_news_wrap .item {
    padding: 16px 4px;
  }
}
.top_news_wrap .item:first-child {
  border-top: 1px #ddd solid;
}
.top_news_wrap .item .thumb {
  width: 240px;
  aspect-ratio: 16/9;
  position: relative;
  overflow: hidden;
  border-radius: 8px;
}
@media (max-width: 559.9px) {
  .top_news_wrap .item .thumb {
    width: 88px;
    height: 88px;
  }
}
.top_news_wrap .item .thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  transition: all 0.3s ease;
}
.top_news_wrap .item .inner {
  width: calc(100% - 280px);
}
@media (max-width: 559.9px) {
  .top_news_wrap .item .inner {
    width: calc(100% - 104px);
  }
}
.top_news_wrap .item .inner .top_news_head {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  margin-bottom: 24px;
}
@media (max-width: 559.9px) {
  .top_news_wrap .item .inner .top_news_head {
    margin-bottom: 8px;
  }
}
.top_news_wrap .item .inner .top_news_head .date {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  color: #1A2D74;
  padding-top: 3px;
  margin-right: 32px;
}
@media (max-width: 559.9px) {
  .top_news_wrap .item .inner .top_news_head .date {
    font-size: 1.3rem;
    margin-right: 16px;
  }
}
.top_news_wrap .item .inner .top_news_head .top_news_cat_tags {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: flex-start;
  align-content: flex-start;
}
.top_news_wrap .item .inner .top_news_head .top_news_cat_tags span {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 27px;
  background-color: #d6d6d6;
  padding: 0 16px;
  border-radius: 24px;
  font-family: Arial, Helvetica, "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.4rem;
}
@media (max-width: 559.9px) {
  .top_news_wrap .item .inner .top_news_head .top_news_cat_tags span {
    height: 21px;
    font-size: 1.2rem;
  }
}
.top_news_wrap .item .inner .tit {
  font-weight: bold;
}
@media (max-width: 559.9px) {
  .top_news_wrap .item .inner .tit {
    font-size: 1.3rem;
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
}
.top_news_wrap .item:hover .thumb img {
  transform: scale(1.1);
}

.news-target {
  transition: all 0.4s ease;
  display: none;
  opacity: 0;
  visibility: hidden;
}
.news-target.current {
  display: block;
  opacity: 1;
  visibility: visible;
}

/**************
Under PageTitle
**************/
.pageTitle {
  width: 100%;
  position: relative;
  overflow: hidden;
  background-color: #1A2D74;
}
@media (min-width: 1160px) {
  .pageTitle {
    height: 496px;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .pageTitle {
    height: 328px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .pageTitle {
    height: 250px;
  }
}
@media (max-width: 559.9px) {
  .pageTitle {
    height: 192px;
  }
}
.pageTitle .title_inner {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
}
.pageTitle .textArea {
  position: relative;
  height: 100%;
  width: 90%;
  margin: 0 auto;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  flex-direction: column;
  z-index: 2;
}
@media (min-width: 1160px) {
  .pageTitle .textArea {
    padding-top: 80px;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .pageTitle .textArea {
    padding-top: 128px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .pageTitle .textArea {
    padding-top: 128px;
  }
}
@media (max-width: 559.9px) {
  .pageTitle .textArea {
    padding-top: 108px;
  }
}
.pageTitle .textArea .eng {
  color: white;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.04em;
}
@media (max-width: 559.9px) {
  .pageTitle .textArea .eng {
    font-size: 1.2rem;
  }
}
.pageTitle .textArea .jp {
  color: #fff;
  font-size: 4rem;
  font-weight: 900;
  opacity: 0;
  -webkit-animation: slideIn 0.5s ease 0.2s forwards;
          animation: slideIn 0.5s ease 0.2s forwards;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .pageTitle .textArea .jp {
    font-size: 3.2rem;
  }
}
@media (max-width: 559.9px) {
  .pageTitle .textArea .jp {
    font-size: 2rem;
  }
}
.pageTitle .title_bg {
  width: 100%;
  height: 100%;
  position: relative;
}
.pageTitle .title_bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
@media (min-width: 560px) {
  .pageTitle.single_page {
    height: 200px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .pageTitle.single_page {
    height: 200px;
  }
}
@media (max-width: 559.9px) {
  .pageTitle.single_page {
    height: 120px;
  }
}
@media (min-width: 821px) {
  .pageTitle.single_page .textArea {
    opacity: 1;
    padding-top: 120px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .pageTitle.single_page .textArea {
    padding-top: 64px;
  }
}
@media (max-width: 559.9px) {
  .pageTitle.single_page .textArea {
    padding-top: 48px;
  }
}
@media (min-width: 821px) {
  .pageTitle.single_page .textArea .jp {
    display: none;
  }
}

.breadcrumbs {
  padding: 12px 0;
  font-size: 1.2rem;
  box-sizing: border-box;
}
.breadcrumbs a {
  display: inline-block;
  font-weight: normal;
  color: #666;
}

.flex_content {
  width: 100%;
  margin-bottom: 80px;
}
@media (min-width: 560px) {
  .flex_content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .flex_content.start {
    align-items: flex-start;
  }
  .flex_content.mt70 {
    margin-top: 70px;
  }
}
@media (min-width: 560px) {
  .flex_content_r {
    flex-direction: row-reverse;
  }
}
@media (max-width: 559.9px) {
  .flex_content > .item {
    width: 100%;
  }
  .flex_content > .item:not(:last-child) {
    margin-bottom: 24px;
  }
}
@media (min-width: 560px) {
  .flex_content .item_1 {
    width: 12%;
  }
}
@media (min-width: 560px) {
  .flex_content .item_2 {
    width: 21%;
  }
}
@media (min-width: 560px) {
  .flex_content .item_3 {
    width: 33%;
  }
}
@media (min-width: 560px) {
  .flex_content .item_35 {
    width: 38%;
  }
}
@media (min-width: 560px) {
  .flex_content .item_4 {
    width: 47.5%;
  }
}
.flex_content .item_4 .text_title {
  font-size: 2.4rem;
  font-weight: 600;
  margin-bottom: 30px;
}
@media (max-width: 559.9px) {
  .flex_content .item_4 .text_title {
    font-size: 1.8rem;
    margin-bottom: 18px;
  }
}
@media (min-width: 560px) {
  .flex_content .item_45 {
    width: 56%;
  }
}
@media (min-width: 560px) {
  .flex_content .item_5 {
    width: 62%;
  }
}
@media (min-width: 560px) {
  .flex_content .item_6 {
    width: 73%;
  }
}
@media (min-width: 560px) {
  .flex_content .item_7 {
    width: 84%;
  }
}

@media (min-width: 1160px) {
  .leftColumn {
    width: 230px;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .leftColumn {
    width: 22%;
  }
}

@media (min-width: 1160px) {
  .rightColumn {
    width: calc(100% - 340px);
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .rightColumn {
    width: 72%;
  }
}
@media (max-width: 820.9px) {
  .rightColumn {
    margin-top: 40px;
  }
}

.c_container {
  width: 100%;
}
@media (min-width: 560px) {
  .c_container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media (max-width: 820.9px) {
  .c_container {
    padding: 0 4%;
  }
}
@media (min-width: 560px) {
  .c_container .leftColumn {
    background-color: #f3f3f3;
  }
}

.news_container {
  width: 100%;
}
@media (min-width: 560px) {
  .news_container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    flex-direction: row-reverse;
  }
}
@media (max-width: 559.9px) {
  .news_container {
    display: flex;
    flex-direction: column-reverse;
  }
}
@media (min-width: 1160px) {
  .news_container .rightColumn {
    width: calc(100% - 300px);
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .news_container .rightColumn {
    width: 72%;
  }
}
@media (max-width: 820.9px) {
  .news_container .rightColumn {
    margin-top: 0px;
  }
}
@media (min-width: 1160px) {
  .news_container .leftColumn {
    width: 220px;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .news_container .leftColumn {
    width: 22%;
  }
}
@media (max-width: 820.9px) {
  .news_container .leftColumn {
    margin-top: 40px;
    width: 100%;
  }
}

.divider-full {
  margin: 35px 0;
  display: block;
  width: 100%;
  height: 1px;
  border-bottom: 1px #aaa dotted;
}
@media (max-width: 820.9px) {
  .divider-full {
    margin: 20px 0;
  }
}

.sticky_content {
  width: 100%;
}
@media (min-width: 821px) {
  .sticky_content {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}

/**************
Sidebar
**************/
@media (min-width: 821px) {
  .sidebar-sticky {
    position: -webkit-sticky;
    position: sticky;
    top: 100px;
    margin-bottom: 35px;
  }
  .admin-bar .sidebar-sticky {
    top: 132px;
  }
}

.sidebar_title {
  background-color: #14A5F4;
  padding: 16px 18px;
}
@media (max-width: 820.9px) {
  .sidebar_title {
    display: none;
  }
}
.sidebar_title.mt35 {
  margin-top: 35px;
}
.sidebar_title .jp {
  font-size: 1.5rem;
  color: #fff;
  font-weight: bold;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .sidebar_title .jp {
    font-size: 1.8rem;
  }
}
@media (max-width: 820.9px) {
  .sidebar_title .jp {
    font-size: 1.6rem;
  }
  .sidebar_title .jp br {
    display: none;
  }
}
.sidebar_title .eng {
  color: #fff;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.5;
  line-height: 1;
}

@media (max-width: 820.9px) {
  .side_links {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}
@media (min-width: 821px) {
  .side_links li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px #d9d9d9 solid;
    margin-top: 2px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .side_links li {
    display: block;
    width: 32%;
    margin-bottom: 10px;
  }
}
@media (max-width: 559.9px) {
  .side_links li {
    display: block;
    width: 49.4%;
    margin-bottom: 4px;
  }
}
.side_links li a {
  display: flex;
  width: 100%;
  align-items: center;
  padding: 12px 0 12px 18px;
  position: relative;
  color: #777;
  font-size: 1.5rem;
  line-height: 1.5;
  background-color: white;
  border-radius: 8px;
}
@media (max-width: 820.9px) {
  .side_links li a {
    border: 1px #3795D5 solid;
    width: 100%;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 0 8px 0 16px;
    color: #3795D5;
    line-height: 1.4;
    border-radius: 3px;
    background-color: white;
  }
}
@media (max-width: 559.9px) {
  .side_links li a {
    font-size: 3vw;
    height: 40px;
  }
}
.side_links li a::before {
  transform: translate(-50%, -50%);
  font-family: "Font Awesome 5 Free";
  content: "\f0da";
  display: block;
  position: absolute;
  left: 10px;
  top: 22px;
}
@media (max-width: 820.9px) {
  .side_links li a::before {
    top: 50%;
    left: 8px;
  }
}
.side_links li a:hover {
  background-color: #fafafa;
}
@media (min-width: 560px) {
  .side_links li.active a {
    color: #333;
  }
  .side_links li.active a::before {
    background-color: #14A5F4;
  }
}

/**************
選ばれる理由
**************/
.page_top_eng {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 4.8rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.06em;
  color: #1A2D74;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .page_top_eng {
    font-size: 4rem;
  }
}
@media (max-width: 559.9px) {
  .page_top_eng {
    font-size: 3rem;
    line-height: 1.3;
  }
}
.page_top_eng i {
  font-size: 3rem;
}
@media (max-width: 559.9px) {
  .page_top_eng i {
    font-size: 2.4rem;
  }
}

.with_jp {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  font-size: 2rem;
  font-weight: 500;
  color: #1A2D74;
  gap: 8px;
}
@media (max-width: 559.9px) {
  .with_jp {
    font-size: 1.6rem;
    margin-top: 15px;
  }
}
.with_jp::before {
  content: "";
  display: block;
  width: 30px;
  height: 1px;
  background-color: #1A2D74;
}

.reason_section {
  background-color: #f5f5f5;
  padding: 120px 0;
  position: relative;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .reason_section {
    padding: 100px 0;
  }
}
@media (max-width: 559.9px) {
  .reason_section {
    padding: 80px 0;
  }
}

.section_navi {
  position: absolute;
  top: -40px;
  background-color: white;
  border-radius: 8px;
  padding: 12px 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}
@media (min-width: 821px) {
  .section_navi {
    right: 10vw;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .section_navi {
    right: 40px;
  }
}
@media (max-width: 559.9px) {
  .section_navi {
    left: 50%;
    top: -20px;
    transform: translateX(-50%);
    padding: 10px 20px;
  }
}
.section_navi > a {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 4rem;
  font-weight: 400;
  line-height: 1.5;
  color: #1A2D74;
  line-height: 1;
  padding-bottom: 8px;
  display: block;
  position: relative;
}
@media (max-width: 559.9px) {
  .section_navi > a {
    font-size: 2.4rem;
  }
}
.section_navi > a::after {
  content: "";
  display: block;
  width: 100%;
  max-width: 0;
  background-color: #B3B1B9;
  height: 2px;
  transition: all 0.3s ease;
}
.section_navi > a:hover::after {
  max-width: 100%;
}

.reason_list {
  width: 90%;
  margin: 0 auto;
  max-width: 1280px;
}
.reason_list .reason_wrap {
  background-color: white;
  padding: 100px 64px 64px;
  position: relative;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .reason_list .reason_wrap {
    padding: 80px 40px 40px;
  }
}
@media (max-width: 559.9px) {
  .reason_list .reason_wrap {
    padding: 64px 20px 30px;
  }
}
.reason_list .reason_wrap:not(:last-child) {
  margin-bottom: 80px;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .reason_list .reason_wrap:nth-child(3) {
    padding-bottom: 140px;
  }
}
@media (min-width: 821px) {
  .reason_list .reason_wrap.with_sub_image {
    padding-bottom: 160px;
  }
}
.reason_list .reason_wrap .reason_header {
  position: relative;
  width: 100%;
  height: 100%;
}
.reason_list .reason_wrap .reason_header .img {
  width: 100%;
  overflow: hidden;
  position: relative;
}
@media (min-width: 821px) {
  .reason_list .reason_wrap .reason_header .img {
    aspect-ratio: 16/12;
    height: 100%;
    max-height: 90vh;
  }
}
@media (min-width: 821px) {
  .reason_list .reason_wrap .reason_header .img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
  }
}
.reason_list .reason_wrap .reason_header .reason_num {
  position: absolute;
  left: 0;
  top: -90px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .reason_list .reason_wrap .reason_header .reason_num {
    top: -80px;
  }
}
.reason_list .reason_wrap .reason_header .reason_num .small {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.5;
  color: #1A2D74;
  line-height: 1;
  text-transform: capitalize;
}
.reason_list .reason_wrap .reason_header .reason_num .big {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 11rem;
  font-weight: 400;
  line-height: 1.5;
  color: #1A2D74;
  line-height: 1;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .reason_list .reason_wrap .reason_header .reason_num .big {
    font-size: 9rem;
  }
}
@media (min-width: 821px) {
  .reason_list .reason_wrap .reason_header .textArea {
    width: 380px;
    position: absolute;
    right: 40px;
    top: 64px;
  }
}
@media (max-width: 820.9px) {
  .reason_list .reason_wrap .reason_header .textArea {
    transform: translateY(-30px);
  }
}
.reason_list .reason_wrap .reason_header .textArea .navy-title {
  margin-bottom: 40px;
}
@media (max-width: 820.9px) {
  .reason_list .reason_wrap .reason_header .textArea .navy-title {
    margin-bottom: 20px;
  }
}
.reason_list .reason_wrap .reason_header .textArea .whiteBox {
  background-color: white;
  padding: 24px;
}
@media (max-width: 820.9px) {
  .reason_list .reason_wrap .reason_header .textArea .whiteBox {
    padding: 10px 0 0;
  }
}
.reason_list .reason_wrap .reason_header .textArea .whiteBox p {
  color: #1A2D74;
  font-weight: 500;
}
.reason_list .reason_wrap .reason_header .textArea .whiteBox p:not(:last-child) {
  margin-bottom: 15px;
}
.reason_list .reason_wrap .header_sub_image {
  width: 100%;
  max-width: 480px;
}
@media (min-width: 821px) {
  .reason_list .reason_wrap .header_sub_image {
    position: absolute;
    right: 88px;
    bottom: 64px;
  }
}
@media (max-width: 820.9px) {
  .reason_list .reason_wrap .header_sub_image {
    margin: 0 auto;
  }
}
.reason_list .reason_wrap .buttons {
  display: flex;
  margin-top: 50px;
  gap: 20px;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .reason_list .reason_wrap .buttons {
    flex-direction: column;
    gap: 16px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .reason_list .reason_wrap .buttons {
    justify-content: center;
    margin-top: 30px;
  }
}
@media (max-width: 559.9px) {
  .reason_list .reason_wrap .buttons {
    flex-direction: column;
    align-items: center;
    gap: 16px;
    margin-top: 30px;
  }
}
@media (max-width: 820.9px) {
  .reason_list .reason_wrap .flex_content {
    flex-direction: column;
  }
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .reason_list .reason_wrap .flex_content .item {
    width: 48%;
  }
}
@media (max-width: 820.9px) {
  .reason_list .reason_wrap .flex_content .item {
    width: 100% !important;
  }
  .reason_list .reason_wrap .flex_content .item.item_5 {
    margin-bottom: 20px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .reason_list .reason_wrap .flex_content.mt80 {
    margin-top: 40px;
  }
}

.reason_content {
  margin-bottom: 0;
}
.reason_content .sub_title {
  font-size: 2.2rem;
  font-weight: 500;
  margin: 15px 0 24px;
}
@media (max-width: 559.9px) {
  .reason_content .sub_title {
    font-size: 1.8rem;
    font-weight: bold;
    margin: 18px 0 12px;
  }
}
.reason_content .desc p {
  color: #4B505A;
}
.reason_content .desc p:not(:last-child) {
  margin-bottom: 15px;
}

/**************
板金×塗装
**************/
.sp_section {
  width: 100%;
  position: relative;
  overflow: hidden;
}
.sp_section::before {
  content: "";
  display: block;
  border-radius: 50%;
  width: 56vw;
  height: 56vw;
  background-color: #14A5F4;
  position: absolute;
  right: -240px;
  top: 120px;
  opacity: 0.3;
}
.sp_section::after {
  content: "";
  display: block;
  border-radius: 50%;
  width: calc(56vw - 80px);
  height: calc(56vw - 80px);
  background-color: #3795D5;
  position: absolute;
  right: -200px;
  top: 160px;
  opacity: 0.2;
}
.sp_section .reason_content {
  position: relative;
  z-index: 1;
}

.sp_flow {
  display: flex;
  width: 100%;
  margin-top: 70px;
  flex-wrap: wrap;
  gap: 40px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .sp_flow {
    gap: 40px 24px;
  }
}
@media (max-width: 559.9px) {
  .sp_flow {
    gap: 24px 16px;
    margin-top: 40px;
  }
}
.sp_flow .sp_flow_item {
  background-color: white;
  position: relative;
  width: calc(25% - 30px);
  padding: 30px 2vw 20px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .sp_flow .sp_flow_item {
    width: calc(25% - 18px);
  }
}
@media (max-width: 559.9px) {
  .sp_flow .sp_flow_item {
    width: calc(50% - 8px);
    padding: 14px;
  }
}
.sp_flow .sp_flow_item::after {
  width: 36px;
  height: 36px;
  display: block;
  content: "";
  background: url(../images/icon/icon-arrow-next.png);
  background-size: cover;
  position: absolute;
  left: 101%;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .sp_flow .sp_flow_item::after {
    width: 24px;
    height: 24px;
  }
}
@media (max-width: 559.9px) {
  .sp_flow .sp_flow_item::after {
    left: 98%;
    width: 20px;
    height: 20px;
  }
}
@media (min-width: 560px) {
  .sp_flow .sp_flow_item:nth-child(4n)::after {
    display: none;
  }
}
@media (max-width: 559.9px) {
  .sp_flow .sp_flow_item:nth-child(even)::after {
    left: -12%;
    top: 101%;
    transform: rotate(-225deg);
  }
}
@media (max-width: 559.9px) {
  .sp_flow .sp_flow_item:last-child::after {
    display: none;
  }
}
.sp_flow .sp_flow_item .icon {
  display: block;
  width: 80px;
  margin: 0 auto;
}
@media (max-width: 559.9px) {
  .sp_flow .sp_flow_item .icon {
    padding-top: 20px;
    width: 64px;
  }
}
.sp_flow .sp_flow_item .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 4rem;
  font-weight: 400;
  line-height: 1.5;
  color: #1A2D74;
  position: absolute;
  left: 0px;
  top: -20px;
  line-height: 1;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .sp_flow .sp_flow_item .num {
    font-size: 5rem;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .sp_flow .sp_flow_item .num {
    font-size: 4rem;
  }
}
@media (max-width: 559.9px) {
  .sp_flow .sp_flow_item .num {
    top: -10px;
    font-size: 4.8rem;
  }
}
.sp_flow .sp_flow_item .caption {
  text-align: center;
  margin-top: 10px;
  font-weight: 500;
}
@media (min-width: 560px) {
  .sp_flow .sp_flow_item .caption {
    font-size: 1.6;
  }
}

.sp_area_list {
  margin-top: 64px;
}
@media (max-width: 559.9px) {
  .sp_area_list {
    margin-top: 32px;
  }
}
.sp_area_list > li {
  background-color: #D8DAE5;
  padding: 15px;
}
.sp_area_list > li:not(:last-child) {
  margin-bottom: 20px;
}
.sp_area_list > li > dl {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
@media (max-width: 820.9px) {
  .sp_area_list > li > dl {
    flex-direction: column;
  }
}
.sp_area_list > li > dl dt {
  width: 240px;
  text-align: center;
  color: #1A2D74;
  font-weight: bold;
}
@media (max-width: 820.9px) {
  .sp_area_list > li > dl dt {
    margin-bottom: 8px;
  }
}
.sp_area_list > li > dl dd {
  flex: 1;
}
@media (min-width: 821px) {
  .sp_area_list > li > dl dd {
    border-left: 2px white solid;
    padding-left: 24px;
  }
}
@media (max-width: 559.9px) {
  .sp_area_list > li > dl dd {
    font-size: 1.4rem;
  }
}
.sp_area_list > li > dl dd table th {
  font-weight: 500;
}
@media (max-width: 559.9px) {
  .sp_area_list > li > dl dd table th {
    min-width: 72px;
  }
}
@media (min-width: 560px) {
  .sp_area_list > li > dl dd .list-sq {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 4px;
  }
  .sp_area_list > li > dl dd .list-sq > li {
    width: 44%;
  }
}
.sp_area_list.white > li {
  background-color: white;
}
@media (min-width: 821px) {
  .sp_area_list.white > li > dl dd {
    border-left: 2px #1A2D74 solid;
  }
}

/**************
課題解決事例
**************/
.case_navi {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin: 50px auto;
  flex-wrap: wrap;
}
@media (max-width: 559.9px) {
  .case_navi {
    gap: 8px 8px;
  }
}
.case_navi > li {
  background-color: #D8DAE5;
  padding: 16px 16px 30px;
  border-radius: 8px;
  width: 240px;
  position: relative;
}
@media (max-width: 559.9px) {
  .case_navi > li {
    width: calc(50% - 4px);
    padding: 8px 8px 24px;
  }
}
.case_navi > li .thumb {
  width: 100%;
  aspect-ratio: 16/9;
  position: relative;
}
.case_navi > li .thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  border-radius: 8px;
}
.case_navi > li .title {
  font-size: 1.3rem;
  font-weight: 500;
  color: #1A2D74;
  margin-top: 8px;
}
@media (max-width: 559.9px) {
  .case_navi > li .title {
    line-height: 1.5;
    font-size: 1.2rem;
  }
}
.case_navi > li i {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 24px;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: 3px;
  color: white;
}

.case_list .reason_wrap {
  background-color: #f5f5f5;
  padding: 64px 40px 40px;
}
@media (max-width: 559.9px) {
  .case_list .reason_wrap {
    padding: 30px 20px;
  }
}
.case_list .reason_wrap .case_title {
  color: #1A2D74;
  font-size: 2rem;
  padding-left: 160px;
  margin-bottom: 24px;
  line-height: 1.5;
}
@media (max-width: 559.9px) {
  .case_list .reason_wrap .case_title {
    padding-left: 0;
    margin-bottom: 50px;
    font-size: 1.8rem;
  }
}
.case_list .reason_wrap .reason_header .img {
  width: 100%;
  aspect-ratio: 16/6;
  position: relative;
}
.case_list .reason_wrap .reason_header .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
@media (max-width: 559.9px) {
  .case_list .reason_wrap .reason_header .reason_num {
    top: -40px !important;
  }
}
@media (max-width: 559.9px) {
  .case_list .reason_wrap .reason_header .reason_num .big {
    font-size: 7rem !important;
  }
}
.case_list .reason_wrap .inner dl {
  margin-top: 24px;
}
.case_list .reason_wrap .inner dl dt {
  padding-left: 10px;
  position: relative;
  font-weight: 700;
}
@media (min-width: 560px) {
  .case_list .reason_wrap .inner dl dt {
    font-size: 1.8rem;
  }
}
.case_list .reason_wrap .inner dl dt::before {
  content: "";
  display: block;
  width: 3px;
  height: 80%;
  background-color: #B3B1B9;
  position: absolute;
  left: 0;
  top: 10%;
}
.case_list .reason_wrap .inner dl dd {
  background-color: white;
  padding: 24px;
  margin-top: 10px;
}
.case_list .reason_wrap .inner dl dd p:not(:last-of-type) {
  margin-bottom: 15px;
}
.case_list .reason_wrap .inner dl dd ul {
  margin-bottom: 15px;
}

/**************
会社情報
**************/
.company_section {
  margin-top: 40px;
  width: 100%;
  background-color: #f5f5f5;
  padding: 100px 0;
  position: relative;
}
.company_section .wrap {
  position: relative;
}

.company_section_navi {
  position: absolute;
  top: -25px;
  background-color: white;
  border-radius: 16px;
  padding: 12px 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 30px;
  z-index: 3;
}
@media (min-width: 560px) {
  .company_section_navi {
    right: 10vw;
  }
}
@media (max-width: 559.9px) {
  .company_section_navi {
    left: 50%;
    transform: translateX(-50%);
    gap: 4px 16px;
    width: 90%;
    padding: 8px 24px;
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}
.company_section_navi > a {
  color: #191718;
  padding-bottom: 8px;
  display: block;
  position: relative;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .company_section_navi > a {
    font-size: 1.4rem;
  }
}
@media (max-width: 559.9px) {
  .company_section_navi > a {
    font-size: 1.3rem;
    line-height: 1.5;
    padding-bottom: 0;
  }
}
.company_section_navi > a::after {
  content: "";
  display: block;
  width: 100%;
  max-width: 0;
  background-color: #B3B1B9;
  height: 2px;
  transition: all 0.3s ease;
}
.company_section_navi > a:hover::after {
  max-width: 100%;
}

.company_contents {
  width: 100%;
}
.company_contents > li {
  background-color: white;
  padding: 50px 64px 60px;
  position: relativergb(21, 21, 21);
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .company_contents > li {
    padding: 50px 40px 60px;
  }
}
@media (max-width: 559.9px) {
  .company_contents > li {
    padding: 30px 24px;
  }
}
.company_contents > li:not(:last-child) {
  margin-bottom: 80px;
}
.company_contents > li .center-title {
  margin-bottom: 40px;
}

.greeting .greeting_head {
  font-size: 2rem;
  text-align: center;
  margin-bottom: 20px;
}
.greeting p:not(:last-child) {
  margin-bottom: 20px;
}

.ceo_image {
  width: 100%;
  max-width: 800px;
  margin: 50px auto 0;
}
.ceo_image img {
  border-radius: 8px;
}

.ceo_name {
  text-align: center;
  margin-top: 10px;
}

.overview {
  width: 100%;
  margin: 20px auto 0;
}
.overview th,
.overview td.head {
  text-align: left;
  font-weight: normal;
}
@media (min-width: 560px) {
  .overview th,
.overview td.head {
    width: 200px;
    border-bottom: 1px #3795D5 solid;
    padding: 20px 0;
  }
}
@media (max-width: 820.9px) {
  .overview th,
.overview td.head {
    display: block;
    width: 100%;
    padding: 14px 0 4px;
    font-weight: bold;
  }
}
.overview td {
  border-bottom: 1px #ddd solid;
}
@media (min-width: 560px) {
  .overview td {
    padding: 20px 0;
  }
}
@media (max-width: 820.9px) {
  .overview td {
    display: block;
    width: 100%;
    padding: 0 0 14px;
  }
}

.history {
  width: 100%;
}
.history .timeline {
  position: relative;
  width: 100%;
  margin-left: 10px;
}
@media (max-width: 559.9px) {
  .history .timeline {
    width: calc(100% - 30px);
  }
}
.history .timeline::before {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  position: absolute;
  left: 3px;
  top: 0;
  background-color: #ddd;
}
.history .timeline dl {
  width: 100%;
}
@media (min-width: 560px) {
  .history .timeline dl {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
  }
}
.history .timeline dl dt {
  padding: 8px 0 8px 30px;
  vertical-align: top;
  width: 168px;
  font-weight: 600;
  text-align: left;
  position: relative;
}
@media (max-width: 559.9px) {
  .history .timeline dl dt {
    display: block;
    width: 100%;
    border-bottom: 0;
    padding: 8px 0 2px 20px;
    font-size: 1.4rem;
  }
}
.history .timeline dl dt::before {
  width: 7px;
  height: 7px;
  content: "";
  display: block;
  background-color: #f132a1;
  border-radius: 6px;
  position: absolute;
  left: 0;
  top: 18px;
}
.history .timeline dl dt::after {
  content: "";
  width: 90px;
  height: 3px;
  display: block;
  background-image: linear-gradient(to right, #f132a1, 4px, transparent 4px);
  background-size: 10px 3px;
  position: absolute;
  right: -120px;
  top: 22px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .history .timeline dl dt::after {
    width: 60px;
    right: -75px;
  }
}
@media (max-width: 559.9px) {
  .history .timeline dl dt::after {
    display: none;
  }
}
.history .timeline dl dd {
  padding: 8px 0;
  width: calc(100% - 120px);
  margin-left: 160px;
  position: relative;
  display: block;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .history .timeline dl dd {
    width: calc(100% - 90px);
    margin-left: 100px;
  }
}
@media (max-width: 559.9px) {
  .history .timeline dl dd {
    display: block;
    width: 100%;
    border-bottom: 0;
    padding: 0 0 8px 20px;
    margin-left: 0;
    font-size: 1.3rem;
  }
}

.gmap {
  width: 100%;
}
.gmap iframe {
  width: 100%;
}
@media (max-width: 559.9px) {
  .gmap iframe {
    height: 300px;
  }
}

.access_content {
  width: 100%;
  margin-top: 50px;
}
@media (min-width: 560px) {
  .access_content {
    display: flex;
    justify-content: space-between;
  }
}
@media (min-width: 560px) {
  .access_content .imgSide {
    width: 48%;
  }
}
@media (min-width: 560px) {
  .access_content .textSide {
    width: 48%;
  }
}
@media (max-width: 559.9px) {
  .access_content .textSide {
    margin-top: 15px;
  }
}
.access_content .textSide .sq_black {
  margin-top: 20px;
  margin-bottom: 4px;
}

.ill_sdgs {
  display: block;
  width: 100%;
  max-width: 720px;
  margin: 20px auto;
}

.sdgs_list > li {
  margin-top: 64px;
}
@media (max-width: 559.9px) {
  .sdgs_list > li {
    margin-top: 40px;
  }
}
.sdgs_list > li .box {
  background-color: #F0FBFF;
  padding: 40px;
}
@media (max-width: 559.9px) {
  .sdgs_list > li .box {
    padding: 24px;
  }
}

.icon-title {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 8px;
  line-height: 1.5;
  margin-bottom: 20px;
}
.icon-title .txt {
  flex: 1;
  font-size: 2.8rem;
  font-weight: bold;
}
@media (max-width: 559.9px) {
  .icon-title .txt {
    font-size: 2rem;
    padding-top: 2px;
  }
}

.icon-earth {
  display: block;
  width: 40px;
  height: 40px;
  background: url(../images/icon/icon-earth.png) no-repeat;
  background-size: cover;
}
@media (max-width: 559.9px) {
  .icon-earth {
    width: 32px;
    height: 32px;
  }
}

.sdgs_icon_list {
  display: flex;
  gap: 20px;
  margin-top: 40px;
}
@media (max-width: 559.9px) {
  .sdgs_icon_list {
    flex-wrap: wrap;
    gap: 12px 12px;
    margin-top: 30px;
  }
}
.sdgs_icon_list > li {
  width: calc(20% - 16px);
}
@media (max-width: 559.9px) {
  .sdgs_icon_list > li {
    width: calc(33.3333333333% - 8px);
  }
}

.sdgs_wrap {
  position: relative;
  overflow: hidden;
}
.sdgs_wrap p {
  position: relative;
  z-index: 1;
}
.sdgs_wrap .engTxt {
  color: white;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
  width: 210px;
  letter-spacing: 0.2em;
  opacity: 0.8;
}
@media (min-width: 560px) {
  .sdgs_wrap .engTxt {
    position: absolute;
    right: 80px;
    top: 30px;
  }
}
@media (max-width: 559.9px) {
  .sdgs_wrap .engTxt {
    display: none;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .sdgs_wrap .engTxt {
    width: 200px;
    font-size: 1.5rem;
    letter-spacing: 2px;
    right: 0;
    top: 4px;
  }
}
@media (max-width: 559.9px) {
  .sdgs_wrap .engTxt {
    font-size: 1.3rem;
    width: 100%;
    margin-top: 10px;
    letter-spacing: 1px;
  }
}
.sdgs_wrap .engTxt .big {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 4rem;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
}
.sdgs_wrap::before {
  content: "";
  display: block;
  border-radius: 50%;
  width: 560px;
  height: 560px;
  background-color: #3795D5;
  opacity: 0.6;
  position: absolute;
  right: 0;
  top: 0;
  transform: translate(20%, -30%);
}
.sdgs_wrap::after {
  content: "";
  display: block;
  border-radius: 50%;
  width: 480px;
  height: 480px;
  background-color: #F0FBFF;
  position: absolute;
  right: 0;
  top: 0;
  opacity: 0.4;
  transform: translate(15%, -28%);
}

/**************
設備一覧
**************/
.sp-scroll {
  width: 100%;
  overflow-x: auto;
}

@media (max-width: 559.9px) {
  .facilities {
    margin-top: 50px;
  }
}

.facility_sect:not(:first-child) {
  margin-top: 80px;
}
@media (max-width: 559.9px) {
  .facility_sect:not(:first-child) {
    margin-top: 40px;
  }
}

.table_facility {
  width: 100%;
  position: relative;
  z-index: 3;
  min-width: 720px;
}
@media (max-width: 559.9px) {
  .table_facility {
    margin-top: 20px;
  }
}
.table_facility thead tr th {
  background-color: #3795D5;
  padding: 8px 16px;
  text-align: left;
  color: white;
  border: 4px white solid;
}
@media (max-width: 820.9px) {
  .table_facility thead tr th {
    font-size: 1.3rem;
    padding: 8px;
  }
}
.table_facility thead tr th:last-child {
  text-align: center;
  width: 80px;
}
.table_facility tbody tr td {
  padding: 8px 16px;
  border: 4px white solid;
  background-color: #F0FBFF;
}
.table_facility tbody tr td:last-child {
  text-align: center;
  width: 80px;
}
@media (max-width: 820.9px) {
  .table_facility tbody tr td {
    font-size: 1.3rem;
    padding: 8px;
  }
}

/**************
製作実績
**************/
.search_item_list {
  width: 100%;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: flex-start;
  align-content: flex-start;
  gap: 3px 24px;
}
@media (max-width: 559.9px) {
  .search_item_list {
    gap: 3px 16px;
  }
}
.search_item_list:not(:last-of-type) {
  margin-bottom: 10px;
}
@media (max-width: 559.9px) {
  .search_item_list > li {
    width: calc(50% - 8px);
  }
}
@media (max-width: 559.9px) {
  .search_item_list.p100 > li {
    width: 100%;
  }
}

.search_list_table tr th {
  width: 60px;
}
.search_list_table tr:not(:last-child) th, .search_list_table tr:not(:last-child) td {
  padding-bottom: 10px;
}

.search_btn {
  background-color: #1A2D74;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 240px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  border: none;
  transition: all 0.4s cubic-bezier(0.445, 0.05, 0.55, 0.95);
  font-weight: bold;
  font-size: 1.8rem;
  border-radius: 4px;
  cursor: pointer;
  margin: 30px auto 0;
  gap: 10px;
}

.imgList {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: flex-start;
  align-content: flex-start;
}
@media (min-width: 821px) {
  .imgList > li {
    width: 32%;
    margin-right: 2%;
  }
  .imgList > li:nth-child(3n) {
    margin-right: 0;
  }
}
@media (min-width: 560px) {
  .imgList > li {
    margin-bottom: 40px;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .imgList > li {
    width: 48%;
  }
  .imgList > li:nth-child(odd) {
    margin-right: 4%;
  }
}
@media (max-width: 559.9px) {
  .imgList > li:not(:last-child) {
    margin-bottom: 24px;
  }
}
.imgList > li .thumb {
  margin-bottom: 8px;
  border-radius: 8px;
  overflow: hidden;
}
.imgList > li .thumb a {
  display: block;
  width: 100%;
  position: relative;
  overflow: hidden;
}
.imgList > li .thumb a::before {
  content: "";
  display: block;
  padding-top: 66.25%;
}
.imgList > li .thumb a img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  transition: all 0.2s ease-out;
}
.imgList > li .thumb a:hover img {
  transform: scale(1.05);
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .imgList > li {
    width: 49%;
  }
  .imgList > li:nth-child(odd) {
    margin-right: 2%;
  }
}
@media (max-width: 559.9px) {
  .imgList > li {
    width: 100%;
  }
}
.imgList > li .inner {
  display: block;
}
@media (min-width: 560px) {
  .imgList > li .inner {
    padding: 0 8px;
  }
}
.imgList > li .inner dl {
  margin-top: 8px;
  border-bottom: 1px #ddd solid;
}
.imgList > li .inner dl dt {
  font-weight: 500;
}
.imgList > li .inner dl dd {
  font-size: 1.5rem;
  color: #4B505A;
  padding-bottom: 5px;
}
.imgList > li .cat_tag {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 2px 2px;
  margin-top: 8px;
}
@media (max-width: 559.9px) {
  .imgList > li .cat_tag {
    margin-top: 5px;
  }
}
.imgList > li .cat_tag .cat_tag_item {
  display: inline-block;
  padding: 1px 12px;
  background-color: white;
  color: #3795D5;
  font-size: 1.2rem;
  border: 1px #3795D5 solid;
}
@media (max-width: 559.9px) {
  .imgList > li .cat_tag .cat_tag_item {
    font-size: 1.1rem;
    line-height: 1.5;
  }
}

.caption {
  text-align: center;
  margin-top: 3px;
  font-size: 1.3rem;
}

@media (min-width: 560px) {
  .product_wrap {
    display: flex;
    justify-content: space-between;
    width: 90%;
    max-width: 1200px;
    margin: 0 auto 80px;
  }
}
@media (max-width: 559.9px) {
  .product_wrap {
    width: 100%;
    margin-bottom: 56px;
  }
}
@media (min-width: 560px) {
  .product_wrap .product_main_image {
    width: 50%;
  }
}
.product_wrap .product_main_image img {
  height: auto;
}
@media (min-width: 560px) {
  .product_wrap .product_info_side {
    width: 43%;
  }
}
@media (max-width: 559.9px) {
  .product_wrap .product_info_side {
    margin-top: 20px;
    padding: 0 5%;
  }
}
.product_wrap .product_info_side .product_title {
  font-size: 3rem;
  line-height: 1.5;
  margin-bottom: 10px;
  font-weight: 500;
  letter-spacing: 0.08em;
}
@media (max-width: 559.9px) {
  .product_wrap .product_info_side .product_title {
    font-size: 1.8rem;
    margin-bottom: 20px;
  }
}
.product_wrap .product_info_side .cat_tag {
  width: 100%;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: flex-start;
  align-content: flex-start;
  margin-top: 8px;
}
@media (max-width: 559.9px) {
  .product_wrap .product_info_side .cat_tag {
    margin-top: 5px;
  }
}
.product_wrap .product_info_side .cat_tag .cat_tag_item {
  display: inline-block;
  padding: 1px 12px;
  background-color: white;
  color: #3795D5;
  font-size: 1.2rem;
  border: 1px #3795D5 solid;
}
@media (max-width: 559.9px) {
  .product_wrap .product_info_side .cat_tag .cat_tag_item {
    font-size: 1.1rem;
    line-height: 1.5;
  }
}
.product_wrap .product_info_side .cat_tag .cat_tag_item:not(:last-child) {
  margin-right: 3px;
}
.product_wrap .product_info_side .inner {
  display: block;
  margin-top: 24px;
}
.product_wrap .product_info_side .inner dl {
  margin-top: 8px;
  border-bottom: 1px #ddd solid;
}
.product_wrap .product_info_side .inner dl dt {
  font-weight: 500;
}
.product_wrap .product_info_side .inner dl dd {
  font-size: 1.5rem;
  color: #4B505A;
  padding-bottom: 5px;
}

.product_table {
  width: 100%;
}
.product_table tr th {
  background-color: #C5DAF1;
  border: 1px #ddd solid;
  padding: 8px 16px;
  width: 120px;
  text-align: left;
}
@media (max-width: 559.9px) {
  .product_table tr th {
    font-size: 1.2rem;
    width: 80px;
    padding: 8px 12px;
  }
}
.product_table tr td {
  background-color: white;
  border: 1px #ddd solid;
  padding: 8px 16px;
  text-align: left;
}
@media (max-width: 559.9px) {
  .product_table tr td {
    font-size: 1.2rem;
    padding: 8px 12px;
  }
}

.product_info {
  margin-top: 30px;
}

.searchHead {
  font-size: 1.3rem;
  color: #292A2B;
  margin-bottom: 16px;
}

.product_list_title a {
  color: #191718;
}
.product_list_title a:hover {
  text-decoration: underline;
}

/**************
採用情報
**************/
.recruit_section {
  margin-top: 40px;
  width: 100%;
  background-color: #C5DAF1;
  padding: 100px 0;
  position: relative;
}
.recruit_section .wrap {
  position: relative;
}

.recruit_message {
  max-width: 800px;
  margin: 0 auto;
}
.recruit_message p {
  font-feature-settings: normal;
  letter-spacing: 0.03em;
}
@media (min-width: 560px) {
  .recruit_message p {
    font-size: 1.8rem;
    line-height: 2;
  }
}
.recruit_message p:not(:last-child) {
  margin-bottom: 20px;
}

.page_top_eng_big {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 8rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.06em;
  color: #1A2D74;
  opacity: 0.4;
}
@media (max-width: 559.9px) {
  .page_top_eng_big {
    font-size: 4rem;
  }
}
.page_top_eng_big i {
  font-size: 3rem;
}

.job_list {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  gap: 64px 64px;
  flex-wrap: wrap;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .job_list {
    gap: 32px;
  }
}
@media (max-width: 559.9px) {
  .job_list {
    gap: 24px;
  }
}
.job_list .job_list_item {
  width: calc(50% - 32px);
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .job_list .job_list_item {
    width: calc(50% - 16px);
  }
}
@media (max-width: 559.9px) {
  .job_list .job_list_item {
    width: 100%;
  }
}
.job_list .job_list_item .thumb {
  width: 100%;
  aspect-ratio: 16/9;
  position: relative;
  margin-bottom: 10px;
  border-radius: 8px;
  overflow: hidden;
}
.job_list .job_list_item .thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
.job_list .job_list_item .case_cat_tit {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: flex-start;
  align-content: flex-start;
  margin-bottom: 16px;
}
.job_list .job_list_item .case_cat_tit > p {
  font-size: 2.2rem;
  font-weight: 500;
  padding-bottom: 2px;
  border-bottom: 1px #1A2D74 solid;
  color: #1A2D74;
}
@media (max-width: 559.9px) {
  .job_list .job_list_item .case_cat_tit > p {
    font-size: 1.8rem;
  }
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .job_list .job_list_item .excerpt {
    font-size: 1.4rem;
  }
}

.data_wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 2%;
  background-color: #C5DAF1;
  padding: 20px;
  border-radius: 8px;
  margin-top: 40px;
}
@media (max-width: 559.9px) {
  .data_wrap {
    padding: 10px;
    gap: 10px 2%;
  }
}
.data_wrap .data_box {
  width: 32%;
  background-color: white;
  box-sizing: border-box;
  padding: 20px 24px 24px;
  border-radius: 8px;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .data_wrap .data_box {
    padding: 20px 15px;
  }
}
@media (max-width: 559.9px) {
  .data_wrap .data_box {
    width: 49%;
    padding: 15px 8px;
  }
}
.data_wrap .data_box .text {
  text-align: center;
  margin-top: 4px;
  font-size: 1.4rem;
}
.data_wrap .data_box.p_50 {
  width: calc(50% - 10px);
}
.data_wrap .data_box.p_100 {
  width: 100%;
  display: flex;
}
@media (max-width: 559.9px) {
  .data_wrap .data_box.p_100 {
    flex-direction: column;
    align-items: center;
  }
}
.data_wrap .data_box.p_100 .l_side {
  width: 30%;
}
@media (max-width: 559.9px) {
  .data_wrap .data_box.p_100 .l_side {
    width: 100%;
  }
}
@media (max-width: 559.9px) {
  .data_wrap .data_box.p_100 .l_side .data_unit .num {
    font-size: 56px;
  }
}
@media (max-width: 559.9px) {
  .data_wrap .data_box.p_100 .l_side .data_unit .unit {
    font-size: 16px;
    top: 13px;
  }
}
.data_wrap .data_box.p_100.not_flex {
  display: block;
}
@media (max-width: 559.9px) {
  .data_wrap .data_box.sp_100 {
    width: 100%;
  }
}
.data_wrap .data_box .inner {
  position: relative;
  min-height: 72px;
  text-align: center;
}
.data_wrap .data_box .inner .hosoku {
  text-align: center;
  margin-top: 5px;
  font-size: 14px;
}
@media (max-width: 559.9px) {
  .data_wrap .data_box .inner .hosoku {
    font-size: 12px;
    margin-top: 4px;
  }
}
.data_wrap .data_box .inner .after_kome {
  font-size: 1.4rem;
}
@media (max-width: 559.9px) {
  .data_wrap .data_box .inner .after_kome {
    font-size: 1.2rem;
    padding-bottom: 24px;
  }
}
.data_wrap .data_box .tit {
  color: #1A2D74;
  font-size: 1.7rem;
  font-weight: bold;
  position: relative;
  text-align: center;
  padding-bottom: 4px;
  margin-bottom: 20px;
}
@media (max-width: 559.9px) {
  .data_wrap .data_box .tit {
    font-size: 14px;
  }
}
.data_wrap .data_box .tit::after {
  content: "";
  display: block;
  width: 120px;
  height: 2px;
  background-color: #1A2D74;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
}
.data_wrap .data_box .data_unit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}
.data_wrap .data_box .data_unit .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 7.2rem;
  font-weight: 700;
  line-height: 1.5;
  font-weight: 700;
  color: #1A2D74;
  line-height: 1;
  letter-spacing: 0;
}
@media (max-width: 559.9px) {
  .data_wrap .data_box .data_unit .num {
    font-size: 48px;
  }
}
.data_wrap .data_box .data_unit .unit {
  font-size: 20px;
  font-weight: bold;
  position: relative;
  top: 20px;
}
@media (max-width: 559.9px) {
  .data_wrap .data_box .data_unit .unit {
    font-size: 18px;
    top: 10px;
  }
}
.data_wrap .data_box .pie {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 32px auto 0;
  width: 80%;
  aspect-ratio: 1/1;
  border-radius: 50%;
  transform: scale(0);
  transition: all 0.5s ease;
}
.data_wrap .data_box .pie.jd_pie {
  background-image: radial-gradient(#f2f2f2 30%, transparent 31%), conic-gradient(#f4c5ca 0% 50%, #f896a0 50% 100%);
}
.data_wrap .data_box .pie.br_pie {
  background-image: radial-gradient(#f2f2f2 30%, transparent 31%), conic-gradient(#e1ed5a 0% 80%, #ace83f 80% 100%);
}
.data_wrap .data_box .pie.sc_pie {
  background-image: radial-gradient(#f2f2f2 30%, transparent 31%), conic-gradient(#5aeaed 0% 59%, #e1f4ff 59% 100%);
}
.data_wrap .data_box .pie.age_pie {
  width: 50%;
  margin: auto;
  background-image: radial-gradient(#ebf3f9 30%, transparent 31%), conic-gradient(#aec9ed 0% 30%, #9eadef 30% 70%, #7487e3 70% 90%, #4d78d6 90% 100%);
}
.data_wrap .data_box .pie.way_pie {
  width: 100%;
  margin: auto;
  background-image: radial-gradient(#ebf3f9 30%, transparent 31%), conic-gradient(#71a2e2 0% 47%, #9cc7f5 47% 78%, #cad1f4 76% 92%, #d5e1fa 92% 100%);
}
.data_wrap .data_box .pie.lunch_pie {
  width: 100%;
  margin: auto;
  background-image: radial-gradient(#f2f2f2 30%, transparent 31%), conic-gradient(#f4c5ca 0% 60%, #f896a0 60% 100%);
}
.data_wrap .data_box .pie.cloth_pie {
  width: 100%;
  margin: auto;
  background-image: radial-gradient(#f2f2f2 30%, transparent 31%), conic-gradient(#e1ed5a 0% 80%, #ace83f 80% 94%, #c8f69c 94% 100%);
}
.data_wrap .data_box .pie.job_pie {
  width: 100%;
  margin: auto;
  background-image: radial-gradient(#ebf3f9 30%, transparent 31%), conic-gradient(#2a6cc3 0% 44%, #546bcf 44% 60%, #8594e2 60% 68%, #95afe8 68% 76%, #c1d3f3 76% 84%, #b2b9d6 84% 92%, #c4c8da 92% 100%);
}
.data_wrap .data_box.moved .pie {
  transform: scale(1);
}
.data_wrap .data_box .j_data {
  position: absolute;
}
.data_wrap .data_box .j_data.right {
  top: -8px;
  left: 72%;
}
@media (max-width: 559.9px) {
  .data_wrap .data_box .j_data.right {
    top: -13px;
  }
}
.data_wrap .data_box .j_data.left {
  top: -8px;
  left: 5%;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .data_wrap .data_box .j_data.left {
    left: 0;
  }
}
@media (max-width: 559.9px) {
  .data_wrap .data_box .j_data.left {
    top: -13px;
    left: 3%;
  }
}
.data_wrap .data_box .j_data.center {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.data_wrap .data_box .j_data.center .data_unit .num {
  font-size: 4rem;
}
.data_wrap .data_box .j_data .jd_head {
  font-weight: bold;
  font-size: 12px;
  text-align: center;
}
.data_wrap .data_box .j_data .data_unit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
}
.data_wrap .data_box .j_data .data_unit .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.5;
  line-height: 1;
}
.data_wrap .data_box .j_data .data_unit .unit {
  font-size: 1.5rem;
  font-weight: bold;
  position: relative;
  top: 10px;
}
.data_wrap .data_box .past_recs {
  display: flex;
  justify-content: center;
  gap: 25px;
}
@media (max-width: 559.9px) {
  .data_wrap .data_box .past_recs {
    gap: 10px;
  }
}
.data_wrap .data_box .past_recs .bb_numbox {
  text-align: center;
}
.data_wrap .data_box .past_recs .bb_numbox .year {
  font-weight: bold;
}
.data_wrap .data_box_long {
  width: 60%;
  margin-left: 4%;
  position: relative;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .data_wrap .data_box_long {
    margin-left: 8%;
  }
}
@media (max-width: 559.9px) {
  .data_wrap .data_box_long {
    width: 100%;
    margin-left: 0;
    padding-bottom: 10px;
  }
}
.data_wrap .age_data {
  width: 100%;
  height: 100%;
  position: relative;
}
.data_wrap .age_data .j_data {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 3px;
}
.data_wrap .age_data .j_data .jd_head {
  position: relative;
  top: 1px;
  font-size: 14px;
}
.data_wrap .age_data .j_data .data_unit .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1.5;
  line-height: 1;
}
.data_wrap .age_data .age_1 {
  right: 12%;
  top: 5%;
}
@media (max-width: 820.9px) {
  .data_wrap .age_data .age_1 {
    right: 1%;
  }
}
.data_wrap .age_data .age_2 {
  right: 15%;
  top: 80%;
}
@media (max-width: 820.9px) {
  .data_wrap .age_data .age_2 {
    right: 8%;
  }
}
.data_wrap .age_data .age_3 {
  left: 8%;
  top: 31%;
}
@media (max-width: 820.9px) {
  .data_wrap .age_data .age_3 {
    left: 5%;
  }
}
.data_wrap .age_data .age_4 {
  left: 17%;
  top: 0%;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .data_wrap .age_data .age_4 {
    left: 16%;
    top: -9%;
  }
}
@media (max-width: 559.9px) {
  .data_wrap .age_data .age_4 {
    left: 1%;
    top: -10%;
  }
}
.data_wrap .age_data .age_5 {
  left: 27%;
  top: -6%;
}
@media (max-width: 559.9px) {
  .data_wrap .age_data .age_5 {
    top: -14%;
  }
}
.data_wrap .way_data {
  width: 100%;
  height: 100%;
  position: relative;
  text-align: center;
  max-width: 240px;
  margin: 0 auto;
}
.data_wrap .way_data .j_data {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 3px;
}
.data_wrap .way_data .j_data .jd_head {
  position: relative;
  top: 1px;
  font-size: 14px;
}
.data_wrap .way_data .j_data .data_unit .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1.5;
  line-height: 1;
}
.data_wrap .way_data .way_1 {
  right: -10%;
  top: 34%;
}
@media (max-width: 820.9px) {
  .data_wrap .way_data .way_1 {
    right: 1%;
  }
}
.data_wrap .way_data .way_2 {
  left: -5%;
  top: 60%;
}
@media (max-width: 820.9px) {
  .data_wrap .way_data .way_2 {
    left: -3%;
  }
}
.data_wrap .way_data .way_3 {
  left: -16%;
  top: 12%;
}
@media (max-width: 820.9px) {
  .data_wrap .way_data .way_3 {
    left: -7%;
  }
}
.data_wrap .way_data .way_4 {
  left: 18%;
  top: -2%;
}
@media (max-width: 820.9px) {
  .data_wrap .way_data .way_4 {
    top: -4%;
  }
}
.data_wrap .lunch_data {
  width: 100%;
  height: 100%;
  position: relative;
  text-align: center;
  max-width: 240px;
  margin: 0 auto;
}
.data_wrap .lunch_data .j_data {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 3px;
}
.data_wrap .lunch_data .j_data .jd_head {
  position: relative;
  top: 1px;
  font-size: 14px;
}
.data_wrap .lunch_data .j_data .data_unit .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1.5;
  line-height: 1;
}
.data_wrap .lunch_data .lunch_1 {
  right: -24%;
  top: 34%;
}
@media (max-width: 820.9px) {
  .data_wrap .lunch_data .lunch_1 {
    right: -15%;
  }
}
.data_wrap .lunch_data .lunch_2 {
  left: -9%;
  top: 7%;
}
.data_wrap .cloth_data {
  width: 100%;
  height: 100%;
  position: relative;
  text-align: center;
  max-width: 240px;
  margin: 0 auto;
}
.data_wrap .cloth_data .j_data {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 3px;
}
.data_wrap .cloth_data .j_data .jd_head {
  position: relative;
  top: 1px;
  font-size: 14px;
}
.data_wrap .cloth_data .j_data .data_unit .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1.5;
  line-height: 1;
}
.data_wrap .cloth_data .cloth_1 {
  right: -15%;
  top: 50%;
}
@media (max-width: 820.9px) {
  .data_wrap .cloth_data .cloth_1 {
    right: 1%;
  }
}
.data_wrap .cloth_data .cloth_2 {
  left: -9%;
  top: 15%;
}
@media (max-width: 820.9px) {
  .data_wrap .cloth_data .cloth_2 {
    left: -13%;
  }
}
.data_wrap .cloth_data .cloth_3 {
  left: 21%;
  top: -3%;
}
.data_wrap .job_data {
  width: 100%;
  height: 100%;
  position: relative;
  text-align: center;
  max-width: 240px;
  margin: 0 auto;
}
.data_wrap .job_data .j_data {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 3px;
}
.data_wrap .job_data .j_data .jd_head {
  position: relative;
  top: 1px;
  font-size: 14px;
}
.data_wrap .job_data .j_data .data_unit .num {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1.5;
  line-height: 1;
}
.data_wrap .job_data .job_1 {
  right: -25%;
  top: 32%;
}
@media (max-width: 820.9px) {
  .data_wrap .job_data .job_1 {
    right: -14%;
  }
}
.data_wrap .job_data .job_2 {
  left: 25%;
  top: 73%;
}
.data_wrap .job_data .job_3 {
  left: -17%;
  top: 58%;
}
@media (max-width: 559.9px) {
  .data_wrap .job_data .job_3 {
    left: -12%;
  }
}
.data_wrap .job_data .job_4 {
  left: -22%;
  top: 40%;
}
@media (max-width: 820.9px) {
  .data_wrap .job_data .job_4 {
    left: -17%;
  }
}
@media (max-width: 559.9px) {
  .data_wrap .job_data .job_4 {
    left: -12%;
  }
}
.data_wrap .job_data .job_5 {
  left: -28%;
  top: 22%;
}
@media (max-width: 820.9px) {
  .data_wrap .job_data .job_5 {
    left: -17%;
  }
}
@media (max-width: 559.9px) {
  .data_wrap .job_data .job_5 {
    left: -12%;
  }
}
.data_wrap .job_data .job_6 {
  left: -8%;
  top: 4%;
}
.data_wrap .job_data .job_7 {
  left: 24%;
  top: -5%;
}

.looking {
  text-align: center;
}
@media (min-width: 560px) {
  .looking {
    margin: 60px auto 20px;
  }
}
.looking li {
  font-weight: 500;
  letter-spacing: 0.14em;
}
.looking li:not(:last-child) {
  margin-bottom: 20px;
}
@media (min-width: 560px) {
  .looking li {
    font-size: 2.4rem;
  }
}

/**************
新着情報
**************/
.news_archive {
  width: 100%;
}
@media (min-width: 560px) {
  .news_archive {
    width: 100%;
    display: inline-flex;
    flex-wrap: wrap;
    align-items: flex-start;
    align-content: flex-start;
  }
}
.news_archive .news_item {
  position: relative;
  margin-bottom: 32px;
  border-radius: 8px;
  background-color: #F0FBFF;
  overflow: hidden;
}
@media (min-width: 560px) {
  .news_archive .news_item {
    width: 32%;
  }
  .news_archive .news_item:not(:nth-child(3n)) {
    margin-right: 2%;
  }
}
@media (max-width: 559.9px) {
  .news_archive .news_item {
    background-color: white;
    padding: 16px;
    margin-bottom: 16px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
  }
}
.news_archive .news_item:first-child {
  border-top: 1px #ddd solid;
}
.news_archive .news_item .thumb {
  width: 100%;
  aspect-ratio: 16/10;
  position: relative;
  overflow: hidden;
}
@media (max-width: 559.9px) {
  .news_archive .news_item .thumb {
    width: 96px;
    aspect-ratio: 1/1;
    border-radius: 8px;
    overflow: hidden;
  }
}
.news_archive .news_item .thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  transition: all 0.3s cubic-bezier(0.445, 0.05, 0.55, 0.95);
}
.news_archive .news_item .news_inner {
  width: 100%;
  position: relative;
  padding: 12px 20px 16px;
}
@media (max-width: 559.9px) {
  .news_archive .news_item .news_inner {
    width: calc(100% - 118px);
    padding: 0;
    margin-top: -4px;
  }
}
.news_archive .news_item .news_inner .news_item_cat_tags {
  width: 100%;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: flex-start;
  align-content: flex-start;
  margin-bottom: 10px;
}
@media (max-width: 559.9px) {
  .news_archive .news_item .news_inner .news_item_cat_tags {
    margin-bottom: 5px;
  }
}
.news_archive .news_item .news_inner .news_item_cat_tags .cat_tag_item {
  display: inline-block;
  padding: 1px 10px;
  border-radius: 3px;
  background-color: white;
  color: #3795D5;
  font-size: 1.2rem;
  border: 1px #3795D5 solid;
  line-height: 1.5;
  margin-bottom: 3px;
}
@media (max-width: 559.9px) {
  .news_archive .news_item .news_inner .news_item_cat_tags .cat_tag_item {
    font-size: 1.1rem;
  }
}
.news_archive .news_item .news_inner .news_item_cat_tags .cat_tag_item:not(:last-child) {
  margin-right: 3px;
}
.news_archive .news_item .news_inner .date {
  color: #666;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 8px;
}
@media (max-width: 559.9px) {
  .news_archive .news_item .news_inner .date {
    margin-bottom: 2px;
    font-size: 1.3rem;
  }
}
.news_archive .news_item .news_inner .news_text {
  font-size: 1.4rem;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  font-weight: bold;
}
@media (max-width: 559.9px) {
  .news_archive .news_item .news_inner .news_text {
    -webkit-line-clamp: 2;
    font-size: 1.4rem;
  }
}
.news_archive .news_item:hover .thumb img {
  transform: scale(1.1);
}

.news_single {
  background-color: white;
  border-radius: 8px;
}

.single_title {
  font-size: 2.4rem;
  padding: 32px 24px;
  line-height: 1.5;
}
@media (max-width: 820.9px) {
  .single_title {
    font-size: 1.6rem;
  }
}
@media (max-width: 559.9px) {
  .single_title {
    padding: 20px;
  }
}

.post_data {
  padding: 16px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media (max-width: 559.9px) {
  .post_data {
    margin-bottom: 40px;
  }
}
.post_data .news_date {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
}

.single_icatch {
  width: 100%;
  background-color: #191718;
  position: relative;
}
.single_icatch img {
  display: block;
  margin: 0 auto;
  width: auto;
  height: auto;
  max-width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.single_content {
  padding: 24px 40px 40px;
}
@media (max-width: 559.9px) {
  .single_content {
    padding: 0 20px 24px;
  }
}
.single_content *:first-child {
  margin-top: 0;
}
.single_content img {
  max-width: 100% !important;
  height: auto;
}
.single_content .auto {
  margin: 15px 0;
}
.single_content h1 {
  font-size: 3rem;
  margin-top: 56px;
  font-weight: bold;
  margin-bottom: 16px;
}
@media (max-width: 820.9px) {
  .single_content h1 {
    font-size: 2.1rem;
    margin: 30px 0 12px;
  }
}
.single_content h2 {
  font-size: 2.4rem;
  font-weight: 700 !important;
  margin: 40px 0 24px;
  border-radius: 8px;
  line-height: 1.5;
  padding-bottom: 1rem;
  border-bottom: 1px #ccc solid;
}
@media (max-width: 820.9px) {
  .single_content h2 {
    font-size: 1.9rem;
    margin: 30px 0 12px;
  }
}
.single_content h3 {
  font-size: 2rem;
  color: #444;
  margin: 40px 0 20px;
  font-weight: 700 !important;
}
@media (max-width: 820.9px) {
  .single_content h3 {
    font-size: 1.8rem;
    margin: 20px 0 10px;
  }
}
.single_content h4 {
  font-size: 1.8rem;
  margin: 40px 0 16px;
}
@media (max-width: 820.9px) {
  .single_content h4 {
    font-size: 1.7rem;
    margin: 20px 0 16px;
  }
}
.single_content h5 {
  position: relative;
  margin: 40px 0 16px;
  font-size: 1.7rem;
  padding-left: 15px;
}
@media (max-width: 820.9px) {
  .single_content h5 {
    font-size: 1.6rem;
    margin: 32px 0 16px;
  }
}
.single_content h5::before {
  width: 5px;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background-color: #07afbf;
  content: "";
  display: block;
}
.single_content h6 {
  font-size: 1.6rem;
  color: #666;
  position: relative;
  padding-left: 16px;
  margin: 40px 0 16px;
}
@media (max-width: 820.9px) {
  .single_content h6 {
    margin: 32px 0 16px;
  }
}
.single_content h6::before {
  background: #3875a1;
  width: 5px;
  height: 90%;
  display: block;
  content: "";
  position: absolute;
  left: 0;
  top: 5%;
}
.single_content table {
  border-collapse: collapse;
  border-spacing: 0;
  margin: 15px 0;
  width: 100%;
}
.single_content table th,
.single_content table td {
  vertical-align: middle;
  padding: 15px 10px;
  border: 1px solid #ddd;
  margin: 0;
}
.single_content table th {
  text-align: center;
  background: #eee;
  font-weight: bold;
}
.single_content blockquote {
  position: relative;
  box-sizing: border-box;
  padding: 45px 20px 45px 30px;
  margin: 0 0 30px;
  font-weight: 400;
  color: #444;
  background-color: #f3f3f3;
  border: 1px #ddd solid;
}
@media (max-width: 820.9px) {
  .single_content blockquote {
    padding: 20px 5%;
  }
}
.single_content pre {
  padding: 20px;
  margin: 20px;
  background: #eee;
  border-radius: 5px;
  font-size: 1.5rem;
  white-space: pre-line;
}
.single_content code {
  word-wrap: break-word;
  font-size: 1.5rem;
}
.single_content .word-set {
  display: inline-table;
  position: relative;
  vertical-align: baseline;
  white-space: initial;
}
.single_content .aligncenter {
  margin: 0 auto;
  text-align: center;
  display: inline-block;
}
.single_content .alignright {
  display: inline-block;
  margin-left: auto;
  margin-right: 0;
}
.single_content img {
  height: auto;
}
.single_content ul {
  list-style: inherit;
}
.single_content ul li {
  list-style-type: inherit;
  list-style-position: inside;
}
.single_content ol {
  list-style: inherit;
}
.single_content ol li {
  list-style-type: decimal;
  list-style-position: inside;
}

.single_page_navi {
  background-color: #f3f3f3;
  padding: 30px;
  border-radius: 8px;
  margin-top: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 820.9px) {
  .single_page_navi {
    padding: 16px;
    margin-top: 36px;
    border-radius: 8px;
  }
}
.single_page_navi a {
  color: #666;
}
.single_page_navi a:nth-child(2) {
  margin: 0 72px;
}
@media (max-width: 820.9px) {
  .single_page_navi a:nth-child(2) {
    margin: 0 24px;
  }
}
.single_page_navi a img {
  display: block;
  width: 22px;
}

@media (max-width: 820.9px) {
  .single_info {
    margin-top: 25px;
    padding-top: 15px;
  }
}

.single_cat_tag {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: flex-start;
  align-content: flex-start;
}
.single_cat_tag .single_cat_tag_item {
  display: inline-block;
  margin-right: 4px;
  border-radius: 3px;
  background-color: white;
  color: #3795D5;
  font-size: 1.2rem;
  border: 1px #3795D5 solid;
  padding: 1px 12px;
  line-height: 1.5;
}

.side_title {
  background-color: #14A5F4;
  padding: 8px 12px;
  color: #fff;
  font-weight: bold;
  border-radius: 8px;
}
@media (max-width: 820.9px) {
  .side_title {
    margin-bottom: 12px;
  }
}

.side_list li a {
  border-bottom: 1px #ccc solid;
  display: block;
  padding: 8px;
  color: #666;
  background-color: #fff;
  font-size: 1.4rem;
}
@media (min-width: 560px) {
  .side_list li a {
    transition: all 0.3s ease;
  }
  .side_list li a:hover {
    background-color: #f3f3f3;
  }
}
.side_list li a i {
  margin-right: 4px;
}

.side_column_list li {
  border-bottom: 1px #ddd solid;
}
.side_column_list li a {
  width: 100%;
  padding: 12px 0;
  display: block;
  transition: all 0.3s ease;
}
.side_column_list li a:hover {
  background-color: #f3f3f3;
}
.side_column_list li a .inner {
  width: 100%;
}
.side_column_list li a .inner .date {
  color: #666;
  font-size: 1.2rem;
}
.side_column_list li a .inner .tit {
  font-size: 1.3rem;
  line-height: 1.6;
  color: #333;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .side_column_list li a .inner .tit {
    -webkit-line-clamp: 2;
  }
}

.side_btn {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  height: 72px;
  width: 100%;
  padding: 0 16px;
  background: linear-gradient(0deg, #3795D5 0 50%, #0b39af 50% 100%);
  color: #fff;
  margin-top: 8px;
  line-height: 1.6;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .side_btn {
    padding: 0 12px;
    font-size: 1.4rem;
  }
}
@media (min-width: 560px) {
  .side_btn {
    transition: all 0.3s ease;
  }
  .side_btn:hover {
    opacity: 0.8;
    color: white;
  }
}
.side_btn i {
  font-size: 2.4rem;
  margin-right: 16px;
}
@media (min-width: 821px) and (max-width: 1159.9px) {
  .side_btn i {
    font-size: 1.8rem;
    margin-right: 12px;
  }
}

.single_info {
  padding-bottom: 16px;
  border-bottom: #ddd 1px solid;
  margin-bottom: 24px;
}
@media (min-width: 560px) {
  .single_info {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
  }
}
.single_info .date {
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 1.7rem;
  font-weight: 400;
  line-height: 1.5;
  color: #666;
}

/* ------------
PAGENATION
------------- */
.wp-pagenavi {
  padding: 12px 5px;
  font-size: 100%;
  text-align: center;
  margin-top: 30px;
}

.all_seminar .wp-pagenavi {
  margin: 0 auto;
}

.wp-pagenavi span,
.wp-pagenavi a {
  padding: 5px 7px !important;
  border-radius: 3px;
}

.wp-pagenavi .page,
.wp-pagenavi .pages,
.wp-pagenavi .extend,
.wp-pagenavi .last,
.wp-pagenavi .nextpostslink,
.wp-pagenavi .previouspostslink,
.wp-pagenavi .first {
  background: #fff;
}

.wp-pagenavi .current {
  background: #1eb0d6;
  color: #fff;
}

/**************
お問い合わせ
**************/
.contact-kome {
  margin-top: 15px;
  color: #777777;
  font-size: 1.4rem;
}

.contact_nums {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
}
@media (max-width: 559.9px) {
  .contact_nums + .textCenter {
    font-size: 1.3rem;
    text-align: left;
  }
}

.telfax_box {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px 24px;
  flex-wrap: wrap;
}
@media (max-width: 559.9px) {
  .telfax_box {
    gap: 8px;
  }
}

.contact_box {
  display: flex;
  width: calc(50% - 12px);
}
.contact_box.bottom {
  margin-top: -1px;
}
@media (max-width: 559.9px) {
  .contact_box {
    width: 100%;
  }
}
.contact_box > dt {
  width: 110px;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 0;
  background-color: #3795D5;
  line-height: inherit;
  font-weight: bold;
  font-size: 2.4rem;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .contact_box > dt {
    font-size: 2.4rem;
  }
}
@media (max-width: 559.9px) {
  .contact_box > dt {
    font-size: 1.4rem;
    width: 88px;
  }
}
.contact_box > dd {
  flex: 1;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.5;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 0;
  color: #191718;
  background-color: #F0FBFF;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .contact_box > dd {
    font-family: "Quantico", Arial, Helvetica, sans-serif;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.5;
    line-height: inherit;
  }
}
@media (max-width: 559.9px) {
  .contact_box > dd {
    font-family: "Quantico", Arial, Helvetica, sans-serif;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.5;
    width: calc(100% - 65px);
  }
}

.mail_cont {
  background-color: white;
  padding: 40px 64px;
  margin-top: 80px;
}
@media (max-width: 559.9px) {
  .mail_cont {
    margin-top: 50px;
    padding: 30px 24px;
  }
}

.con02_text {
  text-align: center;
  margin: 40px auto 25px;
}

.contact_table,
.wpcf7 table {
  width: 100%;
}
.contact_table tr th,
.wpcf7 table tr th {
  border: 1px solid #d3d3d3;
  padding: 18px 24px;
  width: 32%;
  vertical-align: middle;
  text-align: left;
  background-color: #f3f3f3;
}
@media (max-width: 1159.9px) {
  .contact_table tr th,
.wpcf7 table tr th {
    display: block;
    width: 100%;
    padding: 5px 12px;
    border: none;
  }
}
.contact_table tr th .hissu_cell,
.wpcf7 table tr th .hissu_cell {
  position: relative;
}
.contact_table tr th .hissu_cell .hissu,
.wpcf7 table tr th .hissu_cell .hissu {
  background-color: #30479e;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  display: inline-block;
  padding: 4px 11px;
  position: absolute;
  right: 0;
  top: 50%;
  margin-top: -13px;
}
@media (max-width: 1159.9px) {
  .contact_table tr th .hissu_cell .hissu,
.wpcf7 table tr th .hissu_cell .hissu {
    padding: 0 7px 1px;
    margin-top: -10px;
  }
}
.contact_table tr th .hissu_cell .nini,
.wpcf7 table tr th .hissu_cell .nini {
  background-color: #fff;
  font-size: 12px;
  font-weight: 700;
  color: #333;
  display: inline-block;
  padding: 4px 11px;
  position: absolute;
  right: 0;
  top: 50%;
  margin-top: -13px;
}
@media (max-width: 1159.9px) {
  .contact_table tr th .hissu_cell .nini,
.wpcf7 table tr th .hissu_cell .nini {
    padding: 0 7px 1px;
    margin-top: -10px;
  }
}
.contact_table tr td,
.wpcf7 table tr td {
  padding: 18px 24px;
  border: 1px solid #d3d3d3;
  width: 68%;
}
@media (max-width: 1159.9px) {
  .contact_table tr td,
.wpcf7 table tr td {
    display: block;
    width: 100%;
    padding: 8px 0 16px;
    border: none;
  }
}
@media (min-width: 560px) {
  .contact_table tr:last-child th,
.wpcf7 table tr:last-child th {
    border-bottom: 1px solid #d3d3d3;
  }
}
.contact_table tr:last-child td,
.wpcf7 table tr:last-child td {
  border-bottom: 1px solid #d3d3d3;
}

input,
button,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.c-input,
.c-select,
.c-textarea {
  background: #fff;
  border: 1px solid #d3d3d3;
  transition: background-color 100ms, border-color 100ms;
  width: 100%;
  box-sizing: border-box;
}

.c-select {
  padding: 5px 10px;
}

.c-input {
  height: 40px;
  padding: 2px 10px;
}
@media (max-width: 1159.9px) {
  .c-input {
    height: auto;
    padding: 8px 12px;
    box-sizing: border-box;
  }
}

@media (min-width: 560px) {
  .c-select-list {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
}
.c-select-list__item {
  display: flex;
  align-items: center;
}
@media (min-width: 560px) {
  .c-select-list__item {
    width: 32%;
  }
}
@media (max-width: 820.9px) {
  .c-select-list__item {
    width: 80%;
    margin-bottom: 4px;
  }
}

.c-radio-list {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  margin: 0 -20px -5px 0;
  width: 100%;
}
.c-radio-list__item {
  margin: 0 0 5px 0;
}
@media (max-width: 1159.9px) {
  .c-radio-list__item {
    text-align: left;
  }
}
.c-radio-list__item label {
  cursor: pointer;
  margin-right: 20px;
}
@media (max-width: 1159.9px) {
  .c-radio-list__item label {
    margin-right: 10px;
  }
}

.c-radio {
  position: relative;
  top: -3px;
  -webkit-appearance: radio;
  -moz-appearance: radio;
  appearance: radio;
}

.c-textarea {
  height: 200px;
  width: 100%;
  padding: 8px 10px;
}
@media (max-width: 1159.9px) {
  .c-textarea {
    box-sizing: border-box;
    width: 100%;
    height: 120px;
  }
}

@media (max-width: 559.9px) {
  .c-file {
    font-size: 1.3rem;
  }
}

.form-btn {
  margin-top: 30px;
  text-align: center;
}

.c-submit,
.c-confirm,
.c-back {
  padding: 18px 0;
  text-align: center;
  width: 280px;
  cursor: pointer;
}
@media (min-width: 1160px) {
  .c-submit,
.c-confirm,
.c-back {
    transition: all 0.3s ease 0s;
  }
}
@media (max-width: 1159.9px) {
  .c-submit,
.c-confirm,
.c-back {
    width: 48%;
    padding: 15px 0;
  }
}

.c-submit {
  border: 2px #3795D5 solid;
  color: #fff;
  background-color: #3795D5;
  font-weight: bold;
  font-size: 1.8rem;
}

.c-submit:hover {
  opacity: 0.8;
}

.c-confirm,
.c-back {
  border: 2px #777 solid;
  color: #777;
  background-color: #fff;
}

.c-confirm:hover,
.c-back:hover {
  background-color: #eee;
}

.privacyCheck {
  text-align: center;
  margin: 60px 0 40px;
}
@media (max-width: 559.9px) {
  .privacyCheck {
    margin: 30px 0 20px;
  }
}
.privacyCheck h5 {
  font-size: 1.7rem;
}
.privacyCheck p {
  margin: 10px 0 20px;
}

.btn-confirm, #btn_confirm {
  display: block;
  border: 1px #999 solid;
  border-radius: 5px;
  max-width: 400px;
  width: 90%;
  padding: 15px 0;
  text-align: center;
  font-size: 1.8rem;
  margin: 0 auto;
  background-color: #ddd;
  transition: all 0.3s ease 0s;
}
.btn-confirm.hoverOn, .hoverOn#btn_confirm {
  border: 1px solid #5d3fff;
  background-color: #fff;
  color: #5d3fff;
  cursor: pointer;
}

.btns .btn {
  color: white;
  font-size: 22px;
  font-weight: 600;
  height: auto;
  width: 370px;
  text-rendering: optimizelegibility;
  border-radius: 8px;
  cursor: pointer;
  display: inline-block;
  text-align: center;
  padding: 18px 0;
  margin: 0 5px 20px;
}
@media (max-width: 1159.9px) {
  .btns .btn {
    font-size: 18px;
    width: 90%;
    margin: 0 auto 20px;
  }
}

.wpcf7cp-btns {
  margin-top: 30px;
  text-align: center;
}
.wpcf7cp-btns button {
  color: white;
  font-size: 2rem;
  font-weight: bold;
  height: auto;
  width: 370px;
  text-rendering: optimizelegibility;
  border-radius: 8px;
  cursor: pointer;
  display: inline-block;
  text-align: center;
  padding: 18px 0;
  margin: 0 5px 20px;
}
@media (max-width: 1159.9px) {
  .wpcf7cp-btns button {
    font-size: 18px;
    width: 90%;
    margin: 0 auto 20px;
  }
}
.wpcf7cp-btns button.wpcf7cp-cfm-edit-btn {
  background-color: #81c320;
  border-bottom: 3px solid #679b1b;
}
.wpcf7cp-btns button.wpcf7cp-cfm-edit-btn:hover {
  background-color: #a2d400;
  border-color: #a2d400;
}
.wpcf7cp-btns button.wpcf7cp-cfm-submit-btn {
  background-color: #21b2c1;
  border-bottom: 3px solid #1d8691;
  border-color: #21b2c1 #21b2c1 #1d8691;
}
.wpcf7cp-btns button.wpcf7cp-cfm-submit-btn:hover {
  background-color: #2fccdc;
  border-bottom: 3px solid #1d8691;
  border-color: #2fccdc #2fccdc #2fccdc;
}

.btn-conta {
  color: white;
  font-size: 22px;
  font-weight: 600;
  height: 51px;
  width: 80%;
  text-rendering: optimizelegibility;
  border-radius: 8px;
  cursor: pointer;
  display: block;
  text-align: center;
  padding-top: 18px;
  margin: 0 auto 20px;
  background-color: #333;
  border-bottom: 3px solid #888;
}
.btn-conta:hover {
  background-color: #555;
  border-bottom: 3px solid #999;
}

.btns .btn-primary {
  background-color: #81c320;
  border-color: #a2d400;
  border-bottom: 3px solid #679b1b;
}
.btns .btn-primary:hover {
  background-color: #a2d400;
  border-color: #a2d400;
}

.btn-info {
  background-color: #21b2c1;
  border-color: #21b2c1 #21b2c1 #1d8691;
  border-bottom: 3px solid #1d8691;
}
.btn-info:hover {
  background-color: #2fccdc;
  border-bottom: 3px solid #1d8691;
  border-color: #2fccdc #2fccdc #2fccdc;
}

input[type=radio] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
  appearance: radio;
  border-radius: 50%;
  position: relative;
  top: -2px;
}

input[type=checkbox] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
  appearance: checkbox;
  border-radius: 50%;
}

.c-radio,
.c-checkbox {
  margin-right: 5px;
  position: relative;
  top: -0.1em;
}

.alert-block {
  border: 2px tomato solid;
  padding: 24px;
  color: red;
  font-weight: bold;
}

.help-block {
  display: block;
  color: tomato;
  font-size: 12px;
  font-weight: bold;
  margin-top: 3px;
}

.wpcf7-response-output {
  background-color: #fff0f0;
  text-align: center;
  color: red;
  padding: 24px !important;
  border-radius: 8px;
  border: none !important;
}

.wpcf7-not-valid-tip {
  display: block;
  font-size: 1.3rem !important;
  font-weight: bold !important;
  margin-top: 3px !important;
}

/**************
プライバシーポリシー
**************/
.privacy_cont {
  width: 100%;
  margin-top: 50px;
}
@media (max-width: 559.9px) {
  .privacy_cont {
    margin-top: 30px;
  }
}

.privacy-title {
  text-align: center;
  font-size: 1.8rem;
  margin-top: 30px;
}

.privacy_policy {
  margin-top: 10px;
  height: 400px;
  padding: 10px 30px;
  border: 1px #4B505A solid;
  overflow-y: scroll;
}
@media (min-width: 560px) and (max-width: 820.9px) {
  .privacy_policy {
    padding: 24px;
  }
}
@media (max-width: 559.9px) {
  .privacy_policy {
    width: 100%;
    padding: 10px;
    font-size: 1.3rem;
  }
}
@media (min-width: 821px) {
  .privacy_policy .privacy_policy_box {
    padding: 0 24px;
  }
}
.privacy_policy .privacy_policy_box *:first-child {
  margin-top: 0;
}
.privacy_policy .privacy_policy_box ul {
  margin-top: 10px;
}
.privacy_policy .privacy_policy_box p {
  margin-top: 10px;
}
.privacy_policy .privacy_policy_box h3 {
  font-size: 110%;
  margin-top: 24px;
  margin-bottom: 8px;
}
.privacy_policy .privacy_policy_box h4 {
  font-size: 105%;
  margin-top: 20px;
}
.privacy_policy .privacy_policy_box h5 {
  margin-top: 15px;
}

.sq_black::before {
  background-color: black;
}

.privacy {
  background-color: #fff;
}
@media (min-width: 560px) {
  .privacy {
    padding: 0 24px;
  }
}
.privacy *:first-child {
  margin-top: 0;
}
.privacy ul {
  margin-top: 10px;
}
.privacy ul li {
  margin-top: 5px;
}
.privacy p {
  margin-top: 24px;
}
.privacy h3 {
  font-size: 110%;
  margin-top: 24px;
  margin-bottom: 8px;
}
.privacy h4 {
  font-size: 105%;
  margin-top: 20px;
}
.privacy h5 {
  margin-top: 15px;
}

/**************
よくある質問
**************/
.faq-link_btn-box {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px 10px;
  flex-wrap: wrap;
}
@media (max-width: 559.9px) {
  .faq-link_btn-box {
    gap: 6.4px;
  }
}

.faq-link_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  background-color: #1A2D74;
  border-radius: 8px;
  padding: 0 32px 0 20px;
  height: 44px;
  transition: all 0.3s ease;
}
@media (max-width: 559.9px) {
  .faq-link_btn {
    height: 28px;
    padding: 0 20px 0 12px;
  }
}
.faq-link_btn .text {
  font-weight: 500;
  color: white;
}
@media (max-width: 559.9px) {
  .faq-link_btn .text {
    font-size: 1.2rem;
  }
}
.faq-link_btn i {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  color: white;
}
@media (max-width: 559.9px) {
  .faq-link_btn i {
    font-size: 1rem;
  }
}
.faq-link_btn:hover, .faq-link_btn:active {
  background-color: #3795D5;
}

.faq_list .faq_item {
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
}
.faq_list .faq_item:not(:last-child) {
  margin-bottom: 24px;
}
.faq_list .faq_item .box .inner-flex {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  position: relative;
  padding: 24px;
}
@media (max-width: 559.9px) {
  .faq_list .faq_item .box .inner-flex {
    padding: 20px;
  }
}
.faq_list .faq_item .box .alpha {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Quantico", Arial, Helvetica, sans-serif;
  font-size: 3.2rem;
  font-weight: 400;
  line-height: 1.5;
  color: white;
  border-radius: 40px;
  margin-right: 24px;
}
@media (max-width: 559.9px) {
  .faq_list .faq_item .box .alpha {
    width: 32px;
    height: 32px;
    font-family: "Quantico", Arial, Helvetica, sans-serif;
    font-size: 2rem;
    font-weight: 400;
    line-height: 1.5;
    margin-right: 16px;
  }
}
.faq_list .faq_item .box .inner {
  width: calc(100% - 80px);
  padding-top: 12px;
}
@media (max-width: 559.9px) {
  .faq_list .faq_item .box .inner {
    width: calc(100% - 48px);
    padding-top: 2px;
  }
}
.faq_list .faq_item .box.q-box {
  background-color: #D8DAE5;
}
.faq_list .faq_item .box.q-box .alpha {
  background-color: #1A2D74;
}
.faq_list .faq_item .box.q-box .inner {
  font-weight: bold;
  font-size: 110%;
  padding-right: 80px;
}
@media (max-width: 559.9px) {
  .faq_list .faq_item .box.q-box .inner {
    font-size: 100%;
    padding-right: 48px;
  }
}
.faq_list .faq_item .box.a-box {
  display: none;
  background-color: #F0FBFF;
  padding-bottom: 8px;
}
.faq_list .faq_item .box.a-box .head {
  font-size: 110%;
  font-weight: bold;
}
@media (max-width: 559.9px) {
  .faq_list .faq_item .box.a-box .head {
    font-size: 100%;
  }
}
.faq_list .faq_item .box.a-box .alpha {
  background-color: #7BCCEA;
  color: white;
}
.faq_list .faq_item .q-box {
  cursor: pointer;
}
.faq_list .faq_item .q-box .faq-open {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
  background: #f8fafa;
  box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.08), -5px -5px 5px #D8DAE5;
  transform: translateY(-50%);
  transition: 0.3s;
  position: absolute;
  right: 24px;
  top: 50%;
}
@media (max-width: 559.9px) {
  .faq_list .faq_item .q-box .faq-open {
    width: 32px;
    height: 32px;
    right: 16px;
  }
}
.faq_list .faq_item .q-box .faq-open::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 100%;
  background: #1A2D74;
  transform: translate(-50%, -50%);
  transition: 0.3s;
}
.faq_list .faq_item .q-box .faq-open span {
  width: 100%;
  height: 100%;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}
.faq_list .faq_item .q-box .faq-open span::after, .faq_list .faq_item .q-box .faq-open span::before {
  position: absolute;
  background: #1A2D74;
  display: block;
  content: "";
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  height: 2px;
  width: 20px;
  border-radius: 1px;
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}
@media (max-width: 559.9px) {
  .faq_list .faq_item .q-box .faq-open span::after, .faq_list .faq_item .q-box .faq-open span::before {
    width: 16px;
  }
}
.faq_list .faq_item .q-box .faq-open span::before {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.faq_list .faq_item .q-box .faq-open span::after {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(90deg);
}
.faq_list .faq_item .q-box.opened .faq-open span::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.faq_list .faq_item .q-box.opened .faq-open span::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.faq_list .faq_item .q-box:hover .faq-open::after {
  width: 48px;
  height: 48px;
}
@media (max-width: 559.9px) {
  .faq_list .faq_item .q-box:hover .faq-open::after {
    width: 32px;
    height: 32px;
  }
}
.faq_list .faq_item .q-box:hover .faq-open span::after, .faq_list .faq_item .q-box:hover .faq-open span::before {
  background: white;
}
/*# sourceMappingURL=styles.css.map */