@charset "UTF-8";
/* Only output numerical values
/* 数値のみ出力する
====================================== */
/* font $size
====================================== */
/* font family
====================================== */
/* Break point ブレイクポイント
====================================== */
/* max site width コンテンツ最大幅
====================================== */
/* colors 色管理
====================================== */
/* media query
====================================== */
/* font-size フォントサイズのrem表示用
====================================== */
/* font-weight フォントの太さの指定用
====================================== */
html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 16px;
  color: #000000;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 2.2;
  font-size: 3.3816425121cqw;
  font-weight: 500;
}
@media (min-width: 960px) {
  body {
    letter-spacing: 0.05em;
    font-size: min(1.5384615385cqw, 20px);
  }
}

h1, h2, h3, h4, h5, h6 {
  font-family: "Noto Sans JP", sans-serif;
  color: #000000;
  line-height: 1.2;
}

p {
  margin: 0;
}
p + p {
  margin-top: 1em;
}

ul, dl, figure {
  margin: 0;
  padding: 0;
}

dt {
  font-weight: normal;
}

ul, li {
  list-style: none;
}

a {
  color: #000000;
  transition: 0.4s;
}
a:before, a:after {
  transition: 0.4s;
}
a:hover {
  color: #000000;
  text-decoration: none;
}

em {
  font-style: normal;
  font-weight: normal;
  color: inherit;
}

input,
select,
textarea {
  outline: none;
  vertical-align: middle;
  font-size: 16px;
  font-size: 1rem;
}

input:not([type=checkbox]):not([type=radio]):not([type=file]):not([type=hidden]):not([type=submit]):not([type=reset]):not([type=button]):not([type=image]),
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  padding: 1em;
  border: 0;
  box-sizing: border-box;
  border-radius: 5px;
}
@media (min-width: 640px) {
  input:not([type=checkbox]):not([type=radio]):not([type=file]):not([type=hidden]):not([type=submit]):not([type=reset]):not([type=button]):not([type=image]),
  select,
  textarea {
    padding: 2em;
  }
}

button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  outline: none;
  width: 100%;
  font-size: 15px;
  font-size: 0.9375rem;
  line-height: 2;
}

address {
  margin-bottom: 0;
}

/* uk-container
====================================== */
.uk-container {
  max-width: 1200px;
}
.uk-container-small {
  max-width: 1050px;
}
.uk-container-large {
  max-width: 1300px;
}
.uk-container-expand {
  max-width: none;
}

/* Contact Form 7
====================================== */
.wpcf7 .ajax-loader {
  position: absolute;
  top: 0;
  left: 0;
  visibility: hidden;
}

/* reCAPTCHA
====================================== */
.grecaptcha-badge {
  visibility: hidden;
}

/* Margin class in 5px steps
/* 余白調整用のクラス　5px刻みで20回処理を繰り返し
====================================== */
.mt0 {
  margin-top: 0px !important;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.com-txt-color-text {
  color: #000000 !important;
}

.com-bg-text {
  background-color: #000000 !important;
}

.com-txt-color-main {
  color: #FF6600 !important;
}

.com-bg-main {
  background-color: #FF6600 !important;
}

.com-txt-color-danger {
  color: red !important;
}

.com-bg-danger {
  background-color: red !important;
}

.com-txt-color-white {
  color: #fff !important;
}

.com-bg-white {
  background-color: #fff !important;
}

.com-txt-color-yellow {
  color: #FFFDE8 !important;
}

.com-bg-yellow {
  background-color: #FFFDE8 !important;
}

.com-txt-color-yellow_02 {
  color: #FFEFAD !important;
}

.com-bg-yellow_02 {
  background-color: #FFEFAD !important;
}

.com-txt-color-blue {
  color: #016FC0 !important;
}

.com-bg-blue {
  background-color: #016FC0 !important;
}

.com-txt-color-blue_02 {
  color: #F2F7FA !important;
}

.com-bg-blue_02 {
  background-color: #F2F7FA !important;
}

.com-txt-color-gray {
  color: #D1D1D1 !important;
}

.com-bg-gray {
  background-color: #D1D1D1 !important;
}

.com-txt-color-gray_02 {
  color: #EDEDED !important;
}

.com-bg-gray_02 {
  background-color: #EDEDED !important;
}

.com-txt-color-gray_03 {
  color: #D0D0D0 !important;
}

.com-bg-gray_03 {
  background-color: #D0D0D0 !important;
}

.com-txt-color-gray_04 {
  color: #C1C1C1 !important;
}

.com-bg-gray_04 {
  background-color: #C1C1C1 !important;
}

.com-txt-color-black_02 {
  color: #333 !important;
}

.com-bg-black_02 {
  background-color: #333 !important;
}

.com-txt-color-facebook {
  color: #3b5999 !important;
}

.com-bg-facebook {
  background-color: #3b5999 !important;
}

.com-txt-color-x {
  color: #000 !important;
}

.com-bg-x {
  background-color: #000 !important;
}

.com-txt-color-youtube {
  color: #cd201f !important;
}

.com-bg-youtube {
  background-color: #cd201f !important;
}

.com-txt-color-line {
  color: #18ba07 !important;
}

.com-bg-line {
  background-color: #18ba07 !important;
}

/* 共通クラス　common class
--------------------------------- */
.com-grid-01 {
  margin-left: -1px;
}
.com-grid-01 > * {
  padding-left: 1px;
}

.com-grid-margin-20 > .uk-grid-margin {
  margin-top: 4.8309178744cqw;
}
@media (min-width: 960px) {
  .com-grid-margin-20 > .uk-grid-margin {
    margin-top: min(1.5384615385cqw, 20px);
  }
}

.com-text-medium {
  font-weight: 500;
}

/* Gap between sections or blocks
/* セクションやブロック間の隙間
--------------------------------- */
.com-mt-s {
  margin-top: 4.8309178744cqw;
}
@media (min-width: 640px) {
  .com-mt-s {
    margin-top: min(2.3076923077cqw, 30px);
  }
}

.com-mt-m {
  margin-top: 9.6618357488cqw;
}
@media (min-width: 640px) {
  .com-mt-m {
    margin-top: min(4.6153846154cqw, 60px);
  }
}

.com-mt-l {
  margin-top: 21.7391304348cqw;
}
@media (min-width: 640px) {
  .com-mt-l {
    margin-top: min(9.2307692308cqw, 120px);
  }
}

.com-mt-02 {
  margin-top: 14.4927536232cqw;
}
@media (min-width: 640px) {
  .com-mt-02 {
    margin-top: min(6.1538461538cqw, 80px);
  }
}

.com-mt-1em {
  margin-top: 1em;
}

.com-mt-half {
  margin-top: 0.5em;
}

.com-link-01:hover {
  color: #FF6600;
}

.com-link-02:hover {
  opacity: 0.6;
}

.front-sec-01 {
  position: relative;
  z-index: 2;
  margin-top: -2%;
  padding-block: 60px;
}
@media (min-width: 640px) {
  .front-sec-01 {
    padding-block: 120px;
  }
}
.front-sec-01 .sec-video {
  display: block;
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-mask-image: url(../img/about_wave_mask_s.svg);
  mask-image: url(../img/about_wave_mask_s.svg);
  -webkit-mask-repeat: repeat-x;
  mask-repeat: repeat-x;
  -webkit-mask-position: 0 0;
  mask-position: 0 0;
  -webkit-mask-size: calc(100% + 2px) 100%;
  mask-size: calc(100% + 2px) 100%;
  animation: wave_moment 15s linear 0s infinite normal;
}
@media (min-width: 960px) {
  .front-sec-01 .sec-video {
    -webkit-mask-image: url(../img/about_wave_mask.svg);
    mask-image: url(../img/about_wave_mask.svg);
  }
}
.front-sec-01 .sec-video > video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.front-sec-01 .sec-video::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/bg_about_overlap.svg) no-repeat center/cover;
}

.front-sec-02 {
  padding-top: 100px;
  padding-bottom: 80px;
}
@media (min-width: 640px) {
  .front-sec-02 {
    padding-top: 210px;
    padding-bottom: 160px;
  }
}

@keyframes wave_moment {
  0% {
    -webkit-mask-position: 0 0;
    mask-position: 0 0;
  }
  100% {
    -webkit-mask-position: 100svw 0;
    mask-position: 100svw 0;
  }
}
@keyframes wave_moment_02 {
  0% {
    background-position: 0 100%;
  }
  100% {
    background-position: 378px 100%;
  }
}
@media (min-width: 960px) {
  @keyframes wave_moment_02 {
    0% {
      background-position: 0 100%;
    }
    100% {
      background-position: 683px 100%;
    }
  }
}
.com-sec-02 {
  --bg: #F2F7FA;
  position: relative;
  z-index: 2;
  background-color: var(--bg);
}
.com-sec-02::before {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 15px;
  background: url(../img/wave_top_blue_s.png) repeat-x center center/auto 100%;
  animation: wave_moment_02 15s linear 0s infinite normal;
  left: 0;
  top: 0;
  transform: translateY(-96%);
}
@media (min-width: 960px) {
  .com-sec-02::before {
    background-image: url(../img/wave_top_blue.png);
    height: 27px;
  }
}
.com-sec-02.white {
  --bg: #fff;
}
.com-sec-02.white::before {
  background-image: url(../img/wave_top_white_s.png);
}
@media (min-width: 960px) {
  .com-sec-02.white::before {
    background-image: url(../img/wave_top_white.png);
  }
}
.com-sec-02.yellow {
  --bg: #FFFDE8;
}
.com-sec-02.yellow::before {
  background-image: url(../img/wave_top_yellow_s.png);
}
@media (min-width: 960px) {
  .com-sec-02.yellow::before {
    background-image: url(../img/wave_top_yellow.png);
  }
}

.com-text-01 {
  font-size: 2.8985507246cqw;
  line-height: 1;
  font-family: "Poppins", sans-serif;
  text-transform: uppercase;
  font-weight: 700;
  color: #FF6600;
  text-align: center;
  margin-bottom: 0.5em;
  display: flex;
  justify-content: center;
}
@media (min-width: 960px) {
  .com-text-01 {
    font-size: min(2.1538461538cqw, 28px);
    margin-bottom: 0.7em;
  }
}
.com-text-01::before {
  content: "＃";
}

.com-tit-01 {
  text-align: center;
  line-height: 1.8;
  letter-spacing: 0.05em;
  font-weight: 700;
  font-size: 4.8309178744cqw;
  margin-bottom: 1.8em;
}
@media (min-width: 960px) {
  .com-tit-01 {
    font-size: min(4.6153846154cqw, 60px);
    line-height: 1.5333333333;
    margin-bottom: 0.6em;
  }
}
.com-tit-01 .small-01 {
  font-size: 85%;
}
@media (min-width: 960px) {
  .com-tit-01 .small-01 {
    font-size: 83%;
  }
}
.com-tit-01 .small-02 {
  font-size: 100%;
}
@media (min-width: 960px) {
  .com-tit-01 .small-02 {
    font-size: 67%;
  }
}

.com-tit-02 {
  margin-block: 0 1.6em;
  font-size: 5.7971014493cqw;
  line-height: 1.25;
  font-weight: 600;
}
@media (min-width: 960px) {
  .com-tit-02 {
    font-size: min(4.2307692308cqw, 55px);
    line-height: 1.2363636364;
    margin-bottom: 1.4em;
  }
}
.com-tit-02.small {
  font-size: 4.8309178744cqw;
  line-height: 1.5;
}
@media (min-width: 960px) {
  .com-tit-02.small {
    font-size: min(2.7692307692cqw, 36px);
    line-height: 1.8888888889;
  }
}
.com-tit-02 .small-01 {
  font-size: 85%;
}
@media (min-width: 960px) {
  .com-tit-02 .small-01 {
    font-size: 83%;
  }
}

.com-tit-03 {
  font-size: 3.8647342995cqw;
  letter-spacing: 0.05em;
  font-family: "Poppins", sans-serif;
  color: #FF6600;
  text-transform: uppercase;
  font-weight: 700;
  margin: 0;
}
@media (min-width: 640px) {
  .com-tit-03 {
    font-size: min(1.3846153846cqw, 18px);
  }
}
.com-tit-03::before {
  content: "＃";
}
.com-tit-03 .num {
  display: inline-block;
  margin-left: 0.2em;
  font-size: 112.5%;
}
@media (min-width: 640px) {
  .com-tit-03 .num {
    font-size: 122%;
  }
}

.com-catch-01 {
  font-size: 5.7971014493cqw;
  line-height: 1.6666666667;
  letter-spacing: 0.05em;
  font-weight: 700;
}
@media (min-width: 960px) {
  .com-catch-01 {
    font-size: min(3.2307692308cqw, 42px);
    line-height: 1.4285714286;
  }
}
.com-catch-01 .small-01 {
  font-size: 83%;
}
@media (min-width: 960px) {
  .com-catch-01 .small-01 {
    font-size: 76%;
  }
}

.com-card-01 {
  text-align: center;
  align-content: center;
  background-color: #FFFDE8;
  border-radius: 1.2077294686cqw;
  padding: 0 0;
  font-weight: 600;
  font-size: 5.3140096618cqw;
  line-height: 1.5;
  letter-spacing: 0.05em;
  padding: 9.6618357488cqw 7.2463768116cqw;
}
@media (min-width: 640px) {
  .com-card-01 {
    border-radius: min(0.7692307692cqw, 10px);
    padding: min(3.8461538462cqw, 50px) min(3.0769230769cqw, 40px);
    font-size: min(2.3076923077cqw, 30px);
    line-height: 1.5666666667;
  }
}

.com-panel-01 {
  background-color: #fff;
  border-radius: 4.8309178744cqw;
  box-shadow: 0 3px 30px rgba(0, 0, 0, 0.16);
}
@media (min-width: 960px) {
  .com-panel-01 {
    border-radius: min(3.0769230769cqw, 40px);
  }
}

.com-panel-02 {
  text-align: center;
}
.com-panel-02 .panel-head {
  color: #FF6600;
  display: flex;
  justify-content: center;
  gap: 3%;
  font-family: "Poppins", sans-serif;
  font-size: 2.8985507246cqw;
  line-height: 1.2;
  font-weight: 700;
}
@media (min-width: 960px) {
  .com-panel-02 .panel-head {
    font-size: min(1.3846153846cqw, 18px);
    gap: 2%;
  }
}
.com-panel-02 .panel-head::before, .com-panel-02 .panel-head::after {
  content: "";
  flex-shrink: 0;
  display: block;
  width: 8px;
  background: no-repeat bottom 0.1em center/contain;
}
.com-panel-02 .panel-head::before {
  background-image: url(../img/quote_01_left.svg);
}
.com-panel-02 .panel-head::after {
  background-image: url(../img/quote_01_right.svg);
}
.com-panel-02 .panel-btn {
  margin-top: 5px;
}

.com-panel-03 {
  background-color: #fff;
  box-shadow: 0 3px 30px rgba(0, 0, 0, 0.16);
  border-radius: 0.7246376812cqw;
  border: 2.4154589372cqw solid #FF6600;
  color: #FF6600;
  font-size: 5.5555555556cqw;
  line-height: 1.3913043478;
  letter-spacing: 0.05em;
  font-weight: 700;
  padding: 18.115942029cqw 10.38647343cqw;
}
@media (min-width: 960px) {
  .com-panel-03 {
    padding: min(7.8461538462cqw, 102px);
    border-width: min(0.7692307692cqw, 10px);
    font-size: min(3.2307692308cqw, 42px);
    line-height: 1.8095238095;
  }
}

.com-btn-01 {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 88%;
  margin-inline: auto;
  background-color: #016FC0;
  color: #fff;
  font-size: 5.3140096618cqw;
  line-height: 1.4545454545;
  font-weight: 700;
  gap: 25px;
  padding: 1em;
  box-sizing: border-box;
  border-radius: 12.077294686cqw;
}
@media (min-width: 960px) {
  .com-btn-01 {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    min-width: 452px;
    max-width: 100%;
    font-size: min(2.4615384615cqw, 32px);
    padding: 0.6em 1.5em;
    border-radius: min(3.9230769231cqw, 51px);
  }
}
.com-btn-01::after {
  content: "";
  display: block;
  width: 28px;
  aspect-ratio: 1/1;
  background: url(../img/arrow_01.svg) no-repeat center/contain;
}
.com-btn-01:hover {
  color: #fff;
  background-color: #FF6600;
}

.com-scrollbar-01::-webkit-scrollbar {
  width: 4px;
}
@media (min-width: 960px) {
  .com-scrollbar-01::-webkit-scrollbar {
    width: 15px;
  }
}
.com-scrollbar-01::-webkit-scrollbar-thumb {
  background: #016FC0;
  border-radius: 10px;
}
.com-scrollbar-01::-webkit-scrollbar-track {
  background-color: #EDEDED;
  border-radius: 10px;
}

.kv-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100svh;
  box-sizing: border-box;
  padding-block: 4svw 6svw;
  background: url(../img/kv_s.jpg) no-repeat center/cover;
}
@media (min-width: 960px) {
  .kv-wrap {
    background-image: url(../img/kv.jpg);
    min-height: 100svh;
  }
}
.kv-wrap > .uk-container {
  width: 100%;
}
.kv-wrap img {
  display: block;
  max-height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}
@media (min-width: 640px) {
  .kv-wrap img {
    max-width: 80%;
  }
}
.kv-wrap .kv-panel-01 {
  background: #fff;
  text-align: center;
  padding: 5svh 5.7971014493cqw;
  border-radius: 10px;
  max-width: 100%;
  box-sizing: border-box;
}
@media (min-width: 960px) {
  .kv-wrap .kv-panel-01 {
    padding: 5svh min(1.8461538462cqw, 24px);
  }
}
.kv-wrap .kv-panel-01 .title {
  font-size: 5.3140096618cqw;
  line-height: 1.4545454545;
  color: #FF6600;
  font-weight: 900;
  margin-bottom: 3svh;
}
@media (min-width: 960px) {
  .kv-wrap .kv-panel-01 .title {
    font-size: min(3.6923076923cqw, 48px);
  }
}
.kv-wrap .kv-panel-01 .small {
  font-size: 70%;
  color: #000000;
}
.kv-wrap .kv-panel-01 .text-01 {
  font-size: 3.8647342995cqw;
  line-height: 1.6;
}
@media (min-width: 960px) {
  .kv-wrap .kv-panel-01 .text-01 {
    font-size: min(1.8461538462cqw, 24px);
  }
}
.kv-wrap .kv-panel-01 .text-01.large {
  font-size: 4.347826087cqw;
}
@media (min-width: 960px) {
  .kv-wrap .kv-panel-01 .text-01.large {
    font-size: min(2.1538461538cqw, 28px);
  }
}
.kv-wrap .kv-text-01 {
  font-size: 2.4154589372cqw;
  color: #fff;
  margin-top: 1em;
}
@media (min-width: 960px) {
  .kv-wrap .kv-text-01 {
    font-size: min(0.9230769231cqw, 12px);
    text-align: center;
  }
}

.about-mt-03 {
  margin-top: -3svw;
}

.about-panel-01 {
  padding: 14.4927536232cqw 4.8309178744cqw 7.2463768116cqw;
  position: relative;
  z-index: 3;
  font-size: 3.3816425121cqw;
}
@media (min-width: 960px) {
  .about-panel-01 {
    padding: min(9.2307692308cqw, 120px);
    font-size: min(1.5384615385cqw, 20px);
  }
}
.about-panel-01 .fz-large {
  font-size: 5.3140096618cqw;
  font-weight: bold;
}
@media (min-width: 960px) {
  .about-panel-01 .fz-large {
    font-size: min(3.0769230769cqw, 40px);
  }
}
.about-panel-01 .fz-medium {
  font-size: 4.347826087cqw;
  font-weight: bold;
}
@media (min-width: 960px) {
  .about-panel-01 .fz-medium {
    font-size: min(2.3076923077cqw, 30px);
  }
}
.about-panel-01 .lh130 {
  line-height: 1.3;
}

.about-dl-01 {
  color: #fff;
  border-radius: 10px;
}
@media (min-width: 960px) {
  .about-dl-01 {
    border-radius: 50px;
  }
}
@media (max-width: 959px) {
  .about-dl-01 {
    text-align: left;
  }
}
@media (min-width: 960px) {
  .about-dl-01 .dl-main,
  .about-dl-01 .dl-sub {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 0.5em;
  }
}
.about-dl-01 .dl-sub + .dl-sub {
  margin-top: 1em;
}
.about-dl-01 .dl-main {
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #fff;
}
@media (min-width: 960px) {
  .about-dl-01 .dl-main {
    border-bottom: none;
    position: relative;
    margin-bottom: 30px;
    padding-bottom: 30px;
  }
  .about-dl-01 .dl-main::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 400px;
    height: 1px;
    background: #fff;
  }
}
@media (min-width: 960px) {
  .about-dl-01 .dl-main dt {
    font-size: min(2.1538461538cqw, 28px);
  }
}
.about-dl-01 dt {
  font-size: 3.8647342995cqw;
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: 0.3em;
}
@media (min-width: 960px) {
  .about-dl-01 dt {
    font-size: min(1.5384615385cqw, 20px);
    margin-bottom: 0;
    white-space: nowrap;
  }
}
.about-dl-01 dd {
  font-weight: 500;
  line-height: 1.8;
  font-size: 4.347826087cqw;
}
@media (min-width: 960px) {
  .about-dl-01 dd {
    line-height: 1.2;
    font-size: min(1.5384615385cqw, 20px);
  }
}
.about-dl-01 .time {
  font-size: 4.347826087cqw;
  display: inline-block;
}
@media (min-width: 960px) {
  .about-dl-01 .time {
    font-size: min(1.5384615385cqw, 20px);
  }
}
.about-dl-01 .time small {
  font-size: 89%;
}
@media (min-width: 960px) {
  .about-dl-01 .time small {
    font-size: 87.5%;
  }
}
.about-dl-01 .time .num {
  font-family: "Poppins", sans-serif;
  font-size: 5.7971014493cqw;
  font-weight: 700;
  line-height: 1;
  color: #FFEFAD;
  display: inline-block;
  padding-inline: 0.1em;
}
@media (min-width: 960px) {
  .about-dl-01 .time .num {
    font-size: min(2.4615384615cqw, 32px);
  }
}
.about-dl-01 .time-separator {
  display: inline-block;
  vertical-align: middle;
}

.news-panel-01 {
  padding: 14.4927536232cqw 7.2463768116cqw 7.2463768116cqw;
}
@media (min-width: 960px) {
  .news-panel-01 {
    padding: min(6.9230769231cqw, 90px) min(8.8461538462cqw, 115px) min(11.5384615385cqw, 150px);
  }
}

.news-list-01 {
  --list-height: 0;
  --border: 1px solid #D1D1D1;
  font-size: 3.3816425121cqw;
  line-height: 1.7142857143;
  font-weight: 600;
  height: var(--list-height);
  overflow-y: auto;
  padding-right: 15px;
}
@media (min-width: 960px) {
  .news-list-01 {
    font-size: min(1.5384615385cqw, 20px);
    padding-right: 40px;
  }
}
.news-list-01 li {
  padding-block: 4.8309178744cqw;
}
@media (min-width: 960px) {
  .news-list-01 li {
    padding-block: min(2.3076923077cqw, 30px);
  }
}
.news-list-01 .date, .news-list-01 .link, .news-list-01 .tit {
  display: block;
}
.news-list-01 .date {
  color: #016FC0;
}
@media (min-width: 960px) {
  .news-list-01 .date {
    font-size: 90%;
  }
}
.news-list-01 .link {
  position: relative;
  padding-right: 7.2463768116cqw;
}
@media (min-width: 960px) {
  .news-list-01 .link {
    padding-right: min(4.2307692308cqw, 55px);
  }
}
.news-list-01 .link::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  display: block;
  width: 6.7632850242cqw;
  flex-shrink: 0;
  background: url(../img/arrow_02.svg) no-repeat center/100%;
}
@media (min-width: 960px) {
  .news-list-01 .link::after {
    width: min(3.2307692308cqw, 42px);
    right: min(0.7692307692cqw, 10px);
  }
}
.news-list-01 .link:hover {
  background-color: rgba(1, 111, 192, 0.2);
}
.news-list-01 .tit {
  gap: 2.4154589372cqw;
  margin-top: 2.4154589372cqw;
}
@media (min-width: 960px) {
  .news-list-01 .tit {
    margin-top: min(0.9230769231cqw, 12px);
  }
}
.news-list-01 > * {
  border-bottom: var(--border);
}
.news-list-01 > *:first-child {
  border-top: var(--border);
}

.attr-sec-01 {
  padding-block: 36.231884058cqw 14.4927536232cqw;
}
@media (min-width: 960px) {
  .attr-sec-01 {
    padding-block: min(12.3076923077cqw, 160px) min(6.1538461538cqw, 80px);
  }
}

.attr-tit-01 {
  --radius: 0.4830917874cqw;
  position: relative;
  z-index: 2;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  max-width: 100%;
  box-sizing: border-box;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-weight: 700;
  font-size: 8.9371980676cqw;
  letter-spacing: 0;
  background-color: #FF6600;
  color: #fff;
  border-radius: 0 var(--radius) var(--radius) 0;
  margin-block: 0 -1em;
  padding: 0.35em 0.6em;
}
@media (min-width: 640px) {
  .attr-tit-01 {
    --radius: min(0.3846153846cqw, 5px);
    font-size: clamp(37px, 3.5cqw, 60px);
    letter-spacing: 0.1em;
    padding: 0.3em 0.5em;
    margin-bottom: -1.2em;
  }
}
.attr-tit-01::before {
  content: "#";
}

.attr-card-01 {
  color: #fff;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-weight: 700;
  font-size: 5.7971014493cqw;
  line-height: 1.875;
  letter-spacing: 0;
  position: relative;
}
@media (min-width: 640px) {
  .attr-card-01 {
    line-height: 1.875;
    font-size: clamp(24px, 2.5cqw, 40px);
  }
}
.attr-card-01 .card-capt {
  position: absolute;
  width: 100%;
  box-sizing: border-box;
  left: 0;
  bottom: 0;
  padding: 1.5em 1.3em;
}

.hint-card-01 .card-tit {
  --radius: 1.2077294686cqw;
  font-size: 4.8309178744cqw;
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: 0.1em;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  max-width: 100%;
  box-sizing: border-box;
  color: #fff;
  background-color: #FF6600;
  border-radius: 0 var(--radius) var(--radius) 0;
  margin-block: 0 -1.3em;
  padding: 0.5em 0.85em;
  position: relative;
  z-index: 2;
}
@media (min-width: 960px) {
  .hint-card-01 .card-tit {
    --radius: min(0.3846153846cqw, 5px);
    font-weight: 600;
    font-size: min(2.4615384615cqw, 32px);
    padding-block: 0.4em;
  }
}
.hint-card-01 .card-tit::before {
  content: "#";
  font-weight: 700;
}
.hint-card-01 .card-wrapper {
  background-color: #F2F7FA;
  border-radius: 2.4154589372cqw;
  box-shadow: 0 3px 20px rgba(0, 0, 0, 0.16);
  padding: 14.4927536232cqw 9.6618357488cqw 9.6618357488cqw;
  display: flex;
  flex-direction: column;
  gap: 4.8309178744cqw;
}
@media (min-width: 960px) {
  .hint-card-01 .card-wrapper {
    flex-direction: row;
    align-items: flex-start;
    gap: min(1.5384615385cqw, 20px) min(4.3076923077cqw, 56px);
    border-radius: min(0.7692307692cqw, 10px);
    padding: min(6.1538461538cqw, 80px) min(6.1538461538cqw, 80px);
  }
}
.hint-card-01 .card-body {
  flex: 1;
  font-size: 3.3816425121cqw;
  line-height: 2.2857142857;
}
@media (min-width: 960px) {
  .hint-card-01 .card-body {
    font-size: min(1.5384615385cqw, 20px);
    line-height: 2.4;
    align-self: center;
  }
}
.hint-card-01 .card-body.moon::before {
  content: "";
  display: block;
  width: 68px;
  aspect-ratio: 100/84;
  background: url(../img/hint_02.png) no-repeat center/contain;
  margin-inline: auto 0;
  mix-blend-mode: multiply;
  margin-bottom: 5px;
}
@media (min-width: 960px) {
  .hint-card-01 .card-body.moon::before {
    width: 100px;
    margin-block: -10px 10px;
    margin-bottom: 10px;
  }
}
.hint-card-01 .card-image {
  display: block;
  max-width: 63.4%;
  flex-shrink: 0;
  margin-inline: auto;
}
@media (min-width: 960px) {
  .hint-card-01 .card-image {
    width: 25.6%;
  }
}
.hint-card-01 .card-signature {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  max-width: 100%;
  margin-inline: auto 0;
  display: flex;
  flex-direction: column;
  margin-top: 12px;
}
@media (min-width: 960px) {
  .hint-card-01 .card-signature {
    flex-direction: row;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 20px;
  }
}
.hint-card-01 .card-signature > * {
  display: block;
}
.hint-card-01 .card-signature .label {
  font-size: 2.8985507246cqw;
  line-height: 2;
  font-weight: 700;
  color: #016FC0;
}
@media (min-width: 960px) {
  .hint-card-01 .card-signature .label {
    font-size: min(1.3846153846cqw, 18px);
  }
}
.hint-card-01 .card-signature .signature {
  mix-blend-mode: multiply;
}
@media (max-width: 959px) {
  .hint-card-01 .card-signature .signature {
    max-width: 36.9565217391cqw;
  }
}
.hint-card-01 .card-signature.no-flex {
  display: block;
}

.dc-sec-01 {
  padding-block: 19.3236714976cqw 7.2463768116cqw;
}
@media (min-width: 960px) {
  .dc-sec-01 {
    padding-block: min(10.3846153846cqw, 135px) min(5.3846153846cqw, 70px);
  }
}

.dc-panel-01 {
  background-color: #fff;
  border-radius: 2.4154589372cqw;
  padding: 7.2463768116cqw 4.8309178744cqw;
  font-size: 3.3816425121cqw;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  letter-spacing: 0;
}
@media (min-width: 960px) {
  .dc-panel-01 {
    border-radius: min(1.5384615385cqw, 20px);
    padding: min(3.8461538462cqw, 50px) min(6.9230769231cqw, 90px) min(1.1538461538cqw, 15px);
    font-size: min(1.8461538462cqw, 24px);
    line-height: 2;
  }
}

.concept-sec-01 {
  padding-block: 7.2463768116cqw 38.6473429952cqw;
}
@media (min-width: 960px) {
  .concept-sec-01 {
    padding-block: min(5.7692307692cqw, 75px) min(19.2307692308cqw, 250px);
  }
}

.archive-sec-01 {
  padding-top: 24.154589372cqw;
}
@media (min-width: 960px) {
  .archive-sec-01 {
    padding-top: min(15.3846153846cqw, 200px);
  }
}

.archive-dl-01 {
  font-size: 3.3816425121cqw;
}
@media (min-width: 960px) {
  .archive-dl-01 {
    font-size: min(1.5384615385cqw, 20px);
  }
}
.archive-dl-01 dd {
  margin-bottom: 1.5em;
}
.archive-dl-01 dd:last-child {
  margin-bottom: 0;
}

.contact-sec-01 {
  padding-block: 14.4927536232cqw;
}
@media (min-width: 960px) {
  .contact-sec-01 {
    padding-block: min(12.3076923077cqw, 160px);
  }
}

.contact-text-01 {
  font-size: 2.8985507246cqw;
  line-height: 2.4166666667;
}
@media (min-width: 960px) {
  .contact-text-01 {
    font-size: min(1.8461538462cqw, 24px);
  }
}

.contact-mb-01 {
  margin-bottom: 0.5em;
}
@media (min-width: 960px) {
  .contact-mb-01 {
    margin-bottom: 0.7em;
  }
}

.foot-banner-sec-01 {
  padding-block: 4.8309178744cqw 16.9082125604cqw;
}
@media (min-width: 960px) {
  .foot-banner-sec-01 {
    padding-block: min(9.2307692308cqw, 120px) min(3.4615384615cqw, 45px);
  }
}

.foot-banner-container-01 {
  max-width: 950px;
}

.foot-banner-link-01 {
  display: block;
  width: 100%;
  box-sizing: border-box;
  aspect-ratio: 172/52;
  border: 1px solid #D1D1D1;
}
.foot-banner-link-01:hover {
  opacity: 0.6;
}
.foot-banner-link-01 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.foot-banner-grid-01 {
  --space: 2.4154589372cqw;
  margin-left: calc(var(--space) * -1);
}
@media (min-width: 640px) {
  .foot-banner-grid-01 {
    --space: min(1.5384615385cqw, 20px);
  }
}
.foot-banner-grid-01 > * {
  padding-left: var(--space);
}
.foot-banner-grid-01 > .uk-grid-margin {
  margin-top: var(--space);
}

.footer {
  background-color: #016FC0;
  padding-block: 8.4541062802cqw 16.9082125604cqw;
}
@media (min-width: 960px) {
  .footer {
    padding-block: min(5.3846153846cqw, 70px) min(3.0769230769cqw, 40px);
  }
}
.footer .footer-sns-list {
  display: flex;
  justify-content: center;
  -moz-column-gap: 8px;
  column-gap: 8px;
}
@media (min-width: 960px) {
  .footer .footer-sns-list {
    -moz-column-gap: 11px;
    column-gap: 11px;
  }
}
.footer .footer-sns-list a {
  display: block;
}
@media (max-width: 959px) {
  .footer .footer-sns-list a {
    width: 42px;
  }
}
.footer .footer-copyright {
  text-align: center;
  color: #fff;
  font-weight: 500;
}
.footer .footer-copyright p {
  font-size: 4.347826087cqw;
}
@media (min-width: 960px) {
  .footer .footer-copyright p {
    font-size: min(1.8461538462cqw, 24px);
  }
}
.footer .footer-copyright small, .footer .footer-copyright a {
  color: inherit;
  display: block;
  font-size: 3.1400966184cqw;
  line-height: 1.2;
}
@media (min-width: 960px) {
  .footer .footer-copyright small, .footer .footer-copyright a {
    font-size: min(1cqw, 13px);
  }
}

.footer-text-01 {
  color: #fff;
  display: flex;
  justify-content: center;
  gap: 3%;
  font-family: "Poppins", sans-serif;
  font-size: 3.3816425121cqw;
  line-height: 1.2;
  font-weight: 700;
  margin-bottom: 2.4154589372cqw;
}
@media (min-width: 960px) {
  .footer-text-01 {
    font-size: min(1.0769230769cqw, 14px);
    gap: 1%;
    margin-bottom: min(0.7692307692cqw, 10px);
  }
}
.footer-text-01::before, .footer-text-01::after {
  content: "";
  flex-shrink: 0;
  display: block;
  width: 8px;
  background-color: currentColor;
  -webkit-mask: no-repeat bottom 0.1em center/contain;
  mask: no-repeat bottom 0.1em center/contain;
}
.footer-text-01::before {
  -webkit-mask-image: url(../img/quote_01_left.svg);
  mask-image: url(../img/quote_01_left.svg);
}
.footer-text-01::after {
  -webkit-mask-image: url(../img/quote_01_right.svg);
  mask-image: url(../img/quote_01_right.svg);
}

.js-fixed-btn-01 {
  transition: 0.3s all ease-in-out;
  visibility: hidden;
  opacity: 0;
}
.js-fixed-btn-01.uk-actived {
  visibility: visible;
  opacity: 1;
}

.js-animation-text-01 > .animation-row {
  display: flex;
  justify-content: center;
}
.js-animation-text-01 > .animation-row > span {
  --js-delay: 0;
  display: block;
  opacity: 0;
  transform: translate(40%, 0);
  transition: 0.8s cubic-bezier(0.22, 1, 0.36, 1);
  transition-property: opacity, transform;
  transition-delay: var(--js-delay);
}
.js-animation-text-01.uk-actived > .animation-row > span {
  opacity: 1;
  transform: none;
}

#pagetop {
  display: block;
  position: fixed;
  width: 11.5458937198cqw;
  aspect-ratio: 1/1;
  background: url(../img/pagetop.png) no-repeat center/contain;
  left: 5%;
  bottom: 3%;
  z-index: 10;
}
@media (min-width: 960px) {
  #pagetop {
    left: 3%;
    width: min(5.3846153846cqw, 70px);
  }
}

#fixed-btn {
  display: block;
  position: fixed;
  width: 28.9855072464cqw;
  right: 5%;
  bottom: 3%;
  z-index: 10;
}
@media (min-width: 960px) {
  #fixed-btn {
    right: 3%;
    width: min(15.0769230769cqw, 196px);
  }
}
/*# sourceMappingURL=layout.css.map */
