@charset "UTF-8";
/* --------------------------------
 * resset v5.0.2
 * -------------------------------- */
body {
  padding: 0;
}

html {
  -webkit-box-sizing: border-box;
  -webkit-text-size-adjust: 100%; /* Prevent adjustments of font size after orientation changes in iOS */
  -moz-tab-size: 4;
  -o-tab-size: 4;
  box-sizing: border-box;
  word-break: normal;
  tab-size: 4;
  scroll-behavior: smooth;
}

*,
::before,
::after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
  background-repeat: no-repeat; /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
}

::before,
::after {
  text-decoration: inherit; /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit;
}

* {
  margin: 0;
  padding: 0; /* Reset `padding` and `margin` of all elements */
}

/* # =================================================================
     # General elements
     # ================================================================= */
hr {
  height: 0; /* Add the correct box sizing in Firefox */
  overflow: visible; /* Show the overflow in Edge and IE */
  color: inherit; /* Correct border color in Firefox. */
}

details,
main {
  display: block; /* Render the `main` element consistently in IE. */
}

summary {
  display: list-item; /* Add the correct display in all browsers */
}

small {
  font-size: 80%; /* Set font-size to 80% in `small` elements */
}

[hidden] {
  display: none; /* Add the correct display in IE */
}

abbr[title] {
  -webkit-text-decoration: underline dotted;
  border-bottom: none; /* Remove the bottom border in Chrome 57 */
  /* Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari */
  text-decoration: underline;
  text-decoration: underline dotted;
}

a {
  background-color: transparent; /* Remove the gray background on active links in IE 10 */
}

a:active,
a:hover {
  outline-width: 0; /* Remove the outline when hovering in all browsers */
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace; /* Specify the font family of code elements */
}

pre {
  font-size: 1em; /* Correct the odd `em` font sizing in all browsers */
}

b,
strong {
  font-weight: bolder; /* Add the correct font weight in Chrome, Edge, and Safari */
}

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

table {
  border-color: inherit; /* Correct border color in all Chrome, Edge, and Safari. */
  text-indent: 0; /* Remove text indentation in Chrome, Edge, and Safari */
}

iframe {
  border-style: none;
}

/* # =================================================================
     # Forms
     # ================================================================= */
input {
  border-radius: 0;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; /* Correct the cursor style of increment and decrement buttons in Chrome */
}

[type="search"] {
  -webkit-appearance: textfield; /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px; /* Correct the outline style in Safari */
}

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; /* Remove the inner padding in Chrome and Safari on macOS */
}

textarea {
  overflow: auto; /* Internet Explorer 11+ */
  resize: vertical; /* Specify textarea resizability */
}

button,
input,
optgroup,
select,
textarea {
  font: inherit; /* Specify font inheritance of form elements */
}

optgroup {
  font-weight: bold; /* Restore the font weight unset by the previous rule */
}

button {
  overflow: visible; /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

button,
select {
  text-transform: none; /* Firefox 40+, Internet Explorer 11- */
}

/* Apply cursor pointer to button elements */
button,
[type="button"],
[type="reset"],
[type="submit"],
[role="button"] {
  cursor: pointer;
}

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  padding: 0;
  border-style: none;
}

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  outline: 1px dotted ButtonText;
}

button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; /* Correct the inability to style clickable types in iOS */
}

/* Remove the default button styling in all browsers */
button,
input,
select,
textarea {
  border-style: none;
  background-color: transparent;
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
  outline-width: 0;
}

/* Style select like a standard input */
select {
  -moz-appearance: none; /* Firefox 36+ */
  -webkit-appearance: none; /* Chrome 41+ */
}

select::-ms-expand {
  display: none; /* Internet Explorer 11+ */
}

select::-ms-value {
  color: currentColor; /* Internet Explorer 11+ */
}

legend {
  display: table; /* Correct the text wrapping in Edge and IE */
  max-width: 100%; /* Correct the text wrapping in Edge and IE */
  max-width: 100%; /* Correct the text wrapping in Edge 18- and IE */
  border: 0; /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit; /* Correct the color inheritance from `fieldset` elements in IE */
  white-space: normal; /* Correct the text wrapping in Edge and IE */
}

::-webkit-file-upload-button {
  /* Correct the inability to style clickable types in iOS and Safari */
  -webkit-appearance: button;
  color: inherit;
  font: inherit; /* Change font properties to `inherit` in Chrome and Safari */
}

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default;
}

/* # =================================================================
     # Specify media element style
     # ================================================================= */
img {
  width: 100%;
  border-style: none; /* Remove border when inside `a` element in IE 8/9/10 */
  vertical-align: middle;
}

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline;
}

/* # =================================================================
     # Accessibility
     # ================================================================= */
/* Specify the progress cursor of updating elements */
[aria-busy="true"] {
  cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled="true"] {
  cursor: default;
}

:root {
  /* color */
  --c__text: #101010;
  --c__black: #101010;
  --c__yellow: #ff9d00;
  --c__gray: #585757;
  --c__lightGray: #f7f9fb;
  --c__white: #ffffff;
  --c__blue: #013894;
  --c__blue02: #3862a5;
  --c__lightBlue: #d4e4ff;
  --c__overlay: rgb(32, 73, 142, 0.72);
  --c__overlay02: rgb(1, 56, 148, 0.3);
  --c__shadow: 0 0 6px rgb(0, 0, 0, 0.16);
  --c__shadow02: 0 3px 6px rgb(0, 0, 0, 0.16);
  /* padding */
  --pd__inner: min(4rem, 4%);
  /* width */
  --wd__inner: 102rem;
  --wd__inner02: 94rem;
  --wd__inner03: 123rem;
  --wd__burger_menu: 60rem;
  /* heigt */
  --hi__header: 10rem;
  /* fontsize */
  --fs__5l: 9.5rem;
  --fs__4l: 5rem;
  --fs__3l: 4.8rem;
  --fs__2l: 3.2rem;
  --fs__1l: 2.4rem;
  --fs__xl: 2rem;
  --fs__l: 1.8rem;
  --fs__m: 1.6rem;
  --fs__s: 1.4rem;
  --fs__xs: 1.2rem;
  /* font-family */
  --ff__sans: "Noto Sans JP", "Hiragino Sans", "ヒラギノ角ゴ Pro",
    "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic,
    "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  --ff__sans02: "Odibee Sans", cursive, "游ゴシック体", "Yu Gothic", YuGothic,
    "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo,
    "MS Pゴシック", "MS PGothic", sans-serif;
  --ff__sans03: "Roboto Condensed", "Helvetica", "游ゴシック体", "Yu Gothic",
    YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo,
    "MS Pゴシック", "MS PGothic", sans-serif;
}

/* --------------------------------
 * ベース
 * -------------------------------- */
html {
  overflow: auto;
  font-size: 62.5%;
}

/* ドロワー開閉時、スクロール禁止 */
html.is_drawerOpen {
  overflow: hidden;
}

body {
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  -webkit-backface-visibility: hidden;
  color: var(--c__text);
  font-weight: 400;
  font-size: var(--fs__m);
  line-height: calc(21 / var(--fs__m));
  font-family: var(--ff__sans);
}

p {
  font-size: var(--fs__m);
}

h1,
h2,
h3,
h4,
h5 {
  font-weight: bold;
  font-family: var(--ff__sans);
}

h1 {
  margin-top: 0;
  font-size: var(--fs__31);
  line-height: calc(129 / 95);
}

h2 {
  font-size: var(--fs__2l);
  line-height: calc(65 / 48);
}

h3 {
  font-size: var(--fs__1l);
  line-height: calc(44 / 32);
}

h4 {
  font-size: var(--fs__xl);
}

h5 {
  font-size: var(--fs__l);
}

small {
  font-size: var(--fs__s);
}

.ly_page {
  padding: 4.3rem 0 17.2rem;
}

.ly_cont {
  padding: 10.9rem 0 14rem;
}

.ly_cont.ly_cont__colorBg {
  background-color: var(--c__lightBlue);
}

.ly_cont.ly_cont__imgBg {
  background-image: url("../img/cta-b.jpg.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
@media (max-width: 768px) {
  .ly_cont.ly_cont__imgBg {
    background-position: 35% 50%;
  }
}

.ly_siteInner {
  max-width: 1020px;
  margin: 0 auto;
  padding: 0 var(--pd__inner) 0;
  box-sizing: content-box;
}

.ly_siteInner.ly_siteInner__s {
  /*width: min(var(--wd__inner02) + var(--pd__inner) * 2, 100%);*/
}

.ly_siteInner.ly_siteInner__l {
  /*width: min(var(--wd__inner03) + var(--pd__inner) * 2, 100%);*/
}

.ly_2colSiteInner {
  -webkit-column-gap: 7.8%;
  -moz-column-gap: 7.8%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 7.8%;
}
.ly_2colSiteInner > aside {
  -webkit-box-flex: 0;
  -webkit-flex: 0 1 22rem;
  -ms-flex: 0 1 22rem;
  flex: 0 1 22rem;
}
.ly_2colSiteInner > main {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.ly_pageCont {
  margin-top: 10rem;
}
.ly_pageCont:first-child {
  margin-top: 8rem;
}

.ly_pageSubCont {
  margin-top: 8rem;
}

.bl_moreBtn_wrap {
  margin-top: 6.3rem;
  text-align: center;
}

@-webkit-keyframes zoomUp {
  0% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.15);
    transform: scale(1.15);
  }
}

@keyframes zoomUp {
  0% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.15);
    transform: scale(1.15);
  }
}
.dbg1 {
  outline: 0.5px solid rgba(0, 0, 0, 0.5);
  background: rgba(255, 99, 71, 0.5);
  color: black;
}

.dbg2 {
  outline: 0.5px solid rgba(0, 0, 0, 0.5);
  background: rgba(135, 206, 235, 0.5);
  color: black;
}

.dbg3 {
  outline: 0.5px solid rgba(0, 0, 0, 0.5);
  background: rgba(144, 238, 144, 0.5);
  color: black;
}

.dbg4 {
  outline: 0.5px solid rgba(0, 0, 0, 0.5);
  background: rgba(210, 180, 140, 0.5);
  color: black;
}

.dbg5 {
  outline: 0.5px solid rgba(0, 0, 0, 0.5);
  background: rgba(255, 182, 193, 0.5);
  color: black;
}

/* --------------------------------
 * エレメント：ボタン
 * -------------------------------- */
.el_ctaBtn {
  -webkit-transition: 0.5s all;
  -webkit-transition: all 0.5s;
  display: inline-block;
  width: min(15rem, 100%);
  padding: 0.8rem 1.2rem;
  border-width: 1px;
  border-style: solid;
  border-radius: 3.7rem;
  color: var(--c__blue);
  font-size: var(--fs__m);
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  transition: 0.5s all;
  transition: all 0.5s;
}

.el_ctaBtn.el_ctaBtn__download {
  -webkit-box-shadow: 0 0 6px var(--c__yellow);
  width: min(21rem, 100%);
  border-color: var(--c__yellow);
  background-color: var(--c__yellow);
  box-shadow: 0 0 6px var(--c__yellow);
  color: var(--c__white);
  font-weight: bold;
  font-size: var(--fs__xl);
}
.el_ctaBtn.el_ctaBtn__download:hover,
.el_ctaBtn.el_ctaBtn__download:focus {
  background-color: var(--c__white);
  color: var(--c__yellow);
}

.el_ctaBtn.el_ctaBtn__contact {
  width: 15rem;
  border-color: var(--c__blue);
  background-color: var(--c__white);
  font-weight: bold;
}
.el_ctaBtn.el_ctaBtn__contact:hover,
.el_ctaBtn.el_ctaBtn__contact:focus {
  background-color: var(--c__blue);
  color: var(--c__white);
}

.el_headerBtn,
.el_drawerBtn {
  position: relative;
  width: 5rem;
  height: 5rem;
  padding: 0 0.01rem;
  border: 1px solid #eee;
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
}
.el_headerBtn span,
.el_drawerBtn span {
  --height: 2px;
  -webkit-transition: 400ms;
  -webkit-transform: translateX(-50%);
  display: block;
  position: absolute;
  left: 50%;
  width: 70%;
  transform: translateX(-50%);
  border-radius: 1px;
  transition: 400ms;
}
.el_headerBtn span:nth-of-type(1),
.el_drawerBtn span:nth-of-type(1) {
  height: var(--height);
  background-color: var(--c__gray);
}
.el_headerBtn span:nth-of-type(2),
.el_drawerBtn span:nth-of-type(2) {
  height: var(--height);
  background-color: var(--c__gray);
}
.el_headerBtn span:nth-of-type(3),
.el_drawerBtn span:nth-of-type(3) {
  height: var(--height);
  background-color: var(--c__gray);
}

.el_headerBtn span:nth-of-type(1) {
  top: 25%;
}
.el_headerBtn span:nth-of-type(2) {
  top: 50%;
}
.el_headerBtn span:nth-of-type(2) {
  top: 75%;
}

.el_drawerBtn span {
  top: 50%;
}
.el_drawerBtn span:nth-of-type(1) {
  -webkit-transform: translateX(-50%) rotate(-45deg);
  transform: translateX(-50%) rotate(-45deg);
}
.el_drawerBtn span:nth-of-type(2) {
  -webkit-transform: translateY(-0.7rem) rotate(45deg);
  transform: translateX(-50%) rotate(45deg);
}

.el_moreBtn {
  -webkit-transition: 0.5s all;
  -webkit-transition: all 0.5s;
  display: inline-block;
  width: min(33.8rem, 100%);
  padding: 2rem 0.8rem;
  border-width: 1px;
  border-style: solid;
  border-radius: 3.7rem;
  border-color: var(--c__yellow);
  background-color: var(--c__white);
  color: var(--c__yellow);
  font-weight: bold;
  font-size: var(--fs__1l);
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  transition: 0.5s all;
  transition: all 0.5s;
}
.el_moreBtn:hover,
.el_moreBtn:focus {
  background-color: var(--c__yellow);
  color: var(--c__white);
}

.el_moreBtn.el_moreBtn__info {
  border-color: var(--c__blue);
  color: var(--c__blue);
}
.el_moreBtn.el_moreBtn__info:hover,
.el_moreBtn.el_moreBtn__info:focus {
  background-color: var(--c__blue);
  color: var(--c__white);
}

/* --------------------------------
 * エレメント：タイトル及び導入文
 * -------------------------------- */
.el_pageTtl {
  margin-top: 2.7rem;
}
.el_pageTtl span {
  display: block;
  color: var(--c__blue);
}
.el_pageTtl .sub {
  font-weight: 400;
  font-size: 2.5rem;
  line-height: 1;
  font-family: var(--ff__sans02);
}
.el_pageTtl .main {
  font-weight: 900;
  font-size: var(--fs__3l);
  line-height: calc(65 / 48);
}

.el_secTopTtl {
  color: var(--c__blue);
  text-align: center;
}
.el_secTopTtl .main,
.el_secTopTtl .sub {
  display: block;
}
.el_secTopTtl .sub {
  color: var(--c__blue02);
  font-weight: normal;
  font-size: var(--fs__xl);
  line-height: calc(22 / 20);
  font-family: var(--ff__sans02);
}
.el_secTopTtl .main {
  font-weight: 900;
  font-size: var(--fs__3l);
  line-height: calc(65 / 48);
}

.el_pageCont_ttl {
  font-weight: 900;
  font-size: 2.8rem;
  line-height: calc(38 / 28);
  text-align: center;
}
.el_pageCont_ttl .emphasis {
  -webkit-text-emphasis: dot var(--c__yellow);
  text-emphasis: dot var(--c__yellow);
  font-weight: 900;
}

.el_pageCont__intro {
  margin-top: 2.2rem;
  text-align: center;
}

.el_pageCont_subTtl {
  font-weight: 900;
  font-size: var(--fs__xl);
  text-align: center;
}

/* --------------------------------
 * エレメント：電話情報
 * -------------------------------- */
.el_telInfo .el_telInfo_number {
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  font-family: var(--ff__sans03);
}
.el_telInfo a {
  text-decoration: none;
}
.el_telInfo .el_telInfo_txt {
  display: block;
}

.el_telInfo.el_telInfo__header i,
.el_telInfo.el_telInfo__header a,
.el_telInfo.el_telInfo__header span {
  color: var(--c__blue);
}
.el_telInfo.el_telInfo__header i {
  -webkit-margin-end: 0.4rem;
  margin-inline-end: 0.4rem;
  font-size: 2.6rem;
}
.el_telInfo.el_telInfo__header .el_telInfo_number {
  font-size: 4rem;
}
.el_telInfo.el_telInfo__header .el_telInfo_txt {
  font-size: 1.2rem;
  text-align: right;
  white-space: nowrap;
}

/* --------------------------------
 * ブロック：ドロワーメニュー
 * -------------------------------- */
.bl_drawer {
  z-index: 30;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  visibility: hidden;
}

.bl_drawer_backdrop {
  z-index: -1;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: transparent;
}

.bl_drawerBtn_wrap {
  z-index: 40;
  position: absolute;
  top: 3rem;
  right: 4rem;
}

.bl_drawer_nav {
  -webkit-overflow-scrolling: touch;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  top: 0;
  right: 0;
  row-gap: 1.6rem;
  flex-direction: column;
  justify-content: flex-start;
  width: min(50rem, 100%);
  height: 100%;
  overflow: auto;
  background-color: var(--c__white);
  padding-top: 10rem;
}

.bl_drawer_nav_list {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  flex-direction: column;
  /* リンク領域を広げる */
  padding-top: 0;
  justify-content: flex-start;
}
.bl_drawer_nav_list > li {
  border-bottom: 1px solid var(--c__blue);
  list-style: none;
}
.bl_drawer_nav_list > li:first-of-type {
  border-top: 1px solid var(--c__blue);
}
.bl_drawer_nav_list ul {
  border-top: 1px solid var(--c__blue);
}
.bl_drawer_nav_list ul > li + li {
  border-top: 1px solid var(--c__blue);
}
.bl_drawer_nav_list li a {
  display: inline-block;
  position: relative;
  width: 100%;
  padding: 0.8rem 7.5rem 0.8rem;
  color: var(--c__text);
  font-size: 1.8rem;
  text-decoration: none;
}
.bl_drawer_nav_list li a:visited {
  color: var(--c__text);
}
.bl_drawer_nav_list .sub-menu a {
  padding: 0.8rem 7.5rem 0.8rem 12rem;
  color: var(--c__blue);
}
.bl_drawer_nav_list li a::after {
  z-index: 1;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: "";
}
@media (max-width: 520px) {
  .bl_drawer_nav_list li a {
    font-size: 2.4rem;
  }
}
/* aria-expanded
    対象が展開されているか否かを示す属性 */
.bl_drawer[aria-expanded] {
  --duration: 0.25s;
  -webkit-transition-property: visibility;
  -webkit-transition-duration: var(--duration);
  transition-duration: var(--duration);
  transition-property: visibility;
}
.bl_drawer[aria-expanded] .bl_drawer_backdrop {
  -webkit-transition-property: opacity;
  -webkit-transition-duration: var(--duration);
  -webkit-transition-timing-function: linear;
  transition-duration: var(--duration);
  transition-property: opacity;
  transition-timing-function: linear;
}
.bl_drawer[aria-expanded] .bl_drawer_nav {
  -webkit-transition-property: -webkit-transform;
  -webkit-transition-duration: var(--duration);
  -webkit-transition-timing-function: ease;
  transition-duration: var(--duration);
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  transition-timing-function: ease;
}

/* 開いているとき */
.bl_drawer[aria-expanded="true"] {
  visibility: visible;
}
.bl_drawer[aria-expanded="true"] .bl_drawer_backdrop {
  opacity: 1;
}
.bl_drawer[aria-expanded="true"] .bl_drawer_nav {
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

/* 閉じているとき */
.bl_drawer[aria-expanded="false"] {
  visibility: hidden;
}
.bl_drawer[aria-expanded="false"] .bl_drawer_backdrop {
  opacity: 0;
}
.bl_drawer[aria-expanded="false"] .bl_drawer_nav {
  -webkit-transform: translateX(100%);
  transform: translateX(100%);
}

/* --------------------------------
 * ブロック：ロゴ
 * -------------------------------- */
.bl_logo {
  width: min(34.8rem, 100%);
}
.bl_logo a {
  display: inline-block;
  width: 100%;
  height: 100%;
}
.bl_logo a img {
  display: block;
  width: 100%;
}

.bl_logo.bl_logo__footer {
  width: min(23rem, 100%);
}

/* --------------------------------
 * メインビジュアル
 * -------------------------------- */
.bl_mainVisual {
  background-color: var(--c__lightGray);
}

.bl_mainVisual_item {
  display: grid;
  grid-template-rows: auto 1fr;
  grid-template-columns: auto auto;
  grid-template-areas: "txtArea imgArea" "ctaArea imgArea";
  grid-auto-flow: row;
  gap: 0px 0px;
}
.bl_mainVisual_item .bl_mainVisual_txtArea {
  grid-area: txtArea;
}
.bl_mainVisual_item .bl_mainVisual_imgArea {
  grid-area: imgArea;
}
.bl_mainVisual_item .bl_mainVisual_ctaArea {
  grid-area: ctaArea;
}

.bl_mainVisual_txtArea {
  padding-top: 4.8rem;
  padding-bottom: 2.9rem;
  text-align: center;
}
.bl_mainVisual_txtArea span {
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  display: block;
  font-weight: bold;
  text-align: center;
}

.bl_mainVisual_txtArea_mainCatch span {
  font-weight: 900;
}
.bl_mainVisual_txtArea_mainCatch span:nth-child(1) {
  padding-top: 1.5rem;
  padding-right: 2.6rem;
  padding-bottom: 2rem;
  padding-left: 2.6rem;
  background-color: var(--c__blue);
  color: var(--c__white);
  font-size: min(2.604166666666667vw, 5rem);
  letter-spacing: -1px;
  white-space: nowrap;
}
.bl_mainVisual_txtArea_mainCatch span:nth-child(2) {
  padding-right: 2.6rem;
  padding-left: 2.6rem;
  color: var(--c__blue);
  font-size: min(4.947916666666666vw, 9.5rem);
  letter-spacing: -5px;
  white-space: nowrap;
}

.bl_mainVisual_txtArea_subCatch {
  display: inline-block;
  margin: 1.8rem auto 0;
  padding-right: 2.6rem;
  padding-left: 2.6rem;
  color: var(--c__blue);
  font-weight: bold;
  font-size: min(1.25vw, 2.4rem);
  text-align: left;
}

.bl_mainVisual_cta {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  row-gap: 0.8rem;
  flex-direction: column;
  align-items: center;
  margin-top: 2.9rem;
  margin-bottom: 3rem;
}
.bl_mainVisual_cta .sub {
  display: inline-block;
  position: relative;
  color: var(--c__yellow);
  font-size: var(--fs__l);
}
.bl_mainVisual_cta .sub::before,
.bl_mainVisual_cta .sub::after {
  position: absolute;
  width: 2px;
  height: 100%;
  background-color: var(--c__yellow);
  content: "";
}
.bl_mainVisual_cta .sub::before {
  -webkit-transform: translateX(-2.5rem) rotate(-30deg);
  top: 0;
  left: 0;
  transform: translateX(-2.5rem) rotate(-30deg);
}
.bl_mainVisual_cta .sub::after {
  -webkit-transform: translateX(2.5rem) rotate(30deg);
  top: 0;
  left: 100%;
  transform: translateX(2.5rem) rotate(30deg);
}
.bl_mainVisual_cta .el_ctaBtn.el_ctaBtn__download {
  width: 80%;
  max-width: 33.8rem;
  padding-top: 1.8rem;
  padding-bottom: 1.8rem;
}

.bl_mainVisual_imgArea img {
  -o-object-fit: cover;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 768px) {
  .bl_mainVisual_txtArea_mainCatch span:nth-child(1) {
    font-size: min(6vw, 5rem);
  }
  .bl_mainVisual_txtArea_mainCatch span:nth-child(2) {
    font-size: min(9vw, 10rem);
    letter-spacing: -2px;
  }
  .bl_mainVisual_txtArea_subCatch {
    font-size: min(3vw, 2rem);
  }
}

/* --------------------------------
 * ブロック：パンくずリスト
 * -------------------------------- */
.bl_breadcrumb {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  z-index: 1;
  position: relative;
  margin-top: 0.8rem;
  line-height: 1;
}

.bl_breadcrumb_list {
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  list-style: none;
}
.bl_breadcrumb_list:not(:first-child) {
  margin-left: 0.8rem;
}
.bl_breadcrumb_list:not(:first-child)::before {
  -webkit-transform: rotate(45deg);
  -webkit-transform-origin: left;
  display: block;
  width: 5px;
  height: 5px;
  margin-right: 0.8rem;
  transform: rotate(45deg);
  transform-origin: left;
  border-top: 1.5px solid var(--c__black);
  border-right: 1.5px solid var(--c__black);
  content: "";
}

a.bl_breadcrumb_link {
  text-decoration: none;
}

.bl_breadcrumb_ttl {
  color: var(--c__text);
  font-size: var(--fs__xs);
}

/* --------------------------------
 * ブロック：CTAセクション
 * -------------------------------- */
.bl_ctaSec .el_ctaBtn.el_ctaBtn__download {
  width: 100%;
  max-width: 57.5rem;
  padding: 1.3rem 1.6rem 1.8rem;
  font-size: var(--fs__2l);
  box-sizing: border-box;
}
.bl_ctaSec .el_ctaBtn.el_ctaBtn__contact {
  width: 36rem;
  min-height: auto;
  padding: 2rem 1.6rem;
  border-radius: 4.8rem;
  background-color: var(--c__white);
  color: var(--c__blue);
  font-size: var(--fs__l);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
}
.bl_ctaSec .el_ctaBtn.el_ctaBtn__contact i {
  margin-right: 2rem;
  font-size: 3rem;
  vertical-align: middle;
}
.bl_ctaSec .el_ctaBtn.el_ctaBtn__contact:hover,
.bl_ctaSec .el_ctaBtn.el_ctaBtn__contact:focus {
  border-color: var(--c__blue);
  background-color: var(--c__blue);
  color: var(--c__white);
}
.bl_ctaSec .el_telInfo {
  text-align: center;
}
.bl_ctaSec .el_telInfo i,
.bl_ctaSec .el_telInfo a,
.bl_ctaSec .el_telInfo span {
  color: var(--c__white);
}
.bl_ctaSec .el_telInfo .el_telInfo_ttl {
  font-size: var(--fs__s);
}
.bl_ctaSec .el_telInfo .el_telInfo_txt {
  font-size: var(--fs__xs);
}

.bl_ctaSec_ttl,
.bl_ctaSec_txt {
  color: var(--c__white);
  text-align: center;
}

.bl_ctaSec_ttl {
  font-weight: 900;
  font-size: 3.6rem;
}

.bl_ctaSec_txt {
  margin-top: 0.8rem;
  font-weight: bold;
  font-size: var(--fs__xl);
}

.el_telInfo_number {
  font-size: 4.6rem;
  white-space: nowrap;
}
.el_telInfo_number i {
  margin-right: 0.8rem;
  font-size: 3.2rem;
}

.bl_ctaSec_ctaUnit {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 3.1rem;
  text-align: center;
}
.bl_ctaSec_ctaUnit .sub {
  position: relative;
  padding: 0.8rem 1.8rem;
  color: var(--c__yellow);
  font-weight: bold;
  font-size: var(--fs__l);
}
.bl_ctaSec_ctaUnit .sub::before,
.bl_ctaSec_ctaUnit .sub::after {
  position: absolute;
  top: 50%;
  width: 2px;
  height: 80%;
  background-color: var(--c__yellow);
  content: "";
}
.bl_ctaSec_ctaUnit .sub::before {
  -webkit-transform: translate(-50%, -50%) rotate(-30deg);
  left: 0;
  transform: translate(-50%, -50%) rotate(-30deg);
}
.bl_ctaSec_ctaUnit .sub::after {
  -webkit-transform: translate(-50%, -50%) rotate(30deg);
  right: 0;
  transform: translate(-50%, -50%) rotate(30deg);
}

.bl_ctaSec_contactUnit {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -webkit-column-gap: 12%;
  -moz-column-gap: 12%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 12%;
  row-gap: 1.6rem;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin-top: 5.8rem;
}

.bl_ctaSec.bl_ctaSec__pageBg,
.bl_ctaSec.bl_ctaSec__page {
  padding: 3.2rem 0 4.2rem;
}
.bl_ctaSec.bl_ctaSec__pageBg .bl_ctaSec_ttl,
.bl_ctaSec.bl_ctaSec__page .bl_ctaSec_ttl {
  margin: 0 auto;
}
.bl_ctaSec.bl_ctaSec__pageBg .bl_ctaSec_contactUnit,
.bl_ctaSec.bl_ctaSec__page .bl_ctaSec_contactUnit {
  -webkit-column-gap: 5%;
  -moz-column-gap: 5%;
  column-gap: 5%;
  margin-top: 2rem;
}

.bl_ctaSec.bl_ctaSec__page {
  position: relative;
  border-top: 3px solid var(--c__blue);
  border-bottom: 3px solid var(--c__blue);
}
.bl_ctaSec.bl_ctaSec__page::before,
.bl_ctaSec.bl_ctaSec__page::after {
  z-index: 1;
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: var(--c__blue);
  content: "";
}
.bl_ctaSec.bl_ctaSec__page::before {
  top: 0.4rem;
}
.bl_ctaSec.bl_ctaSec__page::after {
  bottom: 0.4rem;
}
.bl_ctaSec.bl_ctaSec__page .bl_ctaSec_ttl,
.bl_ctaSec.bl_ctaSec__page .bl_ctaSec_txt {
  color: var(--c__blue);
}
.bl_ctaSec.bl_ctaSec__page .bl_ctaSec_ttl {
  position: relative;
}
.bl_ctaSec.bl_ctaSec__page .bl_ctaSec_ttl::after {
  -webkit-transform: translateX(-50%);
  z-index: -1;
  position: absolute;
  bottom: 0;
  left: 50%;
  width: min(55rem, 98%);
  height: 1.3rem;
  transform: translateX(-50%);
  background-color: var(--c__lightBlue);
  content: "";
}
.bl_ctaSec.bl_ctaSec__page .el_telInfo_ttl,
.bl_ctaSec.bl_ctaSec__page .el_telInfo_number i,
.bl_ctaSec.bl_ctaSec__page .el_telInfo_number span,
.bl_ctaSec.bl_ctaSec__page .el_telInfo_txt {
  color: var(--c__blue);
}

/* --------------------------------
 * ブロック：円状画像のメディア要素
 * -------------------------------- */
.bl_circleImgMedia_wrap {
  margin-top: 5.5rem;
}

.bl_circleImgMedia {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  -webkit-column-gap: 5.58%;
  -moz-column-gap: 5.58%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  column-gap: 5.58%;
  justify-content: center;
  align-items: center;
  margin-bottom: 1.6rem;
}
.bl_circleImgMedia::before {
  -webkit-transform: translateY(-50%);
  z-index: -1;
  position: absolute;
  top: 50%;
  right: 0;
  width: 90%;
  height: 16.8rem;
  transform: translateY(-50%);
  border-radius: 7.8rem;
  background-color: var(--c__lightBlue);
  content: "";
}

.bl_circleImgMedia_imgWrap {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  -webkit-box-flex: 0;
  -webkit-flex: 0 1 39.4%;
  -ms-flex: 0 1 39.4%;
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  position: relative;
  flex: 0 1 39.4%;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-radius: 50%;
}
.bl_circleImgMedia_imgWrap::before {
  -webkit-transform: translateY(-50%);
  position: absolute;
  top: 50%;
  left: 0;
  aspect-ratio: 1/1;
  width: 100%;
  transform: translateY(-50%);
  border-radius: 50%;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(var(--c__overlay02)),
    to(var(--c__overlay02))
  );
  background: linear-gradient(var(--c__overlay02), var(--c__overlay02));
  content: "";
}
.bl_circleImgMedia_imgWrap img {
  -o-object-fit: cover;
  -o-object-position: center;
  aspect-ratio: 1/1;
  width: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: 50%;
}

.bl_circleImgMedia_body {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  margin-top: -11%;
  padding-right: 4rem;
}

.bl_circleImgMedia_ttl {
  color: var(--c__blue);
  font-weight: 900;
  font-size: var(--fs__2l);
}

.bl_circleImgMedia_txt {
  margin-top: 2rem;
}

.bl_circleImgMedia.bl_circleImgMedia__re {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
.bl_circleImgMedia.bl_circleImgMedia__re::before {
  -webkit-transform: translateY(-50%);
  z-index: -1;
  top: 48%;
  right: auto;
  left: 0;
  width: 90%;
  transform: translateY(-50%);
  border-radius: 7.8rem;
}
.bl_circleImgMedia.bl_circleImgMedia__re .bl_circleImgMedia_ttl {
  text-align: right;
}
.bl_circleImgMedia.bl_circleImgMedia__re .bl_circleImgMedia_body {
  padding-right: 0;
  padding-left: 4rem;
}

@media (max-width: 520px) {
  .bl_circleImgMedia {
    margin-bottom: 4rem;
    flex-direction: column;
  }
  .bl_circleImgMedia.bl_circleImgMedia__re {
    flex-direction: column;
  }
  .bl_circleImgMedia::before {
    display: none;
  }
  .bl_circleImgMedia_body {
    margin-top: 0;
    background-color: var(--c__lightBlue);
    padding: 5rem 4rem 4rem;
    margin-top: -4rem;
    border-radius: 5rem;
  }
  .bl_circleImgMedia.bl_circleImgMedia__re .bl_circleImgMedia_body {
    padding: 5rem 4rem 4rem;
  }
  .bl_circleImgMedia_ttl {
    text-align: center;
  }
  .bl_circleImgMedia.bl_circleImgMedia__re .bl_circleImgMedia_ttl {
    text-align: center;
  }
}

/* --------------------------------
 * ブロック：カルーセル（事例）
 * -------------------------------- */
.bl_caseCarousel {
  margin-top: 6rem;
  overflow: hidden;
}

.bl_caseCarousel_card {
  -webkit-transition: 0.5s all;
  display: block;
  min-height: 41.5rem;
  margin: 0 2.88rem;
  color: currentColor;
  text-decoration: none;
  transition: 0.5s all;
}
.bl_caseCarousel_card .bl_card_imgWrap {
  overflow: hidden;
  border-radius: 1.5rem 1.5rem 0 0;
  margin: 0;
  aspect-ratio: 16 / 9;
}
.bl_caseCarousel_card .bl_card_body {
  padding: 1rem 2.75rem 2.85rem;
  border-radius: 0 0 1.5rem 1.5rem;
  background-color: var(--c__white);
}
.bl_caseCarousel_card .bl_card_imgWrap > img {
  -webkit-transition: 0.5s all;
  transition: 0.5s all;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.bl_caseCarousel_card .bl_card_cat {
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.55);
  -webkit-transform: translateX(-5.1rem);
  display: inline-block;
  min-width: 20.7rem;
  padding: 0.3rem 1.6rem;
  transform: translateX(-5.1rem);
  background-color: var(--c__blue);
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.55);
  color: var(--c__white);
  font-size: var(--fs__s);
}
.bl_caseCarousel_card .bl_card_ttl {
  margin-top: 1.1rem;
  color: var(--c__blue);
  font-size: var(--fs__l);
}
.bl_caseCarousel_card .bl_card_txt {
  margin-top: 1.1rem;
}
.bl_caseCarousel_card:hover .bl_card_imgWrap > img,
.bl_caseCarousel_card:focus .bl_card_imgWrap > img {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
  opacity: 0.6;
}

.bl_swiper_cont {
  position: relative;
  width: 100%;
  max-width: 128rem;
  margin-right: auto;
  margin-left: auto;
  padding: 0 2rem 9rem;
  /* ページネーションの余白 */
  /* ページネーションのサイズと色 */
}
.bl_swiper_cont .bl_swiper_pagination_wrap {
  -webkit-transform: translateX(-50%);
  display: inline-block;
  position: absolute;
  left: 50%;
  width: min(42.7rem, 90%);
  margin: 0 auto;
  margin-top: 6.8rem;
  transform: translateX(-50%);
  /* 前への矢印 */
  /* 次への矢印 */
  /* ページネーション */
}
.bl_swiper_cont .bl_swiper_pagination_wrap .swiper-button-prev,
.bl_swiper_cont .bl_swiper_pagination_wrap .swiper-button-next {
  color: var(--c__blue);
}
.bl_swiper_cont .bl_swiper_pagination_wrap .swiper-button-prev {
  left: 0;
}
.bl_swiper_cont .bl_swiper_pagination_wrap .swiper-button-next {
  right: 0;
}
.bl_swiper_cont
  .bl_swiper_pagination_wrap
  .swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: -1rem;
}
.bl_swiper_cont .bl_swiper_pagination_wrap .swiper-button-next:after,
.bl_swiper_cont .bl_swiper_pagination_wrap .swiper-button-prev:after {
  font-size: 4.4rem;
}
.bl_swiper_cont
  .swiper-horizontal
  > .swiper-pagination-bullets
  .swiper-pagination-bullet,
.bl_swiper_cont
  .swiper-pagination-horizontal.swiper-pagination-bullets
  .swiper-pagination-bullet {
  margin: 0 1.4rem;
}
.bl_swiper_cont .swiper-pagination-bullet {
  width: 1.8rem;
  height: 1.8rem;
  background-color: var(--c__white);
  opacity: 1;
}
.bl_swiper_cont .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: var(--c__blue);
}
@media (max-width: 600px) {
  .swiper02 {
    overflow: hidden;
  }
}

/* --------------------------------
 * ブロック：バルーン
 * -------------------------------- */
.bl_balloonWrap {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-top: 3.8rem;
}

.bl_customerBalloon {
  display: inline-block;
  position: relative;
  width: min(47.1rem, 100%);
  padding: 2rem min(3.9rem, 4%);
  border-radius: 1.5rem;
  background: var(--c__blue);
  text-align: center;
}
.bl_customerBalloon::after {
  -webkit-transform: translateX(-50%);
  position: absolute;
  bottom: -2.5rem;
  left: 40%;
  width: 2.7rem;
  height: 3.2rem;
  transform: translateX(-50%);
  background-image: url("../img/balloon.png");
  background-size: contain;
  content: "";
}
.bl_customerBalloon:not(:first-of-type) {
  margin-top: 6.4rem;
}

.bl_customerBalloon_txt {
  color: var(--c__white);
  font-weight: bold;
  font-size: var(--fs__l);
}

.bl_officialBalloon {
  display: inline-block;
  position: relative;
  width: min(65.4rem, 100%);
  margin-top: 4rem;
  padding: 2.6rem min(2.9rem, 4%) 2.1rem;
  border-radius: 1.5rem;
  background-color: var(--c__lightBlue);
  box-sizing: border-box;
}
.bl_officialBalloon .bl_officialBalloon_ttl {
  position: absolute;
  top: -1.4rem;
}

.bl_officialBalloon_ttl {
  display: inline-block;
  position: relative;
  color: var(--c__blue);
  font-weight: 900;
  font-size: var(--fs__l);
}
.bl_officialBalloon_ttl::after {
  -webkit-transform: translateY(-50%) rotate(20deg);
  position: absolute;
  top: 50%;
  right: -2rem;
  transform: translateY(-50%) rotate(20deg);
  content: "！";
}

.bl_officialBalloon_txt {
  font-size: var(--fs__l);
}
.bl_officialBalloon_txt .emphasis {
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(80%, transparent),
    color-stop(80%, rgba(255, 157, 0, 0.6))
  );
  background: linear-gradient(transparent 80%, rgba(255, 157, 0, 0.6) 80%);
  font-weight: bold;
}

.bl_customerBalloon.bl_customerBalloon__re {
  -webkit-align-self: flex-end;
  -ms-flex-item-align: end;
  align-self: flex-end;
}
.bl_customerBalloon.bl_customerBalloon__re::after {
  -webkit-transform: scale(-1, 1);
  left: 60%;
  transform: scale(-1, 1);
}

.bl_officialBalloon.bl_officialBalloon__re {
  -webkit-align-self: flex-end;
  -ms-flex-item-align: end;
  align-self: flex-end;
}

/* --------------------------------
 * 下層ページ：導入部分
 * -------------------------------- */
.pg_intro {
  margin-top: 4rem;
}

.pg_intro_imgWrap {
  -webkit-box-shadow: var(--c__shadow);
  box-shadow: var(--c__shadow);
}

.pg_intro_catch {
  margin-top: 2.5rem;
  padding-bottom: 0.8rem;
  border-bottom: 2px solid var(--c__blue);
  color: var(--c__blue);
  font-size: var(--fs__1l);
}

.pg_intro_txt {
  margin-top: 2.6rem;
}

.pg_intro_question_imgWrap {
  width: min(61.8rem, 95%);
  margin: 2rem auto 0;
}

.pg_intro_questionTtl {
  font-weight: 900;
  font-size: var(--fs__l);
  text-align: center;
}

.pg_intro_question_txt {
  margin-top: 2rem;
}

.pg_intro_questionBox {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  width: min(58rem, 95%);
  margin-top: 3.5rem;
  margin-right: auto;
  margin-left: auto;
  border: 2px solid var(--c__blue);
}

.pg_intro_questionList {
  padding: 2rem 1rem 2.5rem;
}
.pg_intro_questionList .emphasis {
  color: var(--c__yellow);
  font-weight: bold;
}
.pg_intro_questionList li + li {
  margin-top: 1.4rem;
}
.pg_intro_questionList li {
  position: relative;
  padding-left: 2rem;
  list-style: none;
}
.pg_intro_questionList li::before {
  -webkit-transform: translateY(-50%);
  position: absolute;
  top: 50%;
  left: 0;
  width: 1rem;
  height: 1rem;
  transform: translateY(-50%);
  border-radius: 55%;
  background-color: var(--c__blue);
  content: "";
}

/* --------------------------------
 * 下層ページ：特徴セクション
 * -------------------------------- */
.pg_featureSec_circleWrap {
  margin-top: 3.6rem;
}
.pg_featureSec_circleWrap > img {
  display: block;
  width: min(64.6rem, 100%);
  margin: 0 auto;
}

.pg_featureSec_desc {
  margin-top: 4rem;
}
.pg_featureSec_desc p {
  margin-top: 1.6rem;
}
.pg_featureSec_desc p:first-of-type {
  margin-top: 0;
}

.pg_featureSec_imgUnit {
  -webkit-box-align: stretch;
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  -webkit-column-gap: 3.6%;
  -moz-column-gap: 3.6%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 3.6%;
  row-gap: 1.6rem;
  align-items: stretch;
  justify-content: center;
  margin-top: 5.6rem;
}
.pg_featureSec_imgUnit .pg_featureSec_imgWrap {
  -webkit-box-flex: 0;
  -webkit-flex: 0 1 21.3rem;
  -ms-flex: 0 1 21.3rem;
  flex: 0 1 21.3rem;
}
.pg_featureSec_imgUnit .pg_featureSec_imgWrap img {
  -o-object-fit: contain;
  min-height: 14.2rem;
  object-fit: contain;
  background-color: #ececec;
}

.pg_featureSec_imgUnit.pg_featureSec_imgUnit__grid {
  -webkit-column-gap: 9%;
  -moz-column-gap: 9%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 9%;
  row-gap: 3rem;
}
.pg_featureSec_imgUnit.pg_featureSec_imgUnit__grid .pg_featureSec_imgWrap img {
  /* aspect-ratio: 327/165; */
}

.pg_featureSec_caption {
  margin-top: 1.6rem;
  font-size: var(--fs__xs);
  text-align: center;
}

/* --------------------------------
* 下層ページ：種類セクション
* -------------------------------- */
.pg_typeSec_intro {
  margin-top: 2rem;
}

.pg_typeSec_card {
  position: relative;
  padding: 1.6rem 0.8rem;
}
.pg_typeSec_card .pg_typeSec_card_ttl {
  position: absolute;
  top: -0.4rem;
  left: -0.2rem;
}
.pg_typeSec_card:first-of-type {
  margin-top: 4rem;
}

.pg_typeSec_card + .pg_typeSec_card {
  margin-top: 8.1rem;
}

.pg_typeSec_card_caption {
  font-size: var(--fs__s);
}

.pg_typeSec_card_ttl {
  -webkit-box-shadow: var(--c__shadow02);
  display: inline-block;
  padding: 0.8rem 2.4rem;
  background-color: var(--c__blue);
  box-shadow: var(--c__shadow02);
  color: var(--c__white);
  font-weight: 900;
  font-size: var(--fs__l);
}

.pg_typeSec_card_body {
  margin-top: 2rem;
}

.pg_typeSec_card_list {
  padding-left: 2rem;
}
.pg_typeSec_card_list li {
  padding-left: 2.4rem;
  font-size: var(--fs__m);
  line-height: calc(32 / 16);
  list-style-position: inside;
  list-style-type: disc;
  text-indent: -3.4rem;
}

/* --------------------------------
 * 下層ページ：活用シーンセクション
 * -------------------------------- */
.pg_sceneSec_media {
  -webkit-column-gap: 2rem;
  -moz-column-gap: 2rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  column-gap: 2rem;
  margin-top: 6.4rem;
  padding-left: 1rem;
}
.pg_sceneSec_media .pg_sceneSec_mediaTtl {
  position: absolute;
  top: -2.4rem;
  left: 0.5rem;
  margin-top: 0;
}
.pg_sceneSec_media_imgWrap {
  width: 35%;
}
.pg_sceneSec_media .pg_sceneSec_media_txtArea {
  width: 70%;
  margin-top: 3rem;
}
@media (max-width: 520px) {
  .pg_sceneSec_media .pg_sceneSec_media_txtArea {
    width: 100%;
  }
}

.pg_sceneSec_listTtl,
.pg_sceneSec_mediaTtl {
  -webkit-box-shadow: var(--c__shadow02);
  display: inline-block;
  padding: 0.8rem 2.4rem;
  background-color: var(--c__blue);
  box-shadow: var(--c__shadow02);
  color: var(--c__white);
  font-weight: 900;
  font-size: var(--fs__l);
}

.pg_sceneSec_listTtl {
  margin-top: 2.8rem;
}
.pg_sceneSec_listTtl:first-of-type {
  margin-top: 3.5rem;
}

.pg_sceneSec_list li {
  padding-left: 2.4rem;
  font-size: var(--fs__s);
  line-height: calc(30 / 14);
  list-style-position: inside;
  list-style-type: disc;
  text-indent: -1.4rem;
}

/* バーチャル空間制作の活用シーン */
.virtual-createive .pg_sceneSec_list {
  margin-top: 1.6rem;
  padding-left: 2rem;
  text-indent: -3.4rem;
}
@media (max-width: 520px) {
  .pg_sceneSec_media {
    flex-direction: column;
  }
  .pg_sceneSec_media .pg_sceneSec_media_imgWrap {
    width: 80%;
    margin: 0 auto;
  }
  /*.pg_sceneSec_list li{
    list-style-type: none;
    list-style-position: initial;
    text-indent: 0;
    padding-left: 0;
  }*/
}

/* --------------------------------
 * 下層ページ：機能セクション
 * -------------------------------- */
.pg_functionSec_mediaWrap {
  -webkit-column-gap: 4rem;
  -moz-column-gap: 4rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 4rem;
  row-gap: 2.9rem;
  margin-top: 3.9rem;
  padding: 0 4rem 0;
}
.pg_functionSec_media {
  -webkit-column-gap: 1.7rem;
  -moz-column-gap: 1.7rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 1.7rem;
}
.pg_functionSec_media .pg_functionSec_media_imgArea {
  -webkit-box-flex: 0;
  -webkit-flex: 0 1 8.9rem;
  -ms-flex: 0 1 8.9rem;
  flex: 0 1 8.9rem;
}
.pg_functionSec_media .pg_functionSec_media_txtArea {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.pg_functionSec_media_ttl {
  font-weight: 900;
  font-size: var(--fs__l);
}

.pg_functionSec_media_txt {
  margin-top: 1.2rem;
  font-size: var(--fs__s);
}

/* --------------------------------
 * 下層ページ：運用サポートセクション
 * -------------------------------- */
.pg_opeSupSec_table {
  width: min(64.6rem, 100%);
  margin-top: 7.2rem;
  margin-right: auto;
  margin-left: auto;
  border: 1px solid var(--c__black);
  border-collapse: collapse;
}
.pg_opeSupSec_table th,
.pg_opeSupSec_table td {
  border-bottom: 1px solid var(--c__black);
  border-collapse: collapse;
  box-sizing: border-box;
}
.pg_opeSupSec_table th {
  width: 23%;
  padding: 2.3rem 1rem;
  background-color: var(--c__lightBlue);
  font-weight: bold;
  vertical-align: middle;
}
.pg_opeSupSec_table td {
  width: 77%;
  padding: 2.3rem 2.4rem;
}
.pg_opeSupSec_table tr:last-child td {
  border-bottom: none;
}

.pg_opeSupSec_tableMediaUnit {
  display: grid;
  grid-template-rows: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
  row-gap: 2.3rem;
}

.pg_opeSupSec_tableMedia {
  -webkit-column-gap: 1.6rem;
  -moz-column-gap: 1.6rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 1.6rem;
  align-items: center;
}
.pg_opeSupSec_tableMedia i {
  display: inline-block;
  width: 3.6rem;
  height: auto;
}
.pg_opeSupSec_tableMedia span {
  font-weight: bold;
  font-size: var(--fs__s);
}

.pg_opeSupSec_media {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  width: 64rem;
  margin-right: auto;
  margin-left: auto;
  overflow: hidden;
  border-radius: 1rem;
}
.pg_opeSupSec_media:first-of-type {
  margin-top: 3.2rem;
}
.pg_opeSupSec_media .pg_opeSupSec_media_imgArea {
  -webkit-box-flex: 0;
  -webkit-flex: 0 1 17rem;
  -ms-flex: 0 1 17rem;
  flex: 0 1 17rem;
}
.pg_opeSupSec_media .pg_opeSupSec_media_imgArea img {
  -o-object-fit: cover;
  height: 100%;
  object-fit: cover;
}
.pg_opeSupSec_media .pg_opeSupSec_media_txtArea {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding: 1.5rem 2rem 1.3rem;
  background-color: var(--c__lightGray);
}

.pg_opeSupSec_media + .pg_opeSupSec_media {
  margin-top: 1.2rem;
}

.pg_opeSupSec_media_ttl {
  font-weight: 900;
  font-size: var(--fs__l);
}

.pg_opeSupSec_media_txt {
  margin-top: 0.4rem;
  font-size: var(--fs__s);
}

/* --------------------------------
 * 下層ページ：導入フロー
 * -------------------------------- */
.pg_flowSec_imgWrap {
  width: 80%;
  margin: 3.5rem auto 0;
}

/* --------------------------------
 * 下層ページ：サンプル動画
 * -------------------------------- */
.pg_movieSec_movieWrap {
  margin-top: 7.6rem;
}
.pg_movieSec_movieWrap:first-of-type {
  margin-top: 3.5rem;
}
.pg_movieSec_movieWrap iframe {
  aspect-ratio: 725/405;
  width: 100%;
  margin-top: 1.6rem;
}

.pg_movieSec_movieTtl {
  color: var(--c__blue);
  font-size: var(--fs__xl);
  text-align: center;
}

/* --------------------------------
 * 下層ページ：事例セクション
 * -------------------------------- */
.pg_caseSec_mediaWrap {
  margin-top: 3.5rem;
}

.pg_caseSec_media {
  margin-top: 5rem;
  background-color: var(--c__lightGray);
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

.pg_caseSec_media_imgWrap {
  overflow: hidden;
  border-radius: 1.5rem 0 0 1.5rem;
  margin: 0;
  width: 40%;
}
.pg_caseSec_media_imgWrap > img {
  -o-object-fit: cover;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pg_caseSec_media_body {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  -webkit-justify-content: space-around;
  -ms-flex-pack: distribute;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  flex-direction: column;
  justify-content: space-around;
  padding: 5.5rem 2.9rem 2.75rem;
  width: 60%;
  box-sizing: border-box;
  border-radius: 0 1.5rem 1.5rem 0;
  background: #fff;
}

.pg_caseSec_media_cat {
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.55);
  position: absolute;
  top: 1rem;
  left: 0;
  padding: 0.3rem 2.8rem 0.3rem 1.4rem;
  background-color: var(--c__blue);
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.55);
  color: var(--c__white);
  font-size: var(--fs__s);
}

.pg_caseSec_media_ttl {
  color: var(--c__blue);
  font-weight: bold;
  font-size: var(--fs__xl);
}

.pg_caseSec_media_txt {
  margin-top: 0.95rem;
}

a.pg_caseSec_media_link {
  color: var(--c__blue);
}

a.pg_caseSec_media_more {
  -webkit-align-self: end;
  -ms-flex-item-align: end;
  display: inline-block;
  align-self: end;
  width: 14.1rem;
  margin-top: 1.6rem;
  padding-right: 0.8rem;
  padding-bottom: 0.45rem;
  border-bottom: 1px solid var(--c__blue);
  color: var(--c__blue);
  text-align: right;
  text-decoration: none;
  white-space: nowrap;
  transition: all 0.3s ease;
}
a.pg_caseSec_media_more:hover {
  color: var(--c__yellow);
  border-bottom: 1px solid var(--c__yellow);
}

.pg_caseSec.pg_caseSec__box .pg_caseSec_media {
  -webkit-box-shadow: var(--c__shadow);
  row-gap: 1.6rem;
  padding: 1rem;
  box-shadow: var(--c__shadow);
}
.pg_caseSec.pg_caseSec__box .pg_caseSec_media_cat {
  top: 0;
}
.pg_caseSec.pg_caseSec__box .pg_caseSec_media_imgWrap {
  overflow: auto;
  border-radius: 0;
}
.pg_caseSec.pg_caseSec__box .pg_caseSec_media_imgWrap > img {
  -o-object-fit: cover;
  aspect-ratio: 292/212;
  width: 100%;
  height: auto;
  object-fit: cover;
}
.pg_caseSec.pg_caseSec__box
  .pg_caseSec_media_imgWrap
  > img:not(:first-of-type) {
  margin-top: 0.8rem;
}
@media (max-width: 520px) {
  .pg_caseSec_media {
    flex-direction: column;
  }
  .pg_caseSec_media_imgWrap {
    width: 100%;
  }
  .pg_caseSec_media_body {
    width: 100%;
    margin-top: -3rem;
  }
  .pg_caseSec.pg_caseSec__box .pg_caseSec_media_imgWrap {
    max-width: 40rem;
    margin: 0 auto;
  }
}

/* --------------------------------
* 下層ページ：支援内容セクション
* -------------------------------- */
.pg_supportSec_imgWrap {
  width: min(57rem, 100%);
  margin: 3.5rem auto 0;
}

/* --------------------------------
 * ブロック:サイド
 * -------------------------------- */
.bl_aside_list {
  position: -webkit-sticky;
  position: sticky;
  top: 14.4rem;
}
.bl_aside_list li {
  list-style: none;
  white-space: nowrap;
}
.bl_aside_list > li {
  margin-bottom: 2.5rem;
}
.bl_aside_list li a {
  color: var(--c__text);
  text-decoration: none;
}
.bl_aside_list > li > a {
  padding: 0.8rem 1rem 0.8rem;

  white-space: nowrap;
  display: block;
  margin-bottom: 1rem;
}
.bl_aside_list > li.menu-item-has-children > a {
  border-bottom: 1px solid var(--c__blue);
}
.bl_aside_list > li > a {
  color: var(--c__blue);
  font-weight: bold;
}
.bl_aside_list > li.current-menu-item > a {
  background-color: var(--c__blue);
  color: var(--c__white);
}
.bl_aside_list > ul {
  padding-top: 1.45rem;
}
.bl_aside_list li > ul > li {
  position: relative;
  padding: 0.8rem 1rem 0.8rem 4.5rem;
}
.bl_aside_list li > ul > li::before {
  -webkit-transform: translateY(-50%);
  position: absolute;
  top: 50%;
  left: 2.4rem;
  width: 0;
  height: 0;
  transform: translateY(-50%);
  border-width: 0.7rem 0 0.7rem 1.2rem;
  border-style: solid;
  border-color: transparent transparent transparent var(--c__blue);
  content: "";
}
.bl_aside_list li > ul > li.current-menu-item {
  background-color: var(--c__blue);
}
.bl_aside_list li > ul > li.current-menu-item > a {
  color: var(--c__white);
}
.bl_aside_list li > ul > li.current-menu-item::before {
  border-color: transparent transparent transparent var(--c__white);
}

/* --------------------------------
 * ヘッダー
 * -------------------------------- */
.ly_header {
  -webkit-box-shadow: var(--c__shadow02);
  z-index: 20;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: var(--c__shadow02);
}

.ly_header_inner {
  -webkit-column-gap: 1.8rem;
  -moz-column-gap: 1.8rem;
  -webkit-box-align: stretch;
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 1.8rem;
  align-items: stretch;
  justify-content: space-between;
  width: 100%;
  min-height: var(--hi__header);
  padding-top: 2.2rem;
  padding-right: var(--pd__inner);
  padding-bottom: 2.2rem;
  padding-left: var(--pd__inner);
}

.bl_header_leftArea {
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  -webkit-column-gap: 7.2rem;
  -moz-column-gap: 7.2rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 7.2rem;
  align-items: center;
}
.bl_header_leftArea .bl_logo {
  -webkit-box-flex: 0;
  -webkit-flex: 0 1 34.8rem;
  -ms-flex: 0 1 34.8rem;
  flex: 0 1 34.8rem;
}
.bl_header_leftArea .bl_gNav {
  -webkit-box-flex: 0;
  -webkit-flex: 0 1 49rem;
  -ms-flex: 0 1 49rem;
  flex: 0 1 49rem;
}

.bl_header_rightArea {
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  -webkit-column-gap: 3.2rem;
  -moz-column-gap: 3.2rem;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
  -ms-flex-pack: end;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 3.2rem;
  row-gap: 1.6rem;
  align-items: center;
  justify-content: flex-end;
  margin-left: 2rem;
}

.bl_header_rightArea_btnUnit {
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  -webkit-column-gap: 2.2rem;
  -moz-column-gap: 2.2rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 2.2rem;
  align-items: center;
}
.bl_header_rightArea_btnUnit .el_ctaBtn.el_ctaBtn__contact {
  min-height: 4.7rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.bl_headereBtn_wrap {
  display: none;
}

.bl_gNav_list {
  -webkit-column-gap: 2.6rem;
  -moz-column-gap: 2.6rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 2.6rem;
  list-style: none;
}
.bl_gNav_list li {
  list-style: none;
}
.bl_gNav_list a {
  display: inline-block;
  position: relative;
  width: 100%;
  margin-top: -1rem;
  margin-bottom: -1rem;
  padding-top: 1.7rem;
  padding-bottom: 1.7rem;
  color: var(--c__text);
  text-decoration: none;
  white-space: nowrap !important;
}
.bl_gNav_list a:hover,
.bl_gNav_list a:focus {
  color: var(--c__blue);
}
.bl_gNav_list > li {
  position: relative;
  padding: 1rem 0;
}
.bl_gNav_list > li > ul {
  -webkit-transform: translateY(-1rem);
  -webkit-transition: opacity 0.5s, -webkit-transform 0.5s;
  -webkit-box-shadow: var(--c__shadow);
  visibility: hidden;
  position: absolute;
  top: 4.5rem;
  left: 0;
  padding-top: 0;
  padding-bottom: 1.6rem;
  transform: translateY(-1rem);
  background-color: var(--c__white);
  box-shadow: var(--c__shadow);
  opacity: 0;
  transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, transform 0.5s;
  transition: opacity 0.5s, transform 0.5s, -webkit-transform 0.5s;
}
.bl_gNav_list > li > ul > li {
  padding: 0.4rem 1.6rem;
}
.bl_gNav_list > li > ul > li:hover {
  background-color: var(--c__lightGray);
}
.bl_gNav_list li:hover > ul {
  -webkit-transform: translateY(0);
  visibility: visible;
  transform: translateY(0);
  opacity: 1;
}

/* --------------------------------
 * フッター
 * -------------------------------- */
footer.ly_footer {
  padding: 7.5rem 0 10rem;
  background: none;
}

.ly_footer_inner {
  width: min(var(--wd__inner) + var(--pd__inner) * 2, 100%);
  margin: 0 auto;
  padding: 0 var(--pd__inner) 0;
}

.bl_footer_topArea {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

.bl_footer_infoUnit {
  -webkit-box-flex: 0;
  -webkit-flex: 0 1 35%;
  -ms-flex: 0 1 35%;
  flex: 0 1 35%;
}
.bl_footer_menuUnit {
  flex-grow: 1;
}
.bl_footer_infoUnit_ttl {
  margin-bottom: 1.5em;
  color: var(--c__text);
  font-weight: 900;
}

address.bl_footer_infoUnit_address {
  margin-top: 2.28rem;
  font-style: normal;
}
address.bl_footer_infoUnit_address a,
address.bl_footer_infoUnit_address p {
  font-size: var(--fs__s);
  color: var(--c__text);
}
address.bl_footer_infoUnit_address a {
  display: block;
  color: var(--c__text);
  text-decoration: none;
}

.bl_footer_menu {
  -webkit-column-gap: 3rem;
  -moz-column-gap: 3rem;
  display: grid;
  grid-template-rows: repeat(5, auto);
  grid-template-columns: repeat(2, 1fr);
  grid-auto-flow: column;
  column-gap: 3rem;
  row-gap: 0.8rem;
  padding: 0 1.6rem 0;
}
.bl_footer_menu ul {
  padding-left: 1.6rem;
}
.bl_footer_menu ul > li {
  position: relative;
  padding-left: 2rem;
}
.bl_footer_menu ul > li::before {
  -webkit-transform: translateY(-50%);
  position: absolute;
  top: 55%;
  left: 0.2rem;
  width: 1rem;
  height: 1px;
  transform: translateY(-50%);
  background-color: var(--c__text);
  content: "";
}
.bl_footer_menu li {
  list-style: none;
}
.bl_footer_menu li a {
  display: inline-block;
  position: relative;
  width: 100%;
  color: var(--c__text);
  font-size: var(--fs__s);
  text-decoration: none;
  /* リンク領域の拡大 */
}
.bl_footer_menu li a::before {
  z-index: 1;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: "";
}
.bl_footer_menu li a::after {
  -webkit-transition: width 0.3s linear;
  position: absolute;
  bottom: -0.3rem;
  left: 0;
  width: 0%;
  height: 1px;
  background-color: var(--c__text);
  content: "";
  transition: width 0.3s linear;
}
.bl_footer_menu li:hover > a::after {
  width: 100%;
}

.bl_footer_snsList {
  -webkit-column-gap: 11rem;
  -moz-column-gap: 11rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 11rem;
  align-items: center;
  justify-content: center;
  margin-top: 8rem;
}
.bl_footer_snsList li {
  list-style: none;
}
.bl_footer_snsList img {
  width: 5.2rem;
  transition: all 0.3s ease-in-out;
}
.bl_footer_snsList a:hover img {
  opacity: 0.7;
}

.bl_footer_copyright {
  margin-top: 3.7rem;
  font-size: var(--fs__l);
  text-align: center;
  color: #333;
}

.bl_footer_ctaArea {
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  -webkit-column-gap: 3.3rem;
  -moz-column-gap: 3.3rem;
  display: none;
  z-index: 20;
  position: fixed;
  bottom: 0;
  left: 0;
  gap: 1rem;
  width: 100%;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding-top: 1rem;
  padding-bottom: 1rem;
  background: rgba(255, 255, 255, 0.9);
}

.bl_footer_ctaArea_infoUnit .el_telInfo,
.bl_footer_ctaArea_infoUnit .el_telInfo_ttl {
  color: var(--c__blue);
  text-align: center;
}
.bl_footer_ctaArea_infoUnit .el_telInfo_ttl {
  display: block;
  font-weight: bold;
  font-size: 3rem;
}
.bl_footer_ctaArea_infoUnit .el_telInfo_ttl span {
  margin-left: 1rem;
}
.bl_footer_menu .sub-menu li {
  margin: 1rem;
}
@media (max-width: 768px) {
  .bl_footer_menu {
    row-gap: 2.5rem;
    grid-auto-flow: row;
  }
}

/* --------------------------------
 * トップページ
 * -------------------------------- */
.tp_sec_desc {
  margin-top: 3.2rem;
  font-size: var(--fs__l);
  text-align: center;
}

.tp_featureSec,
.tp_serviceSec {
  margin-top: 9.2rem;
}

.tp_featureSec_empText {
  margin-top: 4rem;
  font-weight: 900;
  font-size: var(--fs__1l);
  text-align: center;
}

.tp_aboutSec_imgUnit {
  margin-top: 4.4rem;
}
.tp_aboutSec_imgUnit > img {
  -o-object-fit: contain;
  width: 100%;
  object-fit: contain;
}

.tp_featureSec .bl_media {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin-top: 5.6rem;
  padding-bottom: 5.6rem;
}
.tp_featureSec .bl_media .bl_media_imaArea {
  -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
  z-index: 1;
  padding: 1.5% 1.5%;
  background-color: var(--c__lightGray);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
  width: 45%;
}
.tp_featureSec .bl_media .bl_media_imaArea img {
  -o-object-fit: cover;
  aspect-ratio: 442/288;
  height: 100%;
  object-fit: cover;
}
.tp_featureSec .bl_media .bl_media_txtArea {
  -webkit-transform: translateY(1rem);
  padding-right: min(5.3rem, 5%);
  padding-left: 2.5%;
  transform: translateY(1rem);
  width: 55%;
}
.tp_featureSec .bl_media .bl_media_txtArea::after {
  z-index: -1;
  position: absolute;
  right: 0;
  bottom: -4rem;
  width: 130%;
  height: 90%;
  background-color: var(--c__lightBlue);
  content: "";
}
.tp_featureSec .bl_media .bl_media_txtArea .bl_media_txtArea_ttl {
  color: var(--c__blue);
  font-weight: 900;
  font-size: var(--fs__2l);
  line-height: calc(44 / 32);
}
.tp_featureSec .bl_media .bl_media_txtArea .bl_media_txtArea_desc {
  position: relative;
  padding-top: 3.6rem;
}
.tp_featureSec .bl_media .bl_media_txtArea .bl_media_txtArea_desc span {
  display: block;
}
.tp_featureSec .bl_media .bl_media_txtArea .bl_media_txtArea_desc span + span {
  margin-top: 1.6rem;
}
.tp_featureSec .bl_media.bl_media__re {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
.tp_featureSec .bl_media.bl_media__re .bl_media_imaArea {
  -webkit-transform: translateY(5.6rem);
  transform: translateY(5.6rem);
}
.tp_featureSec .bl_media.bl_media__re .bl_media_txtArea {
  padding-right: 2.5%;
  padding-left: 5.3rem;
}
.tp_featureSec .bl_media.bl_media__re .bl_media_txtArea::after {
  z-index: -1;
  bottom: -1rem;
  left: 0;
  width: 130%;
  height: 95%;
}
.tp_featureSec .bl_media.bl_media__re .bl_media_txtArea .bl_media_txtArea_desc {
  padding-right: 0;
}

.tp_serviceSec_boxWrap {
  -webkit-column-gap: 2%;
  -moz-column-gap: 2%;
  display: grid;
  grid-template-rows: auto auto;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 2%;
  row-gap: 6rem;
  margin-top: 6.4rem;
}

.tp_serviceSec_boxWrap > .tp_serviceSec_box:last-child {
  grid-column: 1 / -1;
  justify-self: center;
  width: 50%;
}

.tp_serviceSec_box {
  padding-top: 2.8rem;
  padding-bottom: 2.8rem;
  background-color: var(--c__lightGray);
  position: relative;
  width: 100%;
}

.tp_serviceSec_box_body {
  -webkit-column-gap: 3%;
  -moz-column-gap: 3%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 3%;
  height: 100%;
}

.tp_serviceSec_box_ttl {
  -webkit-box-shadow: var(--c__shadow02);
  display: inline-block;
  padding: 1.2rem 2.3rem;
  background-color: var(--c__blue);
  box-shadow: var(--c__shadow02);
  color: var(--c__white);
  font-weight: 900;
  font-size: 2.2rem;
  margin-left: -2.3rem;
  margin-bottom: 3rem;
}
@media (max-width: 1024px) {
  .tp_serviceSec_box_ttl {
    font-size: 1.8rem;
  }
}

.tp_serviceSec_box_body_txtArea {
  padding-left: 2.3rem;
  width: 60%;
  padding-bottom: 6rem;
}
.tp_serviceSec_box_body_txtArea .tp_serviceSec_box_link {
  display: inline-block;
  width: min(50rem, 60%);
  padding-right: 0.8rem;
  padding-bottom: 0.45rem;
  border-bottom: 1px solid var(--c__blue);
  color: var(--c__blue);
  text-align: right;
  text-decoration: none;
  white-space: nowrap;
  transition: all 0.3s ease;
  position: absolute;
  bottom: 2.3rem;
  right: 40%;
  width: 30%;
}
.tp_serviceSec_box_body_txtArea .tp_serviceSec_box_link:hover {
  color: var(--c__yellow);
  border-bottom: 1px solid var(--c__yellow);
}

.tp_serviceSec_box_body_imgArea {
  width: 30%;
  padding-right: 2.3rem;
}
.tp_serviceSec_box_body_imgArea img {
  -o-object-fit: cover;
  aspect-ratio: 141/294;
  height: 100%;
  object-fit: cover;
}

.tp_opeSupSec_group .bl_circleUnit {
  -webkit-transform: translateX(-5%);
  width: 55%;
  transform: translateX(-5%);
}

.tp_opeSupSec_ttl {
  margin-bottom: 2.8rem;
}
.tp_opeSupSec_ttl .main,
.tp_opeSupSec_ttl .sub {
  display: block;
  color: var(--c__blue);
}
.tp_opeSupSec_ttl .main {
  padding-left: 0;
  font-weight: 900;
  font-size: var(--fs__3l);
  line-height: calc(65 / 48);
}
.tp_opeSupSec_ttl .sub {
  color: var(--c__blue02);
  font-size: var(--fs__xl);
  line-height: calc(22 / 20);
  font-family: var(--ff__sans02);
}

.tp_opeSupSec_descUnit {
  padding-bottom: 3.2rem;
}
.tp_opeSupSec_descUnit p {
  margin-top: 1.8rem;
}

.tp_opeSupSec_group.tp_opeSupSec_group__re {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  flex-direction: column-reverse;
  align-items: flex-end;
  margin-top: -38%;
}
.tp_opeSupSec_group.tp_opeSupSec_group__re .bl_circleUnit {
  -webkit-transform: translateX(5%);
  width: 50%;
  transform: translateX(5%);
}
.tp_opeSupSec_group.tp_opeSupSec_group__re .tp_opeSupSec_ttl {
  margin-top: 3.2rem;
}
.tp_opeSupSec_group.tp_opeSupSec_group__re .tp_opeSupSec_ttl .sub {
  text-align: right;
}
.tp_opeSupSec_group.tp_opeSupSec_group__re .tp_opeSupSec_descUnit {
  /* 順番の入れ替え */
  -webkit-box-ordinal-group: 0;
  -webkit-order: -1;
  -ms-flex-order: -1;
  order: -1;
  padding-bottom: 0;
  text-align: right;
}
.tp_opeSupSec_group.tp_opeSupSec_group__re .tp_opeSupSec_descUnit p {
  margin-top: 0;
}

.tp_recSec_empText {
  margin-top: 3.3rem;
  font-weight: 900;
  font-size: var(--fs__1l);
  text-align: center;
}

.tp_recSec_unitWrap {
  -webkit-column-gap: min(4rem, 4%);
  -moz-column-gap: min(4rem, 4%);
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: min(4rem, 4%);
  justify-items: center;
  margin-top: 6.7rem;
}

.tp_recSec_unit {
  width: 100%;
  text-align: center;
}

.tp_recSec_unit_ttl {
  -webkit-transform: translateY(2.3rem);
  display: inline-block;
  padding: 0.8rem 1.6rem;
  transform: translateY(2.3rem);
  background-color: var(--c__blue);
  color: var(--c__white);
  font-weight: 900;
  font-size: var(--fs__l);
  line-height: calc(27 / 20);
}

.tp_recSec_unit_txtWrap {
  padding: 4.8rem 1rem 3rem;
  background-color: var(--c__white);
}

.tp_recSec_unit_txt {
  letter-spacing: -0.033;
}
.tp_recSec_unit_txt:not(:first-of-type) {
  margin-top: 1.4rem;
}

.tp_advantSec_unitWrap {
  -webkit-column-gap: min(4.2rem, 4%);
  -moz-column-gap: min(4.2rem, 4%);
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: min(4.2rem, 4%);
  row-gap: 4.2rem;
  margin-top: 6.5rem;
}

.tp_advantSec_unit {
  padding: 3.2rem 4rem 7rem;
  border: 1px solid var(--c__blue);
}

.tp_advantSec_unit_ttl {
  color: var(--c__blue);
  font-size: var(--fs__1l);
  text-align: center;
}

.tp_advantSec_unit_imgWrap {
  margin-top: 2.2rem;
}
.tp_advantSec_unit_imgWrap img {
  aspect-ratio: 403/173;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.tp_advantSec_unit_txt {
  margin-top: 2.3rem;
}
.swiper-slide {
  height: auto !important;
}

@media (max-width: 1200px) {
  .tp_opeSupSec_group.tp_opeSupSec_group__re .bl_circleUnit {
    transform: none;
  }
  .tp_opeSupSec_group .bl_circleUnit {
    transform: none;
  }
}
@media (max-width: 768px) {
  .tp_opeSupSec_group.tp_opeSupSec_group__re {
    margin-top: 0;
  }
  .tp_opeSupSec_group .bl_circleUnit {
    width: 100% !important;
    max-width: 600px;
    margin: 0 auto;
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re .bl_circleUnit {
    width: 100% !important;
    max-width: 570px;
    margin: 0 auto;
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re {
    flex-direction: column;
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re .tp_opeSupSec_ttl {
    order: 1s;
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re .tp_opeSupSec_descUnit {
    order: 2;
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re .bl_circleUnit {
    order: 3;
    margin-top: 3rem;
  }
}

.bl_infoList {
  width: min(80rem, 100%);
  margin-top: 4.9rem;
  margin-inline: auto;
}

.bl_infoList_item {
  padding: 2.86rem 0.5em 1.54rem;
  border-bottom: 1px solid rgb(185, 185, 185);
  list-style: none;
}
.bl_infoList_item:first-of-type {
  padding-top: 0;
}

.bl_infoList_link {
  -webkit-transition: opacity 0.5s;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -webkit-column-gap: 3.55rem;
  -moz-column-gap: 3.55rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  column-gap: 3.55rem;
  flex-wrap: wrap;
  text-decoration: none;
  transition: opacity 0.5s;
}
.bl_infoList_link:hover,
.bl_infoList_link:focus {
  opacity: 0.6;
}
.bl_infoList_link .bl_infoList_labelArea {
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  -webkit-box-flex: 0;
  -webkit-flex: 0 1 28.2rem;
  -ms-flex: 0 1 28.2rem;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  flex: 0 1 28.2rem;
  flex-wrap: nowrap;
  align-items: flex-start;
}
.bl_infoList_link .bl_infoList_txtArea {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.bl_infoList_link .date {
  -webkit-box-flex: 0;
  -webkit-flex: 0, 1, 12.2rem;
  -ms-flex: 0, 1, 12.2rem;
  flex: 0, 1, 12.2rem;
  color: rgb(57, 57, 57);
  white-space: nowrap;
}
.bl_infoList_link .cat {
  display: inline-block;
  min-width: 12.5rem;
  min-height: 2.4rem;
  margin-left: 3.6rem;
  padding: 0.16rem 1.4rem;
  background-color: var(--c__blue);
  color: var(--c__white);
  font-size: var(--fs__s);
  text-align: center;
}
.bl_infoList_link .ttl {
  display: inline-block;
  color: rgb(0, 0, 0);
  font-weight: bold;
}

/* --------------------------------
 * サービスページ
 * -------------------------------- */
.bl_serviceExample_Unit {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  -webkit-box-align: stretch;
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  align-items: stretch;
  justify-content: center;
  margin-top: 8rem;
}

.bl_serviceExample {
  padding: 0 2rem 2rem;
  background-color: var(--c__lightBlue);
}

.bl_serviceExample_ttl {
  -webkit-transform: translateY(-2.4rem);
  display: block;
  width: 32.4rem;
  margin: 0 auto;
  padding: 1rem;
  transform: translateY(-2.4rem);
  border-radius: 3rem;
  background-color: #8d8d8d;
  color: var(--c__white);
  font-size: var(--fs__xl);
  text-align: center;
}

.bl_serviceExample_ttl.bl_serviceExample_ttl__bgBlue {
  background-color: #578de8;
}

.bl_serviceExample_imgWrap {
  margin-top: 2rem;
}
.bl_serviceExample_imgWrap img {
  -o-object-fit: contain;
  aspect-ratio: 323/305;
  object-fit: contain;
}

.bl_2colServiceCardUnit {
  -webkit-column-gap: 5.55%;
  -moz-column-gap: 5.55%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 5.55%;
  row-gap: 8.8rem;
  margin-top: 9.2rem;
}

a.bl_serviceCard {
  color: var(--c__text);
  text-decoration: none;
}
a.bl_serviceCard .bl_serviceCard_imgWrap {
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
  overflow: hidden;
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
  position: relative;
}
a.bl_serviceCard .bl_serviceCard_imgWrap:after {
  content: "";
  width: 100%;
  height: 100%;
  background-color: rgba(1, 56, 148, 0.2);
  position: absolute;
  top: 0;
  left: 0;
  transition: all 0.3s ease;
}
a.bl_serviceCard:hover .bl_serviceCard_imgWrap:after {
  opacity: 0;
}
a.bl_serviceCard .bl_serviceCard_imgWrap > img {
  -webkit-transition: 0.5s all;
  width: 100%;
  height: auto;
  transition: 0.5s all;
}
a.bl_serviceCard:hover .bl_serviceCard_imgWrap > img,
a.bl_serviceCard:focus .bl_serviceCard_imgWrap > img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

.bl_serviceCard_body {
  z-index: 1;
  position: relative;
  margin-top: -9%;
}
.bl_serviceCard_body .bl_serviceCard_ttl {
  -webkit-box-shadow: var(--c__shadow02);
  display: inline-block;
  padding: 1.4rem 4.8rem 1.4rem 2.3rem;
  background-color: var(--c__blue);
  box-shadow: var(--c__shadow02);
  color: var(--c__white);
  font-weight: 900;
  font-size: var(--fs__1l);
}
.bl_serviceCard_body .bl_serviceCard_txt {
  margin-top: 2rem;
}

.hp_br__pc {
  display: block;
}

.hp_br__sp {
  display: none;
}

.hp_wh__nowrap {
  white-space: nowrap !important;
}

.hp_mt__3rem {
  margin-top: 3rem;
}

@media only screen and (max-width: 1440px) {
  html {
    font-size: 62.5%;
  }
  .bl_gNav {
    display: none;
  }
  .bl_headereBtn_wrap {
    display: block;
  }
}

@media only screen and (max-width: 1024px) {
  html {
    font-size: 62.5%;
  }
  .bl_header_rightArea_telUnit {
    display: none;
  }
  .bl_footer_ctaArea {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
  .ly_2colSiteInner {
    flex-direction: column-reverse;
  }
  .ly_2colSiteInner > aside {
    width: 100%;
    margin-top: 10rem;
  }
  .ly_2colSiteInner > main {
    width: 100%;
  }
  .bl_footer_topArea {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    row-gap: 6.7rem;
    flex-direction: column;
  }
  .bl_aside_list {
    position: relative;
  }
}

@media only screen and (max-width: 768px) {
  html {
    font-size: 50%;
  }
  .bl_mainVisual_item {
    grid-template-rows: auto;
    grid-template-columns: auto;
    grid-template-areas: "txtArea" "imgArea" "ctaArea";
  }
  .bl_mainVisual_txtArea {
    text-align: left;
  }
  .bl_mainVisual_txtArea span {
    text-align: left;
  }
  .ly_header_inner {
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    position: relative;
    align-items: center;
  }
  .tp_opeSupSec_group .bl_circleUnit {
    -webkit-transform: translateX(0);
    width: 50%;
    transform: translateX(0);
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re .bl_circleUnit {
    -webkit-transform: translateX(0);
    width: 48%;
    transform: translateX(0);
  }
  .hp_br__pc {
    display: none;
  }
  .hp_br__sp {
    display: block;
  }
  .tp_featureSec .bl_media {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
    -ms-flex-direction: column-reverse;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    row-gap: 3.2rem;
    flex-direction: column-reverse;
    align-items: center;
  }
  .tp_featureSec .bl_media .bl_media_imaArea {
    -webkit-box-flex: 0;
    -webkit-flex: 0 1 auto;
    -ms-flex: 0 1 auto;
    flex: 0 1 auto;
    width: 70%;
  }
  .tp_featureSec .bl_media .bl_media_txtArea {
    -webkit-transform: translateY(0);
    -webkit-box-flex: 1;
    -webkit-flex: auto;
    -ms-flex: auto;
    flex: auto;
    padding-right: 4%;
    padding-left: 4%;
    transform: translateY(0);
    width: calc(100% - 8rem);
  }
  .tp_featureSec .bl_media .bl_media_txtArea::after {
    width: 100%;
    height: 100%;
  }
  .tp_featureSec .bl_media.bl_media__re {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
    -ms-flex-direction: column-reverse;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    row-gap: 3.2rem;
    flex-direction: column-reverse;
    align-items: center;
  }
  .tp_featureSec .bl_media.bl_media__re .bl_media_imaArea {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
  .tp_featureSec .bl_media.bl_media__re .bl_media_txtArea {
    padding-right: 4%;
    padding-left: 4%;
  }
  .tp_featureSec .bl_media.bl_media__re .bl_media_txtArea::after {
    bottom: -6rem;
    width: 100%;
    height: 100%;
  }
  .bl_infoList_link {
    display: block;
  }
  .bl_infoList_link .bl_infoList_txtArea {
    margin-top: 0.8rem;
  }
  .tp_recSec_unitWrap {
    grid-template-columns: 1fr;
  }
  .tp_advantSec_unitWrap {
    grid-template-columns: 1fr;
  }
  .tp_serviceSec_box_body {
    justify-content: space-between;
  }
  .tp_serviceSec_box_body_txtArea {
    width: 70%;
  }
}
@media (max-width: 700px) {
  .tp_serviceSec_boxWrap {
    display: block;
  }
  .tp_serviceSec_boxWrap > .tp_serviceSec_box:last-child {
    grid-column: auto;
    justify-self: stretch;
    width: auto;
  }
  .tp_serviceSec_box {
    margin-bottom: 3rem;
  }
  .tp_serviceSec_box_body_txtArea {
    width: 65%;
  }
  .tp_serviceSec_box_body_imgArea {
    width: 20%;
  }
  .tp_serviceSec_box_body_txtArea .tp_serviceSec_box_link {
    right: 30%;
  }
  .bl_footer_menu {
    padding: 0;
  }
}

@media only screen and (max-width: 520px) {
  html {
    font-size: 50%;
  }
  .el_secTopTtl {
    text-align: left;
  }
  .bl_drawer_nav {
    width: 100%;
  }
  .bl_ctaSec_contactUnit .bl_ctaSec_contactUnit_btnArea,
  .bl_ctaSec_contactUnit .bl_ctaSec_contactUnit_telArea {
    width: 100%;
    text-align: center;
  }
  .bl_circleImgMedia_imgWrap {
    -webkit-box-flex: 0;
    -webkit-flex: 0 1 35.8%;
    -ms-flex: 0 1 35.8%;
    flex: 0 1 35.8%;
  }
  .bl_customerBalloon {
    width: 80%;
  }
  .pg_featureSec_imgUnit {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .pg_featureSec_imgUnit .pg_featureSec_imgWrap {
    -webkit-box-flex: 0;
    -webkit-flex: 0 1 48.2%;
    -ms-flex: 0 1 48.2%;
    flex: 0 1 48.2%;
  }
  .pg_opeSupSec_table {
    width: 92%;
  }
  .pg_opeSupSec_table th {
    display: block;
    width: 100%;
  }
  .pg_opeSupSec_table td {
    display: block;
    width: 100%;
    padding-left: 10%;
  }
  .pg_opeSupSec_media {
    width: 92%;
  }
  .pg_caseSec_media_imgWrap {
    border-radius: 1.5rem 1.5rem 0 0;
  }
  .bl_header_rightArea_btnUnit .el_ctaBtn.el_ctaBtn__contact,
  .bl_header_rightArea_btnUnit .el_ctaBtn.el_ctaBtn__download {
    display: none;
  }
  .tp_sec_desc {
    text-align: left;
  }
  .tp_featureSec_empText {
    text-align: left;
  }
  .tp_serviceSec_box {
    width: 100%;
  }
  .tp_opeSupSec_group .bl_circleUnit {
    width: 100%;
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    flex-direction: column;
    align-items: flex-start;
    margin-top: 5rem;
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re .bl_circleUnit {
    width: 92%;
    margin: 6rem auto 0;
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re .tp_opeSupSec_ttl {
    margin-top: 0;
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re .tp_opeSupSec_ttl .main {
    padding-left: 0;
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re .tp_opeSupSec_ttl .sub {
    text-align: left;
  }
  .tp_opeSupSec_group.tp_opeSupSec_group__re .tp_opeSupSec_descUnit {
    /* 順番をもとに戻す */
    -webkit-box-ordinal-group: 1;
    -webkit-order: 0;
    -ms-flex-order: 0;
    order: 0;
    text-align: left;
  }
  .tp_recSec_empText {
    text-align: left;
  }

  .bl_infoList {
    width: 100%;
  }

  .bl_serviceExample_Unit {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    row-gap: 8rem;
    flex-direction: column;
  }
  .bl_2colServiceCardUnit {
    grid-template-columns: 1fr;
    justify-items: center;
  }
  a.bl_serviceCard {
    width: 100%;
  }
  .bl_footer_ctaArea_infoUnit .el_telInfo_ttl {
    font-size: 2.3rem;
  }
  .bl_footer_ctaArea .el_telInfo_txt {
    font-size: 1.4rem;
  }
  .el_pageTtl .main {
    font-size: 3.6rem;
  }
  .pg_functionSec_mediaWrap {
    padding: 0;
    grid-template-columns: 1fr;
    display: inline-grid;
  }
  .pg_functionSec_media .pg_functionSec_media_txtArea {
    flex-shrink: 0;
    text-align: left;
  }
  .pg_functionSec {
    text-align: center;
  }
  .bl_ctaSec_ttl {
    font-size: 3rem;
  }
  .pg_flowSec_imgWrap {
    width: 100%;
  }
  .el_secTopTtl .main {
    font-size: 3.3rem;
  }
}
@media (max-width: 400px) {
  .pg_opeSupSec_table td {
    padding: 2.3rem 2.4rem;
  }
}

.swiper-slide {
  height: auto;
}
.mv-wrapper {
  width: 100%;
  position: relative;
  height: 100%;
}
.mv-bg {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.mv-content {
  position: absolute;
  top: 50%;
  right: 10%;
  background: rgba(30, 80, 164, 0.7);
  padding: 3rem;
  color: #fff;
  transform: translateY(-50%);
  width: 30%;
  min-width: 40rem;
  box-sizing: border-box;
}
.mv-header {
  font-size: min(1.5625vw, 3rem);
  font-weight: 700;
}
.mv-index {
  font-size: min(3.125vw, 6rem);
  font-weight: 900;
  line-height: 1.3;
  border-bottom: 1px solid #fff;
  padding-bottom: min(1.3020833333333335vw, 2.5rem);
  margin-bottom: min(1.3020833333333335vw, 2.5rem);
}
.mv-bottom {
  font-size: 1.6rem;
  margin-bottom: 2.5rem;
}
.mv-button-area {
  text-align: right;
  margin-bottom: 0;
}
.mv-outer {
  width: 100%;
  height: 100%;
}
.mv-wrapper-left .mv-content {
  right: auto;
  left: 10%;
}
@media (max-width: 768px) {
  .mv-wrapper {
    display: flex;
    flex-direction: column;
  }
  .mv-content {
    position: static;
    width: 100%;
    top: auto;
    left: auto;
    right: auto;
    transform: none;
    padding-top: 4.8rem;
    padding-bottom: 2.9rem;
  }
  .mv-outer {
    width: 100%;
    height: 100%;
  }
  .mv-header {
    font-size: min(3.90625vw, 3rem);
    font-weight: 700;
  }
  .mv-index {
    font-size: min(7.8125vw, 6rem);
    font-weight: 900;
    line-height: 1.5;
    border-bottom: 1px solid #fff;
    padding-bottom: min(3.2552083333333335vw, 2.5rem);
    margin-bottom: min(3.2552083333333335vw, 2.5rem);
    letter-spacing: -0.2rem;
  }
  .mv-bottom {
    font-size: min(3vw, 2rem);
    font-weight: 700;
    margin-bottom: 0;
  }
  .mv-button-area {
    position: absolute;
    bottom: 3rem;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
  }
}
.overray {
  position: fixed;
  z-index: -1;
  background-color: rgba(0, 0, 0, 0.5);
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.home,
.page-template-page-service,
.page-template-page-aiavatar,
.page-template-page-onlinecs,
.page-template-page-virtualcreative,
.page-template-page-robotics,
.page-template-page-operationsupport,
.page-template-page-ai-interview,
.page-template-page-edu-rpg,
.page-template-page-aiavatar,
.page-template-page-edu-rpg-edit {
  background-color: #fff;
}
.blog-cta {
  max-width: 40rem;
  margin: 2rem auto 0;
}

.case-wrapper {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 40px 0;
}
.bl_swiper_pagination_wrap {
  display: none;
}
.case-item {
  width: 33%;
}
.bl_caseCarousel_card {
  background-color: #fff;
  border-radius: 1.5rem;
}
.bl_swiper_cont {
  padding-bottom: 2rem;
}
@media (max-width: 1024px) {
  .case-item {
    width: 50%;
  }
}
@media (max-width: 768px) {
  .case-item {
    width: 100%;
  }
  .bl_serviceExample_Unit {
    flex-wrap: wrap;
    gap: 60px;
  }
}
/*# sourceMappingURL=style.css.map */
#ez-toc-container {
  font-weight: bold;
}
.ez-toc-list-level-3 li {
  padding-left: 1.5em !important;
}
h2, h3, h4 {
  scroll-margin-top: 140px;
}