@charset "UTF-8";
/*--------------------------------------------------------------
共通でインポートモジュール
# mixinや変数の定義を行う
--------------------------------------------------------------*/
/**
 * clamp関数の文字列を返す
 *
 * @param {Number} $size-at-min-width - 最小画面幅での要素のサイズ (px|rem|emなど)
 * @param {Number} $size-at-max-width - 最大画面幅での要素のサイズ (px|rem|emなど)
 * @param {Number} $min-width [optional] - 最小画面幅 (デフォルト: $min-width-default)
 * @param {Number} $max-width [optional] - 最大画面幅 (デフォルト: $max-width-default)
 * @return {String} CSS clamp関数を含む計算式
 *
 * @description
 * 画面幅に応じて値が滑らかに変化するレスポンシブな値を生成します。
 * 例えば、フォントサイズやマージン、パディングなどの値を画面幅に応じて
 * 自動的に調整することができます。
 *
 * @example
 *   // フォントサイズを16pxから24pxまで可変させる
 *   font-size: clamp-calc(16px, 24px);
 *
 *   // マージンを2remから4remまで可変させる（画面幅768px～1200px）
 *   margin: clamp-calc(2rem, 4rem, 768px, 1200px);
 *
 * @note
 * - 引数の単位は一貫している必要はありません（px, rem等が混在可能）
 * - 内部で全ての値をpxに変換して計算を行います
 * - 返り値は入力された$size-at-min-widthと同じ単位で返されます
 * - 負の値（マイナスマージンなど）にも対応しています
 *
 * @implementation
 * 1. 入力値を全てpxに変換
 * 2. 線形の傾きを計算
 * 3. y軸との交点を計算
 * 4. 必要に応じて最小値と最大値を入れ替え
 * 5. 元の単位に変換して最終的なclamp関数を構築
 */
/**
	* 与えられた値をピクセル(px)単位に変換する関数
	*
	* @param {Number} $value - 変換したい値（rem または px）
	* @return {Number} 変換後のピクセル値
	*
	* @example
	*   convert-to-px(1.5rem)  // 24px ($base-font-size が 16px の場合)
	*   convert-to-px(20px)    // 20px (そのまま返される)
	*   convert-to-px(2em)     // 2em (非対応の単位はそのまま返される)
	*
	* @description
	* - rem単位の場合: $base-font-sizeを基準にしてpxに変換
	* - px単位の場合: 値をそのまま返す
	* - その他の単位: 変換せずそのまま返す
	*
	* @throws {Error} $base-font-size が定義されていない場合にエラー
	*/
/**
	* ピクセル(px)単位の値をrem単位に変換する関数
	*
	* @param {Number} $px-value - 変換したい値（px または rem）
	* @return {Number} 変換後のrem値
	*
	* @example
	*   convert-to-rem(16px)   // 1rem ($base-font-size が 16px の場合)
	*   convert-to-rem(24px)   // 1.5rem ($base-font-size が 16px の場合)
	*   convert-to-rem(1.5rem) // 1.5rem (そのまま返される)
	*   convert-to-rem(2em)    // 2em (非対応の単位はそのまま返される)
	*
	* @description
	* - px単位の場合: $base-font-sizeを基準にしてremに変換
	* - rem単位の場合: 値をそのまま返す
	* - その他の単位: 変換せずそのまま返す
	*
	* @note
	* - レスポンシブデザインに適したrem単位への変換に使用
	* - $base-font-size はグローバルで定義されている必要がある
	*
	* @throws {Error} $base-font-size が定義されていない場合にエラー
	*/
/*
	* 補助関数：小数点以下の指定した桁数で四捨五入する関数
	*/
/*
	* 補助関数：累乗を計算する関数
	* 引数：$number 底となる数
	*      $exponent 指数（正の整数のみ対応）
	*/
:root {
  --text-color: #333;
  --main-color: #163e7b;
  --sub-color: #4a90e2;
  --sub-color-2: #a4ceff;
  --navy-08: #e4e8ef;
  --navy-09: #f1f4f7;
  --accent-color: #fb7200;
  --bg-color: #fff;
  --link-color: var(--main-color);
  --border-color: #e5e5e5;
  --fw-medium: 500;
  --fw-regular: 400;
  --fw-bold: 700;
  --fw-black: 900;
  --site-width: 1440px;
  --content-width: 900px;
  --site-inline-padding: 24px;
  --header-height: 80px;
  --header-inline-padding: 16px;
  --transition-time: 0.3s;
  --transition: var(--transition-time) ease;
}

html,
body,
div,
span,
object,
iframe,
button,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
sub,
sup,
var,
b,
i,
a,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
dialog,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  font-weight: inherit;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  word-break: normal;
  line-break: strict;
  word-wrap: normal;
  word-break: normal;
  line-height: inherit;
}

textarea,
input[type=button],
input[type=text],
input[type=image],
input[type=submit] {
  -webkit-appearance: none;
  word-break: normal;
}

input[type=submit],
input[type=button] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}

input[type=submit]::focus,
input[type=button]::focus {
  outline-offset: -2px;
}

* {
  outline: none;
}

body {
  font-size: 15px;
  word-break: break-all;
  -webkit-text-size-adjust: none;
}

* html body {
  font-size: small;
  font: x-small;
}

*:first-child + html body {
  font-size: small;
  font: x-small;
}

img {
  border: 0;
  vertical-align: bottom;
}

ul,
dl {
  text-indent: 0;
}

ul li {
  list-style: none;
}

ol li {
  list-style: decimal;
}

ol ul li {
  list-style: none;
}

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

sup {
  vertical-align: text-top;
}

sub {
  vertical-align: text-bottom;
}

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

* html input,
* html textarea,
* html select {
  font-size: 100%;
}

*:first-child + html + input,
*:first-child html + textarea,
*:first-child + html select {
  font-size: 100%;
}

table {
  border-collapse: separate;
  border-spacing: 0;
  font-size: inherit;
  font: 100%;
}

th,
td {
  text-align: left;
  vertical-align: top;
}

caption {
  text-align: left;
}

pre,
code,
kbd,
samp,
tt {
  font-family: monospace;
}

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

*:first-child + html pre,
*:first-child html + code,
*:first-child html + kbd,
*:first-child + html + samp,
*:first-child + html tt {
  font-size: 108%;
  line-height: 100%;
}

input,
select,
textarea {
  font-size: 100%;
  font-family: Verdana, Helvetica, sans-serif;
  margin: 0;
}

button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  cursor: pointer;
  line-height: inherit;
}

figure {
  line-height: 0;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  backface-visibility: hidden;
}

input,
textarea {
  border-radius: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-family: sans-serif;
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -ms-overflow-style: scrollbar;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

@-ms-viewport {
  width: device-width;
}
article,
aside,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section {
  display: block;
}

[tabindex="-1"]:focus {
  outline: 0 !important;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

img {
  height: auto;
  max-width: 100%;
  vertical-align: bottom;
}

body {
  font-family: "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic UI", "メイリオ", sans-serif;
  font-size: 16px;
  line-height: 1.8;
  font-weight: var(--fw-regular);
  color: var(--text-color);
}

@media screen and (min-width: 1080px) {
  .br_sp {
    display: none;
  }
}

@media screen and (max-width: 1079px) {
  .br_pc {
    display: none;
  }
}

@media screen and (max-width: 1079px) {
  .is-pc {
    display: none !important;
  }
}

@media screen and (min-width: 1080px) {
  .is-mobile {
    display: none !important;
  }
}

.ut_flex_row {
  display: flex;
  flex-wrap: wrap;
}

.loading {
  width: 100vw;
  height: 100vh;
  transition: all 1s;
  background-color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  opacity: 1;
  visibility: visible;
}
.loading.is-active {
  opacity: 0;
  visibility: hidden;
}

.loadingInner > div {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 5px;
}
@media screen and (min-width: 1080px) {
  .loadingInner > div {
    flex-direction: row;
    gap: 0;
  }
}
.loadingInner img {
  filter: brightness(0) invert(100%);
  width: 216px;
}
@media screen and (min-width: 1080px) {
  .loadingInner img {
    width: 331px;
  }
}
.loadingInner {
  color: #fff;
  font-size: clamp(15px, 10.873px + 0.794vw, 19px);
}
@media screen and (min-width: 1080px) {
  .loadingInner {
    font-size: 24px;
  }
}

.loading-animation {
  width: 100vw;
  height: 100vh;
  transition: all 1s;
  background-color: var(--main-color);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
}
.loading-animation.is-active {
  opacity: 1;
  visibility: visible;
}

.is-quickIn,
.is-fadein-fast,
.is-fadeUp-fast,
.is-fadeUp-bounce,
.is-fadeInOut,
.is-slidein,
.is-fadein,
.is-fadeInLeft,
.is-fadeInRight,
.is-fadeUp {
  opacity: 0;
}

.is-wipe {
  opacity: 0;
  width: 0;
}

.is-fadeInLeft,
.is-fadeInRight,
.is-fadeUp {
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0;
}

.is-animated.is-fadeUp {
  animation-name: fadeUpAnime;
}
.is-animated.is-fadeUp-fast {
  animation: fadeUpFastAnime 1s ease 1 forwards;
}
.is-animated.is-fadeInLeft {
  animation-name: fadeLeftAnime;
}
.is-animated.is-fadeInRight {
  animation-name: fadeRightAnime;
}
.is-animated.is-fadein {
  opacity: 0;
  animation: fadein 1.5s ease forwards;
}
.is-animated.is-fadein-fast {
  opacity: 0;
  animation: fadein 0.5s ease forwards;
}
.is-animated.is-quickIn {
  opacity: 0;
  animation: fadein 0.1s ease forwards;
}
.is-animated.is-slidein {
  opacity: 0;
  animation: slidein 1s ease-out forwards;
}
.is-animated.is-fadeInOut {
  animation: fade-in-out 2.5s ease forwards;
  animation-delay: 0.5s;
}
.is-animated.is-fadeUp-bounce {
  animation: fadeUpBounceAnime 1s ease 1 forwards;
}
.is-animated.is-wipe {
  animation: wipeAnime 1.2s ease-out 0s 1 normal forwards, zoom-in-out 1s ease-in 1.2s infinite alternate-reverse;
}
.is-animated.is-first {
  animation-delay: 0.8s;
}
.is-animated.is-2nd {
  animation-delay: 2s;
}
.is-animated.is-3rd {
  animation-delay: 3.4s;
}
.is-animated.is-4th {
  animation-delay: 3.4s;
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(50px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeUpFastAnime {
  0% {
    opacity: 0;
    transform: translateY(50px);
  }
  60%, 100% {
    opacity: 1;
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes fadeLeftAnime {
  from {
    opacity: 0;
    transform: translateX(-100px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes fadeRightAnime {
  from {
    opacity: 0;
    transform: translateX(100px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes fadein {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fade-in-out {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  30% {
    opacity: 1;
    transform: translateY(0);
  }
  70% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(0);
  }
}
@keyframes fadeUpBounceAnime {
  0% {
    transform: translateY(80px);
    opacity: 0;
  }
  50% {
    transform: translateY(0);
  }
  65% {
    transform: translateY(8px);
  }
  100% {
    transform: translateY(0);
  }
  20%, 100% {
    opacity: 1;
  }
}
@keyframes slidein {
  0% {
    opacity: 0;
    transform: translateX(-300px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes wipeAnime {
  0% {
    opacity: 1;
    width: 0;
  }
  100% {
    opacity: 1;
    width: 155px;
  }
}
.is-fadeInSlant {
  opacity: 0;
  animation-duration: 1s;
  animation-fill-mode: forwards;
}

.is-fadeInSlant_delayed {
  opacity: 0;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  animation-delay: 1s;
}

.is-animated.is-fadeInSlant {
  animation-name: fadeSlantAnime;
}
.is-animated.is-fadeInSlant_delayed {
  animation-name: fadeSlantAnime;
}

@keyframes fadeSlantAnime {
  from {
    opacity: 0;
    transform: translateX(-300px) translateY(173px);
  }
  to {
    opacity: 1;
    transform: translateX(0) translateY(0);
  }
}
/* 文字が滑らかに表示される */
.smooth {
  clip-path: inset(0 100% 0 0);
  display: inline-block;
  transition: 2.4s cubic-bezier(0.37, 0, 0.63, 1);
  transition-property: clip-path;
}

.smooth.is-animated {
  clip-path: inset(0);
}

.smooth-mv {
  clip-path: inset(0 0 0 100%);
  animation-duration: 3s;
  animation-fill-mode: forwards;
  animation-timing-function: linear;
}

.smooth-mv.is-animated {
  animation-name: smoothClipAnime;
}

@keyframes smoothClipAnime {
  0% {
    clip-path: inset(0 0 0 100%);
  }
  50% {
    clip-path: inset(0 0 0 70%); /* 最初の30%で20%しか進まない */
  }
  100% {
    clip-path: inset(0 0 0 0);
  }
}
.blur {
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0;
}
.blur.is-animated {
  animation-name: blurAnime;
}

@keyframes blurAnime {
  from {
    filter: blur(10px);
    transform: scale(1.02);
    opacity: 0;
  }
  to {
    filter: blur(0);
    transform: scale(1);
    opacity: 1;
  }
}
/*背景色が伸びて出現（共通）*/
.bgextend {
  animation-duration: 1s;
  animation-fill-mode: forwards;
  position: relative;
  overflow: hidden; /*　はみ出た色要素を隠す　*/
  opacity: 0;
}
.bgextend.is-animated {
  animation-name: bgextendAnimeBase;
}

@keyframes bgextendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/*中の要素*/
.bgappear {
  animation-duration: 1s;
  animation-delay: 0.6s;
  animation-fill-mode: forwards;
  opacity: 0;
}
.bgappear.is-animated {
  animation-name: bgextendAnimeSecond;
}

@keyframes bgextendAnimeSecond {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
/*左から*/
.bgLRextend::before {
  animation-name: bgLRextendAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #666; /*伸びる背景色の設定*/
}

@keyframes bgLRextendAnime {
  0% {
    transform-origin: left;
    transform: scaleX(0);
  }
  50% {
    transform-origin: left;
    transform: scaleX(1);
  }
  50.001% {
    transform-origin: right;
  }
  100% {
    transform-origin: right;
    transform: scaleX(0);
  }
}
.is_float {
  animation: float 1.8s ease-in-out infinite alternate-reverse;
}

@keyframes float {
  0% {
    transform: translateY(-2%);
  }
  100% {
    transform: translateY(2%);
  }
}
@keyframes floatY {
  0% {
    transform: translateY(5%);
  }
  100% {
    transform: translateY(-5%);
  }
}
@keyframes floatX {
  0% {
    transform: translateX(-15%);
  }
  100% {
    transform: translateX(10%);
  }
}
/* アクセシビリティ：ユーザーがアニメーションを嫌う場合は無効化 */
@media (prefers-reduced-motion: reduce) {
  .float {
    animation: none !important;
    transition: none !important;
  }
}
@keyframes zoom-in-out {
  0% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}
.ly_siteHeader {
  width: 100%;
  background: #fff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 3;
}

.ly_siteHeader_content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100vw;
  max-width: var(--site-width);
  padding-inline: var(--header-inline-padding);
  padding-block: 12px;
  margin-inline: auto;
  position: relative;
  gap: 15px;
}
.ly_siteHeader_content .el_siteHeader_logo {
  flex-shrink: 0;
  width: 105px;
}

@media screen and (min-width: 1080px) {
  .ly_siteHeader_nav {
    margin-left: auto;
  }
}

.ly_header_nav {
  margin-inline: auto;
  max-width: var(--site-width);
}
@media screen and (min-width: 1080px) {
  .ly_header_nav {
    display: flex;
    justify-content: space-around;
  }
}

.ly_fixed_header {
  margin-top: var(--header-height);
}
.ly_fixed_header .ly_siteHeader {
  position: fixed;
  top: 0;
  left: 0;
}
.ly_fixed_header.admin-bar {
  margin-top: calc(var(--header-height));
}
.ly_fixed_header.admin-bar .ly_siteHeader {
  top: 32px;
}

@media screen and (max-width: 1079px) {
  .ly_mainVisual {
    width: 100vw;
    margin-left: calc(50% - 50vw);
  }
}

.ly_content_header {
  margin-inline: auto;
  max-width: var(--site-width);
  display: flex;
  align-items: center;
  justify-content: center;
  height: var(--content-header-height, 150px);
  padding: 20px;
}

.ly_siteMain {
  margin-inline: auto;
  width: 100%;
  background-color: var(--bg-color);
}

.ly_mainContent {
  max-width: var(--site-width);
  margin-inline: auto;
}

.ly_pageHeader {
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-inline: var(--site-inline-padding);
  padding-block: 20px;
  background-color: var(--main-color);
  color: #fff;
  margin-top: 30px;
  min-height: 100px;
  background: linear-gradient(131deg, #007fe5 22%, var(--main-color) 22%);
}

.ly_article {
  margin-inline: auto;
}
.ly_article .bl_postThumbnail {
  margin-bottom: var(--article-mt);
}
.ly_article .bl_article_content {
  max-width: var(--content-width);
  margin-inline: auto;
  padding-inline: var(--site-inline-padding);
}
.ly_article .bl_article_content > * + * {
  margin-top: var(--article-mt);
}
.ly_article .bl_article_content > * + h2,
.ly_article .bl_article_content > * + h3,
.ly_article .bl_article_content > * + h4,
.ly_article .bl_article_content > * + h5,
.ly_article .bl_article_content > * + h6 {
  margin-top: var(--artilce-heading-mt);
}

.ly_siteFooter {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding-block: 20px;
  padding-inline: 20px;
}
@media screen and (min-width: 1080px) {
  .ly_siteFooter {
    padding-block: 30px;
  }
}

.bl_mv_mediaText {
  display: grid;
  grid-template-columns: 1fr;
}
@media screen and (min-width: 1080px) {
  .bl_mv_mediaText {
    grid-template-columns: 50% 50%;
  }
}

.bl_mediaText {
  display: grid;
  grid-template-columns: 1fr;
}
@media screen and (min-width: 1080px) {
  .bl_mediaText {
    grid-template-columns: 50% 50%;
  }
}
.bl_mediaText figure {
  text-align: center;
}

.el_linkButton {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 3px;
  background: var(--accent-color);
  color: #fff;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 10px 20px;
  font-weight: var(--fw-bold);
  text-shadow: 0px 0px 56px #820000;
  transition: all var(--transition);
}
.el_linkButton::after {
  content: "";
  content: "";
  background-image: url(../images/icon-button-arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 13px;
  height: 14px;
  display: block;
  margin-left: 12px;
}
@media (hover: hover) {
  .el_linkButton:hover {
    background-color: #ff9e4d;
  }
}
.el_linkButton:active {
  background-color: #c45a03;
}

.full-width {
  width: 100vw;
  margin-left: calc(50% - 50vw);
}

.is_text_center {
  text-align: center;
}

.is_blue {
  color: var(--sub-color);
}

.is_underline {
  position: relative;
}
.is_underline::after {
  content: "";
  position: absolute;
  bottom: -7px;
  left: 0;
  width: 100%;
  background-image: url(../images/problem-ul.svg);
  background-repeat: no-repeat;
  background-size: contain;
  height: 10px;
  background-position: center;
}

.el_siteHeader_logo a {
  display: flex;
  position: relative;
  align-items: flex-end;
}

.ly_siteHeader_content .el_linkButton {
  font-size: 14px;
  height: 56px;
  width: 175px;
}

.bl_header_nav_wrapper {
  background-color: var(--global-menu-bg);
}
@media screen and (max-width: 1240px) {
  .bl_header_nav_wrapper {
    display: none;
  }
}

.bl_siteHeader_contacts {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 1240px) {
  .bl_siteHeader_contacts {
    display: none;
  }
}
.bl_siteHeader_contacts .el_linkButton {
  font-size: 18px;
  box-shadow: 4px 4px 0 var(--text-color);
  border-radius: 8px;
  color: var(--text-color);
}
.bl_siteHeader_contacts .el_linkButton::before {
  content: "\e61d";
  font-family: "Material Symbols Outlined";
  color: var(--text-color);
  font-size: 30px;
  line-height: 1.3;
  flex-shrink: 0;
}
@media screen and (min-width: 1241px) {
  .bl_siteHeader_contacts .el_linkButton + .el_linkButton {
    margin-left: 15px;
  }
}
@media screen and (min-width: 1367px) {
  .bl_siteHeader_contacts .el_linkButton + .el_linkButton {
    margin-left: 25px;
  }
}
.bl_siteHeader_contacts .el_linkButton.for_request {
  background-color: var(--accent-color);
  width: clamp(140px, 1.6389rem + 11.1111vw, 178px);
  height: 63px;
}
.bl_siteHeader_contacts .el_linkButton.for_request::before {
  content: "\e873";
  font-size: 30px;
}
.bl_siteHeader_contacts .el_linkButton.for_contact {
  width: 208px;
  width: clamp(180px, 6.0102rem + 8.1871vw, 208px);
  height: 63px;
  background-color: #fff;
  border: 1px solid var(--main-color);
}
.bl_siteHeader_contacts .el_linkButton.for_contact::before {
  content: "\e158";
  font-size: 30px;
}

@media screen and (max-width: 1240px) {
  .ly_siteHeader_nav {
    visibility: hidden;
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    height: 100vh;
    height: 100dvh;
    z-index: 0;
    background-color: #fff;
    color: var(--text-color);
    justify-content: center;
    overflow-y: auto;
    overflow-x: hidden;
    padding-block: 70px 24px;
    padding-inline: 24px;
    transform: translateX(110%);
    transition: all var(--transition-time) ease;
  }
  .is_open .ly_siteHeader_nav {
    transform: translateX(0);
    visibility: visible;
    z-index: 9;
  }
}

@media screen and (max-width: 1240px) {
  .bl_siteHeader_nav {
    height: fit-content;
    padding-bottom: 30px;
    max-width: 480px;
    margin-inline: auto;
  }
  .bl_siteHeader_nav li {
    font-size: 18px;
  }
  .bl_siteHeader_nav li a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-block: 10px;
    padding-inline: 10px;
    font-weight: 500;
    height: 60px;
    line-height: 1.2;
    border-bottom: 1px solid #ccc;
  }
  .bl_siteHeader_nav .el_header_button a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 164px;
    height: 56px;
    padding: 10px;
    background-color: var(--main-color);
    color: #fff;
    margin-inline: auto;
  }
  .bl_siteHeader_nav .el_linkButton {
    color: #fff;
    height: 48px;
    max-width: 400px;
    width: 100%;
    margin-top: 20px;
    border-bottom: none;
    justify-content: center;
  }
  .bl_siteHeader_nav .el_linkButton.for_login {
    background-color: #4662a4;
    border-radius: 5px;
  }
  .bl_siteHeader_nav .el_linkButton.for_contact {
    background-color: var(--main-color);
    border-radius: 999px;
  }
}
@media screen and (min-width: 1241px) {
  .bl_siteHeader_nav {
    width: auto;
    display: flex;
    gap: 16px;
    align-items: center;
    justify-content: flex-end;
    margin-inline: auto;
  }
  .bl_siteHeader_nav a {
    transition: color 0.5s ease;
  }
  .bl_siteHeader_nav li.is_home_menu {
    display: none;
  }
  .bl_siteHeader_nav > li {
    width: auto;
    position: relative;
    font-size: var(--menu-fsz);
    font-weight: var(--fw-bold);
  }
  .bl_siteHeader_nav > li > a {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: center;
    line-height: 1.2;
    white-space: nowrap;
    height: 100%;
    position: relative;
    padding-inline: 15px;
    padding-inline: clamp(5px, -4.5313rem + 6.25vw, 15px);
    transition: opacity var(--transition-time);
  }
  .bl_siteHeader_nav > li > a:hover {
    opacity: 0.7;
  }
  .bl_siteHeader_nav .el_linkButton {
    color: #fff;
    height: 48px;
    max-width: 206px;
    max-width: clamp(150px, -74px + 17.5vw, 206px);
    width: 100vw;
  }
  .bl_siteHeader_nav .el_linkButton.for_login {
    background-color: #4662a4;
    border-radius: 5px;
  }
  .bl_siteHeader_nav .el_linkButton.for_contact {
    background-color: var(--main-color);
    border-radius: 999px;
  }
}

.el_siteHeader_mobile {
  gap: 15px;
  margin-bottom: 40px;
}
@media screen and (min-width: 1241px) {
  .el_siteHeader_mobile {
    display: none;
  }
}
.el_siteHeader_mobile .bl_ctaBuutons {
  grid-template-columns: 1fr;
  color: var(--text-color);
}
.el_siteHeader_mobile .el_linkButton {
  padding-left: 30px;
}
.el_siteHeader_mobile .el_linkButton::before {
  content: "";
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  display: block;
  width: 38px;
  height: 38px;
  position: absolute;
  left: 25px;
}

/* スライドメニューボタン */
@media screen and (min-width: 1241px) {
  .bl_menuToggleButton {
    display: none;
  }
}
.bl_menuToggleButton {
  z-index: 10;
  transition: all var(--transition-time) ease;
  right: 20px;
  top: 44px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  margin-left: auto;
}
.is_open .bl_menuToggleButton {
  background-color: transparent;
}
.bl_menuToggleButton .openbtn1 {
  position: relative; /*ボタン内側の基点となるためrelativeを指定*/
  width: 36px;
  height: 26px;
}
.bl_menuToggleButton {
  /*ボタン内側*/
}
.bl_menuToggleButton .openbtn1 span {
  display: inline-block;
  transition: all 0.4s;
  position: absolute;
  left: 0;
  height: 2px;
  background: #333;
  width: 100%;
}
.bl_menuToggleButton .openbtn1 span:nth-of-type(1) {
  top: 0;
}
.bl_menuToggleButton .openbtn1 span:nth-of-type(2) {
  top: 11px;
}
.bl_menuToggleButton .openbtn1 span:nth-of-type(3) {
  top: 22px;
}
.bl_menuToggleButton.is_open .openbtn1 span {
  background: var(--text-color);
}
.bl_menuToggleButton.is_open .openbtn1 span:nth-of-type(1) {
  transform: translateY(11px) rotate(-45deg);
}
.bl_menuToggleButton.is_open .openbtn1 span:nth-of-type(2) {
  left: 50%;
  opacity: 0;
  animation: active-btn05-bar02 0.8s forwards;
}
.bl_menuToggleButton.is_open .openbtn1 span:nth-of-type(3) {
  transform: translateY(-11px) rotate(45deg);
}

@keyframes active-btn05-bar02 {
  100% {
    height: 0;
  }
}
body.is_open {
  overflow: hidden;
}

@media screen and (min-width: 1241px) {
  .global-menu-toggle {
    display: none;
  }
}
.global-menu-toggle:before {
  content: "";
  background-image: url(../images/header/slide-menu-toggle.svg);
  background-repeat: no-repeat;
  background-size: contain;
  display: block;
  width: 20px;
  height: 20px;
  transition: transform var(--transition-time) ease;
}
.global-menu-toggle {
  cursor: pointer;
}
.global-menu-toggle.is-open::before {
  transform: rotate(180deg);
}

.overlay {
  position: fixed;
  top: var(--header-height);
  left: 0;
  width: 100%;
  height: calc(100% - var(--header-height));
  z-index: 0;
  visibility: hidden;
  opacity: 0;
  transition: all var(--transition-time);
}
.is_open .overlay {
  z-index: 1;
  background-color: #000;
  opacity: 0.5;
  visibility: visible;
}

.bl_siteFooter {
  display: flex;
  justify-content: center;
}

.bl_siteFooter_content {
  max-width: var(--site-width);
  width: 100%;
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 1080px) {
  .bl_siteFooter_content {
    flex-wrap: wrap;
    flex-direction: row;
  }
}
.bl_siteFooter_content {
  width: 100%;
  justify-content: space-between;
  margin-inline: auto;
  align-items: center;
  font-weight: var(--fw-bold);
  gap: 16px;
}
@media screen and (max-width: 767px) {
  .bl_siteFooter_content {
    justify-content: center;
  }
}
.bl_siteFooter_content .el_siteFooter_logoLink {
  flex-shrink: 0;
  width: 140px;
}
.bl_siteFooter_content .el_siteFooter_logo {
  flex-shrink: 0;
  width: 140px;
}
.bl_siteFooter_content > div {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
@media screen and (min-width: 768px) {
  .bl_siteFooter_content > div {
    gap: 8px;
    align-items: flex-end;
  }
}

ul.bl_siteFooter_menu {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-direction: column;
  font-size: 14px;
  color: #6c6c6c;
}
@media screen and (min-width: 768px) {
  ul.bl_siteFooter_menu {
    justify-content: flex-end;
    margin-top: 0;
    gap: 0;
    flex-direction: row;
  }
  ul.bl_siteFooter_menu li {
    line-height: 1.3;
    border-left: 1px solid;
    padding-inline: 7px;
  }
  ul.bl_siteFooter_menu li:first-child {
    border-left: none;
    padding-left: 0;
  }
}
ul.bl_siteFooter_menu a {
  transition: opacity var(--transidion);
}
@media (hover: hover) {
  ul.bl_siteFooter_menu a:hover {
    opacity: 0.7;
  }
}

.bl_siteFooter_copyRight {
  font-size: 12px;
  width: 100%;
  line-height: 1;
  font-weight: var(--fw-regular);
  font-size: 12px;
  line-height: 1.2;
  text-align: center;
  letter-spacing: 0.64px;
  color: #6c6c6c;
}
@media screen and (min-width: 1080px) {
  .bl_siteFooter_copyRight {
    text-align: right;
  }
}

.bl_goTopButton {
  opacity: 0;
  visibility: hidden;
  position: fixed;
  right: 0;
  bottom: 65px;
  z-index: 10;
  transition: all var(--transition);
  width: 54px;
  height: 54px;
  bottom: 0;
  right: 1.2em;
  background-color: var(--main-color);
  border-radius: 100%;
}
.bl_goTopButton.is_show {
  opacity: 1;
  visibility: visible;
  transform: translate(0, -50px);
}
.bl_goTopButton.is_stop {
  position: absolute;
}
@media (hover: hover) {
  .bl_goTopButton:hover {
    background-color: #4a90e2;
  }
}
.bl_goTopButton:active {
  background-color: #333333;
}
.bl_goTopButton::before {
  content: "";
  position: absolute;
  border-top: solid 3px #fff;
  border-right: solid 3px #fff;
  transform: rotate(-45deg);
  width: 14px;
  height: 14px;
  top: 21px;
  right: 20px;
}
@media screen and (min-width: 1080px) {
  .bl_goTopButton::before {
    width: 16px;
    height: 16px;
    top: 21px;
    right: 19px;
  }
}

.bl_main {
  --section-pt: 48px;
  --section-pb: 48px;
  --h2-circle-top: -18px;
  --h2-circle-left: -20px;
  --h2-circle-size: 80px;
}
@media screen and (min-width: 1080px) {
  .bl_main {
    --section-pt: 100px;
    --section-pb: 100px;
    --h2-circle-top: -25px;
    --h2-circle-left: -60px;
    --h2-circle-size: 120px;
  }
}
.bl_main {
  --h2-linge-height: 1.5;
  --h2-color: #163e7b;
}
.bl_main > section {
  padding-inline: var(--site-inline-padding);
  padding-block: var(--section-pt) var(--section-pb);
}
.bl_main > section .ly_sectionInner {
  margin-inline: auto;
  max-width: var(--content-width);
  width: 100%;
}
.bl_main > section.is_wide_width .ly_sectionInner {
  --content-width: 1312px;
}
.bl_main > section.has_bg_color {
  background-color: var(--bg-sub-color);
  padding-top: 80px;
}
@media screen and (min-width: 1080px) {
  .bl_main > section.has_bg_color {
    padding-top: 105px;
  }
}
.bl_main > section.has_bg_color .ly_sectionInner {
  margin-top: 0;
}
.bl_main > section h2 {
  font-weight: 900;
  line-height: var(--h2-linge-height);
  color: var(--h2-color);
  font-size: 28px;
  position: relative;
}
@media screen and (min-width: 1080px) {
  .bl_main > section h2 {
    font-size: 36px;
  }
}
.bl_main > section h2 .is_orange {
  color: #fb7200;
}
.bl_main > section h2 .el_h2_subCopy {
  font-size: 24px;
  line-height: 130%;
  display: block;
}
.bl_main > section h2.has_bg_circle::before {
  content: "";
  position: absolute;
  width: var(--h2-circle-size);
  height: var(--h2-circle-size);
  background-color: #f1f4f7;
  border-radius: 100%;
  z-index: -1;
  top: var(--h2-circle-top);
  left: var(--h2-circle-left);
}
@media screen and (min-width: 1080px) {
  .bl_main > section h2.has_bg_circle::before {
    width: var(--h2-circle-size);
    height: var(--h2-circle-size);
    top: var(--h2-circle-top);
    left: var(--h2-circle-left);
  }
}

.bl_main {
  overflow: hidden;
}

div.el_heading_full,
h2.el_heading_full {
  text-align: center;
  font-size: 28px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1;
  font-weight: var(--fw-bold);
  color: #fff;
  background-color: var(--main-color);
  min-height: 90px;
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
}
@media screen and (min-width: 1080px) {
  div.el_heading_full,
  h2.el_heading_full {
    min-height: 240px;
  }
}
div.el_heading_full::after,
h2.el_heading_full::after {
  content: "";
  border-style: solid solid none;
  border-color: var(--main-color) transparent transparent;
  position: absolute;
  border-width: 25px 70px 0px;
  bottom: -22px;
}
@media screen and (min-width: 1080px) {
  div.el_heading_full::after,
  h2.el_heading_full::after {
    border-width: 74px 190px 0px;
    bottom: -70px;
  }
}
div.el_heading_full::after,
h2.el_heading_full::after {
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (min-width: 1080px) {
  div.el_heading_full,
  h2.el_heading_full {
    font-size: 70px;
  }
}

h2.el_heading_subtext {
  text-align: center;
  font-size: 36px;
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1;
  font-weight: var(--fw-bold);
}
h2.el_heading_subtext span {
  margin-top: 10px;
  font-size: 12px;
}
@media screen and (min-width: 1080px) {
  h2.el_heading_subtext {
    font-size: 52px;
  }
  h2.el_heading_subtext span {
    margin-top: 15px;
    font-size: 24px;
  }
}

.bl_mv {
  height: auto;
  overflow: hidden;
  padding-block: 40px 74px;
  padding-inline: 24px;
  background-position: bottom center;
  background-size: 100% auto;
  position: relative;
  z-index: 1;
}
.bl_mv::before {
  background-color: var(--main-color);
  clip-path: polygon(0% 0%, 100% 0%, 100% calc(100% - 275px), 0% 100%);
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
}
@media screen and (min-width: 1080px) {
  .bl_mv {
    padding-block: 60px 74px;
  }
  .bl_mv::before {
    clip-path: polygon(0% 0%, calc(100% - 3.4722222222vw) 0%, calc(100% - 33.3333333333vw) 100%, 0% 100%);
  }
}
.bl_mv .bl_mv_inner {
  max-width: 1312px;
  position: relative;
  margin-inline: auto;
}
.bl_mv .bl_mv_mediaText {
  color: #fff;
  gap: 24px;
}
@media screen and (min-width: 1080px) {
  .bl_mv .bl_mv_mediaText {
    gap: 0;
    grid-template-columns: 55% 45%;
  }
}
@media screen and (min-width: 1241px) {
  .bl_mv .bl_mv_mediaText {
    grid-template-columns: 50% 50%;
  }
}
.bl_mv .bl_mv_mediaText .bl_mv_mediaText_content {
  width: fit-content;
  margin-inline: auto;
}
.bl_mv .bl_mv_mediaText .el_subCopy {
  font-weight: 900;
  font-size: 29px;
  line-height: 1.3;
  color: rgba(255, 255, 255, 0.8);
}
@media screen and (min-width: 1080px) {
  .bl_mv .bl_mv_mediaText .el_subCopy {
    font-size: 28px;
    white-space: nowrap;
  }
}
.bl_mv .bl_mv_mediaText .el_mainCopy {
  margin-top: 16px;
  font-weight: 900;
  line-height: 1.5;
  letter-spacing: 0.05em;
  text-shadow: 0px 0px 16px #163e7b;
  white-space: nowrap;
  font-size: 38px;
}
@media screen and (min-width: 1080px) {
  .bl_mv .bl_mv_mediaText .el_mainCopy {
    font-size: 48px;
  }
}
.bl_mv .bl_mv_mediaText .el_mainCopy span {
  color: #ff9e4d;
}
.bl_mv .bl_mv_mediaText .el_mainCopy + p {
  margin-top: 16px;
  font-weight: 500;
  font-size: 18px;
  line-height: 180%;
  color: rgba(255, 255, 255, 0.8);
  max-width: 567px;
}
.bl_mv .bl_mv_mediaText .el_linkButton {
  margin-top: 32px;
  padding: 24px 48px;
  width: 306px;
  height: 70px;
  border-radius: 8px;
  font-size: 20px;
  line-height: 1;
  margin-inline: auto;
}
@media screen and (min-width:520px) {
  .bl_mv .bl_mv_mediaText .el_linkButton {
    margin-inline: 0 auto;
  }
}
.bl_mv .bl_mv_mediaText .el_linkButton::after {
  width: 18px;
  height: 20px;
}
.bl_mv .bl_mv_mediaText .el_note {
  font-weight: 400;
  font-size: 14px;
  line-height: 140%;
  margin-top: 14px;
  display: flex;
  text-shadow: 0 0 3px var(--main-color);
}
.bl_mv .bl_mv_mediaText .el_note::before {
  content: "";
  content: "";
  background-image: url(../images/icon-check-white.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 14px;
  height: 14px;
  display: inline-block;
  margin-right: 4px;
  margin-top: 3px;
}
.bl_mv figure {
  align-self: flex-end;
  text-align: center;
  display: grid;
  grid-template-columns: 1fr;
}
.bl_mv figure > img {
  grid-column: 1/-1;
  grid-row: 1/-1;
}
.bl_mv .el_linkScroll {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  animation-delay: 4.5s;
}
.bl_mv .el_linkScroll a {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.49;
  align-items: center;
  letter-spacing: 0.2em;
  color: #163e7b;
  animation: floatY 1s ease-out infinite alternate-reverse;
}
@media screen and (min-width: 1080px) {
  .bl_mv .el_linkScroll a {
    color: #fff;
  }
}
.bl_mv .el_linkScroll a::after {
  content: "";
  content: "";
  background-image: url(../images/mv-scroll.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 13px;
  height: 14px;
  display: inline-block;
  margin-right: 4px;
  margin-top: 3px;
}
@media screen and (min-width: 1080px) {
  .bl_mv .el_linkScroll a::after {
    filter: brightness(15);
  }
}

.bl_problem {
  --section-pb: 0;
}
.bl_problem .bl_mediaText.is_heading {
  gap: 20px;
}
@media screen and (min-width: 768px) {
  .bl_problem .bl_mediaText.is_heading {
    grid-template-columns: 1fr 288px;
    gap: 10px;
    align-items: center;
  }
}
@media screen and (min-width: 768px) {
  .bl_problem .bl_mediaText.is_heading .bl_mediaText_content {
    padding-left: 66px;
  }
}
.bl_problem .bl_mediaText.is_heading .bl_mediaText_content p {
  margin-top: 24px;
  max-width: 650px;
  font-weight: 700;
  font-size: 18px;
  line-height: 180%;
}
.bl_problem .bl_mediaText.is_heading figure {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .bl_problem .bl_mediaText.is_heading figure img {
    max-width: 400px;
    width: 100%;
  }
}
.bl_problem .bl_problem_items {
  max-width: 1200px;
  margin-inline: auto;
  display: grid;
  padding-bottom: 34px;
  grid-template-columns: 1fr;
  gap: 50px;
  margin-top: 32px;
}
@media screen and (min-width: 768px) {
  .bl_problem .bl_problem_items {
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    margin-top: 48px;
    align-items: flex-start;
  }
}
@media screen and (min-width: 1080px) {
  .bl_problem .bl_problem_items {
    gap: 40px;
  }
}
.bl_problem .bl_problem_items li.el_problem_item {
  padding: 32px;
}
@media screen and (min-width: 768px) {
  .bl_problem .bl_problem_items li.el_problem_item {
    padding: 32px 16px;
  }
}
@media screen and (min-width: 1080px) {
  .bl_problem .bl_problem_items li.el_problem_item {
    padding: 32px;
  }
}
.bl_problem .bl_problem_items li.el_problem_item {
  gap: 0;
  background: #f2f2f2;
  border-radius: 8px 8px 0px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}
.bl_problem .bl_problem_items li.el_problem_item figure {
  height: 150px;
}
.bl_problem .bl_problem_items li.el_problem_item .el_problem_index {
  font-weight: 700;
  font-size: 20px;
  line-height: 125%;
  color: #163e7b;
  margin-top: 8px;
}
.bl_problem .bl_problem_items li.el_problem_item ul {
  margin-top: 24px;
}
.bl_problem .bl_problem_items li.el_problem_item ul li {
  display: flex;
  font-weight: 400;
  font-size: 14px;
  line-height: 120%;
  gap: 4px;
}
.bl_problem .bl_problem_items li.el_problem_item ul li + li {
  margin-top: 10px;
}
.bl_problem .bl_problem_items li.el_problem_item ul li::before {
  content: "";
  content: "";
  background-image: url(../images/icon-problem.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 14px;
  height: 14px;
  display: inline-block;
  margin-top: 2px;
}
.bl_problem .bl_problem_items li.el_problem_item .el_accordion {
  display: none;
}
.bl_problem .bl_problem_items li.el_problem_item .el_accordion .el_accordion_inner {
  transition: margin-top 0.1s ease;
  padding: 16px;
  background: #ffffff;
  border-radius: 4px;
  font-weight: 400;
  font-size: 16px;
  line-height: 170%;
  color: #333333;
  margin-top: 24px;
}
.bl_problem .bl_problem_items li.el_problem_item .el_accordion_tab {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  padding: 8px 16px;
  gap: 4px;
  width: 151px;
  height: 34px;
  background: #c8d2e0;
  border-radius: 0px 0px 8px 8px;
  position: absolute;
  bottom: -34px;
  right: 0;
  --transition-time: 0.1s;
  transition: all var(--transition);
}
.bl_problem .bl_problem_items li.el_problem_item .el_accordion_tab span::before {
  content: "詳しい解説を見る";
  font-weight: 700;
  font-size: 12px;
  line-height: 146%;
  color: #163e7b;
  transition: all var(--transition);
}
.bl_problem .bl_problem_items li.el_problem_item .el_accordion_tab span::after {
  content: "";
  content: "";
  background-image: url(../images/icon-accordion-arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 14px;
  height: 7px;
  display: inline-block;
  margin-left: 4px;
  transition: all var(--transition);
}
@media (hover: hover) {
  .bl_problem .bl_problem_items li.el_problem_item .el_accordion_tab:hover {
    background: #4a90e2 !important;
  }
  .bl_problem .bl_problem_items li.el_problem_item .el_accordion_tab:hover span::after {
    filter: brightness(0) invert(1);
  }
  .bl_problem .bl_problem_items li.el_problem_item .el_accordion_tab:hover span::before {
    color: #fff;
  }
}
.bl_problem .bl_problem_items li.el_problem_item .el_accordion_tab:active {
  background: var(--main-color) !important;
}
.bl_problem .bl_problem_items li.el_problem_item .el_accordion_tab:active span::after {
  filter: brightness(0) invert(1);
}
.bl_problem .bl_problem_items li.el_problem_item .el_accordion_tab:active span::before {
  color: #fff;
}
.bl_problem .bl_problem_items li.el_problem_item .is_open + .el_accordion_tab {
  background-color: #e4e8ef;
}
.bl_problem .bl_problem_items li.el_problem_item .is_open + .el_accordion_tab span::before {
  content: "閉じる";
}
.bl_problem .bl_problem_items li.el_problem_item .is_open + .el_accordion_tab span::after {
  transform: rotate(180deg);
}
.bl_problem .bl_answer {
  padding-inline: var(--site-inline-padding);
  padding-block: 64px 32px;
  position: relative;
  margin-top: 32px;
  background: rgba(22, 62, 123, 0.1);
}
@media screen and (min-width: 1080px) {
  .bl_problem .bl_answer {
    margin-top: 80px;
    padding-block: 22px 25px;
    background: #ff9e4d;
  }
}
.bl_problem .bl_answer::before {
  content: "";
  content: "";
  background-image: url(../images/arrow-section.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 168px;
  height: 56px;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.bl_problem .bl_answer .bl_mediaText {
  max-width: 900px;
  margin-inline: auto;
  gap: 32px;
}
@media screen and (min-width: 1080px) {
  .bl_problem .bl_answer .bl_mediaText {
    gap: 48px;
    grid-template-columns: 1fr 241px;
    align-items: center;
  }
}
.bl_problem .bl_answer .bl_mediaText p {
  display: flex;
  flex-direction: column;
  font-weight: 900;
  text-align: center;
  color: #333333;
  font-size: 24px;
  gap: 14px;
  line-height: 1.2;
}
.bl_problem .bl_answer .bl_mediaText p span {
  font-size: 32px;
  color: #4a90e2;
  line-height: 1.3;
}
@media screen and (min-width: 1080px) {
  .bl_problem .bl_answer .bl_mediaText p {
    text-align: left;
  }
  .bl_problem .bl_answer .bl_mediaText p span {
    color: #ffffff;
  }
}

.bl_about {
  --content-width: 1200px;
  --section-pb: 48px;
}
.bl_about h2 {
  --h2-linge-height: 1.3;
}
.bl_about h2 + p {
  margin-top: 22px;
  font-weight: 700;
  font-size: 18px;
  line-height: 180%;
}
@media screen and (min-width: 768px) {
  .bl_about h2 + p {
    text-align: center;
  }
}
.bl_about h2 .is_underline::after {
  background-image: url(../images/about-ul.svg);
}
.bl_about .bl_about_image {
  margin-top: 40px;
  text-align: center;
  background-image: linear-gradient(to bottom, #fff 0%, #fff 11%, #91a4c1 11%, #91a4c1 100%);
}
.bl_about .bl_about_image figure {
  width: fit-content;
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
}
.bl_about .bl_about_image figure > img {
  grid-column: 1/-1;
  grid-row: 1/-1;
}
.bl_about .bl_about_image figure > img:first-child {
  animation-delay: 0.5s;
}
.bl_about .bl_about_image figure > img:nth-child(2) {
  animation-delay: 1s;
}
.bl_about .bl_about_image figure > img:nth-child(3) {
  animation-delay: 1.5s;
}
.bl_about .bl_about_image figure > img:nth-child(4) {
  animation-delay: 3.5s;
}
.bl_about .bl_about_image figure > img:nth-child(5) {
  animation-delay: 2s;
}
.bl_about .bl_about_image figure > img:nth-child(6) {
  animation-delay: 2.5s;
}
.bl_about .el_copy {
  margin-top: 40px;
  font-weight: 900;
  line-height: 160%;
  text-align: center;
  font-size: 26px;
}
@media screen and (min-width: 1080px) {
  .bl_about .el_copy {
    font-size: 32px;
  }
}

.bl_cta {
  background-color: var(--main-color);
  color: #fff;
  --section-pt: 48px;
  --section-pb: 0;
  --content-width: 1358px;
}
@media screen and (min-width: 1080px) {
  .bl_cta {
    --section-pt: 64px;
    --section-pb: 64px;
  }
}
.bl_cta .ly_sectionInner {
  position: relative;
}
.bl_cta h2 {
  --h2-color: var(--sub-color-2);
  --h2-linge-height: 1.2;
}
.bl_cta h2 + p {
  margin-top: 28px;
  font-weight: 700;
  font-size: 18px;
  line-height: 180%;
  text-align: center;
}
.bl_cta h2 + p .is_orange {
  color: #ff9e4d;
}
.bl_cta p {
  font-weight: 500;
  font-size: 16px;
  line-height: 180%;
  text-align: center;
}
.bl_cta p + p {
  margin-top: 20px;
}
.bl_cta .el_linkButton {
  padding: 32px 64px;
  width: 338px;
  height: 84px;
  border-radius: 8px;
  font-size: 20px;
  margin-top: 36px;
  margin-inline: auto;
}
.bl_cta .el_linkButton::after {
  width: 18px;
  height: 20px;
  animation: floatX 0.6s ease-out infinite alternate-reverse;
}
.bl_cta figure {
  text-align: center;
  margin-top: 24px;
  max-width: 200px;
  margin-inline: auto;
}
@media screen and (min-width: 1080px) {
  .bl_cta figure {
    max-width: none;
    position: absolute;
    bottom: calc(-1 * var(--section-pb));
  }
  .bl_cta figure.is_right_side {
    right: 0;
  }
  .bl_cta figure.is_left_side {
    left: 0;
  }
}
@media screen and (min-width: 1080px) and (min-width: 1080px) {
  .bl_cta figure.is_left_side {
    width: clamp(220px, -47.13px + 26.087vw, 292px);
  }
}

.bl_feature {
  --content-width: 1312px;
}
.bl_feature h2 .is_underline::after {
  left: -7px;
  width: 107%;
  background-image: url(../images/feature-ul.svg);
}
.bl_feature h2 + p {
  font-weight: 700;
  font-size: 18px;
  line-height: 180%;
  text-align: center;
  margin-top: 28px;
}
.bl_feature .bl_feature_list {
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: 32px;
}
@media screen and (min-width: 768px) {
  .bl_feature .bl_feature_list {
    margin-top: 48px;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    align-items: flex-start;
  }
}
@media screen and (min-width: 1080px) {
  .bl_feature .bl_feature_list {
    gap: 32px;
  }
}
.bl_feature .bl_feature_list > li {
  display: flex;
  flex-direction: column;
  padding: 24px;
  gap: 0;
  background: #f1f4f7;
  border-radius: 8px;
}
@media screen and (min-width: 768px) {
  .bl_feature .bl_feature_list > li {
    padding: 16px;
    min-height: 500px;
  }
}
@media screen and (min-width: 1080px) {
  .bl_feature .bl_feature_list > li {
    padding: 32px;
    min-height: 563px;
  }
}
.bl_feature .bl_feature_list > li figure {
  height: 70px;
  text-align: center;
}
.bl_feature .bl_feature_list > li h3 {
  margin-top: 16px;
  font-weight: 700;
  font-size: 20px;
}
@media screen and (min-width: 768px) {
  .bl_feature .bl_feature_list > li h3 {
    font-size: 14px;
  }
}
@media screen and (min-width: 1080px) {
  .bl_feature .bl_feature_list > li h3 {
    font-size: 20px;
  }
}
.bl_feature .bl_feature_list > li h3 {
  line-height: 130%;
  text-align: center;
  color: #163e7b;
  border-bottom: 1px solid var(--main-color);
  padding-bottom: 24px;
  width: 100%;
}
.bl_feature .bl_feature_list > li > ul {
  margin-top: 32px;
}
.bl_feature .bl_feature_list > li > ul li {
  font-weight: 700;
  font-size: 16px;
}
@media screen and (min-width: 768px) {
  .bl_feature .bl_feature_list > li > ul li {
    font-size: 14px;
  }
}
@media screen and (min-width: 1080px) {
  .bl_feature .bl_feature_list > li > ul li {
    font-size: 16px;
  }
}
.bl_feature .bl_feature_list > li > ul li {
  line-height: 130%;
  display: flex;
  letter-spacing: 0.64px;
  gap: 11px;
  padding-left: 7px;
}
.bl_feature .bl_feature_list > li > ul li + li {
  margin-top: 12px;
}
.bl_feature .bl_feature_list > li > ul li::before {
  content: "";
  background-color: var(--accent-color);
  width: 8px;
  height: 8px;
  border-radius: 100%;
  display: inline-block;
  margin-top: 8px;
  flex-shrink: 0;
}
.bl_feature .bl_feature_list > li .el_benefit {
  margin-top: 32px;
  border-radius: 4px;
  overflow: hidden;
}
.bl_feature .bl_feature_list > li .el_benefit .el_benefit_title {
  height: 37px;
  padding: 4px 16px;
  line-height: 130%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #ffffff;
  background: #163e7b;
  font-weight: 700;
  font-size: 16px;
}
@media screen and (min-width: 768px) {
  .bl_feature .bl_feature_list > li .el_benefit .el_benefit_title {
    font-size: 14px;
  }
}
@media screen and (min-width: 1080px) {
  .bl_feature .bl_feature_list > li .el_benefit .el_benefit_title {
    font-size: 16px;
  }
}
.bl_feature .bl_feature_list > li .el_benefit ul {
  padding: 16px;
  background: #ffffff;
}
.bl_feature .bl_feature_list > li .el_benefit ul li {
  font-weight: 700;
  font-size: 16px;
}
@media screen and (min-width: 768px) {
  .bl_feature .bl_feature_list > li .el_benefit ul li {
    font-size: 14px;
  }
}
@media screen and (min-width: 1080px) {
  .bl_feature .bl_feature_list > li .el_benefit ul li {
    font-size: 16px;
  }
}
.bl_feature .bl_feature_list > li .el_benefit ul li {
  line-height: 130%;
  display: flex;
  gap: 6px;
  padding-left: 4px;
}
.bl_feature .bl_feature_list > li .el_benefit ul li::before {
  content: "";
  content: "";
  background-image: url(../images/icon-check-orange.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 14px;
  height: 14px;
  display: inline-block;
  margin-top: 4px;
  flex-shrink: 0;
}
.bl_feature .bl_feature_list > li .el_benefit ul li + li {
  margin-top: 12px;
}
.bl_feature .bl_feature_list .el_accordion {
  display: none;
}
.bl_feature .bl_feature_list .el_accordion .el_accordion_inner {
  transition: margin-top 0.1s ease;
  font-weight: 500;
  font-size: 16px;
}
@media screen and (min-width: 768px) {
  .bl_feature .bl_feature_list .el_accordion .el_accordion_inner {
    font-size: 14px;
  }
}
@media screen and (min-width: 1080px) {
  .bl_feature .bl_feature_list .el_accordion .el_accordion_inner {
    font-size: 16px;
  }
}
.bl_feature .bl_feature_list .el_accordion .el_accordion_inner {
  line-height: 180%;
  color: #163e7b;
  margin-block: 24px;
  margin-inline: 16px;
}
.bl_feature .bl_feature_list .el_accordion_tab {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  padding: 8px 16px;
  gap: 4px;
  width: 100%;
  height: 42px;
  --transition-time: 0.1s;
  transition: all var(--transition);
}
.bl_feature .bl_feature_list .el_accordion_tab span::before {
  content: "詳しい解説を見る";
  font-weight: 700;
  font-size: 14px;
  line-height: 17.5px;
  color: #163e7b;
  transition: all var(--transition);
}
.bl_feature .bl_feature_list .el_accordion_tab span::after {
  content: "";
  content: "";
  background-image: url(../images/icon-accordion-arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 14px;
  height: 7px;
  display: inline-block;
  margin-left: 4px;
  transition: all var(--transition);
  vertical-align: 2px;
}
@media (hover: hover) {
  .bl_feature .bl_feature_list .el_accordion_tab:hover span::after {
    filter: brightness(2.2);
  }
  .bl_feature .bl_feature_list .el_accordion_tab:hover span::before {
    color: #4a90e2;
  }
}
.bl_feature .bl_feature_list .el_accordion_tab:active span::after {
  filter: brightness(0);
}
.bl_feature .bl_feature_list .el_accordion_tab:active span::before {
  color: var(--text-color);
}
.bl_feature .bl_feature_list .is_open + .el_accordion_tab span::before {
  content: "閉じる";
}
.bl_feature .bl_feature_list .is_open + .el_accordion_tab span::after {
  transform: rotate(180deg);
}

.bl_reason {
  background-color: #f1f4f7;
}
@media screen and (min-width: 1080px) {
  .bl_reason {
    background-repeat: no-repeat;
    background-position: right top -12.5px, left top -12.5px;
    background-size: 307px auto, 307px auto;
    background-image: url(../images/reason-bg-right.png), url(../images/reason-bg-left.png);
  }
}
@media screen and (max-width: 1079px) {
  .bl_reason h2 .is_underline::after {
    content: none;
  }
}
.bl_reason h2 .is_underline::after {
  background-image: url(../images/reason-ul.svg);
}
@media screen and (max-width: 1079px) {
  .bl_reason h2 .is_underline_sp_1,
  .bl_reason h2 .is_underline_sp_2 {
    position: relative;
    display: block;
  }
  .bl_reason h2 .is_underline_sp_1::after,
  .bl_reason h2 .is_underline_sp_2::after {
    content: "";
    position: absolute;
    bottom: -7px;
    left: 0;
    width: 100%;
    background-image: url(../images/reason-ul-sp-1.svg);
    background-repeat: no-repeat;
    background-size: contain;
    height: 10px;
    background-position: center;
  }
  .bl_reason h2 .is_underline_sp_2::after {
    background-image: url(../images/reason-ul-sp-2.svg);
  }
}
.bl_reason h2 + p {
  margin-top: 28px;
  font-weight: 700;
  font-size: 18px;
  line-height: 180%;
  text-align: center;
}
.bl_reason ul.bl_reason_list {
  margin-top: 48px;
}
@media screen and (min-width: 1080px) {
  .bl_reason ul.bl_reason_list {
    margin-top: 64px;
  }
}
.bl_reason ul.bl_reason_list li {
  padding: 56px 24px 24px;
  background: #ffffff;
  border-radius: 8px 8px 0px 0px;
  position: relative;
}
.bl_reason ul.bl_reason_list li + li {
  margin-top: 32px;
}
.bl_reason ul.bl_reason_list li h3 {
  display: flex;
  align-items: center;
  padding: 13px 18px 14px;
  border-radius: 8px 0 0 0;
  width: 204px;
  height: 48px;
  background: #4a90e2;
  font-weight: 700;
  font-size: 20px;
  line-height: 102%;
  color: #ffffff;
  position: absolute;
  left: 0;
  top: -10px;
}
.bl_reason ul.bl_reason_list li h3::before {
  content: "";
  display: inline-block;
  flex-shrink: 0;
}
.bl_reason ul.bl_reason_list li h3::after {
  content: "";
  content: "";
  background-image: url(../images/reason-ribbon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 12px;
  height: 48px;
  position: absolute;
  top: 0;
  right: -12px;
}
.bl_reason ul.bl_reason_list li:first-child h3::before {
  content: "";
  background-image: url(../images/icon-reason-1.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 26px;
  height: 16px;
}
.bl_reason ul.bl_reason_list li:nth-child(2) h3::before {
  content: "";
  background-image: url(../images/icon-reason-2.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 26px;
  height: 20px;
}
.bl_reason ul.bl_reason_list li:nth-child(3) h3::before {
  content: "";
  background-image: url(../images/icon-reason-3.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 29px;
  height: 17px;
}
.bl_reason ul.bl_reason_list li .bl_mediaText {
  gap: 23px;
}
@media screen and (min-width: 768px) {
  .bl_reason ul.bl_reason_list li .bl_mediaText {
    grid-template-columns: 1fr 240px;
  }
}
.bl_reason ul.bl_reason_list li p.el_reason_copy {
  font-weight: 700;
  font-size: 20px;
  line-height: 125%;
}
.bl_reason ul.bl_reason_list li p.el_reason_copy + p {
  margin-top: 23px;
  margin-bottom: 8px;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.7;
  text-align: justify;
}
.bl_reason ul.bl_reason_list .el_accordion {
  display: none;
}
.bl_reason ul.bl_reason_list .el_accordion .el_accordion_inner {
  transition: margin-top 0.1s ease;
  padding: 16px;
  background: #f1f4f7;
  border-radius: 4px 4px 0 0;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.7;
}
.bl_reason ul.bl_reason_list .el_accordion_tab {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  padding: 8px 16px;
  gap: 4px;
  width: 100%;
  height: 50px;
  background: #e4e8ef;
  border-radius: 4px;
  --transition-time: 0.1s;
  transition: all var(--transition);
}
.bl_reason ul.bl_reason_list .el_accordion_tab span::before {
  content: "なぜ価値があるのか？";
  font-weight: 700;
  font-size: 14px;
  line-height: 146%;
  color: #163e7b;
  transition: all var(--transition);
}
.bl_reason ul.bl_reason_list .el_accordion_tab span::after {
  content: "";
  content: "";
  background-image: url(../images/icon-accordion-arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 14px;
  height: 7px;
  display: inline-block;
  margin-left: 4px;
  transition: all var(--transition);
}
@media (hover: hover) {
  .bl_reason ul.bl_reason_list .el_accordion_tab:hover {
    background: #4a90e2 !important;
  }
  .bl_reason ul.bl_reason_list .el_accordion_tab:hover span::after {
    filter: brightness(0) invert(1);
  }
  .bl_reason ul.bl_reason_list .el_accordion_tab:hover span::before {
    color: #fff;
  }
}
.bl_reason ul.bl_reason_list .el_accordion_tab:active {
  background: #333 !important;
}
.bl_reason ul.bl_reason_list .el_accordion_tab:active span::after {
  filter: brightness(0) invert(1);
}
.bl_reason ul.bl_reason_list .el_accordion_tab:active span::before {
  color: #fff;
}
.bl_reason ul.bl_reason_list .is_open + .el_accordion_tab {
  background-color: #e4e8ef;
  border-radius: 0 0 4px 4px;
}
.bl_reason ul.bl_reason_list .is_open + .el_accordion_tab span::before {
  content: "閉じる";
}
.bl_reason ul.bl_reason_list .is_open + .el_accordion_tab span::after {
  transform: rotate(180deg);
}

.bl_caseStudy .bl_mediaText.is_heading {
  --h2-circle-size: 120px;
  --h2-circle-left: 0;
  --h2-circle-top: -24px;
  gap: 24px;
}
@media screen and (min-width: 768px) {
  .bl_caseStudy .bl_mediaText.is_heading {
    --h2-circle-top: -14px;
    --h2-circle-left: -60px;
  }
}
@media screen and (min-width: 768px) {
  .bl_caseStudy .bl_mediaText.is_heading {
    grid-template-columns: 1fr 210px;
    gap: 10px;
    align-items: center;
  }
}
.bl_caseStudy .bl_mediaText.is_heading h2 .is_underline::after {
  background-image: url(../images/casestudy-ul.svg);
}
@media screen and (max-width: 767px) {
  .bl_caseStudy .bl_mediaText.is_heading h2 {
    padding-left: 66px;
  }
}
@media screen and (min-width: 768px) {
  .bl_caseStudy .bl_mediaText.is_heading .bl_mediaText_content {
    padding-left: 66px;
  }
}
.bl_caseStudy .bl_mediaText.is_heading .bl_mediaText_content p {
  margin-top: 24px;
  max-width: 650px;
  font-weight: 700;
  font-size: 18px;
  line-height: 180%;
}
.bl_caseStudy .bl_mediaText.is_heading figure img {
  max-width: 327px;
  width: 100%;
}
.bl_caseStudy ul.bl_caseStudy_list {
  margin-top: 48px;
  margin-bottom: 34px;
}
@media screen and (min-width: 1080px) {
  .bl_caseStudy ul.bl_caseStudy_list {
    margin-top: 48px;
  }
}
.bl_caseStudy ul.bl_caseStudy_list > li {
  position: relative;
}
.bl_caseStudy ul.bl_caseStudy_list > li + li {
  margin-top: 58px;
}
.bl_caseStudy ul.bl_caseStudy_list .bl_columns {
  display: grid;
  grid-template-columns: 1fr;
  gap: 25px;
  padding: 16px;
  background-color: #f1f4f7;
  border-radius: 8px 8px 0 0;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .bl_caseStudy ul.bl_caseStudy_list .bl_columns {
    grid-template-columns: 270px 1fr;
  }
}
.bl_caseStudy ul.bl_caseStudy_list .bl_columns .bl_column.is_balloon {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 24px 40px 26px;
  /* black */
  background: #333333;
  border-radius: 4px;
  font-weight: 900;
  font-size: 18px;
  line-height: 180%;
  text-align: center;
  color: #ffffff;
}
.bl_caseStudy ul.bl_caseStudy_list .bl_columns .bl_column.is_balloon span.el_quote_left {
  position: absolute;
  top: 7px;
  left: 8px;
  font-size: 32px;
}
.bl_caseStudy ul.bl_caseStudy_list .bl_columns .bl_column.is_balloon span.el_quote_right {
  position: absolute;
  bottom: 0;
  right: 8px;
  font-size: 32px;
}
@media screen and (min-width: 1080px) {
  .bl_caseStudy ul.bl_caseStudy_list .bl_columns .bl_column.is_balloon::after {
    content: "";
    border-style: solid none solid solid;
    border-color: transparent transparent transparent #333333;
    border-width: 20px 0px 20px 20px;
    position: absolute;
    right: -15px;
    top: 50%;
    transform: translateY(-50%);
  }
}
.bl_caseStudy ul.bl_caseStudy_list .bl_measures {
  padding: 16px;
  background: #e4e8ef;
  border-radius: 0 0 0 8px;
}
.bl_caseStudy ul.bl_caseStudy_list .bl_measures .el_measures_label {
  font-weight: 700;
  font-size: 18px;
  line-height: 1.11;
  text-align: center;
  color: #163e7b;
  padding-bottom: 10px;
  border-bottom: 2px solid rgba(22, 62, 123, 0.3);
}
.bl_caseStudy ul.bl_caseStudy_list .bl_measures ul {
  margin-top: 16px;
  display: flex;
  gap: 12px;
  flex-direction: column;
}
@media screen and (min-width:520px) {
  .bl_caseStudy ul.bl_caseStudy_list .bl_measures ul {
    gap: 24px;
    flex-direction: row;
  }
}
.bl_caseStudy ul.bl_caseStudy_list .bl_measures ul li {
  flex-grow: 1;
  flex-shrink: 1;
  display: flex;
  align-items: center;
  font-weight: 700;
  font-size: 14px;
  line-height: 1.7;
  align-items: center;
  color: #163e7b;
  gap: 6px;
  flex-direction: row;
}
@media screen and (min-width:520px) {
  .bl_caseStudy ul.bl_caseStudy_list .bl_measures ul li {
    flex-direction: column;
    text-align: center;
  }
}
.bl_caseStudy ul.bl_caseStudy_list .bl_measures ul li::before {
  content: "";
  content: "";
  background-image: url(../images/icon-check-blue.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 32px;
  height: 32px;
  display: inline-block;
}
@media screen and (max-width:521px) {
  .bl_caseStudy ul.bl_caseStudy_list .bl_measures ul li br {
    display: none;
  }
}
.bl_caseStudy ul.bl_caseStudy_list .is_open .bl_measures {
  border-radius: 0;
}
.bl_caseStudy ul.bl_caseStudy_list .el_accordion {
  display: none;
}
.bl_caseStudy ul.bl_caseStudy_list .el_accordion .el_accordion_inner {
  transition: margin-top 0.1s ease;
  padding: 24px;
  background: var(--main-color);
  color: #fff;
  border-radius: 0 0 0 4px;
  font-weight: 400;
  font-size: 16px;
  line-height: 180%;
}
.bl_caseStudy ul.bl_caseStudy_list .el_accordion .el_accordion_inner p + p {
  margin-top: 12px;
}
.bl_caseStudy ul.bl_caseStudy_list .el_accordion_tab {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  padding: 8px 16px;
  gap: 4px;
  width: 151px;
  height: 34px;
  background: var(--main-color);
  border-radius: 0px 0px 8px 8px;
  position: absolute;
  bottom: -34px;
  right: 0;
  --transition-time: 0.1s;
  transition: all var(--transition);
}
.bl_caseStudy ul.bl_caseStudy_list .el_accordion_tab span::before {
  content: "詳しい解説を見る";
  font-weight: 700;
  font-size: 12px;
  line-height: 146%;
  color: #fff;
  transition: all var(--transition);
}
.bl_caseStudy ul.bl_caseStudy_list .el_accordion_tab span::after {
  content: "";
  content: "";
  background-image: url(../images/icon-accordion-arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 14px;
  height: 7px;
  display: inline-block;
  margin-left: 4px;
  transition: all var(--transition);
  filter: brightness(0) invert(1);
}
@media (hover: hover) {
  .bl_caseStudy ul.bl_caseStudy_list .el_accordion_tab:hover {
    background: #4a90e2 !important;
  }
  .bl_caseStudy ul.bl_caseStudy_list .el_accordion_tab:hover span::after {
    filter: brightness(0) invert(1);
  }
  .bl_caseStudy ul.bl_caseStudy_list .el_accordion_tab:hover span::before {
    color: #fff;
  }
}
.bl_caseStudy ul.bl_caseStudy_list .el_accordion_tab:active {
  background: #333 !important;
}
.bl_caseStudy ul.bl_caseStudy_list .el_accordion_tab:active span::after {
  filter: brightness(0) invert(1);
}
.bl_caseStudy ul.bl_caseStudy_list .el_accordion_tab:active span::before {
  color: #fff;
}
.bl_caseStudy ul.bl_caseStudy_list .is_open + .el_accordion_tab {
  background-color: var(--main-color);
}
.bl_caseStudy ul.bl_caseStudy_list .is_open + .el_accordion_tab span::before {
  content: "閉じる";
}
.bl_caseStudy ul.bl_caseStudy_list .is_open + .el_accordion_tab span::after {
  transform: rotate(180deg);
}

.bl_menu {
  background-color: #f1f4f7;
  --content-width: 1312px;
}
.bl_menu h2 .is_underline::after {
  background-image: url(../images/menu-ul.svg);
}
.bl_menu h2 + p {
  margin-top: 28px;
  font-weight: 700;
  font-size: 18px;
  line-height: 180%;
  text-align: center;
}
.bl_menu ul.bl_menu_items {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  margin-top: 48px;
}
@media screen and (min-width: 768px) {
  .bl_menu ul.bl_menu_items {
    grid-template-columns: repeat(3, 1fr);
    align-items: flex-end;
    gap: 16px;
  }
}
@media screen and (min-width: 1080px) {
  .bl_menu ul.bl_menu_items {
    gap: 32px;
  }
}
.bl_menu ul.bl_menu_items > li {
  position: relative;
}
.bl_menu ul.bl_menu_items > li figure {
  background-color: var(--main-color);
  text-align: center;
  overflow: hidden;
  height: 170px;
  border-radius: 8px 8px 0 0;
}
.bl_menu ul.bl_menu_items > li figure img {
  margin-top: 15px;
  display: block;
  margin-inline: auto;
}
.bl_menu ul.bl_menu_items > li.is_recomended figure {
  height: 220px;
}
.bl_menu ul.bl_menu_items > li.is_recomended figure img {
  margin-top: 39px;
}
.bl_menu ul.bl_menu_items > li.is_recomended .el_menu_type {
  background-color: var(--accent-color);
}
.bl_menu ul.bl_menu_items > li.is_recomended .el_linkButton {
  font-size: 18px;
  height: 70px;
}
.bl_menu ul.bl_menu_items > li .bl_card_item_tag_wrapper {
  position: absolute;
  top: -10px;
  left: 0;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 155px;
}
.bl_menu ul.bl_menu_items > li .el_card_item_tag {
  position: relative;
  display: flex;
  flex-shrink: 0;
  align-items: center;
  padding: 5px 18px;
  gap: 8px;
  width: 142px;
  height: 50px;
  background: #fb7200;
  font-weight: 700;
  font-size: 20px;
  line-height: 102%;
  color: #ffffff;
  border-radius: 8px 0 0 0;
}
.bl_menu ul.bl_menu_items > li .el_card_item_tag::before {
  content: "";
  display: block;
  flex-shrink: 0;
  content: "";
  background-image: url(../images/icon-recommend.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 18px;
  height: 23px;
}
.bl_menu ul.bl_menu_items > li .el_card_item_tag::after {
  content: "";
  content: "";
  background-image: url(../images/recommend-ribbon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 13px;
  height: 50px;
  position: absolute;
  top: 0;
  right: -12.5px;
}
.bl_menu ul.bl_menu_items .bl_card_item_content {
  background-color: #fff;
  border-radius: 0 0 8px 8px;
  padding: 24px;
}
@media screen and (min-width: 768px) {
  .bl_menu ul.bl_menu_items .bl_card_item_content {
    padding: 16px;
  }
}
@media screen and (min-width: 1080px) {
  .bl_menu ul.bl_menu_items .bl_card_item_content {
    padding: 24px;
  }
}
.bl_menu ul.bl_menu_items .bl_card_item_content h3 {
  font-weight: 900;
  font-size: 26px;
  line-height: 130%;
  text-align: center;
  color: #163e7b;
}
.bl_menu ul.bl_menu_items .bl_card_item_content .el_menu_type {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding: 4px;
  min-height: 29px;
  background-color: #4a90e2;
  border-radius: 2px;
  font-weight: 700;
  font-size: 16px;
  line-height: 130%;
  text-align: center;
  letter-spacing: 0.64px;
  color: #ffffff;
  margin-top: 8px;
}
.bl_menu ul.bl_menu_items .bl_card_item_content .el_menu_type span {
  display: block;
  font-weight: 700;
  font-size: 12px;
  line-height: 170%;
  letter-spacing: 0.64px;
}
.bl_menu ul.bl_menu_items .bl_card_item_content .bl_menu_item_content {
  margin-top: 24px;
  padding-block: 24px;
  border-top: 1px solid rgba(0, 0, 0, 0.3);
}
.bl_menu ul.bl_menu_items .bl_card_item_content .bl_menu_item_content p {
  font-size: 16px;
  line-height: 160%;
  letter-spacing: 0.64px;
}
.bl_menu ul.bl_menu_items .bl_card_item_content .bl_menu_item_content p span {
  font-weight: 700;
  color: var(--accent-color);
}
.bl_menu ul.bl_menu_items .bl_card_item_content .bl_menu_item_content ul {
  margin-top: 24px;
  padding: 16px;
}
@media screen and (min-width: 768px) {
  .bl_menu ul.bl_menu_items .bl_card_item_content .bl_menu_item_content ul {
    padding: 0;
  }
}
@media screen and (min-width: 1080px) {
  .bl_menu ul.bl_menu_items .bl_card_item_content .bl_menu_item_content ul {
    padding: 16px;
  }
}
.bl_menu ul.bl_menu_items .bl_card_item_content .bl_menu_item_content ul li {
  font-weight: 700;
  font-size: 16px;
  line-height: 130%;
  display: flex;
  letter-spacing: 0.64px;
  gap: 11px;
  padding-left: 7px;
}
.bl_menu ul.bl_menu_items .bl_card_item_content .bl_menu_item_content ul li + li {
  margin-top: 12px;
}
.bl_menu ul.bl_menu_items .bl_card_item_content .bl_menu_item_content ul li::before {
  content: "";
  background-color: var(--accent-color);
  width: 8px;
  height: 8px;
  border-radius: 100%;
  display: inline-block;
  margin-top: 8px;
  flex-shrink: 0;
}
.bl_menu ul.bl_menu_items .bl_card_item_content .el_linkButton {
  background-color: var(--main-color);
  font-size: 14px;
  height: 54px;
  transition: background-color var(--transition);
}
@media (hover: hover) {
  .bl_menu ul.bl_menu_items .bl_card_item_content .el_linkButton:hover {
    background-color: #4a90e2;
  }
}
.bl_menu ul.bl_menu_items .bl_card_item_content .el_linkButton:active {
  background-color: #333;
}

.bl_customize {
  --content-width: 1200px;
  background-color: #e4e8ef;
}
.bl_customize h2 .is_underline::after {
  background-image: url(../images/customize-ul.svg);
}
@media screen and (max-width: 1079px) {
  .bl_customize h2 {
    font-size: 27px !important;
  }
  .bl_customize h2 .el_h2_subCopy {
    font-size: 20px !important;
  }
}
.bl_customize figure {
  text-align: center;
}
.bl_customize .bl_customize_list {
  padding-block: 100px 24px;
  padding-inline: 16px;
}
@media screen and (min-width: 1080px) {
  .bl_customize .bl_customize_list {
    padding: 140px 70px 55px;
  }
}
.bl_customize .bl_customize_list {
  background: #ffffff;
  border-radius: 12px;
  position: relative;
}
.bl_customize .bl_customize_list .bl_customize_topics {
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
  gap: 8px;
}
@media screen and (min-width: 1080px) {
  .bl_customize .bl_customize_list .bl_customize_topics {
    top: -40px;
    gap: 28px;
  }
}
.bl_customize .bl_customize_list .bl_customize_topics > li {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 5px;
  width: 104px;
  height: 104px;
  background: #163e7b;
  outline: 6px solid #ffffff;
  border-radius: 100%;
  font-weight: 900;
  font-size: 16px;
  line-height: 104%;
  letter-spacing: 0.64px;
  text-align: center;
  color: #ffffff;
}
@media screen and (min-width: 1080px) {
  .bl_customize .bl_customize_list .bl_customize_topics > li {
    outline: 8px solid #ffffff;
    font-size: 24px;
    width: 158px;
    height: 158px;
  }
}
.bl_customize .bl_customize_list .bl_customize_topics > li:nth-child(2) {
  font-size: 11px;
}
@media screen and (min-width: 1080px) {
  .bl_customize .bl_customize_list .bl_customize_topics > li:nth-child(2) {
    font-size: 18px;
  }
}
.bl_customize .bl_customize_list > p {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 16px 32px 18px;
  margin-inline: auto;
  max-width: 640px;
  height: 65px;
  background: #a4ceff;
  border-radius: 50px;
  font-weight: 900;
  line-height: 130%;
  color: #163e7b;
  font-size: 18px;
}
@media screen and (min-width: 1080px) {
  .bl_customize .bl_customize_list > p {
    font-size: 24px;
  }
}
.bl_customize .bl_customize_list .bl_customize_items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-top: 24px;
}
@media screen and (min-width: 1080px) {
  .bl_customize .bl_customize_list .bl_customize_items {
    margin-top: 38px;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 20px;
    row-gap: 16px;
  }
}
.bl_customize .bl_customize_list .bl_customize_items li {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 5px 12px;
  min-height: 50px;
  background: #f1f4f7;
  border-radius: 4px;
  font-weight: 900;
  line-height: 130%;
  letter-spacing: 0.64px;
  color: #4a90e2;
  font-size: 14px;
}
@media screen and (min-width: 1080px) {
  .bl_customize .bl_customize_list .bl_customize_items li {
    padding: 16px 12px;
    min-height: 55px;
    font-size: 18px;
  }
}

.bl_step {
  --content-width: 900px;
  --section-pb: 0;
}
.bl_step h2 .is_underline::after {
  background-image: url(../images/step-ul.svg);
}
.bl_step h2 + p {
  margin-top: 28px;
  max-width: 900px;
  font-weight: 700;
  font-size: 18px;
  line-height: 180%;
  text-align: center;
}
.bl_step .bl_step_list {
  margin-top: 48px;
  padding-left: 36px;
  margin-bottom: 34px;
  position: relative;
}
.bl_step .bl_step_list::before {
  content: "";
  position: absolute;
  top: 0;
  left: 16px;
  width: 8px;
  height: 100%;
  background: #ff9e4d;
  border-radius: 4px 0 0 0;
}
.bl_step .bl_step_list::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  border-style: solid none none solid;
  border-color: #ff9e4d transparent transparent #fff;
  border-width: 37px 0 0 24px;
}
.bl_step .bl_step_list li.bl_step_item {
  position: relative;
}
.bl_step .bl_step_list li.bl_step_item .bl_step_item_heading {
  border-radius: 8px 8px 0px 8px;
  padding: 24px;
  background: #e4e8ef;
}
.bl_step .bl_step_list li.bl_step_item h3 {
  display: flex;
  gap: 8px;
  font-weight: 700;
  font-size: 20px;
  line-height: 130%;
  color: #163e7b;
  border-bottom: 2px solid #163e7b;
  padding-bottom: 8px;
  flex-wrap: wrap;
  flex-direction: column;
  align-items: flex-start;
}
@media screen and (min-width: 1080px) {
  .bl_step .bl_step_list li.bl_step_item h3 {
    align-items: center;
    flex-direction: row;
  }
}
.bl_step .bl_step_list li.bl_step_item h3 .el_step_counter {
  font-weight: 900;
  font-size: 24px;
  line-height: 100%;
}
.bl_step .bl_step_list li.bl_step_item h3 .el_step_meta {
  display: flex;
  align-items: center;
  padding: 4px 12px;
  gap: 4px;
  white-space: nowrap;
  background: #c8d2e0;
  border-radius: 2px;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.7;
  color: #163e7b;
  width: 100%;
}
@media screen and (min-width: 1080px) {
  .bl_step .bl_step_list li.bl_step_item h3 .el_step_meta {
    margin-left: auto;
    width: auto;
  }
}
.bl_step .bl_step_list li.bl_step_item h3 .el_step_meta::before {
  content: "";
  content: "";
  background-image: url(../images/icon-clock.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 14px;
  height: 14px;
  display: inline-block;
  flex-shrink: 0;
}
.bl_step .bl_step_list li.bl_step_item p {
  margin-top: 16px;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.7;
  color: #333333;
}
.bl_step .bl_step_list li.bl_step_item p span {
  font-weight: 700;
  color: var(--accent-color);
}
.bl_step .bl_step_list li.bl_step_item + li {
  margin-top: 58px;
}
.bl_step .bl_step_list li.bl_step_item.is_open .bl_step_item_heading {
  border-radius: 8px 8px 0 0;
}
.bl_step .bl_step_list .el_accordion {
  display: none;
  background-color: var(--main-color);
  color: #fff;
  padding: 24px;
  border-radius: 0 0 0 8px;
}
.bl_step .bl_step_list .el_accordion ul {
  display: flex;
  flex-shrink: 1;
  flex-grow: 1;
  gap: 12px;
  flex-direction: column;
}
@media screen and (min-width: 1080px) {
  .bl_step .bl_step_list .el_accordion ul {
    gap: 24px;
    flex-direction: row;
  }
}
.bl_step .bl_step_list .el_accordion ul li {
  display: flex;
  font-weight: 700;
  font-size: 14px;
  line-height: 1.7;
  gap: 6px;
}
.bl_step .bl_step_list .el_accordion ul li::before {
  content: "";
  content: "";
  background-image: url(../images/icon-check-orange.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 26px;
  height: 26px;
  display: inline-block;
  flex-shrink: 0;
}
.bl_step .bl_step_list .el_accordion_tab {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  padding: 8px 16px;
  gap: 4px;
  width: 151px;
  height: 34px;
  background: var(--main-color);
  border-radius: 0px 0px 8px 8px;
  position: absolute;
  bottom: -34px;
  right: 0;
  --transition-time: 0.1s;
  transition: all var(--transition);
}
.bl_step .bl_step_list .el_accordion_tab span::before {
  content: "詳しい内容を見る";
  font-weight: 700;
  font-size: 12px;
  line-height: 146%;
  color: #fff;
  transition: all var(--transition);
}
.bl_step .bl_step_list .el_accordion_tab span::after {
  content: "";
  content: "";
  background-image: url(../images/icon-accordion-arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 14px;
  height: 7px;
  display: inline-block;
  margin-left: 4px;
  filter: brightness(0) invert(1);
  transition: all var(--transition);
}
@media (hover: hover) {
  .bl_step .bl_step_list .el_accordion_tab:hover {
    background: #4a90e2 !important;
  }
  .bl_step .bl_step_list .el_accordion_tab:hover span::after {
    filter: brightness(0) invert(1);
  }
  .bl_step .bl_step_list .el_accordion_tab:hover span::before {
    color: #fff;
  }
}
.bl_step .bl_step_list .el_accordion_tab:active {
  background: #333 !important;
}
.bl_step .bl_step_list .el_accordion_tab:active span::after {
  filter: brightness(0) invert(1);
}
.bl_step .bl_step_list .el_accordion_tab:active span::before {
  color: #fff;
}
.bl_step .bl_step_list .is_open + .el_accordion_tab {
  background-color: var(--main-color);
}
.bl_step .bl_step_list .is_open + .el_accordion_tab span::before {
  content: "閉じる";
}
.bl_step .bl_step_list .is_open + .el_accordion_tab span::after {
  transform: rotate(180deg);
}
.bl_step .bl_step_summary {
  margin-top: 90px;
  background: rgba(22, 62, 123, 0.1);
  padding-block: 48px 32px;
  padding-inline: var(--site-inline-padding);
  position: relative;
}
.bl_step .bl_step_summary::before {
  content: "";
  content: "";
  background-image: url(../images/arrow-section.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 168px;
  height: 56px;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.bl_step .bl_step_summary p {
  max-width: 743px;
  font-weight: 900;
  font-size: 24px;
  line-height: 160%;
  text-align: center;
  color: #333333;
  margin-inline: auto;
}
.bl_step .bl_step_summary p span {
  color: #4a90e2;
}

.bl_faq {
  --content-width: 900px;
}
.bl_faq .bl_mediaText.is_heading {
  --h2-circle-size: 83px;
  --h2-circle-left: 0;
  --h2-circle-top: -24px;
  gap: 24px;
}
@media screen and (min-width: 1080px) {
  .bl_faq .bl_mediaText.is_heading {
    --h2-circle-top: -14px;
    --h2-circle-left: -30px;
  }
}
@media screen and (min-width: 1080px) {
  .bl_faq .bl_mediaText.is_heading {
    grid-template-columns: 1fr 182px;
    gap: 10px;
    align-items: center;
  }
}
@media screen and (max-width: 1079px) {
  .bl_faq .bl_mediaText.is_heading h2 {
    padding-left: 29px;
  }
}
@media screen and (min-width: 1080px) {
  .bl_faq .bl_mediaText.is_heading .bl_mediaText_content {
    padding-left: 29px;
  }
}
.bl_faq .bl_mediaText.is_heading .bl_mediaText_content p {
  margin-top: 24px;
  max-width: 650px;
  font-weight: 700;
  font-size: 18px;
  line-height: 180%;
}
.bl_faq .bl_mediaText.is_heading figure img {
  max-width: 117px;
}
@media screen and (min-width: 1080px) {
  .bl_faq .bl_mediaText.is_heading figure img {
    max-width: 327px;
  }
}
.bl_faq .bl_mediaText.is_heading figure img {
  width: 100%;
}
.bl_faq .bl_faqItem {
  position: relative;
  margin-top: 16px;
}
.bl_faq .bl_faqItem .el_faq_label {
  font-weight: 700;
  font-size: 24px;
  line-height: 100%;
  align-self: flex-start;
  padding: 4px;
}
.bl_faq .bl_faqItem dt button {
  display: flex;
  flex-direction: row;
  align-items: center;
  text-align: left;
  gap: 4px;
  border-radius: 4px;
  min-height: 76px;
  background: #d0d8e5;
  font-weight: 700;
  font-size: 18px;
  line-height: 130%;
  color: #163e7b;
  width: 100%;
  position: relative;
  padding-block: 16px 16px;
  padding-inline: 8px 16px;
}
@media screen and (min-width: 1080px) {
  .bl_faq .bl_faqItem dt button {
    padding-block: 24px 20px;
    padding-inline: 24px;
  }
}
.bl_faq .bl_faqItem dt button::after {
  content: "";
  background-image: url(../images/icon-faq-toggle2.svg);
  background-size: 14px;
  background-repeat: no-repeat;
  background-position: center;
  width: 32px;
  height: 32px;
  border-radius: 100%;
  background-color: var(--main-color);
  margin-left: auto;
  transition: all var(--transition);
  flex-shrink: 0;
}
@media (hover: hover) {
  .bl_faq .bl_faqItem dt button:hover::after {
    background-color: #4a90e2;
  }
}
.bl_faq .bl_faqItem dt button:active::after {
  background-color: #333;
}
.bl_faq .bl_faqItem dt.is_open button {
  border-radius: 4px 4px 0 0;
}
.bl_faq .bl_faqItem dt.is_open button::after {
  transform: rotate(45deg);
}
.bl_faq .bl_faqItem dd {
  display: none;
}
.bl_faq .bl_faqItem .el_faqItem_ans {
  display: grid;
  color: var(--main-color);
  align-items: flex-start;
  background: #f1f4f7;
  border-radius: 0 0 4px 4px;
  font-weight: 400;
  font-size: 16px;
  line-height: 180%;
  grid-template-columns: 36px 1fr;
  padding-block: 16px 16px;
  padding-inline: 8px 16px;
}
@media screen and (min-width: 1080px) {
  .bl_faq .bl_faqItem .el_faqItem_ans {
    grid-template-columns: 42px 1fr;
    padding-block: 24px 32px;
    padding-inline: 24px;
  }
}
.bl_faq .bl_faqItem .el_faqItem_ans > div > * + * {
  margin-top: 12px;
}
.bl_faq .bl_faqItem .el_faqItem_ans > div span {
  font-weight: 700;
  color: var(--accent-color);
}

.bl_form {
  --content-width: 900px;
  background-color: #f1f4f7;
  background-repeat: no-repeat;
  background-image: url(../images/form-bg-top.svg), url(../images/form-bg-bottom.svg);
  background-position: top right, bottom left;
}
.bl_form h2 + p {
  margin-top: 16px;
  max-width: 900px;
  font-weight: 700;
  line-height: 180%;
  margin-inline: auto;
  font-size: 16px;
  text-align: left;
}
@media screen and (min-width: 1080px) {
  .bl_form h2 + p {
    text-align: center;
    font-size: 18px;
  }
}
.bl_form .bl_contact {
  margin-top: 40px;
  background: #ffffff;
  border-radius: 8px;
  padding: 16px;
}
@media screen and (min-width: 1080px) {
  .bl_form .bl_contact {
    padding: 56px;
  }
}
.is_confirm .bl_form .bl_contact, .is_thanks .bl_form .bl_contact {
  margin-top: 0;
}
.bl_form ol.bl_contact_steps {
  display: flex;
  align-items: stretch;
  border-radius: 4px;
  overflow: hidden;
}
.bl_form ol.bl_contact_steps li {
  display: flex;
  height: auto;
  justify-content: center;
  align-items: center;
  gap: 4px;
  background: var(--contact-step-bg, #163e7b);
  position: relative;
  color: var(--contact-step-color, #fff);
  flex: 1 1 0;
  font-weight: 400;
  font-size: 12px;
  line-height: 100%;
  padding-block: 16px;
  padding-inline: 16px 8px;
  min-height: 44px;
}
@media screen and (min-width: 1080px) {
  .bl_form ol.bl_contact_steps li {
    min-height: 50px;
    font-size: 14px;
    padding-inline: 40px 24px;
  }
}
.bl_form ol.bl_contact_steps li .el_contact_step_label {
  white-space: nowrap;
  font-weight: 700;
  font-size: 12px;
}
@media screen and (min-width: 1080px) {
  .bl_form ol.bl_contact_steps li .el_contact_step_label {
    font-size: 16px;
  }
}
@media screen and (max-width: 1079px) {
  .bl_form ol.bl_contact_steps li .el_contact_step_text > span {
    display: none;
  }
}
.bl_form ol.bl_contact_steps li::after {
  content: "";
  position: absolute;
  top: 0;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% 100%;
  width: 8px;
  right: -8px;
}
@media screen and (min-width: 1080px) {
  .bl_form ol.bl_contact_steps li::after {
    width: 16px;
    right: -16px;
  }
}
.bl_form ol.bl_contact_steps li::after {
  z-index: 2;
}
.bl_form ol.bl_contact_steps li:first-child {
  --contact-step-bg: #163e7b;
  --contact-step-color: #fff;
}
.bl_form ol.bl_contact_steps li:first-child::after {
  background-image: url(../images/arrow-step-navy.png);
}
.bl_form ol.bl_contact_steps li:first-child {
  padding-left: 8px;
}
@media screen and (min-width: 1080px) {
  .bl_form ol.bl_contact_steps li:first-child {
    padding-left: 24px;
  }
}
.bl_form ol.bl_contact_steps li:nth-child(2) {
  --contact-step-bg: #e4e8ef;
  --contact-step-color: #163e7b;
}
.bl_form ol.bl_contact_steps li:nth-child(2)::after {
  background-image: url(../images/arrow-step-gray.png);
}
.bl_form ol.bl_contact_steps li:last-child {
  --contact-step-bg: #f1f4f7;
  --contact-step-color: #163e7b;
}
.bl_form ol.bl_contact_steps li:last-child::after {
  content: none;
}
.is_confirm .bl_form ol.bl_contact_steps li:first-child {
  --contact-step-bg: #e4e8ef;
  --contact-step-color: #163e7b;
}
.is_confirm .bl_form ol.bl_contact_steps li:first-child::after {
  background-image: url(../images/arrow-step-gray.png);
}
.is_confirm .bl_form ol.bl_contact_steps li:nth-child(2) {
  --contact-step-bg: #163e7b;
  --contact-step-color: #fff;
}
.is_confirm .bl_form ol.bl_contact_steps li:nth-child(2)::after {
  background-image: url(../images/arrow-step-navy.png);
}
.is_thanks .bl_form ol.bl_contact_steps li:first-child {
  --contact-step-bg: #e4e8ef;
  --contact-step-color: #163e7b;
}
.is_thanks .bl_form ol.bl_contact_steps li:first-child::after {
  background-image: url(../images/arrow-step-gray.png);
}
.is_thanks .bl_form ol.bl_contact_steps li:nth-child(2) {
  --contact-step-bg: #f1f4f7;
  --contact-step-color: #163e7b;
}
.is_thanks .bl_form ol.bl_contact_steps li:nth-child(2)::after {
  background-image: url(../images/arrow-step-white.png);
}
.is_thanks .bl_form ol.bl_contact_steps li:last-child {
  --contact-step-bg: #163e7b;
  --contact-step-color: #fff;
}
.bl_form form {
  margin-inline: auto;
  margin-top: 40px;
}
.bl_form .el_formItem {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-bottom: 1px solid var(--border-color);
}
@media screen and (min-width: 768px) {
  .bl_form .el_formItem {
    grid-template-columns: 220px 1fr;
  }
}
.bl_form .el_formItem + .el_formItem {
  margin-top: 16px;
}
@media screen and (min-width: 768px) {
  .bl_form .el_formItem + .el_formItem {
    margin-top: 0;
  }
}
.bl_form .el_formItem_label {
  display: flex;
  align-items: center;
  font-weight: 700;
  font-size: 16px;
  line-height: 130%;
  color: #163e7b;
  flex-direction: row-reverse;
  justify-content: flex-end;
  gap: 8px;
}
@media screen and (min-width: 1080px) {
  .bl_form .el_formItem_label {
    flex-direction: row;
    justify-content: space-between;
  }
}
.bl_form .el_formItem_label.is_optional::after, .bl_form .el_formItem_label.is_require::after {
  content: "必須";
  color: #fff;
  background-color: #4a90e2;
  width: 36px;
  height: 23px;
  font-weight: 400;
  font-size: 12px;
  line-height: 100%;
  display: flex;
  align-items: center;
  text-align: center;
  justify-content: center;
  letter-spacing: 0.64px;
  border-radius: 2px;
  font-size: 12px;
  line-height: 1;
  letter-spacing: 0.64px;
}
.bl_form .el_formItem_label.is_require::after {
  content: "必須";
  color: #fff;
  background-color: #4a90e2;
}
.bl_form .el_formItem_label.is_optional::after {
  content: "任意";
  color: #333;
  background-color: #d0d0d0;
}
.bl_form .el_formItem_form {
  display: flex;
  align-items: center;
  min-height: 73px;
  padding-block: 8px 16px;
  padding-inline: 0;
  flex-wrap: wrap;
}
@media screen and (min-width: 1080px) {
  .bl_form .el_formItem_form {
    padding: 16px;
  }
}
.bl_form .el_formItem_form textarea,
.bl_form .el_formItem_form input[type=text],
.bl_form .el_formItem_form input[type=url],
.bl_form .el_formItem_form input[type=email],
.bl_form .el_formItem_form input[type=tel] {
  border: 1px solid #c9c9c9;
  background-color: #fff;
  padding-block: 8px;
  padding-inline: 12px;
  width: 100%;
  font-size: 16px;
}
.bl_form .el_formItem_form textarea.sec-form-set__error-mark, .bl_form .el_formItem_form textarea.is_error,
.bl_form .el_formItem_form input[type=text].sec-form-set__error-mark,
.bl_form .el_formItem_form input[type=text].is_error,
.bl_form .el_formItem_form input[type=url].sec-form-set__error-mark,
.bl_form .el_formItem_form input[type=url].is_error,
.bl_form .el_formItem_form input[type=email].sec-form-set__error-mark,
.bl_form .el_formItem_form input[type=email].is_error,
.bl_form .el_formItem_form input[type=tel].sec-form-set__error-mark,
.bl_form .el_formItem_form input[type=tel].is_error {
  filter: drop-shadow(0px 0px 4px #e88383);
  border-color: #e88383;
  margin-bottom: 10px;
}
.bl_form .el_formItem_form textarea::placeholder,
.bl_form .el_formItem_form input[type=text]::placeholder,
.bl_form .el_formItem_form input[type=url]::placeholder,
.bl_form .el_formItem_form input[type=email]::placeholder,
.bl_form .el_formItem_form input[type=tel]::placeholder {
  color: #333;
  opacity: 0.54;
}
.bl_form .el_formItem_form input[type=radio] {
  margin-right: 10px;
}
.bl_form .el_formItem_form input[type=radio] + span {
  cursor: pointer;
}
.bl_form .el_formItem_form.el_checkboxGroup {
  display: flex;
  flex-wrap: wrap;
  column-gap: 24px;
  row-gap: 16px;
}
@media screen and (max-width: 1079px) {
  .bl_form .el_formItem_form.el_checkboxGroup {
    margin-top: 16px;
  }
}
.bl_form .el_formItem_form.el_checkboxGroup label {
  white-space: nowrap;
  line-height: 1.3;
  display: flex;
  gap: 4px;
  align-items: center;
}
.bl_form .el_formItem_form textarea {
  height: 200px;
}
.bl_form .el_formItem_form .sec-form-set__error-msg {
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.bl_form .el_formItem_form .ico-error {
  width: 16px;
  height: 14px;
  background-image: url(../images/icon-error.svg);
}
.bl_form .el_formItem_form .sec-form-set__error-txt {
  margin: 0 0 0 5px;
  padding: 0;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1;
  color: #e88383;
}
.bl_form .el_formPolicy {
  margin-top: 40px;
  text-align: center;
  line-height: 1.3;
}
.bl_form .el_formPolicy label {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  text-align: left;
}
.bl_form .el_formPolicy label input {
  margin-top: 5px;
  margin-right: 10px;
}
/* 追加 */
.bl_form .el_formPolicy .sec-form-set__error-msg {
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  gap: 6px;
  padding: 10px 0 0 0;
}
.bl_form .el_formPolicy .ico-error {
  width: 16px;
  height: 14px;
  flex: 0 0 auto;
  background-image: url(../images/icon-error.svg);
  background-repeat: no-repeat;
  background-size: contain;
}
.bl_form .el_formPolicy .sec-form-set__error-txt {
  margin: 0;
  padding: 0;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1;
  color: #e88383;
  overflow-wrap: anywhere;
}
/* 追加 ここまで */
.bl_form .el_linkButton {
  max-width: 400px;
  width: 100%;
  height: 84px;
  border-radius: 8px;
  margin-inline: auto;
  margin-top: 32px;
  font-weight: 700;
  font-size: 20px;
  line-height: 1;
}
.bl_form .el_linkButton:after {
  width: 18px;
  height: 20px;
}
.bl_form .el_linkButton.is_backButton {
  background-color: var(--main-color);
  width: 128px;
}
.bl_form h3 {
  margin-top: 32px;
  font-weight: 700;
  font-size: 18px;
  line-height: 120%;
  text-align: center;
  color: #163e7b;
}
.bl_form .el_formPolicy_content {
  margin-top: 15px;
  padding: 24px 24px;
  height: 200px;
  overflow-y: auto;
  background: #f1f4f7;
  border-radius: 4px;
  font-weight: 400;
  font-size: 16px;
  line-height: 180%;
  text-align: justify;
  color: #333333;
}
.bl_form .el_formPolicy_content > * + * {
  margin-top: 16px;
}
.bl_form .el_formPolicy_content > h4 + * {
  margin-top: 4px;
}
.bl_form .el_formPolicy_content ol li {
  list-style-type: none;
}
.bl_form .bl_formButtons {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-direction: column-reverse;
  align-items: center;
  margin-top: 40px;
}
@media screen and (min-width: 768px) {
  .bl_form .bl_formButtons {
    flex-direction: row;
  }
}
.bl_form .bl_formButtons .el_linkButton {
  margin-inline: 0;
  width: 298px;
  height: 68px;
  margin-top: 0;
}
.bl_form .bl_formButtons .el_linkButton.is_backButton {
  background-color: var(--main-color);
  width: 298px;
}
@media screen and (min-width: 768px) {
  .bl_form .bl_formButtons .el_linkButton.is_backButton {
    width: 128px;
  }
}
.bl_form .bl_formButtons .el_linkButton.is_backButton::after {
  content: none;
}
@media (hover: hover) {
  .bl_form .bl_formButtons .el_linkButton.is_backButton:hover {
    background-color: #4a90e2;
  }
}
.bl_form .bl_formButtons .el_linkButton.is_backButton:active {
  background-color: #333333;
}
.is_thanks .bl_form .bl_thanks_content {
  margin-top: 40px;
}
.is_thanks .bl_form h2 {
  font-weight: 700;
  font-size: 24px;
  line-height: 130%;
  text-align: center;
  color: #163e7b;
}
.is_thanks .bl_form h2 + p {
  margin-top: 28px;
}
.is_thanks .bl_form h2 + p,
.is_thanks .bl_form p {
  font-weight: 500;
  font-size: 18px;
  line-height: 180%;
  color: #333333;
}
@media screen and (min-width:520px) {
  .is_thanks .bl_form h2 + p,
  .is_thanks .bl_form p {
    text-align: center;
  }
}
.is_thanks .bl_form p + p {
  margin-top: 1.3em;
}
.is_thanks .bl_form .el_linkButton {
  background-color: var(--main-color);
  max-width: 400px;
  width: 100%;
  height: 68px;
}
.is_thanks .bl_form .el_linkButton::after {
  content: none;
}
@media (hover: hover) {
  .is_thanks .bl_form .el_linkButton:hover {
    background-color: #4a90e2;
  }
}
.is_thanks .bl_form .el_linkButton:active {
  background-color: #333333;
}

/*# sourceMappingURL=style.css.map */
