@charset "UTF-8";
/* ===========================================================================
  variable
============================================================================= */
/* 外部読み込みを使用していないためiOS / Android では内蔵フォント優先 */
/* ===========================================================================
  mixin
============================================================================= */
/* ===========================================================================
  mv
============================================================================= */
#top main {
  margin-top: 69px;
}
#top .header_logoArea {
  z-index: 1;
  position: absolute;
}

.p-mv {
  position: relative;
  padding-bottom: max(47px, 13%);
  overflow: hidden;
  background: linear-gradient(to right, #ff7b16, #b90316) left bottom/100% 19.5% no-repeat, #fff;
}
.p-mv::after {
  z-index: 5;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  max-width: max(375px, 76%);
  height: 100%;
  background: url("../../img/index/mv/catch-sp.svg") no-repeat left top/100%;
  content: "";
  pointer-events: none;
}

.p-mv_inner {
  width: max(355px, 95%);
  margin-top: 112px;
  margin-left: auto;
  overflow: hidden;
  border-bottom-left-radius: 50px;
  background-color: #fff;
}

.p-mv_img {
  display: block;
  width: 100%;
  height: auto;
  transform: scale(1.05) translateZ(0);
  transform-origin: center center;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  will-change: transform, opacity;
}
.p-mv_img.is-zooming {
  animation: mvZoomOut 7.2s cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}

@keyframes mvZoomOut {
  from {
    transform: scale(1.1) translateZ(0);
  }
  to {
    transform: scale(1.02) translateZ(0);
  }
}
/* ===========================================================================
  scrolldown
============================================================================= */
.p-scrolldown {
  z-index: 6;
  position: absolute;
  bottom: 0;
  left: 30px;
}
.p-scrolldown::before, .p-scrolldown::after {
  position: absolute;
  bottom: 0;
  content: "";
}
.p-scrolldown::before {
  left: 0;
  width: 1px;
  height: 80px;
  background-color: #fff;
}
.p-scrolldown::after {
  left: -3px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: #d60016;
  animation: verticalMove 1.6s ease-in-out infinite, opacityAnime 1.6s ease-out infinite;
}

.p-scrolldown_text {
  position: absolute;
  top: -102px;
  left: 50%;
  translate: -50% 0;
  color: #fff;
  font-size: 1.2rem;
  line-height: 1;
  font-family: "Outfit", sans-serif;
}

@keyframes verticalMove {
  0% {
    bottom: 88px;
  }
  100% {
    bottom: 0;
  }
}
@keyframes opacityAnime {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  80% {
    opacity: 0.9;
  }
  100% {
    opacity: 0;
  }
}
/* ===========================================================================
  btnList
============================================================================= */
.p-btnList-right, .p-btnList-left {
  display: grid;
  width: max(335px, 70%);
  margin-top: 16px;
  margin-inline: auto;
  gap: 12px;
  translate: 0 -17%;
}

/* ===========================================================================
  btn01
============================================================================= */
.p-btn01, .p-btn01-shinkin {
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 56px;
  padding: 13px 16px 17px;
  border: 3px solid transparent;
  border-radius: 100px;
  background-color: #d60016;
  color: #fff;
  font-weight: 700;
  text-align: center;
}

.p-btn01-shinkin {
  background-color: #ff5e16;
}

.p-btn01_text, .p-btn01_text-shinkin {
  display: block;
  position: relative;
  width: 100%;
  padding: 0 24px 0 10px;
  font-size: 1.8rem;
  line-height: 1.35;
}
.p-btn01_text::after, .p-btn01_text-shinkin::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../../img/icon_chevron-white.svg") no-repeat right center/0.45em;
  content: "";
}

.p-btn01_text-shinkin {
  font-size: 1.45rem;
  line-height: 1.45;
}
.p-btn01_text-shinkin::after {
  background: url("../../img/icon_chevron-white.svg") no-repeat right center/0.65em;
}

/* ===========================================================================
  heading02
============================================================================= */
.p-heading02 {
  position: relative;
  text-align: center;
}

.p-heading02_jp, .p-heading02_jp-center, .p-heading02_jp-right {
  display: block;
  z-index: 1;
  position: absolute;
  bottom: -7px;
  left: 50%;
  translate: -50% 0;
  font-weight: 700;
  font-size: 2rem;
  white-space: nowrap;
}
.p-heading02_jp::before, .p-heading02_jp-center::before, .p-heading02_jp-right::before {
  position: absolute;
  top: 52%;
  left: -16px;
  width: 8px;
  height: 8px;
  translate: 0 -50%;
  border-radius: 50%;
  background: linear-gradient(to right, #ff7b16, #b90316);
  content: "";
}

.p-heading02_en {
  display: block;
  background: linear-gradient(to right, #f2d694, #f5b7a1);
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
  font-weight: 200;
  font-size: clamp(6.6rem, 27vw, 13.2rem);
  line-height: 0.8;
  font-family: "Outfit", sans-serif;
  letter-spacing: -0.02em;
  white-space: normal;
  word-break: break-word;
}

/* ===========================================================================
  card
============================================================================= */
.p-cardList {
  display: grid;
  gap: 20px;
}

.p-card {
  position: relative;
  padding-bottom: 32px;
}

.p-card_imgArea {
  overflow: hidden;
  border-radius: 20px;
}

.p-card_btn {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 100%;
  max-width: max(335px, 70%);
  min-height: 56px;
  translate: -50% 0;
}

/* ===========================================================================
  content01
============================================================================= */
.p-content01 {
  padding-top: 131px;
  background: linear-gradient(to bottom, #f2e4d5, #f6efe1);
}

.p-content01_inner {
  position: relative;
  margin-inline: auto;
}

.p-content01_heading02 {
  margin-bottom: 30px;
}

.p-content01_imgArea {
  margin-bottom: 20px;
  overflow: hidden;
}

.p-content01_img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 30px 0 0 30px;
}

/* ===========================================================================
  content02
============================================================================= */
.p-content02 {
  padding-top: 80px;
}

.p-content02_inner {
  position: relative;
  margin-inline: auto;
}

.p-content02_heading02 {
  margin-bottom: 40px;
}

.p-content02_heading02En {
  font-size: clamp(6.6rem, 27vw, 12.2rem);
  letter-spacing: -0.1em;
  text-align: left;
}

.p-content02_imgArea {
  margin-bottom: 20px;
  overflow: hidden;
}

.p-content02_img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 0 30px 30px 0;
}

/* ===========================================================================
  content03
============================================================================= */
.p-content03 {
  padding-block: 80px 140px;
  background: linear-gradient(to top, #f2e4d5, #f6efe1);
}

.p-content03_inner {
  margin-inline: auto;
}

.p-content03_heading02 {
  position: relative;
  margin-bottom: 40px;
  text-align: center;
}

.p-content03_cardList {
  width: calc(100% - 20px * 2);
  max-width: 1200px;
  margin: 0 auto;
}
.p-content03_cardList {
  max-width: 85%;
}

/* ===========================================================================
  content04
============================================================================= */
.p-content04 {
  position: relative;
  padding-bottom: 100px;
  overflow: hidden;
  background: #fff;
}

.p-content04_heading02 {
  position: relative;
  margin-bottom: 40px;
  line-height: 0.5;
}

.p-content04_heading02En {
  font-size: clamp(6.6rem, 23vw, 9.5rem);
  letter-spacing: -0.06em;
}

.p-content04_heading02Jp {
  right: 10px;
  bottom: -12px;
  left: auto;
  translate: 0;
}

.p-content04_textArea {
  text-align: center;
}

.p-content04_text {
  display: inline-block;
  font-size: 1.8rem;
  text-align: left;
}

.p-content04_btn {
  max-width: 335px;
  margin: 30px auto 0;
}

@media (min-width: 550px){
  .p-content04_heading02Jp {
    right: auto;
    bottom: -7px;
    left: 50%;
    translate: -50% 0;
  }
}

@media (min-width: 768px){
  #top main {
    margin-top: 0;
  }
  .p-mv {
    padding-bottom: 64px;
    background: linear-gradient(to right, #ff7b16, #b90316) left bottom/100% 27.5% no-repeat, #fff;
  }
  .p-mv::after {
    top: 0;
    max-width: none;
    background: url("../../img/index/mv/catch-pc.svg") no-repeat center/100%;
  }
  .p-mv_inner {
    width: 83.5%;
    margin-top: 0;
    border-bottom-left-radius: 80px;
  }
  .p-scrolldown {
    left: 6%;
  }
  .p-scrolldown::before {
    height: 100px;
  }
  .p-scrolldown_text {
    top: -125px;
    font-size: 1.4rem;
  }
  .p-btnList-right, .p-btnList-left {
    position: absolute;
    width: 38%;
    margin-top: 0;
    gap: 15px;
    translate: 0;
  }
  .p-btnList-left {
    top: 29%;
    left: 8%;
    align-self: flex-end;
  }
  .p-btnList-right {
    top: 64%;
    right: 3%;
    translate: 0 -50%;
  }
  .p-heading02_jp-right {
    right: 3.5%;
    bottom: -15px;
    left: auto;
    translate: 0;
  }
  .p-cardList {
    grid-template-columns: repeat(2, 1fr);
  }
  .p-card_btn {
    width: 80%;
    max-width: none;
    min-height: 68px;
  }
  .p-content01_heading02 {
    position: absolute;
    bottom: 92%;
    left: 4%;
    margin-bottom: 0;
  }
  .p-content01_imgArea {
    width: 69.5%;
    margin-bottom: 0;
    margin-left: auto;
  }
  .p-content02 {
    padding-top: 180px;
  }
  .p-content02_heading02 {
    position: absolute;
    right: 4%;
    bottom: 85%;
    margin-bottom: 0;
  }
  .p-content02_imgArea {
    width: 69.5%;
    margin-right: auto;
    margin-bottom: 0;
  }
  .p-content03_cardList {
    width: calc(100% - 40px * 2);
  }
  .p-content03_cardList {
    max-width: none;
  }
  .p-content04 {
    padding-bottom: 0;
  }
  .p-content04_inner {
    z-index: 1;
    position: absolute;
    top: 50%;
    left: min(160px, 5%);
    translate: 0 -50%;
  }
  .p-content04_heading02Jp {
    left: 43%;
  }
  .p-content04_textArea {
    padding-left: 30px;
    text-align: left;
  }
  .p-content04_btn {
    margin: 30px 0 0;
  }
}

@media (any-hover: hover) and (min-width: 1024px){
  .p-btn01, .p-btn01-shinkin {
    transition: background-color 0.2s, border 0.2s, color 0.2s;
  }
  .p-btn01:hover, .p-btn01-shinkin:hover {
    border: 3px solid #d60016;
    background-color: #fff;
    color: #d60016;
  }
  .p-btn01-shinkin:hover {
    border: 3px solid #ff5e16;
    color: #ff5e16;
  }
  .p-btn01_text, .p-btn01_text-shinkin {
    transition: background 0.2s;
  }
  .p-btn01:hover .p-btn01_text::after, .p-btn01:hover .p-btn01_text-shinkin::after, .p-btn01-shinkin:hover .p-btn01_text::after, .p-btn01-shinkin:hover .p-btn01_text-shinkin::after {
    background: url("../../img/icon_chevron-red.svg") no-repeat right center/0.5em;
  }
  .p-btn01:hover .p-btn01_text-shinkin::after, .p-btn01-shinkin:hover .p-btn01_text-shinkin::after {
    background: url("../../img/icon_chevron-orange.svg") no-repeat right center/0.6em;
  }
}

@media (min-width: 1024px){
  .p-mv {
    padding-bottom: 80px;
    background: linear-gradient(to right, #ff7b16, #b90316) left bottom/100% 27% no-repeat, #fff;
  }
  .p-mv_img {
    transform: scale(1.08) translateZ(0);
  }
  .p-scrolldown::before {
    height: 120px;
  }
  .p-scrolldown_text {
    top: -150px;
  }
  @keyframes verticalMove {
    0% {
      bottom: 120px;
    }
    100% {
      bottom: 0;
    }
  }
  .p-btnList-right, .p-btnList-left {
    gap: 25px;
  }
  .p-btnList-left {
    left: 8%;
  }
  .p-btnList-right {
    top: 57%;
    right: 0;
  }
  .p-btn01, .p-btn01-shinkin {
    max-width: 380px;
    min-height: 0;
    padding: 25px;
  }
  .p-btn01_text, .p-btn01_text-shinkin {
    padding: 0 20px;
    font-size: max(2rem, 1.2vw);
  }
  .p-btn01_text-shinkin {
    font-size: max(1.8rem, 1vw);
  }
  .p-heading02 {
    text-align: left;
  }
  .p-heading02_jp, .p-heading02_jp-center, .p-heading02_jp-right {
    top: 85%;
    bottom: auto;
    left: 17%;
    translate: 0 -50%;
    font-size: 2.8rem;
  }
  .p-heading02_jp::before, .p-heading02_jp-center::before, .p-heading02_jp-right::before {
    top: 54%;
    left: -23px;
    width: 10px;
    height: 10px;
  }
  .p-heading02_jp-right {
    right: 6.5%;
    left: auto;
    translate: 0 -50%;
  }
  .p-heading02_jp-center {
    top: 73%;
    right: auto;
    left: 50%;
    translate: -50% 0;
  }
  .p-heading02_en {
    display: inline-block;
    font-size: clamp(10rem, 20vw, 18rem);
    line-height: 1;
    letter-spacing: 0;
    white-space: nowrap;
    word-break: normal;
  }
  .p-cardList {
    gap: 40px;
  }
  .p-card {
    padding-bottom: 52px;
  }
  .p-card_imgArea {
    border-radius: 30px;
  }
  .p-card_btn {
    width: 75%;
    min-height: 78px;
  }
  .p-content01 {
    padding-top: 300px;
  }
  .p-content01_inner {
    width: auto;
  }
  .p-content01_heading02 {
    bottom: 83%;
  }
  .p-content01_img {
    border-radius: 60px 0 0 60px;
  }
  .p-content02 {
    padding-top: 300px;
  }
  .p-content02_inner {
    width: auto;
  }
  .p-content02_heading02En {
    font-size: clamp(10rem, 13vw, 18rem);
  }
  .p-content02_img {
    border-radius: 0 60px 60px 0;
  }
  .p-content03 {
    padding-block: 255px 260px;
  }
  .p-content03_inner {
    width: auto;
  }
  .p-content03_heading02 {
    margin-bottom: 88px;
    text-align: center;
  }
  .p-content03_cardList {
    width: calc(100% - 50px * 2);
  }
  .p-content03_cardList {
    max-width: 85%;
  }
  .p-content04_heading02 {
    margin-bottom: 30px;
    font-size: max(16rem, 10.5vw);
  }
  .p-content04_heading02En {
    font-size: clamp(10rem, 20vw, 14rem);
  }
  .p-content04_heading02Jp {
    left: 12%;
  }
  .p-content04_textArea {
    padding-left: 70px;
  }
  .p-content04_text {
    font-size: 2.2rem;
  }
}

@media (min-width: 1440px){
  .p-btnList-right, .p-btnList-left {
    width: 26.4%;
  }
  .p-btnList-left {
    left: 11.5%;
  }
  .p-btnList-right {
    right: 8.5%;
  }
  .p-btn01, .p-btn01-shinkin {
    max-width: none;
    padding: 1.58vw 1vw;
  }
  .p-heading02_jp, .p-heading02_jp-center, .p-heading02_jp-right {
    font-size: max(2.8rem, 2vw);
  }
  .p-heading02_en {
    font-size: max(18rem, 10.5vw);
  }
  .p-content01_heading02 {
    bottom: 85%;
    left: 9%;
  }
  .p-content04_inner {
    left: 160px;
  }
  .p-content04_heading02En {
    font-size: clamp(10rem, 20vw, 18rem);
  }
  .p-content04_text {
    font-size: max(2.2rem, 1.15vw);
  }
  .p-content04_btn {
    max-width: 380px;
    margin: 40px 0 0;
  }
}
/*# sourceMappingURL=index.css.map */