@charset "UTF-8";
/*------------------------------------------------------------------------------
    config
------------------------------------------------------------------------------*/
/***  media ***/
/***  color ***/
/*** font ***/
@font-face {
  font-family: 'Garamond Premier Pro ';
  src: url('../fonts/AGaramondPro-Bold.otf') format('opentype'), url('../fonts/AGaramondPro-BoldItalic.otf') format('opentype'), url('../fonts/AGaramondPro-Italic.otf') format('opentype'), url('../fonts/AGaramondPro-Regular.otf') format('opentype');
}
#mv01 {
  position: relative;
  /*--------------------------------------
	
	kv
	
--------------------------------------*/
  /*test*/
  /*
.kv_area.kv_pow .copy {
	height:7.2em;
}
*/
  /*test*/
  /*
.kv .ph:after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: #fff;
	filter: blur(100px);
	transition: 0.8s ease-in-out;
	opacity: 0.1;
}

.kv.text_show .ph:after {
	opacity: 1.5;
	left: 100%;
}
*/
  /*
.kv.before a {
	pointer-events: none;
}
*/
  /*
.kv_area .sw01:hover {
	background: rgba(0,0,0,0.2);
}
*/
  /*----------------------------------------------------

	loading
	
----------------------------------------------------*/
  /*loading key visual show*/
}
#mv01 .kv_area {
  width: 100%;
  height: 100%;
  position: relative;
  padding: 0;
  margin: 0;
  min-height: 640px;
  overflow: hidden;
}
@media screen and (max-width: 850px) {
  #mv01 .kv_area {
    min-height: 600px;
  }
}
#mv01 .kv_area .copy .line {
  transform: translateX(-1.2em);
  opacity: 0;
  display: block;
  transition: 0.9s ease-in-out;
}
#mv01 .kv_area .copy .line01,
#mv01 .kv_area .copy .main .line02,
#mv01 .kv_area .copy .main .line03 {
  position: relative;
  display: block;
  overflow: hidden;
  transition: 0.7s ease-in-out;
}
#mv01 .kv_area .copy .line01.show .line,
#mv01 .kv_area .copy .main.show .line02 .line,
#mv01 .kv_area .copy .main.show .line03 .line {
  transform: translateX(0);
  opacity: 1;
  transition: 1.1s ease-in-out;
}
#mv01 .kv_area.kv_pow .copy .line {
  transform: translateY(1.2em);
  transition: 1s ease-in-out;
  /* 	letter-spacing: 0.3em; */
}
#mv01 .kv_area.kv_pow .copy .line01,
#mv01 .kv_area.kv_pow .copy .main .line02,
#mv01 .kv_area.kv_pow .copy .main .line03 {
  overflow: visible;
}
#mv01 .kv_area.kv_pow .copy .line01.show .line,
#mv01 .kv_area.kv_pow .copy .main.show .line02 .line,
#mv01 .kv_area.kv_pow .copy .main.show .line03 .line {
  transform: translateY(0);
  transition: 1s ease-in-out;
  /* 	letter-spacing: 0.1em; */
}
#mv01 .kv_in {
  position: relative;
  width: 100%;
  height: 802px;
  height: 640px;
  overflow: hidden;
}
@media screen and (max-width: 850px) {
  #mv01 .kv_in {
    height: 600px;
  }
}
#mv01 .kv {
  width: 91.18%;
  height: 100%;
  position: absolute;
  z-index: 10;
  opacity: 1;
  transition: 1.1s ease-in-out;
  overflow: hidden;
}
#mv01 .kv .text {
  position: absolute;
  left: 0;
  bottom: 45px;
  color: #1c446e;
  color: #fff;
  padding: 0 0 0 70px;
  overflow: hidden;
  width: 0;
  transition: 1.5s ease-in-out;
}
@media screen and (max-width: 850px) {
  #mv01 .kv .text {
    padding: 0 0 0 20px;
    bottom: 65px !important;
  }
}
#mv01 .kv .text2 {
  bottom: 85px !important;
}
@media screen and (max-width: 850px) {
  #mv01 .kv .text2 {
    bottom: 75px !important;
  }
}
#mv01 .fv_txt {
  width: fit-content;
  background: #ffffff;
}
#mv01 .fv_txt23 {
  width: fit-content;
  background: #ffffff;
}
@media screen and (max-width: 850px) {
  #mv01 .fv_txt23 {
    background: none !important;
  }
  #mv01 .fv_txt23 .main {
    padding: 0 !important;
  }
}
@media screen and (max-width: 850px) {
  #mv01 .fv_txt22 {
    font-size: 30px !important;
  }
}
#mv01 .kv .text3 {
  bottom: 85px !important;
}
@media screen and (max-width: 850px) {
  #mv01 .kv .text3 {
    bottom: 75px !important;
  }
  #mv01 .kv .text3 .fv_txt23 {
    width: fit-content;
    background: #ffffff !important;
    padding: 6px 10px;
    margin-bottom: 10px;
  }
  #mv01 .kv .text3 .fv_txt23 .main {
    margin: 0 !important;
  }
}
@media screen and (max-width: 850px) {
  #mv01 .fv_txt4 {
    background: none !important;
  }
  #mv01 .fv_txt4 .main {
    padding: 0 !important;
  }
}
#mv01 .kv .text .main {
  width: fit-content;
  line-height: 1.2;
  display: block;
  font-size: 34px;
  font-weight: 500;
  margin: 0 0 15px 0;
  padding: 10px 20px;
  background: linear-gradient(315deg, #CB6DC7, #843FF5);
  background: -webkit-linear-gradient(315deg, #CB6DC7, #843FF5);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-wrap: nowrap;
}
@media screen and (max-width: 850px) {
  #mv01 .kv .text .main {
    margin: 0 0 20px 0;
    font-size: 28px;
  }
}
#mv01 .en_top {
  font-weight: 400 !important;
  font-family: "Garamond Premier Pro", serif;
  font-size: 52px !important;
  padding: 10px 20px 0 20px !important;
  text-wrap: nowrap;
}
@media screen and (max-width: 850px) {
  #mv01 .en_top {
    font-size: 36px !important;
    letter-spacing: 0.025em !important;
    padding: 5px 10px 0 10px !important;
    margin-bottom: 8px !important;
  }
}
#mv01 .en_bottom {
  font-weight: 400 !important;
  font-size: 52px !important;
  font-family: "Garamond Premier Pro", serif;
  padding: 5px 20px 0 20px !important;
  text-wrap: nowrap;
}
@media screen and (max-width: 850px) {
  #mv01 .en_bottom {
    font-size: 34px !important;
    letter-spacing: 0.05em !important;
    padding: 2px 10px 0 10px !important;
  }
}
#mv01 .kv .text .sub {
  letter-spacing: 0;
  font-size: 24px;
  line-height: 100%;
  margin-top: 38px;
  padding: 6px 0 8px 13px;
  font-weight: bold;
  width: fit-content;
  display: block;
  background: linear-gradient(315deg, #CB6DC7, #843FF5);
  background: -webkit-linear-gradient(315deg, #CB6DC7, #843FF5);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-wrap: nowrap;
}
@media screen and (max-width: 850px) {
  #mv01 .kv .text .sub {
    font-size: 17px;
    margin-top: 18px;
    padding: 4px 30px 4px 7px;
  }
}
#mv01 .kv.text_show .text {
  width: 100%;
}
#mv01 .kv.text_show .text:before {
  height: 100%;
}
#mv01 .kv.show {
  opacity: 1;
}
#mv01 .kv .ph_area {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
}
#mv01 .kv .ph_out {
  transition: 1s cubic-bezier(0.61, 1, 0.88, 1);
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  overflow: hidden;
}
#mv01 .kv .ph {
  position: absolute;
  left: 0;
  transform: translateX(3.5%) scale(1.07);
  /*fade in の時の状態*/
  top: 0;
  width: 100%;
  height: 100%;
  background: no-repeat center center;
  background-size: cover;
  transition: 7s cubic-bezier(0.61, 1, 0.88, 1);
}
#mv01 .kv .ph img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (max-width: 850px) {
  #mv01 .kv .ph img {
    height: 100%;
  }
}
#mv01 .kv .ph:after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: #222;
  opacity: 0.02;
}
#mv01 .kv.show .ph {
  transform: translateX(1%) scale(1.07);
  /*fade out の時の状態*/
}
#mv01 .kv.show.current .ph {
  transform: translateX(-3.5%) scale(1.07);
  /*fade out の時の状態*/
}
#mv01 .kv.current {
  width: 91.18%;
}
@media screen and (max-width: 850px) {
  #mv01 .kv.current {
    width: 100%;
  }
}
#mv01 .kv.before,
#mv01 .kv.after {
  width: 20%;
}
#mv01 .kv01,
#mv01 .kv.current {
  left: 0;
  margin-left: 0;
}
#mv01 .kv.after {
  left: -100%;
}
#mv01 .kv02,
#mv01 .kv.before {
  left: 91.18%;
  margin-left: 60px;
}
#mv01 .kv.after.pre {
  left: 140.26%;
  margin-left: 60px;
}
#mv01 .kv.off {
  transition: none;
}
#mv01 .kv_area .sw01 {
  display: block;
  position: absolute;
  left: 91.18%;
  bottom: 0;
  margin-left: 18.75vw;
  width: 20%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  z-index: 20;
  background: rgba(255, 255, 255, 0);
  transition: 0.4s ease-in-out;
}
#mv01 .kv_area .sw01.show {
  opacity: 1;
}
#mv01 .kv_area .sw01:active {
  background: rgba(255, 255, 255, 0.8);
}
#mv01 .kv_area .sw01:after {
  content: '';
  display: block;
  width: 1.388vw;
  max-width: 20px;
  height: 40px;
  position: absolute;
  left: -18.75vw;
  margin-left: 26.97vw;
  bottom: 2.08vw;
  background: url(images/common/key_arrow.svg) no-repeat center bottom;
  background-size: contain;
  /* 	border: 1px solid #333; */
  transition: 0.4s ease-in-out;
}
#mv01 .kv_area .sw01:hover:after {
  animation: key_arrow 2s linear forwards;
}
@keyframes key_arrow {
  0% {
    left: -18.75vw;
  }
  10% {
    left: -18vw;
  }
  20% {
    left: -18.75vw;
  }
  30% {
    left: -18vw;
  }
  40% {
    left: -18.75vw;
  }
  100% {
    left: -18.75vw;
  }
}
#mv01 .kv_area .sw01:active:after {
  animation: key_arrow_a 1s linear forwards;
  transform: scale(1);
}
@keyframes key_arrow_a {
  0% {
    transform: scale(1);
  }
  60% {
    transform: scale(1.3);
  }
  40% {
    transform: scale(1);
  }
}
#mv01 .fv_btn {
  position: absolute;
  right: 6.5vw;
  top: 20vw;
  display: block;
  z-index: 90;
}
@media screen and (max-width: 850px) {
  #mv01 .fv_btn {
    display: none;
  }
}
#mv01 .fv_btn a {
  display: block;
  height: 41px;
  width: 1px;
  background: #CCCCCC;
}
#mv01 .fv_btn a + a {
  margin-top: 20px;
}
#mv01 .fv_btn a:hover {
  background: #707070;
}
@media screen and (max-width: 1200px) {
  #mv01 .kv02,
  #mv01 .kv.before {
    left: 91.18%;
    margin-left: 22vw;
  }
  #mv01 .kv.after.pre {
    left: 140.26%;
    margin-left: 22vw;
  }
  #mv01 .kv_area .sw01 {
    left: 91.18%;
    margin-left: 22vw;
    width: 20%;
  }
  #mv01 .kv_area .sw01:after {
    left: -22vw;
    margin-left: 26.97vw;
  }
  @keyframes key_arrow {
    0% {
      left: -22vw;
    }
    10% {
      left: -20vw;
    }
    20% {
      left: -22vw;
    }
    30% {
      left: -20vw;
    }
    40% {
      left: -22vw;
    }
    100% {
      left: -22vw;
    }
  }
}
#mv01 .loading {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 200;
  pointer-events: none;
  overflow: hidden;
}
#mv01 .loading.hide {
  display: none;
}
#mv01 .loading div.cover01 {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 60;
  /* 	background: #f9f9f9; */
  transition: 1s cubic-bezier(0.33, 1, 0.68, 1);
}
#mv01 .loading div.cover01.hide {
  top: -100%;
}
#mv01 .load_anime {
  position: absolute;
  left: 50%;
  margin-left: -43%;
  top: 150px;
  transition: 0.6s cubic-bezier(0.36, 0, 0.66, -0.56);
  transform: translateY(50px);
}
#mv01 .home .load_anime {
  left: 50%;
  top: 50%;
  margin-left: -15px;
  margin-top: -15px;
}
#mv01 .load_anime.hide {
  margin-top: -45px;
  opacity: 0;
}
#mv01 .loading img {
  width: 30px;
  opacity: 0.3;
  animation: loadspin 0.8s linear infinite;
}
@keyframes loadspin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
#mv01 .kv_area .kv:before {
  content: '';
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  z-index: 100;
  transition: 1.7s cubic-bezier(0.65, 0, 0.35, 1);
}
#mv01 .kv_area.show .kv:before {
  width: 0;
}
#mv01 #mv_news {
  position: absolute;
  bottom: 40px;
  right: 70px;
  -webkit-backdrop-filter: blur(7px);
  backdrop-filter: blur(7px);
  z-index: 55;
  padding: 12px 20px;
  width: fit-content;
}
@media screen and (max-width: 850px) {
  #mv01 #mv_news {
    right: auto;
    left: 20px;
    bottom: 15px;
    width: calc(100% - 40px);
    padding: 6px 12px;
    -webkit-backdrop-filter: blur(18px);
    backdrop-filter: blur(18px);
  }
}
#mv01 #mv_news dl {
  display: flex;
  align-items: center;
  width: fit-content;
}
#mv01 #mv_news dl dt {
  width: fit-content;
  text-align: left;
  font-family: "Garamond Premier Pro", serif;
  color: #242424;
  font-size: 19px;
  font-weight: 500;
  padding-right: 15px;
  line-height: 1.42;
}
@media screen and (max-width: 850px) {
  #mv01 #mv_news dl dt {
    padding-right: 10px;
    font-size: 10px;
  }
}
#mv01 #mv_news dl dd {
  width: fit-content;
  color: #242424;
  font-size: 15px;
  text-align: left;
  font-weight: 500;
  line-height: 1.42;
}
@media screen and (max-width: 850px) {
  #mv01 #mv_news dl dd {
    font-size: 10px;
  }
}
#about {
  position: relative;
}
#about .inner {
  padding-top: 200px;
  padding-left: 70px;
  padding-right: 20px;
  max-width: 100%;
  padding-bottom: 120px;
}
@media screen and (max-width: 850px) {
  #about .inner {
    padding: 75px 20px 0 20px;
  }
}
#about .bg_txt {
  position: absolute;
  width: fit-content;
  height: fit-content;
  z-index: 2;
  font-family: "Garamond Premier Pro", serif;
  color: #F4F4F4;
  right: 0;
  text-align: right;
  bottom: 20px;
  font-size: 264px;
  line-height: 1.7;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 850px) {
  #about .bg_txt {
    font-size: 115px;
    bottom: auto;
    top: 0;
  }
}
#about dl {
  display: flex;
  position: relative;
  z-index: 3;
}
@media screen and (max-width: 850px) {
  #about dl {
    display: block;
  }
}
#about dl dt {
  width: 51%;
}
@media screen and (max-width: 850px) {
  #about dl dt {
    width: 100%;
  }
}
#about dl dd {
  width: 49%;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 850px) {
  #about dl dd {
    width: 100%;
    margin-top: 50px;
  }
}
#about .en_small_ttl {
  font-family: "Garamond Premier Pro", serif;
  font-size: 20px;
  font-weight: 400;
  color: #222222;
  line-height: 1.45;
  text-align: left;
}
@media screen and (max-width: 850px) {
  #about .en_small_ttl {
    font-size: 10px;
  }
}
#about .jp_sub_ttl {
  font-size: 30px;
  font-weight: 500;
  text-align: left;
  color: #363636;
  line-height: 1.466;
  margin-top: 45px;
  margin-bottom: 45px;
  text-wrap: nowrap;
  z-index: 5;
  position: relative;
}
@media screen and (max-width: 850px) {
  #about .jp_sub_ttl {
    margin-top: 20px;
    margin-bottom: 12px;
    font-size: 13px;
    font-weight: 500;
  }
}
#about .ttl span {
  width: fit-content;
  letter-spacing: 0;
  font-size: 32px;
  font-weight: bold;
  display: block;
  color: #ffffff;
  line-height: 100%;
  padding: 12px 20px;
  background: -moz-linear-gradient(top left, #CB6DC7, #843FF5);
  background: -webkit-linear-gradient(top left, #CB6DC7, #843FF5);
  background: linear-gradient(to bottom right, #CB6DC7, #843FF5);
  margin-bottom: 15px;
  text-wrap: nowrap;
  z-index: 5;
  position: relative;
}
@media screen and (max-width: 850px) {
  #about .ttl span {
    padding: 6px 10px;
    font-size: 20px;
    margin-bottom: 8px;
  }
}
#about .jp_sub {
  font-size: 24px;
  font-weight: 500;
  color: #363636;
  text-align: left;
  margin-bottom: 45px;
  line-height: 1.44;
}
@media screen and (max-width: 850px) {
  #about .jp_sub {
    font-size: 12px;
  }
}
#about .jp_sub span {
  font-size: 32px;
  font-weight: bold;
  color: #B961D2;
}
@media screen and (max-width: 850px) {
  #about .jp_sub span {
    font-size: 20px;
  }
}
#about p {
  font-size: 15px;
  font-weight: 500;
  line-height: 2;
  margin-bottom: 35px;
  text-align: left;
}
@media screen and (max-width: 850px) {
  #about p {
    font-size: 12px;
    margin-bottom: 25px;
    line-height: 1.6;
  }
}
@-webkit-keyframes linelink {
  0% {
    background-position: right bottom;
    background-size: 100% 1px;
  }
  50% {
    background-position: right bottom;
    background-size: 0 1px;
  }
  51% {
    background-position: left bottom;
    background-size: 0 1px;
  }
  100% {
    background-position: left bottom;
    background-size: 100% 1px;
  }
}
@keyframes linelink {
  0% {
    background-position: right bottom;
    background-size: 100% 1px;
  }
  50% {
    background-position: right bottom;
    background-size: 0 1px;
  }
  51% {
    background-position: left bottom;
    background-size: 0 1px;
  }
  100% {
    background-position: left bottom;
    background-size: 100% 1px;
  }
}
.more_btn {
  position: relative;
  cursor: pointer;
  width: fit-content;
  overflow: hidden;
  padding-bottom: 4px;
}
.more_btn::after {
  content: '';
  width: 100%;
  height: 1px;
  background: #000000;
  position: absolute;
  right: 0;
  bottom: 0;
}
.more_btn::before {
  content: '';
  width: 100%;
  height: 1px;
  background: #000000;
  position: absolute;
  left: -400%;
  bottom: 0;
}
.more_btn .btn_txt {
  font-family: "Montserrat", sans-serif;
  font-size: 20px;
  font-weight: 500;
  color: #222222;
  letter-spacing: 0;
  position: relative;
}
@media screen and (max-width: 850px) {
  .more_btn .btn_txt {
    font-size: 13px;
  }
}
.more_btn .icon {
  position: relative;
  width: 30px;
  height: 20px;
  overflow: hidden;
  display: inline-block;
  margin-left: 14px;
}
@media screen and (max-width: 850px) {
  .more_btn .icon {
    margin-left: 25px;
    width: 19px;
    height: 12px;
  }
}
.more_btn .icon img {
  position: absolute;
  right: 0;
  top: 0;
  width: 30px;
  height: 20px;
}
@media screen and (max-width: 850px) {
  .more_btn .icon img {
    width: 19px;
    height: 12px;
  }
}
.more_btn .icon::before {
  position: absolute;
  content: "";
  width: 30px;
  height: 20px;
  left: -40px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/common/more_icon.png) no-repeat center / contain;
  transition: 0.3s ease-in-out;
}
@media screen and (max-width: 850px) {
  .more_btn .icon::before {
    width: 19px;
    height: 12px;
  }
}
.more_btn:hover::after {
  right: -100%;
  animation-duration: 0.2s;
  animation-name: b_line_r;
}
.more_btn:hover::before {
  left: 0;
  animation-duration: 0.4s;
  animation-name: b_line_l;
}
.more_btn:hover .icon img {
  right: -40px;
  animation-duration: 0.6s;
  animation-name: icon_img;
}
.more_btn:hover .icon::before {
  left: 0;
  animation-duration: 0.6s;
  animation-name: icon_before;
  animation-fill-mode: forwards;
}
@keyframes icon_before {
  from {
    left: -40px;
  }
  to {
    left: 0;
  }
}
@keyframes icon_img {
  from {
    right: 0;
  }
  to {
    right: -40px;
  }
}
@keyframes b_line_r {
  from {
    right: 0;
  }
  to {
    right: -100%;
  }
}
@keyframes b_line_l {
  from {
    left: -400%;
  }
  to {
    left: 0;
  }
}
.more_btn_w {
  position: relative;
  cursor: pointer;
  width: fit-content;
  overflow: hidden;
  padding-bottom: 4px;
}
.more_btn_w::after {
  content: '';
  width: 100%;
  height: 1px;
  background: #ffffff;
  position: absolute;
  right: 0;
  bottom: 0;
}
.more_btn_w::before {
  content: '';
  width: 100%;
  height: 1px;
  background: #ffffff;
  position: absolute;
  left: -400%;
  bottom: 0;
}
.more_btn_w .btn_txt {
  font-family: "Montserrat", sans-serif;
  font-size: 20px;
  font-weight: 500;
  color: #ffffff;
  letter-spacing: 0;
  position: relative;
}
@media screen and (max-width: 850px) {
  .more_btn_w .btn_txt {
    font-size: 13px;
  }
}
.more_btn_w .icon {
  position: relative;
  width: 30px;
  height: 20px;
  overflow: hidden;
  display: inline-block;
  margin-left: 14px;
}
@media screen and (max-width: 850px) {
  .more_btn_w .icon {
    margin-left: 25px;
    width: 19px;
    height: 12px;
  }
}
.more_btn_w .icon img {
  position: absolute;
  right: 0;
  top: 0;
  width: 30px;
  height: 20px;
}
@media screen and (max-width: 850px) {
  .more_btn_w .icon img {
    width: 19px;
    height: 12px;
  }
}
.more_btn_w .icon::before {
  position: absolute;
  content: "";
  width: 30px;
  height: 20px;
  left: -40px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/common/more_icon_w.png) no-repeat center / contain;
  transition: 0.3s ease-in-out;
}
@media screen and (max-width: 850px) {
  .more_btn_w .icon::before {
    width: 19px;
    height: 12px;
  }
}
.more_btn_w:hover::after {
  right: -100%;
  animation-duration: 0.2s;
  animation-name: b_line_r;
}
.more_btn_w:hover::before {
  left: 0;
  animation-duration: 0.4s;
  animation-name: b_line_l;
}
.more_btn_w:hover .icon img {
  right: -40px;
  animation-duration: 0.6s;
  animation-name: icon_img;
}
.more_btn_w:hover .icon::before {
  left: 0;
  animation-duration: 0.6s;
  animation-name: icon_before;
  animation-fill-mode: forwards;
}
.anim_img {
  width: 100%;
}
.anim_img figure {
  margin-block-start: 0;
  margin-block-end: 0;
  margin-inline-start: 0;
  margin-inline-end: 0;
}
.anim_img .mask {
  opacity: 0;
  mask-repeat: no-repeat;
  mask-position: 3% 0;
  mask-size: auto 100%;
  clip-path: inset(50px 50px 50px 50px);
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: 3% 0;
  -webkit-mask-size: auto 100%;
  animation-duration: 3.2s;
  animation-name: img_o;
  animation-fill-mode: forwards;
}
@media screen and (max-width: 850px) {
  .anim_img .mask {
    clip-path: inset(20px 20px 20px 20px);
    animation-duration: 1.8s;
    animation-name: img_o_sp;
    animation-fill-mode: forwards;
  }
}
@keyframes img_o {
  0% {
    opacity: 0;
    clip-path: inset(50px 50px 50px 50px);
  }
  2% {
    opacity: 1;
    clip-path: inset(50px 50px 50px 50px);
  }
  100% {
    opacity: 1;
    clip-path: inset(0 0 0 0);
  }
}
@keyframes img_o_sp {
  0% {
    opacity: 0;
    clip-path: inset(20px 20px 20px 20px);
  }
  2% {
    opacity: 1;
    clip-path: inset(20px 20px 20px 20px);
  }
  100% {
    opacity: 1;
    clip-path: inset(0 0 0 0);
  }
}
.anim_ttl {
  margin-left: 110px;
  margin-top: 35px;
}
@media screen and (max-width: 850px) {
  .anim_ttl {
    margin-left: 0;
    margin-top: 15px;
  }
}
.anim_ttl .ttl {
  height: fit-content;
  position: relative;
  overflow: hidden;
}
.anim_ttl .ttl .anim_txt,
.anim_ttl .ttl .anim_txt_la {
  display: block;
  color: #ffffff;
  font-size: 40px;
  font-weight: bold;
  line-height: 100%;
  text-align: left;
  line-height: 1.6;
  opacity: 1;
  height: fit-content;
  width: fit-content;
  transform: translateY(100%);
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 850px) {
  .anim_ttl .ttl .anim_txt,
  .anim_ttl .ttl .anim_txt_la {
    font-size: 31px;
  }
}
.anim_ttl .ttl .anim_txt_v {
  animation-duration: 0.6s;
  animation-name: txt_v;
  animation-fill-mode: forwards;
  animation-timing-function: ease-in;
}
@media screen and (max-width: 850px) {
  .anim_ttl .ttl .anim_txt_v {
    animation-duration: 0.6s;
  }
}
.anim_ttl .ttl .anim_txt_v_latter {
  animation-delay: 0.08s;
  animation-duration: 0.7s;
  animation-name: txt_v;
  animation-fill-mode: forwards;
  animation-timing-function: ease-in;
}
@media screen and (max-width: 850px) {
  .anim_ttl .ttl .anim_txt_v_latter {
    animation-delay: 0.02s;
    animation-duration: 0.6s;
  }
}
@keyframes txt_v {
  0% {
    opacity: 0;
    transform: translateY(100%);
  }
  2% {
    opacity: 1;
    transform: translateY(100%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    transition: transform cubic-bezier(0.7, 0.2, 0.1, 1) 0.8s;
  }
}
#theme {
  position: relative;
  background: url(../img/top/theme_bg.jpg) no-repeat top / contain;
  background-size: cover;
  margin-top: -120px;
  z-index: 1;
}
@media screen and (max-width: 850px) {
  #theme {
    background: url(../img/top/theme_bg_sp.jpg) no-repeat top / contain;
    background-size: cover;
    margin-top: -45px;
  }
}
#theme .inner {
  padding-top: 230px;
  padding-left: 70px;
  padding-right: 70px;
  max-width: 100%;
  padding-bottom: 310px;
}
@media screen and (max-width: 850px) {
  #theme .inner {
    padding: 190px 20px 90px 20px;
  }
}
#theme .en_small_ttl {
  font-family: "Garamond Premier Pro", serif;
  font-size: 30px;
  font-weight: 400;
  color: #ffffff;
  text-align: left;
  margin-bottom: 12px;
  line-height: 1;
}
@media screen and (max-width: 850px) {
  #theme .en_small_ttl {
    font-size: 10px;
    line-height: 1.4;
  }
}
#theme .jp_small_ttl {
  font-size: 20px;
  font-weight: bold;
  text-align: left;
  color: #ffffff;
  line-height: 1;
}
@media screen and (max-width: 850px) {
  #theme .jp_small_ttl {
    font-size: 10px;
  }
}
#theme .txt_item {
  width: fit-content;
  text-align: left;
  margin-right: 0;
  margin-left: auto;
}
@media screen and (max-width: 850px) {
  #theme .txt_item {
    text-align: left;
    margin-right: auto;
    margin-left: 0;
    margin-top: 50px;
  }
}
#theme .txt_item p {
  font-size: 15px;
  font-weight: 500;
  line-height: 2;
  margin-bottom: 35px;
  text-align: left;
  color: #ffffff;
  width: fit-content;
  padding-right: 120px;
}
@media screen and (max-width: 850px) {
  #theme .txt_item p {
    font-size: 12px;
    padding-right: 0;
    line-height: 1.6;
    margin-bottom: 42px;
  }
}
#mission {
  position: relative;
}
#mission::after {
  position: absolute;
  content: '';
  width: 40%;
  height: 100%;
  background: linear-gradient(315deg, #CB6DC7, #843FF5);
  opacity: 0.06;
  z-index: 1;
  left: 0;
  top: 0;
}
@media screen and (max-width: 850px) {
  #mission::after {
    width: calc(100% - 20px);
    height: 317px;
    top: 0;
  }
}
#mission .inner {
  position: relative;
  z-index: 5;
  padding: 230px 70px 260px 70px;
  max-width: 100%;
}
@media screen and (max-width: 850px) {
  #mission .inner {
    padding: 75px 0 0 20px;
  }
}
#mission .main_ttl {
  width: fit-content;
  line-height: 1;
  display: block;
  background: linear-gradient(315deg, #CB6DC7, #843FF5);
  background: -webkit-linear-gradient(315deg, #CB6DC7, #843FF5);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 400;
  font-family: "Garamond Premier Pro", serif;
  font-size: 64px;
  text-align: left;
  text-wrap: nowrap;
}
@media screen and (max-width: 850px) {
  #mission .main_ttl {
    font-size: 45px;
    letter-spacing: 0.05em;
  }
}
#mission .anim_ttl {
  margin-top: 0;
  margin-left: 0;
  position: relative;
  z-index: 5;
}
#mission .sub_ttl {
  font-size: 20px;
  color: #363636;
  font-weight: bold;
  margin-top: 0;
}
@media screen and (max-width: 850px) {
  #mission .sub_ttl {
    font-size: 10px;
  }
}
#mission p {
  font-size: 15px;
  font-weight: 400;
  line-height: 2;
  text-align: left;
  color: #1C1C1C;
  margin-top: 75px;
  position: relative;
  z-index: 5;
}
@media screen and (max-width: 850px) {
  #mission p {
    font-size: 12px;
    line-height: 1.6;
    margin-top: 25px;
    padding-right: 45px;
  }
}
#mission .mission_img {
  position: absolute;
  width: 71.5%;
  right: 0;
  top: -90px;
  z-index: 2;
  max-width: 1030px;
}
@media screen and (max-width: 850px) {
  #mission .mission_img {
    position: relative;
    margin-top: 25px;
    width: 100%;
    top: auto;
  }
}
#corporate .inner {
  position: relative;
  z-index: 5;
  padding: 120px 0 120px 70px;
  max-width: 100%;
}
@media screen and (max-width: 850px) {
  #corporate .inner {
    padding: 75px 0 70px 0;
  }
}
#corporate .cor_box {
  display: flex;
}
@media screen and (max-width: 850px) {
  #corporate .cor_box {
    display: block;
  }
}
#corporate .cor_box .cor_txt {
  width: 37%;
  text-align: left;
  position: relative;
  z-index: 9;
}
@media screen and (max-width: 850px) {
  #corporate .cor_box .cor_txt {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }
}
#corporate .cor_box .cor_img {
  width: 63%;
}
@media screen and (max-width: 850px) {
  #corporate .cor_box .cor_img {
    width: 100%;
    margin-top: 25px;
  }
}
#corporate .en_small_ttl {
  width: fit-content;
  line-height: 1;
  display: block;
  background: linear-gradient(315deg, #CB6DC7, #843FF5);
  background: -webkit-linear-gradient(315deg, #CB6DC7, #843FF5);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 400;
  font-family: "Garamond Premier Pro", serif;
  font-size: 36px;
  text-align: left;
  text-wrap: nowrap;
}
@media screen and (max-width: 850px) {
  #corporate .en_small_ttl {
    font-size: 16px;
  }
}
#corporate .jp_small_ttl {
  font-size: 20px;
  font-weight: bold;
  color: #363636;
  text-align: left;
  margin-top: 5px;
}
@media screen and (max-width: 850px) {
  #corporate .jp_small_ttl {
    font-size: 10px;
  }
}
#corporate .jp_ttl {
  width: fit-content;
  display: block;
  background: linear-gradient(315deg, #CB6DC7, #843FF5);
  background: -webkit-linear-gradient(315deg, #CB6DC7, #843FF5);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: bold;
  font-size: 42px;
  text-align: left;
  text-wrap: nowrap;
  line-height: 1.6;
  letter-spacing: 0.05em;
  margin-top: 40px;
}
@media screen and (max-width: 850px) {
  #corporate .jp_ttl {
    font-size: 24px;
    letter-spacing: 0.05em;
    margin-top: 10px;
  }
}
#corporate .en_big_ttl {
  width: fit-content;
  line-height: 1;
  display: block;
  background: linear-gradient(315deg, #CB6DC7, #843FF5);
  background: -webkit-linear-gradient(315deg, #CB6DC7, #843FF5);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 400;
  font-family: "Garamond Premier Pro", serif;
  font-size: 82px;
  letter-spacing: 0.05em;
  text-align: left;
  margin-top: 20px;
  text-wrap: nowrap;
}
@media screen and (max-width: 850px) {
  #corporate .en_big_ttl {
    margin-top: 10px;
    font-size: 62px;
  }
}
#corporate p {
  font-size: 15px;
  font-weight: 400;
  text-align: left;
  color: #1C1C1C;
  margin-top: 40px;
}
@media screen and (max-width: 850px) {
  #corporate p {
    margin-top: 20px;
    font-size: 12px;
  }
}
#force {
  background: #F7F7F7;
  position: relative;
  z-index: 5;
}
#force::after {
  content: 'Sevens force';
  font-family: "Garamond Premier Pro", sans-serif;
  color: #F0F0F0;
  font-size: 41vw;
  top: 7.5vw;
  left: -5vw;
  position: absolute;
  line-height: 100%;
  text-wrap: nowrap;
  z-index: 1;
}
@media screen and (max-width: 850px) {
  #force::after {
    display: table-cell;
    writing-mode: vertical-rl;
    font-size: 100vh;
    top: 0;
    left: -3.5rem;
    font-size: 13rem;
  }
}
#force .inner {
  max-width: 1254px;
  max-width: 1100px;
  padding-top: 90px;
  padding-bottom: 100px;
  position: relative;
  z-index: 5;
}
@media screen and (max-width: 850px) {
  #force .inner {
    padding-top: 50px;
    padding-bottom: 85px;
  }
}
#force p {
  text-align: center;
  font-size: 14px;
  font-weight: 400;
  line-height: 2;
  margin-top: 40px;
}
@media screen and (max-width: 850px) {
  #force p {
    margin-top: 25px;
    font-size: 12px;
    font-weight: 500;
    line-height: 1.6;
    text-align: left;
  }
}
#force ul {
  display: flex;
  flex-wrap: wrap;
  column-gap: 44px;
  justify-content: center;
  margin-top: 50px;
}
@media screen and (max-width: 1080px) {
  #force ul {
    column-gap: 20px;
  }
}
@media screen and (max-width: 850px) {
  #force ul {
    column-gap: 22px;
    justify-content: flex-start;
    margin: auto;
    margin-top: 15px;
    max-width: 330px;
  }
}
#force ul li {
  margin-top: 20px;
  width: calc(25% - 33px);
  position: relative;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 1080px) {
  #force ul li {
    width: calc(25% - 15px);
  }
}
@media screen and (max-width: 850px) {
  #force ul li {
    width: calc(50% - 11px);
    margin-top: 25px;
  }
}
#force ul li .bg {
  position: relative;
  width: 100%;
}
#force ul li .txt {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 5;
  width: 100%;
  display: flex;
  align-items: center;
  height: 100%;
  justify-content: center;
  color: #ffffff;
}
#force ul li .txt .num {
  font-size: 22px;
  font-weight: 400;
  text-align: center;
  font-family: "Garamond Premier Pro", serif;
  line-height: 100%;
}
@media screen and (max-width: 850px) {
  #force ul li .txt .num {
    font-size: 13px;
  }
}
#force ul li .txt .en_ttl {
  font-size: 28px;
  font-weight: 400;
  text-align: center;
  font-family: "Garamond Premier Pro", serif;
  line-height: 100%;
  margin-top: 15px;
  position: relative;
  padding-bottom: 20px;
  letter-spacing: 0;
}
@media screen and (max-width: 1280px) {
  #force ul li .txt .en_ttl {
    font-size: 30px;
  }
}
@media screen and (max-width: 1024px) {
  #force ul li .txt .en_ttl {
    font-size: 24px;
  }
}
@media screen and (max-width: 850px) {
  #force ul li .txt .en_ttl {
    font-size: 19px;
    margin-top: 11px;
    padding-bottom: 14px;
  }
}
#force ul li .txt .en_ttl:after {
  position: absolute;
  content: '';
  bottom: 0;
  left: calc(50% - 12.5px);
  width: 25px;
  height: 1px;
  background: #ffffff;
}
@media screen and (max-width: 850px) {
  #force ul li .txt .en_ttl:after {
    width: 14px;
    left: calc(50% - 7px);
  }
}
#force ul li .txt .list_jp_ttl {
  font-size: 20px;
  font-weight: 400;
  text-align: center;
  line-height: 100%;
  margin-top: 20px;
}
@media screen and (max-width: 850px) {
  #force ul li .txt .list_jp_ttl {
    font-size: 12px;
    margin-top: 10px;
  }
}
#force ul li:nth-child(7) .en_ttl {
  font-size: 30px;
}
@media screen and (max-width: 1280px) {
  #force ul li:nth-child(7) .en_ttl {
    font-size: 26px;
  }
}
@media screen and (max-width: 1024px) {
  #force ul li:nth-child(7) .en_ttl {
    font-size: 20px;
  }
}
@media screen and (max-width: 850px) {
  #force ul li:nth-child(7) .en_ttl {
    font-size: 14px;
  }
}
#sevice .inner {
  max-width: 100%;
  padding-right: 70px;
  padding-left: 0;
  position: relative;
}
#sevice .inner:after {
  content: '';
  position: absolute;
  width: 100vw;
  height: 100vw;
  border-radius: 100%;
  top: -7vw;
  left: -20vw;
  border: 1px solid #F0F0F0;
  z-index: 1;
}
@media screen and (max-width: 1280px) {
  #sevice .inner:after {
    top: 2vw;
    left: -25vw;
  }
}
@media screen and (max-width: 850px) {
  #sevice .inner:after {
    display: none;
  }
}
@media screen and (max-width: 850px) {
  #sevice .inner {
    padding-right: 20px;
    padding-left: 20px;
  }
}
#sevice .h2_ttl {
  position: relative;
  z-index: 10;
}
#sevice dl {
  display: flex;
  margin-top: 100px;
  flex-direction: row-reverse;
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 1280px) {
  #sevice dl {
    margin-top: 50px;
  }
}
@media screen and (max-width: 850px) {
  #sevice dl {
    margin-top: 50px;
    display: block;
  }
}
#sevice dl dd {
  width: 55%;
  position: relative;
}
@media screen and (max-width: 850px) {
  #sevice dl dd {
    width: 100%;
  }
}
#sevice dl dd img {
  max-width: 120%;
  width: 120%;
  margin-left: -10%;
  margin-top: -20%;
}
@media screen and (max-width: 1280px) {
  #sevice dl dd img {
    margin-top: -20%;
    max-width: 130%;
    width: 130%;
    margin-left: -18%;
  }
}
@media screen and (max-width: 850px) {
  #sevice dl dd img {
    max-width: 170%;
    width: 170%;
    margin-left: -35%;
    margin-top: -14%;
  }
}
#sevice dl dt {
  width: 45%;
  display: flex;
}
@media screen and (max-width: 850px) {
  #sevice dl dt {
    width: 100%;
    display: block;
  }
}
#sevice dl dt ul {
  position: relative;
  z-index: 5;
  width: calc(50% - 28px);
}
@media screen and (max-width: 1380px) {
  #sevice dl dt ul {
    width: calc(50% - 14px);
  }
}
@media screen and (max-width: 850px) {
  #sevice dl dt ul {
    width: 100%;
  }
}
#sevice dl dt ul + ul {
  margin-left: 56px;
}
@media screen and (max-width: 1380px) {
  #sevice dl dt ul + ul {
    margin-left: 28px;
  }
}
@media screen and (max-width: 850px) {
  #sevice dl dt ul + ul {
    margin-left: 0;
  }
}
#sevice dl dt ul li {
  width: 100%;
}
#sevice dl dt ul li + li a {
  border-top: 1px solid #CCCCCC;
}
#sevice dl dt ul li:last-child a {
  border-bottom: 1px solid #CCCCCC;
}
#sevice dl dt ul li a {
  cursor: default;
  border-top: 1px solid #CCCCCC;
  padding: 18px 0 18px 16px;
  display: flex;
  align-items: center;
  transition: 0.3s ease-in-out;
  height: 116px;
  justify-content: flex-start;
}
@media screen and (max-width: 1280px) {
  #sevice dl dt ul li a {
    padding: 14px 0 14px 6px;
    height: 110px;
  }
}
@media screen and (max-width: 850px) {
  #sevice dl dt ul li a {
    padding: 12px 0 12px 6px;
    height: auto;
  }
}
#sevice dl dt ul li a .num {
  display: flex;
  font-family: "Garamond Premier Pro", serif;
  font-size: 20px;
  font-weight: 400;
  color: #000000;
}
@media screen and (max-width: 850px) {
  #sevice dl dt ul li a .num {
    display: none;
  }
}
#sevice dl dt ul li a .ttl {
  font-size: 20px;
  font-weight: 400;
  color: #000000;
  text-align: left;
  transition: 0.3s ease-in-out;
  margin-left: 20px;
  line-height: 1.45;
}
@media screen and (max-width: 1480px) {
  #sevice dl dt ul li a .ttl {
    font-size: 18px;
  }
}
@media screen and (max-width: 1280px) {
  #sevice dl dt ul li a .ttl {
    margin-left: 6px;
    font-size: 15px;
  }
}
@media screen and (max-width: 850px) {
  #sevice dl dt ul li a .ttl {
    margin-left: 0;
    font-size: 15px;
  }
}
#sevice dl dt ul li a .ttl span {
  font-size: 15px;
  font-family: "Garamond Premier Pro", serif;
  color: #7D2CFF;
  display: block;
  margin-bottom: 6px;
  line-height: 100%;
}
@media screen and (max-width: 1280px) {
  #sevice dl dt ul li a .ttl span {
    font-size: 13px;
  }
}
@media screen and (max-width: 850px) {
  #sevice dl dt ul li a .ttl span {
    font-size: 12px;
    display: flex;
    align-items: center;
    margin-bottom: 2px;
  }
}
#sevice dl dt ul li a .ttl span .num_sp {
  display: none;
}
@media screen and (max-width: 850px) {
  #sevice dl dt ul li a .ttl span .num_sp {
    display: block;
    color: #000000;
    font-size: 14px;
    font-family: "Noto Sans JP", sans-serif;
    padding-right: 8px;
  }
}
#sevice dl dt ul li a .more {
  color: #857156;
  font-size: 10px;
  font-weight: 400;
  font-family: "Montserrat", sans-serif;
  position: relative;
  padding-right: 19px;
  margin: auto;
  margin-right: 10px;
  transition: 0.3s ease-in-out;
  display: none;
}
@media screen and (max-width: 1280px) {
  #sevice dl dt ul li a .more {
    margin-right: 5px;
    padding-right: 15px;
  }
}
@media screen and (max-width: 850px) {
  #sevice dl dt ul li a .more {
    padding-right: 19px;
    margin-right: 5px;
  }
}
#sevice dl dt ul li a .more::after {
  position: absolute;
  content: "";
  width: 6.4px;
  height: 12.8px;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/top/more_icon.png) no-repeat center / contain;
  transition: 0.3s ease-in-out;
}
#sevice dl dt ul .play a {
  cursor: pointer;
}
#sevice dl dt ul .play a .more {
  display: block !important;
}
#sevice dl dt ul .play a:hover {
  background: #FAF0FA;
  transition: 0.3s ease-in-out;
}
#sevice dl dt ul .play a:hover .more {
  margin-right: 5px;
  transition: 0.3s ease-in-out;
}
@media screen and (max-width: 1280px) {
  #sevice dl dt ul .play a:hover .more {
    margin-right: 0;
  }
}
@media screen and (max-width: 850px) {
  #sevice dl dt ul .play a:hover .more {
    margin-right: 0;
  }
}
#sevice dl dt ul .play a:hover .ttl {
  margin-left: 25px;
  transition: 0.3s ease-in-out;
  color: #7D2CFF;
}
@media screen and (max-width: 1280px) {
  #sevice dl dt ul .play a:hover .ttl {
    margin-left: 11px;
  }
}
@media screen and (max-width: 850px) {
  #sevice dl dt ul .play a:hover .ttl {
    margin-left: 5px;
  }
}
#business {
  margin-top: -20px;
}
@media screen and (max-width: 850px) {
  #business {
    margin-top: 0;
  }
}
#business .inner {
  padding: 0 70px 110px 70px;
  max-width: 100%;
}
@media screen and (max-width: 850px) {
  #business .inner {
    padding: 35px 20px 60px 20px;
  }
}
#business .b_h2_ttl {
  text-align: left;
  font-size: 20px;
  font-weight: bold;
  color: #363636;
  line-height: 1;
}
@media screen and (max-width: 850px) {
  #business .b_h2_ttl {
    font-size: 10px;
    text-align: center;
  }
}
#business .b_h2_ttl span {
  text-align: left;
  font-family: "Garamond Premier Pro", serif;
  width: fit-content;
  display: block;
  font-size: 64px;
  font-weight: 400;
  line-height: 100%;
  background: linear-gradient(315deg, #CB6DC7, #843FF5);
  background: -webkit-linear-gradient(315deg, #CB6DC7, #843FF5);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-wrap: nowrap;
}
@media screen and (max-width: 850px) {
  #business .b_h2_ttl span {
    font-size: 52px;
    margin-bottom: 10px;
    text-align: center;
    margin: auto;
  }
}
#business .ttl_item {
  display: flex;
  align-items: flex-end;
}
@media screen and (max-width: 850px) {
  #business .ttl_item {
    display: block;
  }
}
#business .ttl_item .t_l {
  width: 50%;
}
@media screen and (max-width: 850px) {
  #business .ttl_item .t_l {
    width: 100%;
  }
}
#business .ttl_item .t_r {
  width: 50%;
  font-size: 15px;
  font-weight: 400;
  text-align: right;
}
@media screen and (max-width: 850px) {
  #business .ttl_item .t_r {
    width: 100%;
    font-size: 12px;
    margin-top: 45px;
    text-align: center;
  }
}
#business ul {
  margin-top: 50px;
  display: flex;
  column-gap: 57.5px;
}
@media screen and (max-width: 1380px) {
  #business ul {
    column-gap: 30px;
  }
}
@media screen and (max-width: 850px) {
  #business ul {
    display: block;
    margin-top: 40px;
  }
}
#business ul li {
  width: calc(33.3333% - 38.333333px);
  background: linear-gradient(180deg, #FAF0F9, #F3EBFE);
  position: relative;
  padding: 35px 50px 70px 35px;
}
@media screen and (max-width: 1380px) {
  #business ul li {
    width: calc(33.3333% - 20px);
    padding: 35px 30px 50px 30px;
  }
}
@media screen and (max-width: 1380px) {
  #business ul li {
    padding: 35px 20px 50px 20px;
  }
}
@media screen and (max-width: 850px) {
  #business ul li {
    width: 100%;
    padding: 20px 20px 35px 20px;
  }
  #business ul li + li {
    margin-top: 20px;
  }
}
#business ul li .bg {
  position: absolute;
  bottom: 0;
  z-index: 1;
  right: 0;
  width: 88%;
  max-width: 350px;
}
@media screen and (max-width: 850px) {
  #business ul li .bg {
    max-width: 262px;
  }
}
#business ul li .txt_item {
  position: relative;
  z-index: 5;
}
#business ul li .num {
  font-size: 40px;
  font-weight: 400;
  color: #6E6E6E;
  text-align: left;
  font-family: "Garamond Premier Pro", serif;
  line-height: 100%;
}
#business ul li .en_ttl {
  text-align: left;
  font-family: "Garamond Premier Pro", serif;
  width: fit-content;
  display: block;
  font-size: 48px;
  font-weight: 400;
  background: linear-gradient(315deg, #CB6DC7, #843FF5);
  background: -webkit-linear-gradient(315deg, #CB6DC7, #843FF5);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-wrap: nowrap;
  margin-top: 5px;
  line-height: 100%;
  line-height: 1.2;
}
@media screen and (max-width: 1280px) {
  #business ul li .en_ttl {
    font-size: 42px;
  }
}
@media screen and (max-width: 850px) {
  #business ul li .en_ttl {
    font-size: 48px;
  }
}
#business ul li .jp_ttl {
  margin-top: 3px;
  line-height: 100%;
  text-align: left;
  font-size: 15px;
  font-weight: 400;
}
#business ul li p {
  border-top: #C5BFCA 1px solid;
  width: 100%;
  padding-top: 55px;
  margin-top: 65px;
  text-align: left;
}
@media screen and (max-width: 1280px) {
  #business ul li p {
    padding-top: 30px;
    margin-top: 30px;
  }
}
@media screen and (max-width: 850px) {
  #business ul li p {
    padding-top: 30px;
    margin-top: 30px;
  }
}
#business ul li p span {
  display: block;
  font-size: 18px;
  line-height: 2.22;
  font-weight: 400;
  padding-left: 15px;
  position: relative;
}
@media screen and (max-width: 1380px) {
  #business ul li p span {
    font-size: 16px;
  }
}
@media screen and (max-width: 1280px) {
  #business ul li p span {
    font-size: 14px;
    line-height: 1.66;
  }
}
@media screen and (max-width: 850px) {
  #business ul li p span {
    padding-left: 12px;
    font-size: 12px;
    line-height: 1.66;
  }
}
#business ul li p span::after {
  content: '●';
  position: absolute;
  font-weight: 500;
  font-family: "Garamond Premier Pro", sans-serif;
  font-size: 12px;
  left: 0;
  top: 40%;
  line-height: 100%;
}
@media screen and (max-width: 1280px) {
  #business ul li p span::after {
    font-size: 10px;
    line-height: 1.66;
  }
}
@media screen and (max-width: 850px) {
  #business ul li p span::after {
    font-size: 8px;
    top: 28%;
    line-height: 1.66;
  }
}
@media screen and (max-width: 850px) {
  #page2 .inner {
    padding-left: 18px;
    padding-right: 18px;
  }
}
#page2 #page2_fv {
  position: relative;
}
#page2 #page2_fv img {
  width: 100%;
}
#page2 #page2_fv .logo {
  display: block;
  position: absolute;
  top: 35px;
  left: 55px;
  width: 70px;
  z-index: 5;
}
@media screen and (max-width: 850px) {
  #page2 #page2_fv .logo {
    width: 40px;
    top: 10px;
    left: 15px;
  }
}
#page2 #page2_fv .sub_logo {
  position: absolute;
  bottom: 80px;
  right: 70px;
  width: 370px;
  z-index: 5;
}
@media screen and (max-width: 850px) {
  #page2 #page2_fv .sub_logo {
    bottom: -20px;
    right: 18px;
    width: 170px;
  }
}
#page2 #page2_fv .scroll {
  position: absolute;
  bottom: 115px;
  left: 108px;
  width: 10.7px;
  z-index: 5;
}
@media screen and (max-width: 850px) {
  #page2 #page2_fv .scroll {
    bottom: 18px;
    left: 17px;
    width: 7.5px;
  }
}
#page2 #page2_fv .mv_img {
  position: relative;
}
#page2 #page2_fv .mv_img .l_b {
  position: absolute;
  left: 0;
  top: 0;
  width: 13.8%;
  height: 100%;
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  background: rgba(255, 255, 255, 0.6);
  opacity: 0.9;
  z-index: 3;
}
@media screen and (max-width: 850px) {
  #page2 #page2_fv .mv_img .l_b {
    display: none;
  }
}
#page2 #page2_fv .mv_img .r_b {
  position: absolute;
  top: 0;
  right: 0;
  width: 13.8%;
  height: 100%;
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  background: rgba(255, 255, 255, 0.6);
  opacity: 0.9;
  z-index: 3;
}
@media screen and (max-width: 850px) {
  #page2 #page2_fv .mv_img .r_b {
    display: none;
  }
}
#page2 #page2_fv .fv_ttl {
  position: absolute;
  font-size: 34px;
  font-weight: 400;
  letter-spacing: 0.15em;
  line-height: 1.6;
  color: #030303;
  top: 220px;
  left: 70px;
  z-index: 10;
}
@media screen and (max-width: 850px) {
  #page2 #page2_fv .fv_ttl {
    font-size: 16px;
    line-height: 1.5;
    top: 95px;
    left: 20px;
  }
}
#page2 #page2_fv .fv_ttl span {
  padding: 8px 13px;
  line-height: 100%;
  background: #F7EDC9;
  width: fit-content;
}
#page2 #page2_fv .fv_ttl_bg {
  position: absolute;
  font-size: 34px;
  font-weight: 400;
  letter-spacing: 0.15em;
  line-height: 1.6;
  color: #030303;
  top: 220px;
  left: 55px;
  z-index: 10;
}
@media screen and (max-width: 850px) {
  #page2 #page2_fv .fv_ttl_bg {
    font-size: 16px;
    line-height: 1.5;
    top: 95px;
    left: 12px;
  }
}
#page2 #page2_fv .fv_ttl_bg span {
  padding: 8px 13px;
  line-height: 100%;
  background: #F7EDC9;
  width: fit-content;
  margin-bottom: 6px;
  display: block;
}
@media screen and (max-width: 850px) {
  #page2 #page2_fv .fv_ttl_bg span {
    padding: 4px 8px;
    margin-bottom: 4px;
  }
}
#page2 #page2_fv .p-swiper-container {
  position: relative;
}
#page2 #page2_fv .swiper-slide {
  overflow: hidden;
  backface-visibility: hidden;
}
#page2 #bland {
  position: relative;
  margin-top: 65px;
  color: #030303;
  margin-bottom: 65px;
}
@media screen and (max-width: 850px) {
  #page2 #bland {
    margin-top: 40px;
    margin-bottom: 0;
  }
}
#page2 #bland .inner {
  max-width: 1150px;
  position: relative;
  background: url(../img/top/bland_bg.png) no-repeat top / contain;
  background-size: cover;
  padding-top: 180px;
  padding-bottom: 110px;
}
@media screen and (max-width: 850px) {
  #page2 #bland .inner {
    background: url(../img/top/bland_bg_sp.png) no-repeat top / contain;
    background-size: 100% auto;
    padding-top: 60px;
    padding-bottom: 55px;
  }
}
#page2 #bland .bland_logo {
  width: 518px;
  left: calc(50% - 259px);
  top: 86px;
  position: absolute;
  z-index: 5;
}
@media screen and (max-width: 850px) {
  #page2 #bland .bland_logo {
    width: 202px;
    left: calc(50% - 101px);
    top: 25px;
  }
}
#page2 #bland .bland_ttl {
  font-size: 28px;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-align: center;
  line-height: 100%;
  position: relative;
  z-index: 10;
  margin-bottom: 50px;
}
@media screen and (max-width: 850px) {
  #page2 #bland .bland_ttl {
    font-weight: 500;
    font-size: 12px;
    margin-bottom: 25px;
  }
}
#page2 #bland .bland_ttl span {
  display: block;
  font-family: "Josefin Sans", sans-serif;
  font-size: 73px;
  letter-spacing: 0.2em;
  line-height: 100%;
  text-align: center;
}
@media screen and (max-width: 850px) {
  #page2 #bland .bland_ttl span {
    font-size: 34px;
    font-weight: 400;
    margin-bottom: -4px;
  }
}
#page2 #bland .sub_ttl {
  font-size: 34px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-align: center;
  margin-bottom: 55px;
}
@media screen and (max-width: 850px) {
  #page2 #bland .sub_ttl {
    font-size: 18px;
    margin-bottom: 25px;
  }
}
#page2 #bland .sub_ttl span {
  padding: 5px 15px;
  line-height: 100%;
  background: #F7EDC9;
  width: fit-content;
  margin: auto;
  margin-bottom: 18px;
  display: block;
}
@media screen and (max-width: 850px) {
  #page2 #bland .sub_ttl span {
    padding: 5px 10px;
    margin-bottom: 6px;
  }
}
#page2 #bland p {
  font-size: 16px;
  text-align: center;
  line-height: 2.3;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 850px) {
  #page2 #bland p {
    font-size: 14px;
    letter-spacing: 0.04em;
    line-height: 1.78;
  }
}
#page2 #origin {
  background: #F7F7F7;
}
#page2 #origin .inner {
  padding-top: 65px;
  padding-bottom: 65px;
  max-width: 890px;
}
@media screen and (max-width: 850px) {
  #page2 #origin .inner {
    padding-top: 35px;
    padding-bottom: 35px;
  }
}
#page2 #origin ul {
  display: flex;
  column-gap: 10px;
}
@media screen and (max-width: 850px) {
  #page2 #origin ul {
    display: block;
  }
}
#page2 #origin ul li {
  width: calc(50% - 5px);
  text-align: left;
}
@media screen and (max-width: 1024px) {
  #page2 #origin ul li:first-child {
    width: 40%;
  }
  #page2 #origin ul li:last-child {
    width: 60%;
  }
}
@media screen and (max-width: 850px) {
  #page2 #origin ul li {
    text-align: center;
  }
  #page2 #origin ul li:first-child {
    width: 100%;
  }
  #page2 #origin ul li:last-child {
    margin-top: 35px;
    width: 100%;
  }
}
#page2 #origin ul li .l_logo {
  max-width: 167px;
}
@media screen and (max-width: 850px) {
  #page2 #origin ul li .l_logo {
    max-width: 63px;
  }
}
#page2 #origin .origin_ttl {
  text-align: left;
  font-size: 42px;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #origin .origin_ttl {
    font-size: 28px;
  }
}
#page2 #origin .origin_ttl span {
  font-family: "Josefin Sans", sans-serif;
  font-size: 22px;
  font-weight: 400;
  display: block;
  letter-spacing: 0;
  margin-bottom: -5px;
}
@media screen and (max-width: 850px) {
  #page2 #origin .origin_ttl span {
    font-size: 11px;
  }
}
#page2 #origin .txt {
  display: flex;
  align-items: center;
  font-size: 26px;
  font-weight: 500;
  letter-spacing: 0;
  margin-top: 30px;
  line-height: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #origin .txt {
    font-size: 17px;
    margin-top: 20px;
  }
}
#page2 #origin .txt .num {
  max-width: 24px;
  margin: 0;
  display: flex;
  margin-right: 20px;
}
#page2 #origin .txt .bg {
  background: #F7EDC9;
  line-height: 100%;
  padding: 8px 15px;
  margin-left: 15px;
}
@media screen and (max-width: 850px) {
  #page2 #origin .txt .bg {
    margin-left: 8px;
    padding: 4px 12px;
  }
}
#page2 #origin .txt .bg .small {
  font-size: 16px;
}
@media screen and (max-width: 850px) {
  #page2 #origin .txt .bg .small {
    font-size: 11px;
  }
}
#page2 #performance {
  color: #030303;
}
#page2 #performance .inner {
  padding-top: 110px;
  padding-bottom: 110px;
  max-width: 1340px;
}
@media screen and (max-width: 850px) {
  #page2 #performance .inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
#page2 #performance .per_ttl {
  text-align: center;
  line-height: 100%;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 850px) {
  #page2 #performance .per_ttl {
    font-size: 12px;
  }
}
#page2 #performance .per_ttl span {
  display: block;
  font-size: 50px;
  letter-spacing: 0.2em;
  font-weight: 400;
  font-family: "Josefin Sans", sans-serif;
  margin-bottom: 20px;
}
@media screen and (max-width: 850px) {
  #page2 #performance .per_ttl span {
    margin-bottom: 15px;
    font-size: 34px;
    letter-spacing: 0.08em;
  }
}
#page2 #performance .per_contents {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 5%;
  padding: 60px 0;
  margin-top: 40px;
  border-top: 1px solid #222222;
  border-bottom: 1px solid #222222;
}
@media screen and (max-width: 850px) {
  #page2 #performance .per_contents {
    flex-direction: column;
    gap: 30px;
    padding: 35px 0;
  }
}
#page2 #performance .per_video {
  aspect-ratio: 16 / 9;
  width: 49%;
}
@media screen and (max-width: 1120px) {
  #page2 #performance .per_video {
    width: 40%;
  }
}
@media screen and (max-width: 850px) {
  #page2 #performance .per_video {
    max-width: 400px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}
#page2 #performance .per_video iframe {
  max-width: 100% !important;
  display: block;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  aspect-ratio: 16 / 9;
}
#page2 #performance .per_lead-block {
  width: 33%;
  text-align: left;
}
@media screen and (max-width: 1120px) {
  #page2 #performance .per_lead-block  {
    width: 45%;
  }
}
@media screen and (max-width: 850px) {
  #page2 #performance .per_lead-block {
    width: 100%;
  }
}
#page2 #performance .per_lead-sub {
  font-size: 20px;
  letter-spacing: 0.02em;
  font-weight: 500;
}
#page2 #performance .per_lead-main {
  margin-top: 5px;
  color: #8D2E2D;
  font-weight: 500;
  font-size: 32px;
  letter-spacing: 0.1em;
  line-height: 1;
}
@media screen and (max-width: 850px) {
  #page2 #performance .per_lead-main {
    font-size: 24px;
  }
}
#page2 #performance .per_text {
  font-size: 15px;
  line-height: 2;
  letter-spacing: 0.02em;
  font-weight: 500;
  margin-top: 30px;
}
@media screen and (max-width: 850px) {
  #page2 #performance .per_text {
    font-size: 13px;
  }
}
#page2 #performance .btn_line_item.btn_line_item--m {
  margin-top: 40px;
  margin-left: auto;
}
@media screen and (max-width: 850px) {
  #page2 #performance .btn_line_item.btn_line_item--m {
    margin-left: initial;
  }
}
#page2 #performance ul {
  display: flex;
  column-gap: 90px;
  margin-top: 50px;
  justify-content: center;
}
@media screen and (max-width: 850px) {
  #page2 #performance ul {
    margin-top: 40px;
    display: block;
  }
}
#page2 #performance ul li {
  width: 284px;
}
@media screen and (max-width: 850px) {
  #page2 #performance ul li {
    width: 100%;
  }
  #page2 #performance ul li + li {
    margin-top: 50px;
  }
}
#page2 #performance ul li .ttl {
  margin-top: 25px;
  text-align: left;
  margin-bottom: 20px;
  font-size: 24px;
  letter-spacing: 0.1em;
  font-weight: 500;
  line-height: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #performance ul li .ttl {
    margin-top: 16px;
    margin-bottom: 15px;
    font-size: 20px;
    text-align: center;
  }
}
#page2 #performance ul li p {
  text-align: left;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 2;
}
@media screen and (max-width: 850px) {
  #page2 #performance ul li p {
    font-size: 13px;
    line-height: 2.3;
  }
}
#page2 #movie .inner {
  padding-top: 110px;
  padding-bottom: 180px;
  max-width: 100%;
  position: relative;
}
@media screen and (max-width: 850px) {
  #page2 #movie .inner {
    padding-top: 70px;
    padding-bottom: 145px;
  }
}
#page2 #movie .inner::after {
  position: absolute;
  content: "";
  width: 446px;
  height: 356px;
  right: 70px;
  bottom: -80px;
  background: url(../img/top/movie_after.png) no-repeat center / contain;
  transition: 0.3s ease-in-out;
  z-index: 1;
}
@media screen and (max-width: 850px) {
  #page2 #movie .inner::after {
    width: 375px;
    height: 174px;
    left: 0;
    bottom: 10px;
    right: auto;
    background: url(../img/top/movie_after_sp.svg) no-repeat center / contain;
  }
}
#page2 #movie .inner::before {
  position: absolute;
  content: "";
  width: 457px;
  height: 712px;
  left: 0;
  top: 148px;
  background: url(../img/top/movie_before.png) no-repeat center / contain;
  transition: 0.3s ease-in-out;
  z-index: 1;
}
@media screen and (max-width: 850px) {
  #page2 #movie .inner::before {
    width: 80px;
    height: 93px;
    left: auto;
    top: 0;
    right: 20px;
    background: url(../img/top/movie_before_sp.svg) no-repeat center / contain;
  }
}
#page2 #movie p {
  margin-top: 25px;
  text-align: center;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0;
  z-index: 2;
  position: relative;
}
@media screen and (max-width: 850px) {
  #page2 #movie p {
    font-size: 13px;
    margin-top: 15px;
  }
}
#page2 #movie .movie_ttl {
  text-align: center;
  line-height: 100%;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
  z-index: 2;
  position: relative;
}
@media screen and (max-width: 850px) {
  #page2 #movie .movie_ttl {
    font-size: 12px;
  }
}
#page2 #movie .movie_ttl span {
  display: block;
  font-size: 50px;
  letter-spacing: 0.2em;
  font-weight: 400;
  font-family: "Josefin Sans", sans-serif;
  margin-bottom: 20px;
}
@media screen and (max-width: 850px) {
  #page2 #movie .movie_ttl span {
    margin-bottom: 15px;
    font-size: 34px;
    letter-spacing: 0.08em;
  }
}
#page2 #movie .movice_txt {
  /* max-width: 735px; */
  margin: auto;
  z-index: 2;
  position: relative;
  margin-top: 65px;
}
#page2 #movie .movice_txt video {
  width: 100%;
  height: a;
}
#page2 #movie .movice_txt iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  max-width: 735px;
  display: block;
  margin: auto;
}
@media screen and (max-width: 850px) {
  #page2 #movie .movice_txt {
    margin-top: 35px;
  }
}
#page2 #work .inner {
  padding-top: 110px;
  padding-bottom: 110px;
  max-width: 1230px;
}
@media screen and (max-width: 850px) {
  #page2 #work .inner {
    padding-top: 50px;
    padding-bottom: 40px;
    padding-left: 5px;
    padding-right: 5px;
  }
}
#page2 #work .work_ttl {
  text-align: left;
  line-height: 100%;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 850px) {
  #page2 #work .work_ttl {
    text-align: center;
    font-size: 12px;
  }
}
#page2 #work .work_ttl span {
  font-size: 50px;
  letter-spacing: 0.2em;
  font-weight: 400;
  font-family: "Josefin Sans", sans-serif;
  margin-bottom: 20px;
}
@media screen and (max-width: 850px) {
  #page2 #work .work_ttl span {
    display: block;
    text-align: center;
    margin-bottom: 15px;
    font-size: 34px;
    letter-spacing: 0.08em;
  }
}
#page2 #work .img_box {
  margin-top: 60px;
}
@media screen and (max-width: 850px) {
  #page2 #work .img_box {
    margin-top: 20px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #work .img_box .mySwiper01 {
    padding-left: 30px;
    padding-right: 30px;
  }
}
#page2 #work .img_box .mySwiper01 img {
  width: 100%;
  height: 687px;
  object-fit: cover;
}
@media screen and (max-width: 850px) {
  #page2 #work .img_box .mySwiper01 img {
    height: 185px;
  }
}
#page2 #work .img_box .swiper-wrapper a:hover {
  opacity: 1 !important;
}
#page2 #work .img_box .swiper01Thumbnail {
  margin-top: 30px;
  cursor: pointer;
}
@media screen and (max-width: 850px) {
  #page2 #work .img_box .swiper01Thumbnail {
    margin-top: 10px;
  }
}
#page2 #work .img_box .swiper01Thumbnail img {
  width: 100%;
  height: 148px;
  object-fit: cover;
}
@media screen and (max-width: 850px) {
  #page2 #work .img_box .swiper01Thumbnail img {
    height: 60px;
  }
}
#page2 #work .img_box .swiper01Thumbnail .swiper-slide-visible {
  border: 2px solid #fff;
}
#page2 #work .img_box .swiper01Thumbnail .swiper-slide {
  border: 2px solid #fff;
}
#page2 #work .img_box .swiper01Thumbnail .swiper-slide-thumb-active {
  border: 2px solid #030303;
}
#page2 #work .img_box .swiper-button-next {
  position: absolute;
  right: 0;
  width: 51px;
  height: 51px;
  top: calc(50% - 25.5px);
  z-index: 100;
}
#page2 #work .img_box .swiper-button-next img {
  width: 51px;
  height: 51px;
}
@media screen and (max-width: 850px) {
  #page2 #work .img_box .swiper-button-next img {
    width: 25px;
    height: 25px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #work .img_box .swiper-button-next {
    width: 25px;
    height: 25px;
    top: 50%;
    right: 10px;
  }
}
#page2 #work .img_box .swiper-button-next::after {
  display: none;
}
#page2 #work .img_box .swiper-button-next .none {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #work .img_box .swiper-button-next .on {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #work .img_box .swiper-button-next:hover .none {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #work .img_box .swiper-button-next:hover .on {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #work .img_box .swiper-button-prev {
  position: absolute;
  left: 0;
  width: 51px;
  height: 51px;
  top: calc(50% - 25.5px);
  z-index: 100;
}
#page2 #work .img_box .swiper-button-prev img {
  width: 51px;
  height: 51px;
}
@media screen and (max-width: 850px) {
  #page2 #work .img_box .swiper-button-prev img {
    width: 25px;
    height: 25px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #work .img_box .swiper-button-prev {
    width: 25px;
    height: 25px;
    top: 50%;
    left: 10px;
  }
}
#page2 #work .img_box .swiper-button-prev::after {
  display: none;
}
#page2 #work .img_box .swiper-button-prev .none {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #work .img_box .swiper-button-prev .on {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #work .img_box .swiper-button-prev:hover .none {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #work .img_box .swiper-button-prev:hover .on {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #event {
  background: #F7F7F7;
}
#page2 #event .inner {
  padding-top: 110px;
  padding-bottom: 100px;
  max-width: 1230px;
}
@media screen and (max-width: 850px) {
  #page2 #event .inner {
    padding-top: 45px;
    padding-bottom: 50px;
  }
}
#page2 #event .event_ttl {
  text-align: left;
  line-height: 100%;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 850px) {
  #page2 #event .event_ttl {
    text-align: center;
    font-size: 12px;
  }
}
#page2 #event .event_ttl span {
  font-size: 50px;
  letter-spacing: 0.2em;
  font-weight: 400;
  font-family: "Josefin Sans", sans-serif;
  display: block;
  margin-bottom: 20px;
}
@media screen and (max-width: 850px) {
  #page2 #event .event_ttl span {
    text-align: center;
    margin-bottom: 15px;
    font-size: 34px;
    letter-spacing: 0.08em;
  }
}
#page2 #event .f_item {
  display: flex;
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item {
    display: block;
  }
}
#page2 #event .f_item .ttl_item {
  width: 38%;
  text-align: center;
  padding-right: 9.5%;
}
@media screen and (max-width: 1200px) {
  #page2 #event .f_item .ttl_item {
    padding-right: 3.5%;
  }
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .ttl_item {
    padding-right: 0;
    width: 100%;
  }
}
#page2 #event .f_item .ttl_item p {
  font-size: 15px;
  letter-spacing: 0;
  font-weight: 500;
  line-height: 2;
  text-align: left;
  margin-top: 50px;
  margin-bottom: 50px;
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .ttl_item p {
    font-size: 13px;
    text-align: center;
    line-height: 1.7;
    margin-top: 25px;
    margin-bottom: 30px;
  }
}
#page2 #event .f_item .ttl_item .btn_line_item {
  max-width: calc(100% - 25px);
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .ttl_item .btn_line_item {
    max-width: calc(100% - 25px);
    display: none;
  }
}
#page2 #event .f_item .txt_item {
  width: 62%;
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .txt_item {
    width: 100%;
  }
}
#page2 #event .f_item .txt_item .btn_line_item {
  max-width: calc(100% - 25px);
  display: none;
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .txt_item .btn_line_item {
    max-width: calc(100% - 25px);
    display: block;
  }
}
#page2 #event .f_item .event_list {
  display: flex;
  flex-wrap: wrap;
  column-gap: 56px;
}
@media screen and (max-width: 1024px) {
  #page2 #event .f_item .event_list {
    column-gap: 20px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .event_list {
    column-gap: 20px;
  }
}
#page2 #event .f_item .event_list li {
  width: calc(50% - 28px);
  margin-top: 50px;
}
@media screen and (max-width: 1024px) {
  #page2 #event .f_item .event_list li {
    width: calc(50% - 10px);
    margin-top: 18px;
  }
}
#page2 #event .f_item .event_list li:nth-child(1),
#page2 #event .f_item .event_list li:nth-child(2) {
  margin-top: 0;
}
#page2 #event .f_item .event_list li img {
  width: 100%;
  /* height: 204px; */
  height: auto;
  object-fit: cover;
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .event_list li img {
    height: auto;
  }
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .event_list li {
    margin-top: 18px;
    width: calc(50% - 10px);
  }
  #page2 #event .f_item .event_list li:nth-child(1),
  #page2 #event .f_item .event_list li:nth-child(2) {
    margin-top: 0;
  }
}
#page2 #event .f_item .event_list li .tag_item {
  display: flex;
  align-items: center;
  margin-top: 20px;
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .event_list li .tag_item {
    margin-top: 7px;
  }
}
#page2 #event .f_item .event_list li .tag_item .tag {
  color: #ffffff;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1;
  padding: 8px 13px;
  background: #030303;
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .event_list li .tag_item .tag {
    padding: 3px 6px;
    font-size: 12px;
  }
}
#page2 #event .f_item .event_list li .tag_item .addr {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #919191;
  margin-left: 17px;
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .event_list li .tag_item .addr {
    font-size: 10px;
    margin-left: 6px;
  }
}
#page2 #event .f_item .event_list li .date {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #363636;
  margin-top: 12px;
  margin-bottom: 14px;
  text-align: left;
  line-height: 1.2;
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .event_list li .date {
    font-size: 10px;
    margin-top: 5px;
    margin-bottom: 8px;
  }
}
#page2 #event .f_item .event_list li p {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0;
  color: #363636;
  text-align: left;
  line-height: 2;
}
@media screen and (max-width: 850px) {
  #page2 #event .f_item .event_list li p {
    font-size: 11px;
    line-height: 1.6;
  }
}
#page2 #key {
  background: url(../img/top/key_bg.jpg) no-repeat bottom / contain;
  background-size: cover;
}
@media screen and (max-width: 850px) {
  #page2 #key {
    background: url(../img/top/key_bg_sp.jpg) no-repeat bottom / contain;
    background-size: cover;
  }
}
#page2 #key .inner {
  padding-top: 100px;
  padding-bottom: 100px;
  max-width: 1114px;
}
@media screen and (max-width: 850px) {
  #page2 #key .inner {
    padding-top: 25px;
    padding-bottom: 30px;
  }
}
#page2 #key .ttl {
  font-size: 42px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: center;
  color: #ffffff;
  margin-bottom: 65px;
}
@media screen and (max-width: 850px) {
  #page2 #key .ttl {
    font-size: 28px;
    line-height: 1.42;
    margin-bottom: 53px;
  }
}
#page2 #w_about {
  display: flex;
}
@media screen and (max-width: 850px) {
  #page2 #w_about {
    display: block;
  }
}
#page2 #w_about .img_item {
  width: 50%;
}
@media screen and (max-width: 850px) {
  #page2 #w_about .img_item {
    width: 100%;
    padding-bottom: 40px;
  }
}
#page2 #w_about .img_item .img_s {
  width: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #w_about .img_item .img_s {
    width: 77%;
    margin: auto;
    margin-right: auto;
  }
}
#page2 #w_about .img_item .swiper {
  width: 100%;
  height: 100%;
}
#page2 #w_about .img_item .swiper-slide {
  text-align: center;
  font-size: 18px;
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
}
#page2 #w_about .img_item .swiper-slide img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#page2 #w_about .img_item .swiper-button-next {
  position: absolute;
  right: 70px;
  width: 51px;
  height: 51px;
  top: auto;
  bottom: 75px;
  z-index: 100;
}
#page2 #w_about .img_item .swiper-button-next img {
  width: 51px;
  height: 51px;
}
@media screen and (max-width: 850px) {
  #page2 #w_about .img_item .swiper-button-next img {
    width: 45px;
    height: 45px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #w_about .img_item .swiper-button-next {
    width: 45px;
    height: 45px;
    bottom: 2px;
    right: 15px;
  }
}
#page2 #w_about .img_item .swiper-button-next::after {
  display: none;
}
#page2 #w_about .img_item .swiper-button-prev {
  position: absolute;
  right: 190px;
  width: 51px;
  height: 51px;
  bottom: 75px;
  top: auto;
  z-index: 100;
  left: auto;
}
#page2 #w_about .img_item .swiper-button-prev img {
  width: 51px;
  height: 51px;
}
@media screen and (max-width: 850px) {
  #page2 #w_about .img_item .swiper-button-prev img {
    width: 45px;
    height: 45px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #w_about .img_item .swiper-button-prev {
    width: 45px;
    height: 45px;
    bottom: 2px;
    right: 120px;
  }
}
#page2 #w_about .img_item .swiper-button-prev::after {
  display: none;
}
#page2 #w_about .txt_item {
  width: 50%;
  text-align: left;
  padding: 20px 70px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 1360px) {
  #page2 #w_about .txt_item {
    padding: 30px 18px 20px 18px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #w_about .txt_item {
    width: 100%;
    padding: 45px 18px 30px 18px;
  }
}
#page2 #w_about .txt_item .border_txt {
  border: 1px solid #707070;
  padding: 45px 55px;
  text-align: left;
  margin-top: 45px;
}
@media screen and (max-width: 1360px) {
  #page2 #w_about .txt_item .border_txt {
    padding: 20px 20px 20px 25px;
    margin-top: 15px;
  }
}
@media screen and (max-width: 940px) {
  #page2 #w_about .txt_item .border_txt {
    padding: 20px 20px 20px 25px;
    margin-top: 25px;
  }
}
@media screen and (max-width: 900px) {
  #page2 #w_about .txt_item .border_txt {
    padding: 10px 20px 10px 25px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #w_about .txt_item .border_txt {
    margin-top: 30px;
    width: 100%;
    padding: 30px 20px 30px 25px;
  }
}
#page2 #w_about .txt_item .border_txt .sub_ttl {
  font-size: 18px;
  font-weight: bold;
  text-align: left;
  margin-bottom: 8px;
  color: #363636;
}
@media screen and (max-width: 1300px) {
  #page2 #w_about .txt_item .border_txt .sub_ttl {
    margin-bottom: 5px;
    font-size: 16px;
  }
}
@media screen and (max-width: 1150px) {
  #page2 #w_about .txt_item .border_txt .sub_ttl {
    margin-bottom: 0px;
    font-size: 14px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #w_about .txt_item .border_txt .sub_ttl {
    font-size: 16px;
    margin-bottom: 12px;
  }
}
#page2 #w_about .txt_item .border_txt .ttl {
  font-size: 32px;
  font-weight: bold;
  text-align: left;
  margin-bottom: 32px;
  color: #363636;
}
@media screen and (max-width: 1300px) {
  #page2 #w_about .txt_item .border_txt .ttl {
    margin-bottom: 10px;
    font-size: 24px;
  }
}
@media screen and (max-width: 1150px) {
  #page2 #w_about .txt_item .border_txt .ttl {
    margin-bottom: 8px;
    font-size: 20px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #w_about .txt_item .border_txt .ttl {
    font-size: 20px;
    margin-bottom: 15px;
  }
}
#page2 #w_about .txt_item .border_txt p {
  font-weight: 500;
  font-size: 15px;
  line-height: 2;
  color: #363636;
}
@media screen and (max-width: 1300px) {
  #page2 #w_about .txt_item .border_txt p {
    font-size: 13px;
  }
}
@media screen and (max-width: 940px) {
  #page2 #w_about .txt_item .border_txt p {
    line-height: 1.6;
  }
}
@media screen and (max-width: 850px) {
  #page2 #w_about .txt_item .border_txt p {
    font-size: 13px;
    line-height: 2.15;
  }
}
#page2 #w_about .w_about_ttl {
  text-align: center;
  line-height: 100%;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 850px) {
  #page2 #w_about .w_about_ttl {
    font-size: 12px;
  }
}
#page2 #w_about .w_about_ttl span {
  font-size: 48px;
  letter-spacing: 0.15em;
  font-weight: 400;
  font-family: "Josefin Sans", sans-serif;
  display: block;
  line-height: 1.125;
}
@media screen and (max-width: 1300px) {
  #page2 #w_about .w_about_ttl span {
    font-size: 38px;
  }
}
@media screen and (max-width: 1150px) {
  #page2 #w_about .w_about_ttl span {
    font-size: 34px;
  }
}
@media screen and (max-width: 940px) {
  #page2 #w_about .w_about_ttl span {
    font-size: 34px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #w_about .w_about_ttl span {
    text-align: center;
    font-size: 34px;
    letter-spacing: 0.08em;
    line-height: 1.029;
  }
}
#page2 #black_wabout {
  position: relative;
  background: #030303;
  margin-top: -4px;
  z-index: 10;
}
#page2 #black_wabout .bg {
  width: 100%;
  position: absolute;
  height: 100%;
  z-index: 1;
  text-align: center;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1439px) {
  #page2 #black_wabout .bg img {
    height: 100%;
    max-width: fit-content;
    width: auto;
    margin: auto;
  }
}
#page2 #black_wabout .inner_a {
  position: relative;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  z-index: 5;
}
#page2 #black_wabout .inner {
  min-height: 535px;
  display: flex;
  align-items: end;
  justify-content: center;
  padding-top: 0;
  padding-bottom: 50px;
}
@media screen and (max-width: 850px) {
  #page2 #black_wabout .inner {
    min-height: 321px;
    padding-bottom: 35px;
  }
}
#page2 #black_wabout .ttl {
  position: absolute;
  right: -8px;
  top: -27px;
  font-size: 71px;
  font-weight: 400;
  letter-spacing: 0.1em;
  line-height: 100%;
  width: fit-content;
  color: #E5DDD6;
  opacity: 0.5;
  z-index: 5;
  font-family: "Josefin Sans", sans-serif;
  white-space: nowrap;
}
@media screen and (max-width: 850px) {
  #page2 #black_wabout .ttl {
    top: -17px;
    right: auto;
    left: 80px;
    font-size: 40px;
  }
}
#page2 #black_wabout .icon {
  max-width: 70px;
  margin: auto;
}
@media screen and (max-width: 850px) {
  #page2 #black_wabout .icon {
    max-width: 39px;
  }
}
#page2 #black_wabout .txt {
  line-height: 1.5;
  font-size: 38px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: center;
  color: #ffffff;
}
@media screen and (max-width: 850px) {
  #page2 #black_wabout .txt {
    font-size: 18px;
    line-height: 2;
  }
}
#page2 #black_wabout .bg_txt {
  margin-top: 40px;
}
@media screen and (max-width: 850px) {
  #page2 #black_wabout .bg_txt {
    margin-top: 30px;
  }
}
#page2 #black_wabout .bg_txt span {
  font-size: 42px;
  text-align: center;
  letter-spacing: 0.04em;
  line-height: 1.42;
  width: fit-content;
  margin: auto;
  color: #030303;
  background: #FAF3D9;
  line-height: 1;
  padding: 0px 20px 2px 20px;
  font-weight: 500;
}
#page2 #black_wabout .bg_txt span:last-child {
  padding: 0 20px 2px 0;
}
#page2 #black_wabout .bg_txt span:first-child {
  padding: 0 0 2px 20px;
}
@media screen and (max-width: 1024px) {
  #page2 #black_wabout .bg_txt span {
    font-size: 36px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #black_wabout .bg_txt span {
    display: block;
    font-size: 20px;
    line-height: 1;
    padding: 3px 10px 5px 10px;
  }
  #page2 #black_wabout .bg_txt span:last-child {
    margin-top: 4px;
  }
  #page2 #black_wabout .bg_txt span:last-child {
    padding: 0 20px 2px 20px;
  }
}
#page2 #design {
  background: #F7F7F7;
  position: relative;
  margin-top: 110px;
}
@media screen and (max-width: 850px) {
  #page2 #design {
    margin-top: 60px;
  }
}
#page2 #design::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 323px;
  right: 0;
  bottom: 0;
  z-index: 1;
  background: url(../img/top/design_bg.jpg) no-repeat bottom / contain;
  transition: 0.3s ease-in-out;
  background-size: 100% 100%;
}
@media screen and (max-width: 850px) {
  #page2 #design::after {
    height: 84px;
  }
}
#page2 #design::before {
  position: absolute;
  content: "";
  width: 130px;
  height: 100%;
  right: 0;
  bottom: 0;
  z-index: 5;
  background: #ffffff;
  transition: 0.3s ease-in-out;
}
@media screen and (max-width: 850px) {
  #page2 #design::before {
    width: 15px;
  }
}
#page2 #design .inner {
  padding-top: 115px;
  z-index: 10;
  padding-left: 16.5%;
  padding-right: 0;
  max-width: 100%;
  padding-bottom: 380px;
}
@media screen and (max-width: 1280px) {
  #page2 #design .inner {
    padding-left: 8%;
  }
}
@media screen and (max-width: 1100px) {
  #page2 #design .inner {
    padding-left: 4%;
  }
}
@media screen and (max-width: 850px) {
  #page2 #design .inner {
    padding-top: 30px;
    padding-left: 15px;
    padding-bottom: 140px;
  }
}
#page2 #design .slide_design {
  position: relative;
  padding-bottom: 80px;
}
@media screen and (max-width: 850px) {
  #page2 #design .slide_design {
    padding-bottom: 65px;
  }
}
#page2 #design .swiper {
  width: 100%;
  height: 100%;
}
#page2 #design .swiper-slide {
  text-align: center;
  font-size: 18px;
  background: none;
  display: flex;
  justify-content: center;
  align-items: center;
}
#page2 #design .swiper-slide img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#page2 #design .swiper-button-next-dg {
  position: absolute;
  cursor: pointer;
  left: 113px;
  right: auto;
  width: 51px;
  height: 51px;
  top: auto;
  bottom: 0;
  z-index: 100;
}
#page2 #design .swiper-button-next-dg img {
  width: 51px;
  height: 51px;
}
@media screen and (max-width: 850px) {
  #page2 #design .swiper-button-next-dg img {
    width: 46px;
    height: 46px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #design .swiper-button-next-dg {
    width: 45px;
    height: 45px;
    bottom: 0;
    left: 100px;
  }
}
#page2 #design .swiper-button-next-dg::after {
  display: none;
}
#page2 #design .swiper-button-next-dg .none {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #design .swiper-button-next-dg .on {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #design .swiper-button-next-dg:hover .none {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #design .swiper-button-next-dg:hover .on {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #design .swiper-button-prev-dg {
  position: absolute;
  cursor: pointer;
  width: 51px;
  height: 51px;
  bottom: 0;
  top: auto;
  z-index: 100;
  left: 0;
  right: auto;
}
#page2 #design .swiper-button-prev-dg img {
  width: 51px;
  height: 51px;
}
@media screen and (max-width: 850px) {
  #page2 #design .swiper-button-prev-dg img {
    width: 46px;
    height: 46px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #design .swiper-button-prev-dg {
    width: 45px;
    height: 45px;
    bottom: 0;
  }
}
#page2 #design .swiper-button-prev-dg::after {
  display: none;
}
#page2 #design .swiper-button-prev-dg .none {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #design .swiper-button-prev-dg .on {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #design .swiper-button-prev-dg:hover .none {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #design .swiper-button-prev-dg:hover .on {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #design .design_ttl {
  text-align: left;
  line-height: 100%;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 850px) {
  #page2 #design .design_ttl {
    font-size: 12px;
  }
}
#page2 #design .design_ttl span {
  font-size: 50px;
  letter-spacing: 0.2em;
  font-weight: 400;
  font-family: "Josefin Sans", sans-serif;
  display: block;
  line-height: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #design .design_ttl span {
    font-size: 34px;
    letter-spacing: 0.08em;
  }
}
#page2 #design .design_list01 {
  padding-bottom: 30px;
  margin-top: 35px;
  position: relative;
  text-align: left;
}
@media screen and (max-width: 850px) {
  #page2 #design .design_list01 {
    padding-bottom: 15px;
    margin-top: 25px;
  }
}
#page2 #design .design_list01:after {
  width: 42px;
  height: 1px;
  position: absolute;
  content: '';
  left: 0;
  bottom: 0;
  background: #031D1D;
}
@media screen and (max-width: 850px) {
  #page2 #design .design_list01:after {
    width: 20px;
  }
}
#page2 #design .design_list01 .ttl_item {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 35px;
  width: fit-content;
}
@media screen and (max-width: 850px) {
  #page2 #design .design_list01 .ttl_item {
    margin-top: 11px;
  }
}
#page2 #design .design_list01 .ttl_item .icon {
  width: auto;
  height: 63px;
}
@media screen and (max-width: 850px) {
  #page2 #design .design_list01 .ttl_item .icon {
    height: 28px;
  }
}
#page2 #design .design_list01 .ttl_item .ttl {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.1em;
  margin-left: 30px;
  text-align: left;
  line-height: 1;
}
@media screen and (max-width: 850px) {
  #page2 #design .design_list01 .ttl_item .ttl {
    font-size: 10px;
    margin-left: 12px;
  }
}
#page2 #design .design_list01 .ttl_item .ttl span {
  display: block;
  font-size: 45px;
  font-weight: 400;
  letter-spacing: 0.2em;
  font-family: "Garamond Premier Pro", serif;
}
@media screen and (max-width: 850px) {
  #page2 #design .design_list01 .ttl_item .ttl span {
    font-size: 20px;
  }
}
#page2 #design #hierarchy {
  padding-top: 120px;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy {
    padding-top: 60px;
  }
}
#page2 #design #hierarchy .design_list01 {
  padding-bottom: 30px;
  margin-top: 35px;
  position: relative;
  text-align: left;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .design_list01 {
    padding-bottom: 15px;
    margin-top: 25px;
  }
}
#page2 #design #hierarchy .design_list01:after {
  width: 42px;
  height: 1px;
  position: absolute;
  content: '';
  left: 0;
  bottom: 0;
  background: #031D1D;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .design_list01:after {
    width: 20px;
  }
}
#page2 #design #hierarchy .slide_hierarchy {
  margin-top: 35px;
  padding-bottom: 70px;
  padding-right: 50px;
  position: relative;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .slide_hierarchy {
    padding-bottom: 65px;
    padding-right: 0;
    margin-top: 25px;
    min-height: 360px;
  }
}
#page2 #design #hierarchy .swiper-button-next-hi {
  position: absolute;
  cursor: pointer;
  left: 113px;
  right: auto;
  width: 51px;
  height: 51px;
  top: auto;
  bottom: 0;
  z-index: 100;
}
#page2 #design #hierarchy .swiper-button-next-hi img {
  width: 51px;
  height: 51px;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .swiper-button-next-hi img {
    width: 46px;
    height: 46px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .swiper-button-next-hi {
    width: 45px;
    height: 45px;
    bottom: 0;
    left: 100px;
  }
}
#page2 #design #hierarchy .swiper-button-next-hi::after {
  display: none;
}
#page2 #design #hierarchy .swiper-button-next-hi .none {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #design #hierarchy .swiper-button-next-hi .on {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #design #hierarchy .swiper-button-next-hi:hover .none {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #design #hierarchy .swiper-button-next-hi:hover .on {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #design #hierarchy .swiper-button-prev-hi {
  position: absolute;
  cursor: pointer;
  width: 51px;
  height: 51px;
  bottom: 0;
  top: auto;
  z-index: 100;
  left: 0;
  right: auto;
}
#page2 #design #hierarchy .swiper-button-prev-hi img {
  width: 51px;
  height: 51px;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .swiper-button-prev-hi img {
    width: 46px;
    height: 46px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .swiper-button-prev-hi {
    width: 45px;
    height: 45px;
    bottom: 0;
  }
}
#page2 #design #hierarchy .swiper-button-prev-hi::after {
  display: none;
}
#page2 #design #hierarchy .swiper-button-prev-hi .none {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #design #hierarchy .swiper-button-prev-hi .on {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #design #hierarchy .swiper-button-prev-hi:hover .none {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #design #hierarchy .swiper-button-prev-hi:hover .on {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #design #hierarchy .ttl_item {
  display: flex;
  align-items: space-around;
  justify-content: center;
  margin-top: 27px;
  width: fit-content;
  width: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .ttl_item {
    margin-top: 20px;
  }
}
#page2 #design #hierarchy .ttl_item .r_txt {
  font-size: 20px;
  letter-spacing: 0;
  font-weight: 500;
  color: #ffffff;
  background: #030303;
  padding: 8px 8px;
  width: fit-content;
  margin-right: 0;
  margin-left: auto;
  line-height: 100%;
  height: fit-content;
}
@media screen and (max-width: 1380px) {
  #page2 #design #hierarchy .ttl_item .r_txt {
    font-size: 18px;
  }
}
@media screen and (max-width: 1280px) {
  #page2 #design #hierarchy .ttl_item .r_txt {
    font-size: 16px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .ttl_item .r_txt {
    padding: 5px 6px;
    font-size: 13px;
  }
}
#page2 #design #hierarchy .ttl_item .icon {
  margin-right: 15px;
  max-width: 35px;
}
#page2 #design #hierarchy .ttl_item .icon img {
  object-fit: scale-down;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .ttl_item .icon {
    max-width: 21px;
    margin-right: 12px;
  }
}
#page2 #design #hierarchy .ttl_item .icon28 {
  max-width: 28px;
  margin-right: 9px;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .ttl_item .icon28 {
    max-width: 17px;
    margin-right: 5px;
    letter-spacing: 0.08em;
  }
}
#page2 #design #hierarchy .ttl_item .icon26 {
  max-width: 26px;
  margin-right: 9px;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .ttl_item .icon26 {
    max-width: 15px;
    margin-right: 5px;
    letter-spacing: 0.08em;
  }
}
#page2 #design #hierarchy .ttl_item .ttl {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: left;
  line-height: 1;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .ttl_item .ttl {
    font-size: 10px;
  }
}
#page2 #design #hierarchy .ttl_item .ttl span {
  display: block;
  font-size: 38px;
  font-weight: 400;
  letter-spacing: 0.2em;
  font-family: "Garamond Premier Pro", serif;
}
@media screen and (max-width: 1380px) {
  #page2 #design #hierarchy .ttl_item .ttl span {
    font-size: 34px;
  }
}
@media screen and (max-width: 1280px) {
  #page2 #design #hierarchy .ttl_item .ttl span {
    font-size: 30px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .ttl_item .ttl span {
    font-size: 20px;
  }
}
#page2 #design #hierarchy .ttl_item .ttl .jp_ttl {
  padding-left: 50px;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .ttl_item .ttl .jp_ttl {
    padding-left: 35px;
  }
}
#page2 #design #hierarchy .ttl_item .ttl .ttl_icon {
  display: flex;
  align-items: flex-start;
}
#page2 #design #hierarchy .small {
  padding-right: 59px;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .small {
    padding-right: 41px;
  }
}
#page2 #design #hierarchy .small .ttl_item .ttl {
  font-size: 13px;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .small .ttl_item .ttl {
    font-size: 7px;
  }
}
#page2 #design #hierarchy .small .ttl_item .ttl span {
  font-size: 37px;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 1540px) {
  #page2 #design #hierarchy .small .ttl_item .ttl span {
    font-size: 30px;
    letter-spacing: 0.04em;
  }
}
@media screen and (max-width: 1280px) {
  #page2 #design #hierarchy .small .ttl_item .ttl span {
    font-size: 26px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .small .ttl_item .ttl span {
    font-size: 22px;
  }
}
#page2 #design #hierarchy .small .ttl_item .ttl .jp_ttl_37 {
  padding-left: 37px;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .small .ttl_item .ttl .jp_ttl_37 {
    padding-left: 22px;
  }
}
#page2 #design #hierarchy .small .ttl_item .ttl .jp_ttl_42 {
  padding-left: 42px;
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .small .ttl_item .ttl .jp_ttl_42 {
    padding-left: 24px;
  }
}
#page2 #design #hierarchy .small .ttl_item .r_txt {
  font-size: 16px;
  padding: 6px 8px;
}
@media screen and (max-width: 1540px) {
  #page2 #design #hierarchy .small .ttl_item .r_txt {
    font-size: 14px;
    padding: 4px 5px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #design #hierarchy .small .ttl_item .r_txt {
    padding: 4px 8px;
    font-size: 7px;
  }
}
#page2 #grade {
  margin-top: 110px;
  padding-right: 16.5%;
}
@media screen and (max-width: 1280px) {
  #page2 #grade {
    padding-right: 8%;
  }
}
@media screen and (max-width: 1100px) {
  #page2 #grade {
    padding-right: 4%;
  }
}
@media screen and (max-width: 850px) {
  #page2 #grade {
    display: block;
    padding-right: 15px;
    margin-top: 55px;
  }
}
#page2 #grade .grade_list {
  display: flex;
  flex-wrap: wrap;
  column-gap: 57px;
}
@media screen and (max-width: 850px) {
  #page2 #grade .grade_list {
    display: block;
  }
}
#page2 #grade .grade_list li {
  width: calc(50% - 28.5px);
  border: 2px solid #CBBDB2;
  margin-top: 50px;
}
@media screen and (max-width: 850px) {
  #page2 #grade .grade_list li {
    width: 100%;
    margin-top: 27px;
  }
}
#page2 #grade .grade_list li .img {
  padding-top: 15px;
  padding-bottom: 13px;
  text-align: center;
  width: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #grade .grade_list li .img {
    padding-top: 10px;
    padding-bottom: 8px;
  }
}
#page2 #grade .grade_list li .img img {
  max-width: 101px;
}
@media screen and (max-width: 850px) {
  #page2 #grade .grade_list li .img img {
    max-width: 60px;
  }
}
#page2 #grade .grade_list li .bg_txt {
  background: #EFEAE6;
  color: #666666;
  width: 100%;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.12em;
  padding: 15px 5px;
  line-height: 100%;
  text-align: center;
}
@media screen and (max-width: 850px) {
  #page2 #grade .grade_list li .bg_txt {
    font-size: 13px;
    padding: 9px 5px;
  }
}
#page2 #grade .grade_list li .ttl {
  color: #880602;
  background: #F7F7F7;
  padding: 2px 22px;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 120%;
  margin: auto;
  margin-top: -17px;
  width: fit-content;
}
@media screen and (max-width: 850px) {
  #page2 #grade .grade_list li .ttl {
    margin-top: -12px;
    font-size: 13px;
    letter-spacing: 0.1em;
  }
}
#page2 #step {
  position: relative;
  margin-top: -140px;
  z-index: 20;
}
@media screen and (max-width: 850px) {
  #page2 #step {
    margin-top: -80px;
  }
}
#page2 #step .inner {
  padding-top: 0;
  max-width: 1230px;
  position: relative;
  z-index: 5;
}
#page2 #step .after_txt {
  position: absolute;
  right: -20px;
  top: 35px;
  text-align: left;
  font-size: 127px;
  letter-spacing: 0.05em;
  line-height: 1.118;
  color: #F7F7F7;
  font-family: "Josefin Sans", sans-serif;
}
#page2 #step .after_txt .m_20 {
  margin-left: 90px;
}
@media screen and (max-width: 850px) {
  #page2 #step .after_txt {
    display: none;
  }
}
#page2 #step .step_ttl {
  display: flex;
  align-items: flex-end;
  color: #030303;
  width: fit-content;
  margin: auto;
  margin-bottom: 20px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_ttl {
    margin-bottom: 0;
    align-items: baseline;
  }
}
#page2 #step .step_ttl .jp_ttl {
  font-size: 27px;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 100%;
  padding-bottom: 12px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_ttl .jp_ttl {
    font-size: 17px;
  }
}
#page2 #step .step_ttl .en_ttl {
  font-size: 60px;
  font-weight: 400;
  font-family: "Josefin Sans", sans-serif;
  letter-spacing: 0.1em;
  line-height: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_ttl .en_ttl {
    font-size: 32px;
  }
}
#page2 #step .step_ttl .num {
  font-size: 60px;
  font-weight: bold;
  letter-spacing: 0.1em;
  padding-bottom: 12px;
  margin-right: 13px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_ttl .num {
    margin-right: 5px;
    padding-bottom: 0;
  }
}
#page2 #step .step_ttl .num img {
  max-width: 91px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_ttl .num img {
    max-width: 52px;
  }
}
#page2 #step p {
  font-size: 15px;
  font-weight: 500;
  line-height: 2;
  text-align: center;
  color: #363636;
}
@media screen and (max-width: 850px) {
  #page2 #step p {
    font-size: 13px;
  }
}
#page2 #step .step_list {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  margin-top: 100px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list {
    margin-left: 17px;
    display: block;
    margin-top: 30px;
    padding-bottom: 35px;
  }
}
#page2 #step .step_list:after {
  width: 2px;
  height: 100%;
  content: '';
  position: absolute;
  left: calc(50% - 1px);
  background: #030303;
  top: 0;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list:after {
    top: 35px;
    left: 0;
  }
}
#page2 #step .step_list li {
  width: 50%;
  position: relative;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li {
    width: 100%;
  }
}
#page2 #step .step_list li:nth-child(1) {
  margin-right: 50%;
  padding-right: 40px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(1) {
    margin-right: 0;
    padding-right: 0;
  }
}
#page2 #step .step_list li:nth-child(1)::after {
  width: 22px;
  height: 22px;
  content: '';
  position: absolute;
  border-radius: 100%;
  right: -11px;
  top: 0;
  background: #030303;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(1)::after {
    left: -10px;
    right: auto;
    top: 35px;
  }
}
#page2 #step .step_list li:nth-child(1) .ttl {
  flex-direction: row-reverse;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(1) .ttl {
    flex-direction: row;
  }
}
#page2 #step .step_list li:nth-child(1) .ttl .icon {
  margin-left: 25px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(1) .ttl .icon {
    margin-left: 35px;
    margin-right: 3px;
  }
}
#page2 #step .step_list li:nth-child(1) .content {
  padding-right: 91px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(1) .content {
    padding-right: 0;
  }
}
#page2 #step .step_list li:nth-child(1) .content img {
  margin-top: 22px;
  margin-bottom: 35px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(1) .content img {
    max-width: 247px;
    margin-top: 18px;
    margin-bottom: 25px;
  }
}
#page2 #step .step_list li:nth-child(1) p {
  padding-right: 30px;
  padding-left: 85px;
  text-align: left;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(1) p {
    padding-right: 0;
    padding-left: 35px;
  }
}
#page2 #step .step_list li:nth-child(2) {
  margin-left: 50%;
  padding-left: 32px;
  margin-top: -180px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(2) {
    width: 100%;
    margin-left: 0;
    margin-top: 60px;
    padding-left: 35px;
  }
}
#page2 #step .step_list li:nth-child(2)::after {
  width: 22px;
  height: 22px;
  content: '';
  position: absolute;
  border-radius: 100%;
  left: -11px;
  top: 0;
  background: #030303;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(2)::after {
    left: -10px;
    right: auto;
    top: 30px;
  }
}
#page2 #step .step_list li:nth-child(2) .ttl .icon {
  margin-right: 30px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(2) .ttl .icon {
    margin-left: 0;
    margin-right: 3px;
  }
}
#page2 #step .step_list li:nth-child(2) .content {
  padding-left: 35px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(2) .content {
    padding-left: 0;
  }
}
#page2 #step .step_list li:nth-child(2) .content img {
  margin-top: 22px;
  margin-bottom: 45px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(2) .content img {
    margin-top: 10px;
    margin-bottom: 20px;
  }
}
#page2 #step .step_list li:nth-child(2) p {
  text-align: left;
}
#page2 #step .step_list li:nth-child(3) {
  margin-right: 50%;
  padding-right: 40px;
  margin-top: 45px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(3) {
    width: 100%;
    padding-right: 0;
    margin-right: 0;
    padding-left: 35px;
  }
}
#page2 #step .step_list li:nth-child(3)::after {
  width: 22px;
  height: 22px;
  content: '';
  position: absolute;
  border-radius: 100%;
  right: -11px;
  top: 0;
  background: #030303;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(3)::after {
    left: -10px;
    right: auto;
    top: 28px;
  }
}
#page2 #step .step_list li:nth-child(3) .sp_hoshi {
  display: none;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(3) .sp_hoshi {
    display: block;
    max-width: 137px;
    margin-top: 17px;
    margin-bottom: 17px;
  }
}
#page2 #step .step_list li:nth-child(3) .ttl {
  flex-direction: row-reverse;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(3) .ttl {
    flex-direction: row;
  }
}
#page2 #step .step_list li:nth-child(3) .ttl .icon {
  margin-left: 25px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(3) .ttl .icon {
    margin-left: 0;
    margin-right: 3px;
  }
}
#page2 #step .step_list li:nth-child(3) .ttl .txt {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(3) .ttl .txt {
    flex-direction: row;
  }
}
#page2 #step .step_list li:nth-child(3) .ttl .txt img {
  max-width: 191px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(3) .ttl .txt img {
    display: none;
  }
}
#page2 #step .step_list li:nth-child(3) .content {
  padding-right: 91px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(3) .content {
    padding-right: 0;
  }
}
#page2 #step .step_list li:nth-child(3) p {
  padding-right: 20px;
  text-align: left;
  margin-top: 25px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li:nth-child(3) p {
    padding-right: 0;
    margin-top: 0;
  }
}
#page2 #step .step_list li .ttl {
  display: flex;
  align-items: flex-end;
  margin-top: -50px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li .ttl {
    margin-top: 0;
  }
}
#page2 #step .step_list li .ttl .icon img {
  max-width: 66px;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li .ttl .icon img {
    max-width: 42px;
  }
}
#page2 #step .step_list li .ttl .txt {
  font-size: 28px;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: #030303;
}
@media screen and (max-width: 850px) {
  #page2 #step .step_list li .ttl .txt {
    font-size: 18px;
    padding-bottom: 8px;
  }
}
#page2 #step .end_item {
  text-align: center;
  width: fit-content;
  margin: auto;
  font-size: 34px;
  letter-spacing: 0.1em;
  font-weight: 500;
  color: #030303;
}
@media screen and (max-width: 850px) {
  #page2 #step .end_item {
    top: 35px;
    left: 0;
    text-align: left;
    font-size: 25px;
    width: 100%;
    margin-left: 52px;
  }
}
#page2 #step .end_item .txt {
  padding-left: 25px;
}
@media screen and (max-width: 850px) {
  #page2 #step .end_item .txt {
    padding-left: 0;
  }
}
#page2 #step .end_item img {
  max-width: 321px;
  margin-top: 15px;
}
@media screen and (max-width: 850px) {
  #page2 #step .end_item img {
    max-width: 226px;
    margin-top: 8px;
  }
}
#page2 #plan .inner {
  padding-top: 210px;
  max-width: 1230px;
  padding-bottom: 120px;
}
@media screen and (max-width: 850px) {
  #page2 #plan .inner {
    padding-bottom: 70px;
    padding-top: 90px;
  }
}
#page2 #plan .plan_ttl {
  line-height: 100%;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: center;
  padding-bottom: 40px;
  border-bottom: 1px solid #030303;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_ttl {
    padding-bottom: 18px;
    font-size: 12px;
  }
}
#page2 #plan .plan_ttl span {
  font-size: 50px;
  letter-spacing: 0.2em;
  font-weight: 400;
  font-family: "Josefin Sans", sans-serif;
  display: block;
  line-height: 100%;
  margin-top: 10px;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_ttl span {
    font-size: 34px;
    letter-spacing: 0.08em;
  }
}
#page2 #plan .plan_list {
  display: flex;
  column-gap: 200px;
  margin-top: 75px;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list {
    margin-top: 30px;
    display: block;
  }
}
#page2 #plan .plan_list li {
  width: calc(33.3333% - 133.333px);
  position: relative;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list li {
    width: 100%;
    max-width: 226px;
    margin: auto;
  }
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list li + li {
    margin-top: 80px;
  }
}
#page2 #plan .plan_list li + li::after {
  position: absolute;
  content: "";
  width: 56px;
  height: 58px;
  left: -45%;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/top/plan_icon.png) no-repeat center / contain;
  transition: 0.3s ease-in-out;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list li + li::after {
    width: 31px;
    height: 32px;
    left: calc(50% - 15.5px);
    background: url(../img/top/plan_icon_sp.png) no-repeat center / contain;
    top: -40px;
  }
}
#page2 #plan .plan_list .plan_img01 {
  margin-top: 15px;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .plan_img01 {
    margin-top: 3px;
  }
  #page2 #plan .plan_list .plan_img01 img {
    max-width: 136px;
  }
}
#page2 #plan .plan_list .plan_img02 {
  margin-top: 20px;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .plan_img02 {
    margin-top: 10px;
  }
  #page2 #plan .plan_list .plan_img02 img {
    max-width: 136px;
  }
}
#page2 #plan .plan_list .ttl_item01 {
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
}
#page2 #plan .plan_list .ttl_item01 .icon {
  width: 56px;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .ttl_item01 .icon {
    width: 28px;
  }
}
#page2 #plan .plan_list .ttl_item01 .ttl {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.1em;
  margin-left: 15px;
  text-align: left;
  line-height: 1;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .ttl_item01 .ttl {
    font-size: 10px;
    margin-left: 12px;
  }
}
#page2 #plan .plan_list .ttl_item01 .ttl span {
  display: block;
  font-size: 38px;
  font-weight: 400;
  letter-spacing: 0.2em;
  font-family: "Garamond Premier Pro", serif;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .ttl_item01 .ttl span {
    font-size: 20px;
  }
}
#page2 #plan .plan_list .ttl_item02 {
  display: flex;
  align-items: space-around;
  justify-content: center;
  width: fit-content;
  width: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .ttl_item02 {
    max-width: 182px;
  }
}
#page2 #plan .plan_list .ttl_item02 .r_txt {
  font-size: 16px;
  letter-spacing: 0;
  font-weight: 500;
  color: #ffffff;
  background: #030303;
  padding: 8px 8px;
  width: fit-content;
  margin-right: 0;
  margin-left: auto;
  line-height: 100%;
  height: fit-content;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .ttl_item02 .r_txt {
    padding: 2px 6px;
    font-size: 13px;
  }
}
#page2 #plan .plan_list .ttl_item02 .icon {
  margin-right: 10px;
  max-width: 30px;
}
#page2 #plan .plan_list .ttl_item02 .icon img {
  max-width: 30px;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .ttl_item02 .icon img {
    max-width: 17px;
  }
}
#page2 #plan .plan_list .ttl_item02 .ttl {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: left;
  line-height: 1;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .ttl_item02 .ttl {
    font-size: 10px;
  }
}
#page2 #plan .plan_list .ttl_item02 .ttl span {
  display: block;
  font-size: 38px;
  font-weight: 400;
  letter-spacing: 0.2em;
  font-family: "Garamond Premier Pro", serif;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .ttl_item02 .ttl span {
    font-size: 20px;
  }
}
#page2 #plan .plan_list .ttl_item02 .ttl .jp_ttl {
  padding-left: 50px;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .ttl_item02 .ttl .jp_ttl {
    padding-left: 30px;
  }
}
#page2 #plan .plan_list .ttl_item02 .ttl .ttl_icon {
  display: flex;
  align-items: flex-start;
}
#page2 #plan .plan_list .list03 {
  width: 100%;
  border: 2px solid #CBBDB2;
  margin-top: 20px;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .list03 {
    width: 100%;
    margin-top: 27px;
  }
}
#page2 #plan .plan_list .list03 .img {
  padding-top: 15px;
  padding-bottom: 13px;
  text-align: center;
  width: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .list03 .img {
    padding-top: 10px;
    padding-bottom: 8px;
  }
}
#page2 #plan .plan_list .list03 .img img {
  max-width: 80px;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .list03 .img img {
    max-width: 60px;
  }
}
#page2 #plan .plan_list .list03 .bg_txt {
  background: #EFEAE6;
  color: #666666;
  width: 100%;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.12em;
  padding: 15px 5px;
  line-height: 100%;
  text-align: center;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .list03 .bg_txt {
    font-size: 13px;
    padding: 9px 5px;
  }
}
#page2 #plan .plan_list .list03 .ttl {
  color: #880602;
  background: #fff;
  padding: 2px 22px;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 120%;
  margin: auto;
  margin-top: -17px;
  width: fit-content;
}
@media screen and (max-width: 850px) {
  #page2 #plan .plan_list .list03 .ttl {
    margin-top: -12px;
    font-size: 13px;
    letter-spacing: 0.1em;
  }
}
#page2 #plan_content {
  background: #FAF3D9;
  position: relative;
}
#page2 #plan_content::after {
  position: absolute;
  content: "";
  width: 127px;
  height: 72px;
  left: calc(50% - 63.5px);
  top: -2px;
  background: url(../img/top/plan_list.png) no-repeat center / contain;
  transition: 0.3s ease-in-out;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content::after {
    width: 49px;
    height: 28px;
    left: calc(50% - 24.5px);
    top: -1px;
  }
}
#page2 #plan_content .inner {
  padding-top: 145px;
  max-width: 1230px;
  padding-bottom: 110px;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .inner {
    padding-bottom: 65px;
    padding-top: 75px;
  }
}
#page2 #plan_content dl {
  display: flex;
  margin-bottom: 25px;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content dl {
    margin-bottom: 40px;
    display: block;
  }
}
#page2 #plan_content dl dt {
  width: 50%;
  padding-right: 55px;
}
@media screen and (max-width: 1200px) {
  #page2 #plan_content dl dt {
    width: 60%;
  }
}
@media screen and (max-width: 850px) {
  #page2 #plan_content dl dt {
    width: 100%;
    padding-right: 0;
  }
}
#page2 #plan_content dl dd {
  width: 50%;
  text-align: right;
}
@media screen and (max-width: 1200px) {
  #page2 #plan_content dl dd {
    width: 40%;
  }
}
@media screen and (max-width: 850px) {
  #page2 #plan_content dl dd {
    margin-top: 50px;
    width: 100%;
    padding-left: 30px;
    padding-right: 30px;
  }
}
#page2 #plan_content dl dd img {
  max-width: 441px;
  width: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content dl dd img {
    max-width: 100%;
  }
}
#page2 #plan_content .sub_ttl {
  background: #ffffff;
  font-size: 24px;
  color: #030303;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 10px;
  padding-bottom: 10px;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .sub_ttl {
    font-size: 17px;
  }
}
#page2 #plan_content .sub_ttl img {
  margin-left: 10px;
  margin-right: 15px;
  width: 21px;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .sub_ttl img {
    width: 12px;
    margin-right: 10px;
  }
}
#page2 #plan_content .sub_ttl .red {
  color: #880602;
  font-size: 23px;
  font-weight: 500;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .sub_ttl .red {
    font-size: 15px;
  }
}
#page2 #plan_content .sub_ttl span {
  display: flex;
  align-items: center;
}
#page2 #plan_content .sub_ttl .black {
  background: #030303;
  padding: 2px 10px;
  color: #ffffff;
  font-size: 15px;
  line-height: 140%;
  margin-left: 5px;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .sub_ttl .black {
    font-size: 10px;
    padding: 1px 10px;
  }
}
#page2 #plan_content .btn_line_item {
  max-width: 510px;
  background: #ffffff;
  margin: auto;
}
#page2 #plan_content .btn_line_item .btn_line span {
  font-size: 24px;
  text-align: center;
  padding: 30px 20px;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .btn_line_item .btn_line span {
    font-size: 18px;
    padding: 17px 10px;
  }
}
#page2 #plan_content .tag {
  text-align: left;
  font-size: 24px;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: #000000;
  border-bottom: 1px solid #ffffff;
  padding-bottom: 15px;
  line-height: 100%;
  width: fit-content;
  margin-top: 20px;
  padding-right: 60px;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .tag {
    font-size: 16px;
    margin-top: 15px;
    padding-bottom: 10px;
  }
}
#page2 #plan_content .tag span {
  font-size: 45px;
  letter-spacing: 0.05em;
  font-family: "Josefin Sans", sans-serif;
  font-weight: 400;
  line-height: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .tag span {
    font-size: 29px;
  }
}
#page2 #plan_content .ttl_flex {
  margin-top: 30px;
  display: flex;
  margin-bottom: 22px;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .ttl_flex {
    margin-bottom: 15px;
    margin-top: 20px;
  }
}
#page2 #plan_content .ttl_flex .flex_l .unity {
  font-size: 21px;
  font-family: "Josefin Sans", sans-serif;
  font-weight: 400;
  line-height: 100%;
  border: 0.7px solid #4D4D4D;
  width: 107px;
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #4D4D4D;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .ttl_flex .flex_l .unity {
    font-size: 13px;
    width: 73px;
    height: 23px;
  }
}
#page2 #plan_content .ttl_flex .flex_l .hei {
  margin-top: 10px;
  font-size: 24px;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.05em;
  width: 107px;
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #CBBDB2;
  background: #4D4D4D;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .ttl_flex .flex_l .hei {
    margin-top: 7px;
    font-size: 15px;
    width: 73px;
    height: 23px;
  }
}
#page2 #plan_content .ttl_flex .flex_r {
  width: fit-content;
  text-align: center;
  margin-left: 20px;
}
#page2 #plan_content .ttl_flex .flex_r p {
  color: #880602;
  font-size: 24px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 100%;
  text-align: center;
  width: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .ttl_flex .flex_r p {
    font-size: 15px;
  }
}
#page2 #plan_content .ttl_flex .flex_r img {
  max-width: 7.3px;
  margin-top: 4px;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .ttl_flex .flex_r img {
    max-width: 5px;
  }
}
#page2 #plan_content .price {
  padding-top: 11px ;
  border-top: 1px solid #000000;
  width: 100%;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .price {
    padding-top: 8px ;
  }
}
#page2 #plan_content .price .bg_txt {
  color: #FAF3D9;
  background: #000000;
  text-align: center;
  padding: 5px;
  line-height: 100%;
  display: block;
  width: fit-content;
  height: fit-content;
  margin-right: 15px;
  margin-bottom: 5px;
  font-size: 16px;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .price .bg_txt {
    margin-right: 5px;
    font-size: 12px;
  }
}
#page2 #plan_content .price .num {
  font-size: 65px;
  font-family: "Josefin Sans", sans-serif;
  font-weight: 400;
  letter-spacing: 0.01em;
  line-height: 100%;
  color: #000000;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .price .num {
    font-size: 43px;
  }
}
#page2 #plan_content .price .kala {
  font-size: 39px;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 100%;
  margin-left: 10px;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .price .kala {
    font-size: 24px;
  }
}
#page2 #plan_content .price .txt {
  font-size: 28px;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .price .txt {
    font-size: 17px;
  }
}
#page2 #plan_content .small_p {
  margin-top: 10px;
  text-align: left;
  color: #363636;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 2;
}
@media screen and (max-width: 850px) {
  #page2 #plan_content .small_p {
    font-size: 13px;
    margin-top: 5px;
  }
}
#page2 #staff {
  background: #F7F7F7;
}
#page2 #staff .inner {
  padding-top: 145px;
  max-width: 1000px;
  padding-bottom: 130px;
}
@media screen and (max-width: 1200px) {
  #page2 #staff .inner {
    max-width: 800px;
  }
}
@media screen and (max-width: 980px) {
  #page2 #staff .inner {
    max-width: 720px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #staff .inner {
    padding-bottom: 30px;
    padding-top: 40px;
  }
}
#page2 #staff .staff_ttl {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: center;
  color: #030303;
}
#page2 #staff .staff_item {
  position: relative;
  margin-top: 50px;
}
@media screen and (max-width: 850px) {
  #page2 #staff .staff_item {
    margin-top: 30px;
  }
}
#page2 #staff .swiper-button-next-staff {
  position: absolute;
  cursor: pointer;
  right: -115px;
  left: auto;
  width: 51px;
  height: 51px;
  top: 50%;
  bottom: auto;
  z-index: 100;
}
@media screen and (max-width: 1200px) {
  #page2 #staff .swiper-button-next-staff {
    right: -75px;
  }
}
#page2 #staff .swiper-button-next-staff img {
  width: 51px;
  height: 51px;
}
@media screen and (max-width: 850px) {
  #page2 #staff .swiper-button-next-staff img {
    width: 46px;
    height: 46px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #staff .swiper-button-next-staff {
    width: 45px;
    height: 45px;
    right: -10px;
    left: auto;
    display: none;
  }
}
#page2 #staff .swiper-button-next-staff::after {
  display: none;
}
#page2 #staff .swiper-button-next-staff .none {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #staff .swiper-button-next-staff .on {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #staff .swiper-button-next-staff:hover .none {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #staff .swiper-button-next-staff:hover .on {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #staff .swiper-button-prev-staff {
  position: absolute;
  cursor: pointer;
  width: 51px;
  height: 51px;
  top: 50%;
  bottom: auto;
  z-index: 100;
  left: -115px;
  right: auto;
}
@media screen and (max-width: 1200px) {
  #page2 #staff .swiper-button-prev-staff {
    left: -75px;
  }
}
#page2 #staff .swiper-button-prev-staff img {
  width: 51px;
  height: 51px;
}
@media screen and (max-width: 850px) {
  #page2 #staff .swiper-button-prev-staff img {
    width: 46px;
    height: 46px;
  }
}
@media screen and (max-width: 850px) {
  #page2 #staff .swiper-button-prev-staff {
    width: 45px;
    height: 45px;
    left: -10px;
    display: none;
  }
}
#page2 #staff .swiper-button-prev-staff::after {
  display: none;
}
#page2 #staff .swiper-button-prev-staff .none {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #staff .swiper-button-prev-staff .on {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #staff .swiper-button-prev-staff:hover .none {
  display: none;
  transition: 0.3s ease-in-out;
}
#page2 #staff .swiper-button-prev-staff:hover .on {
  display: block;
  transition: 0.3s ease-in-out;
}
#page2 #staff dl {
  display: flex;
}
@media screen and (max-width: 850px) {
  #page2 #staff dl {
    display: block;
  }
}
#page2 #staff dl dt {
  width: 47%;
}
@media screen and (max-width: 1200px) {
  #page2 #staff dl dt {
    width: 42%;
  }
}
@media screen and (max-width: 850px) {
  #page2 #staff dl dt {
    width: 100%;
    display: flex;
  }
}
#page2 #staff dl dt .img {
  position: relative;
}
@media screen and (max-width: 850px) {
  #page2 #staff dl dt .img {
    width: 181px;
  }
}
#page2 #staff dl dt .img:after {
  position: absolute;
  content: '';
  background: #EEEAE6;
  width: 100%;
  height: 100%;
  right: -20px;
  bottom: -20px;
  z-index: 1;
}
@media screen and (max-width: 850px) {
  #page2 #staff dl dt .img:after {
    right: -10px;
    bottom: -10px;
  }
}
#page2 #staff dl dt .img img {
  position: relative;
  z-index: 5;
}
#page2 #staff dl dt .ttl {
  display: none;
}
@media screen and (max-width: 850px) {
  #page2 #staff dl dt .ttl {
    width: calc(100% - 181px);
  }
}
@media screen and (max-width: 850px) {
  #page2 #staff dl dt .ttl {
    display: flex;
  }
}
#page2 #staff dl dd {
  width: 53%;
  padding-left: 110px;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 1200px) {
  #page2 #staff dl dd {
    padding-left: 40px;
    width: 58%;
  }
}
@media screen and (max-width: 850px) {
  #page2 #staff dl dd {
    width: 100%;
    padding-left: 0;
  }
}
#page2 #staff dl dd p {
  margin-top: 40px;
  font-size: 15px;
  font-weight: 500;
  line-height: 2;
  text-align: left;
  letter-spacing: 0;
}
@media screen and (max-width: 850px) {
  #page2 #staff dl dd p {
    font-size: 13px;
  }
}
#page2 #staff dl dd .ttl {
  display: flex;
}
@media screen and (max-width: 850px) {
  #page2 #staff dl dd .ttl {
    display: none;
  }
}
#page2 #staff dl .ttl {
  display: flex;
  align-items: flex-end;
}
@media screen and (max-width: 850px) {
  #page2 #staff dl .ttl {
    padding-left: 10px;
    align-items: center;
    justify-content: center;
  }
}
#page2 #staff dl .ttl .b_txt {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 850px) {
  #page2 #staff dl .ttl .b_txt {
    display: block;
  }
}
#page2 #staff dl .ttl .com {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.1em;
  margin-right: 15px;
  line-height: 100%;
  color: #030303;
}
@media screen and (max-width: 850px) {
  #page2 #staff dl .ttl .com {
    font-size: 13px;
    margin-bottom: 10px;
    display: block;
    margin-right: 0;
    text-align: left;
  }
}
#page2 #staff dl .ttl .name {
  font-size: 28px;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: #030303;
  line-height: 100%;
  margin-right: 10px;
}
@media screen and (max-width: 850px) {
  #page2 #staff dl .ttl .name {
    font-size: 20px;
    text-align: left;
    display: block;
    margin-right: 0;
  }
}
#page2 #staff dl .ttl .en {
  font-size: 15px;
  font-weight: 400;
  font-family: "Josefin Sans", sans-serif;
  letter-spacing: 0;
  color: #D0C9C4;
  line-height: 100%;
}
@media screen and (max-width: 850px) {
  #page2 #staff dl .ttl .en {
    text-align: left;
    display: block;
    font-size: 9px;
    margin-right: 0;
    margin-top: 8px;
  }
}
#support {
  position: relative;
  background: #F7F7F7;
}
#support .inner {
  max-width: 100%;
  padding: 90px 70px 110px 70px;
}
@media screen and (max-width: 850px) {
  #support .inner {
    padding: 45px 20px 20px 20px;
  }
}
#support .s_h2_ttl {
  text-align: left;
  font-size: 20px;
  font-weight: bold;
  color: #363636;
  line-height: 1;
}
@media screen and (max-width: 850px) {
  #support .s_h2_ttl {
    font-size: 10px;
    text-align: center;
  }
}
#support .s_h2_ttl span {
  text-align: left;
  font-family: "Garamond Premier Pro", serif;
  width: fit-content;
  display: block;
  font-size: 64px;
  font-weight: 400;
  line-height: 100%;
  margin-bottom: 15px;
  background: linear-gradient(315deg, #CB6DC7, #843FF5);
  background: -webkit-linear-gradient(315deg, #CB6DC7, #843FF5);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-wrap: nowrap;
}
@media screen and (max-width: 1100px) {
  #support .s_h2_ttl span {
    font-size: 52px;
  }
}
@media screen and (max-width: 1000px) {
  #support .s_h2_ttl span {
    font-size: 64px;
  }
}
@media screen and (max-width: 850px) {
  #support .s_h2_ttl span {
    font-size: 42px;
    text-align: center;
    margin: auto;
    margin-bottom: 10px;
  }
}
#support .s_content {
  display: flex;
}
@media screen and (max-width: 850px) {
  #support .s_content {
    display: block;
  }
}
#support .s_content .s_l {
  text-align: left;
  width: 35%;
}
@media screen and (max-width: 850px) {
  #support .s_content .s_l {
    width: 100%;
    text-align: center;
  }
}
#support .s_content .s_r {
  width: 65%;
  text-align: left;
}
@media screen and (max-width: 850px) {
  #support .s_content .s_r {
    width: 100%;
    margin-top: 45px;
  }
}
#support .s_content .s_r ul {
  width: 100%;
  border-top: #C6C6C6 1px solid;
}
#support .s_content .s_r ul li {
  padding: 20px 20px 20px 60px;
  border-bottom: #C6C6C6 1px solid;
  text-align: left;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  font-size: 24px;
  font-weight: 400;
  letter-spacing: 0;
  font-family: "Garamond Premier Pro", serif;
  line-height: 100%;
  color: #6E6E6E;
  margin: auto;
}
@media screen and (max-width: 1200px) {
  #support .s_content .s_r ul li {
    padding: 20px 20px 20px 40px;
    font-size: 24px;
  }
}
@media screen and (max-width: 1100px) {
  #support .s_content .s_r ul li {
    padding: 20px 20px 20px 20px;
  }
}
@media screen and (max-width: 1000px) {
  #support .s_content .s_r ul li {
    font-size: 20px;
    padding: 15px 20px 15px 20px;
  }
}
@media screen and (max-width: 850px) {
  #support .s_content .s_r ul li {
    display: block;
    font-size: 15px;
    padding: 9px 0 12px 0;
  }
}
#support .s_content .s_r ul li span {
  line-height: 100%;
  padding-left: 47px;
  font-family: "Noto Sans JP", sans-serif;
  text-align: left;
  width: fit-content;
  display: block;
  font-size: 24px;
  font-weight: 400;
  background: linear-gradient(315deg, #CB6DC7, #843FF5);
  background: -webkit-linear-gradient(315deg, #CB6DC7, #843FF5);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-wrap: nowrap;
}
@media screen and (max-width: 1200px) {
  #support .s_content .s_r ul li span {
    padding-left: 30px;
    font-size: 24px;
  }
}
@media screen and (max-width: 1000px) {
  #support .s_content .s_r ul li span {
    font-size: 20px;
  }
}
@media screen and (max-width: 850px) {
  #support .s_content .s_r ul li span {
    display: block;
    padding-left: 0;
    margin-top: 5px;
    font-size: 16px;
  }
}
#lb {
  background: rgba(255, 255, 255, 0.8);
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  display: flex;
  margin-block: 0;
  margin-inline: 0;
  align-items: center;
  justify-content: center;
  z-index: 999999;
  transition: 0.3s ease-in-out;
  animation-delay: 2s;
}
#lb .lb_box {
  position: relative;
  background: linear-gradient(180deg, #CB6DC7 0%, #843FF5 100%);
  background-size: cover;
  z-index: 1;
  padding: 80px;
  border-radius: 22px;
  color: #ffffff;
  font-size: 18px;
  text-align: center;
  font-weight: 500;
  line-height: 1.8;
}
@media screen and (max-width: 850px) {
  #lb .lb_box {
    width: calc(100% - 40px);
    font-size: 14px;
    padding: 30px;
    border-radius: 14px;
  }
}
#lb .lb_box #lb_btn_c {
  position: absolute;
  width: 20px;
  height: 20px;
  right: 20px;
  top: 20px;
  cursor: pointer;
}
@media screen and (max-width: 850px) {
  #lb .lb_box #lb_btn_c {
    width: 18px;
    height: 18px;
    right: 15px;
    top: 15px;
  }
}
.btn_line {
  cursor: pointer;
}
#patie_lb01,
#patie_lb02 {
  background: #f7f7f7e8;
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  display: flex;
  margin-block: 0;
  margin-inline: 0;
  align-items: center;
  justify-content: center;
  z-index: 999999;
  transition: 0.3s ease-in-out;
  animation-delay: 2s;
}
#patie_lb01 .lb_box,
#patie_lb02 .lb_box {
  position: relative;
  background: #fff;
  background-size: cover;
  z-index: 1;
  padding: 80px;
  border-radius: 22px;
  color: #ffffff;
  font-size: 18px;
  text-align: center;
  font-weight: 500;
  max-width: 85%;
  max-height: 100%;
  color: #222222;
  line-height: 1.8;
  border: 1px solid #030303;
}
@media screen and (max-width: 850px) {
  #patie_lb01 .lb_box,
  #patie_lb02 .lb_box {
    width: calc(100% - 40px);
    font-size: 14px;
    padding: 30px;
    border-radius: 14px;
  }
}
#patie_lb01 .lb_box .ttl,
#patie_lb02 .lb_box .ttl {
  font-weight: bold;
  font-size: 20px;
  margin-bottom: 20px;
}
#patie_lb01 .lb_box .lb_btn,
#patie_lb02 .lb_box .lb_btn {
  position: absolute;
  width: 20px;
  height: 20px;
  right: 20px;
  top: 20px;
  cursor: pointer;
}
@media screen and (max-width: 850px) {
  #patie_lb01 .lb_box .lb_btn,
  #patie_lb02 .lb_box .lb_btn {
    width: 18px;
    height: 18px;
    right: 15px;
    top: 15px;
  }
}
/*一瞬表示されるのを防ぐ*/
.show {
  display: flex !important;
  transition: 1.4s ease-in-out !important;
}
.hide {
  display: none !important;
  transition: 2s ease-in-out !important;
}
