@charset "UTF-8";
/*
::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

	reset

::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
*/
*,
*::after,
*::before {
  -webkit-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-print-color-adjust: exact;
  margin: 0;
  padding: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

fieldset,
img {
  border: 0;
}

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

li {
  list-style: none;
}

sup {
  vertical-align: text-top;
}

sub {
  vertical-align: text-bottom;
}

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

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

.clearfix::after {
  content: " ";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

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

img {
  -webkit-backface-visibility: hidden;
  vertical-align: bottom;
  user-select: none;
  pointer-events: none;
}

@media screen and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: 0.001dpcm) {
  img {
    image-rendering: -webkit-optimize-contrast;
  }
}
a[href],
label[for],
button,
input[type=button],
input[type=submit],
input[type=reset],
input[type=image],
input[type=radio],
input[type=checkbox],
select {
  cursor: pointer;
}

a[href^="tel:"] {
  cursor: default;
}

@media print {
  * {
    -webkit-print-color-adjust: exact;
  }
}
@media (prefers-reduced-motion: reduce) {
  /* .anime_on クラスが付いていない全ての要素のアニメーションを無効化 */
  *:not(.anime_on):not([class*=splide]) {
    animation-duration: 0.01ms !important;
    animation-delay: unset !important;
    animation-iteration-count: 1 !important;
    transition-delay: unset !important;
    transition-duration: 0.01ms !important;
    view-transition-name: none !important;
  }
  /* .anime_on クラスが付いている要素の擬似要素のアニメーションは有効化 */
  .anime_on:not([class*=splide]) *,
.anime_on:not([class*=splide])::before,
.anime_on:not([class*=splide])::after,
.anime_on:not([class*=splide])::backdrop {
    animation-duration: inherit !important;
    transition-duration: inherit !important;
  }
  /* .anime_on クラスが付いていない要素の擬似要素のアニメーションを無効化 */
  *:not(.anime_on):not([class*=splide])::before,
*:not(.anime_on):not([class*=splide])::after,
*:not(.anime_on):not([class*=splide])::backdrop {
    animation-duration: 0.01ms !important;
    animation-delay: unset !important;
    animation-iteration-count: 1 !important;
    transition-delay: unset !important;
    transition-duration: 0.01ms !important;
    view-transition-name: none !important;
  }
  [data-aos] {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) !important;
  }
}
/*
::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

	PLUGIN

::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
*/
/*== Splide.js ====================================================================================================*/
@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__container {
  box-sizing: border-box;
  position: relative;
}

.splide__list {
  backface-visibility: hidden;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  -ms-flex-align: center;
  align-items: center;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide:not(.is-overflow) .splide__pagination {
  display: none;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized, .splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  backface-visibility: hidden;
  box-sizing: border-box;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

.splide__sr {
  clip: rect(0 0 0 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.splide__toggle.is-active .splide__toggle__play, .splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

/*== scroll-hint.js ====================================================================================================*/
@keyframes scroll-hint-appear {
  0% {
    transform: translateX(40px);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  50%, 100% {
    transform: translateX(-40px);
    opacity: 0;
  }
}
/*
.scroll-hint.is-right-scrollable {
  background: linear-gradient(270deg, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
}
.scroll-hint.is-right-scrollable.is-left-scrollable {
  background: linear-gradient(90deg, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0)), linear-gradient(270deg, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
}
.scroll-hint.is-left-scrollable {
  background: linear-gradient(90deg, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
}
*/
.scroll-hint-icon {
  position: absolute;
  top: calc(50% - 25px);
  left: calc(50% - 60px);
  box-sizing: border-box;
  width: 120px;
  height: 80px;
  border-radius: 5px;
  transition: opacity 0.3s;
  opacity: 0;
  background: rgba(0, 0, 0, 0.7);
  text-align: center;
  padding: 20px 10px 10px 10px;
}

.scroll-hint-icon-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-height: 100%;
  pointer-events: none;
}

.scroll-hint-text {
  font-size: 10px;
  color: #FFF;
  margin-top: 5px;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon {
  opacity: 0.8;
}

.scroll-hint-icon:before {
  display: inline-block;
  width: 40px;
  height: 40px;
  color: #FFF;
  vertical-align: middle;
  text-align: center;
  content: "";
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNS43NyIgaGVpZ2h0PSIzMC41MiIgdmlld0JveD0iMCAwIDI1Ljc3IDMwLjUyIj48dGl0bGU+44Ki44K744OD44OIIDM8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxwYXRoIGQ9Ik0yMS4zMywzMC41Mkg3Ljg1QTEuNTUsMS41NSwwLDAsMSw2LjMsMjlhMTIuNDYsMTIuNDYsMCwwLDAtLjYzLTQuNDIsMjUuMTYsMjUuMTYsMCwwLDAtNC4yNS01bC0uMDYtLjA2QTUsNSwwLDAsMSwwLDE1Ljg2YTMuNjQsMy42NCwwLDAsMSwxLjE3LTIuNjIsMy42MywzLjYzLDAsMCwxLDUuMTQuMDdWMy43N2EzLjc3LDMuNzcsMCwxLDEsNy41NCwwVjguMzNhMy4zNSwzLjM1LDAsMCwxLDEuMjYsMCwzLDMsMCwwLDEsMiwxLjIyLDMuNSwzLjUsMCwwLDEsMi0uMDYsMy4yMSwzLjIxLDAsMCwxLDIsMS41NCwzLjc0LDMuNzQsMCwwLDEsMywuNDdBNC4yMSw0LjIxLDAsMCwxLDI1Ljc0LDE1YzAsLjExLDAsLjI3LDAsLjQ2YTE5LjI2LDE5LjI2LDAsMCwxLS44NCw3Yy0uMTQuMzgtLjM2LjgxLS41NiwxLjIybC0uMTEuMjJjMCwuMDctLjA5LjE0LS4xNC4yMWE3LjEzLDcuMTMsMCwwLDAtMS4xNywyLjE3Yy0uMDYuNTYtLjA2LDIuMTUtLjA1LDIuNzFBMS41NSwxLjU1LDAsMCwxLDIxLjMzLDMwLjUyWk04LjYxLDI4LjIxaDEyYzAtLjcxLDAtMS43MS4wNy0yLjIzYTguNzQsOC43NCwwLDAsMSwxLjU5LTMuMjVsLjA2LS4xMmExMCwxMCwwLDAsMCwuNDYtMSwxNi44LDE2LjgsMCwwLDAsLjctNi4xMmMwLS4yMywwLS40MSwwLS41NGgwYTIsMiwwLDAsMC0uNjQtMS41MiwxLjMzLDEuMzMsMCwwLDAtMS41NS4wOCwxLjEzLDEuMTMsMCwwLDEtMS4xOC4yOCwxLjE1LDEuMTUsMCwwLDEtLjc4LS45NCwxLjI2LDEuMjYsMCwwLDAtLjc1LTEuMTEsMSwxLDAsMCwwLTEuMTEuMjhsLS4xLjFhMS4xNSwxLjE1LDAsMCwxLTEuMTkuMjksMS4xNiwxLjE2LDAsMCwxLS43OC0uOTVjLS4wOS0uNjgtLjIxLS43Ny0uNy0uODdhLjgyLjgyLDAsMCwwLTEsLjQ4LDEuMTYsMS4xNiwwLDAsMS0yLjE2LS41OFYzLjc3YTEuNDYsMS40NiwwLDEsMC0yLjkyLDB2Ny44NWwwLDQuMzNhMS4xNywxLjE3LDAsMCwxLS44MywxLjExLDEuMTUsMS4xNSwwLDAsMS0xLjItLjM1bC0xLS45MWMtLjQ3LS40Mi0uNzMtLjY2LS44NC0uNzdhMS4zNSwxLjM1LDAsMCwwLTItLjEyTDIuNywxNWExLjMyLDEuMzIsMCwwLDAtLjM5LDFBMi41NywyLjU3LDAsMCwwLDMsMTcuODVsMCwwYTI3LjI0LDI3LjI0LDAsMCwxLDQuNyw1LjYyQTEyLjYzLDEyLjYzLDAsMCwxLDguNjEsMjguMjFaTTIzLjIsMjMuMzVaTTYuNTEsMTYuNTlaIiBmaWxsPSIjZmZmIi8+PC9nPjwvZz48L3N2Zz4=);
}

.scroll-hint-icon:after {
  content: "";
  width: 34px;
  height: 14px;
  display: block;
  position: absolute;
  top: 10px;
  left: 50%;
  margin-left: -20px;
  background-repeat: no-repeat;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMy4yOSIgaGVpZ2h0PSIxMi4wMiIgdmlld0JveD0iMCAwIDMzLjI5IDEyLjAyIj48dGl0bGU+44Ki44K744OD44OIIDE8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxsaW5lIHgxPSIxLjg1IiB5MT0iNi4wMSIgeDI9IjEwLjQiIHkyPSI2LjAxIiBmaWxsPSIjZmZmIi8+PHBhdGggZD0iTTEwLjQsNy4xN0gxLjg1YTEuMTYsMS4xNiwwLDEsMSwwLTIuMzFIMTAuNGExLjE2LDEuMTYsMCwxLDEsMCwyLjMxWiIgZmlsbD0iI2ZmZiIvPjxwYXRoIGQ9Ik03LjQsMTJhMS4xNSwxLjE1LDAsMCwxLS43Mi0uMjVsLTYuMjUtNUExLjIsMS4yLDAsMCwxLDAsNS44NywxLjE0LDEuMTQsMCwwLDEsLjQ2LDVMNi43LjIzQTEuMTYsMS4xNiwwLDAsMSw4LjEsMi4wOEwzLDUuOTEsOC4xMiwxMEExLjE2LDEuMTYsMCwwLDEsNy40LDEyWiIgZmlsbD0iI2ZmZiIvPjxsaW5lIHgxPSIzMS40NSIgeTE9IjYuMDEiIHgyPSIyMi44OSIgeTI9IjYuMDEiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNMzEuNDUsNy4xN0gyMi44OWExLjE2LDEuMTYsMCwxLDEsMC0yLjMxaDguNTZhMS4xNiwxLjE2LDAsMCwxLDAsMi4zMVoiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNMjUuOSwxMmExLjE4LDEuMTgsMCwwLDEtLjkxLS40M0ExLjE3LDEuMTcsMCwwLDEsMjUuMTcsMTBsNS4wOS00LjA1TDI1LjIsMi4wOEExLjE2LDEuMTYsMCwwLDEsMjYuNTkuMjNMMzIuODQsNWExLjE2LDEuMTYsMCwwLDEsLjQ1LjkxLDEuMTQsMS4xNCwwLDAsMS0uNDMuOTJsLTYuMjQsNUExLjE3LDEuMTcsMCwwLDEsMjUuOSwxMloiIGZpbGw9IiNmZmYiLz48L2c+PC9nPjwvc3ZnPg==);
  opacity: 0;
  transition-delay: 2.4s;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon:after {
  opacity: 1;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon:before {
  animation: scroll-hint-appear 1.2s linear;
  animation-iteration-count: 2;
}

.scroll-hint-icon-white {
  background-color: #FFF;
  box-shadow: 0 4px 5px rgba(0, 0, 0, 0.4);
}

.scroll-hint-icon-white:before {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNS43NyIgaGVpZ2h0PSIzMC41MiIgdmlld0JveD0iMCAwIDI1Ljc3IDMwLjUyIj48dGl0bGU+44Ki44K744OD44OIIDQ8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxwYXRoIGQ9Ik0yMS4zMywzMC41Mkg3Ljg1QTEuNTUsMS41NSwwLDAsMSw2LjMsMjlhMTIuNDYsMTIuNDYsMCwwLDAtLjYzLTQuNDIsMjUuMTYsMjUuMTYsMCwwLDAtNC4yNS01bC0uMDYtLjA2QTUsNSwwLDAsMSwwLDE1Ljg2YTMuNjQsMy42NCwwLDAsMSwxLjE3LTIuNjIsMy42MywzLjYzLDAsMCwxLDUuMTQuMDdWMy43N2EzLjc3LDMuNzcsMCwxLDEsNy41NCwwVjguMzNhMy4zNSwzLjM1LDAsMCwxLDEuMjYsMCwzLDMsMCwwLDEsMiwxLjIyLDMuNSwzLjUsMCwwLDEsMi0uMDYsMy4yMSwzLjIxLDAsMCwxLDIsMS41NCwzLjc0LDMuNzQsMCwwLDEsMywuNDdBNC4yMSw0LjIxLDAsMCwxLDI1Ljc0LDE1YzAsLjExLDAsLjI3LDAsLjQ2YTE5LjI2LDE5LjI2LDAsMCwxLS44NCw3Yy0uMTQuMzgtLjM2LjgxLS41NiwxLjIybC0uMTEuMjJjMCwuMDctLjA5LjE0LS4xNC4yMWE3LjEzLDcuMTMsMCwwLDAtMS4xNywyLjE3Yy0uMDYuNTYtLjA2LDIuMTUtLjA1LDIuNzFBMS41NSwxLjU1LDAsMCwxLDIxLjMzLDMwLjUyWk04LjYxLDI4LjIxaDEyYzAtLjcxLDAtMS43MS4wNy0yLjIzYTguNzQsOC43NCwwLDAsMSwxLjU5LTMuMjVsLjA2LS4xMmExMCwxMCwwLDAsMCwuNDYtMSwxNi44LDE2LjgsMCwwLDAsLjctNi4xMmMwLS4yMywwLS40MSwwLS41NGgwYTIsMiwwLDAsMC0uNjQtMS41MiwxLjMzLDEuMzMsMCwwLDAtMS41NS4wOCwxLjEzLDEuMTMsMCwwLDEtMS4xOC4yOCwxLjE1LDEuMTUsMCwwLDEtLjc4LS45NCwxLjI2LDEuMjYsMCwwLDAtLjc1LTEuMTEsMSwxLDAsMCwwLTEuMTEuMjhsLS4xLjFhMS4xNSwxLjE1LDAsMCwxLTEuMTkuMjksMS4xNiwxLjE2LDAsMCwxLS43OC0uOTVjLS4wOS0uNjgtLjIxLS43Ny0uNy0uODdhLjgyLjgyLDAsMCwwLTEsLjQ4LDEuMTYsMS4xNiwwLDAsMS0yLjE2LS41OFYzLjc3YTEuNDYsMS40NiwwLDEsMC0yLjkyLDB2Ny44NWwwLDQuMzNhMS4xNywxLjE3LDAsMCwxLS44MywxLjExLDEuMTUsMS4xNSwwLDAsMS0xLjItLjM1bC0xLS45MWMtLjQ3LS40Mi0uNzMtLjY2LS44NC0uNzdhMS4zNSwxLjM1LDAsMCwwLTItLjEyTDIuNywxNWExLjMyLDEuMzIsMCwwLDAtLjM5LDFBMi41NywyLjU3LDAsMCwwLDMsMTcuODVsMCwwYTI3LjI0LDI3LjI0LDAsMCwxLDQuNyw1LjYyQTEyLjYzLDEyLjYzLDAsMCwxLDguNjEsMjguMjFaTTIzLjIsMjMuMzVaTTYuNTEsMTYuNTlaIi8+PC9nPjwvZz48L3N2Zz4=);
}

.scroll-hint-icon-white:after {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMy4yOSIgaGVpZ2h0PSIxMi4wMiIgdmlld0JveD0iMCAwIDMzLjI5IDEyLjAyIj48dGl0bGU+44Ki44K744OD44OIIDI8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxsaW5lIHgxPSIxLjg1IiB5MT0iNi4wMSIgeDI9IjEwLjQiIHkyPSI2LjAxIi8+PHBhdGggZD0iTTEwLjQsNy4xN0gxLjg1YTEuMTYsMS4xNiwwLDEsMSwwLTIuMzFIMTAuNGExLjE2LDEuMTYsMCwxLDEsMCwyLjMxWiIvPjxwYXRoIGQ9Ik03LjQsMTJhMS4xNSwxLjE1LDAsMCwxLS43Mi0uMjVsLTYuMjUtNUExLjIsMS4yLDAsMCwxLDAsNS44NywxLjE0LDEuMTQsMCwwLDEsLjQ2LDVMNi43LjIzQTEuMTYsMS4xNiwwLDAsMSw4LjEsMi4wOEwzLDUuOTEsOC4xMiwxMEExLjE2LDEuMTYsMCwwLDEsNy40LDEyWiIvPjxsaW5lIHgxPSIzMS40NSIgeTE9IjYuMDEiIHgyPSIyMi44OSIgeTI9IjYuMDEiLz48cGF0aCBkPSJNMzEuNDUsNy4xN0gyMi44OWExLjE2LDEuMTYsMCwxLDEsMC0yLjMxaDguNTZhMS4xNiwxLjE2LDAsMCwxLDAsMi4zMVoiLz48cGF0aCBkPSJNMjUuOSwxMmExLjE4LDEuMTgsMCwwLDEtLjkxLS40M0ExLjE3LDEuMTcsMCwwLDEsMjUuMTcsMTBsNS4wOS00LjA1TDI1LjIsMi4wOEExLjE2LDEuMTYsMCwwLDEsMjYuNTkuMjNMMzIuODQsNWExLjE2LDEuMTYsMCwwLDEsLjQ1LjkxLDEuMTQsMS4xNCwwLDAsMS0uNDMuOTJsLTYuMjQsNUExLjE3LDEuMTcsMCwwLDEsMjUuOSwxMloiLz48L2c+PC9nPjwvc3ZnPg==);
}

.scroll-hint-icon-white .scroll-hint-text {
  color: #000;
}

/*== mailformpro ====================================================================================================*/
div#mfp_hidden {
  overflow: hidden;
  width: 1px;
  height: 1px;
  padding: 0px;
  margin: 0px;
}

div#mfp_hidden input {
  margin: 10px;
}

div.mfp_thanks {
  padding: 30px;
}

div.mfp_thanks p {
  line-height: 1.7em;
}

div.mfp_thanks ul.mfp_caution {
  margin: 0px;
  padding: 0px;
}

div.mfp_thanks ul.mfp_caution li {
  display: block;
  color: #C00;
  margin: 0px;
  padding: 5px 0px;
}

div#mfp_thanks {
  text-align: center;
  font-size: 18px;
  padding: 20px 0px;
}

div#mfp_thanks strong {
  color: #C00;
  font-size: 24px;
}

/*
form#mailformpro {
	padding: 10px 0px;
}
form#mailformpro dl dt {
	float: left;
	width: 160px;
	clear: both;
	font-size: 12px;
	padding: 10px 0px;
	text-align: right;
	border-top: solid 1px #CCC;
	margin: 0px;
}
form#mailformpro dl dd {
	border-top: solid 1px #CCC;
	margin: 0px;
	padding: 10px 5px 20px 170px;
	font-size: 12px;
	line-height: 1.5em;
	text-align: left;
}
form#mailformpro dl dd ul,form#mailformpro dl dd ol {
	margin: 0px;
	padding: 0px;
}
form#mailformpro dl dd ul li,form#mailformpro dl dd ol li {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
*/
.must {
  display: block;
  background-color: #C00;
  border: solid 2px #C00;
  text-shadow: 0px 1px 2px #933;
  padding: 2px 5px;
  font-size: 10px;
  color: #FFF;
  float: left;
  margin: 0px 5px;
  border-radius: 4px;
  box-shadow: 0px 0px 5px #CCC;
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
}

.optionally {
  display: block;
  background-color: #06C;
  border: solid 2px #06C;
  text-shadow: 0px 1px 2px #933;
  padding: 2px 5px;
  font-size: 10px;
  color: #FFF;
  float: left;
  margin: 0px 5px;
  border-radius: 4px;
  box-shadow: 0px 0px 5px #CCC;
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
}

/*
form#mailformpro label {
	border-radius: 3px;
	margin: 3px;
	display: inline-block;
	white-space: nowrap;
}
*/
form#mailformpro label.mfp_checked {
  /*
  padding: 3px;
  border: solid 1px #CCC;
  background-color: #E8EEF9;
  box-shadow: 0px 1px 3px #CCC inset;
  */
}

form#mailformpro label.mfp_not_checked {
  /*
  padding: 3px;
  border: solid 1px #EEE;
  */
}

/*
table#mfp_confirm_table {
	border-spacing: 0px;
	border-collapse: collapse;
	width: 100%;
}
table#mfp_confirm_table tr.mfp_colored {
	background-color: #F6F7F9;
}
table#mfp_confirm_table tr.mfp_achroma {
	background-color: #FFF;
}
table#mfp_confirm_table tr th,table#mfp_confirm_table tr td {
	text-align: left;
	font-size: 12px;
	border-top: solid 1px #CCC;
	padding: 5px 10px;
}
table#mfp_confirm_table tr th {
	white-space: nowrap;
	width: 200px;
}
table#mfp_confirm_table tr td {
	line-height: 1.5em;
	word-break: break-all;
}
*/
div#mfp_phase_confirm {
  clear: both;
}

/*
div#mfp_phase_confirm h4 {
	font-size: 36px;
	padding: 10px 0px 0px 0px;
	text-align: center;
}
*/
div#mfp_overlay {
  position: absolute;
  display: none;
  z-index: 10001;
}

div#mfp_overlay_inner {
  background-color: #FFF;
  padding: 15px;
  margin: 0px auto;
  border-radius: 5px;
  box-shadow: 0px 0px 10px #000;
  width: 640px;
  max-width: 90%;
}

div#mfp_overlay_background {
  background-color: #000;
  position: absolute;
  display: none;
  z-index: 10000;
}

div#mfp_loading_screen {
  z-index: 20000;
  opacity: 0.8;
  display: none;
  background-color: #000;
  position: absolute;
}

/*
div#mfp_loading {
	z-index: 20001;
	position: absolute;
	display: none;
	width: 40px;
	height: 40px;
	background-image: url(_images/mfp_loading.gif);
}
*/
.mfp_colored {
  background-color: #F6F7F9;
}

.mfp_achroma {
  background-color: #FFF;
}

/*
div.mfp_err {
	clear: both;
	display: none;
	text-align: left;
	margin: 5px 0px 0px 0px;
	padding: 3px 0px 5px 17px;
	color: #F00;
	font-size: 12px;
	line-height: normal;
	background-position: 0px 1px;
}
	*/
/*
.mfp_parent_error {
	border: solid 2px #F00;
}
	*/
.problem {
  background-color: #FCC;
}

div#mfp_error {
  background-color: #FEE;
  border: solid 1px #F00;
  padding: 10px;
  display: none;
}

div#mfp_error p {
  padding: 0px;
  margin: 0px;
  font-size: 14px;
  text-align: center;
}

div#mfp_error p strong {
  font-size: 18px;
  color: #F00;
}

div#mfp_warning {
  background-color: #FEE;
  border: solid 1px #F00;
  padding: 10px;
  display: none;
  border-radius: 5px;
}

div#mfp_warning p {
  padding: 0px;
  margin: 0px;
  font-size: 14px;
  text-align: center;
}

div#mfp_warning p strong {
  font-size: 18px;
  color: #F00;
}

div#mfp_price {
  color: #C00;
  font-size: 36px;
  padding: 10px;
  font-weight: bolder;
}

div#mfp_price span {
  color: #666;
  font-size: 12px;
  font-weight: normal;
}

button.mfp_next, button.mfp_prev {
  font-size: 18px;
  margin: 10px;
  padding: 5px 10px;
}

button.mfp_next {
  float: right;
}

button.mfp_prev {
  float: left;
}

ul#mfp_phase_stat {
  padding: 10px;
  text-align: center;
}

ul#mfp_phase_stat li {
  display: inline-block;
  padding: 8px 15px;
  border-radius: 5px;
  margin: 0px 5px;
  list-style: none;
  font-size: 14px;
}

ul#mfp_phase_stat li.mfp_phase_arrow {
  box-shadow: none;
  color: #999;
  padding: 8px 0px;
}

ul#mfp_phase_stat li.mfp_active_phase {
  box-shadow: 0px 1px 6px #000;
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
  background-color: #0068B7;
  border: solid 2px #0068B7;
  font-weight: bolder;
  color: #FFF;
  text-shadow: 0px 1px 3px #000;
}

ul#mfp_phase_stat li.mfp_inactive_phase {
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
  background-color: #EEE;
  border: solid 2px #EEE;
  color: #999;
  box-shadow: 0px 1px 6px #CCC;
}

div#mfp_shopping_cart {
  border: solid 1px #CCC;
  margin: 0px;
  padding: 0px;
}

div#mfp_shopping_cart p {
  margin: 0px;
  text-align: center;
  padding: 20px 10px;
  font-size: 12px;
  background-color: #FEE;
}

table.mfp_shoppingcart {
  border-spacing: 0px;
  border-collapse: collapse;
  width: 100%;
}

table.mfp_shoppingcart thead tr td {
  background-color: #EEE;
  border-bottom: solid 1px #CCC;
  text-align: center;
  font-size: 12px;
  padding: 5px;
}

table.mfp_shoppingcart tbody tr th, table.mfp_shoppingcart tbody tr td {
  font-size: 12px;
  padding: 5px;
  border-bottom: solid 1px #CCC;
}

table.mfp_shoppingcart tbody tr td select {
  display: block;
  margin: 0px auto;
  text-align: center;
}

table.mfp_shoppingcart tbody tr td select option {
  text-align: center;
}

table.mfp_shoppingcart tbody tr th span {
  display: block;
  font-weight: normal;
  font-size: 10px;
  color: #666;
  padding: 3px 0px;
}

table.mfp_shoppingcart tfoot tr td {
  padding: 5px;
  font-size: 16px;
  font-weight: bolder;
  color: #900;
}

td.msc_price {
  font-size: 12px;
  text-align: right;
}

div.mfp_buttons {
  clear: both;
  padding: 10px 0px;
  text-align: center;
}

.imagebutton {
  margin: 0px;
  padding: 0px;
  border: none;
  outline: none;
  background: none;
}

.mfp_element_all {
  /*
  max-width: 90%;
  */
}

.mfp_element_text,
.mfp_element_number,
.mfp_element_select-one,
.mfp_element_email,
.mfp_element_tel,
.mfp_element_textarea,
.mfp_element_date,
.mfp_element_password {
  /*
  border: solid 1px #CCC;
  border-radius: 3px;
  box-shadow: 0px 0px 5px #CCC inset;
  padding: 3px 8px;
  margin: 2px;
  vertical-align: middle;
  */
}

.mfp_element_checkbox,
.mfp_element_radio {
  /*
  vertical-align: middle;
  margin: 0px 2px;
  */
}

.mfp_element_file {
  /*
  font-size: 12px;
  display: inline-block;
  padding: 10px 10px;
  vertical-align: middle;
  border: solid 1px #CCC;
  border-radius: 3px;
  box-shadow: 0px 0px 5px #CCC inset;
  background: #EEE;
  */
}

.mfp_element_submit, .mfp_element_reset, .mfp_element_button, button.mfp_next, button.mfp_prev {
  /*
  border-radius: 5px;
  padding: 5px 10px;
  border: solid 1px #CCC;
  background: gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
  background: -webkit-gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
  background: -moz-linear-gradient(top, #EEE, #CCC);
  background: -ms-linear-gradient(top, #EEE 0%, #CCC 100%);
  text-shadow: 0px 2px 0px #FFF;
  font-size: 18px;
  cursor: pointer;
  outline: none;
  */
}

.mfp_element_reset {
  /*
  color: #333;
  */
}

.mfp_element_submit:hover, .mfp_element_reset:hover, .mfp_element_button:hover, button.mfp_next:hover, button.mfp_prev:hover {
  /*
  background: gradient(linear, center top, center bottom, from(#FFF), to(#CCC));
  background: -webkit-gradient(linear, center top, center bottom, from(#FFF), to(#CCC));
  background: -moz-linear-gradient(top, #FFF, #CCC);
  background: -ms-linear-gradient(top, #FFF 0%, #CCC 100%);
  box-shadow: 0px 2px 15px #CCC;
  */
}

button.mfp_next, button.mfp_prev {
  font-size: 14px;
}

input#mfp_reserve_item, input#mfp_reserve_date {
  display: none;
}

div#mfp_reserve_wrapper {
  position: relative;
  overflow: hidden;
  border: solid 1px #CCC;
}

div#mfp_reserve_inner {
  position: relative;
  padding: 0px 0px 0px 100px;
  overflow: auto;
}

div#mfp_reserve_wrapper table {
  border-spacing: 0px;
  border-collapse: collapse;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_label {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100px;
  background-color: #FEE;
  z-index: 100;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_value {
  padding: 0px 0px 0px 0px;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_active,
div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_warning {
  cursor: pointer;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_active:hover,
div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_warning:hover {
  background-color: #E8EEF9;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_current {
  background-color: #0068B7;
  color: #FFF;
}

td.mfp_reserve_disabled {
  background-color: #CCC;
}

td.mfp_reserve_warning {
  background-color: #FFC;
}

div#mfp_reserve_wrapper table tr td, div#mfp_reserve_wrapper table tr th {
  border: solid 1px #CCC;
  padding: 0px 5px;
  font-size: 12px;
  text-align: center;
  font-family: Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
  font-weight: normal;
  height: 20px;
  text-align: left;
}

td.mfp_reserve_week_0 {
  color: #F00;
  background-color: #FEE;
}

td.mfp_reserve_week_6 {
  color: #00F;
  background-color: #EEF;
}

div.mfp_ok {
  border-radius: 5px;
  background-color: #090;
  border: solid 1px #090;
  display: inline-block;
  line-height: 1.5em;
  padding: 0px 5px;
  margin: 0px 2px;
  color: #FFF;
  font-size: 10px;
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
  display: none;
}

div.prefcodeWrapper {
  position: relative;
}

div.prefcodeResult {
  position: absolute;
  top: 0px;
  left: 0px;
  padding: 5px;
  border: solid 1px #CCC;
  background-color: #FFF;
  box-shadow: 0px 0px 5px #CCC;
  display: none;
}

div.prefcodeResult div {
  cursor: pointer;
}

div.prefcodeResult div:hover {
  background-color: #C9EBFB;
}

div.prefcodeResult div.prefcodeNext {
  background-color: #EEE;
  text-align: center;
}

div.prefLoading {
  padding: 60px 100px;
  background: url(_images/mfp_zip_loading.gif) no-repeat center center;
}

div.mfpSuggestWrapper {
  position: relative;
}

div.mfpSuggestResult {
  position: absolute;
  top: 0px;
  left: 0px;
  padding: 5px;
  border: solid 1px #CCC;
  background-color: #FFF;
  box-shadow: 0px 0px 5px #CCC;
  display: none;
}

div.mfpSuggestResult div {
  cursor: pointer;
}

div.mfpSuggestResult div:hover {
  background-color: #C9EBFB;
}

div.mfpSuggestResult div.mfpSuggestNext {
  background-color: #EEE;
  text-align: center;
}

div.prefLoading {
  padding: 60px 100px;
  background: url(_images/mfp_zip_loading.gif) no-repeat center center;
}

.hidefield {
  height: 0px;
  overflow: hidden;
}

.showfield {
  height: auto;
  overflow: visible;
}

div.mfp_attached_thumbnails {
  display: none;
  padding: 5px;
  margin: 5px auto;
  border: solid 1px #CCC;
  border-radius: 3px;
  box-shadow: 0px 0px 5px #CCC inset;
  background: #EEE;
}

div.mfp_attached_thumbnails ul {
  margin: 0px;
  padding: 0px;
}

form#mailformpro dl dd div.mfp_attached_thumbnails ul li {
  display: inline-block;
  vertical-align: top;
  padding: 0px;
  border: solid 4px #FFF;
  margin: 5px;
  box-shadow: 0px 2px 5px #999;
}

form#mailformpro dl dd div.mfp_attached_thumbnails ul li a {
  display: block;
  max-height: 100px;
  overflow: hidden;
}

div.mfp_attached_thumbnails ul li a img {
  display: block;
  max-width: 80px;
}

button.mfp_attached_reset {
  font-size: 14px;
}

div.mfp_draganddrop {
  margin: 5px auto;
  width: 100%;
  height: 200px;
  border: solid 2px #CCC;
  border-radius: 3px;
  background: url(_images/draganddrop.png) no-repeat center center #EEE;
  background-size: auto 80%;
}

div.mfp_dragover {
  border: solid 2px #0068B7;
  background-color: #FFF;
}

div.mfp_attached_filelist {
  margin: 5px auto;
  padding: 5px;
  width: 100%;
  border: solid 1px #CCC;
  border-radius: 3px;
}

form#mailformpro dl dd div.mfp_attached_filelist ul,
div.mfp_attached_filelist ul {
  padding: 5px;
}

form#mailformpro dl dd div.mfp_attached_filelist ul li,
div.mfp_attached_filelist ul li {
  padding: 5px 5px 5px 2em;
  background: url(_images/file.png) no-repeat 5px center;
  background-size: 1.3em 1.3em;
  display: inline-block;
  margin-right: 1em;
}

form#mailformpro dl dd div.mfp_attached_filelist ul li:last-child,
div.mfp_attached_filelist ul li:last-child {
  border: none;
}

div.mfp_guide {
  position: relative;
  width: 1px;
  height: 1px;
}

div.mfp_guide div {
  position: absolute;
  bottom: 0px;
  left: 0px;
  margin-top: -2em;
  white-space: nowrap;
  border-radius: 5px;
  padding: 5px 10px;
  line-height: 1em;
  font-size: 12px;
  color: #FFF;
  font-weight: bolder;
  background: #F00;
  display: none;
}

div#mfp_numticket_wrapper,
div#mfp_numticket_wrapper * {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
}

div#mfp_numticket_wrapper {
  clear: both;
  padding: 15px;
}

div#mfp_numticket_wrapper section#numticket_message_wrapper {
  border: solid 3px #F00;
  border-radius: 5px;
  background: #FEE;
  padding: 15px;
  font-size: 16px;
  line-height: 1.7em;
  margin: 5px auto;
}

div#mfp_numticket_wrapper section#numticket_waitTime {
  border: solid 3px #CCC;
  border-radius: 5px;
  background: #FFF;
  padding: 15px;
  font-size: 16px;
  margin: 10px auto;
}

div#mfp_numticket_wrapper section#numticket_waitTime strong {
  font-size: 32px;
  display: block;
  text-align: center;
}

div#mfp_numticket_wrapper section#numticket_waitTime p.numticket_center {
  text-align: center;
}

div.mfp_traffic_status {
  max-width: 460px;
  margin: 10px auto;
  border: solid 1px #CCC;
  border-radius: 3px;
  padding: 15px;
}

div.mfp_traffic_status h3 {
  padding: 0;
  margin: 0;
  font-size: 16px;
  font-weight: normal;
  color: #999;
}

div.mfp_traffic_status table {
  text-align: center;
  width: 100%;
}

div#wrapper div.mfp_traffic_status table tr th,
div#wrapper div.mfp_traffic_status table tr td,
div.mfp_traffic_status table td,
div.mfp_traffic_status table th {
  border: none;
  padding: 0;
}

div#wrapper div.mfp_traffic_status table tr td,
div.mfp_traffic_status table td {
  padding: 0 2px;
}

div#wrapper div.mfp_traffic_status table tr th,
div.mfp_traffic_status table th {
  border-top: solid 1px #CCC;
  font-size: 10px;
  font-weight: normal;
  padding-top: 5px;
  color: #999;
}

div.mfp_traffic_status table td {
  height: 100px;
}

div.mfp_traffic_status table td span {
  display: block;
  background: #7BAAF7;
  border-radius: 3px 3px 0 0;
  border-top: solid 1px #66A1F7;
  border-right: solid 1px #66A1F7;
  border-left: solid 1px #66A1F7;
  min-width: 10px;
  max-width: 30px;
  margin: 0 auto;
  padding-bottom: 10px;
}

div.mfp_traffic_status table td span.mfp_traffic_status_current {
  background: #5D7AF2;
  border-top: solid 1px #546CD1;
  border-right: solid 1px #546CD1;
  border-left: solid 1px #546CD1;
}

.mfp_ok {
  background-color: rgba(0, 255, 0, 0.2);
}

.mfp_ng {
  background-color: rgba(255, 0, 0, 0.2);
}

div#mfp_OperationCheck div#mfp_OperationCheck_inner {
  display: none;
}

div#mfp_OperationCheck strong {
  background: #090;
  display: block;
  color: #222;
  text-align: center;
  border-radius: 3px;
}

div#mfp_OperationCheck * {
  padding: 0px;
  margin: 0px;
  font-size: 12px;
}

div#mfp_OperationCheck p {
  padding: 0px 5px;
  margin: 0px;
  font-size: 12px;
}

div#mfp_OperationCheck p a {
  color: #0C0;
  text-decoration: none;
}

div#mfp_OperationCheck p a:hover,
div#mfp_OperationCheck p button:hover {
  text-decoration: underline;
}

div#mfp_OperationCheck p button {
  border: none;
  background: none;
  color: #0C0;
  cursor: pointer;
}

div#mfp_OperationCheck ul li,
div#mfp_OperationCheck ul li label,
div#mfp_OperationCheck ul li label input {
  line-height: 12px;
  font-size: 12px;
  list-style: none;
  vertical-align: middle;
}

div#mfp_OperationCheck ul li {
  padding: 5px 10px;
}

div#mfp_OperationCheck ul li label {
  text-decoration: underline;
}

button#mfp_recorder_record,
button#mfp_recorder_clear,
button#mfp_recorder_restore {
  border-radius: 5px;
  padding: 5px 10px 5px 2em;
  border: solid 1px #CCC;
  background: gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
  background: -webkit-gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
  background: -moz-linear-gradient(top, #EEE, #CCC);
  background: -ms-linear-gradient(top, #EEE 0%, #CCC 100%);
  text-shadow: 0px 2px 0px #FFF;
  font-size: 16px;
  cursor: pointer;
  outline: none;
  display: inline-block;
  margin: 5px auto;
}

button#mfp_recorder_record {
  background: url(_images/mfp_record_disabled.png) no-repeat 5px center #EEE;
  background-size: 24px 24px;
}

button#mfp_recorder_clear {
  background: url(_images/mfp_record_remove.png) no-repeat 5px center #EEE;
  background-size: 24px 24px;
}

button#mfp_recorder_restore {
  background: url(_images/mfp_record_restore.png) no-repeat 5px center #EEE;
  background-size: 24px 24px;
}

button.enabled#mfp_recorder_record,
button.enabled#mfp_recorder_clear,
button.enabled#mfp_recorder_restore {
  background: url(_images/mfp_record_enabled.png) no-repeat 5px center #EEE;
  background-size: 24px 24px;
}

div#mfp_recorder_wrap {
  border: solid 1px #CCC;
  padding: 10px;
  text-align: center;
  margin: 5px auto;
}

td.request_image {
  width: 100px;
}

td.request_image img {
  max-width: 100px;
}

button.mfp_submit_enable {
  background: none;
  background: #000090;
}

button.mfp_submit_disable {
  background: none;
  background: #FD8282;
}

span.mfp_tips {
  background-image: url(_images/mfp_header.png);
  background-size: 100% 100%;
  background-color: #FCC;
  display: block;
  border-radius: 5px;
  padding: 10px;
  margin: 2px;
  box-shadow: 0px 2px 10px #999;
}

span.mfp_tips strong {
  color: #800040;
}

span.mfp_tips span {
  display: block;
  padding: 10px;
  color: #008080;
}

span.mfp_tips em {
  font-style: normal;
  color: #090;
  font-weight: bold;
}

div.mfp_estimate_wrapper {
  border: solid 1px #CCC;
  padding: 10px;
  margin: 5px;
  border-radius: 5px;
}

div.mfp_estimate_wrapper div.mfp_estimate_wrap {
  position: relative;
  padding: 10px;
  border: solid 1px #CCC;
  border-radius: 5px;
  margin: 10px 0;
  transition-property: all;
  transition-duration: 0.5s;
  transition-timing-function: ease-in-out;
}

div.mfp_estimate_wrapper div.mfp_estimate_wrap div.mfp_estimate_label {
  position: absolute;
  top: -0.7em;
  left: 1em;
  display: inline-block;
  background: #FFF;
  font-size: 12px;
  padding: 0 0.5em;
  color: #666;
}

div.mfp_estimate_wrapper div.mfp_estimate_wrap select {
  font-size: 18px;
  margin: 5px 0;
  padding: 5px 10px;
  line-height: 1em;
  min-height: 2.5em;
}

div.mfp_estimate_wrapper div.mfp_estimate_wrap img {
  width: 100%;
  max-width: 240px;
  display: block;
  margin: 0 auto;
}

div.mfp_estimate_wrapper div.mfp_estimate_wrap strong {
  display: block;
  text-align: right;
  color: #900;
  font-size: 24px;
}

div.mfp_estimate_wrapper div.mfp_estimate_wrap strong em {
  display: inline-block;
  font-size: 30px;
}

div.mfp_estimate_wrapper button.mfp_estimate_button {
  margin: 10px 0 0 0;
  padding: 5px 10px;
  border-radius: 5px;
  border: solid 1px #CCC;
  background: gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
  background: gradient(linear, center top, center bottom, from(#EEE), to(#CCC));
  background: -moz-linear-gradient(top, #EEE, #CCC);
  background: -ms-linear-gradient(top, #EEE 0%, #CCC 100%);
  text-shadow: 0px 2px 0px #FFF;
}

div.mfp_estimate_list table.mfp_estimate_list_table {
  width: 100%;
  margin: 10px 0;
}

div.mfp_estimate_list table.mfp_estimate_list_table thead tr th {
  text-align: center;
}

div#wrapper div.mfp_estimate_list table.mfp_estimate_list_table tr th,
div#wrapper div.mfp_estimate_list table.mfp_estimate_list_table tr td,
div.mfp_estimate_list table.mfp_estimate_list_table tr th,
div.mfp_estimate_list table.mfp_estimate_list_table tr td {
  border: none;
  border-bottom: solid 1px #333;
}

div#wrapper div.mfp_estimate_list table.mfp_estimate_list_table tfoot tr th,
div#wrapper div.mfp_estimate_list table.mfp_estimate_list_table tfoot tr td,
div.mfp_estimate_list table.mfp_estimate_list_table tfoot tr th,
div.mfp_estimate_list table.mfp_estimate_list_table tfoot tr td {
  border: none;
  text-align: right;
}

div#wrapper div.mfp_estimate_list table.mfp_estimate_list_table tbody tr th,
div#wrapper div.mfp_estimate_list table.mfp_estimate_list_table tbody tr td,
div.mfp_estimate_list table.mfp_estimate_list_table tbody tr th,
div.mfp_estimate_list table.mfp_estimate_list_table tbody tr td {
  padding: 0;
  margin: 0;
}

div#wrapper div.mfp_estimate_list table.mfp_estimate_list_table tbody tr th,
div.mfp_estimate_list table.mfp_estimate_list_table tbody tr th {
  padding: 0 10px;
}

div#wrapper div.mfp_estimate_list table.mfp_estimate_list_table tbody tr th span,
div.mfp_estimate_list table.mfp_estimate_list_table tbody tr th span {
  font-size: 10px;
  display: block;
  color: #666;
}

div#wrapper div.mfp_estimate_list table.mfp_estimate_list_table tbody tr td:nth-of-type(1),
div.mfp_estimate_list table.mfp_estimate_list_table tbody tr td:nth-of-type(1) {
  width: 80px;
}

div#wrapper div.mfp_estimate_list table.mfp_estimate_list_table tbody tr td:nth-of-type(2),
div.mfp_estimate_list table.mfp_estimate_list_table tbody tr td:nth-of-type(2) {
  text-align: right;
  padding: 0 10px;
  width: 120px;
}

div#wrapper div.mfp_estimate_list table.mfp_estimate_list_table tbody tr td:nth-of-type(3),
div.mfp_estimate_list table.mfp_estimate_list_table tbody tr td:nth-of-type(3) {
  width: 60px;
}

div.mfp_estimate_list table.mfp_estimate_list_table tbody td img {
  max-width: 80px;
}

div.mfp_estimate_list table.mfp_estimate_list_table tbody td button {
  border: none;
  background: none;
  font-size: 24px;
  cursor: pointer;
}

div.mfp_ticket_wrapper {
  border: solid 1px #CCC;
  margin: 5px;
  overflow: auto;
}

div.mfp_ticket_map {
  position: relative;
  background-position: left top;
  background-repeat: no-repeat;
}

div.mfp_ticket_map div {
  position: absolute;
  width: 20px;
  height: 20px;
  padding: 0;
  margin: 0;
}

div.mfp_ticket_map div label {
  position: relative;
}

div.mfp_ticket_map div label span {
  position: absolute;
  top: 0px;
  left: 20px;
  display: inline-block;
  font-size: 10px;
  white-space: nowrap;
  display: none;
  background-color: #FFF;
  border: solid 1px #CCC;
  padding: 3px 3px;
  line-height: 1em;
}

div.mfp_ticket_map div label:hover span {
  display: block;
  z-index: 10;
}

div.mfp_ticket_map div label input {
  margin: 0;
  padding: 0;
  border-radius: 0;
  background-color: #CCC;
}

@media screen and (max-width: 800px) {
  /*
  form#mailformpro dl dt {
  	float: none;
  	width: auto;
  	font-size: 12px;
  	padding: 5px;
  	text-align: left;
  }
  form#mailformpro dl dd {
  	clear: both;
  	border-top: none;
  	padding: 5px 15px;
  	font-size: 12px;
  	line-height: 1.5em;
  }
  div.mfp_buttons button {
  	font-size: 14px;
  }
  div#mfp_phase_confirm h4 {
  	font-size: 18px;
  }
  */
  ul#mfp_phase_stat {
    padding: 0px;
    text-align: left;
  }
  ul#mfp_phase_stat li {
    text-align: center;
    padding: 5px 0px;
    border-radius: 3px;
    margin: 5px;
    list-style: none;
    font-size: 14px;
    width: 28%;
  }
  ul#mfp_phase_stat li.mfp_phase_arrow {
    bos-shadow: none;
    display: none;
  }
  /*
  table#mfp_confirm_table tr th {
  	white-space: nowrap;
  	width: 100px;
  }
  */
  div#mfp_thanks {
    text-align: center;
    font-size: 18px;
    padding: 20px 0px;
  }
  div#mfp_thanks strong {
    color: #C00;
    font-size: 24px;
    display: block;
  }
}
/*== Animate On Scroll Library ====================================================================================================*/
:root {
  --num: 20px;
}

[data-aos][data-aos][data-aos-duration="50"],
body[data-aos-duration="50"] [data-aos] {
  transition-duration: 50ms;
}

[data-aos][data-aos][data-aos-delay="50"],
body[data-aos-delay="50"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="50"].aos-animate,
body[data-aos-delay="50"] [data-aos].aos-animate {
  transition-delay: 50ms;
}

[data-aos][data-aos][data-aos-duration="100"],
body[data-aos-duration="100"] [data-aos] {
  transition-duration: 0.1s;
}

[data-aos][data-aos][data-aos-delay="100"],
body[data-aos-delay="100"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="100"].aos-animate,
body[data-aos-delay="100"] [data-aos].aos-animate {
  transition-delay: 0.1s;
}

[data-aos][data-aos][data-aos-duration="150"],
body[data-aos-duration="150"] [data-aos] {
  transition-duration: 0.15s;
}

[data-aos][data-aos][data-aos-delay="150"],
body[data-aos-delay="150"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="150"].aos-animate,
body[data-aos-delay="150"] [data-aos].aos-animate {
  transition-delay: 0.15s;
}

[data-aos][data-aos][data-aos-duration="200"],
body[data-aos-duration="200"] [data-aos] {
  transition-duration: 0.2s;
}

[data-aos][data-aos][data-aos-delay="200"],
body[data-aos-delay="200"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="200"].aos-animate,
body[data-aos-delay="200"] [data-aos].aos-animate {
  transition-delay: 0.2s;
}

[data-aos][data-aos][data-aos-duration="250"],
body[data-aos-duration="250"] [data-aos] {
  transition-duration: 0.25s;
}

[data-aos][data-aos][data-aos-delay="250"],
body[data-aos-delay="250"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="250"].aos-animate,
body[data-aos-delay="250"] [data-aos].aos-animate {
  transition-delay: 0.25s;
}

[data-aos][data-aos][data-aos-duration="300"],
body[data-aos-duration="300"] [data-aos] {
  transition-duration: 0.3s;
}

[data-aos][data-aos][data-aos-delay="300"],
body[data-aos-delay="300"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="300"].aos-animate,
body[data-aos-delay="300"] [data-aos].aos-animate {
  transition-delay: 0.3s;
}

[data-aos][data-aos][data-aos-duration="350"],
body[data-aos-duration="350"] [data-aos] {
  transition-duration: 0.35s;
}

[data-aos][data-aos][data-aos-delay="350"],
body[data-aos-delay="350"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="350"].aos-animate,
body[data-aos-delay="350"] [data-aos].aos-animate {
  transition-delay: 0.35s;
}

[data-aos][data-aos][data-aos-duration="400"],
body[data-aos-duration="400"] [data-aos] {
  transition-duration: 0.4s;
}

[data-aos][data-aos][data-aos-delay="400"],
body[data-aos-delay="400"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="400"].aos-animate,
body[data-aos-delay="400"] [data-aos].aos-animate {
  transition-delay: 0.4s;
}

[data-aos][data-aos][data-aos-duration="450"],
body[data-aos-duration="450"] [data-aos] {
  transition-duration: 0.45s;
}

[data-aos][data-aos][data-aos-delay="450"],
body[data-aos-delay="450"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="450"].aos-animate,
body[data-aos-delay="450"] [data-aos].aos-animate {
  transition-delay: 0.45s;
}

[data-aos][data-aos][data-aos-duration="500"],
body[data-aos-duration="500"] [data-aos] {
  transition-duration: 0.5s;
}

[data-aos][data-aos][data-aos-delay="500"],
body[data-aos-delay="500"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="500"].aos-animate,
body[data-aos-delay="500"] [data-aos].aos-animate {
  transition-delay: 0.5s;
}

[data-aos][data-aos][data-aos-duration="550"],
body[data-aos-duration="550"] [data-aos] {
  transition-duration: 0.55s;
}

[data-aos][data-aos][data-aos-delay="550"],
body[data-aos-delay="550"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="550"].aos-animate,
body[data-aos-delay="550"] [data-aos].aos-animate {
  transition-delay: 0.55s;
}

[data-aos][data-aos][data-aos-duration="600"],
body[data-aos-duration="600"] [data-aos] {
  transition-duration: 0.6s;
}

[data-aos][data-aos][data-aos-delay="600"],
body[data-aos-delay="600"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="600"].aos-animate,
body[data-aos-delay="600"] [data-aos].aos-animate {
  transition-delay: 0.6s;
}

[data-aos][data-aos][data-aos-duration="650"],
body[data-aos-duration="650"] [data-aos] {
  transition-duration: 0.65s;
}

[data-aos][data-aos][data-aos-delay="650"],
body[data-aos-delay="650"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="650"].aos-animate,
body[data-aos-delay="650"] [data-aos].aos-animate {
  transition-delay: 0.65s;
}

[data-aos][data-aos][data-aos-duration="700"],
body[data-aos-duration="700"] [data-aos] {
  transition-duration: 0.7s;
}

[data-aos][data-aos][data-aos-delay="700"],
body[data-aos-delay="700"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="700"].aos-animate,
body[data-aos-delay="700"] [data-aos].aos-animate {
  transition-delay: 0.7s;
}

[data-aos][data-aos][data-aos-duration="750"],
body[data-aos-duration="750"] [data-aos] {
  transition-duration: 0.75s;
}

[data-aos][data-aos][data-aos-delay="750"],
body[data-aos-delay="750"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="750"].aos-animate,
body[data-aos-delay="750"] [data-aos].aos-animate {
  transition-delay: 0.75s;
}

[data-aos][data-aos][data-aos-duration="800"],
body[data-aos-duration="800"] [data-aos] {
  transition-duration: 0.8s;
}

[data-aos][data-aos][data-aos-delay="800"],
body[data-aos-delay="800"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="800"].aos-animate,
body[data-aos-delay="800"] [data-aos].aos-animate {
  transition-delay: 0.8s;
}

[data-aos][data-aos][data-aos-duration="850"],
body[data-aos-duration="850"] [data-aos] {
  transition-duration: 0.85s;
}

[data-aos][data-aos][data-aos-delay="850"],
body[data-aos-delay="850"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="850"].aos-animate,
body[data-aos-delay="850"] [data-aos].aos-animate {
  transition-delay: 0.85s;
}

[data-aos][data-aos][data-aos-duration="900"],
body[data-aos-duration="900"] [data-aos] {
  transition-duration: 0.9s;
}

[data-aos][data-aos][data-aos-delay="900"],
body[data-aos-delay="900"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="900"].aos-animate,
body[data-aos-delay="900"] [data-aos].aos-animate {
  transition-delay: 0.9s;
}

[data-aos][data-aos][data-aos-duration="950"],
body[data-aos-duration="950"] [data-aos] {
  transition-duration: 0.95s;
}

[data-aos][data-aos][data-aos-delay="950"],
body[data-aos-delay="950"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="950"].aos-animate,
body[data-aos-delay="950"] [data-aos].aos-animate {
  transition-delay: 0.95s;
}

[data-aos][data-aos][data-aos-duration="1000"],
body[data-aos-duration="1000"] [data-aos] {
  transition-duration: 1s;
}

[data-aos][data-aos][data-aos-delay="1000"],
body[data-aos-delay="1000"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1000"].aos-animate,
body[data-aos-delay="1000"] [data-aos].aos-animate {
  transition-delay: 1s;
}

[data-aos][data-aos][data-aos-duration="1050"],
body[data-aos-duration="1050"] [data-aos] {
  transition-duration: 1.05s;
}

[data-aos][data-aos][data-aos-delay="1050"],
body[data-aos-delay="1050"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1050"].aos-animate,
body[data-aos-delay="1050"] [data-aos].aos-animate {
  transition-delay: 1.05s;
}

[data-aos][data-aos][data-aos-duration="1100"],
body[data-aos-duration="1100"] [data-aos] {
  transition-duration: 1.1s;
}

[data-aos][data-aos][data-aos-delay="1100"],
body[data-aos-delay="1100"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1100"].aos-animate,
body[data-aos-delay="1100"] [data-aos].aos-animate {
  transition-delay: 1.1s;
}

[data-aos][data-aos][data-aos-duration="1150"],
body[data-aos-duration="1150"] [data-aos] {
  transition-duration: 1.15s;
}

[data-aos][data-aos][data-aos-delay="1150"],
body[data-aos-delay="1150"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1150"].aos-animate,
body[data-aos-delay="1150"] [data-aos].aos-animate {
  transition-delay: 1.15s;
}

[data-aos][data-aos][data-aos-duration="1200"],
body[data-aos-duration="1200"] [data-aos] {
  transition-duration: 1.05s;
}

[data-aos][data-aos][data-aos-delay="1200"],
body[data-aos-delay="1200"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1200"].aos-animate,
body[data-aos-delay="1200"] [data-aos].aos-animate {
  transition-delay: 1.05s;
}

[data-aos][data-aos][data-aos-duration="1250"],
body[data-aos-duration="1250"] [data-aos] {
  transition-duration: 1.055s;
}

[data-aos][data-aos][data-aos-delay="1250"],
body[data-aos-delay="1250"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1250"].aos-animate,
body[data-aos-delay="1250"] [data-aos].aos-animate {
  transition-delay: 1.055s;
}

[data-aos][data-aos][data-aos-duration="1300"],
body[data-aos-duration="1300"] [data-aos] {
  transition-duration: 1.3s;
}

[data-aos][data-aos][data-aos-delay="1300"],
body[data-aos-delay="1300"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1300"].aos-animate,
body[data-aos-delay="1300"] [data-aos].aos-animate {
  transition-delay: 1.3s;
}

[data-aos][data-aos][data-aos-duration="1350"],
body[data-aos-duration="1350"] [data-aos] {
  transition-duration: 1.35s;
}

[data-aos][data-aos][data-aos-delay="1350"],
body[data-aos-delay="1350"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1350"].aos-animate,
body[data-aos-delay="1350"] [data-aos].aos-animate {
  transition-delay: 1.35s;
}

[data-aos][data-aos][data-aos-duration="1400"],
body[data-aos-duration="1400"] [data-aos] {
  transition-duration: 1.4s;
}

[data-aos][data-aos][data-aos-delay="1400"],
body[data-aos-delay="1400"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1400"].aos-animate,
body[data-aos-delay="1400"] [data-aos].aos-animate {
  transition-delay: 1.4s;
}

[data-aos][data-aos][data-aos-duration="1450"],
body[data-aos-duration="1450"] [data-aos] {
  transition-duration: 1.45s;
}

[data-aos][data-aos][data-aos-delay="1450"],
body[data-aos-delay="1450"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1450"].aos-animate,
body[data-aos-delay="1450"] [data-aos].aos-animate {
  transition-delay: 1.45s;
}

[data-aos][data-aos][data-aos-duration="1500"],
body[data-aos-duration="1500"] [data-aos] {
  transition-duration: 1.5s;
}

[data-aos][data-aos][data-aos-delay="1500"],
body[data-aos-delay="1500"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1500"].aos-animate,
body[data-aos-delay="1500"] [data-aos].aos-animate {
  transition-delay: 1.5s;
}

[data-aos][data-aos][data-aos-duration="1550"],
body[data-aos-duration="1550"] [data-aos] {
  transition-duration: 1.55s;
}

[data-aos][data-aos][data-aos-delay="1550"],
body[data-aos-delay="1550"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1550"].aos-animate,
body[data-aos-delay="1550"] [data-aos].aos-animate {
  transition-delay: 1.55s;
}

[data-aos][data-aos][data-aos-duration="1600"],
body[data-aos-duration="1600"] [data-aos] {
  transition-duration: 1.6s;
}

[data-aos][data-aos][data-aos-delay="1600"],
body[data-aos-delay="1600"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1600"].aos-animate,
body[data-aos-delay="1600"] [data-aos].aos-animate {
  transition-delay: 1.6s;
}

[data-aos][data-aos][data-aos-duration="1650"],
body[data-aos-duration="1650"] [data-aos] {
  transition-duration: 1.65s;
}

[data-aos][data-aos][data-aos-delay="1650"],
body[data-aos-delay="1650"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1650"].aos-animate,
body[data-aos-delay="1650"] [data-aos].aos-animate {
  transition-delay: 1.65s;
}

[data-aos][data-aos][data-aos-duration="1700"],
body[data-aos-duration="1700"] [data-aos] {
  transition-duration: 1.7s;
}

[data-aos][data-aos][data-aos-delay="1700"],
body[data-aos-delay="1700"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1700"].aos-animate,
body[data-aos-delay="1700"] [data-aos].aos-animate {
  transition-delay: 1.7s;
}

[data-aos][data-aos][data-aos-duration="1750"],
body[data-aos-duration="1750"] [data-aos] {
  transition-duration: 1.75s;
}

[data-aos][data-aos][data-aos-delay="1750"],
body[data-aos-delay="1750"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1750"].aos-animate,
body[data-aos-delay="1750"] [data-aos].aos-animate {
  transition-delay: 1.75s;
}

[data-aos][data-aos][data-aos-duration="1800"],
body[data-aos-duration="1800"] [data-aos] {
  transition-duration: 1.8s;
}

[data-aos][data-aos][data-aos-delay="1800"],
body[data-aos-delay="1800"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1800"].aos-animate,
body[data-aos-delay="1800"] [data-aos].aos-animate {
  transition-delay: 1.8s;
}

[data-aos][data-aos][data-aos-duration="1850"],
body[data-aos-duration="1850"] [data-aos] {
  transition-duration: 1.85s;
}

[data-aos][data-aos][data-aos-delay="1850"],
body[data-aos-delay="1850"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1850"].aos-animate,
body[data-aos-delay="1850"] [data-aos].aos-animate {
  transition-delay: 1.85s;
}

[data-aos][data-aos][data-aos-duration="1900"],
body[data-aos-duration="1900"] [data-aos] {
  transition-duration: 1.9s;
}

[data-aos][data-aos][data-aos-delay="1900"],
body[data-aos-delay="1900"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1900"].aos-animate,
body[data-aos-delay="1900"] [data-aos].aos-animate {
  transition-delay: 1.9s;
}

[data-aos][data-aos][data-aos-duration="1950"],
body[data-aos-duration="1950"] [data-aos] {
  transition-duration: 1.95s;
}

[data-aos][data-aos][data-aos-delay="1950"],
body[data-aos-delay="1950"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="1950"].aos-animate,
body[data-aos-delay="1950"] [data-aos].aos-animate {
  transition-delay: 1.95s;
}

[data-aos][data-aos][data-aos-duration="2000"],
body[data-aos-duration="2000"] [data-aos] {
  transition-duration: 2s;
}

[data-aos][data-aos][data-aos-delay="2000"],
body[data-aos-delay="2000"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2000"].aos-animate,
body[data-aos-delay="2000"] [data-aos].aos-animate {
  transition-delay: 2s;
}

[data-aos][data-aos][data-aos-duration="2050"],
body[data-aos-duration="2050"] [data-aos] {
  transition-duration: 2.05s;
}

[data-aos][data-aos][data-aos-delay="2050"],
body[data-aos-delay="2050"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2050"].aos-animate,
body[data-aos-delay="2050"] [data-aos].aos-animate {
  transition-delay: 2.05s;
}

[data-aos][data-aos][data-aos-duration="2100"],
body[data-aos-duration="2100"] [data-aos] {
  transition-duration: 2.1s;
}

[data-aos][data-aos][data-aos-delay="2100"],
body[data-aos-delay="2100"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2100"].aos-animate,
body[data-aos-delay="2100"] [data-aos].aos-animate {
  transition-delay: 2.1s;
}

[data-aos][data-aos][data-aos-duration="2150"],
body[data-aos-duration="2150"] [data-aos] {
  transition-duration: 2.15s;
}

[data-aos][data-aos][data-aos-delay="2150"],
body[data-aos-delay="2150"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2150"].aos-animate,
body[data-aos-delay="2150"] [data-aos].aos-animate {
  transition-delay: 2.15s;
}

[data-aos][data-aos][data-aos-duration="2200"],
body[data-aos-duration="2200"] [data-aos] {
  transition-duration: 2.2s;
}

[data-aos][data-aos][data-aos-delay="2200"],
body[data-aos-delay="2200"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2200"].aos-animate,
body[data-aos-delay="2200"] [data-aos].aos-animate {
  transition-delay: 2.2s;
}

[data-aos][data-aos][data-aos-duration="2250"],
body[data-aos-duration="2250"] [data-aos] {
  transition-duration: 2.25s;
}

[data-aos][data-aos][data-aos-delay="2250"],
body[data-aos-delay="2250"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2250"].aos-animate,
body[data-aos-delay="2250"] [data-aos].aos-animate {
  transition-delay: 2.25s;
}

[data-aos][data-aos][data-aos-duration="2300"],
body[data-aos-duration="2300"] [data-aos] {
  transition-duration: 2.3s;
}

[data-aos][data-aos][data-aos-delay="2300"],
body[data-aos-delay="2300"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2300"].aos-animate,
body[data-aos-delay="2300"] [data-aos].aos-animate {
  transition-delay: 2.3s;
}

[data-aos][data-aos][data-aos-duration="2350"],
body[data-aos-duration="2350"] [data-aos] {
  transition-duration: 2.35s;
}

[data-aos][data-aos][data-aos-delay="2350"],
body[data-aos-delay="2350"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2350"].aos-animate,
body[data-aos-delay="2350"] [data-aos].aos-animate {
  transition-delay: 2.35s;
}

[data-aos][data-aos][data-aos-duration="2400"],
body[data-aos-duration="2400"] [data-aos] {
  transition-duration: 2.4s;
}

[data-aos][data-aos][data-aos-delay="2400"],
body[data-aos-delay="2400"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2400"].aos-animate,
body[data-aos-delay="2400"] [data-aos].aos-animate {
  transition-delay: 2.4s;
}

[data-aos][data-aos][data-aos-duration="2450"],
body[data-aos-duration="2450"] [data-aos] {
  transition-duration: 2.45s;
}

[data-aos][data-aos][data-aos-delay="2450"],
body[data-aos-delay="2450"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2450"].aos-animate,
body[data-aos-delay="2450"] [data-aos].aos-animate {
  transition-delay: 2.45s;
}

[data-aos][data-aos][data-aos-duration="2500"],
body[data-aos-duration="2500"] [data-aos] {
  transition-duration: 2.5s;
}

[data-aos][data-aos][data-aos-delay="2500"],
body[data-aos-delay="2500"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2500"].aos-animate,
body[data-aos-delay="2500"] [data-aos].aos-animate {
  transition-delay: 2.5s;
}

[data-aos][data-aos][data-aos-duration="2550"],
body[data-aos-duration="2550"] [data-aos] {
  transition-duration: 2.55s;
}

[data-aos][data-aos][data-aos-delay="2550"],
body[data-aos-delay="2550"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2550"].aos-animate,
body[data-aos-delay="2550"] [data-aos].aos-animate {
  transition-delay: 2.55s;
}

[data-aos][data-aos][data-aos-duration="2600"],
body[data-aos-duration="2600"] [data-aos] {
  transition-duration: 2.6s;
}

[data-aos][data-aos][data-aos-delay="2600"],
body[data-aos-delay="2600"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2600"].aos-animate,
body[data-aos-delay="2600"] [data-aos].aos-animate {
  transition-delay: 2.6s;
}

[data-aos][data-aos][data-aos-duration="2650"],
body[data-aos-duration="2650"] [data-aos] {
  transition-duration: 2.65s;
}

[data-aos][data-aos][data-aos-delay="2650"],
body[data-aos-delay="2650"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2650"].aos-animate,
body[data-aos-delay="2650"] [data-aos].aos-animate {
  transition-delay: 2.65s;
}

[data-aos][data-aos][data-aos-duration="2700"],
body[data-aos-duration="2700"] [data-aos] {
  transition-duration: 2.7s;
}

[data-aos][data-aos][data-aos-delay="2700"],
body[data-aos-delay="2700"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2700"].aos-animate,
body[data-aos-delay="2700"] [data-aos].aos-animate {
  transition-delay: 2.7s;
}

[data-aos][data-aos][data-aos-duration="2750"],
body[data-aos-duration="2750"] [data-aos] {
  transition-duration: 2.75s;
}

[data-aos][data-aos][data-aos-delay="2750"],
body[data-aos-delay="2750"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2750"].aos-animate,
body[data-aos-delay="2750"] [data-aos].aos-animate {
  transition-delay: 2.75s;
}

[data-aos][data-aos][data-aos-duration="2800"],
body[data-aos-duration="2800"] [data-aos] {
  transition-duration: 2.8s;
}

[data-aos][data-aos][data-aos-delay="2800"],
body[data-aos-delay="2800"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2800"].aos-animate,
body[data-aos-delay="2800"] [data-aos].aos-animate {
  transition-delay: 2.8s;
}

[data-aos][data-aos][data-aos-duration="2850"],
body[data-aos-duration="2850"] [data-aos] {
  transition-duration: 2.85s;
}

[data-aos][data-aos][data-aos-delay="2850"],
body[data-aos-delay="2850"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2850"].aos-animate,
body[data-aos-delay="2850"] [data-aos].aos-animate {
  transition-delay: 2.85s;
}

[data-aos][data-aos][data-aos-duration="2900"],
body[data-aos-duration="2900"] [data-aos] {
  transition-duration: 2.9s;
}

[data-aos][data-aos][data-aos-delay="2900"],
body[data-aos-delay="2900"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2900"].aos-animate,
body[data-aos-delay="2900"] [data-aos].aos-animate {
  transition-delay: 2.9s;
}

[data-aos][data-aos][data-aos-duration="2950"],
body[data-aos-duration="2950"] [data-aos] {
  transition-duration: 2.95s;
}

[data-aos][data-aos][data-aos-delay="2950"],
body[data-aos-delay="2950"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="2950"].aos-animate,
body[data-aos-delay="2950"] [data-aos].aos-animate {
  transition-delay: 2.95s;
}

[data-aos][data-aos][data-aos-duration="3000"],
body[data-aos-duration="3000"] [data-aos] {
  transition-duration: 3s;
}

[data-aos][data-aos][data-aos-delay="3000"],
body[data-aos-delay="3000"] [data-aos] {
  transition-delay: 0;
}

[data-aos][data-aos][data-aos-delay="3000"].aos-animate,
body[data-aos-delay="3000"] [data-aos].aos-animate {
  transition-delay: 3s;
}

[data-aos][data-aos][data-aos-easing=linear],
body[data-aos-easing=linear] [data-aos] {
  transition-timing-function: cubic-bezier(0.25, 0.25, 0.75, 0.75);
}

[data-aos][data-aos][data-aos-easing=ease],
body[data-aos-easing=ease] [data-aos] {
  transition-timing-function: ease;
}

[data-aos][data-aos][data-aos-easing=ease-in],
body[data-aos-easing=ease-in] [data-aos] {
  transition-timing-function: ease-in;
}

[data-aos][data-aos][data-aos-easing=ease-out],
body[data-aos-easing=ease-out] [data-aos] {
  transition-timing-function: ease-out;
}

[data-aos][data-aos][data-aos-easing=ease-in-out],
body[data-aos-easing=ease-in-out] [data-aos] {
  transition-timing-function: ease-in-out;
}

[data-aos][data-aos][data-aos-easing=ease-in-back],
body[data-aos-easing=ease-in-back] [data-aos] {
  transition-timing-function: cubic-bezier(0.6, -0.28, 0.735, 0.045);
}

[data-aos][data-aos][data-aos-easing=ease-out-back],
body[data-aos-easing=ease-out-back] [data-aos] {
  transition-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.0575);
}

[data-aos][data-aos][data-aos-easing=ease-in-out-back],
body[data-aos-easing=ease-in-out-back] [data-aos] {
  transition-timing-function: cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

[data-aos][data-aos][data-aos-easing=ease-in-sine],
body[data-aos-easing=ease-in-sine] [data-aos] {
  transition-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
}

[data-aos][data-aos][data-aos-easing=ease-out-sine],
body[data-aos-easing=ease-out-sine] [data-aos] {
  transition-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
}

[data-aos][data-aos][data-aos-easing=ease-in-out-sine],
body[data-aos-easing=ease-in-out-sine] [data-aos] {
  transition-timing-function: cubic-bezier(0.445, 0.05, 0.55, 0.95);
}

[data-aos][data-aos][data-aos-easing=ease-in-quad],
body[data-aos-easing=ease-in-quad] [data-aos] {
  transition-timing-function: cubic-bezier(0.55, 0.085, 0.68, 0.53);
}

[data-aos][data-aos][data-aos-easing=ease-out-quad],
body[data-aos-easing=ease-out-quad] [data-aos] {
  transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

[data-aos][data-aos][data-aos-easing=ease-in-out-quad],
body[data-aos-easing=ease-in-out-quad] [data-aos] {
  transition-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

[data-aos][data-aos][data-aos-easing=ease-in-cubic],
body[data-aos-easing=ease-in-cubic] [data-aos] {
  transition-timing-function: cubic-bezier(0.55, 0.085, 0.68, 0.53);
}

[data-aos][data-aos][data-aos-easing=ease-out-cubic],
body[data-aos-easing=ease-out-cubic] [data-aos] {
  transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

[data-aos][data-aos][data-aos-easing=ease-in-out-cubic],
body[data-aos-easing=ease-in-out-cubic] [data-aos] {
  transition-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

[data-aos][data-aos][data-aos-easing=ease-in-quart],
body[data-aos-easing=ease-in-quart] [data-aos] {
  transition-timing-function: cubic-bezier(0.55, 0.085, 0.68, 0.53);
}

[data-aos][data-aos][data-aos-easing=ease-out-quart],
body[data-aos-easing=ease-out-quart] [data-aos] {
  transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

[data-aos][data-aos][data-aos-easing=ease-in-out-quart],
body[data-aos-easing=ease-in-out-quart] [data-aos] {
  transition-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

[data-aos^=fade][data-aos^=fade] {
  opacity: 0;
  transition-property: opacity, transform;
}

[data-aos^=fade][data-aos^=fade].aos-animate {
  opacity: 1;
  transform: translateZ(0);
}

[data-aos=fade-up] {
  transform: translate3d(0, var(--num), 0);
}

[data-aos=fade-down] {
  transform: translate3d(0, calc(var(--num) * -1), 0);
}

[data-aos=fade-right] {
  transform: translate3d(calc(var(--num) * -1), 0, 0);
}

[data-aos=fade-left] {
  transform: translate3d(var(--num), 0, 0);
}

[data-aos=fade-up-right] {
  transform: translate3d(calc(var(--num) * -1), var(--num), 0);
}

[data-aos=fade-up-left] {
  transform: translate3d(var(--num), var(--num), 0);
}

[data-aos=fade-down-right] {
  transform: translate3d(calc(var(--num) * -1), calc(var(--num) * -1), 0);
}

[data-aos=fade-down-left] {
  transform: translate3d(var(--num), calc(var(--num) * -1), 0);
}

[data-aos^=zoom][data-aos^=zoom] {
  opacity: 0;
  transition-property: opacity, transform;
}

[data-aos^=zoom][data-aos^=zoom].aos-animate {
  opacity: 1;
  transform: translateZ(0) scale(1);
}

[data-aos=zoom-in] {
  transform: scale(0.95);
}

[data-aos=zoom-in-up] {
  transform: translate3d(0, var(--num), 0) scale(0.95);
}

[data-aos=zoom-in-down] {
  transform: translate3d(0, calc(var(--num) * -1), 0) scale(0.95);
}

[data-aos=zoom-in-right] {
  transform: translate3d(calc(var(--num) * -1), 0, 0) scale(0.95);
}

[data-aos=zoom-in-left] {
  transform: translate3d(var(--num), 0, 0) scale(0.95);
}

[data-aos=zoom-out] {
  transform: scale(1.05);
}

[data-aos=zoom-out-up] {
  transform: translate3d(0, var(--num), 0) scale(1.05);
}

[data-aos=zoom-out-down] {
  transform: translate3d(0, calc(var(--num) * -1), 0) scale(1.05);
}

[data-aos=zoom-out-right] {
  transform: translate3d(calc(var(--num) * -1), 0, 0) scale(1.05);
}

[data-aos=zoom-out-left] {
  transform: translate3d(var(--num), 0, 0) scale(1.05);
}

[data-aos^=slide][data-aos^=slide] {
  transition-property: transform;
}

[data-aos^=slide][data-aos^=slide].aos-animate {
  transform: translateZ(0);
}

[data-aos=slide-up] {
  transform: translate3d(0, 100%, 0);
}

[data-aos=slide-down] {
  transform: translate3d(0, -100%, 0);
}

[data-aos=slide-right] {
  transform: translate3d(-100%, 0, 0);
}

[data-aos=slide-left] {
  transform: translate3d(100%, 0, 0);
}

[data-aos^=flip][data-aos^=flip] {
  backface-visibility: hidden;
  transition-property: transform;
}

[data-aos=flip-left] {
  transform: perspective(2500px) rotateY(-100deg);
}

[data-aos=flip-left].aos-animate {
  transform: perspective(2500px) rotateY(0);
}

[data-aos=flip-right] {
  transform: perspective(2500px) rotateY(100deg);
}

[data-aos=flip-right].aos-animate {
  transform: perspective(2500px) rotateY(0);
}

[data-aos=flip-up] {
  transform: perspective(2500px) rotateX(-100deg);
}

[data-aos=flip-up].aos-animate {
  transform: perspective(2500px) rotateX(0);
}

[data-aos=flip-down] {
  transform: perspective(2500px) rotateX(100deg);
}

[data-aos=flip-down].aos-animate {
  transform: perspective(2500px) rotateX(0);
}

/*
::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

	COMMON

::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
*/
/*== root ====================================================================================================*/
:root {
  --vw: 1vw;
  --vp: 19.20;
  --c_black: #222;
  --c_white: #fff;
  --c_red: #AE1111;
  --c_red2: #F83E3E;
  --c_blue1: #0C2E4C;
  --c_blue2: #1164AE;
  --c_blue3: #6DADD9;
  --c_blue4: #A9C1D5;
  --c_green1: #144A00;
  --c_green2: #90CF42;
  --c_gray1: #CDD4DA;
  --c_gray2: #F4F4F4;
  --c_gray3: #f6f6f6;
  --c_gray4: #999999;
  --c_gray5: #C4C4C4;
  --c_gray6: #F0F0F0;
  --c_gray7: #707070;
  --c_gray8: #XXXXXX;
  --c_gray9: #XXXXXX;
  --c_gray10: #XXXXXX;
  --shadow: 0px 0px 6px rgba(117, 152, 186, 0.2);
  --shadow2: 0px 0px 10px rgba(0, 0, 0, 0.43);
  --pdX: min(calc(56 / var(--vp) * var(--vw)), 56px);
  --lh2: 2;
  --ls25: 0.025em;
  --ls50: 0.05em;
  --ts: transform 0.25s cubic-bezier(0.5, 0.8, 0.5, 1);
}
@media screen and (max-width: 767px) {
  :root {
    --vp: 3.90;
  }
}
@media screen and (max-width: 767px) {
  :root {
    --pdX: min(calc(30 / var(--vp) * var(--vw)), 30px);
  }
}

/*-------------------------
  アニメーション
-------------------------*/
@keyframes lightning {
  0%, 24%, 100% {
    transform: rotate(0) translate(0, 0);
  }
  4%, 12%, 20% {
    transform: rotate(10deg) translate(0, 0);
  }
  8%, 16% {
    transform: rotate(-10deg) translate(0, 0);
  }
  22% {
    transform: rotate(10deg) translate(calc(var(--ts_num) * -1), var(--ts_num));
  }
}
/*== common ====================================================================================================*/
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■setting
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
html {
  --NotoSans: "Noto Sans";
  --NotoSans: "Noto Sans JP";
  font-family: "Montserrat", var(--NotoSans), "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 100%;
  scroll-padding-top: var(--headerHeight);
  --headerHeight: 140px;
}
html[lang=zh-TW] {
  --NotoSans: "Noto Sans TC";
}
html[lang=zh-CN] {
  --NotoSans: "Noto Sans SC";
}
html[lang=ko] {
  --NotoSans: "Noto Sans KR";
}
@media print, screen and (max-width: 1023px) {
  html {
    --headerHeight: 80px;
  }
}
@media screen and (max-width: 767px) {
  html {
    --headerHeight: 66px;
    padding-top: 0;
  }
}

body {
  position: relative;
  background: var(--c_white);
  color: var(--c_black);
  font-size: 1rem;
  line-height: 1;
  margin: 0 auto;
  -webkit-text-size-adjust: 100%;
  -webkit-overflow-scrolling: touch;
  -webkit-touch-callout: none;
  word-wrap: break-word;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
  text-autospace: normal;
  container: body/inline-size;
}
body a[href=""],
body a.disabled {
  cursor: not-allowed;
  pointer-events: none;
  text-decoration: none;
}
body *[hidden] {
  display: none !important;
}

body:not(.view_sp) a[href^="tel:"] {
  color: inherit;
  text-decoration: none;
  pointer-events: none;
}

#container {
  display: flex;
  flex-flow: column;
  min-height: 100vh;
}

.contents {
  container: contents/inline-size;
  position: relative;
  flex: 1;
  width: 100%;
}

.innerWrap {
  position: relative;
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  padding: 0;
}
@media screen and (max-width: 767px) {
  .innerWrap {
    max-width: none;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■HEADER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.test_local #header {
  background: #fcc;
}
.test_local #header_nav .list_item > *:not(.list_child) {
  --c_blue1: #f00;
}

#header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  column-gap: min(16 / var(--vp) * var(--vw), 16px);
  width: 100%;
  height: 140px;
  padding: 0 var(--pdX) 15px;
  background: linear-gradient(#fff 0%, rgba(255, 255, 255, 0) 100%);
}
@container body (max-width: 1023px) {
  #header {
    height: 80px;
    padding-right: 78px;
    padding-bottom: 0;
  }
}
@media screen and (min-width: 768px) {
  #header {
    position: sticky;
    top: 0;
    z-index: 100;
  }
}
@media screen and (max-width: 767px) {
  #header {
    height: 66px;
    --pdX: 20px;
  }
}
@container body (max-width: 1740px) {
  #header > .logo {
    grid-area: 1/1/3/2;
    margin-right: 0;
  }
}
@container body (max-width: 1740px) {
  #header > #header_nav {
    grid-area: 2/2/3/5;
    margin-left: auto;
  }
  #header > #header_nav .list_child {
    white-space: inherit;
    max-width: 350px;
  }
  @container body (max-width: 1023px) {
    #header > #header_nav {
      display: none;
    }
  }
}
@container body (max-width: 1740px) {
  #header > .lang {
    grid-area: 1/2/2/3;
    margin-left: auto;
  }
}
@container body (max-width: 1740px) {
  #header > .btns:has(.recruit) {
    grid-area: 1/3/2/4;
  }
}
@container body (max-width: 1740px) {
  #header > .btns:has(.contact) {
    grid-area: 1/4/2/5;
  }
}
#header .logo {
  position: relative;
  flex: 1 0 auto;
  align-self: center;
  margin-right: min(25 / var(--vp) * var(--vw), 25px);
}
@media screen and (max-width: 767px) {
  #header .logo {
    margin-right: auto;
  }
}
#header .logo a {
  display: inline-block;
}
#header .logo svg {
  width: 234px;
  height: auto;
}
@media screen and (max-width: 767px) {
  #header .logo svg {
    width: min(176 / var(--vp) * var(--vw), 176px);
  }
}
#header .lang {
  padding: 0 min(32 / var(--vp) * var(--vw), 32px);
}
@container body (max-width: 1680px) {
  #header .lang {
    --vp: 16.80;
    padding: 0 min(24 / var(--vp) * var(--vw), 32px);
  }
}
@media screen and (max-width: 767px) {
  #header .lang {
    padding: 0;
  }
}
@container body (max-width: 1023px) {
  #header .btns {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  #header .btns {
    display: none;
  }
}
#header .btn {
  --h: 44px;
  min-width: 155px;
  font-size: 1rem;
  box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.16);
}
#header .btn span {
  min-width: initial;
}

#header_nav {
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.5625;
}
#header_nav .list_wrap {
  display: flex;
  column-gap: min(40 / var(--vp) * var(--vw), 40px);
}
#header_nav .list_item {
  position: relative;
  z-index: 1;
}
#header_nav .list_item:has(a[href*="/recruit/"]), #header_nav .list_item:has(a[href*="/contact/"]) {
  display: none;
}
#header_nav .list_item:hover .parents, #header_nav .list_item:focus-within .parents {
  --c_blue1: var(--c_blue2);
}
#header_nav .list_item:hover .parents::before, #header_nav .list_item:focus-within .parents::before {
  transform: scaleX(1);
}
#header_nav .list_item:hover .list_child, #header_nav .list_item:focus-within .list_child {
  z-index: 5;
  clip-path: inset(0 -50vw -20px);
  visibility: visible;
}
body.lang-en:not(.header_fixed) #header_nav .list_item:last-child .list_child {
  left: -25%;
}
#header_nav .list_item > *:not(.list_child) {
  color: var(--c_blue1);
}
#header_nav .list_item a {
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#header_nav .list_item a:hover {
  color: var(--c_blue2);
}
#header_nav .list_child {
  white-space: nowrap;
  position: absolute;
  z-index: 10;
  top: 100%;
  left: 0;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  row-gap: 16px;
  font-size: 1rem;
  --top: 23px;
  --pd: 32px;
  padding: calc(var(--top) + var(--pd)) 48px var(--pd) var(--pd);
  clip-path: inset(0 -50vw 100%);
  visibility: hidden;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
  transition: all 0.3s;
}
#header_nav .list_child::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 23px;
  bottom: 0;
  left: 0;
  width: 100%;
  background: var(--c_white);
  border-radius: 0px 80px 0 22px;
  box-shadow: 0px 2px 6px 2px rgba(0, 0, 0, 0.08);
}
#header_nav .list_child a {
  position: relative;
  display: block;
  min-width: 130px;
  padding-right: 40px;
}
html[lang=en] #header_nav .list_child a {
  min-width: 200px;
}
#header_nav .list_child a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 13px;
  aspect-ratio: 1/1;
  background: url(../img/arrow01.svg) no-repeat center center;
  background-size: cover;
  transform: translate(0, -50%);
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#header_nav .list_child a:hover::after {
  transform: translate(5px, -50%);
}
#header_nav .list_item:nth-of-type(3) .list_child a {
  min-width: 280px;
}
@container body (max-width: 1740px) {
  #header_nav .list_item:nth-of-type(3) .list_child a {
    min-width: 200px;
  }
}
#header_nav .parents {
  cursor: pointer;
  padding-right: 37px;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
  --icon-before: 25px;
  --icon-after: 11px;
}
#header_nav .parents::before, #header_nav .parents::after {
  content: "";
  position: absolute;
  aspect-ratio: 1/1;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#header_nav .parents::before {
  top: 0;
  right: 0;
  width: var(--icon-before);
  border: 1px solid var(--c_blue1);
  border-radius: 100%;
}
#header_nav .parents::after {
  top: calc((var(--icon-before) - var(--icon-after)) / 2);
  right: calc((var(--icon-before) - var(--icon-after)) / 2);
  width: var(--icon-after);
  mask: url("../img/icon-plus.svg");
  mask-size: cover;
  background-color: var(--c_blue1);
}

/* 言語切り替え */
#header .lang .gtranslate_wrapper {
  position: relative;
  border-bottom: 1px solid var(--c_blue1);
  color: var(--c_blue1);
  font-weight: 500;
  background: url(../img/icon-lang.svg) no-repeat left center;
  background-size: auto 20px;
}
@media screen and (max-width: 767px) {
  #header .lang .gtranslate_wrapper {
    background-position: center top;
    padding-top: 27px;
    padding-bottom: 5px;
  }
}
#header .lang .gtranslate_wrapper::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 12px;
  aspect-ratio: 1/cos(30deg);
  clip-path: polygon(50% 100%, 100% 0, 0 0);
  background: currentColor;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  #header .lang .gtranslate_wrapper::before {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  #header .lang .gtranslate_wrapper::after {
    content: "LANG";
    display: block;
    font-family: "Montserrat", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
    font-weight: 400;
    letter-spacing: calc(0em / 1000);
    font-size: 0.625rem;
    text-align: center;
  }
}
#header .lang .gt_selector {
  appearance: none !important;
  width: 111px;
  color: inherit;
  font-family: inherit !important;
  background-color: transparent;
  border: none;
  padding: 5px 0;
  padding-left: 28px;
}
@media screen and (max-width: 767px) {
  #header .lang .gt_selector {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    line-height: 0;
    padding: 0;
    margin: 0;
    text-indent: -999px;
  }
}

/*-------------------------
	メニューレイアウト切替
-------------------------*/
@container body (max-width: 1580px) {
  html:not([lang=en]) body:not(.menu_hidden) #header {
    display: grid;
    grid-auto-columns: max-content 1fr max-content max-content;
    grid-template-rows: repeat(2, 1fr);
    padding-bottom: 0;
  }
  @container body (max-width: 1023px) {
    html:not([lang=en]) body:not(.menu_hidden) #header {
      display: flex;
    }
  }
}
@container body (max-width: 1840px) {
  html[lang=en] body:not(.menu_hidden) #header {
    display: grid;
    grid-auto-columns: max-content 1fr max-content max-content;
    grid-template-rows: repeat(2, 1fr);
    padding-bottom: 0;
  }
  @container body (max-width: 1023px) {
    html[lang=en] body:not(.menu_hidden) #header {
      display: flex;
    }
  }
}

/*-------------------------
	第一弾非表示メニューに合わせてレイアウト調整
-------------------------*/
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■FOOTER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#c-contact {
  position: relative;
  color: var(--c_white);
  background: var(--c_black);
  padding: var(--pdY) var(--pdX);
  --pdY: 0;
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  #c-contact {
    padding-top: 64px;
    padding-bottom: 86px;
    margin-top: 80px;
  }
}
#c-contact::before {
  content: "";
  opacity: 0.15;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/footer-contact.webp) no-repeat center center;
  background-size: cover;
}
#c-contact .innerWrap {
  display: flex;
  align-items: center;
  column-gap: min(96 / var(--vp) * var(--vw), 96px);
  max-width: 1200px;
  min-height: 288px;
}
@media screen and (max-width: 767px) {
  #c-contact .innerWrap {
    display: block;
    text-align: center;
    min-height: inherit;
  }
}
#c-contact .innerWrap > .hd {
  flex: 1 0 auto;
}
#c-contact .hd {
  color: var(--c_white);
}
@media screen and (max-width: 767px) {
  #c-contact .hd {
    margin-bottom: 32px;
  }
}
#c-contact .hd span::first-letter {
  color: inherit;
}
#c-contact .hd .en {
  color: var(--c_gray2);
}
html[lang=en] #c-contact .hd .jp {
  color: var(--c_white);
}
#c-contact .txt {
  font-size: 1.25rem;
  line-height: 1.9;
}
@media screen and (max-width: 767px) {
  #c-contact .txt {
    font-size: 1rem;
    line-height: 2;
  }
}
@media screen and (max-width: 767px) {
  #c-contact .btns {
    margin-top: 40px;
  }
}
#c-contact .btn {
  min-width: 310px;
  min-height: 64px;
  font-size: 1.125rem;
}
@media screen and (max-width: 767px) {
  #c-contact .btn {
    max-width: 310px;
    min-width: inherit;
    width: 100%;
  }
}

#footer {
  position: relative;
  background: var(--c_blue1);
  color: var(--c_white);
  padding: 56px min(64 / var(--vp) * var(--vw), 64px) 0 0;
}
@container body (min-width: 1025px) {
  #footer {
    display: grid;
    grid-auto-columns: max-content 1fr;
    column-gap: calc(120 / var(--vp) * var(--vw));
  }
}
@container body (max-width: 1024px) {
  #footer {
    padding-right: 0;
  }
}
@media screen and (max-width: 767px) {
  #footer {
    padding: 64px 0 0;
  }
}
@container body (min-width: 1025px) {
  #footer .detail_wrap {
    grid-area: 1/2/2/3;
    padding-top: 110px;
  }
}
@container body (max-width: 1024px) {
  #footer .detail_wrap {
    padding-left: min(64 / var(--vp) * var(--vw), 64px);
    padding-right: min(64 / var(--vp) * var(--vw), 64px);
  }
}
@media screen and (max-width: 767px) {
  #footer .detail_wrap {
    padding-left: min(40 / var(--vp) * var(--vw), 40px);
    padding-right: min(40 / var(--vp) * var(--vw), 40px);
  }
}
#footer .office {
  margin-bottom: 48px;
}
#footer .office .logo {
  width: 320px;
  margin-bottom: 32px;
}
@media screen and (max-width: 767px) {
  #footer .office .logo {
    width: calc(212 / var(--vp) * var(--vw));
  }
}
#footer .office .logo svg {
  width: 100%;
  height: auto;
}
#footer .office p {
  color: #8697A6;
  font-size: 0.9375rem;
  line-height: 1.7333;
}
@media screen and (max-width: 767px) {
  #footer .office p {
    font-size: 0.875rem;
    line-height: 1.857;
  }
}
@container body (min-width: 561px) {
  #footer .office p br.sp {
    display: none;
  }
}
#footer #copyright {
  color: #8697A6;
  font-size: 0.875rem;
  text-align: center;
  margin-top: 64px;
}
@media screen and (min-width: 768px) {
  #footer #copyright {
    text-align: right;
    padding-bottom: 40px;
  }
}
@container body (min-width: 1025px) {
  #footer #copyright {
    grid-area: 2/2/3/3;
  }
}
@container body (max-width: 1024px) {
  #footer #copyright {
    padding-left: min(64 / var(--vp) * var(--vw), 64px);
    padding-right: min(64 / var(--vp) * var(--vw), 64px);
  }
}
#footer .img {
  overflow: hidden;
  position: relative;
  z-index: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(840 / var(--vp) * var(--vw));
  border-radius: 0 240px 0 0;
}
@container body (min-width: 1025px) {
  #footer .img {
    grid-area: 1/1/3/2;
  }
}
@container body (max-width: 1024px) {
  #footer .img {
    width: 100%;
    min-height: 270px;
    border-radius: 0 64px 0 0;
  }
}
@media screen and (max-width: 767px) {
  #footer .img {
    margin-top: 48px;
  }
}
#footer .img img {
  opacity: 0.6;
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
}
#footer .img figucaption {
  position: relative;
  display: inline-block;
  color: var(--c_white);
  font-size: 1.5rem;
  letter-spacing: 0.01em;
  text-indent: -0.01em;
}
@media screen and (max-width: 767px) {
  #footer .img figucaption {
    font-size: 1.125rem;
  }
}
#footer .img figucaption::after {
  content: "";
  position: absolute;
  top: -30px;
  right: -43px;
  width: 26px;
  aspect-ratio: 23/39;
  background: url("../img/icon-lightning.svg") no-repeat left top;
}
@media screen and (max-width: 767px) {
  #footer .img figucaption::after {
    top: -17px;
    right: -26px;
    width: 18px;
  }
}

#footer_nav {
  font-size: 0.9375rem;
  line-height: 1.5;
}
#footer_nav .list_menu__inner {
  display: grid;
  grid-template-columns: max-content max-content max-content 1fr;
  grid-template-rows: max-content max-content 1fr;
  gap: 24px 64px;
}
@container body (max-width: 1680px) {
  #footer_nav .list_menu__inner {
    grid-template-columns: max-content max-content 1fr max-content;
  }
}
@container body (max-width: 1440px) {
  #footer_nav .list_menu__inner {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: max-content max-content max-content 1fr;
  }
}
@container body (max-width: 1024px) {
  #footer_nav .list_menu__inner {
    grid-template-columns: max-content max-content max-content 1fr;
  }
}
@container body (max-width: 860px) {
  #footer_nav .list_menu__inner {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: max-content max-content max-content 1fr;
  }
}
@container body (max-width: 560px) {
  #footer_nav .list_menu__inner {
    column-gap: 0;
  }
}
html[lang=en] #footer_nav .list_menu__inner {
  grid-template-columns: repeat(4, 1fr);
}
#footer_nav .list_item:first-child {
  font-size: 1rem;
}
#footer_nav .list_item:last-child {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  row-gap: 24px;
}
#footer_nav .list_item:has(> a[href*="/project/"]:only-of-type), #footer_nav .list_item:has(> a[href*="/information/"]:only-of-type) {
  display: none;
}
#footer_nav .list_item:nth-child(1) {
  grid-area: 1/1/2/5;
}
#footer_nav .list_item:nth-child(2) {
  grid-area: 2/1/5/2;
}
#footer_nav .list_item:nth-child(3) {
  grid-area: 2/2/5/3;
}
#footer_nav .list_item:nth-child(4) {
  grid-area: 2/3/4/4;
}
#footer_nav .list_item:nth-child(5) {
  grid-area: 4/3/5/4;
}
#footer_nav .list_item:last-child {
  grid-area: 2/4/3/5;
}
@container body (max-width: 1440px) {
  #footer_nav .list_item:nth-child(1) {
    grid-area: 1/1/2/3;
  }
  #footer_nav .list_item:nth-child(2) {
    grid-area: 2/1/3/2;
  }
  #footer_nav .list_item:nth-child(3) {
    grid-area: 2/2/3/3;
  }
  #footer_nav .list_item:nth-child(4) {
    grid-area: 3/1/4/2;
  }
  #footer_nav .list_item:nth-child(5) {
    grid-area: 4/1/5/2;
  }
  #footer_nav .list_item:last-child {
    grid-area: 3/2/4/3;
  }
}
@container body (max-width: 1024px) {
  #footer_nav .list_item:nth-child(1) {
    grid-area: 1/1/2/5;
  }
  #footer_nav .list_item:nth-child(2) {
    grid-area: 2/1/5/2;
  }
  #footer_nav .list_item:nth-child(3) {
    grid-area: 2/2/5/3;
  }
  #footer_nav .list_item:nth-child(4) {
    grid-area: 2/3/4/4;
  }
  #footer_nav .list_item:nth-child(5) {
    grid-area: 4/3/5/4;
  }
  #footer_nav .list_item:last-child {
    grid-area: 2/4/3/5;
  }
}
@media screen and (max-width: 767px) {
  #footer_nav .list_item:nth-child(1) {
    grid-area: 1/1/2/3;
  }
  #footer_nav .list_item:nth-child(2) {
    grid-area: 2/1/3/2;
  }
  #footer_nav .list_item:nth-child(3) {
    grid-area: 2/2/3/3;
  }
  #footer_nav .list_item:nth-child(4) {
    grid-area: 3/1/4/2;
  }
  #footer_nav .list_item:nth-child(5) {
    grid-area: 4/1/5/2;
  }
  #footer_nav .list_item:last-child {
    grid-area: 3/2/4/3;
  }
}
@container body (max-width: 560px) {
  #footer_nav .list_item:nth-child(1) {
    grid-area: 1/1/2/3;
  }
  #footer_nav .list_item:nth-child(2) {
    grid-area: 2/1/3/2;
  }
  #footer_nav .list_item:nth-child(3) {
    grid-area: 2/2/3/3;
  }
  #footer_nav .list_item:nth-child(4) {
    grid-area: 3/1/4/3;
  }
  #footer_nav .list_item:nth-child(5) {
    grid-area: 4/1/5/3;
  }
  #footer_nav .list_item:last-child {
    grid-area: 5/1/6/3;
  }
}
#footer_nav .list_item a {
  display: inline-block;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#footer_nav .list_item a:hover {
  color: var(--c_blue3);
}
#footer_nav .parents {
  opacity: 0.5;
}
#footer_nav .list_child {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  row-gap: 12px;
  margin-top: 12px;
}
#footer_nav .list_child_item {
  display: flex;
}
#footer_nav .list_child_item::before {
  opacity: 0.5;
  content: "├";
  margin-right: 0.5em;
}
#footer_nav .list_child_item:last-child::before {
  content: "└";
}
#footer_nav .other_link {
  font-size: 0.875rem;
  margin-top: 56px;
}
#footer_nav .other_link a {
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#footer_nav .other_link a:hover {
  color: var(--c_blue3);
}

#pagetop {
  cursor: pointer;
  position: absolute;
  top: 48px;
  right: 40px;
  font-family: "Montserrat", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-weight: 400;
  letter-spacing: calc(0em / 1000);
  font-size: 0.875rem;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  #pagetop {
    top: 0;
    left: 50%;
    line-height: 0;
    font-size: 0;
    transform: translate(-50%, -50%);
  }
}
#pagetop::before {
  content: "";
  display: block;
  width: 54px;
  aspect-ratio: 1/1;
  background: url(../img/pagetop.png) no-repeat center center;
  background-size: cover;
  border-radius: 100%;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  margin: 0 auto 11px;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (max-width: 767px) {
  #pagetop::before {
    margin-bottom: 0;
  }
}
#pagetop:hover::before {
  transform: scale(1.1);
}

/*-------------------------
	第一弾非表示メニューに合わせてレイアウト調整
-------------------------*/
.menu_hidden #footer_nav .list_menu__inner {
  grid-template-columns: max-content 1fr;
}
@container body (max-width: 560px) {
  .menu_hidden #footer_nav .list_menu__inner {
    grid-template-columns: repeat(2, 1fr);
  }
}
.menu_hidden #footer_nav .list_item:last-child {
  grid-area: 2/2/5/3;
}
@container body (max-width: 1024px) {
  .menu_hidden #footer_nav .list_item:last-child {
    grid-area: 2/2/5/3;
  }
}
@media screen and (max-width: 767px) {
  .menu_hidden #footer_nav .list_item:last-child {
    grid-area: 2/2/3/3;
  }
}
@container body (max-width: 560px) {
  .menu_hidden #footer_nav .list_item:last-child {
    grid-area: 2/2/3/3;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■MENU
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@container body (min-width: 1024px) {
  .menuBtn, #spMenu {
    display: none !important;
  }
}

.menuBtn {
  position: fixed;
  z-index: 101;
  top: 15px;
  right: 15px;
  background: var(--c_blue1);
  color: var(--c_white);
  width: 50px;
  height: 50px;
  border-radius: 0px 8px;
  padding: 6px;
}
@media screen and (max-width: 767px) {
  .menuBtn {
    top: 8px;
    right: 8px;
  }
}

/*-------------------------
  spMenuBtn / closeBtn
-------------------------*/
#spMenuBtn {
  z-index: 99999;
  border: none;
  background-color: transparent;
  outline: none;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  row-gap: 6px;
}
#spMenuBtn .spMenuBtn_bar {
  position: relative;
}
#spMenuBtn .spMenuBtn_bar::before, #spMenuBtn .spMenuBtn_bar::after {
  content: "";
}
#spMenuBtn .spMenuBtn_bar span, #spMenuBtn .spMenuBtn_bar::before, #spMenuBtn .spMenuBtn_bar::after {
  position: absolute;
  left: 0;
  right: 0;
  display: block;
  width: 100%;
  margin: auto;
  transition: all 0.2s;
  transform-origin: 50% 50%;
}
#spMenuBtn .spMenuBtn_bar span {
  top: 0;
  bottom: 0;
}
#spMenuBtn .spMenuBtn_bar::before {
  top: 0;
}
#spMenuBtn .spMenuBtn_bar::after {
  bottom: 0;
}
#spMenuBtn::after {
  content: "MENU";
  color: var(--c_white);
  font-size: 0.625rem;
}
#spMenuBtn .spMenuBtn_bar {
  width: 22px;
  height: 13px;
  margin: 0 auto;
}
#spMenuBtn .spMenuBtn_bar span, #spMenuBtn .spMenuBtn_bar::before, #spMenuBtn .spMenuBtn_bar::after {
  height: 1px;
  background: var(--c_white);
}

body.spMenu_open #spMenuBtn::after {
  content: "CLOSE";
}
body.spMenu_open .spMenuBtn_bar {
  position: relative;
}
body.spMenu_open .spMenuBtn_bar::before, body.spMenu_open .spMenuBtn_bar::after {
  content: "";
}
body.spMenu_open .spMenuBtn_bar span, body.spMenu_open .spMenuBtn_bar::before, body.spMenu_open .spMenuBtn_bar::after {
  position: absolute;
  left: 0;
  right: 0;
  display: block;
  width: 100%;
  margin: auto;
  transition: all 0.2s;
  transform-origin: 50% 50%;
}
body.spMenu_open .spMenuBtn_bar span {
  opacity: 0;
  top: 0;
  bottom: 0;
}
body.spMenu_open .spMenuBtn_bar::before {
  top: 0;
  bottom: 0;
  transform: rotate(45deg);
}
body.spMenu_open .spMenuBtn_bar::after {
  top: 0;
  bottom: 0;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
body.spMenu_open .spMenuBtn_bar::before {
  transform: rotate(30deg);
}
body.spMenu_open .spMenuBtn_bar::after {
  transform: rotate(-30deg);
}

/*-------------------------
  spMenu
-------------------------*/
#spMenu {
  opacity: 0;
  position: fixed;
  display: block;
  padding: 0;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: 100;
  background: transparent;
  transform: none;
  overflow: hidden;
  transform: translateX(100%);
  transform-origin: top center;
  margin-right: auto;
  transition: opacity 0.25s linear;
}
body.spMenu_open #spMenu {
  opacity: 1;
}
.spMenu_open #spMenu {
  opacity: 1;
  transform: translateX(0);
  transition: opacity 0.25s linear;
}
#spMenu .spMenu_innerWrap {
  overflow-x: hidden;
  overflow-y: auto;
  height: 100%;
  background: var(--c_blue1);
  color: var(--c_white);
}
#spMenu .spMenu_inner {
  padding: 56px var(--pdX) 80px;
}
@media screen and (min-width: 768px) {
  #spMenu .spMenu_inner {
    padding-top: 76px;
  }
}

/* メニューの中身 */
#spMenu .list_menu {
  margin-bottom: 32px;
  border-bottom: 1px solid #8697A6;
}
#spMenu .list_menu .list_item:not(:first-child) {
  border-top: 1px solid #8697A6;
}
#spMenu .list_menu .list_item .parents, #spMenu .list_menu .list_item > a {
  padding: 0 5px;
}
#spMenu .list_menu .list_child_item {
  border-top: 1px solid #8697A6;
}
#spMenu .list_menu .list_child_item a {
  padding: 10px 5px 10px 25px;
}
#spMenu .list_menu .parents {
  color: #8697A6;
}
#spMenu .list_menu .parents,
#spMenu .list_menu a {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 48px;
  line-height: 1.5;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#spMenu .list_menu .parents::after,
#spMenu .list_menu a::after {
  content: "";
  position: absolute;
  top: 17.5px;
  right: 5px;
  width: 13px;
  aspect-ratio: 1/1;
  mask: url("../img/arrow01.svg");
  mask-size: cover;
  background-color: currentColor;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#spMenu .list_menu .parents:hover,
#spMenu .list_menu a:hover {
  color: var(--c_blue3);
}
#spMenu .list_menu .parents:hover::after,
#spMenu .list_menu a:hover::after {
  transform: translateX(5px);
}
#spMenu .btns {
  max-width: 216px;
  margin: 0 auto;
}
#spMenu .btns + .btns {
  margin-top: 16px;
}
#spMenu .btn {
  width: 100%;
}
#spMenu .other_link {
  display: flex;
  flex-direction: column;
  row-gap: 12px;
  font-size: 0.875rem;
  line-height: 1.5;
  margin-top: 40px;
}
#spMenu .other_link a {
  display: inline-block;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#spMenu .other_link a:hover {
  color: var(--c_blue3);
}

/*== parts ====================================================================================================*/
/*-------------------------
  ROLL OVER
-------------------------*/
.ro {
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
body:not(.view_sp) .ro:hover {
  opacity: 0.6;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.ro:hover img {
  opacity: 1;
}
.ro a:hover, .ro a:hover img {
  transition: none;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .ro:hover, .ro a:hover, .ro a:hover img {
    opacity: 1;
  }
}

/*-------------------------
  pcCont/spCont
-------------------------*/
@media screen and (min-width: 768px) {
  .sp, .spCont {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .pc, .pcCont {
    display: none;
  }
}
/*-------------------------
  COMMONS
-------------------------*/
.tac {
  text-align: center;
}

.tal {
  text-align: left;
}

.tar {
  text-align: right;
}

.f_left {
  float: left;
}

.f_right {
  float: right;
}

.clear {
  clear: both;
}

button {
  cursor: pointer;
  outline: none;
}

.fBox, .flex {
  display: flex;
}

svg {
  fill: currentColor;
}

.preload * {
  transition: none !important;
}

.ofi {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
}

.ac_btn {
  cursor: pointer;
}

.ac_box {
  display: none;
}

.slider {
  opacity: 0;
  transition: opacity 0.3s linear;
}

.slider.slick-initialized {
  opacity: 1;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: inherit;
}

.bold, strong {
  /*font-weight: inherit;*/
}

@media screen and (min-width: 768px) {
  .ptac {
    text-align: center;
  }
}

@media screen and (max-width: 767px) {
  .stac {
    text-align: center;
  }
}

@media screen and (min-width: 768px) {
  .pc_flex, .pflex {
    display: flex;
  }
}

.sp_ac_btn {
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .sp_ac_btn {
    pointer-events: none;
  }
}

@media screen and (min-width: 768px) {
  .sp_ac_box {
    display: block !important;
    height: auto !important;
    transition: none !important;
  }
}
@media screen and (max-width: 767px) {
  .sp_ac_box {
    display: none;
  }
}

code {
  display: inline-block;
  padding: 0.1em 0.25em;
  color: #444;
  background-color: #e7edf3;
  border-radius: 3px;
  border: solid 1px #d6dde4;
  text-indent: 0;
  font-size: 100%;
  line-height: 1.2;
}
code.red {
  display: block;
  background-color: #dc143c;
  border: none;
  border-radius: 0;
  color: #fff;
  font-weight: bold;
  padding: 1em;
  text-align: center;
}
@media screen and (max-width: 767px) {
  code.red {
    font-size: 80%;
  }
}
code.red::before {
  content: "⚠️";
}

/*-------------------------
  Fonts
-------------------------*/
.en {
  font-family: "Montserrat", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-weight: 400;
  letter-spacing: calc(0em / 1000);
}

/*-------------------------
  Splide
-------------------------*/
.splide__arrows {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  column-gap: 34px;
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .splide__arrows {
    margin-top: 16px;
  }
}
.splide__arrows .splide__arrow--prev {
  order: 1;
}
.splide__arrows .splide__arrow--next {
  order: 3;
}
.splide__arrows .splide__pagination {
  order: 2;
  margin-top: 12.5px;
}
.splide__arrows:has(.splide__pagination > li:only-of-type) {
  display: none;
}

.splide__arrow {
  background: none;
  border: none;
  box-shadow: none;
  color: inherit;
  appearance: none;
  font-family: "Montserrat", var(--NotoSans), "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 100%;
  font-weight: inherit;
  position: relative;
  aspect-ratio: 1/1;
  width: 40px;
  background: rgba(255, 255, 255, 0.8);
  border-radius: 100%;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.splide__arrow svg {
  display: none;
}
.splide__arrow::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/arrow03.svg) no-repeat center center;
  background-size: auto 13px;
}
.splide__arrow:hover {
  transform: scale(1.1);
}
.splide__arrow--prev::before {
  transform: rotate(180deg);
}
.splide__pagination {
  position: static;
  justify-content: flex-start;
  padding: 0;
  gap: 12px 24px;
}
@media screen and (max-width: 767px) {
  .splide__pagination {
    gap: 8px 16px;
  }
}
.splide__pagination li {
  vertical-align: top;
  font-size: 0;
  line-height: 1;
}
.splide__pagination__page {
  aspect-ratio: 1/1;
  width: 12px;
  background: rgba(255, 255, 255, 0.8);
  border: none;
  border-radius: 100%;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
body:not(.view_sp) .splide__pagination__page:hover {
  opacity: 0.6;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.splide__pagination__page.is-active {
  background-color: var(--c_blue2);
}

.splide__toggle {
  background: none;
  border: none;
  box-shadow: none;
  color: inherit;
  appearance: none;
  font-family: "Montserrat", var(--NotoSans), "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 100%;
  font-weight: inherit;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.splide__toggle:hover {
  transform: scale(1.1);
}
.splide__toggle > * {
  position: relative;
  aspect-ratio: 1/1;
  width: 35px;
  border-radius: 100%;
  border: 1px solid var(--c_black);
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
}
.splide__toggle > *::before {
  content: "";
  display: block;
  width: 35px;
  padding-bottom: 100%;
  background-color: var(--c_white);
  background-position: center center;
  background-size: 12px auto;
  border-radius: 100%;
}
.splide__toggle__play::before {
  /*@include icon-play('000');*/
}
.splide__toggle__pause::before {
  /*@include icon-pause('000');*/
}

/*-------------------------
  パンくず
-------------------------*/
.test_local #breadcrumbs {
  background: #cfc;
}

#breadcrumbs {
  overflow-x: auto;
  overflow-y: hidden;
}
@media screen and (max-width: 767px) {
  #breadcrumbs {
    display: none;
    padding: 7px 0;
  }
}
#breadcrumbs .innerWrap {
  max-width: inherit;
}
#breadcrumbs .breadcrumbs_list {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  color: var(--c_blue1);
  font-size: 0.875rem;
  line-height: 1;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  #breadcrumbs .breadcrumbs_list {
    font-size: minClamp(12);
  }
}
#breadcrumbs .breadcrumbs_list::before, #breadcrumbs .breadcrumbs_list::after {
  content: "";
  display: block;
  padding-right: min(64 / var(--vp) * var(--vw), 64px);
}
@media screen and (max-width: 767px) {
  #breadcrumbs .breadcrumbs_list::before, #breadcrumbs .breadcrumbs_list::after {
    padding-right: 12px;
  }
}
#breadcrumbs .breadcrumbs_list li {
  cursor: default;
}
#breadcrumbs .breadcrumbs_list li:not(:first-child)::before {
  content: "";
  background: url(../img/arrow02.svg) no-repeat center center;
  background-position: center center;
  background-size: 6px auto;
  padding: 0 18px;
}
#breadcrumbs .breadcrumbs_list li.home {
  width: 1.25rem;
  aspect-ratio: 1/1;
}
#breadcrumbs .breadcrumbs_list li.home > span {
  display: block;
  vertical-align: top;
}
#breadcrumbs .breadcrumbs_list li.home a {
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
  background: url(../img/icon-home.svg) no-repeat center center;
  background-size: auto 14px;
}
#breadcrumbs .breadcrumbs_list li.home a span {
  display: none;
}
#breadcrumbs .breadcrumbs_list a {
  display: inline-block;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#breadcrumbs .breadcrumbs_list a:hover {
  filter: brightness(2);
}

/*-------------------------
  ボタン
-------------------------*/
.btns button {
  background: none;
  border: none;
  box-shadow: none;
  color: inherit;
  appearance: none;
  font-family: "Montserrat", var(--NotoSans), "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 100%;
  font-weight: inherit;
}
.btns .btn {
  overflow: hidden;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  min-height: var(--h);
  background: var(--c_white);
  border-radius: var(--bdrs);
  border: 1px solid var(--bdc);
  color: var(--fc);
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.5;
  text-align: center;
  padding: 0.5em 1em;
}
@media screen and (min-width: 768px) {
  .btns .btn {
    min-width: 200px;
  }
}
@media screen and (max-width: 767px) {
  .btns .btn {
    font-size: 1rem;
  }
}
@media screen and (min-width: 768px) {
  .btns .btn span {
    min-width: 140px;
    text-align: center;
  }
}
.btns a, .btns button {
  position: relative;
  z-index: 0;
  text-decoration: none;
}
.btns a::before, .btns button::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #DFECF9;
  transform-origin: 100% 50%;
  transform: scaleX(0);
  transition: var(--ts);
}
.btns a:hover::before, .btns button:hover::before {
  transform-origin: 0% 50%;
  transform: scaleX(1);
}
.btns a > span, .btns button > span {
  color: currentColor;
}
.btns a[href=""], .btns a[disabled], .btns button[href=""], .btns button[disabled] {
  pointer-events: none;
  cursor: not-allowed;
  background-image: none;
  background-color: #ddd;
  --bdc: var(--c_gray5);
  --fc: var(--c_gray4);
}
.btns a[href=""]::before, .btns a[disabled]::before, .btns button[href=""]::before, .btns button[disabled]::before {
  display: none;
}
.btns .btn {
  --h: 48px;
  --bdrs: 100px;
  --bdc: var(--c_blue1);
  --fc: var(--c_blue1);
}
.btns .contact {
  border: none;
  background-image: linear-gradient(-25deg, #87c5f0, #87f0e2);
}
.btns .contact::before {
  background-color: rgba(255, 255, 255, 0.5);
}
.btns .recruit {
  border: none;
}
.btns .arrow {
  padding-right: 23px;
  padding-left: 23px;
}
.btns .arrow::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 23px;
  width: 14px;
  aspect-ratio: 1/1;
  mask: url("../img/arrow01.svg");
  mask-size: cover;
  background-color: currentColor;
  transform: translate(0, -50%);
}
.btns .arrow span {
  padding-right: 23px;
}
.btns .arrow.left::after {
  left: 23px;
  right: inherit;
  transform: rotate(180deg) translate(0, 50%);
}
.btns .arrow.left span {
  padding-left: 32px;
  padding-right: inherit;
}
.btns .text_link {
  --h: inherit;
  --bdrs: 0;
  min-width: inherit;
  background: none;
  border: none;
  border-bottom: 1px solid currentColor;
  font-size: 1rem;
  font-weight: 500;
  padding: 3px 0;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (max-width: 767px) {
  .btns .text_link {
    font-size: 0.9375rem;
  }
}
.btns .text_link:hover {
  filter: brightness(2);
}
.btns .text_link::before {
  display: none;
}
.btns .text_link span {
  min-width: inherit;
  text-align: left;
}
.btns .text_link .en {
  font-size: 0.9375rem;
  font-weight: 400;
}
.btns .text_link.arrow::after {
  right: 3px;
}
.btns .text_link.arrow > span {
  min-width: 103px;
}
.btns .text_link.arrow.left {
  border-bottom: none;
  padding: 0;
}
.btns .text_link.arrow.left::after {
  left: 0;
}
.btns .text_link.arrow.left > span {
  min-width: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}
@media screen and (max-width: 767px) {
  .btns .text_link.arrow.left > span {
    padding-left: 24px;
  }
}
.btns .text_link.arrow.left .en {
  line-height: 1.8;
  text-underline-offset: 8px;
  padding-bottom: 3px;
}
.btns .text_link:has(> span:only-type) {
  min-width: inherit;
}

/*-------------------------
  見出し
	英語のときは、span.enを非表示にしてspan.jpをspan.enの見た目にする。
-------------------------*/
.hd {
  display: inline-grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 0.275em 0;
  font-size: 2.5rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .hd {
    font-size: 1.75rem;
  }
}
.hd > span:first-letter {
  color: var(--c_blue2);
}
.hd .en {
  color: var(--c_blue1);
  font-weight: 700;
}
html[lang=en] .hd .en:not(:only-of-type) {
  display: none;
}
html:not([lang=en]) .hd .jp {
  font-size: 1.25rem;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  html:not([lang=en]) .hd .jp {
    font-size: 1rem;
  }
}
html:not([lang=en]) .hd .jp:first-letter {
  color: inherit;
}
html[lang=en] .hd .jp {
  color: var(--c_blue1);
  font-family: "Montserrat", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-weight: 700;
  letter-spacing: calc(0em / 1000);
}
.hd .color {
  color: var(--c_blue2);
}
.hd.icon span {
  position: relative;
}
.hd.icon span:not(.color)::after {
  content: "";
  position: absolute;
  top: -34px;
  right: -72px;
  width: 46px;
  --ts_num: 5px;
  aspect-ratio: 23/39;
  background: url("../img/icon-lightning.svg") no-repeat left top;
  animation: lightning 5s ease-out infinite;
  animation-delay: 2s;
  transform: rotate(0) translate(0, 0);
}
@media screen and (max-width: 767px) {
  .hd.icon span:not(.color)::after {
    top: -17px;
    right: -35px;
    width: 22px;
  }
}
@media print, screen and (max-width: 390px) {
  .hd.icon span:not(.color)::after {
    top: min(-17 / var(--vp) * var(--vw), -17px);
    right: min(-35 / var(--vp) * var(--vw), -35px);
    width: min(22 / var(--vp) * var(--vw), 22px);
  }
}
html:not([lang=en]) .hd.icon .jp::after {
  display: none;
}

/* ページタイトル */
.hd.main_title {
  font-size: 5.5rem;
  row-gap: 0.17em;
  text-transform: uppercase;
}
@media screen and (max-width: 767px) {
  .hd.main_title {
    font-size: 2.5rem;
  }
}
@media print, screen and (max-width: 390px) {
  .hd.main_title {
    font-size: min(40 / var(--vp) * var(--vw), 40px);
  }
}
.hd.main_title .en {
  font-weight: 600;
}
.hd.main_title .jp {
  color: var(--c_blue1);
}
html:not([lang=en]) .hd.main_title .jp {
  font-size: 1.5rem;
}
@media screen and (max-width: 767px) {
  html:not([lang=en]) .hd.main_title .jp {
    font-size: 1.1875rem;
  }
}
@media print, screen and (max-width: 390px) {
  html:not([lang=en]) .hd.main_title .jp {
    font-size: min(19 / var(--vp) * var(--vw), 19px);
  }
}
html[lang=en] .hd.main_title .jp {
  font-weight: 600;
}
.hd.main_title:not(.aos-init):not(.noanime) {
  animation: fade_in_up 0.25s cubic-bezier(0.5, 0.8, 0.5, 1) forwards;
  opacity: 0;
  transform: translate3d(calc(var(--num) * -1), var(--num), 0);
}
@keyframes fade_in_up {
  0% {
    opacity: 0;
    transform: translate3d(calc(var(--num) * -1), var(--num), 0);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

/* 下線付きタイトル＋英字と日本語横並び */
.hd.thin_title {
  display: flex;
  border-bottom: 1px solid var(--c_gray1);
  padding-bottom: 10px;
  font-size: 1.5rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .hd.thin_title {
    justify-content: flex-start;
    align-items: center;
    column-gap: 16px;
  }
}
@media screen and (max-width: 767px) {
  .hd.thin_title {
    flex-direction: column;
    font-size: 1.375rem;
    padding-bottom: 16px;
  }
}
.hd.thin_title .en {
  font-weight: 500;
}
html:not([lang=en]) .hd.thin_title .jp:not(:only-of-type) {
  font-size: 1rem;
}
@media screen and (max-width: 767px) {
  html:not([lang=en]) .hd.thin_title .jp:not(:only-of-type) {
    font-size: 0.875rem;
  }
}
html[lang=en] .hd.thin_title .jp {
  font-weight: 500;
}
.hd.thin_title .jp:only-of-type {
  font-weight: 700;
  padding-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .hd.thin_title .jp:only-of-type {
    font-size: 1.125rem;
    padding-bottom: 0;
  }
}
.hd.thin_title .jp:only-of-type:first-letter {
  color: var(--c_blue2);
}

/* 英字と日本語横並び */
@media screen and (min-width: 768px) {
  .hd.row_title {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    column-gap: 24px;
  }
}
html:not([lang=en]) .hd.row_title .jp {
  font-size: 1.125rem;
}
@media screen and (max-width: 767px) {
  html:not([lang=en]) .hd.row_title .jp {
    font-size: 1rem;
  }
}
.hd.row_title .jp:only-of-type {
  color: var(--c_blue1);
}
html:not([lang=en]) .hd.row_title .jp:only-of-type {
  font-size: 2rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  html:not([lang=en]) .hd.row_title .jp:only-of-type {
    font-size: 1.375rem;
  }
}

/* グレー背景付き */
.hd.bg_title {
  align-items: center;
  width: 100%;
  min-height: 80px;
  background: var(--c_gray3);
  border-radius: 8px;
  color: var(--c_blue1);
  font-size: 1.375rem;
  padding: 16px 40px;
}
@media screen and (max-width: 767px) {
  .hd.bg_title {
    min-height: 64px;
    font-size: 1.125rem;
    padding: 16px 20px;
  }
}

/* チェックアイコン付き */
.hd.check_title {
  position: relative;
  color: var(--c_blue1);
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.583;
  padding-left: 40px;
}
@media screen and (max-width: 767px) {
  .hd.check_title {
    font-size: 1.25rem;
  }
}
.hd.check_title::before, .hd.check_title::after {
  content: "";
  position: absolute;
  top: calc((1.583em - 24px) / 2);
  left: 0;
  aspect-ratio: 1/1;
  width: 24px;
}
.hd.check_title::before {
  background: var(--c_white);
  border: 1px solid var(--c_gray4);
}
.hd.check_title::after {
  mask-image: url(../img/icon-check.svg);
  mask-repeat: no-repeat;
  mask-position: center center;
  mask-size: 16px auto;
  background-color: var(--c_red2);
}
html:not([lang=en]) .hd.check_title span {
  font-size: 100%;
  font-weight: 500;
}

/*-------------------------
  テキスト
-------------------------*/
.p_txt1 {
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .p_txt1 {
    font-size: 1.1875rem;
    line-height: 1.636;
  }
}

.p_txt2 {
  font-size: 1.125rem;
  line-height: 2.11;
}
@media screen and (max-width: 767px) {
  .p_txt2 {
    font-size: 0.9375rem;
  }
}
.blk_intro .p_txt2 {
  font-weight: 500;
}

.p_txt3 {
  line-height: 2;
}

/*-------------------------
  背景
-------------------------*/
.bg01 {
  background: linear-gradient(var(--c_gray3) 0%, #e6f3fb 100%);
  background: linear-gradient(135deg, #e6f3fb 0%, var(--c_gray3) 100%);
}

.local_nav {
  margin: 27px 56px 0;
  display: flex;
  align-items: center;
  column-gap: min(4.167vw, 80px);
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .local_nav {
    overflow-x: visible;
    overflow-y: visible;
    flex-direction: column;
    align-items: flex-start;
    row-gap: 6px;
    margin: 34px 20px 0;
  }
}
.local_nav .hd.row_title {
  column-gap: min(0.833vw, 16px);
}
@media screen and (max-width: 767px) {
  .local_nav .hd.row_title {
    column-gap: 10px;
    flex-direction: row;
    display: flex;
    align-items: center;
  }
}
.local_nav .hd.row_title .en {
  text-transform: uppercase;
  font-size: 1.5rem;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .local_nav .hd.row_title .en {
    font-size: 1.25rem;
  }
}
.local_nav .hd.row_title .jp {
  font-size: 1rem;
  font-weight: 500;
  color: #1A3955;
  display: inline;
}
@media screen and (max-width: 767px) {
  .local_nav .hd.row_title .jp {
    font-size: 0.75rem;
  }
}
.local_nav .nav_box {
  display: flex;
  align-items: center;
  column-gap: min(1.25vw, 24px);
}
@media screen and (max-width: 767px) {
  .local_nav .nav_box {
    background-color: #F6F6F6;
    padding: 16px 20px;
    width: 100%;
    column-gap: 16px;
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
  }
}
.local_nav .nav_box .nav_txt {
  font-size: 1rem;
  color: var(--c_blue2);
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .local_nav .nav_box .nav_txt {
    font-size: 0.875rem;
  }
}
.local_nav .nav_box .circle {
  background-color: var(--c_blue1);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}
.local_nav .nav_box .nav_txt.nav_link {
  color: var(--c_blue1);
  text-decoration: underline;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.local_nav .nav_box .nav_txt.nav_link:hover {
  color: var(--c_blue2);
}

html:not([lang=en]) .local_nav .hd.row_title .jp {
  font-size: 1rem;
  color: #1A3955;
}
@media screen and (max-width: 767px) {
  html:not([lang=en]) .local_nav .hd.row_title .jp {
    font-size: 0.75rem;
  }
}

/*== Form ====================================================================================================*/
/*--------------------------------------------------
  form reset
--------------------------------------------------*/
.form input,
.form select,
.form textarea,
.form button {
  font-family: "Montserrat", var(--NotoSans), "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
.form input[type=text],
.form input[type=tel],
.form input[type=email],
.form input[type=password],
.form input[type=number],
.form input[type=url],
.form input[type=date] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: inherit;
  width: 100%;
  background: #fff;
  border: 1px solid var(--c_gray5);
  border-radius: 2px;
  height: 52px;
  color: #000;
  font-family: inherit !important;
  padding: 5px 20px;
}
@media screen and (max-width: 767px) {
  .form input[type=text],
.form input[type=tel],
.form input[type=email],
.form input[type=password],
.form input[type=number],
.form input[type=url],
.form input[type=date] {
    height: 48px;
  }
}
.form input[type=text]:focus,
.form input[type=tel]:focus,
.form input[type=email]:focus,
.form input[type=password]:focus,
.form input[type=number]:focus,
.form input[type=url]:focus,
.form input[type=date]:focus {
  box-shadow: 0 0 4px var(--c_blue2);
}
.form input[type=text]:not(.problem),
.form input[type=tel]:not(.problem),
.form input[type=email]:not(.problem),
.form input[type=password]:not(.problem),
.form input[type=number]:not(.problem),
.form input[type=url]:not(.problem),
.form input[type=date]:not(.problem) {
  background: var(--c_gray6);
}
.form input[type=text].problem,
.form input[type=tel].problem,
.form input[type=email].problem,
.form input[type=password].problem,
.form input[type=number].problem,
.form input[type=url].problem,
.form input[type=date].problem {
  background-color: #F7E6E6 !important;
  border-color: var(--c_red) !important;
  border-width: 2px;
}
.form input[type=date]::-webkit-date-and-time-value,
.form input[type=month]::-webkit-date-and-time-value {
  text-align: left;
}
.form select {
  outline: inherit;
  width: 100%;
  background: #fff;
  border: 1px solid var(--c_gray5);
  border-radius: 2px;
  height: 52px;
  color: #000;
  font-family: inherit !important;
  padding: 5px 20px;
  background: transparent;
  padding-top: 0;
  padding-bottom: 0;
  padding-right: 0;
}
@media screen and (max-width: 767px) {
  .form select {
    height: 48px;
  }
}
.form select:focus {
  box-shadow: 0 0 4px var(--c_blue2);
}
.form select:not(.problem) {
  background: var(--c_gray6);
}
.form select.problem {
  background-color: #F7E6E6 !important;
  border-color: var(--c_red) !important;
  border-width: 2px;
}
.form textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: inherit;
  width: 100%;
  background: #fff;
  border: 1px solid var(--c_gray5);
  border-radius: 2px;
  height: 52px;
  color: #000;
  font-family: inherit !important;
  padding: 5px 20px;
  display: block;
  resize: none;
  resize: both;
  height: 300px;
}
@media screen and (max-width: 767px) {
  .form textarea {
    height: 48px;
  }
}
.form textarea:focus {
  box-shadow: 0 0 4px var(--c_blue2);
}
.form textarea:not(.problem) {
  background: var(--c_gray6);
}
.form textarea.problem {
  background-color: #F7E6E6 !important;
  border-color: var(--c_red) !important;
  border-width: 2px;
}
@media screen and (min-width: 768px) {
  .form textarea {
    padding-top: 15px;
    padding-bottom: 15px;
  }
}
@media screen and (max-width: 767px) {
  .form textarea {
    height: 150px;
  }
}
.form button,
.form input[type=submit] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  border: none;
  outline: none;
  background: transparent;
  text-shadow: none;
  box-shadow: none;
}
.form button:not(.btn_inner):not(.btn):hover,
.form input[type=submit]:hover {
  background: none;
  -webkit-box-shadow: none;
  box-shadow: none;
}
.form input[type=file] {
  cursor: pointer;
}
.form label {
  cursor: pointer;
}
.form label span {
  position: relative;
  display: inline-block;
  padding: 0 0 0 29px;
}
.form label span:before, .form label span:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
}
.form label span:before {
  bottom: 0;
  left: 0;
  width: 20px;
  height: 20px;
  background: transparent;
  border: 1px solid var(--c_gray5);
  background: #fff;
  -webkit-transition: all 0.25s linear;
  transition: all 0.25s linear;
  margin: 3px 0 0;
}
.form label span:after {
  opacity: 0;
  top: 0;
  bottom: 0;
  margin: 8px auto 0;
  -webkit-transition: all 0.15s linear;
  transition: all 0.15s linear;
}
.form input[type=radio],
.form input[type=checkbox] {
  opacity: 0;
  appearance: none;
  position: absolute;
}
.form input[type=radio]:checked + span:after,
.form input[type=radio]:checked + input + span:after,
.form input[type=checkbox]:checked + span:after,
.form input[type=checkbox]:checked + input + span:after {
  opacity: 1;
  -webkit-transition: all 0.15s linear;
  transition: all 0.15s linear;
}
.form label input[type=radio] + span:before,
.form label input[type=radio] + input + span:before,
.form label input[type=radio] + span:after,
.form label input[type=radio] + input + span:after {
  border-radius: 50%;
}
.form label input[type=radio] + span:after,
.form label input[type=radio] + input + span:after {
  left: 5px;
  width: 10px;
  height: 10px;
  background: var(--c_blue2);
}
.form label input[type=checkbox] + span:after,
.form label input[type=checkbox] + input + span:after {
  top: 0;
  bottom: 2px;
  left: 7px;
  width: 6px;
  height: 10px;
  background: none;
  border-bottom: 2px solid var(--c_blue2);
  border-right: 2px solid var(--c_blue2);
  -webkit-transform: rotate(40deg);
  transform: rotate(40deg);
}

/*--------------------------------------------------
  プレースホルダー
--------------------------------------------------*/
:placeholder-shown {
  font-family: inherit;
  color: var(--c_gray4) !important;
}

::-webkit-input-placeholder {
  font-family: inherit;
  color: var(--c_gray4) !important;
}

:-moz-placeholder {
  opacity: 1;
  font-family: inherit;
  color: var(--c_gray4) !important;
}

::-moz-placeholder {
  opacity: 1;
  font-family: inherit;
  color: var(--c_gray4) !important;
}

:-ms-input-placeholder {
  font-family: inherit;
  color: var(--c_gray4) !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■↓↓↓お問い合わせフォーム　各サイトごとに自由編集↓↓↓
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/*--------------------------------------------------
  メールフォームプロ
--------------------------------------------------*/
/* エラー */
div.mfp_err {
  clear: both;
  display: none;
  text-align: left;
  margin: 10px 0 0 0;
  color: var(--c_red1);
  font-weight: bold;
  line-height: normal;
  background-position: 0px 1px;
}
div.mfp_err:empty {
  display: none;
}

.mfp_parent_error {
  border: solid 2px #F00;
}

.problem {
  background-color: #FCC;
}

div#mfp_error {
  background-color: #FEE;
  border: solid 1px #F00;
  padding: 10px;
  display: none;
}

/* ボタン */
@media screen and (min-width: 768px) {
  div.mfp_buttons {
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
  }
}
@media screen and (min-width: 768px) {
  div.mfp_buttons > *:not(:first-child) {
    margin-right: 60px;
  }
}
@media screen and (max-width: 767px) {
  div.mfp_buttons > *:not(:first-child) {
    margin-top: 20px;
  }
}
@media screen and (max-width: 767px) {
  div.mfp_buttons #mfp_button_cancel {
    max-width: 250px;
  }
}
/* テーブル */
#mfp_confirm_table tr {
  background: none;
}
@media screen and (max-width: 767px) {
  #mfp_confirm_table tr:last-child td {
    padding-bottom: 0;
  }
}
#mfp_confirm_table th, #mfp_confirm_table td {
  text-align: left;
  vertical-align: top;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  #mfp_confirm_table th, #mfp_confirm_table td {
    display: block;
    width: 100%;
  }
}

/*--------------------------------------------------
	入力画面
--------------------------------------------------*/
#sec_contact_form .list_input ul + ul {
  margin-top: 15px;
}
#sec_contact_form .list_input li {
  margin: 0 20px 10px 0;
}
#sec_contact_form #mfp_phase_confirm h4 {
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
  margin: 0 0 30px;
}
@media screen and (max-width: 767px) {
  #sec_contact_form #mfp_phase_confirm h4 {
    margin: 0 0 50px;
  }
}

/*--------------------------------------------------
	確認画面
--------------------------------------------------*/
div#mfp_error {
  width: 100%;
}

div#mfp_warning {
  width: 100%;
  margin: 0 auto;
  background: #f7ebeb;
  border: 1px solid var(--red01) !important;
  border-radius: 0;
  padding: 20px 30px;
  margin-bottom: 40px;
}

div#mfp_overlay {
  width: 90%;
}

div#mfp_overlay_inner {
  max-width: 1100px;
  width: 100%;
  border-radius: 0;
  padding: 20px 40px 36px;
}
@media screen and (max-width: 767px) {
  div#mfp_overlay_inner {
    padding: 20px 20px 40px;
  }
}

div.mfp_buttons {
  padding: 0;
}

#mfp_confirm_table {
  width: 100%;
}
#mfp_confirm_table tr {
  display: flex;
  border-bottom: 1px solid var(--c_gray3);
  padding-bottom: 16px;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  #mfp_confirm_table tr {
    flex-direction: column;
  }
}
#mfp_confirm_table th {
  font-weight: bold;
}
@media screen and (min-width: 768px) {
  #mfp_confirm_table th {
    flex: 1 0 auto;
    width: 260px;
    padding-right: 30px;
  }
}
#mfp_confirm_table td {
  width: 100%;
}

#mfp_overlay .hd04 {
  color: var(--c_green1);
  font-size: 1.5rem;
  line-height: 1.5;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  #mfp_overlay .hd04 {
    font-size: 1.125rem;
  }
}

#mfp_overlay div.mfp_buttons {
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  #mfp_overlay div.mfp_buttons {
    display: flex;
    flex-direction: row-reverse;
    column-gap: 12px;
  }
}
@media screen and (max-width: 767px) {
  #mfp_overlay div.mfp_buttons > *:not(:first-child) {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  #mfp_overlay div.mfp_buttons .btn01 {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  #mfp_overlay div.mfp_buttons .btn_inner {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  #mfp_overlay div.mfp_buttons .btn_inner > span {
    min-width: inherit;
  }
}

/*
::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

	wp

::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
*/
/*== wp-common 共通要素 ====================================================================================================*/
/*-------------------------
  ログインバー
-------------------------*/
@media print, screen and (max-width: 782px) {
  html:has(body.admin-bar) {
    margin-top: 0 !important;
  }
}
@media print, screen and (max-width: 782px) {
  html:has(body.admin-bar) body {
    padding-top: var(--wp-admin--admin-bar--height);
  }
}
@media print, screen and (max-width: 782px) {
  html:has(body.admin-bar) #wpadminbar {
    position: fixed;
  }
}
html:has(body.admin-bar) #header {
  top: var(--wp-admin--admin-bar--height);
}
html:has(body.admin-bar) .menuBtn {
  top: calc(15px + var(--wp-admin--admin-bar--height));
}
@media screen and (max-width: 767px) {
  html:has(body.admin-bar) .menuBtn {
    top: calc(8px + var(--wp-admin--admin-bar--height));
  }
}

/*-------------------------
  編集ボタン
-------------------------*/
a.post-edit-link {
  background-color: #F00 !important;
  background-image: none !important;
  border-radius: 5px 5px 5px 5px !important;
  color: #FFFFFF !important;
  font-size: 0.625rem !important;
  font-weight: normal !important;
  padding: 3px 5px !important;
  text-decoration: none !important;
  display: inline-block !important;
  line-height: 1.1 !important;
}

a.post-edit-link:hover {
  background-color: #06C !important;
}

/*-------------------------
  WP用のページャー
-------------------------*/
.wp-pagenavi {
  container: wp_pagenavi/inline-size;
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  max-width: 410px;
  margin: 64px auto 0;
}
@container body (max-width: 470px) {
  .wp-pagenavi {
    --vp: 4.70;
  }
}
@media screen and (max-width: 767px) {
  .wp-pagenavi {
    margin-top: 32px;
  }
}
.wp-pagenavi .first, .wp-pagenavi .last,
.wp-pagenavi > *[class$=postslink] {
  position: absolute;
  height: 40px;
  aspect-ratio: 7/5;
  background-color: var(--c_white);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 16px auto;
  border: 1px solid var(--c_blue1);
  font-size: 0 !important;
  line-height: 0 !important;
  border-radius: 100px;
  margin: 0;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@container body (max-width: 470px) {
  .wp-pagenavi .first, .wp-pagenavi .last,
.wp-pagenavi > *[class$=postslink] {
    height: min(40 / var(--vp) * var(--vw), 40px);
    background-size: min(16 / var(--vp) * var(--vw), 16px) auto;
  }
}
.wp-pagenavi .first:hover, .wp-pagenavi .last:hover,
.wp-pagenavi > *[class$=postslink]:hover {
  --c_white: #DFECF9;
}
.wp-pagenavi .first, .wp-pagenavi .last {
  background-image: url(../img/pager02.svg);
}
.wp-pagenavi > *[class$=postslink] {
  background-image: url(../img/pager01.svg);
  --postlink: 86px;
}
@container body (max-width: 470px) {
  .wp-pagenavi > *[class$=postslink] {
    --postlink: min(calc(72 / var(--vp) * var(--vw)), 86px);
  }
}
.wp-pagenavi .first,
.wp-pagenavi .previouspostslink {
  transform: rotate(-180deg);
}
.wp-pagenavi .first {
  left: 0;
}
.wp-pagenavi .previouspostslink {
  left: var(--postlink);
}
.wp-pagenavi .last {
  right: 0;
}
.wp-pagenavi .nextpostslink {
  right: var(--postlink);
}
.wp-pagenavi .pages {
  display: flex;
  align-items: center;
  height: 40px;
  font-family: "Montserrat", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-weight: 400;
  letter-spacing: calc(100em / 1000);
  font-size: 1.25rem;
}
@media screen and (max-width: 767px) {
  .wp-pagenavi .pages {
    font-size: 1rem;
  }
}
@container body (max-width: 470px) {
  .wp-pagenavi .pages {
    height: min(40 / var(--vp) * var(--vw), 40px);
  }
}

/*非表示*/
.wp-pagenavi {
  /*
  //.first, .last,
  .extend ~ .extend:last-of-type,
  .smaller ~ .current ~ .larger + .larger,
  .extend + .page{
       //display: none;
     }
  */
}
.wp-pagenavi .page, .wp-pagenavi .current, .wp-pagenavi .extend {
  display: none;
}

/*== wp-block_editor ブロックエディタ ====================================================================================================*/
/*-------------------------
  共通
-------------------------*/
:root {
  --text_clor: $txt_color;
  --text_size: 18;
  --line_height: 2;
  --link_color: #008CD6;
  --quote-border_color: #BEBEBE;
  --pullquote-border_color: #BEBEBE;
}

/* ブロック以外の基本装飾 */
article .entry, .wp_editor, .block-editor-block-list__layout {
  overflow-wrap: anywhere;
  word-break: normal;
  font-size: var(--text_size);
  line-height: var(--line_height);
}
article .entry small, .wp_editor small, .block-editor-block-list__layout small {
  font-size: 87.5%;
  line-height: 1.8;
}
article .entry b, article .entry strong, .wp_editor b, .wp_editor strong, .block-editor-block-list__layout b, .block-editor-block-list__layout strong {
  font-weight: bold;
}
article .entry em, article .entry i, .wp_editor em, .wp_editor i, .block-editor-block-list__layout em, .block-editor-block-list__layout i {
  font-style: italic;
  font-weight: inherit;
}
article .entry sup, .wp_editor sup, .block-editor-block-list__layout sup {
  vertical-align: super;
}
article .entry sub, .wp_editor sub, .block-editor-block-list__layout sub {
  vertical-align: sub;
}
article .entry mark[style^=background-color], article .entry mark:not([style^="background-color:rgba(0, 0, 0, 0)"]), article .entry .has-inline-color[style^=background-color], article .entry .has-inline-color:not([style^="background-color:rgba(0, 0, 0, 0)"]), .wp_editor mark[style^=background-color], .wp_editor mark:not([style^="background-color:rgba(0, 0, 0, 0)"]), .wp_editor .has-inline-color[style^=background-color], .wp_editor .has-inline-color:not([style^="background-color:rgba(0, 0, 0, 0)"]), .block-editor-block-list__layout mark[style^=background-color], .block-editor-block-list__layout mark:not([style^="background-color:rgba(0, 0, 0, 0)"]), .block-editor-block-list__layout .has-inline-color[style^=background-color], .block-editor-block-list__layout .has-inline-color:not([style^="background-color:rgba(0, 0, 0, 0)"]) {
  padding: 0 0.25em;
}
article .entry mark[style^="background-color:rgba(0, 0, 0, 0)"], article .entry .has-inline-color[style^="background-color:rgba(0, 0, 0, 0)"], .wp_editor mark[style^="background-color:rgba(0, 0, 0, 0)"], .wp_editor .has-inline-color[style^="background-color:rgba(0, 0, 0, 0)"], .block-editor-block-list__layout mark[style^="background-color:rgba(0, 0, 0, 0)"], .block-editor-block-list__layout .has-inline-color[style^="background-color:rgba(0, 0, 0, 0)"] {
  padding: 0;
}
article .entry iframe, .wp_editor iframe, .block-editor-block-list__layout iframe {
  max-width: 100%;
}
article .entry code, .wp_editor code, .block-editor-block-list__layout code {
  color: #444;
  background-color: #e7edf3;
  border-radius: 3px;
  border: solid 1px #d6dde4;
  text-indent: 0;
  font-size: 100%;
  line-height: 2;
  padding: 1em;
}
article .entry code.memo, .wp_editor code.memo, .block-editor-block-list__layout code.memo {
  display: block;
  padding: 0.25em 1em;
}
article .entry code.red, .wp_editor code.red, .block-editor-block-list__layout code.red {
  display: block;
  background-color: #dc143c;
  border: none;
  border-radius: 0;
  color: #fff;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  article .entry code.red, .wp_editor code.red, .block-editor-block-list__layout code.red {
    font-size: 80%;
  }
}
article .entry code:not(.red):not(.memo):not(.wp-block-code code), .wp_editor code:not(.red):not(.memo):not(.wp-block-code code), .block-editor-block-list__layout code:not(.red):not(.memo):not(.wp-block-code code) {
  display: inline-block;
  padding: 0.1em 0.25em;
  line-height: 1.2;
}
article .entry .wp-block-code.red code, .wp_editor .wp-block-code.red code, .block-editor-block-list__layout .wp-block-code.red code {
  display: block;
  background: var(--c_red);
  border: none;
  border-radius: 0;
  color: #fff;
  font-weight: bold;
  text-align: center;
  padding: 0.25em 1em;
}
@media screen and (max-width: 767px) {
  article .entry .wp-block-code.red code, .wp_editor .wp-block-code.red code, .block-editor-block-list__layout .wp-block-code.red code {
    font-size: 80%;
  }
}
article .entry .wp-block-code.red code::before, .wp_editor .wp-block-code.red code::before, .block-editor-block-list__layout .wp-block-code.red code::before {
  content: "⚠️";
}
article .entry a:not([class]):not(.products_list a):not(.category_list a):not(:has(img)), .wp_editor a:not([class]):not(.products_list a):not(.category_list a):not(:has(img)), .block-editor-block-list__layout a:not([class]):not(.products_list a):not(.category_list a):not(:has(img)) {
  color: var(--link_color);
  text-decoration: underline;
  text-underline-offset: 2px;
}
article .entry a:not([class]):not(.products_list a):not(.category_list a):not(:has(img)):hover, .wp_editor a:not([class]):not(.products_list a):not(.category_list a):not(:has(img)):hover, .block-editor-block-list__layout a:not([class]):not(.products_list a):not(.category_list a):not(:has(img)):hover {
  filter: brightness(2);
}
article .entry a:not([class]):not(.products_list a):not(.category_list a):not(:has(img))[target]::after, .wp_editor a:not([class]):not(.products_list a):not(.category_list a):not(:has(img))[target]::after, .block-editor-block-list__layout a:not([class]):not(.products_list a):not(.category_list a):not(:has(img))[target]::after {
  content: "";
  background-color: currentColor;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 13'%3E%3Cpath d='M14,9H10v4H0V4H4V0H14ZM1,12H9V5H1ZM5,4h5V8h3V1H5Z'/%3E%3C/svg%3E");
  mask-repeat: no-repeat;
  mask-size: contain;
  display: inline-block;
  width: 0.875em;
  aspect-ratio: 14/13;
  margin-left: 0.25em;
  margin-right: 0.25em;
}

.js-scrollable {
  margin-left: calc(var(--spacer2) * -1);
  margin-right: calc(var(--spacer2) * -1);
}
@media screen and (min-width: 768px) {
  .js-scrollable:not(:has(.pc_scroll)):has(.sp_scroll) {
    overflow: inherit !important;
  }
}
@media screen and (max-width: 767px) {
  .js-scrollable .scroll-hint-icon {
    top: 80px;
  }
}

@media screen and (max-width: 767px) {
  .js-scrollable-inner {
    min-width: calc(860px + var(--spacer2) + var(--spacer2));
    padding: 0 var(--spacer2);
  }
}

@media screen and (min-width: 768px) {
  .js-scrollable-inner:has(.pc_scroll) {
    min-width: calc(1080px + var(--spacer2) + var(--spacer2));
    padding: 0 var(--spacer2);
  }
}

/*-------------------------
  空き
-------------------------*/
article .entry > :where(:not(:first-child)), .wp_editor > :where(:not(:first-child)), .block-editor-block-list__layout > :where(:not(:first-child)) {
  margin-top: var(--spacer);
}
article .entry > .wp-block-image:not(:last-child), .wp_editor > .wp-block-image:not(:last-child), .block-editor-block-list__layout > .wp-block-image:not(:last-child) {
  margin-bottom: 20px;
}
article .entry > .wp-block-columns:not(:last-child), .wp_editor > .wp-block-columns:not(:last-child), .block-editor-block-list__layout > .wp-block-columns:not(:last-child) {
  margin-bottom: var(--spacer);
}
article .entry .wp-block-image .wp-element-caption, .wp_editor .wp-block-image .wp-element-caption, .block-editor-block-list__layout .wp-block-image .wp-element-caption {
  margin-top: 8px;
}
@media screen and (max-width: 767px) {
  article .entry .wp-block-image .wp-element-caption, .wp_editor .wp-block-image .wp-element-caption, .block-editor-block-list__layout .wp-block-image .wp-element-caption {
    margin-top: 4px;
  }
}
article .entry .wp-block-columns > *, .wp_editor .wp-block-columns > *, .block-editor-block-list__layout .wp-block-columns > * {
  margin-bottom: 0;
}
article .entry .wp-block-column > :where(:first-child), .wp_editor .wp-block-column > :where(:first-child), .block-editor-block-list__layout .wp-block-column > :where(:first-child) {
  margin-top: 0;
}
article .entry .smb-alert:not(:last-child), .wp_editor .smb-alert:not(:last-child), .block-editor-block-list__layout .smb-alert:not(:last-child) {
  margin-bottom: var(--spacer);
}

/*-------------------------
  カラーパレット
-------------------------*/
:root {
  --wp--preset--color--very-light-gray: #eee;
  --wp--preset--color--very-dark-gray: #313131;
}

:root .has-very-light-gray-background-color {
  background-color: var(--wp--preset--color--very-light-gray);
}
:root .has-very-light-gray-color {
  color: var(--wp--preset--color--very-light-gray);
}
:root .has-very-dark-gray-background-color {
  background-color: var(--wp--preset--color--very-dark-gray);
}
:root .has-very-dark-gray-color {
  color: var(--wp--preset--color--very-dark-gray);
}

/*-------------------------
  テキスト - 段落
-------------------------*/
article .entry, .wp_editor, .block-editor-block-list__layout {
  --text-small-size: 13;
  --text-medium-size: 20;
  --text-large-size: 36;
  --text-x_large-size: 42;
  --ratio-small: var(--text-small-size) / var(--text_size);
  --ratio-medium: var(--text-medium-size) / var(--text_size);
  --ratio-large: var(--text-large-size) / var(--text_size);
  --ratio-x_large: var(--text-x_large-size) / var(--text_size);
}
@media screen and (max-width: 767px) {
  article .entry, .wp_editor, .block-editor-block-list__layout {
    --text-small-size: 13;
    --text-medium-size: 18;
    --text-large-size: 36;
    --text-x_large-size: 42;
  }
}
article .entry .has-small-font-size, .wp_editor .has-small-font-size, .block-editor-block-list__layout .has-small-font-size {
  font-size: calc(var(--text_size) * var(--ratio-small) * 1px) !important;
}
article .entry .has-medium-font-size, .wp_editor .has-medium-font-size, .block-editor-block-list__layout .has-medium-font-size {
  font-size: calc(var(--text_size) * var(--ratio-medium) * 1px) !important;
}
article .entry .has-large-font-size, .wp_editor .has-large-font-size, .block-editor-block-list__layout .has-large-font-size {
  font-size: calc(var(--text_size) * var(--ratio-large) * 1px) !important;
}
article .entry .has-x-large-font-size, .wp_editor .has-x-large-font-size, .block-editor-block-list__layout .has-x-large-font-size {
  font-size: calc(var(--text_size) * var(--ratio-x_large) * 1px) !important;
}
article .entry .wp-element-caption, .wp_editor .wp-element-caption, .block-editor-block-list__layout .wp-element-caption {
  font-size: calc(var(--text_size) * var(--ratio-small) * 1px) !important;
}

/*-------------------------
  テキスト - 見出し
-------------------------*/
.wp-block-heading {
  font-size: calc(var(--text_size) / 16 * 1rem);
  --lh_hd: 1.6;
  line-height: var(--lh_hd) !important;
  /*
  @at-root h2.wp-block-heading:not(.h3):not(.h4):not(.h5):not(.h6) {
  	//font-size: calc(40 / var(--text_size) * 100%);
  	@include h2;
  }
  @at-root h3.wp-block-heading:not(.h2):not(.h4):not(.h5):not(.h6) {
  	//font-size: calc(36 / var(--text_size) * 100%);
  	@include h3;
  }
  @at-root h4.wp-block-heading:not(.h2):not(.h3):not(.h5):not(.h6) {
  	//font-size: calc(24 / var(--text_size) * 100%);
  	@include h4;
  }
  @at-root h5.wp-block-heading:not(.h2):not(.h3):not(.h4):not(.h6) {
  	//font-size: calc(20 / var(--text_size) * 100%);
  	@include h5;
  }
  @at-root h6.wp-block-heading:not(.h2):not(.h3):not(.h4):not(.h5) {
  	//font-size: calc(16 / var(--text_size) * 100%);
  	@include h6;
  }
  //クラスを除外
  @at-root h1.wp-block-heading,h2.wp-block-heading,h3.wp-block-heading,h4.wp-block-heading,h5.wp-block-heading,h6.wp-block-heading {
  	&:not(.h2):not(.h3):not(.h4):not(.h5):not(.h6) {
  	}
  }
  //背景色が設定されたときのスタイル
  &.has-background {
  	padding: 10px;
  }
  */
}
.wp-block-heading:first-child {
  margin-top: 0;
}
.wp-block-heading:not(h3) + h3 {
  margin-top: 0;
}
.wp-block-heading:not(h4) + h4 {
  margin-top: 0;
}
.wp-block-heading:not(h5) + h5 {
  margin-top: 0;
}
.wp-block-heading:not(h6) + h6 {
  margin-top: 0;
}
.wp-block-heading:not(h4) + h4 {
  margin-top: 0;
}
.wp-block-heading:not(h5) + h5 {
  margin-top: 0;
}
.wp-block-heading:not(h6) + h6 {
  margin-top: 0;
}
.wp-block-heading:not(h5) + h5 {
  margin-top: 0;
}
.wp-block-heading:not(h6) + h6 {
  margin-top: 0;
}
.wp-block-heading:not(h6) + h6 {
  margin-top: 0;
}
.wp-block-heading + p {
  margin-top: 0;
}
h1.wp-block-heading {
  --font_size: 10;
  text-decoration: line-through;
}
h1.wp-block-heading::after {
  content: "※使わない";
  display: inline-block;
  text-decoration: none;
  margin-left: 1em;
}

/*-------------------------
  テキスト - リスト（ul , ol）
-------------------------*/
/* 追加クラス　.indent */
.wp-block-list.indent {
  list-style: none;
}
.wp-block-list.indent > li {
  padding-left: 1em;
  text-indent: -1em;
}

/*-------------------------
  テキスト - 引用
-------------------------*/
.wp-block-quote {
  box-sizing: border-box;
  overflow-wrap: break-word;
  border-left: 4px solid var(--quote-border_color);
  padding: 0.5em 1em;
}
.wp-block-quote.is-large:not(.is-style-plain), .wp-block-quote.is-style-large:not(.is-style-plain) {
  margin-bottom: 1em;
  padding: 0 1em;
}
.wp-block-quote.is-large:not(.is-style-plain) p, .wp-block-quote.is-style-large:not(.is-style-plain) p {
  font-style: italic;
}
.wp-block-quote.is-large:not(.is-style-plain) cite, .wp-block-quote.is-large:not(.is-style-plain) footer, .wp-block-quote.is-style-large:not(.is-style-plain) cite, .wp-block-quote.is-style-large:not(.is-style-plain) footer {
  text-align: right;
}

/*-------------------------
  テキスト - プルクオート
-------------------------*/
.wp-block-pullquote {
  font-size: 100%;
  border-top: 4px solid var(--pullquote-border_color);
  border-bottom: 4px solid var(--pullquote-border_color);
  line-height: inherit;
  padding: 2em 0;
  /*
  &::after {
  	content: '”';
  	margin-top: .5em;
  	text-align: right;
  }
  */
}
.wp-block-pullquote::before, .wp-block-pullquote::after {
  display: block;
  font-size: 200%;
  font-weight: bold;
  line-height: 1;
}
.wp-block-pullquote::before {
  content: "“";
  margin-bottom: 0.5em;
}

/*-------------------------
  テキスト - テーブル
-------------------------*/
article .entry table, .wp_editor table,
.block-editor-block-list__layout table,
.wp-block-flexible-table-block-table table {
  overflow: inherit;
  width: 100%;
  border-top: 1px solid #c5c5c5;
  border-left: 1px solid #c5c5c5;
  border-bottom: none;
  border-right: none;
}
article .entry table th, article .entry table td, .wp_editor table th, .wp_editor table td,
.block-editor-block-list__layout table th,
.block-editor-block-list__layout table td,
.wp-block-flexible-table-block-table table th,
.wp-block-flexible-table-block-table table td {
  border-top: none;
  border-left: none;
  border-bottom: 1px solid #c5c5c5;
  border-right: 1px solid #c5c5c5;
  line-height: 1.5;
  padding: 0.5em;
  vertical-align: top;
}
article .entry table th, .wp_editor table th,
.block-editor-block-list__layout table th,
.wp-block-flexible-table-block-table table th {
  background-color: #F3F3F3;
}
article .entry table thead th, .wp_editor table thead th,
.block-editor-block-list__layout table thead th,
.wp-block-flexible-table-block-table table thead th {
  background-color: #F3F3F3;
  text-align: left;
}
article .entry table thead th, article .entry table thead td, .wp_editor table thead th, .wp_editor table thead td,
.block-editor-block-list__layout table thead th,
.block-editor-block-list__layout table thead td,
.wp-block-flexible-table-block-table table thead th,
.wp-block-flexible-table-block-table table thead td {
  font-weight: inherit;
}
article .entry table tfoot, .wp_editor table tfoot,
.block-editor-block-list__layout table tfoot,
.wp-block-flexible-table-block-table table tfoot {
  border-top-width: 1px;
}
article .entry table tfoot th, article .entry table tfoot td, .wp_editor table tfoot th, .wp_editor table tfoot td,
.block-editor-block-list__layout table tfoot th,
.block-editor-block-list__layout table tfoot td,
.wp-block-flexible-table-block-table table tfoot th,
.wp-block-flexible-table-block-table table tfoot td {
  font-weight: inherit;
}

.wp-block-flexible-table-block-table,
.wp-block-table {
  margin: 30px 0;
}
.wp-block-flexible-table-block-table thead,
.wp-block-table thead {
  border-bottom-width: inherit !important;
}
.wp-block-flexible-table-block-table.is-style-regular,
.wp-block-table.is-style-regular {
  border-top: 1px solid #c5c5c5;
  border-left: 1px solid #c5c5c5;
}
.wp-block-flexible-table-block-table.is-style-regular th, .wp-block-flexible-table-block-table.is-style-regular td,
.wp-block-table.is-style-regular th,
.wp-block-table.is-style-regular td {
  border-bottom: 1px solid #c5c5c5;
  border-right: 1px solid #c5c5c5;
}
.wp-block-flexible-table-block-table.is-style-regular th,
.wp-block-table.is-style-regular th {
  background: #F3F3F3;
}
.wp-block-flexible-table-block-table.is-style-stripes table,
.wp-block-table.is-style-stripes table {
  border: none;
}

@media screen and (max-width: 767px) {
  .wp-block-table.sp_scroll table {
    min-width: 860px;
  }
}
@media screen and (max-width: 767px) {
  .wp-block-table.sp_scroll .scroll-hint-icon {
    top: 80px;
  }
}

.wp-block-flexible-table-block-table.is-scroll-on-pc {
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .wp-block-flexible-table-block-table.is-scroll-on-pc {
    margin-left: calc(var(--pdX) * -1);
    margin-right: calc(var(--pdX) * -1);
  }
}
.wp-block-flexible-table-block-table.is-scroll-on-pc table {
  min-width: 2000px;
}
@media screen and (max-width: 767px) {
  .wp-block-flexible-table-block-table.is-scroll-on-pc table {
    margin-left: var(--pdX);
    margin-right: var(--pdX);
  }
}

.wp-block-flexible-table-block-table.is-scroll-on-mobile {
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .wp-block-flexible-table-block-table.is-scroll-on-mobile {
    margin-left: calc(var(--pdX) * -1);
    margin-right: calc(var(--pdX) * -1);
  }
}
@media screen and (max-width: 767px) {
  .wp-block-flexible-table-block-table.is-scroll-on-mobile table {
    min-width: 860px;
    margin-left: var(--pdX);
    margin-right: var(--pdX);
  }
}

/*-------------------------
  メディア - 画像
-------------------------*/
.wp-block-image {
  overflow: hidden;
}
.wp-block-image a {
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
body:not(.view_sp) .wp-block-image a:hover {
  opacity: 0.6;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.wp-block-image img {
  margin-bottom: 0 !important;
}
.wp-block-image img.ofi {
  height: 100%;
  max-width: inherit;
}
.wp-block-image .wp-element-caption {
  margin-top: 20px;
  margin-bottom: 0;
}

/*-------------------------
  メディア - ギャラリー
-------------------------*/
.wp-block-gallery.has-nested-images {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
}
.wp-block-gallery.has-nested-images figure.wp-block-image img {
  aspect-ratio: 1/1;
}
.wp-block-gallery.has-nested-images figure.wp-block-image:has(figcaption)::before {
  background: none;
  backdrop-filter: none;
}
.wp-block-gallery.has-nested-images figure.wp-block-image:has(figcaption) .wp-element-caption {
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.3) 70%, transparent);
  text-shadow: none;
  padding: 5px 10px;
}

/*-------------------------
  メディア - メディアとテキスト
-------------------------*/
.wp-block-media-text {
  column-gap: 50px;
}
.wp-block-media-text .wp-block-media-text__content,
.wp-block-media-text .wp-block-media-text__media {
  width: auto;
  margin: 0 0 auto !important;
  padding: 0;
}
.wp-block-media-text .wp-block-media-text__media img {
  max-width: 100%;
}

.wp-block-media-text .wp-block-media-text__content,
.wp-block-media-text .wp-block-media-text__media,
.wp-block-media-text.is-vertically-aligned-center .wp-block-media-text__content,
.wp-block-media-text.is-vertically-aligned-center .wp-block-media-text__media {
  align-self: flex-start;
}

@media screen and (max-width: 767px) {
  .wp-block-media-text.is-stacked-on-mobile {
    display: block !important;
  }
}
@media screen and (max-width: 767px) {
  .wp-block-media-text.is-stacked-on-mobile > *:not(:first-child) {
    margin-top: 20px;
  }
}
.wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__content {
  padding: 0;
}
@media screen and (min-width: 768px) {
  .wp-block-media-text.is-stacked-on-mobile:not(.has-media-on-the-right) .wp-block-media-text__media {
    margin-right: 40px;
  }
}
@media screen and (min-width: 768px) {
  .wp-block-media-text.is-stacked-on-mobile.has-media-on-the-right .wp-block-media-text__media {
    margin-left: 40px;
  }
}

.wp-block-media-text.is-image-fill > .wp-block-media-text__media img {
  position: static;
  height: auto;
  width: auto;
  margin: 0;
}

/*-------------------------
  デザイン - ボタン
-------------------------*/
.wp-block-buttons {
  position: relative;
  gap: 1em 2em;
}
.wp-block-buttons.is-content-justification-center {
  margin-left: auto;
  margin-right: auto;
}
.wp-block-buttons.is-content-justification-center > *:only-child {
  margin: 0;
}
.wp-block-button {
  /*
  display: inline-flex;
  vertical-align: top;
  margin-bottom: 0 !important;
  &:only-child {
  	width: 100%;
  	margin-left: auto;
  	margin-right: auto;
  }
  &.wp-block-button__width-75 {
  	@include mq(sp) {
  		width: 100%;
  	}
  }
  */
}

/* ボタン共通要素 */
:root {
  --button-background-color: #002F7B;
  --button-border-color: #f00;
  --button-text-color: #FFFFFF;
}

.wp-block-button {
  text-align: center;
}
.wp-block-button > .wp-block-button__link {
  overflow: hidden;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  text-align: center;
}
.wp-block-button a:not([href]),
.wp-block-button a[href=""],
.wp-block-button a[href="#"],
.wp-block-button a[href=""],
.wp-block-button a[href="#"] {
  pointer-events: none;
}
.wp-block-button a[href] {
  position: relative;
  z-index: 0;
  text-decoration: none;
}

/* 塗りつぶし */
/* 輪郭 */
.wp-block-button.is-style-outline > .wp-block-button__link {
  background-color: #fff;
  color: #000;
}

/*-------------------------
  デザイン - 区切り
-------------------------*/
.wp-block-separator {
  border: none;
  border-bottom: 2px solid currentColor;
  margin-left: auto;
  margin-right: auto;
}

.wp-block-separator.is-style-dots {
  background: none !important;
  border: none;
  text-align: center;
  line-height: 1;
  height: auto;
}
.wp-block-separator.is-style-dots:before {
  content: "···";
  color: currentColor;
  font-size: 1.5em;
  letter-spacing: 2em;
  padding-left: 2em;
  font-family: serif;
}

.wp-block-separator.has-css-opacity {
  opacity: 0.4;
}

.wp-block-separator.has-alpha-channel-opacity {
  opacity: 1;
}

.wp-block-separator:not(.is-style-wide):not(.is-style-dots) {
  width: 100px;
}

.wp-block-separator.has-background:not(.is-style-dots) {
  border-bottom: none;
  height: 1px;
}

.wp-block-separator.has-background:not(.is-style-wide):not(.is-style-dots) {
  height: 2px;
}

/*-------------------------
  デザイン - 区切り
-------------------------*/
.wp-block-separator {
  border: none;
  border-bottom: 2px solid currentColor;
  margin-left: auto;
  margin-right: auto;
}

.wp-block-separator.is-style-dots {
  background: none !important;
  border: none;
  text-align: center;
  line-height: 1;
  height: auto;
}
.wp-block-separator.is-style-dots:before {
  content: "···";
  color: currentColor;
  font-size: 1.5em;
  letter-spacing: 2em;
  padding-left: 2em;
  font-family: serif;
}

.wp-block-separator.has-css-opacity {
  opacity: 0.4;
}

.wp-block-separator.has-alpha-channel-opacity {
  opacity: 1;
}

.wp-block-separator:not(.is-style-wide):not(.is-style-dots) {
  width: 100px;
}

.wp-block-separator.has-background:not(.is-style-dots) {
  border-bottom: none;
  height: 1px;
}

.wp-block-separator.has-background:not(.is-style-wide):not(.is-style-dots) {
  height: 2px;
}

/*-------------------------
  デザイン - スペーサー
-------------------------*/
[style*="var(--wp--preset--spacing--20)"].wp-block-spacer {
  height: 10px !important;
}

[style*="var(--wp--preset--spacing--30)"].wp-block-spacer {
  height: 32px !important;
}

[style*="var(--wp--preset--spacing--40)"].wp-block-spacer {
  height: 60px !important;
}
@media screen and (max-width: 767px) {
  [style*="var(--wp--preset--spacing--40)"].wp-block-spacer {
    height: 40px !important;
  }
}

[style*="var(--wp--preset--spacing--50)"].wp-block-spacer {
  height: 80px !important;
}

[style*="var(--wp--preset--spacing--60)"].wp-block-spacer {
  height: 100px !important;
}
@media screen and (max-width: 767px) {
  [style*="var(--wp--preset--spacing--60)"].wp-block-spacer {
    height: 60px !important;
  }
}

[style*="var(--wp--preset--spacing--70)"].wp-block-spacer {
  height: 120px !important;
}
@media screen and (max-width: 767px) {
  [style*="var(--wp--preset--spacing--70)"].wp-block-spacer {
    height: 80px !important;
  }
}

[style*="var(--wp--preset--spacing--80)"].wp-block-spacer {
  height: 200px !important;
}
@media screen and (max-width: 767px) {
  [style*="var(--wp--preset--spacing--80)"].wp-block-spacer {
    height: 120px !important;
  }
}

.wp-block-spacer {
  position: relative;
  margin: 0 !important;
}
.wp-block-spacer::before {
  content: "～余白～右のプリセットからサイズを選んでください";
  white-space: pre;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  display: none !important;
}

[style*="var(--wp--preset--spacing--20)"].wp-block-spacer::before {
  content: "～余白～ 10px";
}

[style*="var(--wp--preset--spacing--30)"].wp-block-spacer::before {
  content: "～余白～ 32px";
}

[style*="var(--wp--preset--spacing--40)"].wp-block-spacer::before {
  content: "～余白～ pc:60px／sp:40px";
}

[style*="var(--wp--preset--spacing--50)"].wp-block-spacer::before {
  content: "～余白～ 80px";
}

[style*="var(--wp--preset--spacing--60)"].wp-block-spacer::before {
  content: "～余白～ pc:100px／sp:60px";
}

[style*="var(--wp--preset--spacing--70)"].wp-block-spacer::before {
  content: "～余白～ pc:120px／sp:80px";
}

[style*="var(--wp--preset--spacing--80)"].wp-block-spacer::before {
  content: "～余白～ pc:200px／sp:100px";
}

/*-------------------------
  HTMLブロック
-------------------------*/
/* Google Map */
/* YouTube */
iframe[src^="https://www.youtube.com/"] {
  aspect-ratio: 16/9;
  height: inherit;
}

/*-------------------------
  YouTubeブロック
-------------------------*/
.wp-block-embed-youtube iframe {
  aspect-ratio: 16/9;
  height: inherit;
}
/*-------------------------
  その他
-------------------------*/
#end-resizable-editor-section {
  display: none;
}

.aligncenter {
  clear: both;
}

.items-justified-left {
  justify-content: flex-start;
}

.items-justified-center {
  justify-content: center;
}

.items-justified-right {
  justify-content: flex-end;
}

.items-justified-space-between {
  justify-content: space-between;
}

.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  word-wrap: normal !important;
}

.screen-reader-text:focus {
  background-color: #ddd;
  clip: auto !important;
  -webkit-clip-path: none;
  clip-path: none;
  color: #444;
  display: block;
  font-size: 100%;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
}

/*-------------------------
  共通
-------------------------*/
:root {
  --text_clor: var(--c_black);
  --text_size: 16;
  --line_height: 2;
  --link_color: #008CD6;
  --quote-border_color: #BEBEBE;
  --pullquote-border_color: #BEBEBE;
}
@media screen and (max-width: 767px) {
  :root {
    --text_size: 15;
  }
}

/* ブロック以外の基本装飾 */
article .entry, .wp_editor, .block-editor-block-list__layout {
  font-size: calc(var(--text_size) / 16 * 1rem);
}

/*-------------------------
  カラー
-------------------------*/
:root {
  --wp--preset--color--pale-cyan-blue: var(--c_blue2);
  --wp--preset--color--vivid-cyan-blue: var(--c_blue1);
}

/* ハイライト */
article .entry mark, article .entry .has-inline-color, .wp_editor mark, .wp_editor .has-inline-color,
.block-editor-block-list__layout mark,
.block-editor-block-list__layout .has-inline-color {
  /*
  font-weight: 700;
  &[style*="background-color"] {
  }
  &:not([style*="background-color:rgba(0, 0, 0, 0)"]) {
  }
  &[style*="background-color:#fcb900"],
  &[style*="background-color:rgb(252 185 0)"],
  &[style*="background-color:rgba(252 185 0, 0)"] {
  	background-color: var(--wp--preset--color--luminous-vivid-amber) !important;
  }
  */
}

/*-------------------------
  テキスト - 段落
-------------------------*/
article .entry, .wp_editor, .block-editor-block-list__layout {
  --text-medium-size: 18;
  --text-large-size: 24;
  --text-x_large-size: 28;
}
@media screen and (max-width: 767px) {
  article .entry, .wp_editor, .block-editor-block-list__layout {
    --text-medium-size: 17;
    --text-large-size: 18;
    --text-x_large-size: 20;
  }
}
@media screen and (max-width: 767px) {
  article .entry > .has-medium-font-size:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)), .wp_editor > .has-medium-font-size:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)), .block-editor-block-list__layout > .has-medium-font-size:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)) {
    line-height: 2;
  }
}
article .entry > .has-x-large-font-size:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)), .wp_editor > .has-x-large-font-size:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)), .block-editor-block-list__layout > .has-x-large-font-size:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)) {
  font-weight: 500;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  article .entry > .has-x-large-font-size:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)), .wp_editor > .has-x-large-font-size:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)), .block-editor-block-list__layout > .has-x-large-font-size:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)) {
    margin-bottom: 14px;
  }
}

/*-------------------------
  行間
-------------------------*/
article .entry, .wp_editor,
.block-editor-block-list__layout {
  line-height: 2.1;
}
@media screen and (max-width: 767px) {
  article .entry, .wp_editor,
.block-editor-block-list__layout {
    line-height: 1.875;
  }
}

/*-------------------------
  空き
-------------------------*/
article .entry > *:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)), .wp_editor > *:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)), .block-editor-block-list__layout > *:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)) {
  margin-bottom: 38px;
}
@media screen and (max-width: 767px) {
  article .entry > *:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)), .wp_editor > *:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)), .block-editor-block-list__layout > *:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)) {
    margin-bottom: 29px;
  }
}
article .entry > *:has(+ #toc_container), .wp_editor > *:has(+ #toc_container), .block-editor-block-list__layout > *:has(+ #toc_container) {
  margin-bottom: 0;
}

article .entry > p:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)):has(+ ul), .wp_editor > p:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)):has(+ ul), .block-editor-block-list__layout > p:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)):has(+ ul) {
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  article .entry > p:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)):has(+ ul), .wp_editor > p:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)):has(+ ul), .block-editor-block-list__layout > p:not(:last-child):not(li):not(.wp-block-flexible-table-block-table):not(.wp-block-heading):not(:has(+ #toc_container)):has(+ ul) {
    margin-bottom: 6px;
  }
}

/*-------------------------
  見出し
-------------------------*/
h2.wp-block-heading {
  border-bottom: 1px solid var(--c_gray1);
  color: var(--c_blue1);
  --text_size: 20;
  font-weight: 700;
  padding-bottom: 14px;
  margin-top: 113px;
  margin-bottom: 44px;
}
@media screen and (max-width: 767px) {
  h2.wp-block-heading {
    margin-top: 80px;
    margin-bottom: 24px;
  }
}
h2.wp-block-heading.has-text-color {
  color: var(--c_blue1) !important;
}
h2.wp-block-heading.has-background {
  background-color: transparent !important;
}

h3.wp-block-heading {
  --text_size: 17;
  font-weight: 700;
  margin-top: 47px;
  margin-bottom: 11px;
}
h4.wp-block-heading {
  --text_size: 15;
  font-weight: 700;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  h4.wp-block-heading {
    --text_size: 10;
  }
}
h5.wp-block-heading {
  --text_size: 14;
  font-weight: 700;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  h5.wp-block-heading {
    --text_size: 10;
  }
}
h6.wp-block-heading {
  --text_size: 12;
  font-weight: 700;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  h6.wp-block-heading {
    --text_size: 10;
  }
}
.wp-block-heading.has-background {
  padding: 10px;
}

/*-------------------------
  テキスト - リスト（ul , ol）
-------------------------*/
.wp-block-list {
  padding-left: 8px;
  line-height: 1.5;
}
.wp-block-list * + * {
  margin-top: 0.8em;
}
.wp-block-list li {
  list-style: inherit;
  list-style: none;
  position: relative;
  padding-left: 16px;
}
.wp-block-list li .wp-block-list {
  margin-top: 0.5em;
  margin-left: 1em;
}
.wp-block-list li::before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  background-color: var(--c_blue2);
  border-radius: 50%;
  position: absolute;
  top: 12px;
  left: 0;
  translate: 0 -50%;
}
.wp-block-list.has-background {
  padding: 20px 20px 20px 42px;
}

/* 追加クラス　.none */
.wp-block-list.none li {
  list-style: none;
}

/* 追加クラス　.num1 */
.wp-block-list.num1 li {
  position: relative;
  list-style-type: none;
  counter-increment: number_1;
}
.wp-block-list.num1 li:before {
  content: "(" counter(number_1) ") ";
}

/*-------------------------
  テーブル
-------------------------*/
/*-------------------------
  ボタン
-------------------------*/
.wp-block-buttons {
  margin-top: 38px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.wp-block-button > .wp-block-button__link {
  min-width: 256px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-height: var(--h);
  background: var(--c_white);
  border-radius: var(--bdrs);
  border: 1px solid var(--bdc);
  color: var(--fc);
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.5;
  text-align: center;
  padding: 0.5em 2.5em;
  position: relative;
  z-index: 1;
  --h: 48px;
  --bdrs: 100px;
  --bdc: var(--c_blue1);
  --fc: var(--c_blue1);
  cursor: pointer;
}
.wp-block-button > .wp-block-button__link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 23px;
  width: 14px;
  aspect-ratio: 1/1;
  mask: url(../img/arrow01.svg);
  mask-size: cover;
  background-color: currentColor;
  transform: translate(0, -50%);
}
.wp-block-button > .wp-block-button__link::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #DFECF9;
  transform-origin: 100% 50%;
  transform: scaleX(0);
  transition: var(--ts);
}
.wp-block-button > .wp-block-button__link:hover::before {
  transform-origin: 0% 50%;
  transform: scaleX(1);
}
/*-------------------------
  デザイン - スペーサー
-------------------------*/
[style*="var(--wp--preset--spacing--20)"].wp-block-spacer {
  height: 10px !important;
}

[style*="var(--wp--preset--spacing--30)"].wp-block-spacer {
  height: 32px !important;
}

[style*="var(--wp--preset--spacing--40)"].wp-block-spacer {
  height: 60px !important;
}
@media screen and (max-width: 767px) {
  [style*="var(--wp--preset--spacing--40)"].wp-block-spacer {
    height: 40px !important;
  }
}

[style*="var(--wp--preset--spacing--50)"].wp-block-spacer {
  height: 80px !important;
}

[style*="var(--wp--preset--spacing--60)"].wp-block-spacer {
  height: 100px !important;
}
@media screen and (max-width: 767px) {
  [style*="var(--wp--preset--spacing--60)"].wp-block-spacer {
    height: 60px !important;
  }
}

[style*="var(--wp--preset--spacing--70)"].wp-block-spacer {
  height: 120px !important;
}
@media screen and (max-width: 767px) {
  [style*="var(--wp--preset--spacing--70)"].wp-block-spacer {
    height: 80px !important;
  }
}

[style*="var(--wp--preset--spacing--80)"].wp-block-spacer {
  height: 200px !important;
}
@media screen and (max-width: 767px) {
  [style*="var(--wp--preset--spacing--80)"].wp-block-spacer {
    height: 120px !important;
  }
}

.wp-block-spacer {
  position: relative;
  margin: 0 !important;
}
.wp-block-spacer::before {
  content: "～余白～右のプリセットからサイズを選んでください";
  white-space: pre;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  display: none !important;
}

[style*="var(--wp--preset--spacing--20)"].wp-block-spacer::before {
  content: "～余白～ 10px";
}

[style*="var(--wp--preset--spacing--30)"].wp-block-spacer::before {
  content: "～余白～ 32px";
}

[style*="var(--wp--preset--spacing--40)"].wp-block-spacer::before {
  content: "～余白～ pc:60px／sp:40px";
}

[style*="var(--wp--preset--spacing--50)"].wp-block-spacer::before {
  content: "～余白～ 80px";
}

[style*="var(--wp--preset--spacing--60)"].wp-block-spacer::before {
  content: "～余白～ pc:100px／sp:60px";
}

[style*="var(--wp--preset--spacing--70)"].wp-block-spacer::before {
  content: "～余白～ pc:120px／sp:80px";
}

[style*="var(--wp--preset--spacing--80)"].wp-block-spacer::before {
  content: "～余白～ pc:200px／sp:100px";
}

.wp-block-image {
  border-radius: 0 120px 0 0;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .wp-block-image {
    border-radius: 0 64px 0 0;
  }
}

@media screen and (max-width: 767px) {
  .wp-block-group {
    flex-direction: column;
  }
}
.wp-block-group .wp-block-image {
  flex: 0 0 50%;
}
@media screen and (max-width: 767px) {
  .wp-block-group .wp-block-image {
    flex: 0 0 100%;
  }
}

/*
::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

	PAGE

::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
*/
/*== 404 ====================================================================================================*/
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ プロジェクト - 一覧
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#page_404 {
  padding: 76px var(--pdX) 0;
}
@media screen and (max-width: 767px) {
  #page_404 {
    padding-top: 45px;
  }
}
#page_404 .hd.main_title {
  margin-bottom: 120px;
}
@container body (max-width: 1023px) {
  #page_404 .hd.main_title {
    --vp: 10.23;
    font-size: min(88 / var(--vp) * var(--vw), 88px);
  }
}
@media screen and (max-width: 767px) {
  #page_404 .hd.main_title {
    --vp: 3.90;
    font-size: min(34 / var(--vp) * var(--vw), 34px);
    margin-bottom: 40px;
  }
}
#page_404 #sec_404 {
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0;
}
@media screen and (max-width: 767px) {
  #page_404 #sec_404 {
    max-width: none;
  }
}
#page_404 .p_txt2 {
  font-weight: 500;
}
#page_404 .btns {
  margin-top: 48px;
}
@media screen and (max-width: 767px) {
  #page_404 .btns {
    text-align: center;
  }
}

/*== blk-project ====================================================================================================*/
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ プロジェクト情報ブロック
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.blk_project {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

/*-------------------------
  画像
-------------------------*/
.blk_project {
  background: #444;
}
@media screen and (min-width: 768px) {
  .blk_project #image_slider {
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
}
.blk_project .splide__track {
  width: 100%;
  height: 100%;
}
.blk_project .splide__slide {
  width: 100%;
  height: 100%;
}
.blk_project figure {
  display: block;
  line-height: 100%;
  width: 100%;
  height: 100%;
}
.blk_project .img {
  overflow: hidden;
  display: block;
  font-size: 0;
  line-height: 0;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .blk_project .img {
    aspect-ratio: 39/27;
  }
}
.blk_project .img > * {
  display: flex;
  align-items: end;
  line-height: 100%;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
}
.blk_project figcaption {
  color: var(--c_gray4);
  position: absolute;
  top: 0;
  right: 0;
  font-size: 0.875rem;
  line-height: 1.5;
  padding: 20px;
}
@media screen and (max-width: 767px) {
  .blk_project figcaption {
    font-size: 0.625rem;
    padding: 10px;
  }
}

/*-------------------------
  詳細情報
-------------------------*/
.blk_project {
  margin: 0 auto;
}
.blk_project .detail_wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: calc(700 / var(--vp) * var(--vw));
  min-height: 735px;
  background-color: rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(20px);
  color: var(--c_gray3);
  padding: 110px calc(96 / var(--vp) * var(--vw));
}
@container contents (max-width: 1280px) {
  .blk_project .detail_wrap {
    padding-left: var(--pdX);
    padding-right: var(--pdX);
  }
}
@media screen and (max-width: 767px) {
  .blk_project .detail_wrap {
    display: block;
    width: auto;
    min-height: inherit;
    background: var(--c_black);
    padding-top: 40px;
    padding-bottom: 48px;
  }
}
.blk_project .project_name {
  font-weight: 500;
  line-height: 1.5;
}
@container contents (max-width: 1280px) {
  .blk_project .project_name {
    font-size: 1.375rem;
  }
}
.blk_project .project_name.icon span:first-letter {
  color: inherit;
}
.blk_project .project_name.icon span::after {
  top: -25px;
  right: -33px;
  width: 30px;
}
@container contents (max-width: 1280px) {
  .blk_project .project_name.icon span::after {
    width: 21px;
    top: -16px;
    right: -24px;
  }
}
@media screen and (max-width: 767px) {
  .blk_project .project_name.icon span::after {
    display: none;
  }
}
.blk_project .project_sub_txt {
  color: rgba(255, 255, 255, 0.6);
  font-size: 1.125rem;
  line-height: 1.5;
  margin-top: 8px;
}
@container contents (max-width: 1280px) {
  .blk_project .project_sub_txt {
    font-size: 1rem;
    margin-top: 5px;
  }
}
.blk_project .project_txt {
  line-height: 2;
  margin: 43px 0 0;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 6;
}
@container contents (max-width: 1280px) {
  .blk_project .project_txt {
    font-size: 0.9375rem;
    line-height: 1.9333333333;
    margin-top: 20px;
  }
}
.blk_project .project_caption {
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.5;
  margin-top: 44px;
}
@container contents (max-width: 1280px) {
  .blk_project .project_caption {
    margin-top: 20px;
  }
}
.blk_project .btns:has(.text_link) {
  margin-top: 58px;
}
@media screen and (max-width: 767px) {
  .blk_project .btns:has(.text_link) {
    margin-top: 40px;
  }
}
.blk_project .btns .text_link {
  color: var(--c_white);
}
.blk_project .btns .text_link:hover {
  color: var(--c_blue3);
}

/*== toppage ====================================================================================================*/
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ トップページ
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#page_toppage font:empty + br {
  display: none;
}
@media screen and (max-width: 767px) {
  #page_toppage .hd.row_title {
    row-gap: 0.25em;
  }
}
#page_toppage .hd.row_title .jp {
  color: var(--c_blue1);
}
@media screen and (min-width: 768px) {
  html:not([lang=en]) #page_toppage .hd.row_title .jp {
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 768px) {
  #page_toppage + #c-contact {
    margin-top: 160px;
  }
}
@media screen and (max-width: 767px) {
  #page_toppage + #c-contact {
    margin-top: 40px;
  }
}

/*-------------------------
  メインビジュアル
-------------------------*/
#top_mainVisual {
  display: grid;
}
@media screen and (min-width: 768px) {
  #top_mainVisual {
    gap: 8px;
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(4, 1fr);
    padding: 0 calc(40 / var(--vp) * var(--vw));
  }
  #top_mainVisual .text {
    grid-area: 2/2/4/4;
  }
  #top_mainVisual .img01 {
    grid-area: 1/4/4/7;
  }
  #top_mainVisual .img02 {
    grid-area: 1/1/2/2;
  }
  #top_mainVisual .img03 {
    grid-area: 1/2/2/3;
  }
  #top_mainVisual .img04 {
    grid-area: 1/3/2/4;
  }
  #top_mainVisual .img05 {
    grid-area: 2/1/3/2;
  }
  #top_mainVisual .img06 {
    grid-area: 3/1/4/2;
  }
  #top_mainVisual .img07 {
    grid-area: 4/1/5/2;
  }
  #top_mainVisual .img08 {
    grid-area: 4/2/5/3;
  }
  #top_mainVisual .img09 {
    grid-area: 4/3/5/4;
  }
  #top_mainVisual .img10 {
    grid-area: 4/4/5/5;
  }
  #top_mainVisual .img11 {
    grid-area: 4/5/5/6;
  }
  #top_mainVisual .img12 {
    grid-area: 4/6/5/7;
  }
}
@media screen and (max-width: 767px) {
  #top_mainVisual {
    gap: 3px;
    padding: 3px 12px 12px;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: max-content max-content max-content max-content max-content 1fr;
  }
  #top_mainVisual .text {
    grid-area: 3/2/5/4;
  }
  #top_mainVisual .img01 {
    grid-area: 1/2/3/4;
  }
  #top_mainVisual .img02 {
    grid-area: 5/3/6/4;
  }
  #top_mainVisual .img03 {
    grid-area: 4/1/5/2;
  }
  #top_mainVisual .img04 {
    grid-area: 2/1/3/2;
  }
  #top_mainVisual .img05 {
    grid-area: 5/1/6/2;
  }
  #top_mainVisual .img06 {
    display: none !important;
  }
  #top_mainVisual .img07 {
    display: none !important;
  }
  #top_mainVisual .img08 {
    grid-area: 5/2/6/3;
  }
  #top_mainVisual .img09 {
    display: none !important;
  }
  #top_mainVisual .img10 {
    display: none !important;
  }
  #top_mainVisual .img11 {
    grid-area: 3/1/4/2;
  }
  #top_mainVisual .img12 {
    grid-area: 1/1/2/2;
  }
}
#top_mainVisual .text {
  display: flex;
  justify-content: center;
  color: var(--c_blue1);
  padding: calc(60 / var(--vp) * var(--vw)) 0 0 calc(10 / var(--vp) * var(--vw));
}
@media screen and (max-width: 767px) {
  #top_mainVisual .text {
    align-items: center;
    padding: calc(5 / var(--vp) * var(--vw)) calc(21 / var(--vp) * var(--vw)) 0;
  }
}
#top_mainVisual .text .jp {
  max-width: calc(446 / var(--vp) * var(--vw));
  position: relative;
  font-size: calc(54 / var(--vp) * var(--vw));
  line-height: 1.37;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  #top_mainVisual .text .jp {
    font-size: calc(24 / var(--vp) * var(--vw));
    line-height: 1.333;
    letter-spacing: 0.05em;
  }
}
@media screen and (min-width: 768px) {
  html[lang=en] #top_mainVisual .text .jp {
    max-width: calc(500 / var(--vp) * var(--vw));
    font-size: calc(46 / var(--vp) * var(--vw));
  }
}
@media screen and (max-width: 767px) {
  html[lang=en] #top_mainVisual .text .jp {
    font-size: calc(20 / var(--vp) * var(--vw));
  }
}
@media screen and (max-width: 767px) {
  html[lang=zh-CN] #top_mainVisual .text .jp, html[lang=zh-TW] #top_mainVisual .text .jp {
    font-size: 1.375rem;
  }
}
html[lang=zh-CN] #top_mainVisual .text .jp > font:first-of-type, html[lang=zh-TW] #top_mainVisual .text .jp > font:first-of-type {
  display: inline-block;
  padding-right: 1em;
}
#top_mainVisual .text .jp::after {
  content: "";
  position: absolute;
  top: calc(-26 / var(--vp) * var(--vw));
  right: calc(62 / var(--vp) * var(--vw));
  width: calc(37 / var(--vp) * var(--vw));
  --ts_num: 2px;
  aspect-ratio: 23/39;
  background: url("../img/icon-lightning.svg") no-repeat left top;
  animation: lightning 5s ease-out infinite;
  animation-delay: 2s;
  transform: rotate(0) translate(0, 0);
}
@media screen and (max-width: 767px) {
  #top_mainVisual .text .jp::after {
    top: calc(-11 / var(--vp) * var(--vw));
    right: calc(26 / var(--vp) * var(--vw));
    width: calc(19 / var(--vp) * var(--vw));
  }
}
@media screen and (min-width: 768px) {
  html[lang=en] #top_mainVisual .text .jp::after {
    right: 0;
  }
}
@media screen and (max-width: 767px) {
  html[lang=en] #top_mainVisual .text .jp::after {
    right: calc(-13 / var(--vp) * var(--vw));
  }
}
@media screen and (min-width: 768px) {
  html[lang=zh-CN] #top_mainVisual .text .jp::after, html[lang=zh-TW] #top_mainVisual .text .jp::after {
    right: 0;
  }
}
@media screen and (max-width: 767px) {
  html[lang=zh-CN] #top_mainVisual .text .jp::after, html[lang=zh-TW] #top_mainVisual .text .jp::after {
    right: calc(10 / var(--vp) * var(--vw));
  }
}
@media screen and (min-width: 768px) {
  html[lang=ko] #top_mainVisual .text .jp::after {
    right: calc(170 / var(--vp) * var(--vw));
  }
}
@media screen and (max-width: 767px) {
  html[lang=ko] #top_mainVisual .text .jp::after {
    right: calc(70 / var(--vp) * var(--vw));
  }
}
#top_mainVisual .text .jp span {
  color: var(--c_blue2);
}
html[lang=en] #top_mainVisual .text .jp br {
  display: none;
}
#top_mainVisual .text .en {
  font-size: calc(24 / var(--vp) * var(--vw));
  font-weight: 600;
  letter-spacing: 0.015em;
  line-height: 1.375;
  margin-top: calc(10 / var(--vp) * var(--vw));
}
@media screen and (max-width: 767px) {
  #top_mainVisual .text .en {
    font-size: calc(16 / var(--vp) * var(--vw));
    font-weight: 500;
    margin-top: calc(4 / var(--vp) * var(--vw));
  }
}
html[lang=en] #top_mainVisual .text .en {
  display: none;
}
#top_mainVisual .text .en > span {
  display: inline-block;
}
#top_mainVisual .text .en > span:nth-of-type(odd):first-letter {
  color: #6DADD9;
}
#top_mainVisual .text .en > span:nth-of-type(even):first-letter {
  color: #55CEBE;
}
#top_mainVisual .img {
  overflow: hidden;
  display: block;
}
@media screen and (min-width: 768px) {
  #top_mainVisual .img {
    --bdrs: min(calc(120 / var(--vp) * var(--vw)), 120px);
    aspect-ratio: 75/57;
  }
}
@media screen and (max-width: 767px) {
  #top_mainVisual .img {
    --bdrs: min(calc(30 / var(--vp) * var(--vw)), 30px);
  }
}
#top_mainVisual .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
}
#top_mainVisual .img video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
}
#top_mainVisual .img01 {
  border-radius: 0px calc(var(--bdrs) * 2) 0px var(--bdrs);
}
#top_mainVisual .img02 {
  border-radius: var(--bdrs) 0px 0px 0px;
}
@media screen and (max-width: 767px) {
  #top_mainVisual .img02 {
    border-radius: 0px var(--bdrs);
  }
}
#top_mainVisual .img03 {
  border-radius: var(--bdrs) 0px;
}
@media screen and (max-width: 767px) {
  #top_mainVisual .img03 {
    --bdrs: min(calc(40 / var(--vp) * var(--vw)), 40px);
  }
}
#top_mainVisual .img04 {
  border-radius: 0px var(--bdrs);
}
@media screen and (max-width: 767px) {
  #top_mainVisual .img04 {
    aspect-ratio: 3/2;
    border-radius: 0px 0px var(--bdrs) 0px;
  }
}
#top_mainVisual .img05 {
  border-radius: 0px var(--bdrs) 0px 0px;
}
#top_mainVisual .img06 {
  border-radius: var(--bdrs) 0px 0px 0px;
}
#top_mainVisual .img07 {
  border-radius: 0px 0px 0px var(--bdrs);
}
#top_mainVisual .img08 {
  border-radius: var(--bdrs) 0px;
}
#top_mainVisual .img09 {
  border-radius: 0px var(--bdrs);
}
#top_mainVisual .img10 {
  border-radius: var(--bdrs) 0px 0px 0px;
}
#top_mainVisual .img11 {
  border-radius: var(--bdrs) 0px;
}
@media screen and (max-width: 767px) {
  #top_mainVisual .img11 {
    --bdrs: min(calc(40 / var(--vp) * var(--vw)), 40px);
    border-radius: 0px var(--bdrs);
  }
}
#top_mainVisual .img12 {
  border-radius: 0px var(--bdrs) 0px 0px;
}
@media screen and (max-width: 767px) {
  #top_mainVisual .img12 {
    aspect-ratio: 3/2;
    --bdrs: min(calc(48 / var(--vp) * var(--vw)), 48px);
    border-radius: var(--bdrs) 0px 0px 0px;
  }
}

/* アニメーション */
#top_mainVisual:not(.zoom):not(.random) .text, #top_mainVisual:not(.zoom):not(.random) .img {
  filter: blur(5px);
  animation: slide_in 0.4s 0s forwards;
  transition: all 0.4s cubic-bezier(0.77, 0, 0.175, 1);
  opacity: 0;
  transform: translateX(-10px);
}
@media screen and (min-width: 768px) {
  #top_mainVisual:not(.zoom):not(.random) .img07 {
    animation-delay: 0.5s;
  }
  #top_mainVisual:not(.zoom):not(.random) .img06, #top_mainVisual:not(.zoom):not(.random) .img08 {
    animation-delay: 0.6s;
  }
  #top_mainVisual:not(.zoom):not(.random) .img05, #top_mainVisual:not(.zoom):not(.random) .img09 {
    animation-delay: 0.65s;
  }
  #top_mainVisual:not(.zoom):not(.random) .img02, #top_mainVisual:not(.zoom):not(.random) .text, #top_mainVisual:not(.zoom):not(.random) .img10 {
    animation-delay: 0.7s;
  }
  #top_mainVisual:not(.zoom):not(.random) .img03, #top_mainVisual:not(.zoom):not(.random) .img11 {
    animation-delay: 0.75s;
  }
  #top_mainVisual:not(.zoom):not(.random) .img04, #top_mainVisual:not(.zoom):not(.random) .img01, #top_mainVisual:not(.zoom):not(.random) .img12 {
    animation-delay: 0.775s;
  }
  #top_mainVisual:not(.zoom):not(.random) .text {
    animation-delay: 0.8s;
  }
}
@media screen and (max-width: 767px) {
  #top_mainVisual:not(.zoom):not(.random) .img12 {
    animation-delay: 0.5s;
  }
  #top_mainVisual:not(.zoom):not(.random) .img04, #top_mainVisual:not(.zoom):not(.random) .img01 {
    animation-delay: 0.6s;
  }
  #top_mainVisual:not(.zoom):not(.random) .img11 {
    animation-delay: 0.65s;
  }
  #top_mainVisual:not(.zoom):not(.random) .img03 {
    animation-delay: 0.7s;
  }
  #top_mainVisual:not(.zoom):not(.random) .img05, #top_mainVisual:not(.zoom):not(.random) .img08, #top_mainVisual:not(.zoom):not(.random) .img02 {
    animation-delay: 0.75s;
  }
  #top_mainVisual:not(.zoom):not(.random) .text {
    animation-delay: 0.7s;
  }
}

@keyframes slide_in {
  0% {
    filter: blur(5px);
    opacity: 0;
    transform: translateX(-10px);
  }
  100% {
    filter: blur(0);
    opacity: 1;
    transform: translateX(0);
  }
}
/* アニメーション ズームイン版 */
#top_mainVisual.zoom .img {
  animation: zoom_in 0.4s 0s forwards;
  transition: all 0.4s cubic-bezier(0.77, 0, 0.175, 1);
  opacity: 0;
  transform: scale(0.95);
  transform-origin: left bottom;
}
#top_mainVisual.zoom .text {
  animation: slide_in 0.4s 0s forwards;
  transition: all 0.4s cubic-bezier(0.77, 0, 0.175, 1);
  opacity: 0;
  transform: translateX(-10px);
}
@media screen and (min-width: 768px) {
  #top_mainVisual.zoom .img07 {
    animation-delay: 0.5s;
  }
  #top_mainVisual.zoom .img06, #top_mainVisual.zoom .img08 {
    animation-delay: 0.6s;
  }
  #top_mainVisual.zoom .img05, #top_mainVisual.zoom .img09 {
    animation-delay: 0.65s;
  }
  #top_mainVisual.zoom .img02, #top_mainVisual.zoom .text, #top_mainVisual.zoom .img10 {
    animation-delay: 0.7s;
  }
  #top_mainVisual.zoom .img03, #top_mainVisual.zoom .img11 {
    animation-delay: 0.75s;
  }
  #top_mainVisual.zoom .img04, #top_mainVisual.zoom .img01, #top_mainVisual.zoom .img12 {
    animation-delay: 0.775s;
  }
  #top_mainVisual.zoom .text {
    animation-delay: 0.8s;
  }
}
@media screen and (max-width: 767px) {
  #top_mainVisual.zoom .img12 {
    animation-delay: 0.5s;
  }
  #top_mainVisual.zoom .img04, #top_mainVisual.zoom .img01 {
    animation-delay: 0.6s;
  }
  #top_mainVisual.zoom .img11 {
    animation-delay: 0.65s;
  }
  #top_mainVisual.zoom .img03 {
    animation-delay: 0.7s;
  }
  #top_mainVisual.zoom .img05, #top_mainVisual.zoom .img08, #top_mainVisual.zoom .img02 {
    animation-delay: 0.75s;
  }
  #top_mainVisual.zoom .text {
    animation-delay: 0.7s;
  }
}

@keyframes zoom_in {
  0% {
    opacity: 0;
    transform: scale(0.95);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
/* アニメーション ランダム版 */
@keyframes zoom_in_bounce {
  0% {
    filter: blur(1rem);
    opacity: 0;
    transform: scale(0.9);
  }
  100% {
    filter: blur(0);
    opacity: 1;
    transform: scale(1);
  }
}
#top_mainVisual.random .img {
  animation: zoom_in_bounce 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
  opacity: 0;
  filter: blur(1rem);
  transform: scale(0.9);
}
#top_mainVisual.random .text {
  animation: zoom_in_bounce 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
  opacity: 0;
  transform: translateX(-10px);
}
@media screen and (min-width: 768px) {
  #top_mainVisual.random .img02, #top_mainVisual.random .img12 {
    animation-delay: 0.5s;
  }
  #top_mainVisual.random .img05 {
    animation-delay: 0.6s;
  }
  #top_mainVisual.random .img07, #top_mainVisual.random .img03 {
    animation-delay: 0.65s;
  }
  #top_mainVisual.random .img04 {
    animation-delay: 0.7s;
  }
  #top_mainVisual.random .img09, #top_mainVisual.random .img06 {
    animation-delay: 0.75s;
  }
  #top_mainVisual.random .img08 {
    animation-delay: 0.775s;
  }
  #top_mainVisual.random .img10, #top_mainVisual.random .img11 {
    animation-delay: 0.8s;
  }
  #top_mainVisual.random .text, #top_mainVisual.random .img01 {
    animation-delay: 0.2s;
  }
}
@media screen and (max-width: 767px) {
  #top_mainVisual.random .img12 {
    animation-delay: 0.5s;
  }
  #top_mainVisual.random .img04, #top_mainVisual.random .img01 {
    animation-delay: 0.6s;
  }
  #top_mainVisual.random .img11 {
    animation-delay: 0.65s;
  }
  #top_mainVisual.random .img03 {
    animation-delay: 0.7s;
  }
  #top_mainVisual.random .img05, #top_mainVisual.random .img08, #top_mainVisual.random .img02 {
    animation-delay: 0.75s;
  }
  #top_mainVisual.random .text {
    animation-delay: 0.7s;
  }
}

/*-------------------------
  導入
-------------------------*/
#top_about {
  padding: 0 var(--pdX);
  margin-top: min(178 / var(--vp) * var(--vw), 178px);
  margin-bottom: min(160 / var(--vp) * var(--vw), 160px);
}
@container contents (max-width: 1023px) {
  #top_about {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  #top_about {
    margin-top: 18px;
    margin-bottom: 38px;
  }
}
#top_about .innerWrap {
  display: grid;
  grid-template-columns: 1fr max-content;
  grid-template-rows: max-content max-content 1fr;
  column-gap: min(101 / var(--vp) * var(--vw), 1001px);
  max-width: 1446px;
  padding-left: 3px;
}
@container contents (max-width: 1280px) {
  #top_about .innerWrap {
    grid-template-columns: repeat(1, 1fr);
    column-gap: min(80 / var(--vp) * var(--vw), 80px);
  }
}
@media screen and (max-width: 767px) {
  #top_about .innerWrap {
    padding-left: 0;
  }
}
@media screen and (min-width: 768px) {
  #top_about .innerWrap {
    --vp: 15.58;
  }
  @container contents (max-width: 1280px) {
    #top_about .innerWrap {
      --vp: 12.80;
    }
  }
}
@container contents (min-width: 1024px) {
  #top_about .innerWrap > .p_txt1 {
    grid-area: 1/1/2/2;
  }
  #top_about .innerWrap > .p_txt2 {
    grid-area: 2/1/3/2;
  }
  #top_about .innerWrap > .deta {
    grid-area: 3/1/4/2;
  }
  #top_about .innerWrap > .img {
    grid-area: 1/2/4/3;
  }
}
#top_about .p_txt1 {
  color: var(--c_blue1);
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  #top_about .p_txt1 {
    margin-top: 19px;
    margin-bottom: 31px;
  }
}
@media screen and (max-width: 767px) {
  #top_about .p_txt1 {
    line-height: 1.599;
    margin-bottom: 14px;
  }
}
#top_about .p_txt2 {
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  #top_about .p_txt2 {
    font-size: 1rem;
    line-height: 2;
    font-weight: 500;
  }
}
@container contents (max-width: 1280px) {
  #top_about .p_txt2 br.pc {
    display: none;
  }
}
#top_about .deta {
  max-width: 672px;
  color: var(--c_blue1);
  margin-top: 57px;
}
@container contents (max-width: 1023px) {
  #top_about .deta {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (max-width: 767px) {
  #top_about .deta {
    max-width: inherit;
    margin-top: 26px;
  }
}
#top_about .deta dl {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  font-weight: 600;
  text-align: center;
}
@container contents (min-width: 1024px) {
  @container contents (max-width: 1280px) {
    #top_about .deta dl {
      grid-template-columns: repeat(1, 1fr);
    }
  }
}
@media screen and (max-width: 767px) {
  #top_about .deta dl {
    gap: 12px;
  }
}
@media print, screen and (max-width: 560px) {
  #top_about .deta dl {
    grid-template-columns: repeat(1, 1fr);
  }
}
#top_about .deta dl > div {
  border-radius: 6px;
  border: 1px solid var(--c_blue1);
  padding: 19px;
}
@media screen and (max-width: 767px) {
  #top_about .deta dl > div {
    padding-top: 16px;
  }
}
#top_about .deta dt {
  line-height: 1.375;
  margin-bottom: 8px;
}
@media screen and (max-width: 767px) {
  #top_about .deta dt {
    font-size: 0.9375rem;
    line-height: 1.466;
  }
}
#top_about .deta dd {
  font-size: 1.75rem;
}
#top_about .deta strong {
  color: var(--c_blue2);
  font-size: 3.5rem;
  font-weight: 600;
  margin-right: 0.1em;
}
@media screen and (max-width: 767px) {
  #top_about .deta strong {
    font-size: 3rem;
    letter-spacing: 0;
  }
}
#top_about .deta small {
  font-size: 1.25rem;
}
#top_about .deta sup {
  font-size: 1rem;
  vertical-align: inherit;
}
html[lang=jp] #top_about .deta sup {
  vertical-align: super;
}
#top_about .deta .notice {
  font-size: 0.875rem;
  line-height: 1.375;
  margin-top: 9px;
}
@media screen and (max-width: 767px) {
  #top_about .deta .notice {
    font-size: 0.8125rem;
    margin-top: 8px;
  }
}
#top_about .img {
  display: block;
  width: 622px;
}
@container contents (max-width: 1280px) {
  #top_about .img {
    width: min(622 / var(--vp) * var(--vw), 622px);
  }
}
@container contents (max-width: 1023px) {
  #top_about .img {
    margin: 32px auto 0;
  }
}
@media screen and (max-width: 767px) {
  #top_about .img {
    padding: 0 calc(12 / var(--vp) * var(--vw));
    max-width: inherit;
    width: auto;
    text-align: center;
    margin: 13px calc(var(--pdX) * -1) 0;
  }
}
#top_about .img img {
  width: 100%;
  height: auto;
}
/*-------------------------
  わたしたちの強み
-------------------------*/
#top_strength {
  --bdc: #486278;
  overflow: hidden;
  position: relative;
  z-index: 0;
  background: var(--c_blue1);
  color: var(--c_white);
  padding: 126px var(--pdX) 120px;
}
@media screen and (max-width: 767px) {
  #top_strength {
    padding-top: 52px;
    padding-bottom: 12px;
  }
}
#top_strength::before {
  content: "";
  opacity: 0.15;
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/toppage/strength-bg.webp) no-repeat center center;
  background-size: cover;
}
#top_strength .hd.row_title {
  margin-bottom: 43px;
}
@media screen and (max-width: 767px) {
  #top_strength .hd.row_title {
    margin-bottom: 26px;
  }
}
#top_strength .hd.row_title > span:first-letter {
  color: #87F0E2;
}
#top_strength .hd.row_title .en {
  color: inherit;
}
#top_strength .hd.row_title .jp {
  color: inherit;
}
html:not([lang=en]) #top_strength .hd.row_title .jp:first-letter {
  color: inherit;
}
#top_strength #carousel_slider {
  margin: 0 calc(var(--pdX) * -1);
}
@media screen and (min-width: 768px) {
  #top_strength #carousel_slider {
    border-top: 1px solid var(--bdc);
    border-bottom: 1px solid var(--bdc);
    padding: 0 var(--pdX);
  }
}
@media screen and (min-width: 768px) {
  #top_strength .splide__track {
    overflow: inherit;
    max-width: 1440px;
    width: 100%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  #top_strength .splide__track {
    border-top: 1px solid var(--bdc);
    border-bottom: 1px solid var(--bdc);
  }
}
#top_strength .splide__arrows {
  justify-content: space-between;
  width: 100%;
  padding: 0 14px;
  margin-top: 12px;
}
@media screen and (min-width: 768px) {
  #top_strength .splide__arrows {
    display: none;
  }
}
#top_strength .splide__arrow {
  background: none;
  border-radius: 0;
}
#top_strength .splide__arrow::before {
  mask-image: url("../img/arrow03.svg");
  mask-position: center center;
  mask-size: auto 17px;
  mask-repeat: no-repeat;
  background: var(--c_white);
}
#top_strength .splide__pagination {
  margin-top: 15px;
}
#top_strength .splide__pagination__page {
  width: 10px;
}
#top_strength .splide__pagination__page:not(.is-active) {
  background-color: rgba(255, 255, 255, 0.5);
}
#top_strength .splide__pagination__page.is-active {
  background-color: var(--c_white);
}
@media screen and (min-width: 768px) {
  #top_strength .splide__list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-columns: repeat(3, 1fr);
    transform: none !important;
  }
  @container contents (max-width: 1280px) {
    #top_strength .splide__list {
      grid-template-columns: repeat(2, 1fr);
    }
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  #top_strength .splide__list::before {
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    bottom: -100vw;
    width: 1px;
    background-color: var(--bdc);
  }
}
@media screen and (min-width: 768px) {
  #top_strength .splide__slide::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: -100vw;
    width: 1px;
    background-color: var(--bdc);
  }
}
@media screen and (min-width: 768px) {
  @container contents (max-width: 1280px) {
    #top_strength .splide__slide::after {
      content: "";
      position: absolute;
      bottom: -1px;
      left: -100vw;
      right: -100vw;
      height: 1px;
      background: var(--bdc);
    }
  }
}
@media screen and (min-width: 768px) {
  #top_strength .splide__slide--clone {
    display: none;
  }
}
#top_strength a:not([href=""]) {
  display: block;
}
#top_strength a:not([href=""])::after {
  content: "";
  position: absolute;
  bottom: 24px;
  right: 24px;
  width: 15px;
  aspect-ratio: 1/1;
  mask: url("../img/arrow01.svg");
  mask-size: cover;
  background-color: currentColor;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (max-width: 767px) {
  #top_strength a:not([href=""])::after {
    bottom: 29px;
    right: 29px;
  }
}
#top_strength a:not([href=""]) > * {
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#top_strength a:not([href=""]):hover {
  color: #87F0E2;
}
#top_strength a:not([href=""]):hover::after {
  transform: translateX(5px);
}
#top_strength .list_item {
  display: grid;
  grid-template-columns: max-content 1fr;
  grid-template-rows: max-content 1fr;
  gap: 0 24px;
}
@media screen and (min-width: 768px) {
  #top_strength .list_item {
    word-break: auto-phrase;
    padding: 48px 43px 60px;
    padding: 48px 64px 60px;
  }
}
@media screen and (max-width: 767px) {
  #top_strength .list_item {
    column-gap: 20px;
    padding: 17px 48px 60px;
  }
}
#top_strength .list_item > .icon {
  grid-area: 1/1/2/2;
}
#top_strength .list_item > .hd {
  grid-area: 1/2/2/3;
}
#top_strength .list_item > p:not([class]) {
  grid-area: 2/1/3/3;
}
#top_strength .list_item .icon {
  width: 80px;
  padding: 5px;
}
#top_strength .list_item .icon svg * {
  aspect-ratio: 1/1;
  fill: currentColor;
}
#top_strength .list_item .hd {
  font-size: 1.5625rem;
  font-weight: 400;
  line-height: 1.5;
  padding-top: 24px;
}
@media screen and (max-width: 767px) {
  #top_strength .list_item .hd {
    font-size: 1.375rem;
    padding-top: 26px;
  }
}
#top_strength .list_item p:not([class]) {
  opacity: 0.8;
  line-height: 1.8125;
  padding-top: 20px;
}
@media screen and (max-width: 767px) {
  #top_strength .list_item p:not([class]) {
    padding-top: 12px;
  }
}

/*-------------------------
  事業内容
-------------------------*/
#top_service {
  padding: 166px var(--pdX) 226px;
}
@media screen and (max-width: 767px) {
  #top_service {
    padding-top: 60px;
    padding-bottom: 70px;
  }
}
#top_service .hd.row_title {
  margin-bottom: 37px;
}
@media screen and (max-width: 767px) {
  #top_service .hd.row_title {
    margin-bottom: 29px;
  }
}
#top_service .p_txt1 {
  color: var(--c_blue1);
  line-height: 1.575;
  letter-spacing: 0.05em;
  margin-bottom: 74px;
}
@media screen and (max-width: 767px) {
  #top_service .p_txt1 {
    line-height: 1.599;
    margin-bottom: 19px;
  }
}
@media screen and (min-width: 768px) {
  #top_service .p_txt1 > span:first-child {
    font-size: 1.5rem;
  }
}
#top_service .p_txt1 strong {
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  #top_service .p_txt1 strong {
    font-size: 2.25rem;
  }
}
#top_service .p_txt1 small {
  font-size: 100%;
}
@media screen and (max-width: 767px) {
  #top_service .p_txt1 small {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767px) {
  #top_service #carousel_slider {
    margin: 0 calc(var(--pdX) * -1);
  }
}
@media screen and (min-width: 768px) {
  #top_service .splide__track {
    overflow: inherit;
  }
}
@media screen and (min-width: 768px) {
  #top_service .splide__arrows {
    display: none;
  }
}
#top_service .splide__arrow {
  border: 1px solid rgba(219, 219, 219, 0.8);
}
#top_service .splide__pagination__page {
  width: 10px;
}
#top_service .splide__pagination__page:not(.is-active) {
  background-color: rgba(205, 212, 218, 0.8);
}
@media screen and (min-width: 768px) {
  #top_service .splide__list {
    transform: none !important;
  }
}
@media screen and (max-width: 767px) {
  #top_service .splide__slide {
    padding: 0 var(--pdX);
  }
}
@media screen and (min-width: 768px) {
  #top_service .splide__slide--clone {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .list_card {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: min(90 / var(--vp) * var(--vw), 90px);
  }
}
.list_card a:not([href=""]) * {
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.list_card a:not([href=""]) .hd {
  position: relative;
  padding-right: 24px;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.list_card a:not([href=""]) .hd::after {
  content: "";
  position: absolute;
  top: 10px;
  right: 1px;
  width: 15px;
  aspect-ratio: 1/1;
  mask: url("../img/arrow01.svg");
  mask-size: cover;
  background-color: currentColor;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (max-width: 767px) {
  .list_card a:not([href=""]) .hd::after {
    top: 7px;
    right: 7px;
  }
}
.list_card a:not([href=""]):hover {
  color: var(--c_blue2);
}
.list_card a:not([href=""]):hover .hd {
  --c_blue1: var(--c_blue2);
}
.list_card a:not([href=""]):hover .hd::after {
  transform: translateX(5px);
}
.list_card a:not([href=""]):hover .img img {
  transform: scale(1.02);
}
.list_card .list_item {
  display: block;
}
.list_card .img {
  overflow: hidden;
  display: block;
  --bdrs: min(calc(100 / var(--vp) * var(--vw)), 100px);
  border-radius: 0 var(--bdrs) 0 0;
  margin-bottom: 26px;
}
@media screen and (max-width: 767px) {
  .list_card .img {
    --bdrs: min(calc(120 / var(--vp) * var(--vw)), 120px);
    margin-bottom: 21px;
  }
}
.list_card .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
}
@media screen and (max-width: 767px) {
  .list_card .img img {
    height: auto;
  }
}
.list_card .hd {
  display: block;
  color: var(--c_blue1);
  font-size: 1.5625rem;
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: 15px;
}
@media screen and (max-width: 767px) {
  .list_card .hd {
    font-size: 1.125rem;
  }
}
.list_card p:not([class]) {
  line-height: 1.8125;
}
@media screen and (max-width: 767px) {
  .list_card p:not([class]) {
    font-size: 0.9375rem;
    line-height: 1.8;
  }
}

/*-------------------------
  プロジェクト
-------------------------*/
#top_project {
  position: relative;
  padding: 0 var(--pdX);
}
#top_project .innerWrap > .btns:has(.text_link) {
  position: absolute;
  top: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  #top_project .innerWrap > .btns:has(.text_link) {
    top: 21px;
  }
}
#top_project .innerWrap > .btns:has(.text_link) span {
  min-width: 103px;
}
#top_project h2.hd {
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  #top_project h2.hd {
    margin-bottom: 27px;
  }
}
#top_project #project_slider {
  margin: 0 calc(var(--pdX) * -1);
}
#top_project .blk_project {
  transform: none;
}
@media screen and (min-width: 768px) {
  @container contents (min-width: 1281px) {
    #top_project .blk_project .detail_wrap {
      width: 655px;
      min-height: 800px;
      padding: 110px calc(114 / var(--vp) * var(--vw));
    }
  }
  @container contents (max-width: 1280px) {
    #top_project .blk_project .detail_wrap {
      --vp: 12.80;
      width: min(655 / var(--vp) * var(--vw), 655px);
      padding-top: 43px;
      padding-bottom: 48px;
    }
  }
}
@container contents (min-width: 1281px) {
  #top_project .blk_project .project_name {
    font-size: 2rem;
  }
}
#top_project .blk_project .project_name span::after {
  display: none;
}
@container contents (min-width: 1281px) {
  #top_project .blk_project .project_sub_txt {
    margin-top: 5px;
  }
}
@container contents (min-width: 1281px) {
  #top_project .blk_project .project_txt {
    line-height: 1.8125;
    margin-top: 49px;
  }
}
@container contents (max-width: 1280px) {
  #top_project .blk_project .project_txt {
    margin-top: 18px;
  }
}
@container contents (min-width: 1281px) {
  #top_project .blk_project .project_caption {
    margin-top: 37px;
  }
}
@container contents (min-width: 1281px) {}
@container contents (max-width: 1280px) {
  #top_project .blk_project .btns:has(.text_link) {
    margin-top: 34px;
  }
}

#project_slider {
  position: relative;
}
@media screen and (min-width: 768px) {
  #project_slider > .splide__arrows {
    position: absolute;
    bottom: 32px;
    right: var(--pdX);
  }
}
#project_slider .splide__arrows {
  margin-top: 24px;
}
#project_slider .splide__arrow {
  border: 1px solid rgba(219, 219, 219, 0.8);
}
#project_slider .splide__pagination__page {
  width: 10px;
}
#project_slider .splide__pagination__page:not(.is-active) {
  background-color: rgba(205, 212, 218, 0.8);
}
#project_slider .blk_project {
  height: 100%;
}
#project_slider .detail_wrap {
  height: 100%;
}

/*-------------------------
  企業情報
-------------------------*/
#top_company {
  overflow: hidden;
  padding: 128px var(--pdX);
}
@media screen and (min-width: 768px) {
  @container contents (max-width: 1255px) {
    #top_company {
      --vp: 12.55;
      padding: 128px min(56 / var(--vp) * var(--vw), 56px);
    }
  }
}
@media screen and (max-width: 767px) {
  #top_company {
    padding-top: 67px;
    padding-bottom: 55px;
  }
}
@media screen and (min-width: 768px) {
  #top_company .innerWrap {
    display: grid;
    grid-template-columns: 476px 1fr;
    grid-template-rows: max-content max-content max-content 1fr;
    column-gap: 88px;
  }
  @container contents (max-width: 1255px) {
    #top_company .innerWrap {
      column-gap: min(88 / var(--vp) * var(--vw), 88px);
    }
  }
  @container contents (max-width: 1023px) {}
  #top_company .innerWrap .hd {
    grid-area: 1/1/2/2;
  }
  #top_company .innerWrap .p_txt1 {
    grid-area: 2/1/3/2;
  }
  #top_company .innerWrap p:not([class]) {
    grid-area: 3/1/4/2;
  }
  #top_company .innerWrap .btn_wrap {
    grid-area: 4/1/5/2;
  }
  #top_company .innerWrap .img {
    grid-area: 1/2/5/3;
  }
}
@media screen and (min-width: 768px) {
  #top_company .hd.row_title {
    margin-top: min(56 / var(--vp) * var(--vw), 56px);
    margin-bottom: min(45 / var(--vp) * var(--vw), 45px);
  }
}
@media screen and (max-width: 767px) {
  #top_company .hd.row_title {
    margin-bottom: 29px;
  }
}
#top_company .p_txt1 {
  color: var(--c_blue1);
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  #top_company .p_txt1 {
    font-size: 1.75rem;
    line-height: 1.5;
    margin-bottom: min(18 / var(--vp) * var(--vw), 18px);
  }
}
@media screen and (max-width: 767px) {
  #top_company .p_txt1 {
    line-height: 1.599;
    margin-bottom: 14px;
  }
}
html[lang=en] #top_company .p_txt1 font + br {
  display: none;
}
#top_company .btn_wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 16px;
}
@media screen and (min-width: 768px) {
  #top_company .btn_wrap {
    margin-top: min(51 / var(--vp) * var(--vw), 51px);
  }
}
@media screen and (max-width: 767px) {
  #top_company .btn_wrap {
    gap: 8px;
    margin-top: 18px;
  }
}
@media screen and (max-width: 767px) {
  #top_company .btn {
    min-width: 150px;
  }
}
@media screen and (max-width: 767px) {
  #top_company .btn.arrow::after {
    right: 13px;
  }
}
@media screen and (max-width: 767px) {
  #top_company .btn.arrow > span {
    padding-right: 13px;
  }
}
#top_company .img {
  display: grid;
}
@media screen and (min-width: 768px) {
  #top_company .img {
    align-self: center;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    width: 876px;
  }
}
@container contents (max-width: 1255px) {
  #top_company .img {
    width: auto;
    grid-template-columns: repeat(2, 1fr);
  }
}
@container contents (max-width: 1023px) {
  #top_company .img {
    width: 330px;
  }
}
@media screen and (max-width: 767px) {
  #top_company .img {
    gap: 2px;
    width: auto;
    margin: 40px auto 0;
  }
}
#top_company .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
  --bdrs: min(calc(100 / var(--vp) * var(--vw)), 100px);
}
@media screen and (min-width: 768px) {
  #top_company .img img {
    aspect-ratio: 141/126;
  }
}
@container contents (max-width: 1023px) {
  #top_company .img img {
    aspect-ratio: 41/32;
  }
}
#top_company .img img:nth-child(1) {
  border-radius: 0 var(--bdrs) 0 0;
}
#top_company .img img:nth-child(2) {
  border-radius: var(--bdrs) 0 0 0;
}
#top_company .img img:nth-child(3) {
  border-radius: 0 var(--bdrs);
}
#top_company .img img:nth-child(4) {
  border-radius: 0 var(--bdrs);
}
#top_company .img img:nth-child(5) {
  border-radius: 0 0 var(--bdrs) 0;
}
#top_company .img img:nth-child(6) {
  border-radius: 0 0 0 var(--bdrs);
}
@container contents (max-width: 1023px) {
  #top_company .img img {
    --bdrs:48px;
  }
  #top_company .img img:nth-child(1) {
    border-radius: 0 var(--bdrs);
  }
  #top_company .img img:nth-child(2) {
    border-radius: var(--bdrs) 0;
  }
  #top_company .img img:nth-child(3) {
    border-radius: var(--bdrs) 0 0 0;
  }
  #top_company .img img:nth-child(4) {
    border-radius: 0 var(--bdrs);
  }
  #top_company .img img:nth-child(5) {
    border-radius: 0 0 var(--bdrs) 0;
  }
  #top_company .img img:nth-child(6) {
    border-radius: 0 0 0 var(--bdrs);
  }
}

/*-------------------------
  クリーンエネルギー
-------------------------*/
#top_sustain_energy {
  background: url(../img/toppage/sustain_energy.png) no-repeat right bottom #FFFCF5;
  background-size: min(1242 / var(--vp) * var(--vw), 1242px) auto;
  color: var(--c_green1);
  padding: min(176 / var(--vp) * var(--vw), 176px) var(--pdX) min(240 / var(--vp) * var(--vw), 240px);
}
@media screen and (max-width: 767px) {
  #top_sustain_energy {
    background-size: min(428 / var(--vp) * var(--vw), 428px);
    padding-top: min(60 / var(--vp) * var(--vw), 60px);
    padding-bottom: min(220 / var(--vp) * var(--vw), 220px);
  }
}
@media screen and (min-width: 768px) {
  #top_sustain_energy .innerWrap > * {
    max-width: 720px;
  }
}
#top_sustain_energy .hd {
  margin-bottom: 27px;
}
@media screen and (max-width: 767px) {
  #top_sustain_energy .hd {
    margin-bottom: 17px;
  }
}
#top_sustain_energy .hd .en {
  color: inherit;
  font-size: 1.625rem;
}
@media screen and (max-width: 767px) {
  #top_sustain_energy .hd .en {
    font-size: 1rem;
  }
}
#top_sustain_energy .hd .en:first-letter {
  color: inherit;
}
#top_sustain_energy .hd .en > span:first-child {
  color: var(--c_green2);
}
#top_sustain_energy .p_txt1 {
  font-size: 2.875rem;
  line-height: 1.478;
  margin-bottom: 31px;
}
@media screen and (max-width: 767px) {
  #top_sustain_energy .p_txt1 {
    font-size: 1.3125rem;
    line-height: 1.619;
    margin-bottom: 14px;
  }
}
#top_sustain_energy .p_txt1 strong {
  color: var(--c_green2);
  font-weight: inherit;
}

/*-------------------------
  お知らせ
-------------------------*/
#top_information {
  padding: 0 var(--pdX);
  margin-top: 164px;
}
@media screen and (max-width: 767px) {
  #top_information {
    margin-top: 60px;
    margin-bottom: 16px;
  }
}
#top_information .hd {
  margin-bottom: 84px;
}
@media screen and (max-width: 767px) {
  #top_information .hd {
    margin-bottom: 28px;
  }
}
@media screen and (min-width: 768px) {
  #top_information .btns {
    position: absolute;
    bottom: 0;
    left: 0;
  }
}
@media screen and (max-width: 767px) {
  #top_information .btns {
    margin-top: 37px;
  }
}
@media screen and (min-width: 768px) {
  #top_information .tab_wrap {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 0 54px;
  }
}
#top_information .tab_radio {
  display: none;
}
@media screen and (min-width: 768px) {
  #top_information .tab_btn {
    width: 150px;
  }
}
@media screen and (max-width: 767px) {
  #top_information .tab_btn {
    margin-bottom: 20px;
  }
}
#top_information .tab_btn ul {
  display: flex;
  flex-direction: column;
  gap: 16px 0;
}
@media screen and (max-width: 767px) {
  #top_information .tab_btn ul {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 6px;
  }
}
#top_information .tab_btn label {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 36px;
  background: var(--bgc);
  border: 1px solid var(--c_blue1);
  border-radius: 100px;
  color: var(--fc);
  line-height: 1.5;
  text-transform: uppercase;
  --fc: var(--c_blue1);
  --bgc: var(--c_white);
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (max-width: 767px) {
  #top_information .tab_btn label {
    min-width: 90px;
    min-height: 40px;
    padding: 6px 22px;
  }
}
#top_information .tab_btn label:hover {
  --bgc: #DFECF9;
}
#top_information #tab-0:checked ~ .tab_btn label[for=tab-0] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-0:checked ~ .tab_box_wrap .tab_box.tab-0 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-1:checked ~ .tab_btn label[for=tab-1] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-1:checked ~ .tab_box_wrap .tab_box.tab-1 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-2:checked ~ .tab_btn label[for=tab-2] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-2:checked ~ .tab_box_wrap .tab_box.tab-2 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-3:checked ~ .tab_btn label[for=tab-3] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-3:checked ~ .tab_box_wrap .tab_box.tab-3 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-4:checked ~ .tab_btn label[for=tab-4] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-4:checked ~ .tab_box_wrap .tab_box.tab-4 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-5:checked ~ .tab_btn label[for=tab-5] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-5:checked ~ .tab_box_wrap .tab_box.tab-5 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-6:checked ~ .tab_btn label[for=tab-6] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-6:checked ~ .tab_box_wrap .tab_box.tab-6 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-7:checked ~ .tab_btn label[for=tab-7] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-7:checked ~ .tab_box_wrap .tab_box.tab-7 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-8:checked ~ .tab_btn label[for=tab-8] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-8:checked ~ .tab_box_wrap .tab_box.tab-8 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-9:checked ~ .tab_btn label[for=tab-9] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-9:checked ~ .tab_box_wrap .tab_box.tab-9 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-10:checked ~ .tab_btn label[for=tab-10] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-10:checked ~ .tab_box_wrap .tab_box.tab-10 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-11:checked ~ .tab_btn label[for=tab-11] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-11:checked ~ .tab_box_wrap .tab_box.tab-11 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-12:checked ~ .tab_btn label[for=tab-12] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-12:checked ~ .tab_box_wrap .tab_box.tab-12 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-13:checked ~ .tab_btn label[for=tab-13] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-13:checked ~ .tab_box_wrap .tab_box.tab-13 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-14:checked ~ .tab_btn label[for=tab-14] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-14:checked ~ .tab_box_wrap .tab_box.tab-14 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-15:checked ~ .tab_btn label[for=tab-15] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-15:checked ~ .tab_box_wrap .tab_box.tab-15 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-16:checked ~ .tab_btn label[for=tab-16] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-16:checked ~ .tab_box_wrap .tab_box.tab-16 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-17:checked ~ .tab_btn label[for=tab-17] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-17:checked ~ .tab_box_wrap .tab_box.tab-17 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-18:checked ~ .tab_btn label[for=tab-18] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-18:checked ~ .tab_box_wrap .tab_box.tab-18 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-19:checked ~ .tab_btn label[for=tab-19] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-19:checked ~ .tab_box_wrap .tab_box.tab-19 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-20:checked ~ .tab_btn label[for=tab-20] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-20:checked ~ .tab_box_wrap .tab_box.tab-20 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-21:checked ~ .tab_btn label[for=tab-21] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-21:checked ~ .tab_box_wrap .tab_box.tab-21 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-22:checked ~ .tab_btn label[for=tab-22] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-22:checked ~ .tab_box_wrap .tab_box.tab-22 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-23:checked ~ .tab_btn label[for=tab-23] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-23:checked ~ .tab_box_wrap .tab_box.tab-23 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-24:checked ~ .tab_btn label[for=tab-24] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-24:checked ~ .tab_box_wrap .tab_box.tab-24 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-25:checked ~ .tab_btn label[for=tab-25] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-25:checked ~ .tab_box_wrap .tab_box.tab-25 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-26:checked ~ .tab_btn label[for=tab-26] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-26:checked ~ .tab_box_wrap .tab_box.tab-26 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-27:checked ~ .tab_btn label[for=tab-27] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-27:checked ~ .tab_box_wrap .tab_box.tab-27 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-28:checked ~ .tab_btn label[for=tab-28] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-28:checked ~ .tab_box_wrap .tab_box.tab-28 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-29:checked ~ .tab_btn label[for=tab-29] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-29:checked ~ .tab_box_wrap .tab_box.tab-29 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-30:checked ~ .tab_btn label[for=tab-30] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-30:checked ~ .tab_box_wrap .tab_box.tab-30 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-31:checked ~ .tab_btn label[for=tab-31] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-31:checked ~ .tab_box_wrap .tab_box.tab-31 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-32:checked ~ .tab_btn label[for=tab-32] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-32:checked ~ .tab_box_wrap .tab_box.tab-32 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-33:checked ~ .tab_btn label[for=tab-33] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-33:checked ~ .tab_box_wrap .tab_box.tab-33 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-34:checked ~ .tab_btn label[for=tab-34] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-34:checked ~ .tab_box_wrap .tab_box.tab-34 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-35:checked ~ .tab_btn label[for=tab-35] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-35:checked ~ .tab_box_wrap .tab_box.tab-35 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-36:checked ~ .tab_btn label[for=tab-36] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-36:checked ~ .tab_box_wrap .tab_box.tab-36 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-37:checked ~ .tab_btn label[for=tab-37] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-37:checked ~ .tab_box_wrap .tab_box.tab-37 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-38:checked ~ .tab_btn label[for=tab-38] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-38:checked ~ .tab_box_wrap .tab_box.tab-38 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-39:checked ~ .tab_btn label[for=tab-39] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-39:checked ~ .tab_box_wrap .tab_box.tab-39 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-40:checked ~ .tab_btn label[for=tab-40] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-40:checked ~ .tab_box_wrap .tab_box.tab-40 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-41:checked ~ .tab_btn label[for=tab-41] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-41:checked ~ .tab_box_wrap .tab_box.tab-41 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-42:checked ~ .tab_btn label[for=tab-42] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-42:checked ~ .tab_box_wrap .tab_box.tab-42 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-43:checked ~ .tab_btn label[for=tab-43] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-43:checked ~ .tab_box_wrap .tab_box.tab-43 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-44:checked ~ .tab_btn label[for=tab-44] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-44:checked ~ .tab_box_wrap .tab_box.tab-44 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-45:checked ~ .tab_btn label[for=tab-45] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-45:checked ~ .tab_box_wrap .tab_box.tab-45 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-46:checked ~ .tab_btn label[for=tab-46] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-46:checked ~ .tab_box_wrap .tab_box.tab-46 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-47:checked ~ .tab_btn label[for=tab-47] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-47:checked ~ .tab_box_wrap .tab_box.tab-47 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-48:checked ~ .tab_btn label[for=tab-48] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-48:checked ~ .tab_box_wrap .tab_box.tab-48 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-49:checked ~ .tab_btn label[for=tab-49] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-49:checked ~ .tab_box_wrap .tab_box.tab-49 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-50:checked ~ .tab_btn label[for=tab-50] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-50:checked ~ .tab_box_wrap .tab_box.tab-50 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-51:checked ~ .tab_btn label[for=tab-51] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-51:checked ~ .tab_box_wrap .tab_box.tab-51 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-52:checked ~ .tab_btn label[for=tab-52] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-52:checked ~ .tab_box_wrap .tab_box.tab-52 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-53:checked ~ .tab_btn label[for=tab-53] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-53:checked ~ .tab_box_wrap .tab_box.tab-53 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-54:checked ~ .tab_btn label[for=tab-54] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-54:checked ~ .tab_box_wrap .tab_box.tab-54 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-55:checked ~ .tab_btn label[for=tab-55] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-55:checked ~ .tab_box_wrap .tab_box.tab-55 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-56:checked ~ .tab_btn label[for=tab-56] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-56:checked ~ .tab_box_wrap .tab_box.tab-56 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-57:checked ~ .tab_btn label[for=tab-57] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-57:checked ~ .tab_box_wrap .tab_box.tab-57 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-58:checked ~ .tab_btn label[for=tab-58] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-58:checked ~ .tab_box_wrap .tab_box.tab-58 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-59:checked ~ .tab_btn label[for=tab-59] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-59:checked ~ .tab_box_wrap .tab_box.tab-59 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-60:checked ~ .tab_btn label[for=tab-60] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-60:checked ~ .tab_box_wrap .tab_box.tab-60 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-61:checked ~ .tab_btn label[for=tab-61] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-61:checked ~ .tab_box_wrap .tab_box.tab-61 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-62:checked ~ .tab_btn label[for=tab-62] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-62:checked ~ .tab_box_wrap .tab_box.tab-62 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-63:checked ~ .tab_btn label[for=tab-63] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-63:checked ~ .tab_box_wrap .tab_box.tab-63 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-64:checked ~ .tab_btn label[for=tab-64] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-64:checked ~ .tab_box_wrap .tab_box.tab-64 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-65:checked ~ .tab_btn label[for=tab-65] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-65:checked ~ .tab_box_wrap .tab_box.tab-65 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-66:checked ~ .tab_btn label[for=tab-66] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-66:checked ~ .tab_box_wrap .tab_box.tab-66 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-67:checked ~ .tab_btn label[for=tab-67] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-67:checked ~ .tab_box_wrap .tab_box.tab-67 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-68:checked ~ .tab_btn label[for=tab-68] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-68:checked ~ .tab_box_wrap .tab_box.tab-68 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-69:checked ~ .tab_btn label[for=tab-69] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-69:checked ~ .tab_box_wrap .tab_box.tab-69 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-70:checked ~ .tab_btn label[for=tab-70] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-70:checked ~ .tab_box_wrap .tab_box.tab-70 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-71:checked ~ .tab_btn label[for=tab-71] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-71:checked ~ .tab_box_wrap .tab_box.tab-71 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-72:checked ~ .tab_btn label[for=tab-72] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-72:checked ~ .tab_box_wrap .tab_box.tab-72 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-73:checked ~ .tab_btn label[for=tab-73] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-73:checked ~ .tab_box_wrap .tab_box.tab-73 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-74:checked ~ .tab_btn label[for=tab-74] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-74:checked ~ .tab_box_wrap .tab_box.tab-74 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-75:checked ~ .tab_btn label[for=tab-75] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-75:checked ~ .tab_box_wrap .tab_box.tab-75 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-76:checked ~ .tab_btn label[for=tab-76] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-76:checked ~ .tab_box_wrap .tab_box.tab-76 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-77:checked ~ .tab_btn label[for=tab-77] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-77:checked ~ .tab_box_wrap .tab_box.tab-77 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-78:checked ~ .tab_btn label[for=tab-78] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-78:checked ~ .tab_box_wrap .tab_box.tab-78 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-79:checked ~ .tab_btn label[for=tab-79] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-79:checked ~ .tab_box_wrap .tab_box.tab-79 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-80:checked ~ .tab_btn label[for=tab-80] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-80:checked ~ .tab_box_wrap .tab_box.tab-80 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-81:checked ~ .tab_btn label[for=tab-81] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-81:checked ~ .tab_box_wrap .tab_box.tab-81 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-82:checked ~ .tab_btn label[for=tab-82] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-82:checked ~ .tab_box_wrap .tab_box.tab-82 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-83:checked ~ .tab_btn label[for=tab-83] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-83:checked ~ .tab_box_wrap .tab_box.tab-83 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-84:checked ~ .tab_btn label[for=tab-84] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-84:checked ~ .tab_box_wrap .tab_box.tab-84 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-85:checked ~ .tab_btn label[for=tab-85] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-85:checked ~ .tab_box_wrap .tab_box.tab-85 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-86:checked ~ .tab_btn label[for=tab-86] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-86:checked ~ .tab_box_wrap .tab_box.tab-86 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-87:checked ~ .tab_btn label[for=tab-87] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-87:checked ~ .tab_box_wrap .tab_box.tab-87 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-88:checked ~ .tab_btn label[for=tab-88] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-88:checked ~ .tab_box_wrap .tab_box.tab-88 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-89:checked ~ .tab_btn label[for=tab-89] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-89:checked ~ .tab_box_wrap .tab_box.tab-89 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-90:checked ~ .tab_btn label[for=tab-90] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-90:checked ~ .tab_box_wrap .tab_box.tab-90 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-91:checked ~ .tab_btn label[for=tab-91] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-91:checked ~ .tab_box_wrap .tab_box.tab-91 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-92:checked ~ .tab_btn label[for=tab-92] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-92:checked ~ .tab_box_wrap .tab_box.tab-92 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-93:checked ~ .tab_btn label[for=tab-93] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-93:checked ~ .tab_box_wrap .tab_box.tab-93 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-94:checked ~ .tab_btn label[for=tab-94] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-94:checked ~ .tab_box_wrap .tab_box.tab-94 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-95:checked ~ .tab_btn label[for=tab-95] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-95:checked ~ .tab_box_wrap .tab_box.tab-95 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-96:checked ~ .tab_btn label[for=tab-96] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-96:checked ~ .tab_box_wrap .tab_box.tab-96 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-97:checked ~ .tab_btn label[for=tab-97] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-97:checked ~ .tab_box_wrap .tab_box.tab-97 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-98:checked ~ .tab_btn label[for=tab-98] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-98:checked ~ .tab_box_wrap .tab_box.tab-98 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-99:checked ~ .tab_btn label[for=tab-99] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-99:checked ~ .tab_box_wrap .tab_box.tab-99 {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
#top_information #tab-all:checked ~ .tab_btn label[for=tab-all] {
  --bgc: var(--c_blue1);
  --fc: var(--c_white);
}
#top_information #tab-all:checked ~ .tab_box_wrap .tab_box.tab-all {
  display: block;
  opacity: 0;
  animation: tabFadeIn 0.25s 0.05s ease-in forwards;
}
@media screen and (min-width: 768px) {
  #top_information .tab_box_wrap {
    min-height: 280px;
    border-left: 1px solid var(--c_gray1);
    padding-left: 54px;
  }
}
#top_information .tab_box {
  display: none;
  opacity: 0;
}
@keyframes tabFadeIn {
  0% {
    opacity: 0;
    display: none;
  }
  1% {
    opacity: 0;
    display: block;
  }
  100% {
    opacity: 1;
    display: block;
  }
}
@media screen and (min-width: 768px) {
  #top_information .article_posts > *:first-child .body {
    padding-top: 0;
  }
}
@container article_posts (min-width: 768px) {
  #top_information .article_posts .post_data {
    min-width: 240px;
  }
}
@container article_posts (min-width: 768px) {
  #top_information .article_posts .post_date {
    font-size: 1.0625rem;
  }
}

/*-------------------------
  採用情報
-------------------------*/
#top_recruit {
  padding: 0 var(--pdX);
  margin-top: 200px;
}
@media screen and (max-width: 767px) {
  #top_recruit {
    margin-top: 56px;
  }
}
.blk_recruit {
  overflow: hidden;
  position: relative;
  z-index: 0;
  display: block;
  width: 100%;
  background: var(--c_blue1);
  --bdrs: min(calc(240 / var(--vp) * var(--vw)), 240px);
  border-radius: 0 var(--bdrs) 0 0;
  color: var(--c_white);
  padding: 0 var(--pdX);
}
@media screen and (max-width: 767px) {
  .blk_recruit {
    --pdX: min(calc(40 / var(--vp) * var(--vw)), 40px);
    --bdrs: 64px;
  }
}
.blk_recruit .blk_recruit_inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 1200px;
  width: 100%;
  min-height: 560px;
  box-sizing: border-box;
  padding: calc(var(--pdX) + 10px) 0 calc(var(--pdX) + 0px);
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .blk_recruit .blk_recruit_inner {
    min-height: inherit;
    padding: 60px 0;
  }
}
.blk_recruit .hd.row_title {
  align-items: baseline;
  column-gap: 18px;
  margin-bottom: 28px;
}
@media screen and (min-width: 768px) {
  .blk_recruit .hd.row_title {
    font-size: 4rem !important;
  }
}
.blk_recruit .hd.row_title span {
  color: inherit;
}
.blk_recruit .hd.row_title span:first-letter {
  color: inherit;
}
.blk_recruit .hd.row_title .jp {
  color: inherit !important;
}
@media screen and (min-width: 768px) {
  html:not([lang=en]) .blk_recruit .hd.row_title .jp {
    font-size: 1.3125rem !important;
  }
}
.blk_recruit .p_txt1 {
  font-size: 1.875rem;
  font-weight: 400;
  letter-spacing: var(--ls50);
}
@media screen and (max-width: 767px) {
  .blk_recruit .p_txt1 {
    word-break: auto-phrase;
    font-size: 1.125rem;
    line-height: 1.599;
  }
}
.blk_recruit .img {
  opacity: 0.5;
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.blk_recruit .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

a.blk_recruit {
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
a.blk_recruit::after {
  content: "";
  position: absolute;
  bottom: 30px;
  right: 39px;
  width: 18px;
  aspect-ratio: 1/1;
  mask: url("../img/arrow01.svg");
  mask-size: cover;
  background-color: var(--c_white);
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (max-width: 767px) {
  a.blk_recruit::after {
    right: 30px;
    width: 14px;
  }
}
a.blk_recruit:hover {
  --bdrs: 0;
}
a.blk_recruit:hover::after {
  transform: translateX(5px);
}

/*== project ====================================================================================================*/
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ プロジェクト - 一覧
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#page_project:not(.page_post) {
  padding-top: 76px;
}
@media screen and (max-width: 767px) {
  #page_project:not(.page_post) {
    padding-top: 45px;
  }
}
#page_project:not(.page_post) .blk_intro {
  padding: 0 var(--pdX);
  margin-bottom: 96px;
}
@media screen and (max-width: 767px) {
  #page_project:not(.page_post) .blk_intro {
    margin-bottom: 60px;
  }
}
#page_project:not(.page_post) .blk_intro .main_title {
  margin-bottom: 120px;
}
@media screen and (max-width: 767px) {
  #page_project:not(.page_post) .blk_intro .main_title {
    margin-bottom: 40px;
  }
}
@container contents (min-width: 1281px) {
  #page_project:not(.page_post) .blk_project .detail_wrap {
    min-height: 660px;
  }
}
@container contents (min-width: 1281px) {
  #page_project:not(.page_post) .blk_project .project_name {
    font-size: 2.25rem;
  }
}
#page_project:not(.page_post) .blk_project .project_name span::after {
  display: none;
}
@container contents (min-width: 1281px) {
  #page_project:not(.page_post) .blk_project .btns:has(.text_link) {
    margin-top: 37px;
  }
}
#page_project:not(.page_post) .blk_project + .blk_project {
  margin-top: 48px;
}
@media screen and (max-width: 767px) {
  #page_project:not(.page_post) .blk_project + .blk_project {
    margin-top: 48px;
  }
}
#page_project:not(.page_post) .blk_outro {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  row-gap: 32px;
  padding: 0 var(--pdX);
  margin-top: 160px;
}
@media screen and (max-width: 767px) {
  #page_project:not(.page_post) .blk_outro {
    margin-top: 80px;
    row-gap: 16px;
  }
}
#page_project:not(.page_post) .blk_outro .p_txt1 {
  line-height: 1.5;
}
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ プロジェクト - 詳細
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#page_project.page_post section + section {
  margin-top: 160px;
}
@media screen and (max-width: 767px) {
  #page_project.page_post section + section {
    margin-top: 56px;
  }
}
#page_project.page_post .btns:has(.text_link):not(.blk_project .btns) {
  padding: 0 var(--pdX) 20px;
}
@media screen and (max-width: 767px) {
  #page_project.page_post .btns:has(.text_link):not(.blk_project .btns) {
    --pdX: 20px;
    padding-top: 26px;
    padding-bottom: 16px;
  }
}
#page_project.page_post .btns:has(.innerWrap) {
  padding: 0 var(--pdX);
  margin-top: 80px;
}
#page_project.page_post .btns:has(.innerWrap) .innerWrap {
  display: block;
}
@media screen and (max-width: 767px) {
  #page_project.page_post .btns:has(.innerWrap) .innerWrap {
    text-align: center;
  }
}

/*-------------------------
  プロジェクト紹介
-------------------------*/
@media screen and (min-width: 768px) {
  #page_project.page_post .blk_project .detail_wrap {
    min-height: inherit;
    padding-bottom: 234px;
  }
}
#page_project.page_post .blk_project .detail_wrap > * {
  opacity: 0;
  animation: detail_wrap 0.4s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  transform: translate(-20px, 20px);
}
@keyframes detail_wrap {
  0% {
    opacity: 0;
    transform: translate(-10px, 10px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
#page_project.page_post .blk_project .project_txt {
  display: block;
}
#page_project.page_post .blk_project .btns:has(.text_link) {
  display: none;
}

/*-------------------------
  プロジェクト概要
-------------------------*/
#page_project.page_post #project_overview {
  position: relative;
  z-index: 0;
  padding: 0 var(--pdX);
  margin-top: -106px;
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_overview {
    --pdX: 15px;
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_overview::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100px;
    background: var(--c_black);
  }
}
#page_project.page_post #project_overview .innerWrap {
  background: var(--c_white);
  border: 1px solid var(--c_blue1);
  border-radius: 6px 120px 6px 6px;
  padding: 24px;
}
@media screen and (min-width: 768px) {
  #page_project.page_post #project_overview .innerWrap {
    display: grid;
    grid-template-columns: max-content 1fr;
    grid-template-rows: max-content 1fr;
    gap: 20px min(67 / var(--vp) * var(--vw), 67px);
  }
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_overview .innerWrap {
    padding: 32px 25px 15px;
  }
}
#page_project.page_post #project_overview .innerWrap > .hd {
  grid-area: 1/2/2/3;
}
#page_project.page_post #project_overview .innerWrap > .table {
  grid-area: 2/2/3/3;
  margin-bottom: auto;
}
#page_project.page_post #project_overview .innerWrap > .img {
  grid-area: 1/1/3/2;
}
#page_project.page_post #project_overview .hd {
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.188;
}
@media screen and (min-width: 768px) {
  #page_project.page_post #project_overview .hd {
    margin-top: 24px;
  }
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_overview .hd {
    margin-bottom: 6px;
  }
}
#page_project.page_post #project_overview .hd > *:first-letter {
  color: inherit;
}
#page_project.page_post #project_overview .hd .en {
  font-weight: 500;
}
#page_project.page_post #project_overview .table {
  max-width: 840px;
}
#page_project.page_post #project_overview table {
  width: 100%;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  #page_project.page_post #project_overview table {
    margin-bottom: 24px;
  }
}
#page_project.page_post #project_overview table tr {
  border-bottom: 1px solid var(--c_gray1);
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_overview table tr {
    display: flex;
    flex-direction: column;
    row-gap: 6px;
    padding: 12px 0;
  }
}
#page_project.page_post #project_overview table tr > * {
  padding: 14px 0;
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_overview table tr > * {
    display: block;
    padding: 0;
  }
}
#page_project.page_post #project_overview table th {
  color: var(--c_blue1);
  font-weight: 500;
  text-align: left;
}
@media screen and (min-width: 768px) {
  #page_project.page_post #project_overview table th {
    width: 154px;
  }
}
#page_project.page_post #project_overview .img {
  overflow: hidden;
  width: min(446 / var(--vp) * var(--vw), 446px);
  min-width: 330px;
  aspect-ratio: 223/152;
  border-radius: 6px;
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_overview .img {
    width: 100%;
    min-width: inherit;
    margin-top: 24px;
  }
}
#page_project.page_post #project_overview .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
}

/*-------------------------
  プロジェクトの特徴
-------------------------*/
#page_project.page_post #project_initiative {
  padding: 0 var(--pdX);
  margin-top: 120px;
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_initiative {
    margin-top: 56px;
  }
}
#page_project.page_post #project_initiative .hd {
  margin-bottom: var(--spacer);
  --spacer: 80px;
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_initiative .hd {
    --spacer: 30px;
  }
}

.blk_group_wrap {
  display: flex;
  flex-direction: column;
  row-gap: var(--spacer);
  --spacer: 80px;
}
@media screen and (max-width: 767px) {
  .blk_group_wrap {
    --spacer: 48px;
  }
}

@media screen and (min-width: 768px) {
  .blk_group {
    display: grid;
    grid-template-columns: 1fr max-content;
    grid-template-rows: max-content 1fr;
    gap: 24px min(80 / var(--vp) * var(--vw), 80px);
  }
}
.blk_group .group_hd {
  grid-area: 1/1/2/2;
  color: var(--c_blue1);
  font-size: 1.875rem;
  font-weight: 500;
  line-height: 1.5;
  padding-top: 8px;
}
@media screen and (max-width: 767px) {
  .blk_group .group_hd {
    font-size: 1.25rem;
    margin-bottom: 16px;
  }
}
.blk_group .group_txt {
  grid-area: 2/1/3/2;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .blk_group .group_txt {
    font-size: 1.0625rem;
  }
}
@media screen and (max-width: 767px) {
  .blk_group .group_txt {
    font-size: 1rem;
  }
}
@media screen and (min-width: 768px) {
  .blk_group .group_img {
    grid-area: 1/2/3/3;
    width: min(680 / var(--vp) * var(--vw), 680px);
    min-width: 330px;
  }
}
@media screen and (max-width: 767px) {
  .blk_group .group_img {
    margin-top: 32px;
  }
}
.blk_group .group_img img {
  overflow: hidden;
  display: block;
  border-radius: 0px min(120 / var(--vp) * var(--vw), 120px);
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .blk_group .group_img img {
    border-radius: 0 64px;
  }
}
.blk_group .group_img figcaption {
  color: var(--c_gray4);
  font-size: 0.875rem;
  line-height: 1.5;
  text-align: right;
  margin-top: 8px;
}
.blk_group:nth-of-type(even) {
  grid-template-columns: max-content 1fr;
}
.blk_group:nth-of-type(even) .group_hd {
  grid-area: 1/2/2/3;
}
.blk_group:nth-of-type(even) .group_txt {
  grid-area: 2/2/3/3;
}
.blk_group:nth-of-type(even) .group_img {
  grid-area: 1/1/3/2;
}
.blk_group:not(:has(img)) {
  column-gap: 0;
}

/*-------------------------
  プロジェクトについてのお知らせ
-------------------------*/
#page_project.page_post #project_information {
  padding: 0 var(--pdX);
}
#page_project.page_post #project_information .hd {
  margin-bottom: var(--spacer);
  --spacer: 80px;
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_information .hd {
    --spacer: 30px;
  }
}
#page_project.page_post #project_information .article_posts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 min(89 / var(--vp) * var(--vw), 89px);
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_information .article_posts {
    display: flex;
    flex-direction: column;
    row-gap: 32px;
  }
}
#page_project.page_post #project_information .post {
  line-height: 1.5;
}
#page_project.page_post #project_information .post a {
  display: block;
}
#page_project.page_post #project_information .post a:hover .post_img img {
  transform: scale(1.05);
}
#page_project.page_post #project_information .post a:hover .body {
  filter: brightness(2);
}
#page_project.page_post #project_information .post .post_img {
  overflow: hidden;
  border-radius: 0 min(120 / var(--vp) * var(--vw), 120px) 0 0;
  aspect-ratio: 105/66;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_information .post .post_img {
    border-radius: 0 64px 0 0;
  }
}
#page_project.page_post #project_information .post .post_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#page_project.page_post #project_information .post .body {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 12px 24px;
}
@media screen and (max-width: 767px) {
  #page_project.page_post #project_information .post .body {
    display: flex;
    flex-direction: column;
    gap: 6px 0;
  }
}
#page_project.page_post #project_information .post .post_date {
  grid-area: 1/1/2/2;
  color: var(--c_blue1);
  line-height: 1.75;
}
#page_project.page_post #project_information .post .post_date time {
  font-family: "Montserrat", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-weight: 400;
  letter-spacing: calc(0em / 1000);
}
#page_project.page_post #project_information .post .post_name {
  grid-area: 1/2/2/3;
  color: var(--c_blue1);
  font-size: 1.25rem;
  font-weight: 500;
}
#page_project.page_post #project_information .post .post_txt {
  grid-area: 2/1/3/3;
  overflow: hidden;
  line-height: 1.8125;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
#page_project.page_post #project_information .btns {
  display: flex;
  justify-content: flex-end;
  padding: 0;
  margin-left: auto;
  margin-top: 50px;
}
/*== information ====================================================================================================*/
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ お知らせ - 共通
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#page_information {
  padding: 0 var(--pdX);
}
@media screen and (max-width: 767px) {
  #page_information {
    padding-top: 45px;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ お知らせ - 一覧
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media screen and (min-width: 768px) {
  #page_information:not(.page_post) {
    padding-top: 76px;
  }
}
#page_information:not(.page_post) .hd.main_title {
  margin-bottom: 124px;
}
@media screen and (max-width: 767px) {
  #page_information:not(.page_post) .hd.main_title {
    margin-bottom: 40px;
  }
}
#page_information:not(.page_post) .navigation {
  position: relative;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0;
}
@media screen and (max-width: 767px) {
  #page_information:not(.page_post) .navigation {
    max-width: none;
  }
}
@media screen and (min-width: 768px) {
  #page_information:not(.page_post) .navigation {
    display: grid;
    grid-template-columns: 1fr max-content;
    align-items: flex-start;
    column-gap: 32px;
    margin-bottom: 60px;
  }
}
@media screen and (max-width: 767px) {
  #page_information:not(.page_post) .navigation {
    display: flex;
    flex-direction: column;
    row-gap: 16px;
    margin-bottom: 20px;
  }
}
#page_information:not(.page_post) .category_title {
  position: relative;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0;
  margin-top: 80px;
  margin-bottom: 23px;
}
@media screen and (max-width: 767px) {
  #page_information:not(.page_post) .category_title {
    max-width: none;
  }
}
@media screen and (min-width: 768px) {
  #page_information:not(.page_post) .category_title {
    background: var(--c_gray3);
    border-radius: 8px;
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    padding: 0 28px 0 0;
  }
}
@media screen and (max-width: 767px) {
  #page_information:not(.page_post) .category_title {
    margin-top: 40px;
    margin-bottom: 16px;
  }
}
@media screen and (min-width: 768px) {
  #page_information:not(.page_post) .category_title .hd {
    background: none;
    border-radius: 0;
  }
}
@media screen and (min-width: 768px) {
  #page_information:not(.page_post) .category_title .btns {
    flex: 1 0 auto;
  }
}
@media screen and (max-width: 767px) {
  #page_information:not(.page_post) .category_title .btns {
    text-align: right;
    margin-bottom: 16px;
  }
}
#page_information:not(.page_post) .article_posts {
  position: relative;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0;
}
@media screen and (max-width: 767px) {
  #page_information:not(.page_post) .article_posts {
    max-width: none;
  }
}

.article_posts.type_info {
  container: article_posts/inline-size;
}
.article_posts.type_info .post {
  border-bottom: 1px solid var(--c_gray1);
  color: var(--c_blue1);
}
.article_posts.type_info a {
  display: block;
}
.article_posts.type_info a .post_name {
  position: relative;
  padding-right: 44px;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.article_posts.type_info a .post_name::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 15px;
  width: 14px;
  aspect-ratio: 1/1;
  mask: url("../img/arrow01.svg");
  mask-size: cover;
  background-color: var(--c_blue1);
  transform: translate(0, -50%);
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.article_posts.type_info a:hover .post_name {
  color: var(--c_blue2);
}
.article_posts.type_info a:hover .post_name::after {
  transform: translate(5px, -50%);
}
.article_posts.type_info .body {
  padding: 20px 0;
}
@container article_posts (min-width: 768px) {
  .article_posts.type_info .body {
    display: grid;
    align-items: flex-start;
    grid-template-columns: max-content 1fr;
  }
}
@container article_posts (max-width: 767px) {}
.article_posts.type_info .post_data {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  justify-content: flex-end;
}
@container article_posts (min-width: 768px) {
  .article_posts.type_info .post_data {
    font-size: 1.125rem;
    min-width: 122px;
    padding-right: 36px;
    column-gap: 32px;
  }
}
@container article_posts (max-width: 767px) {
  .article_posts.type_info .post_data {
    column-gap: 12px;
    margin-bottom: 8px;
  }
}
@container article_posts (min-width: 768px) {
  .article_posts.type_info .body:has(.post_cat) .post_data {
    min-width: 254px;
  }
}
.article_posts.type_info .post_date {
  line-height: 1.5;
}
.article_posts.type_info .post_cat {
  display: inline-block;
  min-width: 100px;
  background: var(--c_blue1);
  border-radius: 2px;
  color: var(--c_white);
  font-size: 0.875rem;
  line-height: 1.25;
  text-align: center;
  text-transform: uppercase;
  padding: 6px 17px;
}
@container article_posts (max-width: 767px) {
  .article_posts.type_info .post_cat {
    min-width: 86px;
    line-height: 1.286;
    padding: 3px 10px;
  }
}
.article_posts.type_info .post_name {
  font-size: 1.0625rem;
  line-height: 1.6;
  font-weight: 500;
}
@container article_posts (max-width: 767px) {
  .article_posts.type_info .post_name {
    font-size: 1rem;
  }
}
.article_posts.type_info .post_name > small {
  display: inline-block;
}

.nav_category ul {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
@media screen and (max-width: 767px) {
  .nav_category ul {
    gap: 6px;
  }
}
.nav_category .cat-item {
  font-family: "Montserrat", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-weight: 500;
  letter-spacing: calc(0em / 1000);
  text-transform: uppercase;
  --bgc: var(--c_white);
  --fc: var(--c_blue1);
}
.nav_category .cat-item a {
  overflow: hidden;
  position: relative;
  z-index: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 43px;
  background: var(--bgc);
  border-radius: 100px;
  border: 1px solid var(--fc);
  color: var(--fc);
  line-height: 1.5;
  padding: 10px 30px;
}
@media screen and (min-width: 768px) {
  .nav_category .cat-item a {
    min-width: 214px;
  }
}
@media screen and (max-width: 767px) {
  .nav_category .cat-item a {
    min-width: 90px;
    min-height: 40px;
    padding: 6px 22px;
  }
}
.nav_category .cat-item a::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #DFECF9;
  transform-origin: 100% 50%;
  transform: scaleX(0);
  transition: var(--ts);
}
.nav_category .cat-item a:hover::before {
  transform-origin: 0% 50%;
  transform: scaleX(1);
}
.nav_category .cat-item.current-cat a {
  pointer-events: none;
  --fc: var(--c_white);
  --bgc: var(--c_blue1);
}

.nav_project {
  display: grid;
  grid-template-columns: max-content 1fr;
  align-items: center;
  column-gap: 24px;
}
@media screen and (max-width: 767px) {
  .nav_project {
    column-gap: 16px;
  }
}
.nav_project dt {
  font-family: "Montserrat", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-weight: 500;
  letter-spacing: calc(0em / 1000);
  font-size: 1.125rem;
  text-transform: uppercase;
}
.nav_project select {
  width: 274px;
  height: 43px;
  padding-left: 0.5em;
}
@media screen and (max-width: 767px) {
  .nav_project select {
    width: 100%;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ お知らせ - 詳細
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media screen and (min-width: 768px) {
  #page_information.page_post {
    padding-top: 97px;
  }
}

/*-------------------------
  記事投稿
-------------------------*/
.post_article .post_head {
  position: relative;
  margin-bottom: 46px;
}
@media screen and (max-width: 767px) {
  .post_article .post_head {
    margin-bottom: 32px;
  }
}
@media screen and (min-width: 768px) {
  .post_article .post_head .hd {
    padding-top: 4px;
    padding-bottom: 18px;
    margin-bottom: 66px;
  }
}
@media screen and (max-width: 767px) {
  .post_article .post_head .hd {
    margin-bottom: 16px;
  }
}
.post_article .post_head .post_data {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  column-gap: 32px;
}
@media screen and (min-width: 768px) {
  .post_article .post_head .post_data {
    position: absolute;
    top: 0;
    right: 0;
  }
}
@media screen and (max-width: 767px) {
  .post_article .post_head .post_data {
    justify-content: flex-end;
    column-gap: 12px;
    margin-bottom: 32px;
  }
}
.post_article .post_head .post_date {
  line-height: 1.5;
}
.post_article .post_head .post_cat {
  display: inline-block;
  min-width: 100px;
  background: var(--c_blue1);
  border-radius: 2px;
  color: var(--c_white);
  font-size: 0.875rem;
  line-height: 1.25;
  text-align: center;
  text-transform: uppercase;
  padding: 6px 17px;
}
@media screen and (max-width: 767px) {
  .post_article .post_head .post_cat {
    min-width: 86px;
    line-height: 1.286;
    padding: 3px 10px;
  }
}
.post_article .post_head .post_icon {
  max-width: 1000px;
  width: 100%;
  margin: 0 auto 21px;
}
@media screen and (max-width: 767px) {
  .post_article .post_head .post_icon {
    margin-bottom: 12px;
  }
}
.post_article .post_head .post_icon span {
  display: inline-block;
  border: 1px solid currentColor;
  border-radius: 0 16px;
  color: var(--c_blue1);
  font-weight: 500;
  padding: 10px 10px;
}
@media screen and (max-width: 767px) {
  .post_article .post_head .post_icon span {
    border-radius: 0 8px;
    font-size: 0.875rem;
    line-height: 1.286;
    padding: 3px 10px;
  }
}
.post_article .post_head .post_title {
  max-width: 1000px;
  width: 100%;
  font-size: 1.875rem;
  font-weight: 500;
  line-height: 1.5;
  margin: 0 auto 46px;
}
@media screen and (max-width: 767px) {
  .post_article .post_head .post_title {
    font-size: 1.25rem;
    margin-bottom: 16px;
  }
}
.post_article .post_head .post_img {
  display: block;
  max-width: 1000px;
  aspect-ratio: 2/1.25;
  margin: 0 auto;
}
.post_article .post_head .post_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
}
.post_article .post_main {
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0;
}
@media screen and (max-width: 767px) {
  .post_article .post_main {
    max-width: none;
  }
}
.post_article .post_foot {
  border-top: 1px solid var(--c_gray1);
  padding-top: 56px;
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .post_article .post_foot {
    padding-top: 32px;
    margin-top: 48px;
  }
}
.post_article .post_foot .navigation {
  display: flex;
  justify-content: center;
  gap: 16px 24px;
}
@media screen and (max-width: 767px) {
  .post_article .post_foot .navigation {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (min-width: 768px) {
  .post_article .post_foot .btns {
    min-width: 256px;
  }
}
@media screen and (max-width: 767px) {
  .post_article .post_foot .btns {
    max-width: 256px;
    width: 100%;
  }
}
.post_article .post_foot .btn {
  width: 100%;
}

/*== contact ====================================================================================================*/
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ お問い合わせ - 共通
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#page_contact {
  padding: 76px var(--pdX) 0;
}
@media screen and (max-width: 767px) {
  #page_contact {
    padding-top: 45px;
  }
}
#page_contact .hd.main_title {
  margin-bottom: 120px;
}
@media screen and (max-width: 767px) {
  #page_contact .hd.main_title {
    margin-bottom: 40px;
  }
}
#page_contact .blk_intro {
  margin-bottom: 96px;
}
@media screen and (max-width: 767px) {
  #page_contact .blk_intro {
    margin-bottom: 60px;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ お問い合わせ - 入力画面
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#sec_contact_form .hd {
  max-width: 1000px;
  margin: 0 auto 40px;
}
@media screen and (max-width: 767px) {
  #sec_contact_form .hd {
    margin-bottom: 32px;
  }
}
#sec_contact_form .form,
#sec_contact_form #mfp_confirm_table {
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0;
}
@media screen and (max-width: 767px) {
  #sec_contact_form .form,
#sec_contact_form #mfp_confirm_table {
    max-width: none;
  }
}

/*-------------------------
  入力フォーム
-------------------------*/
#sec_contact_form .form_wrap {
  display: flex;
  flex-direction: column;
  row-gap: 0;
}
#sec_contact_form .form_item {
  border-bottom: 1px solid var(--c_gray1);
}
@media screen and (min-width: 768px) {
  #sec_contact_form .form_item {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 0 25px;
    padding: 40px 40px 40px 23px;
  }
}
@media screen and (max-width: 767px) {
  #sec_contact_form .form_item {
    display: flex;
    flex-direction: column;
    row-gap: 12px;
    padding-bottom: 16px;
  }
}
@media screen and (max-width: 767px) {
  #sec_contact_form .form_item:not(:first-of-type) {
    margin-top: 16px;
  }
}
@media screen and (min-width: 768px) {
  #sec_contact_form .form_item:not(:has(.item_main > input:first-child)):not(:has(.item_main > textarea:first-child)):not(:has(.item_main > div:first-child)) .item_title {
    padding-top: 0;
  }
}
@media screen and (min-width: 768px) {
  #sec_contact_form .form_item:not(:has(.item_main > input:first-child)):not(:has(.item_main > textarea:first-child)):not(:has(.item_main > div:first-child)) .item_main {
    padding-top: 2px;
  }
}
#sec_contact_form .item_title {
  color: var(--c_blue1);
  font-weight: 500;
  column-gap: 22px;
}
@media screen and (min-width: 768px) {
  #sec_contact_form .item_title {
    display: grid;
    grid-template-columns: 1fr max-content;
    width: 212px;
    font-size: 1.125rem;
    line-height: 1.556;
    padding-top: 13px;
  }
}
@media screen and (max-width: 767px) {
  #sec_contact_form .item_title {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    line-height: 1.5;
  }
}
#sec_contact_form .item_main {
  display: flex;
  flex-direction: column;
  row-gap: 8px;
  font-size: 1rem;
  line-height: 1.5;
}
#sec_contact_form .item_main:not(:has(> input:first-child)):not(:has(> textarea:first-child)):not(:has(> div:first-child)) {
  padding-top: 15px;
}
#sec_contact_form .required {
  align-self: flex-start;
  display: inline-block;
  background: var(--c_blue2);
  border-radius: 2px;
  color: var(--c_white);
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1;
  padding: 0.5em 0.643em;
}
@media screen and (max-width: 767px) {
  #sec_contact_form .required {
    font-size: 0.75rem;
  }
}
#sec_contact_form label > span {
  padding-left: 1.75em;
  --top: 5px;
}
#sec_contact_form label > span::before {
  top: var(--top);
  bottom: auto;
  width: 1.125em;
  height: auto;
  aspect-ratio: 1/1;
  background-color: var(--c_gray6);
  border-color: var(--c_gray5);
  border-radius: 2px;
  margin: 0;
}
#sec_contact_form label input:focus ~ span::before {
  box-shadow: 0 0 4px var(--c_blue2);
}
#sec_contact_form label input:checked ~ span::before {
  background-color: var(--c_gray5);
}
#sec_contact_form label input[type=radio] ~ span:before {
  border-radius: 100%;
}
#sec_contact_form label input[type=radio] ~ span:after {
  top: calc(var(--top) + 0.25em);
  left: 0.25em;
  width: 0.625em;
  height: auto;
  aspect-ratio: 1/1;
  bottom: auto;
  margin: 0;
  background-color: var(--c_blue2);
}
#sec_contact_form label input[type=checkbox]:checked ~ span:before {
  background-color: var(--c_blue2);
}
#sec_contact_form label input[type=checkbox] ~ span:after {
  top: 8px;
  bottom: auto;
  left: 6px;
  width: 0.4em;
  height: 0.6em;
  bottom: auto;
  margin: 0;
  border-color: var(--c_gray6);
}
#sec_contact_form input {
  max-width: 700px;
  text-align: left !important;
}
#sec_contact_form select {
  background-color: var(--c_white);
}
#sec_contact_form textarea {
  max-width: 700px;
  width: 100%;
  height: 142px;
}
#sec_contact_form .sizeSS {
  max-width: 80px;
  width: 100%;
}
#sec_contact_form .sizeS {
  max-width: 180px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  #sec_contact_form .sizeM {
    max-width: 50%;
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  #sec_contact_form .sizeM {
    max-width: inherit;
  }
}
#sec_contact_form .sizeL {
  max-width: 80%;
}
@media screen and (max-width: 767px) {
  #sec_contact_form .sizeL {
    max-width: inherit;
  }
}
#sec_contact_form .mfp_err {
  color: var(--c_red);
  font-size: 0.875rem;
  margin-top: calc(1em - 8px);
}
#sec_contact_form .mfp_err + .mfp_err {
  margin-top: 0;
}
#sec_contact_form .form_privacy {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-top: 24px;
}
#sec_contact_form .form_privacy .p_txt2 {
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  #sec_contact_form .form_privacy .p_txt2 {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767px) {
  #sec_contact_form .form_privacy .p_txt2 {
    text-align: left;
  }
}
#sec_contact_form .form_privacy a {
  display: inline-block;
  color: var(--c_blue2);
  text-decoration: underline;
  text-underline-offset: 2px;
}
#sec_contact_form .form_privacy a::before, #sec_contact_form .form_privacy a::after {
  content: "";
  display: inline-block;
  padding-left: 0.25em;
}
#sec_contact_form .form_privacy a:hover {
  filter: brightness(2);
}
#sec_contact_form .check {
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: var(--c_blue1);
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.334;
  margin-top: 24px;
}
#sec_contact_form .check label input[type=checkbox] ~ span {
  --top: 0px;
}
#sec_contact_form .check label input[type=checkbox] ~ span::before {
  width: 24px;
}
#sec_contact_form .check label input[type=checkbox] ~ span:after {
  top: calc(var(--top) + 4px);
  left: 8px;
  aspect-ratio: 2/3;
  width: 8px;
  height: auto;
}
#sec_contact_form .submit.btns {
  text-align: center;
  margin-top: 64px;
}
#sec_contact_form .btn {
  max-width: 340px;
  width: 100%;
  min-height: 64px;
  font-size: 1.125rem;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ お問い合わせ - 確認画面
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#mfp_phase_confirm #mfp_confirm_table {
  display: flex;
  flex-direction: column;
  row-gap: 0;
}
#mfp_phase_confirm #mfp_confirm_table tr {
  border: none;
  padding: 0;
  margin: 0;
}
@media screen and (min-width: 768px) {
  #mfp_phase_confirm #mfp_confirm_table tr {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 0 25px;
    padding: 32px 40px 32px 23px;
  }
}
@media screen and (max-width: 767px) {
  #mfp_phase_confirm #mfp_confirm_table tr {
    display: flex;
    flex-direction: column;
    row-gap: 12px;
  }
}
#mfp_phase_confirm #mfp_confirm_table tr:not(:first-of-type) {
  border-top: 1px solid var(--c_gray1);
}
@media screen and (max-width: 767px) {
  #mfp_phase_confirm #mfp_confirm_table tr:not(:first-of-type) {
    padding-top: 16px;
    margin-top: 16px;
  }
}
#mfp_phase_confirm #mfp_confirm_table tr > * {
  padding: 0;
}
#mfp_phase_confirm #mfp_confirm_table th {
  color: var(--c_blue1);
  width: 212px;
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.778;
}
#mfp_phase_confirm #mfp_confirm_table td {
  line-height: 2;
}
#mfp_phase_confirm .mfp_buttons {
  display: flex;
  justify-content: center;
  flex-direction: row-reverse;
  gap: 16px 24px;
  margin-top: 32px;
}
#mfp_phase_confirm .mfp_buttons > * {
  max-width: 256px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  #mfp_phase_confirm .mfp_buttons .btn span {
    min-width: inherit;
  }
}
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ お問い合わせ - 完了画面
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#sec_contact_thanks {
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0;
  line-height: 2;
  padding: 0;
}
@media screen and (max-width: 767px) {
  #sec_contact_thanks {
    max-width: none;
  }
}
#sec_contact_thanks .p_txt1 {
  color: var(--c_blue1);
  margin-bottom: 32px;
}
@media screen and (max-width: 767px) {
  #sec_contact_thanks .p_txt1 {
    text-align: center;
  }
}
#sec_contact_thanks #mfp_thanks {
  font-weight: 500;
  text-align: left;
  padding: 0;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  #sec_contact_thanks #mfp_thanks {
    text-align: center;
  }
}
#sec_contact_thanks #mfp_thanks strong {
  color: var(--c_blue2);
  font-family: "Montserrat", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic Medium", "游ゴシック Medium", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans Japanese", Meiryo, sans-serif;
  font-weight: 500;
  letter-spacing: calc(0em / 1000);
  line-height: 1;
}
@media screen and (max-width: 767px) {
  #sec_contact_thanks #mfp_thanks strong {
    font-size: 1.125rem;
  }
}
#sec_contact_thanks #mfp_thanks + div#mfp_thanks {
  display: none;
}
#sec_contact_thanks .btns {
  margin-top: 64px;
}
@media screen and (max-width: 767px) {
  #sec_contact_thanks .btns {
    text-align: center;
    margin-top: 48px;
  }
}

/*== privacy ====================================================================================================*/
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ プライバシーポリシー
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#page_privacy {
  padding: 85px var(--pdX) 0;
}
@media screen and (max-width: 767px) {
  #page_privacy {
    padding-top: 56px;
  }
}
#page_privacy .innerWrap {
  max-width: 1000px;
}
#page_privacy .hd.main_title {
  margin-bottom: 46px;
}
@media screen and (max-width: 767px) {
  #page_privacy .hd.main_title {
    margin-bottom: 32px;
  }
}
#page_privacy .hd.main_title .jp {
  --c_blue1: var(--c_black);
  font-size: 2.5rem;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  #page_privacy .hd.main_title .jp {
    font-size: 1.75rem;
  }
}
/*== profile ====================================================================================================*/
/*--------------------------------------------
■MV
----------------------------------------------*/
#page_profile .mv {
  margin-top: 147px;
}
@media screen and (max-width: 767px) {
  #page_profile .mv {
    margin-top: 40px;
  }
}
#page_profile .mv .mv_inner {
  padding: 0 40px;
}
@media screen and (max-width: 767px) {
  #page_profile .mv .mv_inner {
    padding: 0 30px;
  }
}
#page_profile .mv .mv_inner .txt_area {
  display: flex;
  align-items: center;
  justify-content: space-between;
  column-gap: 80px;
  margin-bottom: 127px;
}
@media print, screen and (max-width: 1024px) {
  #page_profile .mv .mv_inner .txt_area {
    flex-direction: column;
    align-items: flex-start;
    row-gap: 45px;
    margin-bottom: 29px;
  }
}
#page_profile .mv .mv_inner .txt_area .hd {
  flex-shrink: 0;
}
#page_profile .mv .mv_inner .txt_area .hd .jp {
  max-width: 490px;
}
#page_profile .mv .mv_inner .txt_area .catch {
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.59375;
  margin-top: 31px;
  color: var(--c_blue1);
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  #page_profile .mv .mv_inner .txt_area .catch {
    font-size: 1.1875rem;
    line-height: 1.6842105263;
    margin-top: 0;
  }
}
#page_profile .mv .mv_inner .txt_area .catch > font + br {
  display: none;
}
#page_profile .mv .img_area {
  width: 100%;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding-left: max(50% - 720px, 40px);
  column-gap: 6px;
}
@media screen and (max-width: 767px) {
  #page_profile .mv .img_area {
    column-gap: 2px;
    padding-left: max(50% - 720px, 30px);
  }
}
#page_profile .mv .img_area li {
  overflow: hidden;
  width: 300px;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  #page_profile .mv .img_area li {
    width: 147px;
  }
}
#page_profile .mv .img_area li:nth-child(1) {
  border-radius: 0 120px 0 120px;
}
@media screen and (max-width: 767px) {
  #page_profile .mv .img_area li:nth-child(1) {
    border-radius: 0 48px 0 48px;
  }
}
#page_profile .mv .img_area li:nth-child(2) {
  border-radius: 120px 0 120px 0;
}
@media screen and (max-width: 767px) {
  #page_profile .mv .img_area li:nth-child(2) {
    border-radius: 48px 0 48px 0;
  }
}
#page_profile .mv .img_area li:nth-child(3) {
  border-radius: 0 120px 0 0;
}
@media screen and (max-width: 767px) {
  #page_profile .mv .img_area li:nth-child(3) {
    border-radius: 0 48px 0 0;
  }
}
#page_profile .mv .img_area li:nth-child(4) {
  border-radius: 120px 0 120px 0;
}
@media screen and (max-width: 767px) {
  #page_profile .mv .img_area li:nth-child(4) {
    border-radius: 48px 0 48px 0;
  }
}
#page_profile .mv .img_area li:nth-child(5) {
  border-radius: 0 0 0 120px;
}
@media screen and (max-width: 767px) {
  #page_profile .mv .img_area li:nth-child(5) {
    border-radius: 0 0 0 48px;
  }
}
#page_profile .mv .img_area li:nth-child(6) {
  border-radius: 120px 0 0 0;
}
@media screen and (max-width: 767px) {
  #page_profile .mv .img_area li:nth-child(6) {
    border-radius: 48px 0 0 0;
  }
}
#page_profile .mv .img_area li:nth-child(7) {
  border-radius: 120px 0 0 0;
}
@media screen and (max-width: 767px) {
  #page_profile .mv .img_area li:nth-child(7) {
    border-radius: 48px 0 0 0;
  }
}
#page_profile .mv .img_area li img {
  width: 100%;
  height: auto;
}

/*--------------------------------------------
■profile_table
----------------------------------------------*/
#page_profile .profile_table {
  margin-top: 96px;
  padding: 0 40px;
}
@media screen and (max-width: 767px) {
  #page_profile .profile_table {
    margin-top: 44px;
    padding: 0 24px 0 29px;
  }
}
#page_profile .profile_table table {
  border-collapse: collapse;
  width: 100%;
}
#page_profile .profile_table table tr {
  display: flex;
  width: 100%;
  border-bottom: 1px solid var(--c_gray1);
}
@media screen and (max-width: 767px) {
  #page_profile .profile_table table tr {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  #page_profile .profile_table table tr:first-child th {
    padding: 0 0 10px;
  }
}
#page_profile .profile_table table th, #page_profile .profile_table table td {
  text-align: left;
}
@media screen and (max-width: 767px) {
  #page_profile .profile_table table th, #page_profile .profile_table table td {
    display: block;
  }
}
#page_profile .profile_table table th {
  padding: 29px 0 32px 30px;
  width: 22.95%;
  min-width: 190px;
  display: flex;
  align-items: center;
  margin-top: 2px;
}
@media screen and (max-width: 767px) {
  #page_profile .profile_table table th {
    width: 100%;
    border: none;
    padding: 24px 0 13px;
    margin-top: 0;
  }
}
#page_profile .profile_table table th span {
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--c_blue1);
  margin-right: 30px;
}
@media screen and (max-width: 767px) {
  #page_profile .profile_table table th span {
    margin-right: 0;
    font-size: 1rem;
  }
}
#page_profile .profile_table table td {
  width: 77.05%;
  font-size: 1.0625rem;
  padding: 29px 10px 29px 0;
  line-height: 1.8235294118;
}
@media screen and (max-width: 767px) {
  #page_profile .profile_table table td {
    padding: 0 0 19px;
    font-size: 1rem;
    line-height: 1.6875;
    width: 100%;
  }
}
#page_profile .profile_table table ol li {
  margin-bottom: 12px;
  text-indent: -15px;
  padding-left: 14px;
}
@media screen and (max-width: 767px) {
  #page_profile .profile_table table ol li {
    text-indent: 0;
    padding-left: 0;
    margin-bottom: 13px;
  }
}
#page_profile .profile_table table ol li:last-child {
  margin-bottom: 0;
}
#page_profile .profile_table table .group_name {
  margin-top: 14px;
}
@media screen and (max-width: 767px) {
  #page_profile .profile_table table .group_name {
    margin-top: 20px;
  }
}

/*== message ====================================================================================================*/
.body_message #breadcrumbs {
  z-index: 1;
}

#page_message .message_bg {
  overflow: hidden;
  position: fixed;
  top: 146px;
  left: 0;
  width: 100%;
  height: 972px;
  transition: filter 0.6s ease;
  filter: blur(0);
}
@media screen and (max-width: 767px) {
  #page_message .message_bg {
    height: 446px;
    top: 207px;
  }
}
#page_message .message_bg .bg_position {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  min-width: 1920px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  #page_message .message_bg .bg_position {
    min-width: 885px;
    left: 35%;
  }
}
#page_message .message_bg .bg_position img {
  display: none;
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  #page_message .message_bg .bg_position img.spCont {
    display: block;
  }
}
@media screen and (min-width: 768px) {
  #page_message .message_bg .bg_position img.pcCont {
    display: block;
  }
}
#page_message .message_bg:has(~ .philosophy.aos-animate) {
  filter: blur(20px);
}
#page_message .mv {
  margin-top: 150px;
  padding: 0 40px;
}
@media screen and (max-width: 767px) {
  #page_message .mv {
    margin-top: 45px;
    padding: 0 30px;
  }
}
#page_message .introduction {
  margin-top: 109px;
  padding: 0 40px;
}
@media screen and (max-width: 767px) {
  #page_message .introduction {
    margin-top: 40px;
    padding: 0 30px;
  }
}
#page_message .introduction .innerWrap {
  max-width: 1280px;
}
#page_message .introduction .innerWrap .hd_txt {
  font-size: 2rem;
  font-weight: 500;
  color: var(--c_blue1);
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  #page_message .introduction .innerWrap .hd_txt {
    font-size: 1.375rem;
    margin-bottom: 20px;
    line-height: 1.6363636364;
  }
}
#page_message .introduction .innerWrap .txt_block {
  margin-bottom: 42px;
  display: flex;
  flex-direction: column;
  row-gap: 48px;
}
@media screen and (max-width: 767px) {
  #page_message .introduction .innerWrap .txt_block {
    row-gap: 33px;
    margin-bottom: 32px;
  }
}
#page_message .introduction .innerWrap .txt_block .txt.medium {
  font-size: 1.1875rem;
  font-weight: 500;
  line-height: 2.6315789474;
}
@media screen and (max-width: 767px) {
  #page_message .introduction .innerWrap .txt_block .txt.medium {
    font-size: 1.0625rem;
    line-height: 2;
  }
}
#page_message .introduction .innerWrap .txt_block .txt.medium .color {
  color: var(--c_blue2);
}
#page_message .introduction .innerWrap .txt_block p.txt.medium > font + br {
  display: none;
}
#page_message .introduction .innerWrap .name {
  text-align: right;
  font-size: 1.25rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  #page_message .introduction .innerWrap .name {
    font-size: 1.125rem;
  }
}
#page_message .introduction .innerWrap .name span {
  font-size: 1rem;
  display: inline-block;
  margin-right: 16px;
}
@media screen and (max-width: 767px) {
  #page_message .introduction .innerWrap .name span {
    font-size: 0.9375rem;
  }
}
#page_message .philosophy {
  margin-top: 208px;
  padding: 0 40px;
}
@media screen and (max-width: 767px) {
  #page_message .philosophy {
    margin-top: 87px;
    padding: 0 30px;
  }
}
#page_message .philosophy .philosophy_block {
  display: flex;
  justify-content: center;
  column-gap: min(5.5555555556 * var(--vw), 80px);
  margin-top: 56px;
}
@media screen and (max-width: 767px) {
  #page_message .philosophy .philosophy_block {
    flex-direction: column;
    column-gap: 0;
    row-gap: 24px;
    margin-top: 28px;
  }
}
#page_message .philosophy .philosophy_block .box {
  width: 47.22%;
  width: min(47.2222222222 * var(--vw), 680px);
  box-shadow: 0px 0px 12px rgba(0, 0, 0, 0.1);
  border-radius: 16px min(11.1111111111 * var(--vw), 160px) 16px 40px;
  background-color: #fff;
  padding: min(3.8541666667 * var(--vw), 74px) min(5 * var(--vw), 96px) min(4.21875 * var(--vw), 81px);
}
@media print, screen and (max-width: 1024px) {
  #page_message .philosophy .philosophy_block .box {
    padding: min(2.63671875 * var(--vw), 27px) min(2.734375 * var(--vw), 28px) min(3.125 * var(--vw), 32px);
  }
}
@media screen and (max-width: 767px) {
  #page_message .philosophy .philosophy_block .box {
    width: 100%;
    border-radius: 8px min(80 / var(--vp) * var(--vw), 85px) 8px 8px;
    padding: 39px 32px 33px;
  }
}
#page_message .philosophy .philosophy_block .box .hd.row_title {
  margin-bottom: 34px;
}
@media print, screen and (max-width: 1024px) {
  #page_message .philosophy .philosophy_block .box .hd.row_title {
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 22px;
  }
}
@media screen and (max-width: 767px) {
  #page_message .philosophy .philosophy_block .box .hd.row_title {
    margin-bottom: 27px;
  }
}
#page_message .philosophy .philosophy_block .box .hd_txt {
  margin-bottom: 16px;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.5;
  color: var(--c_blue1);
}
@media print, screen and (max-width: 1024px) {
  #page_message .philosophy .philosophy_block .box .hd_txt {
    font-size: 1.75rem;
    margin-bottom: 14px;
  }
}
@media screen and (max-width: 767px) {
  #page_message .philosophy .philosophy_block .box .hd_txt {
    margin-bottom: 10px;
    font-size: 1.1875rem;
    line-height: 1.6315789474;
  }
}
#page_message .philosophy .philosophy_block .box .txt {
  line-height: 2;
}
@media screen and (max-width: 767px) {
  #page_message .philosophy .philosophy_block .box .txt {
    font-size: 0.9375rem;
    line-height: 1.8;
  }
}
#page_message .value {
  margin-top: 162px;
  padding: 0 40px;
}
@media screen and (max-width: 767px) {
  #page_message .value {
    margin-top: 62px;
    padding: 0 30px;
  }
}
#page_message .value .value_list {
  max-width: 1438px;
  margin-top: 60px;
  display: flex;
  justify-content: center;
  column-gap: min(6.1891515994 * var(--vw), 89px);
}
@media print, screen and (max-width: 1024px) {
  #page_message .value .value_list {
    column-gap: min(3.90625 * var(--vw), 40px);
  }
}
@media screen and (max-width: 767px) {
  #page_message .value .value_list {
    margin-top: 26px;
    flex-direction: column;
    column-gap: 0;
    row-gap: 38px;
  }
}
#page_message .value .value_list li {
  width: min(29.207232267 * var(--vw), 420px);
}
@media screen and (max-width: 767px) {
  #page_message .value .value_list li {
    width: 100%;
  }
}
#page_message .value .value_list li figure {
  border-radius: 0 min(8.3449235049 * var(--vw), 120px) 0 0;
  overflow: hidden;
  margin-bottom: 29px;
}
@media screen and (max-width: 767px) {
  #page_message .value .value_list li figure {
    border-radius: 0 120px 0 0;
    margin-bottom: 19px;
  }
}
#page_message .value .value_list li figure img {
  width: 100%;
  height: auto;
}
#page_message .value .value_list li h3 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  margin-bottom: 28px;
}
@media screen and (max-width: 767px) {
  #page_message .value .value_list li h3 {
    margin-bottom: 17px;
  }
}
#page_message .value .value_list li h3 .en {
  position: relative;
  padding-bottom: 12px;
  margin-bottom: 15px;
  font-size: 2rem;
  font-weight: 500;
  color: var(--c_blue1);
}
@media print, screen and (max-width: 1024px) {
  #page_message .value .value_list li h3 .en {
    font-size: 1.625rem;
  }
}
@media screen and (max-width: 767px) {
  #page_message .value .value_list li h3 .en {
    font-size: 1.75rem;
    margin-bottom: 13px;
  }
}
#page_message .value .value_list li h3 .en::first-letter {
  color: var(--c_blue2);
}
#page_message .value .value_list li h3 .en::after {
  content: "";
  display: block;
  width: min(24.8333333333 * var(--vw), 298px);
  height: 1px;
  background-color: var(--c_blue2);
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  #page_message .value .value_list li h3 .en::after {
    width: min(66.6666666667 * var(--vw), 360px);
  }
}
#page_message .value .value_list li h3 .jp {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--c_blue1);
}
@media print, screen and (max-width: 1024px) {
  #page_message .value .value_list li h3 .jp {
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 767px) {
  #page_message .value .value_list li h3 .jp {
    font-size: 1.25rem;
  }
}
#page_message .value .value_list li .txt {
  line-height: 1.8125;
}
@media screen and (max-width: 767px) {
  #page_message .value .value_list li .txt {
    font-size: 0.9375rem;
    line-height: 1.8;
  }
}

/*== strength ====================================================================================================*/
/*-------------------------
  Dummy
-------------------------*/
.dami {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  background: #c92e7e;
}
.dami img {
  width: 100%;
  height: auto;
  mix-blend-mode: screen;
}
body:not(.test_local) .dami {
  display: none;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ わたしたちの強み - 下層共通
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/*-------------------------
  下層共通
-------------------------*/
/* 下層ナビ */
@media screen and (max-width: 767px) {
  .page_strength .local_nav {
    margin-top: 26px;
  }
}

/*-------------------------
  ページタイトル（ファーストビュー）
-------------------------*/
/* ページタイトル（ファーストビュー） */
#pagetitle.pattern2 {
  padding: 0 var(--pdX);
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern2 {
    --vp: 12.80;
    --pdX: min(calc(40 / var(--vp) * var(--vw)), 40px);
  }
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern2 .innerWrap {
    display: grid;
    grid-template-columns: 1fr max-content;
    grid-template-rows: max-content 1fr;
    column-gap: 26px;
  }
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern2 .innerWrap .hd {
    grid-area: 1/1/2/2;
  }
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern2 .innerWrap .catch {
    grid-area: 2/1/3/2;
  }
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern2 .innerWrap .img {
    grid-area: 1/2/3/3;
  }
}
.local_nav + #pagetitle.pattern2 {
  margin-top: min(148 / var(--vp) * var(--vw), 148px);
}
@media screen and (max-width: 767px) {
  .local_nav + #pagetitle.pattern2 {
    margin-top: 41px;
  }
}
#pagetitle.pattern2 .hd.main_title {
  position: relative;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern2 .hd.main_title {
    row-gap: 0.22em;
    padding-top: 18px;
    padding-left: min(166 / var(--vp) * var(--vw), 166px);
    margin-bottom: min(43 / var(--vp) * var(--vw), 43px);
  }
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern2 .hd.main_title {
    row-gap: 0.35em;
    padding-top: 10px;
    padding-left: 88px;
    margin-bottom: 46px;
  }
}
#pagetitle.pattern2 .hd.main_title > span::after {
  display: none;
}
#pagetitle.pattern2 .hd.main_title .icon {
  position: absolute;
  top: 2px;
  left: 6px;
  z-index: -1;
  color: var(--c_blue1);
  fill: currentColor;
  width: min(112 / var(--vp) * var(--vw), 112px);
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern2 .hd.main_title .icon {
    top: 0;
    left: -5px;
    width: 72px;
  }
}
#pagetitle.pattern2 .hd.main_title .jp {
  font-size: min(56 / var(--vp) * var(--vw), 56px);
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern2 .hd.main_title .jp {
    font-size: 2rem;
  }
}
html:not([lang=en]) #pagetitle.pattern2 .hd.main_title .jp {
  font-weight: 500;
}
#pagetitle.pattern2 .hd.main_title .en {
  font-size: min(26 / var(--vp) * var(--vw), 26px);
  text-transform: capitalize;
  font-weight: 500;
  word-break: auto-phrase;
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern2 .hd.main_title .en {
    font-size: 1rem;
  }
}
#pagetitle.pattern2 .catch {
  color: var(--c_blue1);
  font-size: min(32 / var(--vp) * var(--vw), 32px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: var(--ls50);
  word-break: auto-phrase;
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern2 .catch {
    font-size: 1.375rem;
    line-height: 1.6363;
  }
}
#pagetitle.pattern2 .img {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern2 .img {
    width: min(526 / var(--vp) * var(--vw), 526px);
  }
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern2 .img {
    gap: calc(4 / var(--vp) * var(--vw));
    margin-top: 27px;
  }
}
#pagetitle.pattern2 .img img {
  width: 100%;
  height: auto;
}
#pagetitle.pattern2 .img img:nth-child(odd) {
  border-radius: 0 min(120 / var(--vp) * var(--vw), 120px);
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern2 .img img:nth-child(odd) {
    border-radius: 0 min(80 / var(--vp) * var(--vw), 80px);
  }
}
#pagetitle.pattern2 .img img:nth-child(even) {
  border-radius: min(120 / var(--vp) * var(--vw), 120px) 0;
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern2 .img img:nth-child(even) {
    border-radius: min(80 / var(--vp) * var(--vw), 80px) 0;
  }
}

/* アニメーション */
#pagetitle.pattern2 .catch {
  animation: fade_in_up 0.25s cubic-bezier(0.5, 0.8, 0.5, 1) forwards;
  opacity: 0;
  transform: translate3d(calc(var(--num) * -1), var(--num), 0);
}

/* ポイント */
#blk_checkbox {
  margin-top: 90px;
  padding: 0 var(--pdX);
}
@media screen and (max-width: 767px) {
  #blk_checkbox {
    padding: 0 var(--pdX);
    margin-top: 40px;
    margin-top: 46px;
  }
}

.list_checkbox {
  display: grid;
}
@media screen and (min-width: 768px) {
  .list_checkbox {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .list_checkbox {
    border-top: 1px solid var(--c_gray5);
  }
}
@media screen and (min-width: 768px) {
  .list_checkbox > * {
    border-left: 1px solid var(--c_gray5);
    --vp: 12.80;
    padding: 20px min(55 / var(--vp) * var(--vw), 55px) 15px min(45 / var(--vp) * var(--vw), 45px);
  }
}
@media screen and (max-width: 767px) {
  .list_checkbox > * {
    border-bottom: 1px solid var(--c_gray5);
    padding-top: 24px;
    padding-bottom: 20px;
  }
}
@media screen and (min-width: 768px) {
  .list_checkbox > *:nth-child(3n) {
    border-right: 1px solid var(--c_gray5);
  }
}
.list_checkbox .hd {
  margin-bottom: 13px;
}
@media screen and (max-width: 767px) {
  .list_checkbox .hd {
    margin-bottom: 12px;
  }
}
@media screen and (max-width: 767px) {
  .list_checkbox .p_txt3 {
    line-height: 1.8125;
  }
}

/* フロー */
.sec_flow {
  padding: 0 var(--pdX);
  margin-top: 170px;
  margin-bottom: 166px;
}
@media screen and (max-width: 767px) {
  .sec_flow {
    padding: 0 var(--pdX);
    margin-top: 55px;
    margin-bottom: 80px;
  }
}
.sec_flow .hd {
  margin-bottom: 32px;
}
@media screen and (max-width: 767px) {
  .sec_flow .hd {
    word-break: auto-phrase;
    line-height: 1.5;
    margin-bottom: 16px;
  }
}
@media screen and (max-width: 767px) {
  .sec_flow .p_txt2 {
    font-size: 1rem;
    line-height: 2;
  }
}
.sec_flow .list_flow {
  margin-top: 72px;
}
@media screen and (max-width: 767px) {
  .sec_flow .list_flow {
    margin-top: 34px;
  }
}

.list_flow {
  counter-reset: listnum;
}
@media screen and (max-width: 767px) {
  .list_flow {
    margin: 0 calc(var(--pdX) * -1);
  }
}
.list_flow > * {
  overflow: inherit;
  position: relative;
  z-index: 1;
  counter-increment: listnum;
}
@media screen and (min-width: 768px) {
  .list_flow > * {
    display: grid;
    grid-template-columns: max-content 1fr;
    --vp: 12.80;
    column-gap: min(120 / var(--vp) * var(--vw), 120px);
  }
}
@media screen and (max-width: 767px) {
  .list_flow > * {
    display: block;
    padding: 36px calc(var(--pdX) + 30px) 0 var(--pdX);
  }
}
.list_flow > *::before, .list_flow > *::after {
  width: 80px;
  background: var(--color);
}
@media screen and (max-width: 767px) {
  .list_flow > *::before, .list_flow > *::after {
    position: absolute;
    top: 0;
    right: 0;
    width: 30px;
  }
}
.list_flow > *::before {
  grid-area: 1/1/3/2;
  content: counter(listnum, decimal-leading-zero);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: rgba(255, 255, 255, 0.3);
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: var(--ls50);
  padding-top: 2em;
}
@media screen and (max-width: 767px) {
  .list_flow > *::before {
    font-size: 1rem;
    height: 100%;
  }
}
.list_flow > *::after {
  content: "";
  position: absolute;
  z-index: 1;
  top: 100%;
  left: 0;
  aspect-ratio: 2;
  clip-path: polygon(50% 100%, 100% 0, 0 0);
}
@media screen and (max-width: 767px) {
  .list_flow > *::after {
    left: auto;
    height: 20.5px;
  }
}
.list_flow > * .hd {
  grid-area: 1/2/2/3;
}
.list_flow > * .detail {
  grid-area: 2/2/3/3;
}
@media screen and (max-width: 767px) {
  .list_flow > *:first-child {
    padding-top: 0;
  }
}
.list_flow > *:first-child .hd {
  margin-top: 32px;
}
@media screen and (max-width: 767px) {
  .list_flow > *:first-child .hd {
    margin-top: 0;
  }
}
.list_flow > *:last-child .detail {
  padding-bottom: 12px;
}
.list_flow .hd {
  position: relative;
  column-gap: 29px;
  color: var(--c_white);
  font-size: 1.875rem;
  font-weight: 500;
  line-height: 1.5;
  margin-top: 71px;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .list_flow .hd {
    display: grid;
    grid-template-columns: max-content 1fr;
    align-items: center;
    column-gap: 22px;
    word-break: auto-phrase;
    font-size: 1.25rem;
    margin-top: 0;
    margin-bottom: 21px;
  }
}
.list_flow .hd::before {
  content: counter(listnum, decimal-leading-zero);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  aspect-ratio: 1/1;
  width: 74px;
  background: var(--color);
  border-radius: 0 32px;
  font-size: 1.9375rem;
  font-weight: 500;
  letter-spacing: var(--ls50);
}
@media screen and (max-width: 767px) {
  .list_flow .hd::before {
    width: 56px;
    font-size: 1.5rem;
    border-radius: 0 24px;
  }
}
html:not([lang=en]) .list_flow .hd .jp:only-of-type {
  font-size: 100%;
}
.list_flow .detail dl {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  row-gap: 18px;
  margin-top: 18px;
}
@media screen and (max-width: 767px) {
  .list_flow .detail dl {
    row-gap: 26px;
    margin-top: 24px;
  }
}
.list_flow .detail dt {
  position: relative;
  color: var(--c_blue2);
  font-weight: 700;
  padding-left: 20px;
}
@media screen and (max-width: 767px) {
  .list_flow .detail dt {
    margin-bottom: 3px;
  }
}
.list_flow .detail dt::before {
  content: "";
  position: absolute;
  top: calc((2.11em - 12px) / 2);
  left: 0;
  aspect-ratio: 1/1;
  width: 12px;
  border-radius: 100%;
  background-color: currentColor;
}
@media screen and (max-width: 767px) {
  .list_flow .detail dt::before {
    top: calc((1.8125em - 12px) / 2);
  }
}
@media screen and (max-width: 767px) {
  .list_flow .detail dd {
    line-height: 1.8125;
  }
}
.list_flow > *:nth-child(1) {
  z-index: 6;
  --color: var(--c_blue1);
}
.list_flow > *:nth-child(2) {
  z-index: 5;
  --color: #1D4E7A;
}
.list_flow > *:nth-child(3) {
  z-index: 4;
  --color: #2A6295;
}
.list_flow > *:nth-child(4) {
  z-index: 3;
  --color: #3670A5;
}
.list_flow > *:nth-child(5) {
  z-index: 2;
  --color: #4282BB;
}
.list_flow > *:nth-child(6) {
  z-index: 1;
  --color: #5496D1;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ 用地開発
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ 設計・施工
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/*== service ====================================================================================================*/
/*-------------------------
  Dummy
-------------------------*/
.dami {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  background: #c92e7e;
}
.dami img {
  width: 100%;
  height: auto;
  mix-blend-mode: screen;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ 事業内容 - 下層共通
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/*-------------------------
  ページタイトル（ファーストビュー）
-------------------------*/
#pagetitle.pattern3 {
  position: relative;
  background: var(--c_blue1);
  color: var(--c_white);
  --bdrs: min(calc(600 / var(--vp) * var(--vw)), 600px);
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern3 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    min-height: 600px;
  }
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern3 {
    --bdrs: min(calc(200 / var(--vp) * var(--vw)), 200px);
  }
}
.local_nav + #pagetitle.pattern3 {
  margin-top: min(27 / var(--vp) * var(--vw), 27px);
}
@media screen and (max-width: 767px) {
  .local_nav + #pagetitle.pattern3 {
    margin-top: min(18 / var(--vp) * var(--vw), 18px);
  }
}
#pagetitle.pattern3 > .text_wrap,
#pagetitle.pattern3 > .img_wrap {
  position: relative;
  z-index: 0;
}
#pagetitle.pattern3 > .text_wrap::after,
#pagetitle.pattern3 > .img_wrap::after {
  opacity: 0.5;
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#pagetitle.pattern3 > .text_wrap::after {
  background: linear-gradient(135deg, var(--c_blue2) 0%, var(--c_blue1) 60%);
  border-radius: var(--bdrs) 0 0 0;
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern3 > .text_wrap::after {
    background: linear-gradient(135deg, var(--c_blue2) 0%, var(--c_blue1) 45%);
  }
}
#pagetitle.pattern3 > .img_wrap::after {
  background: linear-gradient(-45deg, var(--c_blue2) 0%, var(--c_blue1) 60%);
  border-radius: 0 0 var(--bdrs) 0;
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern3 > .img_wrap::after {
    background: linear-gradient(-45deg, var(--c_blue2) 0%, var(--c_blue1) 45%);
  }
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern3 .text_wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    --pdY: 40px;
    padding: calc(var(--pdY) + 16px) var(--pdX) var(--pdY) min(130 / var(--vp) * var(--vw), 130px);
  }
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern3 .text_wrap {
    padding: 70px var(--pdX) 56px;
  }
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern3 .text_wrap_inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    row-gap: 30px;
    max-width: 550px;
    width: 100%;
  }
}
#pagetitle.pattern3 .hd.main_title {
  display: inline-block;
  font-weight: 500;
  letter-spacing: var(--ls50);
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern3 .hd.main_title {
    font-size: 4rem;
  }
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern3 .hd.main_title {
    font-size: 1.75rem;
  }
}
#pagetitle.pattern3 .hd.main_title:first-letter {
  color: var(--c_blue3);
}
@media screen and (min-width: 768px) {
  #pagetitle.pattern3 .hd.main_title > span::after {
    top: -12px;
    right: -30px;
    width: 31px;
  }
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern3 .hd.main_title > span::after {
    right: min(-24 / var(--vp) * var(--vw), -24px);
  }
}
#pagetitle.pattern3 .hd.main_title small {
  font-size: 1.625rem;
  font-weight: 600;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern3 .hd.main_title small {
    font-size: 1.125rem;
  }
}
#pagetitle.pattern3 .catch {
  font-size: 1.75rem;
  line-height: 1.6;
  letter-spacing: var(--ls50);
  word-break: auto-phrase;
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern3 .catch {
    font-size: 1.125rem;
    line-height: 1.5;
    margin-top: 16px;
  }
}
#pagetitle.pattern3 .img_wrap {
  display: flex;
  width: 100%;
}
#pagetitle.pattern3 .img {
  overflow: hidden;
  opacity: 0.6;
  border-radius: 0 var(--bdrs);
}
@media screen and (max-width: 767px) {
  #pagetitle.pattern3 .img {
    --bdrs: min(calc(180 / var(--vp) * var(--vw)), 180px);
  }
}
#pagetitle.pattern3 .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

/* アニメーション */
#pagetitle.pattern3 .catch {
  animation: fade_in_up 0.25s cubic-bezier(0.5, 0.8, 0.5, 1) forwards;
  opacity: 0;
  transform: translate3d(calc(var(--num) * -1), var(--num), 0);
}

/*-------------------------
	導入～流れ
-------------------------*/
.about {
  padding: 157px var(--pdX) 0;
}
@media screen and (max-width: 767px) {
  .about {
    padding-top: 44px;
  }
}
.about .copy {
  word-break: auto-phrase;
  color: var(--c_blue1);
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.916;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .about .copy {
    font-size: 1.125rem;
    line-height: 2;
  }
}
.about .copy .color {
  color: var(--c_blue2);
}
.about .flow_nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  max-width: 1280px;
  color: var(--c_white);
  font-size: 1.125rem;
  font-weight: 500;
  margin: 56px auto 0;
}
@media screen and (max-width: 767px) {
  .about .flow_nav {
    grid-template-columns: repeat(1, 1fr);
    font-size: 1rem;
    margin-top: 24px;
  }
}
.about li {
  position: relative;
  background-color: var(--color);
}
@media screen and (min-width: 768px) {
  .about li {
    display: flex;
    justify-content: center;
    align-items: center;
    column-gap: 42px;
    min-height: 100px;
    --pdY: 12px;
    padding: var(--pdY) 36px var(--pdY) 12px;
  }
}
@media screen and (max-width: 767px) {
  .about li {
    display: grid;
    grid-template-columns: max-content 1fr;
    align-items: center;
    text-align: center;
    padding: 24px 56px 20px 24px;
    column-gap: 32px;
  }
}
.about li::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  aspect-ratio: 21/50;
  height: 100%;
  clip-path: polygon(100% 0, 100% 100%, 0% 100%, 100% 50%, 0% 0%);
  background: var(--next);
}
@media screen and (max-width: 767px) {
  .about li::before {
    display: none;
  }
}
.about li:nth-child(3n) {
  --next: var(--c_white);
}
.about li:nth-child(1) {
  --color: var(--c_blue1);
  --next: #1D4E7A;
}
.about li:nth-child(2) {
  --color: #1D4E7A;
  --next: #2A6295;
}
.about li:nth-child(3) {
  --color: #2A6295;
}
.about li:nth-child(4) {
  --color: #3670A5;
  --next: #4282BB;
}
.about li:nth-child(5) {
  --color: #4282BB;
  --next: #5496D1;
}
.about li:nth-child(6) {
  --color: #5496D1;
}
.about .num {
  font-size: 1.75rem;
  letter-spacing: var(--ls50);
}
@media screen and (max-width: 767px) {
  .about .num {
    font-size: 1.5rem;
  }
}

/*-------------------------
  ブロック
-------------------------*/
.blk_service {
  display: flex;
  flex-direction: column;
  row-gap: 150px;
  margin-top: 160px;
  counter-reset: listnum;
}
@media screen and (max-width: 767px) {
  .blk_service {
    row-gap: 42px;
    margin-top: 48px;
  }
}
.blk_service .sec_block {
  counter-increment: listnum;
  padding: 0 var(--pdX);
  --bdrs: min(calc(600 / var(--vp) * var(--vw)), 600px);
}
@media screen and (max-width: 767px) {
  .blk_service .sec_block {
    --bdrs: 180px;
  }
}
.blk_service .img {
  position: relative;
  z-index: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--c_blue1);
  color: var(--c_white);
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 2.133;
  padding: var(--pdX);
  margin: 0 calc(var(--pdX) * -1) 80px;
}
@media screen and (min-width: 768px) {
  .blk_service .img {
    aspect-ratio: 43/15;
  }
}
@media screen and (max-width: 767px) {
  .blk_service .img {
    min-height: 360px;
    font-size: 1.125rem;
    margin-bottom: 36px;
  }
}
.blk_service .img img {
  object-fit: cover;
  opacity: 0.5;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.blk_service .copy {
  word-break: auto-phrase;
  color: var(--c_blue2);
  font-size: 1.75rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: var(--ls50);
  margin-bottom: 36px;
}
@media screen and (max-width: 767px) {
  .blk_service .copy {
    font-size: 1.125rem;
    margin-bottom: 20px;
  }
}
.blk_service .hd {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 5px 42px;
  line-height: 1.5;
  margin-bottom: 45px;
}
@media screen and (max-width: 767px) {
  .blk_service .hd {
    gap: 5px 25px;
    margin-bottom: 22px;
  }
}
.blk_service .hd::before {
  grid-area: 1/1/3/2;
  content: counter(listnum, decimal-leading-zero);
  aspect-ratio: 1/1;
  width: 96px;
  background: #1D4E7A;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 0 32px;
  color: var(--c_white);
  font-size: 2.5rem;
  font-weight: 500;
  letter-spacing: var(--ls50);
}
@media screen and (max-width: 767px) {
  .blk_service .hd::before {
    width: 56px;
    font-size: 1.5rem;
    border-radius: 0 24px;
  }
}
html[lang=en] .blk_service .hd::before {
  grid-area: 1/1/2/2;
}
.blk_service .hd .jp {
  grid-area: 1/2/2/3;
  align-self: flex-end;
  color: var(--c_blue1);
}
html:not([lang=en]) .blk_service .hd .jp {
  font-size: 1.875rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  html:not([lang=en]) .blk_service .hd .jp {
    font-size: 1.1875rem;
  }
}
html[lang=en] .blk_service .hd .jp {
  grid-area: 1/2/2/3;
  align-self: center;
}
.blk_service .hd .en {
  grid-area: 2/2/3/3;
  color: var(--c_blue4);
  font-size: 1.3125rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .blk_service .hd .en {
    font-size: 0.9375rem;
  }
}
.blk_service .hd .en:first-letter {
  color: inherit;
}
@media screen and (max-width: 767px) {
  .blk_service .p_txt2 {
    font-size: 1rem;
    line-height: 2;
  }
}
.blk_service dl {
  display: flex;
  flex-direction: column;
  row-gap: 20px;
  margin-top: 36px;
}
@media screen and (max-width: 767px) {
  .blk_service dl {
    margin-top: 25px;
  }
}
@media screen and (max-width: 767px) {
  .blk_service dl.p_txt2 {
    line-height: 1.8125;
  }
}
.blk_service dt {
  position: relative;
  color: var(--c_blue2);
  font-weight: 700;
  padding-left: 24px;
}
@media screen and (max-width: 767px) {
  .blk_service dt {
    margin-bottom: 5px;
  }
}
.blk_service dt::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 3px;
  aspect-ratio: 1/1;
  width: 12px;
  background: currentColor;
  clip-path: circle(50% at 50% 50%);
}
@media screen and (max-width: 767px) {
  .blk_service dt::before {
    top: 8px;
  }
}
/* アニメーション */
.blk_service .sec_block .img[data-aos=is-show] img {
  transition: all 0.25s cubic-bezier(0.5, 0.8, 0.5, 1);
  transition-delay: 0.4s;
}
.blk_service .sec_block .img[data-aos=is-show]:not(.aos-animate) img {
  border-radius: 0;
}
.blk_service .sec_block .img[data-aos=is-show].aos-animate img {
  border-radius: 0 var(--bdrs);
}
.blk_service .sec_block:nth-child(even) .img[data-aos=is-show].aos-animate img {
  border-radius: var(--bdrs) 0;
}

/*-------------------------
  他の事業　バナー
-------------------------*/
#other_service {
  padding: 0 var(--pdX);
  margin-top: 153px;
}
@media screen and (max-width: 767px) {
  #other_service {
    margin-top: 64px;
  }
}
#other_service .hd.row_title {
  text-transform: uppercase;
  margin-bottom: 36px;
}
@media screen and (max-width: 767px) {
  #other_service .hd.row_title {
    margin-bottom: 26px;
  }
}
@media screen and (min-width: 768px) {
  #other_service .hd.row_title .jp {
    font-size: 1.25rem;
  }
}
.list_bnr {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
}
@media screen and (max-width: 767px) {
  .list_bnr {
    grid-template-columns: repeat(1, 1fr);
    gap: 16px;
  }
}
.list_bnr a {
  display: block;
}
.list_bnr a .inner::after {
  content: "";
  position: absolute;
  z-index: 1;
  top: 50%;
  right: 40px;
  aspect-ratio: 1/1;
  width: 40px;
  background: url(../img/arrow03.svg) no-repeat center center var(--c_white);
  background-size: 7px auto;
  border-radius: 100%;
  transform: translate(0, -50%);
}
@media screen and (max-width: 767px) {
  .list_bnr a .inner::after {
    right: 20px;
    width: 30px;
  }
}
.list_bnr a:hover img {
  border-radius: 0;
}
.list_bnr .inner {
  position: relative;
  z-index: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 140px;
  background: var(--c_blue1);
  color: var(--c_white);
}
.list_bnr .text {
  font-size: 1.3125rem;
  font-weight: 500;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .list_bnr .text {
    font-size: 1.125rem;
  }
}
.list_bnr img {
  opacity: 0.5;
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (min-width: 768px) {
  .list_bnr img {
    border-radius: 0 120px;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ 用地開発
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/*== recruit ====================================================================================================*/
.dami {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  background: #c92e7e;
}
.dami img {
  width: 100%;
  height: auto;
  mix-blend-mode: screen;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ 採用情報 - 共通
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.single-recruit #c-contact {
  margin-top: 0;
}

@media screen and (max-width: 767px) {
  #page_recruit .local_nav {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ 採用情報 - 一覧
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#page_recruit {
  padding: 0 var(--pdX);
}
#page_recruit .mv {
  margin-top: 82px;
  margin-bottom: 120px;
}
@media screen and (max-width: 767px) {
  #page_recruit .mv {
    margin-top: 42px;
    margin-bottom: 56px;
  }
}
#page_recruit .mv .txt_area {
  display: flex;
  align-items: center;
  justify-content: space-between;
  column-gap: 80px;
  padding-right: min(80 / var(--vp) * var(--vw), 80px);
  margin-bottom: 127px;
}
@media print, screen and (max-width: 1024px) {
  #page_recruit .mv .txt_area {
    flex-direction: column;
    align-items: flex-start;
    row-gap: 43px;
    margin-bottom: 18px;
  }
}
#page_recruit .mv .txt_area .hd {
  flex-shrink: 0;
}
#page_recruit .mv .txt_area .hd .jp {
  max-width: 490px;
}
#page_recruit .mv .txt_area .catch {
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.59375;
  margin-top: -14px;
  color: var(--c_blue1);
  letter-spacing: var(--ls50);
}
@media screen and (max-width: 767px) {
  #page_recruit .mv .txt_area .catch {
    font-size: 1.375rem;
    margin-top: 0;
  }
}
#page_recruit .mv .txt_area .catch > font + br {
  display: none;
}
#page_recruit .mv .p_txt2 {
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  #page_recruit .mv .p_txt2 {
    font-size: 1.0625rem;
    line-height: 2;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_posts_list {
    margin-top: 61px;
  }
}
#page_recruit #sec_posts_list .hd.row_title {
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_posts_list .hd.row_title {
    margin-bottom: 24px;
  }
}

.article_posts.type_card {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 56px min(80 / var(--vp) * var(--vw), 80px);
}
@media screen and (max-width: 767px) {
  .article_posts.type_card {
    grid-template-columns: repeat(1, 1fr);
    row-gap: 24px;
  }
}
.article_posts.type_card .body {
  width: 100%;
  box-shadow: 0px 0px 12px rgba(0, 0, 0, 0.1);
  border-radius: 16px;
  padding: 65px min(80 / var(--vp) * var(--vw), 80px);
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (max-width: 767px) {
  .article_posts.type_card .body {
    border-radius: 8px 80px 8px 8px;
    padding: 40px 32px 37px;
  }
}
.article_posts.type_card .post_name {
  color: var(--c_blue1);
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 26px;
}
@media screen and (max-width: 767px) {
  .article_posts.type_card .post_name {
    font-size: 1.3125rem;
    letter-spacing: var(--ls50);
    margin-bottom: 16px;
  }
}
.article_posts.type_card .post_text {
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .article_posts.type_card .post_text {
    font-size: 0.9375rem;
    line-height: 1.8;
  }
}
.article_posts.type_card a {
  position: relative;
  display: flex;
  width: 100%;
  height: 100%;
}
.article_posts.type_card a::after {
  content: "";
  position: absolute;
  bottom: 47px;
  right: 47px;
  aspect-ratio: 1/1;
  width: 16px;
  background: url(../img/arrow01.svg) no-repeat left top;
  background-size: cover;
  transition: all 0.25s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (max-width: 767px) {
  .article_posts.type_card a::after {
    bottom: 23px;
    right: 23px;
    width: 14px;
  }
}
.article_posts.type_card a:hover::after {
  transform: translateX(3px);
}
.article_posts.type_card a:hover .body {
  background-color: #DFECF9;
  border-radius: 16px 160px 16px 40px;
}
@media screen and (max-width: 767px) {
  .article_posts.type_card a:hover .body {
    border-radius: 8px 120px 8px 16px;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 ■ 採用情報 - 詳細
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#page_recruit .post_article {
  margin-top: 124px;
}
@media screen and (max-width: 767px) {
  #page_recruit .post_article {
    margin-top: 58px;
  }
}
#page_recruit .post_article .innerWrap {
  max-width: 1440px;
}
@media screen and (max-width: 767px) {
  #page_recruit .post_article .post_head {
    margin-bottom: 20px;
  }
}
#page_recruit .post_article .post_head .post_title {
  max-width: inherit;
}
#page_recruit .post_title {
  color: var(--c_blue1);
  font-size: 3.5rem;
  font-weight: 500;
  letter-spacing: var(--ls50);
}
@media screen and (max-width: 767px) {
  #page_recruit .post_title {
    font-size: 1.625rem;
  }
}
#page_recruit .post_title:first-letter {
  color: var(--c_blue2);
}
@media screen and (max-width: 767px) {
  #page_recruit h2.wp-block-heading {
    font-size: 1.375rem;
    padding-bottom: 8px;
    margin-top: 50px;
    margin-bottom: 33px;
  }
}
#page_recruit h2.wp-block-heading:first-letter {
  color: var(--c_blue2);
}
@media screen and (max-width: 767px) {
  #page_recruit h2.wp-block-heading + .wp-block-flexible-table-block-table {
    margin-top: 33px;
  }
}
#page_recruit .wp-block-flexible-table-block-table:last-of-type {
  margin-bottom: 0;
}
#page_recruit .wp-block-flexible-table-block-table table {
  border-top: none;
  border-left: none;
  border-right: none;
  border-color: var(--c_gray1);
}
#page_recruit .wp-block-flexible-table-block-table tr > * {
  border-left: none;
  border-right: none;
  border-color: var(--c_gray1);
}
@media screen and (max-width: 767px) {
  #page_recruit .wp-block-flexible-table-block-table tr > * {
    border: none;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit .wp-block-flexible-table-block-table .is-stacked-on-mobile tr {
    display: flex;
    flex-direction: column;
    row-gap: 10px;
    border-bottom: 1px solid var(--c_gray1);
    padding-bottom: 17px;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit .wp-block-flexible-table-block-table .is-stacked-on-mobile tr:not(:first-child) {
    margin-top: 22px;
  }
}
#page_recruit .wp-block-flexible-table-block-table th {
  background-color: transparent;
  text-align: left;
  vertical-align: middle;
  color: var(--c_blue1);
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  #page_recruit .wp-block-flexible-table-block-table th {
    width: 300px;
    font-size: 1.125rem;
    padding: 44px 30px;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit .wp-block-flexible-table-block-table th {
    font-size: 1rem;
    padding: 0;
    margin-bottom: 5px;
  }
}
@media screen and (min-width: 768px) {
  #page_recruit .wp-block-flexible-table-block-table td {
    font-size: 1.0625rem;
    line-height: 1.823;
    padding: 32px 30px;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit .wp-block-flexible-table-block-table td {
    font-size: 1rem;
    line-height: 1.7;
    padding: 0;
  }
}
#page_recruit .post_separate {
  color: var(--c_blue2);
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.583;
  text-align: center;
  padding: 90px var(--pdX) 116px;
}
@media screen and (max-width: 767px) {
  #page_recruit .post_separate {
    font-size: 1.125rem;
    line-height: 1.66;
    padding: 33px var(--pdX) 26px;
  }
}

/*-------------------------
  エントリーフォーム
-------------------------*/
#page_recruit #sec_contact_form {
  padding: 86px var(--pdX) 200px;
  margin: 0 calc(var(--pdX) * -1);
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form {
    padding-top: 40px;
    padding-bottom: 80px;
  }
}
#page_recruit #sec_contact_form .innerWrap {
  max-width: 1440px;
}
#page_recruit #sec_contact_form .hd.thin_title {
  max-width: inherit;
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form .hd.thin_title {
    font-size: 1.375rem;
  }
}
#page_recruit #sec_contact_form .form {
  max-width: inherit;
}
@media screen and (min-width: 768px) {
  #page_recruit #sec_contact_form .form_item {
    column-gap: 30px;
  }
}
@media screen and (min-width: 768px) {
  #page_recruit #sec_contact_form .form_item:has(.item_main > input[checked].readonly) .item_title {
    padding-top: 0;
  }
}
@media screen and (min-width: 768px) {
  #page_recruit #sec_contact_form .item_title {
    width: 277px;
  }
}
#page_recruit #sec_contact_form input {
  background-color: var(--c_white);
}
#page_recruit #sec_contact_form textarea {
  height: inherit;
  background-color: var(--c_white);
}
#page_recruit #sec_contact_form label input:not(:checked) ~ span::before {
  background-color: var(--c_white);
}
#page_recruit #sec_contact_form label input:checked ~ span::before {
  background-color: var(--c_blue2);
}
@media screen and (min-width: 768px) {
  #page_recruit #sec_contact_form .pcflex {
    display: flex;
  }
}
#page_recruit #sec_contact_form input[checked].readonly {
  outline: none;
  pointer-events: none;
  opacity: 1;
  position: static;
  display: block;
  background: none;
  color: var(--c_blue1);
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form input[checked].readonly {
    font-size: 1rem;
  }
}
#page_recruit #sec_contact_form input[checked].readonly::after {
  content: attr(value);
}
#page_recruit #sec_contact_form .blk-address dl {
  display: flex;
  flex-direction: column;
  row-gap: 22px;
}
#page_recruit #sec_contact_form .blk-address div {
  align-items: center;
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form .blk-address .flex {
    column-gap: 0.5em;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form .blk-address .pcflex {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    row-gap: 0.5em;
  }
}
#page_recruit #sec_contact_form .blk-address dt {
  color: var(--c_blue1);
  width: 50px;
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form .blk-address dt {
    width: auto;
    font-size: 1rem;
  }
}
#page_recruit #sec_contact_form .blk-address dd {
  width: 100%;
}
@media screen and (min-width: 768px) {
  #page_recruit #sec_contact_form .blk-address input:not(.sizeS) {
    max-width: 648px;
  }
}
#page_recruit #sec_contact_form .blk-birthday {
  max-width: 510px;
  width: 100%;
  color: var(--c_blue1);
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form .blk-birthday {
    font-size: 1rem;
  }
}
#page_recruit #sec_contact_form .blk-birthday:not(:has(.selectgroup)) {
  display: grid;
  grid-template-columns: 1fr max-content max-content;
  align-items: center;
  column-gap: 22px;
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form .blk-birthday:not(:has(.selectgroup)) {
    display: flex;
    justify-content: flex-start;
    column-gap: 10px;
    width: inherit;
  }
}
#page_recruit #sec_contact_form .blk-birthday .selectgroup {
  display: flex;
  align-items: center;
  column-gap: 22px;
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form .blk-birthday .selectgroup {
    column-gap: 10px;
  }
}
#page_recruit #sec_contact_form .blk-birthday .selectgroup select[id*=year] {
  width: 166px;
}
#page_recruit #sec_contact_form .blk-birthday .selectgroup select:not([id*=year]) {
  width: 96px;
}
#page_recruit #sec_contact_form .blk-birthday span {
  display: grid;
  grid-template-columns: 1fr max-content;
  column-gap: 18px;
  align-items: center;
  width: 100%;
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form .blk-birthday span {
    display: inline-flex;
    column-gap: 5px;
    width: inherit;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form .blk-birthday span:has(select.sizeS) {
    width: 145px;
  }
}
#page_recruit #sec_contact_form .blk-birthday .sizeS {
  max-width: inherit;
  width: 166px;
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form .blk-birthday .sizeS {
    max-width: 124px;
    width: 100%;
  }
}
#page_recruit #sec_contact_form .blk-birthday .sizeSS {
  max-width: inherit;
  width: 96px;
}
@media screen and (max-width: 767px) {
  #page_recruit #sec_contact_form .blk-birthday .sizeSS {
    width: 64px;
  }
}
#page_recruit #sec_contact_form .form_privacy {
  margin-top: 44px;
}
#page_recruit #sec_contact_form .form_privacy .check {
  margin-top: 50px;
}

/* 確認画面 */
#page_recruit #mfp_phase_confirm {
  max-width: 1000px;
  margin: 40px auto 200px;
}
@media screen and (max-width: 767px) {
  #page_recruit #mfp_phase_confirm {
    margin-bottom: 80px;
  }
}
#page_recruit #mfp_phase_confirm:has(#mfp_phase_confirm_inner:empty) {
  margin-top: 0;
  margin-bottom: 0;
}
#page_recruit #mfp_phase_confirm .hd {
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  #page_recruit #mfp_phase_confirm .hd {
    margin-bottom: 32px;
  }
}
#page_recruit #mfp_phase_confirm .btn {
  max-width: 340px;
  width: 100%;
  min-height: 64px;
  font-size: 1.125rem;
}