@charset "UTF-8";
/*============================================================================================================
	base
============================================================================================================*/
body {
  color: #000;
  -webkit-text-size-adjust: 100%;
  line-height: 2.25;
}

div, h1, h2, h3, h4, h5, h6, p, ul, ol, li, dl, dt, dd, th, td, section, article, header, footer, main, nav, span, a {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

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

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}
@media screen and (max-width: 767px) {
  img {
    width: 100%;
  }
}

h1, h2, h3, h4, h5, h6 {
  line-height: 1.4;
  font-weight: normal;
  margin: 0;
  word-wrap: break-word;
}

p, li, td, th, dt, dd {
  font-size: 19px;
  margin: 0;
  word-wrap: break-word;
}
@media screen and (max-width: 767px) {
  p, li, td, th, dt, dd {
    font-size: 15px;
  }
}

table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

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

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

li {
  list-style: none;
}

@media screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}
@media screen and (min-width: 375px) {
  .sp_small {
    display: none !important;
  }
}
/*------------------------------------------
	font
------------------------------------------*/
body {
  font-weight: 500;
  font-family: "Shippori Mincho B1", "Hiragino Mincho ProN", "Hiragino Mincho Pro", "游明朝体", YuMincho, "游明朝", "Yu Mincho", "HGS明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.f-playfair {
  font-family: "Playfair Display", serif;
}

.f-gothic {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "ヒラギノ角ゴ ProN W3", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", Meiryo, sans-serif;
}

/*------------------------------------------
	frame
------------------------------------------*/
@media screen and (min-width: 768px) {
  body {
    min-width: 1000px;
  }
}

/*------------------------------------------
	hover
------------------------------------------*/
@media screen and (min-width: 768px) {
  a {
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
  a:hover {
    opacity: 0.7;
  }
}
/*============================================================================================================
	animation
============================================================================================================*/
@-webkit-keyframes loadAnimae01 {
  0% {
    opacity: 0;
    -webkit-transform: rotate(-15deg);
            transform: rotate(-15deg);
  }
  100% {
    opacity: 1;
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
}
@keyframes loadAnimae01 {
  0% {
    opacity: 0;
    -webkit-transform: rotate(-15deg);
            transform: rotate(-15deg);
  }
  100% {
    opacity: 1;
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
}
@-webkit-keyframes loadAnimae02 {
  0% {
    opacity: 0;
    -webkit-transform: rotate(2deg);
            transform: rotate(2deg);
  }
  100% {
    opacity: 1;
    -webkit-transform: rotate(17deg);
            transform: rotate(17deg);
  }
}
@keyframes loadAnimae02 {
  0% {
    opacity: 0;
    -webkit-transform: rotate(2deg);
            transform: rotate(2deg);
  }
  100% {
    opacity: 1;
    -webkit-transform: rotate(17deg);
            transform: rotate(17deg);
  }
}
@-webkit-keyframes loadAnimae03 {
  0% {
    opacity: 0;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
  }
}
@keyframes loadAnimae03 {
  0% {
    opacity: 0;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
  }
}
@-webkit-keyframes opacity {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes opacity {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes hide {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
  40%, 100% {
    -webkit-transform: scale(1.3);
            transform: scale(1.3);
    opacity: 0;
  }
}
@keyframes hide {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
  40%, 100% {
    -webkit-transform: scale(1.3);
            transform: scale(1.3);
    opacity: 0;
  }
}
@-webkit-keyframes bound {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  10% {
    -webkit-transform: translateY(-8px);
            transform: translateY(-8px);
  }
  20% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes bound {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  10% {
    -webkit-transform: translateY(-8px);
            transform: translateY(-8px);
  }
  20% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes shadow {
  0% {
    -webkit-filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.9));
            filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.9));
  }
  100% {
    -webkit-filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0));
            filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0));
  }
}
@keyframes shadow {
  0% {
    -webkit-filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.9));
            filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.9));
  }
  100% {
    -webkit-filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0));
            filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0));
  }
}
@-webkit-keyframes bgSlide {
  0% {
    left: 0;
    width: 0;
  }
  50% {
    left: 0;
    width: 100%;
  }
  100% {
    left: 100%;
    width: 0;
  }
}
@keyframes bgSlide {
  0% {
    left: 0;
    width: 0;
  }
  50% {
    left: 0;
    width: 100%;
  }
  100% {
    left: 100%;
    width: 0;
  }
}
/*============================================================================================================
	js
============================================================================================================*/
/*------------------------------------------
	scroll action
------------------------------------------*/
.js-scroll {
  -webkit-transition: opacity 1s, -webkit-transform 1.5s;
  transition: opacity 1s, -webkit-transform 1.5s;
  transition: opacity 1s, transform 1.5s;
  transition: opacity 1s, transform 1.5s, -webkit-transform 1.5s;
}
.js-scroll:nth-child(2) {
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
}
.js-scroll:nth-child(3) {
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}
.js-scroll:nth-child(4) {
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}
.js-scroll:nth-child(5) {
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
}
.js-scroll:nth-child(6) {
  -webkit-transition-delay: 1s;
          transition-delay: 1s;
}
.js-scroll:nth-child(7) {
  -webkit-transition-delay: 1.2s;
          transition-delay: 1.2s;
}
.js-scroll:nth-child(8) {
  -webkit-transition-delay: 1.4s;
          transition-delay: 1.4s;
}
.js-scroll:nth-child(9) {
  -webkit-transition-delay: 1.6s;
          transition-delay: 1.6s;
}
.js-scroll:nth-child(10) {
  -webkit-transition-delay: 1.8s;
          transition-delay: 1.8s;
}
.js-scroll.is-fadeIn {
  opacity: 0;
}
.js-scroll.is-fadeIn.is-view {
  opacity: 1;
}
.js-scroll.is-fadeUp {
  -webkit-transform: translate(0, 100px);
          transform: translate(0, 100px);
}
.js-scroll.is-fadeUp.is-view {
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
}
@media screen and (max-width: 767px) {
  .js-scroll.is-fadeUp {
    -webkit-transform: translate(0, 40px);
            transform: translate(0, 40px);
  }
}
.js-scroll.is-slideIn {
  -webkit-transform: translateX(-50px);
          transform: translateX(-50px);
}
.js-scroll.is-slideIn.is-view {
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
}
.js-scroll.is-shadow.is-view {
  display: inline-block;
  background: -webkit-gradient(linear, left top, right top, from(rgba(255, 255, 255, 0.7)), color-stop(#fff), color-stop(rgba(255, 255, 255, 0.5)), color-stop(#fff), color-stop(rgba(255, 255, 255, 0.8)), color-stop(#fff), to(rgba(255, 255, 255, 0.7)));
  background: linear-gradient(to right, rgba(255, 255, 255, 0.7), #fff, rgba(255, 255, 255, 0.5), #fff, rgba(255, 255, 255, 0.8), #fff, rgba(255, 255, 255, 0.7));
  -webkit-background-clip: text;
  color: transparent;
  -webkit-filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.9));
          filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.9));
  -webkit-animation: shadow 1s forwards;
          animation: shadow 1s forwards;
}
.js-scroll.is-shadow:nth-child(2) {
  -webkit-transition-delay: 0.1s;
          transition-delay: 0.1s;
  -webkit-animation-delay: 0.3s;
          animation-delay: 0.3s;
}
.js-scroll.is-shadow:nth-child(3) {
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
}
.js-scroll.is-shadow:nth-child(4) {
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
  -webkit-animation-delay: 0.9s;
          animation-delay: 0.9s;
}
.js-scroll.is-shadow:nth-child(5) {
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
  -webkit-animation-delay: 1.2s;
          animation-delay: 1.2s;
}

/*============================================================================================================
	component
============================================================================================================*/
/*------------------------------------------
	inner
------------------------------------------*/
.c-inner01 {
  width: 100%;
  max-width: 1260px;
  margin: 0 auto;
  padding-left: 10px;
  padding-right: 10px;
}
@media screen and (max-width: 767px) {
  .c-inner01 {
    padding-left: 20px;
    padding-right: 20px;
  }
}

/*------------------------------------------
	color
------------------------------------------*/
.c-pink01 {
  color: #F86D79;
}

/*------------------------------------------
	btn
------------------------------------------*/
.c-btn01 {
  width: min(100%, 480px);
  color: #fff;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
}
.c-btn01 a {
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 70px;
  padding: 10px 45px;
  background: #9C1D2B;
  position: relative;
  z-index: 1;
}
.c-btn01 a::before, .c-btn01 a::after {
  content: "";
  display: block;
  position: absolute;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  pointer-events: none;
}
.c-btn01 a::before {
  width: 25px;
  height: 14px;
  background: url("../img/common/ico_arrow01.svg") no-repeat center/contain;
  z-index: 2;
  top: 0;
  right: 20px;
  bottom: 0;
  margin: auto;
}
.c-btn01 a::after {
  bottom: 0;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .c-btn01 a::after {
    width: calc(100% + 180px);
    height: 100%;
    background: linear-gradient(25deg, #F86D79 20px, #2C2C2C 20px);
    left: calc((100% + 130px) * -1);
    -webkit-clip-path: polygon(0 0, calc(100% - 140px) 0, 100% 100%, 0 100%);
    clip-path: polygon(0 0, calc(100% - 140px) 0, 100% 100%, 0 100%);
  }
  .c-btn01 a:hover {
    opacity: 1;
  }
  .c-btn01 a:hover::before {
    right: 15px;
  }
  .c-btn01 a:hover::after {
    left: 0;
  }
}
@media screen and (max-width: 767px) {
  .c-btn01 {
    width: min(100%, 350px);
    font-size: 13px;
  }
  .c-btn01 a {
    min-height: 50px;
    padding: 10px 30px;
  }
  .c-btn01 a::before {
    width: 20px;
    right: 10px;
  }
  .c-btn01 a::after {
    width: 50px;
    height: 22px;
    background: #2C2C2C;
    left: 0;
    -webkit-clip-path: polygon(0 0, 100% 100%, 0 100%);
    clip-path: polygon(0 0, 100% 100%, 0 100%);
  }
}

/*------------------------------------------
	cv
------------------------------------------*/
.c-cv01 {
  display: none;
  width: 170px;
  height: 161px;
  position: fixed;
  right: 50px;
  bottom: 50px;
  z-index: 9000;
}
.c-cv01 a {
  display: block;
  width: 100%;
  height: 100%;
  background: url("../img/common/bg_cv01.svg") no-repeat center/contain;
  position: relative;
  overflow: hidden;
}
.c-cv01__txt {
  width: calc(100% - 34px);
  height: calc(100% - 34px);
  padding: 18px 0 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: absolute;
  z-index: 2;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  color: #fff;
  font-weight: 700;
  text-align: center;
  line-height: 1.4;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.c-cv01__txt::before, .c-cv01__txt::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: #F86D79;
  position: absolute;
  pointer-events: none;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  -webkit-clip-path: polygon(50% 0, 100% 38%, 82% 100%, 18% 100%, 0 38%);
  clip-path: polygon(50% 0, 100% 38%, 82% 100%, 18% 100%, 0 38%);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.c-cv01__txt::before {
  z-index: -1;
  -webkit-animation: hide 4s ease-in-out infinite;
          animation: hide 4s ease-in-out infinite;
}
.c-cv01__txt::after {
  z-index: -2;
}
@media screen and (min-width: 768px) {
  .c-cv01 a:hover {
    opacity: 1;
  }
  .c-cv01 a:hover .c-cv01__txt {
    text-shadow: 0 0 5px rgba(255, 255, 255, 0.5);
  }
  .c-cv01 a:hover .c-cv01__txt::before, .c-cv01 a:hover .c-cv01__txt::after {
    background: #f64b5a;
  }
}
@media screen and (max-width: 767px) {
  .c-cv01 {
    width: 90px;
    height: 85px;
    right: 10px;
    bottom: 10px;
  }
  .c-cv01__txt {
    width: calc(100% - 16px);
    height: calc(100% - 16px);
    padding-top: 12px;
    font-size: 11px;
  }
}

/*------------------------------------------
	other
------------------------------------------*/
/* 左から背景が伸びて出現するテキスト (width '.js-scroll') */
.c-titBg01 {
  display: table;
  overflow: hidden;
  position: relative;
}
.c-titBg01::before {
  content: "";
  display: block;
  width: 0;
  height: 100%;
  background: #9C1D2B;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
.c-titBg01__txt {
  display: table;
  padding: 1px 10px;
  background: #F86D79;
  opacity: 0;
}
.c-titBg01.is-view::before {
  -webkit-animation: bgSlide 1s forwards;
          animation: bgSlide 1s forwards;
}
.c-titBg01.is-view .c-titBg01__txt {
  -webkit-animation: opacity 0.5s forwards;
          animation: opacity 0.5s forwards;
  -webkit-animation-delay: 0.5s;
          animation-delay: 0.5s;
}
.c-titBg01:nth-child(2)::before {
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}
.c-titBg01:nth-child(2) .c-titBg01__txt {
  -webkit-animation-delay: 0.7s;
          animation-delay: 0.7s;
}
.c-titBg01:nth-child(3)::before {
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}
.c-titBg01:nth-child(3) .c-titBg01__txt {
  -webkit-animation-delay: 0.9s;
          animation-delay: 0.9s;
}
.c-titBg01:nth-child(4)::before {
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
}
.c-titBg01:nth-child(4) .c-titBg01__txt {
  -webkit-animation-delay: 1.1s;
          animation-delay: 1.1s;
}
.c-titBg01:nth-child(5)::before {
  -webkit-animation-delay: 0.8s;
          animation-delay: 0.8s;
}
.c-titBg01:nth-child(5) .c-titBg01__txt {
  -webkit-animation-delay: 1.3s;
          animation-delay: 1.3s;
}

/*============================================================================================================
	.l-header
============================================================================================================*/
.l-header {
  position: sticky;
  top: 0;
  width: 100%;
  height: clamp(700px, 100vh, 1080px);
  overflow: hidden;
}
.l-header-subWrap {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.l-header-subWrap::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: url("../img/home/img_mv01_pc.webp") no-repeat center/cover;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.l-header-titWrap {
  width: min(100% - 40px, 1560px);
  height: 520px;
  margin: 0 auto;
}
.l-header__tit {
  width: 545px;
  height: 100%;
  padding: 140px 20px 0 0;
  position: relative;
  z-index: 2;
}
.l-header__tit::before, .l-header__tit::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  pointer-events: none;
}
.l-header__tit::before {
  width: 100%;
  height: 100%;
  top: 0;
  bottom: 0;
  -webkit-transform: rotate(17deg);
          transform: rotate(17deg);
  background: rgba(255, 255, 255, 0.5);
  -webkit-backdrop-filter: blur(15px) brightness(180%);
  backdrop-filter: blur(15px) brightness(180%);
  -webkit-clip-path: polygon(50% 0, 100% 38%, 82% 100%, 18% 100%, 0 38%);
  clip-path: polygon(50% 0, 100% 38%, 82% 100%, 18% 100%, 0 38%);
  z-index: -1;
}
.l-header__tit::after {
  width: 565px;
  height: 548px;
  top: 20px;
  background: url("../img/home/bg_mv01.svg") no-repeat center/contain;
  z-index: -2;
}
.l-header__tit-logo {
  display: block;
  margin: 0 auto;
}
.l-header-logo {
  position: absolute;
  max-width: calc(100% - 100px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  top: 40px;
  left: 50px;
  gap: 40px;
}
.l-header-logo__img {
  width: 444px;
}
.l-header-logo__img img {
  display: block;
  width: 100%;
}
.l-header-logo__txt {
  width: 300px;
  padding: 6px 10px;
  border-top: 1px solid;
  border-bottom: 1px solid;
  color: #fff;
  font-size: 16px;
  text-align: center;
  line-height: 1.5;
}
.l-header-txtWrap {
  width: min(100% - 40px, 1560px);
  position: absolute;
  z-index: 3;
  left: 0;
  right: 0;
  bottom: calc(50% - 190px);
  margin: auto;
}
.l-header__txt {
  width: 525px;
  text-align: center;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .l-header {
    position: static;
    height: auto;
    padding-top: min(90vh - 40px, 690px);
    padding: clamp(260px, 90vh - 40px, 690px) 0 0;
  }
  .l-header-subWrap {
    position: fixed;
    top: 0;
    left: 0;
    min-height: 300px;
    max-height: 730px;
    height: 90vh;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
  .l-header-subWrap::after {
    background-image: url("../img/home/img_mv01_sp.webp");
    background-position: center top;
  }
  .l-header-titWrap {
    width: 57vw;
    height: 55vw;
    margin: 0 auto 60px 10px;
  }
  .l-header__tit {
    width: 100%;
    padding: 18vw 3vw 0 0;
  }
  .l-header__tit::after {
    width: 100%;
    height: 100%;
  }
  .l-header__tit-logo {
    width: 70%;
  }
  .l-header-logo {
    position: static;
    max-width: none;
    display: block;
  }
  .l-header-logo__img, .l-header-logo__txt {
    position: absolute;
    z-index: 3;
  }
  .l-header-logo__img {
    width: 190px;
    top: 50px;
    left: 20px;
  }
  .l-header-logo__txt {
    top: 0;
    left: 0;
    width: 100%;
    margin: 0;
    border: none;
    background: #9C1D2B;
    font-size: 13px;
  }
  .l-header-txtWrap {
    width: 100%;
    padding: 55px 20px;
    background: #fff;
    position: relative;
    bottom: -1px;
    -webkit-clip-path: polygon(0 20px, 100% 0, 100% 100%, 0 100%);
    clip-path: polygon(0 20px, 100% 0, 100% 100%, 0 100%);
  }
  .l-header__txt {
    width: auto;
    font-size: 18px;
    line-height: 1.85;
  }
}

/* animation */
.l-header-subWrap::after, .l-header__tit::before, .l-header__tit::after, .l-header__tit-logo {
  -webkit-animation-duration: 2s;
          animation-duration: 2s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}
.l-header-subWrap::after {
  -webkit-animation-name: loadAnimae03;
          animation-name: loadAnimae03;
}
.l-header__tit::after {
  -webkit-animation-name: loadAnimae01;
          animation-name: loadAnimae01;
  -webkit-animation-delay: 0.5s;
          animation-delay: 0.5s;
}
.l-header__tit::before {
  -webkit-animation-name: loadAnimae02;
          animation-name: loadAnimae02;
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}
.l-header__tit-logo {
  -webkit-animation-name: opacity;
          animation-name: opacity;
  -webkit-animation-delay: 1.5s;
          animation-delay: 1.5s;
}
@media screen and (min-width: 768px) {
  .l-header__txt {
    -webkit-animation: opacity 1.5s forwards;
            animation: opacity 1.5s forwards;
    -webkit-animation-delay: 1.5s;
            animation-delay: 1.5s;
    opacity: 0;
  }
}

/*============================================================================================================
	.l-footer
============================================================================================================*/
.l-footer {
  position: relative;
  z-index: 1000;
  padding: 50px 0;
  background: #2C2C2C;
}
.l-footer-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.l-footer-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.l-footer-nav__item {
  color: #fff;
  font-size: 16px;
  margin-right: 30px;
}
.l-footer-nav__item:last-of-type {
  margin-right: 0;
}
.l-footer-nav__item a:hover {
  opacity: 1;
  text-decoration: underline;
}
.l-footer__copyright {
  color: #fff;
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .l-footer {
    padding: 30px 20px;
  }
  .l-footer-inner {
    display: block;
  }
  .l-footer-nav {
    margin-bottom: 20px;
  }
  .l-footer-nav__item {
    font-size: 14px;
  }
  .l-footer__copyright {
    font-size: 11px;
  }
}

/*============================================================================================================
	.l-contents (common)
============================================================================================================*/
.l-contents {
  position: relative;
  z-index: 1000;
  background: #fff;
}

/*==========================================
	.l-main
==========================================*/ /*============================================================================================================
	page
============================================================================================================*/
/*	home
============================================================================================================*/


/*------------------------------------------
	.homeNews #custom
------------------------------------------*/
.homeNews {
  padding: 170px 0;
  background-color: #fff;
  -webkit-clip-path: polygon(0 100px, 100% 0, 100% 100%, 0 calc(100% - 150px));
  clip-path: polygon(0 100px, 100% 0, 100% 100%, 0 calc(100% - 150px));
  position: relative;
  z-index: 1000;
}
.homeNews::after {
  content: "";
  display: block;
  width: 100%;
  height: 500px;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0, #fff), to(rgba(255, 255, 255, 0)));
  background: linear-gradient(to bottom, #fff 0, rgba(255, 255, 255, 0) 100%);
  position: absolute;
  pointer-events: none;
  top: 0;
  left: 0;
}
.homeNews-inner {
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.homeNews .bnrBox {
  max-width: 500px;
}
.homeNews .banner {
  width: 100%;
  margin-bottom: 80px;
}
.homeNews__secTit {
  margin-bottom: 65px;
  font-weight: 700;
  font-size: 54px;
  text-align: center;
}
.homeNews__secTit-en {
  display: block;
  margin-bottom: 10px;
  color: #F86D79;
  font-weight: 400;
  font-size: 32px;
}
.homeNews__txt {
  font-weight: 700;
  text-align: center;
}
.homeNews__txt-big {
  font-size: 32px;
  line-height: 1.2;
}
.homeNews__txt + .homeNews__txt {
  margin-top: 50px;
}
@media screen and (min-width: 768px) {
  .homeNews {
    margin-bottom: -100px;
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
  }
}
@media screen and (max-width: 767px) {
  .homeNews {
    padding: 75px 0 90px;
    background-size: 600px;
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 calc(100% - 30px));
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 calc(100% - 30px));
  }
  .homeNews::after {
    height: 300px;
  }
  .homeNews .bnrBox {
    padding-left: 10%;
    padding-right: 10%;
  }
  .homeNews__secTit {
    margin-bottom: 55px;
    font-size: 22px;
  }
  .homeNews__secTit-en {
    font-size: 16px;
  }
  .homeNews__txt {
    font-size: min(3.7vw, 15px);
  }
  .homeNews__txt-big {
    font-size: 24px;
  }
  .homeNews__txt + .homeNews__txt {
    margin-top: 25px;
  }
}

/*------------------------------------------
	.homeProduce
------------------------------------------*/
.homeProduce {
  padding: 170px 0;
  background: url("../img/common/bg_pattern01.webp") repeat center top/765px;
  -webkit-clip-path: polygon(0 0, 100% 100px, 100% calc(100% - 150px), 0 100%);
  clip-path: polygon(0 0, 100% 100px, 100% calc(100% - 150px), 0 100%);
  position: relative;
  z-index: 1000;
}
.homeProduce::after {
  content: "";
  display: block;
  width: 100%;
  height: 500px;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0, #fff), to(rgba(255, 255, 255, 0)));
  background: linear-gradient(to bottom, #fff 0, rgba(255, 255, 255, 0) 100%);
  position: absolute;
  pointer-events: none;
  top: 0;
  left: 0;
}
.homeProduce-inner {
  position: relative;
  z-index: 2;
}
.homeProduce__secTit {
  margin-bottom: 65px;
  font-weight: 700;
  font-size: 54px;
  text-align: center;
}
.homeProduce__secTit-en {
  display: block;
  margin-bottom: 10px;
  color: #F86D79;
  font-weight: 400;
  font-size: 32px;
}
.homeProduce__txt {
  font-weight: 700;
  text-align: center;
}
.homeProduce__txt-big {
  font-size: 32px;
  line-height: 1.2;
}
.homeProduce__txt + .homeProduce__txt {
  margin-top: 50px;
}
@media screen and (min-width: 768px) {
  .homeProduce {
    margin-bottom: -100px;
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
  }
}
@media screen and (max-width: 767px) {
  .homeProduce {
    padding: 75px 0 90px;
    background-size: 600px;
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 calc(100% - 30px));
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 calc(100% - 30px));
  }
  .homeProduce::after {
    height: 300px;
  }
  .homeProduce__secTit {
    margin-bottom: 55px;
    font-size: 22px;
  }
  .homeProduce__secTit-en {
    font-size: 16px;
  }
  .homeProduce__txt {
    font-size: min(3.7vw, 15px);
  }
  .homeProduce__txt-big {
    font-size: 24px;
  }
  .homeProduce__txt + .homeProduce__txt {
    margin-top: 25px;
  }
}

/*------------------------------------------
	.homeStep
------------------------------------------*/
.homeStep {
  padding: 40px 0 80px;
  background: url("../img/home/bg_step01.webp") no-repeat center top;
}
.homeStep-inner {
  max-width: 1210px;
}
.homeStep__secTit {
  display: table;
  margin: 0 auto 150px;
  padding: 10px 0 0 110px;
  background: url("../img/common/ico_flower01.svg") no-repeat left bottom;
  font-weight: 700;
  font-size: 54px;
  text-align: center;
  position: relative;
}
.homeStep__secTit-big {
  font-size: 74px;
}
.homeStep__secTit-kantan {
  font-size: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: absolute;
  top: 0;
  right: 30px;
}
.homeStep__secTit-kantan::before, .homeStep__secTit-kantan::after {
  content: "";
  display: block;
  width: 2px;
  height: 35px;
  background: currentColor;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.homeStep__secTit-kantan::before {
  margin-right: 10px;
  -webkit-transform: rotate(-10deg);
          transform: rotate(-10deg);
}
.homeStep__secTit-kantan::after {
  margin-left: 10px;
  -webkit-transform: rotate(10deg);
          transform: rotate(10deg);
}
.homeStep__secTit-kantan span {
  display: inline-block;
  -webkit-animation: bound 3s ease-in infinite;
          animation: bound 3s ease-in infinite;
}
.homeStep__secTit-kantan span + span {
  -webkit-animation-delay: 0.1s;
          animation-delay: 0.1s;
}
.homeStep__secTit-kantan span + span + span {
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}
.homeStep__secTit-kantan span + span + span + span {
  -webkit-animation-delay: 0.3s;
          animation-delay: 0.3s;
}
.homeStep__secTit-kantan span + span + span + span + span {
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}
.homeStep-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 100px 1fr 100px 1fr;
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 100px;
}
.homeStep-list__item {
  padding: 100px 20px 40px;
  background: #fff;
  border: 1px solid #9C1D2B;
  text-align: center;
  position: relative;
}
.homeStep-list__item::after {
  content: "";
  display: block;
  width: 43px;
  height: 82px;
  background: url("../img/common/ico_arrow02.svg") no-repeat center/contain;
  position: absolute;
  pointer-events: none;
  top: 0;
  bottom: 0;
  right: -73px;
  margin: auto;
}
.homeStep-list__item:last-of-type::after {
  content: none;
}
.homeStep-list__num {
  width: 150px;
  height: 160px;
  padding: 50px 0 0;
  background: url("../img/home/ico_step01.svg") no-repeat center/contain;
  font-size: 18px;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: 0.7;
  position: absolute;
  top: -81px;
  left: 0;
  right: 0;
  margin: auto;
}
.homeStep-list__num-big {
  font-size: 56px;
  letter-spacing: 0;
}
.homeStep-list__txt {
  min-height: 90px;
  margin-bottom: 35px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.75;
}
.homeStep-list__sub {
  margin-top: 5px;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .homeStep {
    padding: 20px 0 40px;
    background: url("../img/home/bg_step_sp01.webp") no-repeat right top 30px/184px, url("../img/home/bg_step_sp02.webp") no-repeat left top 30%/146px, url("../img/home/bg_step_sp03.webp") no-repeat center top 64%/390px;
  }
  .homeStep__secTit {
    margin-bottom: 100px;
    padding: 10px 0 3px 50px;
    background-size: 44px;
    font-size: min(5.5vw, 22px);
  }
  .homeStep__secTit-big {
    font-size: 32px;
  }
  .homeStep__secTit-kantan {
    font-size: 11px;
    right: 5px;
  }
  .homeStep__secTit-kantan::before, .homeStep__secTit-kantan::after {
    width: 1px;
    height: 15px;
  }
  .homeStep-list {
    display: block;
    width: min(100%, 280px);
    margin: 0 auto;
  }
  .homeStep-list__item {
    padding: 75px 20px 25px;
  }
  .homeStep-list__item::after {
    width: 42px;
    height: 15px;
    background-image: url("../img/common/ico_arrow03.svg");
    top: auto;
    right: 0;
    left: 0;
    bottom: -35px;
  }
  .homeStep-list__item + .homeStep-list__item {
    margin-top: 110px;
  }
  .homeStep-list__num {
    padding-top: 40px;
    width: 112px;
    height: 120px;
    font-size: 14px;
    top: -61px;
  }
  .homeStep-list__num-big {
    font-size: 42px;
  }
  .homeStep-list__txt {
    min-height: auto;
    margin-bottom: 20px;
    display: block;
    font-size: 20px;
  }
  .homeStep-list__img {
    width: 120px;
  }
  .homeStep-list__sub {
    margin-top: 10px;
    font-size: 16px;
  }
}
@media screen and (max-width: 374px) {
  .homeStep__secTit-kantan {
    right: 1vw;
  }
}

.homeStep-size {
  margin: 115px auto 0;
}
.homeStep-size__tit {
  width: 315px;
  margin: 0 auto 40px;
  padding: 26px 0 20px;
  border-top: 4px double #F86D79;
  border-bottom: 4px double #F86D79;
  font-weight: 700;
  font-size: 24px;
  text-align: center;
  position: relative;
}
.homeStep-size__tit::after {
  content: "";
  display: block;
  width: 70px;
  height: 56px;
  background: url("../img/home/ico_ribon01.svg") no-repeat center/contain;
  position: absolute;
  top: -32px;
  left: 0;
  right: 0;
  margin: auto;
}
.homeStep-size-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 25px 1fr 25px 1fr;
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 25px;
}
.homeStep-size-list__item {
  background: url("../img/common/bg_pattern02.webp") repeat center/31px;
  text-align: center;
  line-height: 1.75;
  -webkit-clip-path: polygon(30px 0, 100% 0, 100% calc(100% - 30px), calc(100% - 30px) 100%, 0 100%, 0 30px);
  clip-path: polygon(30px 0, 100% 0, 100% calc(100% - 30px), calc(100% - 30px) 100%, 0 100%, 0 30px);
}
.homeStep-size-list__item a {
  padding: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 184px;
}
.homeStep-size-list__tit {
  margin-bottom: 10px;
  font-weight: 700;
  font-size: 32px;
}
@media screen and (min-width: 768px) {
  .homeStep-size-list__item {
    position: relative;
  }
  .homeStep-size-list__item::before, .homeStep-size-list__item::after {
    content: "";
    display: block;
    width: 2px;
    height: 0;
    background: #fff;
    position: absolute;
    z-index: 2;
    pointer-events: none;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    opacity: 0;
    -webkit-transition: all 0.7s;
    transition: all 0.7s;
  }
  .homeStep-size-list__item::before {
    top: -20px;
    left: 80px;
    -webkit-transform-origin: right top;
            transform-origin: right top;
  }
  .homeStep-size-list__item::after {
    bottom: -20px;
    right: 80px;
    -webkit-transform-origin: left bottom;
            transform-origin: left bottom;
  }
  .homeStep-size-list__item:hover::before, .homeStep-size-list__item:hover::after {
    height: 150px;
    opacity: 1;
  }
  .homeStep-size-list__item a:hover {
    opacity: 1;
    background: rgba(248, 109, 121, 0.6);
    color: #fff;
  }
}
@media screen and (max-width: 767px) {
  .homeStep-size {
    margin-top: 80px;
  }
  .homeStep-size__tit {
    width: min(100%, 280px);
    margin-bottom: 30px;
    border-width: 3px;
    font-size: 17px;
  }
  .homeStep-size__tit::after {
    width: 60px;
    height: 48px;
    top: -27px;
  }
  .homeStep-size-list {
    -ms-grid-columns: 1fr 12px 1fr;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 12px;
  }
  .homeStep-size-list__item {
    background-size: 15px;
    -webkit-clip-path: polygon(15px 0, 100% 0, 100% calc(100% - 15px), calc(100% - 15px) 100%, 0 100%, 0 15px);
    clip-path: polygon(15px 0, 100% 0, 100% calc(100% - 15px), calc(100% - 15px) 100%, 0 100%, 0 15px);
  }
  .homeStep-size-list__item a {
    height: 82px;
  }
  .homeStep-size-list__tit {
    margin-bottom: 0;
    font-size: 18px;
  }
  .homeStep-size-list__detail {
    font-size: 12px;
  }
}

/*------------------------------------------
	.homeDesign
------------------------------------------*/
.homeDesign {
  margin-bottom: -145px;
  padding: 160px 0 180px;
  background: url("../img/common/bg_pattern03.webp") no-repeat center/cover;
  -webkit-clip-path: polygon(0 0, 100% 100px, 100% calc(100% - 145px), 0 100%);
  clip-path: polygon(0 0, 100% 100px, 100% calc(100% - 145px), 0 100%);
}
.homeDesign__secTit {
  margin-bottom: 40px;
  color: #fff;
  font-size: 46px;
  text-align: center;
}
.homeDesign__secTit-bg {
  margin: 0 auto;
}
.homeDesign__secTit-bg + .homeDesign__secTit-bg {
  margin-top: 8px;
}
.homeDesign__lead {
  display: table;
  margin: 0 auto 60px;
  padding: 0 10px;
  background: #fff;
  line-height: 1.5;
}
.homeDesign-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 80px;
}
.homeDesign-list__item a {
  display: block;
  padding: 0 0 35px;
  position: relative;
}
.homeDesign-list-imgBox {
  border-radius: 14px;
  overflow: hidden;
}
.homeDesign-list-imgBox img {
  width: 100%;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.homeDesign-list__btn {
  width: min(100% - 60px, 330px);
  color: #fff;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
  position: absolute;
  z-index: 3;
  right: 30px;
  bottom: 0;
}
.homeDesign-list__btn-in {
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 70px;
  padding: 10px 45px;
  background: #9C1D2B;
  position: relative;
  z-index: 1;
}
.homeDesign-list__btn-in::before, .homeDesign-list__btn-in::after {
  content: "";
  display: block;
  position: absolute;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  pointer-events: none;
}
.homeDesign-list__btn-in::before {
  width: 25px;
  height: 14px;
  background: url("../img/common/ico_arrow01.svg") no-repeat center/contain;
  z-index: 2;
  top: 0;
  right: 20px;
  bottom: 0;
  margin: auto;
}
.homeDesign-list__btn-in::after {
  bottom: 0;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .homeDesign-list__btn-in::after {
    width: calc(100% + 180px);
    height: 100%;
    background: linear-gradient(25deg, #F86D79 20px, #2C2C2C 20px);
    left: calc((100% + 130px) * -1);
    -webkit-clip-path: polygon(0 0, calc(100% - 140px) 0, 100% 100%, 0 100%);
    clip-path: polygon(0 0, calc(100% - 140px) 0, 100% 100%, 0 100%);
  }
  .homeDesign-list__item:first-of-type {
    margin-top: 60px;
  }
  .homeDesign-list__item .homeDesign-list-imgBox {
    position: relative;
  }
  .homeDesign-list__item .homeDesign-list-imgBox::before, .homeDesign-list__item .homeDesign-list-imgBox::after {
    content: "";
    display: block;
    width: 50%;
    height: 100%;
    position: absolute;
    pointer-events: none;
    z-index: 2;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    opacity: 0;
  }
  .homeDesign-list__item .homeDesign-list-imgBox::before {
    left: 0;
    bottom: 100%;
    background: #F86D79;
  }
  .homeDesign-list__item .homeDesign-list-imgBox::after {
    right: 0;
    top: 100%;
    background: #fff;
  }
  .homeDesign-list__item a:hover {
    opacity: 1;
  }
  .homeDesign-list__item a:hover .homeDesign-list-imgBox::before, .homeDesign-list__item a:hover .homeDesign-list-imgBox::after {
    opacity: 0.3;
  }
  .homeDesign-list__item a:hover .homeDesign-list-imgBox::before {
    bottom: 0;
  }
  .homeDesign-list__item a:hover .homeDesign-list-imgBox::after {
    top: 0;
  }
  .homeDesign-list__item a:hover .homeDesign-list-imgBox img {
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
  }
  .homeDesign-list__item a:hover .homeDesign-list__btn-in::before {
    right: 15px;
  }
  .homeDesign-list__item a:hover .homeDesign-list__btn-in::after {
    left: 0;
  }
}
@media screen and (max-width: 767px) {
  .homeDesign {
    margin-bottom: -30px;
    padding: 85px 0 100px;
    -webkit-clip-path: polygon(0 0, 100% 25px, 100% calc(100% - 30px), 0 100%);
    clip-path: polygon(0 0, 100% 25px, 100% calc(100% - 30px), 0 100%);
  }
  .homeDesign__secTit {
    margin-bottom: 25px;
    font-size: min(5.1vw, 22px);
  }
  .homeDesign__secTit-bg + .homeDesign__secTit-bg {
    margin-top: 4px;
  }
  .homeDesign__lead {
    margin-bottom: 60px;
    font-size: min(3.5vw, 14px);
  }
  .homeDesign-list {
    display: block;
  }
  .homeDesign-list__item + .homeDesign-list__item {
    margin-top: 40px;
  }
  .homeDesign-list__item a {
    padding-bottom: 25px;
  }
  .homeDesign-list__btn {
    width: min(100% - 20px, 230px);
    font-size: 16px;
    right: 10px;
  }
  .homeDesign-list__btn-in {
    min-height: 50px;
    padding: 10px 30px;
  }
  .homeDesign-list__btn-in::before {
    width: 20px;
    right: 10px;
  }
  .homeDesign-list__btn-in::after {
    width: 50px;
    height: 22px;
    background: #2C2C2C;
    left: 0;
    -webkit-clip-path: polygon(0 0, 100% 100%, 0 100%);
    clip-path: polygon(0 0, 100% 100%, 0 100%);
  }
}

/*------------------------------------------
	.homePrice
------------------------------------------*/
.homePrice {
  overflow: hidden;
  margin-bottom: -100px;
  padding: 195px 0 230px;
  background: url("../img/common/bg_pattern04.webp") repeat center/68px;
  -webkit-clip-path: polygon(0 145px, 100% 0, 100% calc(100% - 100px), 0 100%);
  clip-path: polygon(0 145px, 100% 0, 100% calc(100% - 100px), 0 100%);
}
.homePrice__secTit {
  display: table;
  margin: 0 auto 65px;
  padding: 0 220px;
  background: url("../img/home/bg_price02.svg") no-repeat left 30px center, url("../img/home/bg_price03.svg") no-repeat right center;
  font-weight: 700;
  font-size: 40px;
  text-align: center;
}
.homePrice__secTit-big {
  border-bottom: 4px double;
  font-size: 64px;
  line-height: 1.3;
}
.homePrice-commonBox {
  width: min(100% - 10px, 1220px);
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.7);
  outline: 2px solid #9C1D2B;
  outline-offset: 8px;
}
.homePrice__btn {
  margin: 145px auto 0;
}
@media screen and (max-width: 767px) {
  .homePrice {
    margin-bottom: -20px;
    padding: 100px 0 95px;
    background-size: 40px;
    -webkit-clip-path: polygon(0 30px, 100% 0, 100% calc(100% - 20px), 0 100%);
    clip-path: polygon(0 30px, 100% 0, 100% calc(100% - 20px), 0 100%);
  }
  .homePrice__secTit {
    display: block;
    margin: 0 -20px 50px;
    padding: 0;
    background: url("../img/home/bg_price02.svg") no-repeat left -25px center/82px, url("../img/home/bg_price03.svg") no-repeat right -15px top 15px/82px;
    font-size: 22px;
  }
  .homePrice__secTit-big {
    font-size: 38px;
  }
  .homePrice-commonBox {
    width: calc(100% - 20px);
  }
  .homePrice__btn {
    margin-top: 40px;
  }
}

.homePrice-box01 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 30px;
  padding: 50px 0 50px 50px;
}
.homePrice-box01-txtBox {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.homePrice-box01__txt + .homePrice-box01__txt {
  margin-top: 40px;
}
.homePrice-box01__txt-big {
  font-weight: 700;
  font-size: 24px;
  line-height: 1.7;
}
.homePrice-box01__txt-normal {
  font-size: 19px;
}
.homePrice-box01__txt-small {
  font-size: 14px;
}
.homePrice-box01-set {
  margin: 80px 0 0;
  padding: 70px 60px 45px;
  border: 1px solid #313131;
  background: url("../img/common/bg_pattern02.webp") repeat center/31px;
  position: relative;
}
.homePrice-box01-set::before, .homePrice-box01-set::after {
  content: "";
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: absolute;
  pointer-events: none;
}
.homePrice-box01-set::before {
  width: 100%;
  height: 6px;
  border-left: 1px solid #313131;
  border-bottom: 1px solid #313131;
  bottom: -6px;
  left: 6px;
}
.homePrice-box01-set::after {
  width: 6px;
  height: 100%;
  border-top: 1px solid #313131;
  border-right: 1px solid #313131;
  top: 6px;
  right: -6px;
}
.homePrice-box01-set__tit {
  width: 114px;
  height: 114px;
  padding: 20px 0 0;
  border-radius: 50%;
  background: #F79CA3;
  color: #fff;
  text-align: center;
  font-size: 16px;
  line-height: 1.2;
  position: absolute;
  top: -56px;
  left: 0;
  right: 0;
  margin: auto;
}
.homePrice-box01-set__tit::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border: 1px solid #313131;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: absolute;
  top: -4px;
  left: -4px;
}
.homePrice-box01-set__tit-big {
  font-size: 32px;
}
.homePrice-box01-set-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 20px 1fr 20px 1fr 20px 1fr;
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 20px;
}
.homePrice-box01-set-list__item {
  line-height: 1.5;
}
.homePrice-box01__img {
  width: 53.5%;
  margin: -30px -40px -40px auto;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .homePrice-box01 {
    display: block;
    padding: 0 0 40px;
  }
  .homePrice-box01-txtBox {
    padding: 35px 20px 30px;
  }
  .homePrice-box01__txt {
    text-align: center;
    font-size: min(3.7vw, 15px);
  }
  .homePrice-box01__txt + .homePrice-box01__txt {
    margin-top: 35px;
  }
  .homePrice-box01__txt-big {
    font-size: min(4.5vw, 19px);
  }
  .homePrice-box01__txt-normal, .homePrice-box01__txt-small {
    font-size: min(3.7vw, 15px);
  }
  .homePrice-box01-set {
    margin-top: 100px;
    padding: 70px 40px 30px;
  }
  .homePrice-box01-set-list {
    display: block;
    -webkit-column-count: 2;
       -moz-column-count: 2;
            column-count: 2;
  }
  .homePrice-box01-set-list__item {
    -webkit-column-break-inside: avoid;
       -moz-column-break-inside: avoid;
            break-inside: avoid;
  }
  .homePrice-box01-set-list__item + .homePrice-box01-set-list__item {
    margin-top: 10px;
  }
  .homePrice-box01__img {
    max-width: none;
    width: calc(100% + 20px);
    display: block;
    margin: 0 auto 0 -10px;
  }
}

.homePrice-box02 {
  margin-top: 60px;
  padding: 70px 70px 70px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  gap: 30px;
}
.homePrice-box02-txtBox {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  line-height: 1.5;
  position: relative;
  z-index: 3;
}
.homePrice-box02__tit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto 40px -140px;
  height: 175px;
  background: url("../img/home/bg_price01.webp") no-repeat center right/contain;
  color: #F86D79;
  font-weight: 700;
  font-size: clamp(36px, 3.3vw, 46px);
  line-height: 1.3;
  text-align: center;
}
.homePrice-box02__tit-in {
  width: 80%;
  margin: -10px 0 0 auto;
}
.homePrice-box02__tit-small {
  font-size: 0.7em;
}
.homePrice-box02__tit-big {
  font-size: 1.3em;
}
.homePrice-box02__txt01 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 5px;
}
.homePrice-box02__txt01-big {
  margin-right: 10px;
  padding: 2px 5px;
  background: #F86D79;
  color: #fff;
  font-size: clamp(30px, 3.3vw, 46px);
  line-height: 1.3;
}
.homePrice-box02__txt02 {
  margin-bottom: 5px;
  width: 50%;
  font-weight: 700;
  font-size: clamp(20px, 2vw, 26px);
  text-align: center;
}
.homePrice-box02__txt03 {
  margin-top: 20px;
  font-weight: 700;
  font-size: clamp(24px, 2.5vw, 32px);
}
.homePrice-box02__img {
  width: 58.5%;
  margin: -30px -45px -220px -50px;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .homePrice-box02 {
    display: block;
    padding: 0;
  }
  .homePrice-box02-txtBox {
    padding: 30px 10px;
  }
  .homePrice-box02__tit {
    height: 95px;
    margin: 0 auto 45px -50px;
    background-position: center;
    font-size: min(6vw, 24px);
  }
  .homePrice-box02__tit-in {
    width: 100%;
    margin-top: -5px;
    padding: 0 0 0 min(20vw, 80px);
  }
  .homePrice-box02__txt01 {
    display: block;
    text-align: center;
  }
  .homePrice-box02__txt01-big {
    display: table;
    margin: 0 auto 10px;
    font-size: 28px;
  }
  .homePrice-box02__txt02 {
    width: auto;
    margin-bottom: 10px;
    font-size: 24px;
  }
  .homePrice-box02__txt03 {
    margin-top: 30px;
    font-size: 22px;
    text-align: center;
  }
  .homePrice-box02__img {
    max-width: none;
    width: calc(100% + 40px);
    display: block;
    margin: 0 auto 0 -10px;
  }
}

/*------------------------------------------
	.homeHow
------------------------------------------*/
.homeHow {
  height: 1180px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-clip-path: polygon(0 100px, 100% 0, 100% 100%, 0 calc(100% - 140px));
  clip-path: polygon(0 100px, 100% 0, 100% 100%, 0 calc(100% - 140px));
}
.homeHow__txt {
  font-size: clamp(120px, 13vw, 173px);
  line-height: 1;
  text-align: center;
  position: relative;
  z-index: 2;
}
.homeHow-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  -webkit-clip-path: inset(0 0 0 0);
  clip-path: inset(0 0 0 0);
}
.homeHow-bg::before {
  content: "";
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  height: 100lvh;
  background: url("../img/home/bg_how01_pc.webp") no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .homeHow {
    min-height: 400px;
    max-height: 750px;
    height: 90vh;
    -webkit-clip-path: polygon(0 20px, 100% 0, 100% 100%, 0 calc(100% - 30px));
    clip-path: polygon(0 20px, 100% 0, 100% 100%, 0 calc(100% - 30px));
  }
  .homeHow__txt {
    font-size: 16vw;
    line-height: 18vw;
  }
  .homeHow-bg::before {
    background-image: url("../img/home/bg_how01_sp.webp");
  }
}

/*------------------------------------------
	.homeLocation
------------------------------------------*/
.homeLocation {
  padding: 75px 0 140px;
}
.homeLocation__catch {
  margin: 0 auto 20px;
  font-size: 24px;
  line-height: 1.9;
  text-align: center;
}
.homeLocation__catch-bg {
  padding: 0 5px;
  background: #F5DDDF;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
.homeLocation__secTit {
  margin-bottom: 55px;
  font-size: 54px;
  text-align: center;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .homeLocation {
    padding: 60px 0 50px;
  }
  .homeLocation__catch {
    margin-bottom: 18px;
    font-size: 16px;
  }
  .homeLocation__catch-bg {
    padding: 0 7px;
  }
  .homeLocation__secTit {
    margin-bottom: 60px;
    font-size: 22px;
  }
}

/* slider */
.homeLocation-list .splide__pagination {
  margin: 20px auto 0;
}
.homeLocation-list .splide__pagination li {
  width: 20px;
  height: 5px;
  margin: 0 5px;
}
.homeLocation-list .splide__pagination li button {
  width: 100%;
  height: 100%;
  display: block;
  border: none;
  background: #F86D79;
  border-radius: inherit;
  padding: 0;
  cursor: pointer;
  opacity: 0.5;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.homeLocation-list .splide__pagination li button:hover, .homeLocation-list .splide__pagination li button.is-active {
  opacity: 1;
}
.homeLocation-list .splide__slide.is-active .homeLocation-list__item-in {
  -webkit-transform: scale(1);
          transform: scale(1);
}
.homeLocation-list__item {
  position: relative;
}
.homeLocation-list__item-in {
  padding: 40px 0 0;
  -webkit-transform: scale(0.8);
          transform: scale(0.8);
  -webkit-transform-origin: center bottom;
          transform-origin: center bottom;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.homeLocation-list__img {
  width: 100%;
  border-radius: 14px;
  border: 1px solid #313131;
}
.homeLocation-list__tit {
  position: absolute;
  color: #fff;
  top: 0;
  left: 40px;
  padding: 30px 5px;
  background: #F86D79;
  font-size: max(18px, 1.6vw);
  line-height: 1.3;
  letter-spacing: 0.1em;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}
@media screen and (max-width: 767px) {
  .homeLocation-list__item-in {
    padding-top: 20px;
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  .homeLocation-list__tit {
    padding: 10px 5px;
    font-size: 3.5vw;
    left: 20px;
  }
}

/*------------------------------------------
	.homeManualbook
------------------------------------------*/
.homeManualbook {
  width: min(100% - 40px, 1240px);
  height: 290px;
  margin: 0 auto 140px;
  position: relative;
}
.homeManualbook::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: #F5DDDF;
  border: 1px solid #313131;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: -1;
  pointer-events: none;
}
.homeManualbook-in {
  position: relative;
  z-index: 2;
  height: 100%;
  padding: 30px 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 50px;
  border: 1px solid #313131;
  background: url("../img/common/bg_pattern01.webp") repeat center top/765px;
}
.homeManualbook-in::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: #F79CA3;
  mix-blend-mode: multiply;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -2;
  pointer-events: none;
}
.homeManualbook__img {
  width: 14.8%;
}
.homeManualbook__txt01 {
  margin-bottom: 30px;
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.1em;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .homeManualbook {
    width: calc(100% - 40px);
    height: auto;
    margin-bottom: 85px;
  }
  .homeManualbook-in {
    display: block;
    padding: 50px 20px 70px;
    background-size: 400px;
  }
  .homeManualbook-in::before {
    content: "";
    display: block;
    width: 100%;
    height: 50%;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(247, 156, 163, 0.6)), to(rgba(255, 255, 255, 0)));
    background: linear-gradient(to bottom, rgba(247, 156, 163, 0.6), rgba(255, 255, 255, 0) 100%);
    position: absolute;
    top: 0;
    left: 0;
    pointer-events: none;
    z-index: -1;
  }
  .homeManualbook__img {
    width: 55%;
    display: block;
    margin: 0 auto 30px;
  }
  .homeManualbook__txt01 {
    font-size: min(3.3vw, 15px);
    text-align: center;
  }
  .homeManualbook__txt02 {
    width: min(100%, 280px);
    margin: 0 auto;
  }
}

/*------------------------------------------
	.homeGraduation
------------------------------------------*/
.homeGraduation {
  padding: 205px 0 100px;
  background: url("../img/home/bg_graduation01_pc.webp") no-repeat center/cover;
  -webkit-clip-path: polygon(0 100px, 100% 0, 100% 100%, 0 100%);
  clip-path: polygon(0 100px, 100% 0, 100% 100%, 0 100%);
}
.homeGraduation__secTit {
  margin-bottom: 30px;
  color: #000;
  font-size: 46px;
}
.homeGraduation__secTit-bg {
  margin-top: 8px;
}
.homeGraduation__secTit-bg span {
  background: rgba(255, 255, 255, 0.5);
  -webkit-backdrop-filter: blur(15px) brightness(180%);
  backdrop-filter: blur(15px) brightness(180%);
}
.homeGraduation__txt {
  margin-bottom: 30px;
  font-weight: 700;
  line-height: 2.25;
}
.homeGraduation-price {
  margin-bottom: 50px;
}
.homeGraduation-price__tag {
  display: table;
  margin-bottom: 10px;
  padding: 2px 10px;
  background: #fff;
  font-size: 16px;
  line-height: 1.2;
}
.homeGraduation-price__num-big {
  font-weight: 700;
  font-size: 46px;
  line-height: 1.1;
}
@media screen and (max-width: 767px) {
  .homeGraduation {
    padding: 84vw 0 95px;
    background-image: url("../img/home/bg_graduation01_sp.webp");
    -webkit-clip-path: polygon(0 20px, 100% 0, 100% 100%, 0 100%);
    background-position: center top;
    clip-path: polygon(0 20px, 100% 0, 100% 100%, 0 100%);
  }
  .homeGraduation__secTit {
    margin-bottom: 30px;
    font-size: min(5.8vw, 22px);
  }
  .homeGraduation__txt {
    margin-bottom: 25px;
    color: #fff;
    font-size: min(4.5vw, 16px);
    line-height: 2.5;
  }
  .homeGraduation-price {
    margin-bottom: 30px;
  }
  .homeGraduation-price__tag {
    margin-bottom: 7px;
    background: rgba(255, 255, 255, 0.5);
    -webkit-backdrop-filter: blur(15px) brightness(180%);
    backdrop-filter: blur(15px) brightness(180%);
  }
  .homeGraduation-price__num {
    color: #fff;
    font-size: 16px;
  }
  .homeGraduation-price__num-big {
    font-size: 42px;
  }
}
@media screen and (max-width: 374px) {
  .homeGraduation {
    background-position: center top -5vw;
    padding-top: 85vw;
  }
}

/*------------------------------------------
	.homeLink
------------------------------------------*/
.homeLink {
  padding: 160px 0;
  background: url("../img/common/bg_pattern01.webp") repeat center top/1100px;
  position: relative;
}
.homeLink::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(30%, #fff), to(rgba(255, 255, 255, 0.2)));
  background: linear-gradient(to bottom, #fff 30%, rgba(255, 255, 255, 0.2) 100%);
  position: absolute;
  pointer-events: none;
  top: 0;
  left: 0;
}
.homeLink-inner {
  max-width: 1085px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px;
  position: relative;
  z-index: 2;
}
.homeLink__btn.is-line {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 30px;
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .homeLink {
    padding: 100px 0;
    background-size: 240px;
  }
  .homeLink::after {
    height: 50%;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0, #fff), to(rgba(255, 255, 255, 0)));
    background: linear-gradient(to bottom, #fff 0, rgba(255, 255, 255, 0) 100%);
  }
  .homeLink-inner {
    display: block;
  }
  .homeLink__logo {
    width: min(100%, 350px);
    margin: 0 auto 40px;
  }
  .homeLink__btn {
    margin: 0 auto;
  }
}
/*# sourceMappingURL=style.css.map */
