@charset "UTF-8";
/* Sassでpxからvwへの変換式を定義して使う */
@import url("https://fonts.googleapis.com/css2?family=Crimson+Text:wght@400;600&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Zen+Old+Mincho:wght@700&display=swap");
.pc_vw {
  font-size: 1.25vw;
}

.sp_vw {
  font-size: 4.10256vw;
}

.crimson-text-regular,
.en {
  font-family: "Crimson Text", serif;
  font-weight: 400;
  font-style: normal;
}

.crimson-text-semibold {
  font-family: "Crimson Text", serif;
  font-weight: 600;
  font-style: normal;
}

.zen-old-mincho,
.zen {
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
  font-style: normal;
}

.noto-serif,
.serif,
.ja {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.noto-sans,
.sans {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

/*** The new CSS Reset - version 1.0.0 (last updated 8.7.2021) ***/
/* ブラウザのUAスタイルシートのすべてのスタイルを削除します、displayは除く */
*:where(:not(iframe, canvas, img, svg, video, input):not(svg *)) {
  all: unset;
  display: revert;
}

/* box-sizingの優先値 */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* リストのスタイル（箇条書き・番号）を削除します */
ol, ul {
  list-style: none;
}

/* 画像がコンテナを超えないようにするため */
img {
  max-width: 100%;
}

/* テーブルのセル間のスペースを削除します */
table {
  border-collapse: collapse;
}

html, body {
  width: 100%;
  font-family: "Noto Serif JP", "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, serif;
  /*font-feature-settings: "palt";*/
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

/* wrapper */
#wrapper {
  position: relative;
  background-color: #fff;
  color: #000;
  -webkit-text-size-adjust: 100%;
  box-sizing: border-box;
  font-feature-settings: palt;
}

@media print, screen and (max-width: 768px) {
  /*#wrapper { overflow: hidden; }*/
}

/* hiddn */
#wrapper .pc {
  display: none !important;
}

@media print, screen and (min-width: 769px) {
  #wrapper .pc {
    display: block !important;
  }
  #wrapper .sp {
    display: none !important;
  }
}

/* img */
#wrapper img {
  vertical-align: bottom;
}

@media print, screen and (max-width: 768px) {
  #wrapper img {
    max-width: 100%;
  }
}

@media print, screen and (min-width: 769px) {
  #wrapper img {
    max-width: auto;
    max-height: auto;
  }
}

/* a */
a {
  cursor: pointer;
}

a:hover {
  text-decoration: underline;
}

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

/* rollover */
@media print, screen and (min-width: 768px) {
  .ovrgp a:hover img, img.ovr:hover, input.ovr:hover, button.ovr:hover {
    opacity: 0.8;
  }
  a.hov {
    transition: .3s;
  }
  a.hov:hover {
    transform: scale(1.1);
  }
}

/* wrap */
.wrap {
  position: relative;
}

@media print, screen and (min-width: 769px) {
  .wrap {
    width: 100%;
    height: 100%;
    margin: 0 auto;
  }
}

/* marker */
.marker {
  background: linear-gradient(transparent 55%, #003366 55%);
}

.under {
  text-decoration: underline;
}

@media print, screen and (max-width: 768px) {
  .marker {
    background: linear-gradient(transparent 45%, #003366 45%);
  }
}

/* sticky */
.sticky-wrapper {
  z-index: 999;
}

/* fade-in */
.fade-in {
  opacity: 0;
  transition-duration: 500ms;
  transition-property: opacity,transform;
}

.fade-in-up {
  transform: translate(0, 30px);
}

.fade-in-down {
  transform: translate(0, -30px);
}

.fade-in-left {
  transform: translate(-30px, 0);
}

.fade-in-right {
  transform: translate(30px, 0);
}

.scroll-in {
  opacity: 1;
  transform: translate(0, 0);
}

/* pagetop */
/*.pagetop { display: none; position: fixed; z-index: 99; bottom: 210px; right: 30px; }
.pagetop a { width: 192px; height: 45px; display: flex; flex-flow: column; justify-content: center; align-items: center; border: solid 1px #036; font-size: 16px; color: #036; font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-weight: 500; font-style: normal; background-color: #fff; }
.pagetop a:hover { transition: .5s; background-color: $c-blue; color: #fff; }
*/
.pagetop {
  display: none;
  position: fixed;
  z-index: 99;
  bottom: 14.58333vw;
  right: 2.08333vw;
}

.pagetop a {
  width: 13.33333vw;
  height: 3.125vw;
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  border: solid 1px #036;
  font-size: 1.11111vw;
  color: #036;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  background-color: #fff;
}

.pagetop a:hover {
  transition: .5s;
  background-color: #003366;
  color: #fff;
}

@media print, screen and (max-width: 768px) {
  /*.pagetop { bottom: 20px; right: 0; left: 17px; }
.pagetop a { width: 60px; height: 32px; font-size: 12px; }*/
  .pagetop {
    bottom: 5.12821vw;
    right: 0;
    left: 4.35897vw;
  }
  .pagetop a {
    width: 15.38462vw;
    height: 8.20513vw;
    font-size: 3.07692vw;
  }
}

/* banner */
/*#banner { transition: .3s; position: fixed; z-index: 99; bottom: 0; right: -380px; }
#banner .wrap { display: flex; flex-flow: column; justify-content: center; align-items: left; gap: 20px; width: 380px; height: 190px; padding-left: 30px; border: solid 1px #036; border-right: none; border-bottom: none; text-align: left; background: #fff url(../img/banner_img.png) no-repeat bottom 25px right 25px; }
#banner .txt { font-weight: bold; color: $c-blue; }
#banner .tx01 { display: inline-block; font-size: 16px; }
#banner .tx02 { display: inline-block; margin-top: 5px; font-size: 22px; }
#banner .txt u { font-size: 24px; text-decoration: underline;}
#banner .btn {}
#banner .btn a {}
*/
#banner {
  transition: .3s;
  position: fixed;
  z-index: 99;
  bottom: 0;
  right: -26.38889vw;
}

#banner .wrap {
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: left;
  gap: 1.38889vw;
  width: 26.38889vw;
  height: 13.19444vw;
  padding-left: 2.08333vw;
  border: solid 1px #036;
  border-right: none;
  border-bottom: none;
  text-align: left;
  background: #fff url(../img/banner_img.png) no-repeat bottom 1.73611vw right 1.73611vw;
  background-size: 4.375vw;
}

#banner .txt {
  font-weight: bold;
  color: #003366;
}

#banner .tx01 {
  display: inline-block;
  font-size: 1.11111vw;
}

#banner .tx02 {
  display: inline-block;
  margin-top: 0.34722vw;
  font-size: 1.52778vw;
}

#banner .txt u {
  font-size: 1.66667vw;
  text-decoration: underline;
}

@media print, screen and (max-width: 768px) {
  /*#banner { bottom: 20px; right: -260px; }
#banner .wrap { gap: 0; width: 260px; height: 120px; padding: 0 0 0 15px; border: solid 1px #036; border-right: none; background: #fff url(../img/banner_img.png) no-repeat bottom 15px right 15px; background-size: 31px; }
#banner .txt {  }
#banner .tx01 { font-size: 12px; }
#banner .tx02 { margin-top: 5px; font-size: 14px; }
#banner .txt u { font-size: 18px; }
#banner .btn {}
#banner .btn a { font-size: 12px; }
*/
  #banner {
    bottom: 5.12821vw;
    right: -66.66667vw;
  }
  #banner .wrap {
    gap: 0;
    width: 66.66667vw;
    height: 30.76923vw;
    padding: 0 0 0 3.84615vw;
    border: solid 1px #036;
    border-right: none;
    background: #fff url(../img/banner_img.png) no-repeat bottom 3.84615vw right 3.84615vw;
    background-size: 7.94872vw;
  }
  #banner .tx01 {
    font-size: 3.07692vw;
  }
  #banner .tx02 {
    margin-top: 1.28205vw;
    font-size: 3.58974vw;
  }
  #banner .txt u {
    font-size: 4.61538vw;
  }
  #banner .btn a {
    font-size: 3.07692vw;
  }
}

/* tbl-wrap */
.tbl-wrap {
  position: relative;
  overflow: auto;
  white-space: nowrap;
  margin: 30px 0 0;
}

.tbl-wrap::-webkit-scrollbar {
  height: 6px;
}

.tbl-wrap::-webkit-scrollbar-track {
  background: #fafafa;
}

.tbl-wrap::-webkit-scrollbar-thumb {
  background: #ccc;
}

.tbl-wrap:before {
  display: block;
  content: "下の表は左右にスクロールできます";
  width: 100%;
  color: #003366;
  font-weight: bold;
  text-align: center;
  line-height: 2;
}

@media print, screen and (min-width: 768px) {
  .tbl-wrap {
    overflow: inherit;
    white-space: inherit;
    margin: 0;
  }
  .tbl-wrap:before {
    display: none;
  }
}

/* tbl-nsp */
.tbl-nsp {
  margin: 0;
}

@media print, screen and (min-width: 768px) {
  .tbl-nsp {
    margin: 0;
  }
}

/* sp-btn */
#sp-btn {
  display: none;
}

@media print, screen and (max-width: 768px) {
  /*#sp-btn { display: block; position: fixed; top: 16px; right: 15px; z-index: 1000; }
#sp-btn span { display: flex; flex-flow: column; justify-content: center; align-items: center; width: 60px; height: 32px; border-radius: 2px; border: solid 1px #036; background-color: #fff; }
#sp-btn span i { color: $c-blue; }
#sp-btn.open span { background-color: $c-blue; }
#sp-btn.open span i { color: #fff; }
#sp-btn.open span i:before { content: "\f00d"; }
*/
  #sp-btn {
    display: block;
    position: fixed;
    top: 4.10256vw;
    right: 3.84615vw;
    z-index: 1000;
  }
  #sp-btn span {
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width: 15.38462vw;
    height: 8.20513vw;
    border-radius: 0.51282vw;
    border: solid 1px #036;
    background-color: #fff;
  }
  #sp-btn span i {
    color: #003366;
  }
  #sp-btn.open span {
    background-color: #003366;
  }
  #sp-btn.open span i {
    color: #fff;
  }
  #sp-btn.open span i:before {
    content: "\f00d";
  }
}

/* sp-nav */
#sp-nav {
  display: none;
}

@media print, screen and (max-width: 768px) {
  /*#sp-nav { position: relative; }
#sp-nav .sp-menu { position: fixed; z-index: 999; top: 0; left: 0; right: 0; bottom: 0; width: 390px; height: 100%; display: flex; justify-content: center; align-items: center; background-color: #fff; }
#sp-nav .sp-menu ul { display: flex; flex-flow: column; }
#sp-nav .sp-menu li { position: relative; width: 310px; text-align: left; }
#sp-nav .sp-menu li a { display: inline-block; padding: 40px 0 20px; font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-weight: 500; font-style: normal; font-size: 18px; font-weight: 500; color: $c-blue; border-bottom: 1px solid $c-blue; }
#sp-nav .sp-menu li i { margin-left: 20px; }
*/
  #sp-nav {
    position: relative;
  }
  #sp-nav .sp-menu {
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100vw;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #fff;
  }
  #sp-nav .sp-menu ul {
    display: flex;
    flex-flow: column;
  }
  #sp-nav .sp-menu li {
    position: relative;
    width: 79.48718vw;
    text-align: left;
  }
  #sp-nav .sp-menu li a {
    display: inline-block;
    padding: 5.12821vw 0 5.12821vw;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-weight: 500;
    font-style: normal;
    font-size: 4.61538vw;
    font-weight: 500;
    color: #003366;
    border-bottom: 1px solid #003366;
  }
  #sp-nav .sp-menu li i {
    margin-left: 5.12821vw;
  }
}

/* arrow */
/*.arrow { position: relative; padding-right: 23px; }
.arrow i { overflow: hidden; position: absolute; top: 3px; right: 0; bottom: 0; width: 12px; height: 12px; line-height: 1; }
.arrow i:before,
.arrow i:after { position: absolute; top: 0; right: 0; animation-fill-mode: forwards; animation-duration: 0.2s; }
*/
.arrow {
  position: relative;
  padding-right: 1.59722vw;
}

.arrow i {
  overflow: hidden;
  position: absolute;
  top: 0.20833vw;
  right: 0;
  bottom: 0;
  width: 0.83333vw;
  height: 0.83333vw;
  line-height: 1;
}

.arrow i:before,
.arrow i:after {
  position: absolute;
  top: 0;
  right: 0;
  animation-fill-mode: forwards;
  animation-duration: 0.2s;
}

@media print, screen and (max-width: 768px) {
  /*.arrow { padding-right: 23px; }
.arrow i { top: 3px; width: 10px; height: 10px; }
*/
  .arrow {
    padding-right: 5.89744vw;
  }
  .arrow i {
    top: 0.76923vw;
    width: 2.5641vw;
    height: 2.5641vw;
  }
}

/*.btn .arrow { padding-right: 24px; }
.btn .arrow i { top: 3px; width: 16px; height: 16px; font-weight: 700; color: $c-blue; font-size: 16px; }
.btn .arrow.siro i { color: #fff; }
*/
.btn .arrow {
  padding-right: 1.66667vw;
}

.btn .arrow i {
  top: 0.20833vw;
  width: 1.11111vw;
  height: 1.11111vw;
  font-weight: 700;
  color: #003366;
  font-size: 1.11111vw;
}

.btn .arrow.siro i {
  color: #fff;
}

@media print, screen and (max-width: 768px) {
  /*.btn .arrow { padding-right: 24px; }
.btn .arrow i { top: 3px; width: 14px; height: 14px; font-size: 14px; }
*/
  .btn .arrow {
    padding-right: 6.15385vw;
  }
  .btn .arrow i {
    top: 0.76923vw;
    width: 3.58974vw;
    height: 3.58974vw;
    font-size: 3.58974vw;
  }
}

/*
.menu .arrow { display: block; padding-right: 0; }
.menu .arrow i { top: 50%; width: 20px; height: 24px; margin-top: -10px; font-weight: 700; color: $c-blue; font-size: 20px; }
*/
.menu .arrow {
  display: block;
  padding-right: 0;
}

.menu .arrow i {
  top: 50%;
  width: 1.38889vw;
  height: 1.66667vw;
  margin-top: -0.69444vw;
  font-weight: 700;
  color: #003366;
  font-size: 1.38889vw;
}

@media print, screen and (max-width: 768px) {
  /*.menu .arrow {  }
.menu .arrow i { width: 16px; height: 20px; margin-top: -10px; font-size: 15px; }
*/
  .menu .arrow i {
    width: 4.10256vw;
    height: 5.12821vw;
    margin-top: -2.5641vw;
    font-size: 3.84615vw;
  }
}

/*.train .arrow { display: block; padding-right: 0; }
.train .arrow i { width: 20px; height: 26px; font-weight: 700; color: $c-blue; font-size: 19px; }
*/
.train .arrow {
  display: block;
  padding-right: 0;
}

.train .arrow i {
  width: 1.38889vw;
  height: 1.80556vw;
  font-weight: 700;
  color: #003366;
  font-size: 1.31944vw;
}

@media print, screen and (max-width: 768px) {
  /*.train .arrow { }
.train .arrow i { width: 16px; height: 24px; font-size: 16px; }
*/
  .train .arrow i {
    width: 4.10256vw;
    height: 6.15385vw;
    font-size: 4.10256vw;
  }
}

/*
.sec-contact .arrow i { width: 14px; height: 14px; font-size: 14px; }
*/
.sec-contact .arrow i {
  width: 0.97222vw;
  height: 0.97222vw;
  font-size: 0.97222vw;
}

@media print, screen and (max-width: 768px) {
  .sec-contact .arrow i {
    width: 3.58974vw;
    height: 3.58974vw;
    font-size: 3.58974vw;
  }
}

.arrow i.fa-arrow-right:before,
.arrow i.fa-arrow-right:after {
  content: "\f061";
}

.arrow i.fa-circle-arrow-right:before,
.arrow i.fa-circle-arrow-right:after {
  content: "\f0a9";
}

.arrow i:after {
  transform: translateX(-100%);
}

.arrow:hover i:before {
  animation-name: transRL;
  animation-delay: 0s;
}

.arrow:hover i:after {
  animation-name: transLR;
  animation-delay: 0.2s;
}

@keyframes transLR {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0);
  }
}

@keyframes transRL {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(100%);
  }
}

/* header */
/*#header { position: relative; }
#header .wrap { width: 1440px; height: 90px; display: flex; justify-content: right; align-items: center; gap: 30px; font-family: "Noto Sans JP", sans-serif; font-weight: 500; background-color: #fff; }
#header .logo { position: absolute; top: 30px; left: 30px; }
#header .logo img { vertical-align: middle; }
#header .gnavi { width: 523px; }
#header .gnavi ul { display: flex; justify-content: center; align-items: center; gap: 28px; }
#header .gnavi li { font-size: 14px; }
#header .gnavi a { color: $c-blue; }
#header .gnavi a:hover { transition: .5s; text-decoration: underline; }
#header .button { display: flex; gap: 10px; margin-right: 30px; }
#header .btn_men a { width: 136px; height: 38px; display: flex; flex-direction: row; justify-content: center; align-items: center; gap: 13px; border-radius: 2px; border: solid 1px $c-blue; font-size: 14px; color: $c-blue; }
#header .btn_men i { font-size: 13px; }
#header .btn_con { }
#header .btn_con a { width: 212px; height: 38px; display: flex; flex-direction: row; justify-content: center; align-items: center; gap: 12px; border-radius: 2px; background-color: $c-blue; color: #fff; font-size: 14px; }
#header .btn_con i { font-size: 13px; }
*/
#header {
  position: relative;
}

#header .wrap {
  width: 100vw;
  height: 6.25vw;
  display: flex;
  justify-content: right;
  align-items: center;
  gap: 2.08333vw;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  background-color: #fff;
}

#header .logo {
  position: absolute;
  top: 2.08333vw;
  left: 2.08333vw;
}

#header .logo img {
  width: 13.54167vw;
  vertical-align: middle;
}

#header .gnavi {
  width: 36.31944vw;
}

#header .gnavi ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.94444vw;
}

#header .gnavi li {
  font-size: 0.97222vw;
}

#header .gnavi a {
  color: #003366;
}

#header .gnavi a:hover {
  transition: .5s;
  text-decoration: underline;
}

#header .button {
  display: flex;
  gap: 0.69444vw;
  margin-right: 2.08333vw;
}

#header .btn_men a {
  width: 9.44444vw;
  height: 2.63889vw;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 0.90278vw;
  border-radius: 0.13889vw;
  border: solid 1px #003366;
  font-size: 0.97222vw;
  color: #003366;
}

#header .btn_men i {
  font-size: 0.90278vw;
}

#header .btn_con a {
  width: 14.72222vw;
  height: 2.63889vw;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 0.83333vw;
  border-radius: 0.13889vw;
  background-color: #003366;
  color: #fff;
  font-size: 0.97222vw;
}

#header .btn_con i {
  font-size: 0.90278vw;
}

@media print, screen and (max-width: 768px) {
  /*#header { }
#header .wrap { width: 100%; height: 50px; }
#header .logo { top: 20px; left: 17px; }
#header .logo img { width: 140px; }
#header .gnavi,
#header .button { display: none; }
*/
  #header .wrap {
    width: 100%;
    height: 12.82051vw;
  }
  #header .logo {
    top: 5.12821vw;
    left: 4.35897vw;
  }
  #header .logo img {
    width: 35.89744vw;
  }
  #header .gnavi,
  #header .button {
    display: none;
  }
}

/* visual */
/*#visual { position: relative; margin-top: 60px; }
#visual .wrap { width: 1440px; height: 630px; margin: 0 auto; background: url(../img/visual.png) no-repeat; background-size: cover; }
#visual h1 { position: absolute; top: 95px; left: 52px; font-family: "Zen Old Mincho", serif; font-weight: 700; font-style: normal; font-size: 70px; color: #eee; }
#visual p { position: absolute; top: 217px; left: 95px; font-family: "Zen Old Mincho", serif; font-weight: 600; font-style: normal; font-size: 32px; letter-spacing: 6.4px; color: #eee; }
*/
#visual {
  position: relative;
  margin-top: 4.16667vw;
}

#visual .wrap {
  width: 100vw;
  height: 43.75vw;
  margin: 0 auto;
  background: url(../img/visual.png) no-repeat;
  background-size: cover;
}

#visual h1 {
  position: absolute;
  top: 6.59722vw;
  left: 3.61111vw;
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
  font-style: normal;
  font-size: 4.86111vw;
  color: #eee;
}

#visual p {
  position: absolute;
  top: 15.06944vw;
  left: 6.59722vw;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.22222vw;
  letter-spacing: 0.44444vw;
  color: #eee;
}

@media print, screen and (max-width: 768px) {
  /*#visual { margin-top: 30px; }
#visual .wrap { width: 100%; height: 630px; background: url(../img/visual_sp.png) no-repeat; }
#visual h1 { top: 90px; left: 0; font-size: 48px; }
#visual h1 .tx01 { display: block; }
#visual h1 .tx02 { display: block; margin-left: 30px; }
#visual p { top: 274px; left: 27px; font-size: 16px; letter-spacing: normal; }
*/
  #visual {
    margin-top: 7.69231vw;
  }
  #visual .wrap {
    width: 100%;
    height: 161.53846vw;
    background: url(../img/visual_sp.png) no-repeat;
    background-size: cover;
  }
  #visual h1 {
    top: 23.07692vw;
    left: 0;
    font-size: 12.30769vw;
  }
  #visual h1 .tx01 {
    display: block;
  }
  #visual h1 .tx02 {
    display: block;
    margin-left: 7.69231vw;
  }
  #visual p {
    top: 70.25641vw;
    left: 6.92308vw;
    font-size: 4.10256vw;
    letter-spacing: normal;
  }
}

/* footer */
/*#footer { position: relative; }
#footer .wrap { width: 1440px; height: 600px; display: flex; justify-content: space-between; align-items: center; font-family: "Noto Sans JP", sans-serif; font-weight: 500; }
#footer .footer_info { margin-left: 125px; display: flex; flex-flow: column; gap: 30px; }
#footer .footer_menu { margin-right: 165px; display: flex; justify-content: space-between; gap: 60px; }
#footer .footer_menu li { position: relative; padding: 3px 0; }
#footer .menu li:first-child:before,
#footer .menu li:hover:before { position: absolute; top: 6px; left: -20px; display: inline-block; content: "\f061"; font-family: "Font Awesome 7 Free"; font-weight: 700; font-size: 13px; }
#footer .menu li a:hover { text-decoration: underline; }
#footer .logo { width: 195px; height: 40px; }
#footer .address { font-size: 14px; text-align: left; }
#footer .share { display: flex; align-items: center; gap: 10px; }
#footer .share li { }
#footer .share li a { width: 35px; height: 35px;
display: flex; flex-direction: row; justify-content: center;
align-items: center; border-radius: 50%; border: solid 1px #797979; }
#footer .share li a:hover { opacity: .7;}
#footer .copy { font-weight: 500; font-size: 14px; }
#footer .copyr small { font-size: 13px; color: #3d3d3d; }
#footer .menu { font-size: 15px; line-height: 2.33; letter-spacing: normal; text-align: left; color: #036; }
*/
#footer {
  position: relative;
}

#footer .wrap {
  width: 100vw;
  height: 41.66667vw;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}

#footer .footer_info {
  margin-left: 8.68056vw;
  display: flex;
  flex-flow: column;
  gap: 2.08333vw;
}

#footer .footer_menu {
  margin-right: 11.45833vw;
  display: flex;
  justify-content: space-between;
  gap: 4.16667vw;
}

#footer .footer_menu li {
  position: relative;
  padding: 0.20833vw 0;
}

#footer .menu li:first-child:before,
#footer .menu li:hover:before {
  position: absolute;
  top: 0.41667vw;
  left: -1.38889vw;
  display: inline-block;
  content: "\f061";
  font-family: "Font Awesome 7 Free";
  font-weight: 700;
  font-size: 0.90278vw;
}

#footer .menu li a:hover {
  text-decoration: underline;
}

#footer .logo {
  width: 13.54167vw;
  height: 2.77778vw;
}

#footer .logo img {
  width: 13.54167vw;
}

#footer .address {
  font-size: 0.97222vw;
  text-align: left;
}

#footer .share {
  display: flex;
  align-items: center;
  gap: 0.69444vw;
}

#footer .share li a {
  width: 2.43056vw;
  height: 2.43056vw;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  border: solid 1px #797979;
}

#footer .share li a:hover {
  opacity: .7;
}

#footer .copy {
  font-weight: 500;
  font-size: 0.97222vw;
}

#footer .copyr small {
  font-size: 0.90278vw;
  color: #3d3d3d;
}

#footer .menu {
  font-size: 1.04167vw;
  line-height: 2.33;
  letter-spacing: normal;
  text-align: left;
  color: #036;
}

@media print, screen and (max-width: 768px) {
  /*#footer { }
#footer .wrap { width: 100%; height: auto; padding: 80px 15px 160px; }
#footer .footer_info { margin-left: 0; gap: 20px; }
#footer .footer_menu { display: none; }
#footer .logo { width: 195px; height: 40px; }
#footer .address { font-size: 14px; }
#footer .share { gap: 10px; }
#footer .share li a { width: 40px; height: 40px; }
#footer .copy { font-size: 14px; }
#footer .copyr small { font-size: 13px; }
#footer .menu { font-size: 15px; }
*/
  #footer .wrap {
    width: 100%;
    height: auto;
    padding: 20.51282vw 3.84615vw 41.02564vw;
  }
  #footer .footer_info {
    margin-left: 0;
    gap: 5.12821vw;
  }
  #footer .footer_menu {
    display: none;
  }
  #footer .logo {
    width: 50vw;
    height: 10.25641vw;
  }
  #footer .logo img {
    width: 50vw;
  }
  #footer .address {
    font-size: 3.58974vw;
  }
  #footer .share {
    gap: 2.5641vw;
  }
  #footer .share li a {
    width: 10.25641vw;
    height: 10.25641vw;
  }
  #footer .copy {
    font-size: 3.58974vw;
  }
  #footer .copyr small {
    font-size: 3.33333vw;
  }
  #footer .menu {
    font-size: 3.84615vw;
  }
}

/* title */
/*
.title {}
.title .en { font-size: 120px; background: linear-gradient(to right, #036, #0069d2 48%, #fff);
-webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;}
.title .ja { font-size: 20px; font-weight: 700; }
*/
.title .en {
  font-size: 8.33333vw;
  background: linear-gradient(to right, #036, #0069d2 48%, #fff);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.title .ja {
  font-size: 1.38889vw;
  font-weight: 700;
}

.white .title .en {
  background: linear-gradient(to left, #036, #0069d2 48%, #fff);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.white .title .ja {
  color: #fff;
}

@media print, screen and (max-width: 768px) {
  /*.title { margin-left: 15px; }
.title .en { font-size: 70px; }
.title .ja { font-size: 14px; font-weight: 600; }
*/
  .title {
    margin-left: 3.84615vw;
  }
  .title .en {
    font-size: 17.94872vw;
  }
  .title .en.en-sp {
    font-size: 12.82051vw;
  }
  .title .ja {
    font-size: 3.58974vw;
    font-weight: 600;
  }
}

/* btn */
/*.btn { }
.btn a { position: relative; display: inline-block; padding-bottom: 20px; border-bottom: 1px solid $c-blue; font-size: 14px; font-weight: 500; color: $c-blue; font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-weight: 500; font-style: normal; }
.btn a:hover { text-decoration: underline; }
*/
.btn a {
  position: relative;
  display: inline-block;
  padding-bottom: 1.38889vw;
  border-bottom: 1px solid #003366;
  font-size: 0.97222vw;
  font-weight: 500;
  color: #003366;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.btn a:hover {
  text-decoration: underline;
}

@media print, screen and (max-width: 768px) {
  /*.btn a { padding-bottom: 15px; font-size: 14px; }
*/
  .btn a {
    padding-bottom: 3.84615vw;
    font-size: 3.58974vw;
  }
}

/* service */
/*.sec-service {}
.sec-service .wrap { width: 1180px; margin: 0 auto; padding: 80px 0 160px; text-align: left; }
.sec-service .title {  }
.sec-service .inner { padding: 90px 0 0; }
.sec-service .cnt01 { display: flex; gap: 100px; background: url(../img/service_img03.png) no-repeat bottom 210px right 30px; }
.sec-service .cnt01 .ph {  }
.sec-service .cnt01 .ph img {  }
.sec-service .cnt01 .tx { text-align: left; }
.sec-service .cnt01 .tx h3 { margin-bottom: 50px; color: $c-blue; }
.sec-service .cnt01 .tx .tx01 { font-size: 44.4px; font-weight: bold; }
.sec-service .cnt01 .tx .tx02 { font-size: 70px; font-weight: bold; }
.sec-service .cnt01 .tx p { margin-bottom: 30px; font-size: 18px; font-weight: bold; line-height: 2.78; }
.sec-service .cnt02 { display: flex; justify-content: space-between; gap: 40px; margin-top: 120px; background: url(../img/service_img04.png) no-repeat bottom 120px left; }
.sec-service .cnt02 .ph { order: 2; }
.sec-service .cnt02 .ph img {  }
.sec-service .cnt02 .tx { order: 1;  }
.sec-service .cnt02 .tx h3 { margin-bottom: 30px; color: $c-blue; }
.sec-service .cnt02 .tx .tx01 { display: inline-block; margin-bottom: 10px; font-size: 54px; font-weight: bold; }
.sec-service .cnt02 .tx .tx02 { display: inline-block; font-size: 32px; font-weight: bold; }
.sec-service .cnt02 .tx p { width: 440px; margin: 0 0 30px 280px; font-size: 18px; font-weight: bold; line-height: 2.78; }
.sec-service .cnt02 .btn { margin-left: 280px; }
*/
.sec-service .wrap {
  width: 81.94444vw;
  margin: 0 auto;
  padding: 5.55556vw 0 11.11111vw;
  text-align: left;
}

.sec-service .inner {
  padding: 6.25vw 0 0;
}

.sec-service .cnt01 {
  display: flex;
  gap: 6.94444vw;
  background: url(../img/service_img03.png) no-repeat bottom 14.58333vw right 2.08333vw;
  background-size: 13.81944vw;
}

.sec-service .cnt01 .tx {
  text-align: left;
}

.sec-service .cnt01 .tx h3 {
  margin-bottom: 3.47222vw;
  color: #003366;
}

.sec-service .cnt01 .tx .tx01 {
  font-size: 3.08333vw;
  font-weight: bold;
}

.sec-service .cnt01 .tx .tx02 {
  font-size: 4.86111vw;
  font-weight: bold;
}

.sec-service .cnt01 .tx p {
  margin-bottom: 2.08333vw;
  font-size: 1.25vw;
  font-weight: bold;
  line-height: 2.78;
}

.sec-service .cnt02 {
  display: flex;
  justify-content: space-between;
  gap: 2.77778vw;
  margin-top: 8.33333vw;
  background: url(../img/service_img04.png) no-repeat bottom 8.33333vw left;
  background-size: 15.20833vw;
}

.sec-service .cnt01 .ph img {
  width: 29.65278vw;
}

.sec-service .cnt02 .ph img {
  width: 28.33333vw;
}

.sec-service .cnt02 .ph {
  order: 2;
}

.sec-service .cnt02 .tx {
  order: 1;
}

.sec-service .cnt02 .tx h3 {
  margin-bottom: 2.08333vw;
  color: #003366;
}

.sec-service .cnt02 .tx .tx01 {
  display: inline-block;
  margin-bottom: 0.69444vw;
  font-size: 3.75vw;
  font-weight: bold;
}

.sec-service .cnt02 .tx .tx02 {
  display: inline-block;
  font-size: 2.22222vw;
  font-weight: bold;
}

.sec-service .cnt02 .tx p {
  width: 30.55556vw;
  margin: 0 0 2.08333vw 19.44444vw;
  font-size: 1.25vw;
  font-weight: bold;
  line-height: 2.78;
}

.sec-service .cnt02 .btn {
  margin-left: 19.44444vw;
}

@media print, screen and (max-width: 768px) {
  /*.sec-service {}
.sec-service .wrap { width: 100%; padding: 80px 0; }
.sec-service .title {  }
.sec-service .inner { padding: 45px 0 0; }
.sec-service .cnt01 { display: flex; flex-flow: column; gap: 50px; background: none; }
.sec-service .cnt01 .ph img { width: 340px; }
.sec-service .cnt01 .tx { margin-left: 15px; }
.sec-service .cnt01 .tx h3 { margin-bottom: 25px; }
.sec-service .cnt01 .tx .tx01 { font-size: 32px; }
.sec-service .cnt01 .tx .tx02 { font-size: 48px; }
.sec-service .cnt01 .tx p { margin-bottom: 30px; font-size: 16px; line-height: 2.5; }
.sec-service .cnt02 { display: flex; flex-flow: column; gap: 30px; margin-top: 60px; background: none; }
.sec-service .cnt02 .ph { order: 1; }
.sec-service .cnt02 .ph img { width: 340px; }
.sec-service .cnt02 .tx { order: 2; margin-left: 15px; }
.sec-service .cnt02 .tx h3 { margin-bottom: 30px; }
.sec-service .cnt02 .tx .tx01 { margin-bottom: 10px; font-size: 48px; }
.sec-service .cnt02 .tx .tx02 { font-size: 24px; }
.sec-service .cnt02 .tx p { width: 100%; margin: 0; font-size: 16px; line-height: 2.5; }
.sec-service .cnt02 .btn { margin: 30px 0 0; }
*/
  .sec-service .wrap {
    width: 100%;
    padding: 20.51282vw 0;
  }
  .sec-service .inner {
    padding: 11.53846vw 0 0;
  }
  .sec-service .cnt01 {
    display: flex;
    flex-flow: column;
    gap: 12.82051vw;
    background: none;
  }
  .sec-service .cnt01 .ph img {
    width: 87.17949vw;
  }
  .sec-service .cnt01 .tx {
    margin-left: 3.84615vw;
  }
  .sec-service .cnt01 .tx h3 {
    margin-bottom: 6.41026vw;
  }
  .sec-service .cnt01 .tx .tx01 {
    font-size: 8.20513vw;
  }
  .sec-service .cnt01 .tx .tx02 {
    font-size: 12.30769vw;
  }
  .sec-service .cnt01 .tx p {
    margin-bottom: 7.69231vw;
    font-size: 4.10256vw;
    line-height: 2.5;
  }
  .sec-service .cnt02 {
    display: flex;
    flex-flow: column;
    gap: 7.69231vw;
    margin-top: 15.38462vw;
    background: none;
  }
  .sec-service .cnt02 .ph {
    order: 1;
  }
  .sec-service .cnt02 .ph img {
    width: 87.17949vw;
  }
  .sec-service .cnt02 .tx {
    order: 2;
    margin-left: 3.84615vw;
  }
  .sec-service .cnt02 .tx h3 {
    margin-bottom: 7.69231vw;
  }
  .sec-service .cnt02 .tx .tx01 {
    margin-bottom: 2.5641vw;
    font-size: 12.30769vw;
  }
  .sec-service .cnt02 .tx .tx02 {
    font-size: 6.15385vw;
  }
  .sec-service .cnt02 .tx p {
    width: 100%;
    margin: 0;
    font-size: 4.10256vw;
    line-height: 2.5;
  }
  .sec-service .cnt02 .btn {
    margin: 7.69231vw 0 0;
  }
}

/* members */
/*.sec-members { background: url(../img/members_img03.png) no-repeat center center; background-size: cover; }
.sec-members .wrap { position: relative; width: 1440px; height: 960px; }
.sec-members .inner { height: 100%; display: flex; flex-flow: column; justify-content: center; align-items: center; text-align: center; }
.sec-members .img01 { position: absolute; top:80px; left: 130px; }
.sec-members .img02 { position: absolute; right:130px; bottom: 80px; }
.sec-members .title {}
.sec-members .title .en { background-image: linear-gradient(91deg, #fff 0%, #d9d9d9 102%) !important;}
.sec-members .title .ja { text-shadow: 0 4px 4px rgba(0, 0, 0, 0.25); font-size: 40px; color: #fff; }
.sec-members p { margin: 50px 0; font-size: 18px; line-height: 1.78; color: #fff; }
.sec-members .btn {  }
.sec-members .btn a { border-bottom: 1px solid #fff; color: #fff; }
.sec-members .btn a:after { color: #fff; right: -25px; }
*/
.sec-members {
  background: url(../img/members_img03.png) no-repeat center center;
  background-size: cover;
}

.sec-members .wrap {
  position: relative;
  width: 100vw;
  height: 66.66667vw;
}

.sec-members .inner {
  height: 100%;
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.sec-members .img01 {
  position: absolute;
  top: 5.55556vw;
  left: 9.02778vw;
}

.sec-members .img02 {
  position: absolute;
  right: 9.02778vw;
  bottom: 5.55556vw;
}

.sec-members .img01 img,
.sec-members .img02 img {
  width: 19.09722vw;
}

.sec-members .title .en {
  background-image: linear-gradient(91deg, #fff 0%, #d9d9d9 102%) !important;
}

.sec-members .title .ja {
  text-shadow: 0 0.27778vw 0.27778vw rgba(0, 0, 0, 0.25);
  font-size: 2.77778vw;
  color: #fff;
}

.sec-members p {
  margin: 3.47222vw 0;
  font-size: 1.25vw;
  line-height: 1.78;
  color: #fff;
}

.sec-members .btn a {
  border-bottom: 1px solid #fff;
  color: #fff;
}

.sec-members .btn a:after {
  color: #fff;
  right: -1.73611vw;
}

@media print, screen and (max-width: 768px) {
  /*.sec-members { background: url(../img/members_sp.png) no-repeat center center; background-size: cover; }
.sec-members .wrap { width: 100%; height: 1212px; }
.sec-members .inner {  }
.sec-members .img01 { top: 40px; left: 0; }
.sec-members .img02 { right: 0; bottom: 40px; }
.sec-members .img01 img,
.sec-members .img02 img { width: 200px; }
.sec-members .title {}
.sec-members .title .en { }
.sec-members .title .ja { font-size: 26px; color: #fff; }
.sec-members p { margin: 25px 0; font-size: 14px; line-height: 2.14; }
.sec-members .btn {  }
.sec-members .btn a {  }
.sec-members .btn a:after {  }
*/
  .sec-members {
    background: url(../img/members_sp.png) no-repeat center center;
    background-size: cover;
  }
  .sec-members .wrap {
    width: 100%;
    height: 310.76923vw;
  }
  .sec-members .img01 {
    top: 10.25641vw;
    left: 0;
  }
  .sec-members .img02 {
    right: 0;
    bottom: 10.25641vw;
  }
  .sec-members .img01 img,
  .sec-members .img02 img {
    width: 51.28205vw;
  }
  .sec-members .title .ja {
    font-size: 6.66667vw;
    color: #fff;
  }
  .sec-members p {
    margin: 6.41026vw 0;
    font-size: 3.58974vw;
    line-height: 2.14;
  }
}

/* clients */
/*.sec-clients {}
.sec-clients .wrap { width: 1280px; margin: 0 auto; padding: 100px 0 200px; }
.sec-clients .title { margin-bottom: 70px; }
.sec-clients .title .en { background-image: linear-gradient(to right, #484848, #a3a6aa 48%, #fff); }
.sec-clients .title .ja {}
.sec-clients .cnt { display: flex; justify-content: space-between; gap: 30px; }
.sec-clients .cnt li { position: relative; display: flex; justify-content: center; align-items: center; gap: 30px; width: 480px; height: 150px; border-radius: 5px; border: solid 1px #036; font-size: 18px; font-weight: 600; color: $c-blue; text-align: left; }
.sec-clients .cnt li:last-child { width: 240px; }
.sec-clients .cnt li:before { display: inline-block; width: 50px; height: 50px; content: ""; background: url(../img/ico_company.png) no-repeat; }
*/
.sec-clients .wrap {
  width: 88.88889vw;
  margin: 0 auto;
  padding: 6.94444vw 0 13.88889vw;
}

.sec-clients .title {
  margin-bottom: 4.86111vw;
}

.sec-clients .title .en {
  background-image: linear-gradient(to right, #484848, #a3a6aa 48%, #fff);
}

.sec-clients .cnt {
  display: flex;
  justify-content: space-between;
  gap: 2.08333vw;
}

.sec-clients .cnt li {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2.08333vw;
  width: 33.33333vw;
  height: 10.41667vw;
  border-radius: 0.34722vw;
  border: solid 1px #036;
  font-size: 1.25vw;
  font-weight: 600;
  color: #003366;
  text-align: left;
}

.sec-clients .cnt li:last-child {
  width: 16.66667vw;
}

.sec-clients .cnt li:before {
  display: inline-block;
  width: 3.47222vw;
  height: 3.47222vw;
  content: "";
  background: url(../img/ico_company.png) no-repeat;
}

@media print, screen and (max-width: 768px) {
  /*.sec-clients {}
.sec-clients .wrap { width: 100%; padding: 80px 0; }
.sec-clients .title { margin-bottom: 40px; }
.sec-clients .title .en { }
.sec-clients .title .ja {}
.sec-clients .cnt { display: flex; flex-flow: column; justify-content: center; align-items: center; gap: 15px; }
.sec-clients .cnt li { gap: 15px; width: 350px; height: 100px; border-radius: 5px; font-size: 14px; }
.sec-clients .cnt li:last-child { width: 350px; }
.sec-clients .cnt li:before { position: absolute; top: 50%; left: 30px; width: 30px; height: 30px; margin-top: -15px; background: url(../img/ico_company.png) no-repeat; background-size: cover; }
*/
  .sec-clients .wrap {
    width: 100%;
    padding: 20.51282vw 0;
  }
  .sec-clients .title {
    margin-bottom: 10.25641vw;
  }
  .sec-clients .cnt {
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    gap: 3.84615vw;
  }
  .sec-clients .cnt li {
    gap: 3.84615vw;
    width: 89.74359vw;
    height: 25.64103vw;
    border-radius: 1.28205vw;
    font-size: 3.58974vw;
  }
  .sec-clients .cnt li:last-child {
    width: 89.74359vw;
  }
  .sec-clients .cnt li:before {
    position: absolute;
    top: 50%;
    left: 7.69231vw;
    width: 7.69231vw;
    height: 7.69231vw;
    margin-top: -3.84615vw;
    background: url(../img/ico_company.png) no-repeat;
    background-size: cover;
  }
}

/* training */
/*.sec-training { background-color: #f4f9ff; }
.sec-training .wrap { width: 1280px; margin: 0 auto; padding: 90px 0;}
.sec-training .inner { display: flex; justify-content: space-between; align-items: flex-end; }
.sec-training .title { }
.sec-training .title .en {}
.sec-training .title .ja {}
.sec-training .txt { font-size: 20px; font-weight: 600;}
.sec-training .cnt { position: relative; margin-top: 60px; padding-bottom: 90px; }
.sec-training .cnt ul { display: flex; justify-content: space-between; }
.sec-training .cnt li { position: relative; box-shadow: 0 6px 15px 0 rgba(0, 51, 102, 0.1); background-color: #fff; }
.sec-training .cnt ul a { position: relative; display: block; width: 400px; height: 450px; padding: 20px; }
.sec-training .cnt .img { margin-bottom: 25px; }
.sec-training .cnt ul a:hover img { transition: .5s; opacity: .8; }
.sec-training .cnt .ico { width: 100px; height: 30px; display: flex; flex-direction: row; justify-content: center; align-items: center; background-color: #036; color: #fff; font-size: 14px; font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; }
.sec-training .cnt .txt { font-size: 18px; font-weight: bold; line-height: 1.56; }
.sec-training .cnt .btn { position: absolute; bottom: 20px; right: 20px; }
.sec-training .cnt li .btn { position: absolute; bottom: 0; right: 20px; }
.sec-training .cnt li .arw { position: absolute; bottom: 40px; right: 20px; }
*/
.sec-training {
  background-color: #f4f9ff;
}

.sec-training .wrap {
  width: 88.88889vw;
  margin: 0 auto;
  padding: 6.25vw 0;
}

.sec-training .inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.sec-training .txt {
  font-size: 1.38889vw;
  font-weight: 600;
}

.sec-training .cnt {
  position: relative;
  margin-top: 4.16667vw;
  padding-bottom: 6.25vw;
}

.sec-training .cnt ul {
  display: flex;
  justify-content: space-between;
}

.sec-training .cnt li {
  position: relative;
  box-shadow: 0 0.41667vw 1.04167vw 0 rgba(0, 51, 102, 0.1);
  background-color: #fff;
}

.sec-training .cnt ul a {
  position: relative;
  display: block;
  width: 27.77778vw;
  height: 31.25vw;
  padding: 1.38889vw;
}

.sec-training .cnt .img {
  margin-bottom: 1.73611vw;
}

.sec-training .cnt .img img {
  width: 25vw;
}

.sec-training .cnt .ico {
  width: 6.94444vw;
  height: 2.08333vw;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  background-color: #036;
  color: #fff;
  font-size: 0.97222vw;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.sec-training .cnt .txt {
  font-size: 1.25vw;
  font-weight: bold;
  line-height: 1.56;
}

.sec-training .cnt .btn {
  position: absolute;
  bottom: 1.38889vw;
  right: 1.38889vw;
}

.sec-training .cnt li .btn {
  position: absolute;
  bottom: 0;
  right: 1.38889vw;
}

.sec-training .cnt li .arw {
  position: absolute;
  bottom: 2.77778vw;
  right: 1.38889vw;
}

@media print, screen and (max-width: 768px) {
  /*.sec-training { }
.sec-training .wrap { width: 100%; padding: 80px 0 40px;}
.sec-training .inner { display: flex; flex-flow: column; align-items: flex-start; }
.sec-training .title { margin-bottom: 30px; }
.sec-training .title .en {}
.sec-training .title .ja {}
.sec-training .txt { margin: 0 15px; font-size: 16px; font-weight: 600; line-height: 1.56;}
.sec-training .cnt { margin-top: 30px; padding: 0 15px 40px; }
.sec-training .cnt ul { display: flex; flex-flow: column; gap: 18px; margin-bottom: 30px; }
.sec-training .cnt li {  }
.sec-training .cnt ul a { width: 100%; height: auto; padding: 18px 18px 28px; }
.sec-training .cnt .img { margin-bottom: 15px; }
.sec-training .cnt .ico { width: 90px; height: 27px; font-size: 12px; }
.sec-training .cnt .txt { margin: 0; font-size: 16px; }
.sec-training .cnt .btn { position: absolute; bottom: 0; right: 20px; }
*/
  .sec-training .wrap {
    width: 100%;
    padding: 20.51282vw 0 10.25641vw;
  }
  .sec-training .inner {
    display: flex;
    flex-flow: column;
    align-items: flex-start;
  }
  .sec-training .title {
    margin-bottom: 7.69231vw;
  }
  .sec-training .txt {
    margin: 0 3.84615vw;
    font-size: 4.10256vw;
    font-weight: 600;
    line-height: 1.56;
  }
  .sec-training .cnt {
    margin-top: 7.69231vw;
    padding: 0 3.84615vw 10.25641vw;
  }
  .sec-training .cnt ul {
    display: flex;
    flex-flow: column;
    gap: 4.61538vw;
    margin-bottom: 7.69231vw;
  }
  .sec-training .cnt ul a {
    width: 100%;
    height: auto;
    padding: 4.61538vw 4.61538vw 9.74359vw;
  }
  .sec-training .cnt .img {
    margin-bottom: 3.84615vw;
  }
  .sec-training .cnt .img img {
    width: 83.07692vw;
  }
  .sec-training .cnt .ico {
    width: 23.07692vw;
    height: 6.92308vw;
    font-size: 3.07692vw;
  }
  .sec-training .cnt .txt {
    margin: 0;
    font-size: 4.10256vw;
  }
  .sec-training .cnt .btn {
    position: absolute;
    bottom: 0;
    right: 5.12821vw;
  }
  .sec-training .cnt li .arw {
    position: absolute;
    bottom: 10.25641vw;
    right: 5.12821vw;
  }
}

/* company */
/*.sec-company {}
.sec-company .wrap { position: relative; width: 1280px; margin: 0 auto; padding: 150px 0 300px; }
.sec-company .img01 { position: absolute; top: 430px; left: 0; z-index: 2; }
.sec-company .img02 { position: absolute; top: 160px; left: 190px; z-index: 1; }
.sec-company .inner { margin-left: 700px; }
.sec-company .title {}
.sec-company .title .en {}
.sec-company .title .ja {}
.sec-company .menu { margin-top: 25px; }
.sec-company .menu li { position: relative; border-bottom: 1px solid #000; }
.sec-company .menu li a { display: block; width: 580px; padding: 25px 0 20px; }
.sec-company .menu li a:hover { transition: .5s; }
.sec-company .menu .en { font-family: "Crimson Text", serif; font-weight: 400; font-style: normal; font-size: 48px; }
.sec-company .menu .ja { font-size: 16px; font-weight: 600;}
.sec-company .menu i { position: absolute; right: 0; }
*/
.sec-company .wrap {
  position: relative;
  width: 88.88889vw;
  margin: 0 auto;
  padding: 10.41667vw 0 20.83333vw;
}

.sec-company .img01 {
  position: absolute;
  top: 29.86111vw;
  left: 0;
  z-index: 2;
}

.sec-company .img02 {
  position: absolute;
  top: 11.11111vw;
  left: 13.19444vw;
  z-index: 1;
}

.sec-company .img01 img {
  width: 25.41667vw;
}

.sec-company .img02 img {
  width: 31.875vw;
}

.sec-company .inner {
  margin-left: 48.61111vw;
}

.sec-company .menu {
  margin-top: 1.73611vw;
}

.sec-company .menu li {
  position: relative;
  border-bottom: 1px solid #000;
}

.sec-company .menu li a {
  display: block;
  width: 40.27778vw;
  padding: 1.73611vw 0 1.38889vw;
}

.sec-company .menu li a:hover {
  transition: .5s;
}

.sec-company .menu .en {
  font-family: "Crimson Text", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 3.33333vw;
}

.sec-company .menu .ja {
  font-size: 1.11111vw;
  font-weight: 600;
}

.sec-company .menu i {
  position: absolute;
  right: 0;
}

@media print, screen and (max-width: 768px) {
  /*.sec-company {}
.sec-company .wrap { overflow: hidden; width: 100%; padding: 80px 0; }
.sec-company .img02 { top: 35px; left: inherit; right: -55px; z-index: 1; }
.sec-company .img01 { top: 270px; left: -175px; z-index: 1; }
.sec-company .img01 img,
.sec-company .img02 img { width: 200px; }
.sec-company .inner { position: relative; z-index: 2; margin-left: 0; }
.sec-company .title {}
.sec-company .title .en {}
.sec-company .title .ja {}
.sec-company .menu { width: 245px; margin: 55px 0 0 55px; }
.sec-company .menu li { }
.sec-company .menu li a { width: 100%; padding: 12px 0; }
.sec-company .menu .en { font-size: 28px; }
.sec-company .menu .ja { font-size: 11px; }
.sec-company .menu i { position: absolute; right: 0; }
*/
  .sec-company .wrap {
    overflow: hidden;
    width: 100%;
    padding: 20.51282vw 0;
  }
  .sec-company .img02 {
    top: 8.97436vw;
    left: inherit;
    right: -14.10256vw;
    z-index: 1;
  }
  .sec-company .img01 {
    top: 69.23077vw;
    left: -44.87179vw;
    z-index: 1;
  }
  .sec-company .img01 img,
  .sec-company .img02 img {
    width: 51.28205vw;
  }
  .sec-company .inner {
    position: relative;
    z-index: 2;
    margin-left: 0;
  }
  .sec-company .menu {
    width: 62.82051vw;
    margin: 14.10256vw 0 0 14.10256vw;
  }
  .sec-company .menu li a {
    width: 100%;
    padding: 3.07692vw 0;
  }
  .sec-company .menu .en {
    font-size: 7.17949vw;
  }
  .sec-company .menu .ja {
    font-size: 2.82051vw;
  }
  .sec-company .menu i {
    position: absolute;
    right: 0;
  }
}

/* contact */
/*.sec-contact { position: relative; }
.sec-contact .wrap { width: 1300px; height: 485px; margin: 0 auto; padding: 60px; background: $c-blue url(../img/contact_img.png) no-repeat top right; color: #fff; }
.sec-contact h2 { margin-bottom: 30px; }
.sec-contact .title .en { background-image: linear-gradient(92deg, #fff 1%, #d9d9d9 101%) !important; }
.sec-contact .title .ja {  }
.sec-contact p { margin-bottom: 30px; font-size: 18px; font-weight: 400; line-height: 1.5; color: #fff; }
.sec-contact .btn a { width: 274px; height: 45px; padding-bottom: 0; display: flex; justify-content: center; align-items: center; border-bottom: none; border-radius: 2px; background-color: #fff; }
*/
.sec-contact {
  position: relative;
}

.sec-contact .wrap {
  width: 90.27778vw;
  height: 33.68056vw;
  margin: 0 auto;
  padding: 4.16667vw;
  background: #003366 url(../img/contact_img.png) no-repeat top right;
  background-size: 44.65278vw;
  color: #fff;
}

.sec-contact h2 {
  margin-bottom: 2.08333vw;
}

.sec-contact .title .en {
  background-image: linear-gradient(92deg, #fff 1%, #d9d9d9 101%) !important;
}

.sec-contact p {
  margin-bottom: 2.08333vw;
  font-size: 1.25vw;
  font-weight: 400;
  line-height: 1.5;
  color: #fff;
}

.sec-contact .btn a {
  width: 19.02778vw;
  height: 3.125vw;
  padding-bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  border-bottom: none;
  border-radius: 0.13889vw;
  background-color: #fff;
}

@media print, screen and (max-width: 768px) {
  /*.sec-contact { }
.sec-contact .wrap { width: 100%; height: auto; padding: 80px 15px; background: $c-blue; }
.sec-contact h2 { margin-bottom: 30px; }
.sec-contact p { margin-bottom: 40px; font-size: 14px; line-height: 1.79; }
.sec-contact .btn a { width: 293px; height: 43px; border-radius: 2px; }
*/
  .sec-contact .wrap {
    width: 100%;
    height: auto;
    padding: 20.51282vw 3.84615vw;
    background: #003366;
  }
  .sec-contact h2 {
    margin-bottom: 7.69231vw;
  }
  .sec-contact p {
    margin-bottom: 10.25641vw;
    font-size: 3.58974vw;
    line-height: 1.79;
  }
  .sec-contact .btn a {
    width: 75.12821vw;
    height: 11.02564vw;
    border-radius: 0.51282vw;
  }
}

/* sec-visual */
/*.sec-visual { position: relative; }
.sec-visual .wrap { display: flex; justify-content: space-between; width: 1160px; margin: 140px auto; }
.company .sec-visual .txt { order: 2; }
.company .sec-visual .img { order: 1; }
.sec-visual .img img { width: 570px; }
.sec-visual .subttl { margin-top: 40px; padding-bottom: 20px; font-size: 36px; font-weight: bold; text-align: left; border-bottom: 1px solid $c-blue; }
*/
.sec-visual {
  position: relative;
}

.sec-visual .wrap {
  display: flex;
  gap: 5.55556vw;
  width: 80.55556vw;
  margin: 0 auto;
  padding: 9.72222vw 0;
}

.contact .sec-visual .wrap,
.program .sec-visual .wrap {
  justify-content: space-between;
}

.company .sec-visual .txt,
.service .sec-visual .txt {
  order: 2;
}

.company .sec-visual .img,
.service .sec-visual .img {
  order: 1;
}

.sec-visual .img img {
  width: 39.58333vw;
}

.sec-visual .subttl {
  margin-top: 2.77778vw;
  padding-bottom: 1.38889vw;
  font-size: 2.5vw;
  font-weight: bold;
  text-align: left;
  border-bottom: 1px solid #003366;
}

@media print, screen and (max-width: 768px) {
  /*.sec-visual { }
.sec-visual .wrap { display: flex; flex-flow: column; width: 100%; margin: 0 auto; }
.sec-visual .txt {  }
.sec-visual .img { padding: 20px }
.sec-visual .img img { width: 100%; }
.sec-visual .subttl { margin: 20px 15px 0; padding-bottom: 10px; font-size: 18px; }
*/
  .contact .sec-visual,
  .service .sec-visual {
    margin-top: 3.84615vw;
  }
  .sec-visual .wrap {
    display: flex;
    flex-flow: column;
    gap: 0;
    width: 100%;
    margin: 0 auto;
    padding: 0;
  }
  .sec-visual .img {
    padding: 5.12821vw;
  }
  .sec-visual .img img {
    width: 100%;
  }
  .sec-visual .subttl {
    margin: 5.12821vw 3.84615vw 0;
    padding-bottom: 2.5641vw;
    font-size: 4.61538vw;
  }
  .program .sec-visual .txt,
  .contact .sec-visual .txt {
    order: 2;
  }
  .program .sec-visual .img,
  .contact .sec-visual .img {
    order: 1;
  }
}

/* breadcrumb */
/*.breadcrumb { margin-bottom: 20px;}
.breadcrumb .route { display: flex; text-align: left; }
.breadcrumb .route div { margin-right: 8px; font-size: 14px; color: $c-blue; }
.breadcrumb .route i { margin-left: 8px; content: ""; font-size: 12px; }
.breadcrumb a { color: $c-blue; }
.breadcrumb a:hover { text-decoration: underline; }
*/
.breadcrumb {
  margin-bottom: 1.38889vw;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.breadcrumb .route {
  display: flex;
  text-align: left;
}

.breadcrumb .route div {
  margin-right: 0.55556vw;
  font-size: 0.97222vw;
  color: #003366;
}

.breadcrumb .route i {
  margin-left: 0.55556vw;
  content: "";
  font-size: 0.83333vw;
}

.breadcrumb a {
  color: #003366;
}

.breadcrumb a:hover {
  text-decoration: underline;
}

.white .breadcrumb .route div {
  color: #fff;
}

.white .breadcrumb a {
  color: #fff;
}

@media print, screen and (max-width: 768px) {
  /*.breadcrumb { margin: 20px;}
.breadcrumb .route { }
.breadcrumb .route div { margin-right: 7px; font-size: 13px; }
.breadcrumb .route i { margin-left: 7px; font-size: 11px; }
*/
  .breadcrumb {
    margin: 5.12821vw;
  }
  .breadcrumb .route div {
    margin-right: 1.79487vw;
    font-size: 3.33333vw;
  }
  .breadcrumb .route i {
    margin-left: 1.79487vw;
    font-size: 2.82051vw;
  }
}

/* sec-content */
/*.sec-content { position: relative; }
.sec-content .wrap { width: 1180px; margin: 140px auto; }
.bg01 { background-color: #f3f9ff; }
.sec-content.bg01 .wrap { padding: 80px 0; }
*/
.sec-content {
  position: relative;
}

.sec-content .wrap {
  width: 81.94444vw;
  margin: 9.72222vw auto;
}

@media print, screen and (max-width: 768px) {
  /*.sec-content { }
.sec-content .wrap { width: 100%; margin: 70px auto; }
.sec-content.bg01 .wrap { padding: 40px 0; }
*/
  .sec-content .wrap {
    width: 100%;
    margin: 17.94872vw auto;
  }
}

.company-bg01 {
  background: url(../img/company_bg01.png) no-repeat top center;
  background-size: contain;
}

.company-bg02 {
  background: url(../img/company_bg02.png) no-repeat top center;
  background-size: contain;
}

/*
.company-tbl { width: 1020px; margin: 60px auto; font-family: "Noto Sans JP", sans-serif; font-weight: 500; }
.company-tbl table { width: 100%; }
.company-tbl th { width: 260px; padding: 40px 0; font-weight: bold; font-size: 20px;line-height: 1.14; color: $c-blue; text-align: center; border-bottom: 1px solid $c-blue; }
.company-tbl tr:first-child th { border-top: 1px solid $c-blue; }
.company-tbl td { padding-left: 40px; font-size: 20px; line-height: 1.25; text-align: left; color: #000; }
*/
.company-tbl {
  width: 70.83333vw;
  margin: 4.16667vw auto;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}

.company-tbl table {
  width: 100%;
}

.company-tbl th {
  width: 18.05556vw;
  padding: 2.77778vw 0;
  font-weight: bold;
  font-size: 1.38889vw;
  line-height: 1.14;
  color: #003366;
  text-align: center;
  border-bottom: 1px solid #003366;
}

.company-tbl tr:first-child th {
  border-top: 1px solid #003366;
}

.company-tbl td {
  padding-left: 2.77778vw;
  font-size: 1.38889vw;
  line-height: 1.25;
  text-align: left;
  color: #000;
}

@media print, screen and (max-width: 768px) {
  /*.company-tbl { width: 100%; margin: 0 auto; padding: 0 35px; }
.company-tbl table {  }
.company-tbl th { display: block; width: 100%; padding: 10px 0; font-size: 16px; line-height: 1.25; border-top: 1px solid $c-blue; }
.company-tbl tr:first-child th {  }
.company-tbl td { display: block; padding: 25px 0 45px; font-size: 16px; line-height: 1.25; }
*/
  .company-tbl {
    width: 100%;
    margin: 0 auto;
    padding: 0 8.97436vw;
  }
  .company-tbl th {
    display: block;
    width: 100%;
    padding: 2.5641vw 0;
    font-size: 4.10256vw;
    line-height: 1.25;
    border-top: 1px solid #003366;
  }
  .company-tbl td {
    display: block;
    padding: 6.41026vw 0 11.53846vw;
    font-size: 4.10256vw;
    line-height: 1.25;
  }
}

/*
.company-profile {}
.company-profile strong { display: block; margin: 120px auto; line-height: 1.79; text-align: center; font-size: 28px; font-weight: bold; color: $c-blue; }
.company-profile .box { display: flex; justify-content: space-between; gap: 80px; }
.company-profile .img { order: 2; width: 417px; }
.company-profile .img img { width: 417px; }
.company-profile .cnt { order: 1; text-align: left; }
.company-profile .ttl { margin-bottom: 60px; text-align: left; font-size: 20px; font-weight: bold; }
.company-profile .ttl .en { display: inline-block; font-size: 32px; font-weight: 600; color: $c-blue; }
.company-profile .ttl .ja { display: inline-block; margin: 5px 0 15px; font-size: 64px; }
.company-profile .txt { width: 690px; font-size: 18px; font-weight: bold;  line-height: 2.78; text-align: left; }
.company-profile hr { display: block; width: 270px; height: 2px; margin: 120px auto; background-color: $c-blue; }
.company-profile .box.ph02 { gap: 90px; }
.company-profile .ph02 .img { order: 1; }
.company-profile .ph02 .cnt { order: 2; }
*/
.company-profile strong {
  display: block;
  margin: 8.33333vw auto;
  line-height: 1.79;
  text-align: center;
  font-size: 1.94444vw;
  font-weight: bold;
  color: #003366;
}

.company-profile .box {
  display: flex;
  justify-content: space-between;
  gap: 5.55556vw;
}

.company-profile .img {
  order: 2;
  width: 28.95833vw;
}

.company-profile .img img {
  width: 28.95833vw;
}

.company-profile .cnt {
  order: 1;
  text-align: left;
}

.company-profile .ttl {
  margin-bottom: 4.16667vw;
  text-align: left;
  font-size: 1.38889vw;
  font-weight: bold;
}

.company-profile .ttl .en {
  display: inline-block;
  font-size: 2.22222vw;
  font-weight: 600;
  color: #003366;
}

.company-profile .ttl .ja {
  display: inline-block;
  margin: 0.34722vw 0 1.04167vw;
  font-size: 4.44444vw;
}

.company-profile .txt {
  width: 47.91667vw;
  font-size: 1.25vw;
  font-weight: bold;
  line-height: 2.78;
  text-align: left;
}

.company-profile hr {
  display: block;
  width: 18.75vw;
  height: 2px;
  margin: 8.33333vw auto;
  background-color: #003366;
}

.company-profile .box.ph02 {
  gap: 6.25vw;
}

.company-profile .ph02 .img {
  order: 1;
}

.company-profile .ph02 .cnt {
  order: 2;
}

@media print, screen and (max-width: 768px) {
  /*.company-profile {}
.company-profile strong { margin: 60px auto; line-height: 1.79; font-size: 22px; }
.company-profile .box { display: flex; flex-flow: column; gap: 30px; }
.company-profile .img { order: 1; width: 100%; padding: 0 55px; }
.company-profile .img img { width: 100%; }
.company-profile .cnt { order: 2; padding: 0 35px; }
.company-profile .ttl { margin-bottom: 30px; font-size: 18px; }
.company-profile .ttl .en { font-size: 24px; }
.company-profile .ttl .ja { margin: 5px 0 15px; font-size: 44px; }
.company-profile .txt { width: 100%; font-size: 16px; line-height: 1.98; }
.company-profile hr { width: 220px; height: 1px; margin: 60px auto; }
.company-profile .box.ph02 { gap: 30px; }
.company-profile .ph02 .img { order: 1; }
.company-profile .ph02 .cnt { order: 2; }
*/
  .company-profile strong {
    margin: 15.38462vw auto;
    line-height: 1.79;
    font-size: 5.64103vw;
  }
  .company-profile .box {
    display: flex;
    flex-flow: column;
    gap: 7.69231vw;
  }
  .company-profile .img {
    order: 1;
    width: 100%;
    padding: 0 14.10256vw;
  }
  .company-profile .img img {
    width: 100%;
  }
  .company-profile .cnt {
    order: 2;
    padding: 0 8.97436vw;
  }
  .company-profile .ttl {
    margin-bottom: 7.69231vw;
    font-size: 4.61538vw;
  }
  .company-profile .ttl .en {
    font-size: 6.15385vw;
  }
  .company-profile .ttl .ja {
    margin: 1.28205vw 0 3.84615vw;
    font-size: 11.28205vw;
  }
  .company-profile .txt {
    width: 100%;
    font-size: 4.10256vw;
    line-height: 1.98;
  }
  .company-profile hr {
    width: 56.41026vw;
    height: 1px;
    margin: 15.38462vw auto;
  }
  .company-profile .box.ph02 {
    gap: 7.69231vw;
  }
}

.bg01 {
  background-color: #f3f9ff;
}

.sec-content.bg01 .wrap {
  padding: 5.55556vw 0;
}

@media print, screen and (max-width: 768px) {
  .sec-content.bg01 .wrap {
    padding: 10.25641vw 0;
  }
}

/* mission-box */
/*.mission-box { padding: 80px 0; background: url(../img/program_bg.png) no-repeat center center; }
.mission-box .inner { position: relative; width: 1180px; margin: 0 auto; padding: 80px 60px; background-color: #fff; }
.mission-box .en { position: absolute; top: -35px; left: 45px; font-size: 50px; background: linear-gradient(to right, #036, #0069d2 48%, #fff);
-webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;}
.mission-box .ttl { font-size: 28px; font-weight: bold; line-height: 1.79; color: $c-blue; text-align: center; font-family: "Noto Sans JP", sans-serif; font-weight: 700; }
.mission-box .txt { margin-top: 40px; font-size: 20px; line-height: 1.6; text-align: left; font-family: "Noto Sans JP", sans-serif; font-weight: 500; }
.mission-box .inner:after { position: absolute; top: -75px; right: 50px; display: block; content: ""; background: url(../img/service_img03.png) no-repeat; background-size: cover; width: 179.2px; height: 124px; }
*/
.mission-box {
  padding: 5.55556vw 0;
  background: url(../img/program_bg.png) no-repeat center center;
  background-size: cover;
}

.mission-box .inner {
  position: relative;
  width: 81.94444vw;
  margin: 0 auto;
  padding: 5.55556vw 4.16667vw;
  background-color: #fff;
}

.mission-box .en {
  position: absolute;
  top: -2.43056vw;
  left: 3.125vw;
  font-size: 3.47222vw;
  background: linear-gradient(to right, #036, #0069d2 48%, #fff);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.mission-box .ttl {
  font-size: 1.94444vw;
  font-weight: bold;
  line-height: 1.79;
  color: #003366;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
}

.mission-box .txt {
  margin-top: 2.77778vw;
  font-size: 1.38889vw;
  line-height: 1.6;
  text-align: left;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}

.mission-box .inner:after {
  position: absolute;
  top: -5.20833vw;
  right: 3.47222vw;
  display: block;
  content: "";
  background: url(../img/service_img03.png) no-repeat;
  background-size: cover;
  width: 12.44444vw;
  height: 8.61111vw;
}

@media print, screen and (max-width: 768px) {
  /*.mission-box { padding: 30px 0; background: url(../img/program_bg.png) no-repeat top center;  }
.mission-box .inner { width: 100%; padding: 35px 25px 25px; }
.mission-box .en { top: -30px; left: 15px; font-size: 40px; }
.mission-box .ttl { font-size: 22px; line-height: 1.49; text-align: left; }
.mission-box .txt { margin-top: 15px; font-size: 16px; line-height: 1.5; }
.mission-box .inner:after { display: none; }
*/
  .mission-box {
    padding: 7.69231vw 0;
    background: url(../img/program_bg.png) no-repeat top center;
  }
  .mission-box .inner {
    width: 100%;
    padding: 8.97436vw 6.41026vw 6.41026vw;
  }
  .mission-box .en {
    top: -7.69231vw;
    left: 3.84615vw;
    font-size: 10.25641vw;
  }
  .mission-box .ttl {
    font-size: 5.64103vw;
    line-height: 1.49;
    text-align: left;
  }
  .mission-box .txt {
    margin-top: 3.84615vw;
    font-size: 4.10256vw;
    line-height: 1.5;
  }
  .mission-box .inner:after {
    display: none;
  }
}

/* gaiyo-box */
/*.gaiyo-box { width: 1080px; margin: 80px auto; }
.gaiyo-box .inner { display: flex; gap: 50px; }
.gaiyo-box .ttl { width: 240px; height: 140px; display: flex; flex-direction: row; justify-content: center; align-items: center; background-color: #036; font-size: 18px; font-weight: bold; line-height: 2.78; font-family: "Noto Sans JP", sans-serif; font-weight: 700; color: #fff;}
.gaiyo-box .txt { font-family: "Noto Sans JP", sans-serif; font-weight: 500; }
.gaiyo-box table { width: 100%;  }
.gaiyo-box th { width: 140px; font-size: 20px; line-height: 2.25; }
.gaiyo-box td { padding: 0 30px; font-size: 20px; line-height: 2.25;}
*/
.gaiyo-box {
  width: 75vw;
  margin: 5.55556vw auto;
}

.gaiyo-box .inner {
  display: flex;
  gap: 3.47222vw;
}

.gaiyo-box .ttl {
  width: 16.66667vw;
  height: 9.72222vw;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  background-color: #036;
  font-size: 1.25vw;
  font-weight: bold;
  line-height: 2.78;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  color: #fff;
}

.gaiyo-box .txt {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}

.gaiyo-box table {
  width: 100%;
}

.gaiyo-box th {
  width: 9.72222vw;
  font-size: 1.38889vw;
  line-height: 2.25;
}

.gaiyo-box td {
  padding: 0 2.08333vw;
  font-size: 1.38889vw;
  line-height: 2.25;
}

@media print, screen and (max-width: 768px) {
  /*.gaiyo-box { width: 100%; margin: 0 auto; padding: 30px; }
.gaiyo-box .inner { display: flex; flex-flow: column; gap: 15px; }
.gaiyo-box .ttl { width: 330px; height: 70px; font-size: 16px; }
.gaiyo-box .txt { }
.gaiyo-box table { width: 100%; }
.gaiyo-box th { width: auto; font-size: 16px; line-height: 1.75; }
.gaiyo-box td { padding: 0; font-size: 16px; line-height: 1.75;}
*/
  .gaiyo-box {
    width: 100%;
    margin: 0 auto;
    padding: 7.69231vw;
  }
  .gaiyo-box .inner {
    display: flex;
    flex-flow: column;
    gap: 3.84615vw;
  }
  .gaiyo-box .ttl {
    width: 84.61538vw;
    height: 17.94872vw;
    font-size: 4.10256vw;
  }
  .gaiyo-box table {
    width: 100%;
  }
  .gaiyo-box th {
    width: auto;
    font-size: 4.10256vw;
    line-height: 1.75;
  }
  .gaiyo-box td {
    padding: 0;
    font-size: 4.10256vw;
    line-height: 1.75;
  }
}

/* gallery-box */
/*.gallery-box { width: 1180px; margin: 0 auto; }
.gallery-box .inner { position: relative; padding: 60px; background-color: #f3f9ff; }
.gallery-box .en { position: absolute; top: -35px; left: 45px; font-size: 50px; background: linear-gradient(to right, #036, #0069d2 48%, #fff);
-webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;}
.gallery-box ul { display: flex; justify-content: space-between; }
.gallery-box li { width: 320px; }
.gallery-box img {}
.gallery-box p { margin-top: 25px; font-family: "Noto Sans JP", sans-serif; font-weight: 400; font-size: 16px; line-height: 1.56; text-align: left;}
*/
.gallery-box {
  width: 81.94444vw;
  margin: 0 auto;
}

.gallery-box .inner {
  position: relative;
  padding: 4.16667vw;
  background-color: #f3f9ff;
}

.gallery-box .en {
  position: absolute;
  top: -2.43056vw;
  left: 3.125vw;
  font-size: 3.47222vw;
  background: linear-gradient(to right, #036, #0069d2 48%, #fff);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.gallery-box ul {
  display: flex;
  justify-content: space-between;
}

.gallery-box li {
  width: 22.22222vw;
}

.gallery-box li img {
  width: 22.22222vw;
}

.gallery-box p {
  margin-top: 1.73611vw;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 1.11111vw;
  line-height: 1.56;
  text-align: left;
}

@media print, screen and (max-width: 768px) {
  /*.gallery-box { width: 100%; padding: 30px; }
.gallery-box .inner { padding: 25px; }
.gallery-box .en { top: -30px; left: 0; font-size: 40px; }
.gallery-box ul { display: flex; flex-flow: column; }
.gallery-box li { width: 280px; }
.gallery-box li + li { margin-top: 35px; }
.gallery-box img {}
.gallery-box p { margin-top: 15px; font-size: 14px; line-height: 1.36; }
*/
  .gallery-box {
    width: 100%;
    padding: 7.69231vw;
  }
  .gallery-box .inner {
    padding: 6.41026vw;
  }
  .gallery-box .en {
    top: -7.69231vw;
    left: 0;
    font-size: 10.25641vw;
  }
  .gallery-box ul {
    display: flex;
    flex-flow: column;
  }
  .gallery-box li {
    width: 71.79487vw;
  }
  .gallery-box li img {
    width: 71.79487vw;
  }
  .gallery-box li + li {
    margin-top: 8.97436vw;
  }
  .gallery-box p {
    margin-top: 3.84615vw;
    font-size: 3.58974vw;
    line-height: 1.36;
  }
}

/* prog-ttl */
/*.prog-ttl { margin: 80px 0; font-size: 28px; font-weight: bold; line-height: 1.79; text-align: center; }
*/
.prog-ttl {
  margin: 5.55556vw 0;
  font-size: 1.94444vw;
  font-weight: bold;
  line-height: 1.79;
  text-align: center;
}

@media print, screen and (max-width: 768px) {
  /*.prog-ttl { margin: 40px 15px; font-size: 22px; line-height: 1.49; text-align: left; }
*/
  .prog-ttl {
    margin: 10.25641vw 3.84615vw;
    font-size: 5.64103vw;
    line-height: 1.49;
    text-align: left;
  }
}

/* prog-box */
/*.prog-box + .prog-box { margin-top: 30px; }
.prog-box {  }
.prog-box .inner { display: flex; gap: 35px; padding: 30px 0 30px 35px; border: solid 1px $c-blue; background-color: #fff; font-family: "Noto Sans JP", sans-serif; font-weight: 500; }
.prog-box.v2 .inner { border: none; box-shadow: 0 0 15px 0 rgba(0, 51, 102, 0.1); }
.prog-box .cont {  }
.prog-box .tema { margin: 0 0 30px; }
.prog-box .tag { width: 100px; height: 30px; display: flex; justify-content: center; align-items: center; background-color: #036; font-size: 14px; font-weight: 500; color: #fff; }
.prog-box .tema .tag { margin-bottom: 25px; }
.prog-box .tema .ttl { font-size: 30px; font-weight: bold; color: #036; }
.prog-box .cnt { overflow: hidden; position: relative; width: 920px; padding: 25px 30px; background-color: #f7f7f7;}
.prog-box .cnt .tag { position: absolute; top:0; left: 0; }
.prog-box .cnt .txt { font-size: 18px; line-height: 1.39; text-align: left; }
.prog-box .cnt p { padding-top: 20px; }
.prog-box .cnt img { float: right; margin: 0 0 0 25px; }
.prog-box .data { display: flex; flex-flow: column; justify-content: center; align-items: center; gap: 20px; width: 100%; border-left: 1px solid #ababab; text-align: center; }
.prog-box .data .tag { }
.prog-box .data .time { font-size: 32px; font-weight: bold; line-height: 0.78; color: #036; }
*/
.prog-box + .prog-box {
  margin-top: 2.08333vw;
}

.prog-box .inner {
  display: flex;
  gap: 2.43056vw;
  padding: 2.08333vw 0 2.08333vw 2.43056vw;
  border: solid 1px #003366;
  background-color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}

.prog-box.v2 .inner {
  border: none;
  box-shadow: 0 0 1.04167vw 0 rgba(0, 51, 102, 0.1);
}

.prog-box .tema {
  margin: 0 0 2.08333vw;
}

.prog-box .tag {
  width: 6.94444vw;
  height: 2.08333vw;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #036;
  font-size: 0.97222vw;
  font-weight: 500;
  color: #fff;
}

.prog-box .tema .tag {
  margin-bottom: 1.73611vw;
}

.prog-box .tema .ttl {
  font-size: 2.08333vw;
  font-weight: bold;
  color: #036;
}

.prog-box .cnt {
  overflow: hidden;
  position: relative;
  width: 63.88889vw;
  padding: 1.73611vw 2.08333vw;
  background-color: #f7f7f7;
}

.prog-box .cnt .tag {
  position: absolute;
  top: 0;
  left: 0;
}

.prog-box .cnt p {
  padding-top: 1.38889vw;
  font-size: 1.25vw;
  line-height: 1.39;
  text-align: left;
}

.prog-box .cnt img {
  float: right;
  margin: 0 0 0 1.73611vw;
}

.prog-box .data {
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  gap: 1.38889vw;
  width: 100%;
  border-left: 1px solid #ababab;
  text-align: center;
}

.prog-box .data .time {
  font-size: 2.22222vw;
  font-weight: bold;
  line-height: 0.78;
  color: #036;
}

@media print, screen and (max-width: 768px) {
  /*.prog-box + .prog-box { margin-top: 15px; }
.prog-box { padding: 0 15px; }
.prog-box .inner { display: flex; flex-flow: column; gap: 15px; padding: 15px; }
.prog-box.v2 .inner { }
.prog-box .cont {  }
.prog-box .tema { margin: 0 0 15px; }
.prog-box .tag { width: 80px; height: 25px; font-size: 12px; }
.prog-box .tema .tag { margin-bottom: 15px; }
.prog-box .tema .ttl { font-size: 20px; }
.prog-box .cnt { width: 100%; padding: 45px 25px 25px; background-color: #f7f7f7;}
.prog-box .cnt .tag { }
.prog-box .cnt .txt { font-size: 14px; line-height: 1.29; text-align: left; }
.prog-box .cnt p { padding-top: 20px; }
.prog-box .cnt img { float: none; width: 100%; margin: 0; }
.prog-box .data { display: block; width: 100%; border-left: none; text-align: left; }
.prog-box .data .tag { margin-bottom: 15px; }
.prog-box .data .time { font-size: 20px; }
*/
  .prog-box + .prog-box {
    margin-top: 3.84615vw;
  }
  .prog-box {
    padding: 0 3.84615vw;
  }
  .prog-box .inner {
    display: flex;
    flex-flow: column;
    gap: 3.84615vw;
    padding: 3.84615vw;
  }
  .prog-box .tema {
    margin: 0 0 3.84615vw;
  }
  .prog-box .tag {
    width: 20.51282vw;
    height: 6.41026vw;
    font-size: 3.07692vw;
  }
  .prog-box .tema .tag {
    margin-bottom: 3.84615vw;
  }
  .prog-box .tema .ttl {
    font-size: 5.12821vw;
  }
  .prog-box .cnt {
    width: 100%;
    padding: 11.53846vw 6.41026vw 6.41026vw;
    background-color: #f7f7f7;
  }
  .prog-box .cnt p {
    padding-top: 5.12821vw;
    font-size: 3.58974vw;
    line-height: 1.29;
    text-align: left;
  }
  .prog-box .cnt img {
    float: none;
    width: 100%;
    margin: 0;
  }
  .prog-box .data {
    display: block;
    width: 100%;
    border-left: none;
    text-align: left;
  }
  .prog-box .data .tag {
    margin-bottom: 3.84615vw;
  }
  .prog-box .data .time {
    font-size: 5.12821vw;
  }
}

/*.service_bg { padding-bottom: 100px; background-color: #f3f9ff; }
.service .sec-visual .wrap { padding: 100px 0 100px; }
.service .sec-content .wrap { margin: 0 auto; padding: 0; }
.service .sec-contact { margin-top: 100px; }
*/
.service_bg {
  padding-bottom: 6.94444vw;
  background-color: #f3f9ff;
}

.service .sec-visual .wrap {
  padding: 6.94444vw 0 6.94444vw;
}

.service .sec-content .wrap {
  margin: 0 auto;
  padding: 0;
}

.service .sec-contact {
  margin-top: 6.94444vw;
}

@media print, screen and (max-width: 768px) {
  .service_bg {
    padding-bottom: 12.82051vw;
  }
  .service .sec-visual .wrap {
    padding: 0 0 10.25641vw;
  }
  .service .sec-content .wrap {
    padding: 0;
  }
  .service .sec-contact {
    margin-top: 12.82051vw;
  }
}

.service .sec-content h1 {
  margin-bottom: 4.16667vw;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 2.5vw;
  font-weight: bold;
  text-align: left;
  color: #036;
}

@media print, screen and (max-width: 768px) {
  .service .sec-content h1 {
    margin: 0 3.84615vw 7.69231vw;
    font-size: 5.64103vw;
  }
}

/* editor */
.editor {
  padding: 0 4.16667vw 8.33333vw;
  background-color: #fff;
}

@media print, screen and (max-width: 768px) {
  .editor {
    padding: 0 3.84615vw 15.38462vw;
  }
}

.editor .lead01 {
  overflow: hidden;
  padding: 6.25vw 0;
  font-size: 2.5vw;
  font-weight: bold;
  line-height: 1.67;
  text-align: left;
  color: #036;
}

@media print, screen and (max-width: 768px) {
  .editor .lead01 {
    padding: 10.25641vw 0;
    font-size: 4.61538vw;
    line-height: 1.5;
  }
}

.editor .blue {
  color: #003366;
}

.editor p,
.editor li,
.editor table {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.editor h1,.editor h2 {
  margin-left: -4.16667vw;
  margin-right: -4.16667vw;
  padding: 1.18056vw 2.08333vw;
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  background-color: #036;
  font-size: 1.94444vw;
  color: #fff;
}

.editor p + h1,
.editor p + h2,
.editor ul + h1, .editor ol + h1,
.editor ul + h2, .editor ol + h2,
.editor table + h1, .editor div + h1,
.editor table + h2, .editor div + h2 {
  margin-top: 8.33333vw;
}

@media print, screen and (max-width: 768px) {
  .editor h1,.editor h2 {
    margin-left: -3.84615vw;
    margin-right: -3.84615vw;
    padding: 3.84615vw 3.84615vw;
    font-size: 5.12821vw;
  }
  .editor p + h1,
  .editor p + h2,
  .editor ul + h1, .editor ol + h1,
  .editor ul + h2, .editor ol + h2,
  .editor table + h1, .editor div + h1,
  .editor table + h2, .editor div + h2 {
    margin-top: 15.38462vw;
  }
}

.editor h3 {
  margin: 5.55556vw 0 0;
  padding-bottom: 0.69444vw;
  font-size: 1.66667vw;
  font-weight: bold;
  line-height: 2.08;
  text-align: left;
  border-bottom: 1px solid #003366;
}

.editor h4 {
  margin: 4.16667vw 0 0;
  font-size: 1.52778vw;
  font-weight: bold;
  line-height: 2.27;
  text-align: left;
}

.editor h3 + h4 {
  margin: 2.08333vw 0 0;
}

@media print, screen and (max-width: 768px) {
  .editor h3 {
    margin: 10.25641vw 0 0;
    padding-bottom: 2.5641vw;
    font-size: 5.12821vw;
    line-height: 1.28;
  }
  .editor h4 {
    margin: 7.69231vw 0 0;
    font-size: 4.61538vw;
    line-height: 1.57;
  }
  .editor h3 + h4 {
    margin: 3.84615vw 0 0;
  }
}

.editor p {
  overflow: hidden;
  margin: 4.16667vw 0 0;
  font-weight: 400;
  font-size: 1.38889vw;
  line-height: 1.6;
  text-align: left;
}

.editor h3 + p,
.editor h4 + p,
.editor p + p {
  margin-top: 2.08333vw;
}

@media print, screen and (max-width: 768px) {
  .editor p {
    margin: 7.69231vw 0 0;
    font-size: 4.10256vw;
    font-weight: 500;
    line-height: 1.5;
  }
  .editor h3 + p,
  .editor h4 + p,
  .editor p + p {
    margin-top: 3.84615vw;
  }
}

.editor em {
  font-size: 1.52778vw;
  font-weight: bold;
}

.editor strong {
  font-size: 1.80556vw;
  font-weight: bold;
  color: #c61013;
}

.editor :not(.link) a {
  color: #003366;
  text-decoration: underline;
}

.editor :not(.link) a:hover {
  text-decoration: none;
}

@media print, screen and (max-width: 768px) {
  .editor em {
    font-size: 4.61538vw;
  }
  .editor strong {
    font-size: 5.12821vw;
  }
}

.editor ul,
.editor ol {
  margin: 2.08333vw 0 0;
}

.editor ul li:before {
  position: absolute;
  top: 0.69444vw;
  left: 0;
  content: "■";
  color: #003366;
  font-size: 0.69444vw;
}

.editor ul li {
  position: relative;
  padding-left: 1.38889vw;
  font-weight: 400;
  font-size: 1.38889vw;
  line-height: 1.75;
  text-align: left;
}

.editor ol li {
  position: relative;
  padding-left: 2.43056vw;
  font-weight: 400;
  font-size: 1.38889vw;
  line-height: 1.75;
  text-align: left;
  list-style-type: none;
}

@media print, screen and (max-width: 768px) {
  .editor ul,
  .editor ol {
    margin: 3.84615vw 0 0;
  }
  .editor ul li:before {
    top: 1.28205vw;
    font-size: 2.05128vw;
  }
  .editor ul li {
    padding-left: 3.84615vw;
    font-size: 4.10256vw;
    line-height: 1.55;
  }
  .editor ol li {
    padding-left: 7.69231vw;
    font-size: 4.10256vw;
    line-height: 1.55;
  }
}

.editor ol li:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "(" counter(list-item) ")";
  color: #003366;
  font-weight: bold;
}

.editor table {
  width: 100%;
  margin-top: 6.94444vw;
}

.editor h3 + table,
.editor h4 + table {
  margin-top: 2.08333vw;
}

@media print, screen and (max-width: 768px) {
  .editor table {
    margin-top: 12.82051vw;
  }
  .editor table.sp-tbl {
    margin-top: 5.12821vw;
  }
  .editor h3 + table,
  .editor h4 + table {
    margin-top: 3.84615vw;
  }
}

.editor th {
  padding: 1.38889vw;
  font-size: 1.18056vw;
  font-weight: bold;
  line-height: 2.78;
  border: solid 1px #ababab;
  vertical-align: middle;
  color: #fff;
  background-color: #036;
  text-align: center;
}

.editor td {
  padding: 1.38889vw;
  font-size: 1.18056vw;
  line-height: 1.25;
  border: solid 1px #ababab;
  vertical-align: middle;
}

@media print, screen and (max-width: 768px) {
  .editor th {
    padding: 2.5641vw;
    font-size: 3.84615vw;
    line-height: 1.78;
  }
  .editor td {
    padding: 2.5641vw;
    font-size: 3.84615vw;
    line-height: 1.25;
  }
}

.editor .bg02 {
  background-color: #f3f9ff;
}

.editor .bg03 {
  background-color: #f8f8f8;
}

.editor .box01 {
  margin-top: 4.16667vw;
  padding: 2.77778vw 2.77778vw;
  background-color: #f3f9ff;
}

.editor .box02 {
  margin-top: 4.16667vw;
  padding: 2.77778vw 2.77778vw;
  border: 1px solid #003366;
  background-color: #fff;
}

.editor h3 + .box01, .editor h4 + .box01,
.editor h3 + .box02, .editor h4 + .box02 {
  margin-top: 2.08333vw;
}

@media print, screen and (max-width: 768px) {
  .editor .box01 {
    margin-top: 7.69231vw;
    padding: 5.12821vw 5.12821vw;
  }
  .editor .box02 {
    margin-top: 7.69231vw;
    padding: 5.12821vw 5.12821vw;
  }
  .editor h3 + .box01, .editor h4 + .box01,
  .editor h3 + .box02, .editor h4 + .box02 {
    margin-top: 3.84615vw;
  }
}

.editor .fl {
  float: left;
  margin: 0 2.77778vw 2.77778vw 0;
}

.editor .fr {
  float: right;
  margin: 0 0 2.77778vw 2.77778vw;
}

@media print, screen and (max-width: 768px) {
  .editor .fl {
    float: none;
    width: 100%;
    margin: 0 0 5.12821vw;
  }
  .editor .fr {
    float: none;
    width: 100%;
    margin: 0 0 5.12821vw;
  }
}

.editor .link {
  margin: 6.94444vw auto;
}

.editor .link a {
  width: 48.61111vw;
  height: 9.72222vw;
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 2.77778vw;
  padding: 1.38889vw;
  border: solid 1px #036;
  font-size: 1.52778vw;
  font-weight: bold;
  color: #036;
}

.editor .link img {
  width: 10.41667vw;
}

@media print, screen and (max-width: 768px) {
  .editor .link {
    margin: 12.82051vw auto;
  }
  .editor .link a {
    width: 100%;
    height: 17.94872vw;
    gap: 3.84615vw;
    padding: 2.5641vw;
    font-size: 4.10256vw;
  }
  .editor .link img {
    width: 19.23077vw;
  }
}

.editor .link02 {
  margin: 6.94444vw auto;
}

.editor .link02 a {
  width: 41.66667vw;
  height: 6.94444vw;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2.77778vw;
  padding: 1.38889vw;
  border: solid 1px #036;
  font-size: 1.52778vw;
  font-weight: bold;
  color: #036;
}

@media print, screen and (max-width: 768px) {
  .editor .link02 {
    margin: 12.82051vw auto;
  }
  .editor .link02 a {
    width: 100%;
    height: 17.94872vw;
    gap: 3.84615vw;
    padding: 2.5641vw;
    font-size: 4.10256vw;
  }
}

.editor .link a:hover,
.editor .link02 a:hover {
  background-color: #f3f9ff;
}

.contact-bg01 {
  background: #003366 url(../img/contact_bg.png) no-repeat top center;
}

.contact-bg02 {
  background-color: #f3f9ff;
}

/*
.contact .sec-visual .wrap { padding: 110px 0 80px; }
.contact .sec-content .wrap { margin: 0 auto; padding: 80px 0; }
*/
.contact .sec-visual .wrap {
  padding: 7.63889vw 0 5.55556vw;
}

.contact .sec-content .wrap {
  margin: 0 auto;
  padding: 5.55556vw 0;
}

@media print, screen and (max-width: 768px) {
  .contact .sec-visual .wrap {
    padding: 0 0 10.25641vw;
  }
  .contact .sec-content .wrap {
    padding: 10.25641vw 0;
  }
}

/* chach-box */
/*.chach-box { }
.chach-box .inner { width: 1120px; margin: 0 auto; }
.chach-box .ttl { margin-bottom: 40px; font-size: 36px; font-weight: 500; line-height: 1.53; text-align: center; color: #fff;}
.chach-box .txt { font-size: 20px; font-weight: 400; line-height: 1.5; text-align: left; color: #fff; }
*/
.chach-box .inner {
  width: 77.77778vw;
  margin: 0 auto;
}

.chach-box .ttl {
  margin-bottom: 2.77778vw;
  font-size: 2.5vw;
  font-weight: 500;
  line-height: 1.53;
  text-align: center;
  color: #fff;
}

.chach-box .txt {
  font-size: 1.38889vw;
  font-weight: 400;
  line-height: 1.5;
  text-align: left;
  color: #fff;
}

@media print, screen and (max-width: 768px) {
  /*.chach-box .inner { width: 100%; }
.chach-box .ttl { margin-bottom: 20px; font-size: 22px; line-height: 1.33; }
.chach-box .txt { padding: 0 15px; font-size: 16px; line-height: 1.4; }
*/
  .chach-box .inner {
    width: 100%;
  }
  .chach-box .ttl {
    margin-bottom: 5.12821vw;
    font-size: 5.64103vw;
    line-height: 1.33;
  }
  .chach-box .txt {
    padding: 0 3.84615vw;
    font-size: 4.10256vw;
    line-height: 1.4;
  }
}

/* tel-box */
/*.tel-box { padding: 90px 0; }
.tel-box .inner { display: flex; flex-flow: column; justify-content: center; align-items: center; gap: 20px; width: 1140px; height: 320px; margin: 0 auto; background-color: #fff; text-align: center; color: #036; }
.tel-box .titl { font-size: 32px; font-weight: bold; line-height: 1.56; }
.tel-box .number { font-size: 62px; font-weight: bold; line-height: 0.78; }
.tel-box .number i { font-size: 42px; margin-right: 20px; vertical-align: middle; }
.tel-box .days { font-size: 20px; font-weight: bold; line-height: 2.5; }
*/
.tel-box {
  padding: 6.25vw 0;
}

.tel-box .inner {
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  gap: 1.38889vw;
  width: 79.16667vw;
  height: 22.22222vw;
  margin: 0 auto;
  background-color: #fff;
  text-align: center;
  color: #036;
}

.tel-box .titl {
  font-size: 2.22222vw;
  font-weight: bold;
  line-height: 1.56;
}

.tel-box .number {
  font-size: 4.30556vw;
  font-weight: bold;
  line-height: 0.78;
}

.tel-box .number i {
  font-size: 2.91667vw;
  margin-right: 1.38889vw;
  vertical-align: middle;
}

.tel-box .days {
  font-size: 1.38889vw;
  font-weight: bold;
  line-height: 2.5;
}

@media print, screen and (max-width: 768px) {
  /*.tel-box { padding: 40px 0; }
.tel-box .inner { gap: 10px; width: 360px; height: 150px; margin: 0 auto; }
.tel-box .titl { font-size: 20px; }
.tel-box .number { font-size: 30px; }
.tel-box .number i { font-size: 22px; margin-right: 10px; }
.tel-box .days { font-size: 16px; line-height: 1.2; }
*/
  .tel-box {
    padding: 10.25641vw 0;
  }
  .tel-box .inner {
    gap: 2.5641vw;
    width: 92.30769vw;
    height: 38.46154vw;
    margin: 0 auto;
  }
  .tel-box .titl {
    font-size: 5.12821vw;
  }
  .tel-box .number {
    font-size: 7.69231vw;
  }
  .tel-box .number i {
    font-size: 5.64103vw;
    margin-right: 2.5641vw;
  }
  .tel-box .days {
    font-size: 4.10256vw;
    line-height: 1.2;
  }
}

/* input-box */
/*.input-box { margin-top: 40px; font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; }
.input-box .inner { width: 1140px; margin: 0 auto; }
.input-box table { width: 100%; }
.input-box tr {}
.input-box th { position: relative; padding: 0 60px 30px 0; font-size: 22px; font-weight: bold; line-height: 1.14; text-align: right; vertical-align: bottom; }
.input-box .hisu { display: inline-block; width: 64px; height: 30px; padding-top: 8px; margin-left: 15px; text-align: center; font-size: 14px; color: #fff; background-color: #c61013; }
.input-box td { width: 820px; padding: 60px 0 20px; font-size: 20px; line-height: 2.5; text-align: left; border-bottom: 1px solid #ababab; }
*/
.input-box {
  margin-top: 2.77778vw;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.input-box .inner {
  width: 79.16667vw;
  margin: 0 auto;
}

.input-box table {
  width: 100%;
}

.input-box th {
  position: relative;
  padding: 0 4.16667vw 2.08333vw 0;
  font-size: 1.52778vw;
  font-weight: bold;
  line-height: 1.14;
  text-align: right;
  vertical-align: bottom;
}

.input-box .hisu {
  display: inline-block;
  width: 4.44444vw;
  height: 2.08333vw;
  padding-top: 0.55556vw;
  margin-left: 1.04167vw;
  text-align: center;
  font-size: 0.97222vw;
  color: #fff;
  background-color: #c61013;
}

.input-box td {
  width: 56.94444vw;
  padding: 4.16667vw 0 1.38889vw;
  font-size: 1.38889vw;
  line-height: 2.5;
  text-align: left;
  border-bottom: 1px solid #ababab;
}

@media print, screen and (max-width: 768px) {
  /*.input-box { margin-top: 40px; }
.input-box .inner { width: 100%; }
.input-box th { display: block; padding: 20px 15px; font-size: 20px; font-weight: bold; line-height: 1.14; text-align: left; vertical-align: center; }
.input-box .hisu { width: 34px; height: 20px; padding-top: 3px; margin-left: 7px; font-size: 12px; }
.input-box td { display: block; width: 100%; padding: 0 15px 20px; font-size: 20px; }
*/
  .input-box {
    margin-top: 10.25641vw;
  }
  .input-box .inner {
    width: 100%;
  }
  .input-box th {
    display: block;
    padding: 5.12821vw 3.84615vw;
    font-size: 5.12821vw;
    font-weight: bold;
    line-height: 1.14;
    text-align: left;
    vertical-align: center;
  }
  .input-box .hisu {
    width: 8.71795vw;
    height: 5.12821vw;
    padding-top: 0.76923vw;
    margin-left: 1.79487vw;
    font-size: 3.07692vw;
  }
  .input-box td {
    display: block;
    width: 100%;
    padding: 0 3.84615vw 5.12821vw;
    font-size: 5.12821vw;
  }
}

/*.input-box input[type=text],
.input-box input[type=tel],
.input-box input[type=email] { width: 800px; height: 65px; padding: 15px; border: none; box-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.1); background-color: #fff; font-size: 20px; line-height: 1.25; text-align: left; color: #ababab; }
.input-box input[type=text]:focus,
.input-box input[type=tel]:focus,
.input-box input[type=email]:focus { color: #000; }
*/
.input-box input[type=text],
.input-box input[type=tel],
.input-box input[type=email] {
  width: 55.55556vw;
  height: 4.51389vw;
  padding: 1.04167vw;
  border: none;
  box-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.1);
  background-color: #fff;
  font-size: 1.38889vw;
  line-height: 1.25;
  text-align: left;
  color: #ababab;
}

.input-box textarea {
  width: 55.55556vw;
  padding: 1.04167vw;
  border: none;
  box-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.1);
  background-color: #fff;
  font-size: 1.38889vw;
  line-height: 1.25;
  text-align: left;
  color: #ababab;
  border-radius: 4px;
  border: 2px solid transparent;
}

.input-box input[type=text]:focus,
.input-box input[type=tel]:focus,
.input-box input[type=email]:focus,
.input-box textarea:focus {
  color: #000;
}

.input-box textarea:focus-visible {
  border-color: #000;
}

@media print, screen and (max-width: 768px) {
  .input-box input[type=text],
  .input-box input[type=tel],
  .input-box input[type=email] {
    width: 100%;
    height: 11.53846vw;
    padding: 1.79487vw;
    font-size: 4.10256vw;
  }
  .input-box textarea {
    width: 100%;
    padding: 1.79487vw;
    font-size: 4.10256vw;
  }
}

.radioItem {
  display: inline-flex;
  align-items: center;
  column-gap: 0.48611vw;
  line-height: 1;
  cursor: pointer;
}

.radioItem:not(:last-of-type) {
  margin-right: 1.11111vw;
}

.radioButton {
  appearance: none;
  position: relative;
  width: 1.875vw;
  height: 1.875vw;
  border: 0.34722vw solid #036;
  border-radius: 9999px;
  cursor: pointer;
  background-color: #fff;
}

.radioButton:checked::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 0.90278vw;
  height: 0.90278vw;
  margin: auto;
  border-radius: 9999px;
  background-color: #036;
}

@media print, screen and (max-width: 768px) {
  .radioItem {
    column-gap: 1.79487vw;
  }
  .radioItem:not(:last-of-type) {
    margin-right: 4.10256vw;
  }
  .radioButton {
    width: 6.41026vw;
    height: 6.41026vw;
    border: 1.02564vw solid #036;
  }
  .radioButton:checked::after {
    inset: 0;
    width: 3.84615vw;
    height: 3.84615vw;
  }
}

/* privacy-box */
/*.privacy-box { width: 1180px; margin: 80px auto 40px; font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; }
.privacy-box .ttl { font-size: 22px; line-height: 1.14; text-align: left; }
.privacy-box .inline { overflow: scroll; height: 300px; margin: 20px 0 0; padding: 40px; box-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.1); background-color: #fff; }
.privacy-box .txt { font-size: 16px; line-height: 1.56; text-align: left; }
.privacy-box p + p { margin: 25px 0 0; }
*/
.privacy-box {
  width: 81.94444vw;
  margin: 5.55556vw auto 2.77778vw;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.privacy-box .ttl {
  font-size: 1.52778vw;
  line-height: 1.14;
  text-align: left;
}

.privacy-box .inline {
  overflow: scroll;
  height: 20.83333vw;
  margin: 1.38889vw 0 0;
  padding: 2.77778vw;
  box-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.1);
  background-color: #fff;
}

.privacy-box .txt {
  font-size: 1.11111vw;
  line-height: 1.56;
  text-align: left;
}

.privacy-box p + p {
  margin: 1.73611vw 0 0;
}

@media print, screen and (max-width: 768px) {
  /*.privacy-box { width: 100%; margin: 40px auto; padding: 0 15px; }
.privacy-box .ttl { font-size: 18px; }
.privacy-box .inline { height: 250px; margin: 10px 0 0; padding: 20px; }
.privacy-box .txt { font-size: 12px; line-height: 1.36; }
.privacy-box p + p { margin: 15px 0 0; }
*/
  .privacy-box {
    width: 100%;
    margin: 10.25641vw auto;
    padding: 0 3.84615vw;
  }
  .privacy-box .ttl {
    font-size: 4.61538vw;
  }
  .privacy-box .inline {
    height: 64.10256vw;
    margin: 2.5641vw 0 0;
    padding: 5.12821vw;
  }
  .privacy-box .txt {
    font-size: 3.07692vw;
    line-height: 1.36;
  }
  .privacy-box p + p {
    margin: 3.84615vw 0 0;
  }
}

/* check-box */
/*.check-box { font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; }
.check-box .inner { font-size: 22px; font-weight: bold; line-height: 1.14; text-align: left; color: $c-blue; }
.check-box .inner label { cursor: default; }
.check-box .inner input[type=checkbox] { width: 22px; height: 22px; border: 1px solid $c-blue; }
.check-box .inner { }
*/
.check-box {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.check-box .inner {
  font-size: 1.52778vw;
  font-weight: bold;
  line-height: 1.14;
  text-align: left;
  color: #003366;
}

.check-box .inner label {
  cursor: default;
}

.check-box .inner input[type=checkbox] {
  width: 1.52778vw;
  height: 1.52778vw;
  border: 1px solid #003366;
}

@media print, screen and (max-width: 768px) {
  /*.check-box { padding: 0 15px; }
.check-box .inner { font-size: 16px; }
.check-box .inner input[type=checkbox] { width: 18px; height: 18px; }
*/
  .check-box {
    padding: 0 3.84615vw;
  }
  .check-box .inner {
    font-size: 4.10256vw;
  }
  .check-box .inner input[type=checkbox] {
    width: 4.61538vw;
    height: 4.61538vw;
  }
}

/* submit-box */
.submit-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: right;
  padding: 2.08333vw 0;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  border-bottom: 1px solid #003366;
  gap: 15px;
}

@media print, screen and (max-width: 768px) {
  .submit-box {
    justify-content: center;
    padding: 10.25641vw 0 0;
    border: none;
  }
}

/*
.submit-box button { display: flex; flex-direction: row; justify-content: center; align-items: center; width: 300px; height: 56px; border-radius: 3px; background-color: #036; font-size: 20px; font-weight: 500; color: #fff; cursor: pointer; }
.submit-box button:hover { opacity: .8; }
*/
.submit-box button {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  width: 20.83333vw;
  height: 3.88889vw;
  border-radius: 0.20833vw;
  background-color: #036;
  font-size: 1.38889vw;
  font-weight: 500;
  color: #fff;
  cursor: pointer;
}

.submit-box button:hover {
  opacity: .8;
}

@media print, screen and (max-width: 768px) {
  /*.submit-box button { width: 270px; height: 50px; border-radius: 2px;  font-size: 16px; color: #fff; }
*/
  .submit-box button {
    width: 69.23077vw;
    height: 12.82051vw;
    border-radius: 0.51282vw;
    font-size: 4.10256vw;
    color: #fff;
  }
}

/* ooo */
/* ooo */

.mapWrap {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  /* 16:9のアスペクト比 */
  height: 0;
  margin: 6.94444vw auto 0;
}
.mapWrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}