@charset "utf-8";

/* ↓↓↓ common ↓↓↓ */
* {
  margin: 0;
  box-sizing: border-box;
}

.dir-under .wrap {
  position: relative;
  background: url(../images/main-under-bg.jpg) repeat-y;
  background-size: 100% auto;
  background-position: top center;
}

.dir-under .wrap::before {
  content: '';
  position: absolute;
  translate: -50% 0;
  top: 0;
  left: 50%;
  max-width: 1280px;
  width: 100%;
  height: 100%;
  background: url(../images/deco-under-bg.png) repeat-y;
  background-size: 100% auto;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  .dir-under .wrap::before {
    background: url(../images/deco-under-bg_sp.png) repeat-y;
    background-size: 100% auto;
  }
}

.title-group {
  position: relative;
  z-index: 1;
}

.title-group .deco01 {
  position: absolute;
  top: 40px;
  left: 85%;
  width: 140px;
}

@media screen and (max-width: 768px) {
  .title-group .deco01 {
    top: 125px;
    left: initial;
    right: -30px;
    width: 55px;
  }
}

.title-group .page-title {
  position: relative;
  font-size: clamp(5rem, calc(64/1280*100vw), 6.4rem);
  font-weight: 400;
  font-family: var(--rammetto);
  letter-spacing: 0.048em;
  color: #fff;
  -webkit-text-stroke: 2px #000;
  filter: drop-shadow(8px 8px 0 #55D6C2);
  padding-bottom: 8px;
  margin: 0;
  overflow: hidden;
  opacity: 0;
}

@media screen and (max-width: 768px) {
  .title-group .page-title {
    text-align: center;
    font-size: 4rem;
    padding-bottom: 0;
  }
}

.title-group .page-title span {
  translate: 0 200%;
  display: inline-block;
}

.title-group .sub-title {
  position: relative;
  display: block;
  width: max-content;
  font-size: 1.4rem;
  font-weight: 700;
  font-family: var(--zenKakuAntique);
  text-align: center;
  line-height: 1;
  box-sizing: border-box;
  border: 2px solid #000;
  border-radius: 40px;
  padding: 11px 30px;
  margin: 0 0 20px;
  background-color: #fff;
  z-index: 0;
}

@media screen and (max-width: 768px) {
  .title-group .sub-title {
    margin: 0 auto 20px;
  }
}

.title-group .sub-title::before {
  content: '';
  position: absolute;
  translate: 0 100%;
  bottom: 0;
  left: 35px;
  width: 22px;
  height: 15px;
  clip-path: polygon(20% 0, 0% 100%, 100% 0);
  background-color: #000;
}

.title-group .sub-title::after {
  content: '';
  position: absolute;
  translate: 0 100%;
  bottom: 1px;
  left: 38px;
  width: 18px;
  height: 12px;
  clip-path: polygon(20% 0, 0% 100%, 100% 0);
  background-color: #fff;
}

.contents-main .text {
  text-align: justify;
  word-break: break-all;
  font-size: 1.6rem;
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .contents-main .text {
    font-size: 1.4rem;
  }
}
/* ↑↑↑ common ↑↑↑ */

/* ↓↓↓ fv-area ↓↓↓ */
.fv-area {
  position: relative;
  max-width: calc(1080px + 70px * 2);
  margin: 0 auto;
}

.fv-area .inner {
  padding: 42px 70px 0;
}

@media screen and (max-width: 768px) {
  .fv-area .inner {
    padding: 55px 32px 0;
  }
}

.fv-area .title-group {
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 940px) {
  .fv-area .title-group .page-title.-pc {
    display: none;
  }
  .fv-area .title-group .page-title.-sp {
    display: block;
  }
}

/* ↑↑↑ fv-area ↑↑↑ */

/* ↓↓↓ intro-area ↓↓↓ */
.intro-area  {
  position: relative;
  margin-top: 120px;
  z-index: 1;
}

@media (max-width: 768px) {
  .intro-area  {
    margin-top: 40px;
  } 
}

.intro-area .inner {
  padding: 0 70px;
}

@media (max-width: 768px) {
  .intro-area .inner {
    padding: 0;
  }
}

.intro-area .title-group {
  position: relative;
  z-index: 1;
}

.intro-area .title-group .sub-title {
  margin: 0 auto 20px;
}

.intro-area .title-group .page-title {
  text-align: center;
}

.intro-area .intro-block {
  position: relative;
  max-width: 1080px;
  padding-top: 40px;
  margin: 60px auto 0;
}

@media (max-width: 768px) {
  .intro-area .intro-block {
    display: flex;
    flex-direction: column-reverse;
    padding-top: 0;
    margin: 20px auto 0;
  }
}

.intro-area .intro-block .image {
  position: absolute;
  top: 0;
  right: 0;
  width: 54.352%;
  border-radius: 32px;
  overflow: hidden;
}

@media (max-width: 768px) {
  .intro-area .intro-block .image {
    position: initial;
    width: calc(100% - 32px);
    border-radius: 24px 0 0 24px;
    margin-left: auto;
  }
}

.intro-area .intro-block .intro-box {
  position: relative;
  width: max(400px, 49.908%);
  border-radius: 32px;
  padding: 4.26% 3.705%;
  font-family: var(--zenKakuAntique);
  border: 2px solid #000;
  background-color: #F5E960;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  .intro-area .intro-block .intro-box {
    width: calc(100% - 32px);
    border-radius: 24px;
    margin-top: -80px;
    padding: 30px 32px 22px;
  }
}

.intro-area .intro-block .intro-box .deco01 {
  position: absolute;
  transform: rotateY(180deg);
  translate: 0 -100%;
  top: -10px;
  left: 0;
  width: 144px;
}

@media screen and (max-width: 768px) {
  .intro-area .intro-block .intro-box .deco01 {
    top: 25px;
    left: 15px;
    width: 79px;
  }
}

.intro-area .intro-block .intro-box .copy {
  font-size: clamp(2.8rem, calc(38/1280*100vw), 3.8rem);
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 15px;
}

@media screen and (max-width: 768px) {
  .intro-area .intro-block .intro-box .copy {
    font-size: 2.2rem;
    margin-bottom: 10px;
  }
}

.intro-area .intro-block .intro-box .position,
.intro-area .intro-block .intro-box .joined {
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.3;
}

@media screen and (max-width: 768px) {
  .intro-area .intro-block .intro-box .position,
  .intro-area .intro-block .intro-box .joined {
    font-size: 1.2rem;
  }
}

.intro-area .intro-block .intro-box .name {
  font-size: 2.8rem;
  font-weight: 700;
  background-image: linear-gradient(to right, #000 2px, transparent 2px);
  background-size: 7px 2px;
  background-repeat: repeat-x;
  background-position: bottom;
  margin-bottom: 10px;
}

@media screen and (max-width: 768px) {
  .intro-area .intro-block .intro-box .name {
    font-size: 1.8rem;
    padding-bottom: 5px;
  }
}

.intro-area .intro-block .intro-box .name .en {
  font-family: var(--montserrat);
  font-size: 1.4rem;
  font-weight: 700;
  margin-left: 10px;
}

@media screen and (max-width: 768px) {
  .intro-area .intro-block .intro-box .name .en {
    font-size: 1.2rem;
  }
}

.intro-area .intro-block .intro-box .text-group {
  border-radius: 26px;
  padding: 22px 26px;
  background-color: #fff;
  margin-top: 15px;
}

.intro-area .intro-block .intro-box .text {
  font-size: 1.4rem;
}

@media screen and (max-width: 768px) {
  .intro-area .intro-block .intro-box .text-group {
    padding: 16px 20px;
  }

  .intro-area .intro-block .intro-box .text {
     font-size: 1.2rem;
     line-height: 1.4;
  }
}

/* ↑↑↑ intro-area ↑↑↑ */

/* ↓↓↓ interview-area ↓↓↓ */
.interview-area {
  position: relative;
  max-width: calc(1080px + 70px * 2);
  margin: 55px auto 0;
  z-index: 1;
}

@media (max-width: 768px) {
  .interview-area {
    max-width: 500px;
  }
}

.interview-area .inner {
  padding: 0 70px;
}

@media (max-width: 768px) {
  .interview-area .inner {
    padding: 0 32px;
  }
}

.interview-area .interview-block {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 52px 22px;
}

@media (max-width: 768px) {
  .interview-area .interview-block {
    flex-direction: column;
    gap: 38px 0;
  }
}

.interview-area .interview-box {
  position: relative;
  width: calc((100% - 24px) / 2);
  border-radius: 32px;
  border: 2px solid #000;
  background-color: #fff;
  padding: 60px 3.704% 40px;
}

@media (max-width: 768px) {
  .interview-area .interview-box {
    width: 100%;
    padding: 40px 22px 32px;
  }
}

.interview-area .interview-box .deco01 {
  position: absolute;
  transform: rotateY(180deg);
  bottom: -20px;
  left: -45px;
  width: 73px;
}

@media (max-width: 768px) {
  .interview-area .interview-box .deco01 {
    left: -25px;
    width: 40px;
  }
}

.interview-area .interview-box .num {
  position: absolute;
  translate: -50% 0;
  top: -55px;
  left: 50%;
  font-family: var(--rammetto);
  font-size: 5.4rem;
  letter-spacing: 0.048em;
  color: #fff;
  -webkit-text-stroke: 2px #000;
  filter: drop-shadow(8px 8px 0 #55D6C2);
}

@media (max-width: 768px) {
  .interview-area .interview-box .num {
    top: -40px;
    font-size: 4rem;
    filter: drop-shadow(4px 4px 0 #55D6C2);
  }
}

.interview-area .interview-box .theme {
  text-align: center;
  font-family: var(--zenKakuAntique);
  font-size: clamp(1.6rem, calc(26/1280*100vw), 2.6rem);
  font-weight: 700;
  padding-bottom: 16px;
  background-image: linear-gradient(to right, #000 2px, transparent 2px);
  background-size: 7px 2px;
  background-repeat: repeat-x;
  background-position: bottom;
  margin-bottom: 12px;
}

@media (max-width: 768px) {
  .interview-area .interview-box .theme {
    font-size: 1.6rem;
    line-height: 1.6;
    letter-spacing: 0;
  }
}

.interview-area .interview-box .theme-image {
  display: block;
  max-width: 340px;
  width: 100%;
  margin: 0 auto 20px;
}

@media (max-width: 768px) {
  .interview-area .interview-box .theme-image {
    width: 80%;
    margin: 0 auto;
  }
}

.interview-area .interview-box .logo {
  width: 142px;
  margin-top: 54px;
}

@media (max-width: 768px) {
  .interview-area .interview-box .logo {
    width: 86px;
    margin: 15px auto;
  }
}

.interview-area .interview-box .data-text {
  text-align: center;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.3;
}

@media (max-width: 768px) {
  .interview-area .interview-box .data-text {
    font-size: 1.6rem;
  }
}

.interview-area .interview-block + .image {
  margin-top: 30px;
  border-radius: 32px;
  overflow: hidden;
}

@media (max-width: 768px) {
  .interview-area .interview-block + .image {
    margin-top: 24px;
    border-radius: 24px;
  }
}

.interview-area .image + .interview-block {
  margin-top: 54px;
}
/* ↑↑↑ interview-area ↑↑↑ */

/* ↓↓↓ schedule-area ↓↓↓ */
.schedule-area {
  position: relative;
  margin-top: 112px;
  z-index: 1;
}

@media (max-width: 768px) {
  .schedule-area {
    margin-top: 66px;
  }
}

.schedule-area .inner {
  padding: 0 70px;
}

@media (max-width: 768px) {
  .schedule-area .inner {
    padding: 0 32px;
  }
}

.schedule-area .title-group .sub-title {
  margin: 0 auto 20px;
}

.schedule-area .title-group .page-title {
  text-align: center;
}

.schedule-area .schedule-block {
  position: relative;
  max-width: 860px;
  margin: 40px auto 0;
}

@media (max-width: 768px) {
  .schedule-area .schedule-block {
    max-width: 500px;
    margin: 30px auto 0;
  }
}

.schedule-area .schedule-block .deco01 {
  position: absolute;
  top: -205px;
  left: -45px;
  width: 101px;
  margin: 0;
}

@media (max-width: 768px) {
  .schedule-area .schedule-block .deco01 {
    top: 30px;
    left: 15px;
    width: 63px;
  }
}

.schedule-area .schedule-block .deco02 {
  position: absolute;
  transform: rotateY(180deg);
  top: -140px;
  right: -80px;
  width: 101px;
  margin: 0;
}

@media (max-width: 768px) {
  .schedule-area .schedule-block .deco02 {
    top: -30px;
    right: -10px;
    width: 68px;
  }
}

.schedule-area .schedule-block .deco03 {
  position: absolute;
  top: 62%;
  left: -12%;
  width: 95px;
  margin: 0;
}

@media (max-width: 768px) {
  .schedule-area .schedule-block .deco03 {
    top: 58%;
    left: 12px;
    width: 40px;
  }
}

.schedule-area .schedule-box {
  position: relative;
  display: flex;
  align-items: center;
  gap: 30px;
}

@media (max-width: 768px) {
  .schedule-area .schedule-box {
    gap: 8px;
  }
}

.schedule-area .schedule-box:last-of-type {
  overflow: hidden;
}

.schedule-area .schedule-box:not(:first-of-type):before,
.schedule-area .schedule-box::after {
  content: '';
  position: absolute;
  translate: 0 -50%;
  top: 0;
  left: 67px;
  width: 3px;
  height: 100%;
  background-color: #F5E960;
}

@media (max-width: 768px) {
  .schedule-area .schedule-box:not(:first-of-type):before,
  .schedule-area .schedule-box::after {
    left: 38px;
  }
}

.schedule-area .schedule-box::after {
  translate: 0 50%;
}

.schedule-area .schedule-box:not(:first-of-type) {
  margin-top: 10px;
}

.schedule-area .schedule-box .time {
  position: relative;
  display: grid;
  place-content: center;
  min-width: 134px;
  height: 43px;
  font-family: var(--montserrat);
  font-size: 2.7rem;
  font-weight: 700;
  border-radius: 43px;
  background-color: #F5E960;
  z-index: 1;
}

@media (max-width: 768px) {
  .schedule-area .schedule-box .time {
    min-width: 76px;
    height: 31px;
    font-size: 1.6rem;
  }
}

.schedule-area .schedule-box .text-group {
  display: flex;
  align-items: center;
  flex-grow: 1;
  gap: 46px;
  border-radius: 26px;
  border: 2px solid #231F20;
  background-color: #fff;
  padding: 32px 35px;
}

@media (max-width: 768px) {
  .schedule-area .schedule-box .text-group {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    border-radius: 24px;
    padding: 22px 20px;
  }
}

.schedule-area .schedule-box .text-group .image {
  min-width: 35.05%;
}

@media (max-width: 768px) {
  .schedule-area .schedule-box .text-group .image {
    min-width: initial;
    width: 173px;
    margin: 0 auto;
  }
}

.schedule-area .schedule-box .text-group .text {
  text-align: left;
  flex-grow: 1;
}

@media (max-width: 768px) {
  .schedule-area .schedule-box .text-group .text {
   line-height: 1.4;
  }
}
/* ↑↑↑ schedule-area ↑↑↑ */


/* ↓↓↓ style-area ↓↓↓ */
.style-area  {
  position: relative;
  margin-top: 120px;
  background-color: #F5E960;
}

@media (max-width: 768px) {
  .style-area  {
    margin-top: 64px;
  } 
}

.style-area .deco01 {
  position: absolute;
  top: -60px;
  left: 40px;
  width: 122px;
  z-index: 1;
}

@media (max-width: 768px) {
  .style-area .deco01 {
    top: -30px;
    left: 0;
    width: 73px;
  }
}

.style-area .deco02 {
  position: absolute;
  bottom: -50px;
  right: -85px;
  width: 115px;
  z-index: 1;
}

@media (max-width: 768px) {
  .style-area .deco02 {
    bottom: -100px;
    right: 15px;
    width: 60px;
  }
}

.style-area .inner {
  padding: 100px 70px;
}

@media (max-width: 768px) {
  .style-area .inner {
    padding: 66px 0;
  }
}

.style-area .title-group {
  position: relative;
  z-index: 1;
}

.style-area .title-group .sub-title {
  margin: 0 auto 20px;
}

.style-area .title-group .page-title {
  text-align: center;
}

.style-area .style-block {
  position: relative;
  max-width: 1080px;
  margin: 60px auto 0;
  z-index: 1;
}

.style-area .style-block + .style-block {
  margin-top: 70px;
}

@media (max-width: 768px) {
  .style-area .style-block {
    display: flex;
    flex-direction: column-reverse;
    padding-top: 0;
    margin: 20px auto 0;
  }
}

.style-area .style-block .image {
  position: absolute;
  translate: 0 -50%;
  top: 50%;
  right: 0;
  width: 55.464%;
  border-radius: 30px;
  overflow: hidden;
}

.style-area .style-block:nth-of-type(odd) .image {
  right: initial;
  left: 0;
}

@media (max-width: 768px) {
  .style-area .style-block .image {
    position: initial;
    translate: 0 0;
    width: calc(100% - 32px);
    border-radius: 24px 0 0 24px;
    margin-left: auto;
  }

  .style-area .style-block:nth-of-type(odd) .image {
    border-radius: 0 24px 24px 0;
    margin-left: 0;
  }
}

.style-area .style-block .style-box {
  position: relative;
  width: max(345px, 51.205%);
  border-radius: 30px;
  padding: 4.075% 4.63%;
  font-family: var(--zenKakuAntique);
  border: 2px solid #000;
  background-color: #fff;
  z-index: 1;
}

.style-area .style-block:nth-of-type(odd) .style-box {
  margin-left: auto;
}

@media screen and (max-width: 768px) {
  .style-area .style-block .style-box {
    width: calc(100% - 32px);
    margin-top: -60px;
    padding: 36px 32px 32px;
  }

  .style-area .style-block:nth-of-type(even) .style-box {
    border-radius: 0 30px 30px 0;
    border-left: initial;
  }

  
  .style-area .style-block:nth-of-type(odd) .style-box {
    border-radius: 30px 0 0 30px;
    border-right: initial;
  }
}

.style-area .style-box .num {
  position: absolute;
  top: -45px;
  left: 35px;
  font-size: clamp(4.5rem, calc(60 / 1280* 100vw), 6rem);
  font-family: var(--rammetto);
  letter-spacing: 0.048em;
  color: #fff;
  -webkit-text-stroke: 2px #000;
}

.style-area .style-block:nth-of-type(odd) .num {
  left: initial;
  right: 35px;
}

@media (max-width: 768px) {
  .style-area .style-box .num {
    top: -40px;
    left: 10px;
    font-size: 5rem;
  }
  
  .style-area .style-block:nth-of-type(odd) .num {
    left: 10px;
  }
}

.style-area .style-box .theme {
  text-align: center;
  font-family: var(--zenKakuAntique);
  font-size: clamp(1.6rem, calc(26 / 1280* 100vw), 2.6rem);
  font-weight: 700;
  padding-bottom: 16px;
  background-image: linear-gradient(to right, #000 2px, transparent 2px);
  background-size: 7px 2px;
  background-repeat: repeat-x;
  background-position: bottom;
  margin-bottom: 12px;
}

@media (max-width: 768px) {
  .style-area .style-box .theme {
    font-size: 2rem;
    padding-bottom: 14px;
  }
}
/* ↑↑↑ style-area ↑↑↑ */