@charset "UTF-8";

/*=============================*/
/* fonts */
/*=============================*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400&display=swap');

/*=============================*/
/* clearfix */
/*=============================*/
.clearfix:before, .clearfix:after {
    content:"";
    display:table
}
.clearfix:after {
    clear:both 
}
/*=============================*/
/* SP */
/*=============================*/
body {
    font-family: "游明朝", YuMincho, "Yu Mincho", serif;
}
/*=========hero==========*/

.hero {
    width: 100%;
    height: 100vh;
    text-align: center;
    overflow: hidden;
}
.hero__award-logo {
    display: block;
    width: 25%;
    float: right;
    margin: 5%;
}
.hero__main-back {
    width: 100%;
    height: 100vh;
    background-color: white;
    position: absolute;
    top:0;
}
.hero__main-inner {
    transform: rotate(-5deg);
}
.hero__main-img1 {
    display: block;
    opacity: 0;
    width: 95%;
    margin: 22vh auto auto;
    z-index: 99;
    position: relative;
    animation-name: fade;
    animation-delay: 0.5s;
    animation-duration: 2s;
    animation-iteration-count: 1;
    animation-fill-mode: forwards;
}
@keyframes fade{
    0%{
      opacity: 0;
    }
    100%{
      opacity: 1;
    }
  }
  .hero__main-img2 {
    display: block;
    opacity: 0;
    width: 95%;
    margin: 0 auto auto;
    z-index: 99;
    position: relative;
    animation-name: fade2;
    animation-delay: 2s;
    animation-duration: 2s;
    animation-iteration-count: 1;
    animation-fill-mode: forwards;

}
@keyframes fade2{
    0%{
      opacity: 0;
    }
    100%{
      opacity: 1;
    }
  }
.hero__company-logo {
    display: block;
    width: 30%;
    margin: 20vh auto auto;
}
.hero__head {
    color: rgb(182,0,47);
    display: inline-block;
    margin: 4.5vh auto auto;
    border-top: solid 1px rgb(182,0,47);
    border-bottom: solid 1px rgb(182,0,47);
    padding: 0.3em 0;
    font-size: 2rem;
}

/*=========question==========*/
.question {
    width: 100%;
    text-align: center;
    background-color: #E7E7E7;
}
.question-outer {
    margin: 2rem auto auto;
}
.question-outer:last-of-type {
    margin: 2rem auto 4rem;
}
.question-outer:first-of-type {
    margin: 3.5rem auto auto;
}
.question__head {
    font-size: 1.5rem;
    line-height: 2.6rem;
    margin: 1rem auto auto;
}
.question__head {
    font-size: 1.5rem;
    line-height: 2.6rem;
    margin: 5rem auto auto;
}
.question__head--bigfonts {
    font-size: 2.3rem;
    line-height: 3.1rem;
}
.question__q {
    background-color: white;
    width: 90%;
    display: block;
    margin: auto;
    box-shadow: 0 3px 10px 0 rgb(0 0 0 / 20%);
    text-align: left;
    font-size: 1.6rem;
    padding: 1.8rem 1.5rem;
}
.question__a {
    position: relative;
    background-color: white;
    width: 90%;
    display: block;
    margin: 1rem auto auto;
    box-shadow: 0 3px 10px 0 rgb(0 0 0 / 20%);
    text-align: left;
}
.question__a--head {
    font-size: 1.8rem;
    line-height: 3.15rem;
    color: rgb(182,0,47);
    margin: 1rem 1.5rem auto;
}
.question__a-description {
    font-size: 1.6rem;
    line-height: 2.8rem;
    margin: 1.2rem 1.5rem auto
}
.question__img {
    margin: 1.8rem 1.5rem auto
}
.question__source {
    font-size: 0.7rem;
    text-align: right;
    margin: 2rem 1.5rem 1rem;
}
.question__a--panel {
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: white;
    display: flex;
    justify-content: space-around;
    align-items: center;
    flex-direction: column;
    padding-bottom: 4rem;
}
.display_off {
    opacity: 0;
    transition-duration: .5s;
}
.question__inner {
    height: 350px;
    overflow: hidden;
    transition-duration: .5s;
}
.display_on {
    height: 100%;
    overflow: visible;
    transition-duration: .5s;
}
.panel__align {
    display: flex;
    justify-content: space-around;
    flex-direction: column;
    height: 100%;
    padding: 2rem 0 2rem;
}

.question-a-panel__text-q {
    font-size: 2.2rem;
}
.question-a-panel__text-a {
    font-size: 20px;
    color: rgb(182,0,47);
    border: solid 1px rgb(182,0,47);
    padding: 1rem 2.5rem;
}
/*=========message==========*/
.message {
    background-color: white;
    width: 100%;
    text-align: center;
    margin-top: 2rem;
}
.message__head {
    color: rgb(182,0,47);
    font-size: 1.6rem;
    border-bottom: solid 1px rgb(182,0,47);
    display: inline-block;
    margin-top: 4rem;
}
.message__text-shinsotsu,
.message__text-shinsotsu-red,
.message__text-shinsotsu-large {
    font-size: 1.6rem;
    margin-top: 3.5rem;
    line-height: 2.8rem;
}
.message__text-shinsotsu-red {
    color: rgb(182,0,47);
}
.message__text-shinsotsu-large {
    font-size: 2rem;
    display: block;
    margin-top: 3.5rem;
    line-height: 2rem;
}
.message__text-daini-shinsotsu,
.message__text-daini-shinsotsu-red,
.message__text-daini-shinsotsu-large {
    font-size: 1.4rem;
    margin-top: 3.5rem;
    line-height: 2.6rem;
}
.message__text-daini-shinsotsu-red {
    color: rgb(182,0,47);
}
.message__text-daini-shinsotsu-large {
    font-size: 2rem;
    display: block;
    margin-top: 3.5rem;
    line-height: 2rem;
}
.message__text-chuto,
.message__text-chuto-red,
.message__text-chuto-large {
    font-size: 1.4rem;
    margin-top: 3.5rem;
    line-height: 2.6rem;
}
.message__text-chuto-red {
    color: rgb(182,0,47);
}
.message__text-chuto-large {
    font-size: 2rem;
    display: block;
    margin-top: 3.5rem;
    line-height: 2rem;
}
.message__text--punctuation {
    font-feature-settings: "palt";
}
.message__text--logo {
    display: block;
    margin: 3rem auto;
    width: 7rem;
}
/*=========company==========*/
.pc_br {
    display: none;
}
.sp_br {
    display: inline;
}
.company {
    background-color: white;
    width: 100%;
    text-align: center;
}
.company__head {
    color: rgb(182,0,47);
    font-size: 2rem;
    border-bottom: solid 1px rgb(182,0,47);
    display: inline-block;
    margin-top: 8rem;
}
.company__description {
    font-size: 1.6rem;
    margin-top: 4rem;
    line-height: 2.4rem;
}
.company-wrap {
    background-color: white;
    display: flex;
    width: auto;
    justify-content: space-around;
    align-items: center;
    margin: 3rem 5%;
    box-shadow: 0 3px 10px 0 rgb(0 0 0 / 20%);
    height: 11.5rem;
    text-align: left;
    padding: 0 0.6rem;
}
.company-wrap__logo {
    height: 70px;
    width: 70px;
    margin: auto 0.6rem auto auto;
}

.company-wrap__head {
    font-size: 1.3rem;
    line-height: 2.3rem;
    border-bottom: solid 1px rgb(182,0,47);
    padding-bottom: 0.5rem;
}
.company-wrap__text {
    font-size: 1.3rem;
    margin-top: 0.5rem;
    line-height: 2.3rem;
}
.company__read-more {
    color: rgb(182,0,47);
    float: right;
    margin: 1rem 5%;
    font-size: 1.2rem;
}
/*=========note==========*/
.note {
    background-color: white;
    width: 100%;
    text-align: center;
}
.note__head {
    color: rgb(182,0,47);
    font-size: 2.2rem;
    border-bottom: solid 1px rgb(182,0,47);
    display: inline-block;
    margin-top: 6rem;
    padding-bottom: 0.5rem;
}
.note__description {
    font-size: 1.6rem;
    margin-top: 4rem;
    line-height: 2.1rem;
}
.note__icon {
    width: 7rem;
    margin-top: 2.2rem;
}

/*====swiper=====*/
.swipernote {
    width: 100%;
    margin: 0 0 auto;
    padding: 2.5rem 0 1rem;
    position: relative;
}

.swiper-slide {
    opacity: 0.4;
    overflow: hidden;
    /* transition: .3s; */
    transform: scale(0.8)!important; /* スライドの大きさ調整 */
}

.swiper-slide img {
    width: 100%;
}
.swiper-slide-active {
    opacity: 1;
    z-index: 1;
    transform: scale(1)!important; /* スライドの大きさ調整 */
}

.swiper-button-next,
.swiper-button-prev {
    display: none;
}

/*====thumsnote=====*/
.thumsnote {
    pointer-events:none;
}
.swiper.thumsnote {
    padding: 1.5rem 0 1rem;
}
.swiper-slide.thumsnote {
    font-size: 1.6rem;
    line-height: 2.8rem;
    padding: 0;
}


/*=========wantedly==========*/
.wantedly {
    background-color: white;
    width: 100%;
    text-align: center;
}
.wantedly__head {
    color: rgb(182,0,47);
    font-size: 2.2rem;
    border-bottom: solid 1px rgb(182,0,47);
    display: inline-block;
    margin-top: 6rem;
    padding-bottom: 0.5rem;
}
.wantedly__description {
    font-size: 1.6rem;
    margin-top: 4rem;
    line-height: 2.1rem;
}
.wantedly__icon {
    width: 7rem;
    margin-top: 2.2rem;
}

/*====swiper=====*/
.swiperwantedly {
    width: 100%;
    margin: 0 0 auto;
    padding: 2.5rem 0 1rem;
    position: relative;
}

.swiper-slide {
    opacity: 0.4;
    overflow: hidden;
    /* transition: .3s; */
    transform: scale(0.8)!important; /* スライドの大きさ調整 */
}

.swiper-slide img {
    width: 100%;
}
.swiper-slide-active {
    opacity: 1;
    z-index: 1;
    transform: scale(1)!important; /* スライドの大きさ調整 */
}

/*====thumswantedly=====*/
.thumswantedly {
    pointer-events:none;
}
.swiper.thumswantedly {
    padding: 1.5rem 0 1rem;
}
.swiper-slide.thumswantedly {
    font-size: 1.6rem;
    line-height: 2.8rem;
    padding: 0;
}



/*=========media==========*/
.media {
    background-color: white;
    width: 100%;
    text-align: center;
}
.media__head {
    color: rgb(182,0,47);
    font-size: 2.2rem;
    border-bottom: solid 1px rgb(182,0,47);
    display: inline-block;
    margin-top: 6rem;
    padding-bottom: 0.5rem;
}
.media__description {
    font-size: 1.6rem;
    margin-top: 2rem;
    line-height: 2.1rem;
}
/*====swiper=====*/
.swipermedia {
    width: 100%;
    margin: 0 0 auto;
    padding: 2.5rem 0 1rem;
    position: relative;
}

.swiper-slide {
    opacity: 0.4;
    overflow: hidden;
    /* transition: .7s; */
    transform: scale(0.8)!important; /* スライドの大きさ調整 */
}

.swiper-slide img {
    width: 100%;
}
.swiper-slide-active {
    opacity: 1;
    z-index: 1;
    transform: scale(1)!important; /* スライドの大きさ調整 */
}

/*====thumsmedia=====*/
.thumsmedia {
    pointer-events:none;
}
.swiper.thumsmedia {
    padding: 1.5rem 0 1rem;
}
.swiper-slide.thumsmedia {
    font-size: 1.6rem;
    line-height: 2.8rem;
    padding: 0;
}

/*====ページネーション=====*/

.swiper-pagination-bullets {
    position: static;
    margin-top: 16px;
  } 
.swiper-pagination-bullet {
    width: 6px !important;
    height: 6px !important;
    margin: 0 0 0 10px !important;
    background: #333 !important;
    opacity: 1;
  }
  .swiper-pagination-bullet:first-child {
    margin: 0 !important;
  }
  .swiper-pagination-bullet-active {
    background: rgb(182,0,47)!important;
  }



/*=========awardhistory==========*/

.awardhistory {
    background-color: white;
    width: 100%;
    text-align: center;
}
.awardhistory__head {
    color: rgb(182,0,47);
    font-size: 2.4rem;
    border-bottom: solid 1px rgb(182,0,47);
    display: inline-block;
    margin-top: 6rem;
    padding-bottom: 0.5rem;
}
.awardhistory__description {
    font-size: 1.6rem;
    margin-top: 3rem;
    line-height: 2.1rem;
}
.awardhistory__img {
    display: block;
    width: 30%;
    margin: 3rem auto auto;
}
/*=========entry==========*/
.entry {
    background-color: white;
    width: 100%;
    text-align: center;
}
.entry__outer {
    background-color: white;
    border: rgb(182,0,47) solid 1px;
    width: 90%;
    display: block;
    margin: 6rem auto auto;
    text-align: center;
    font-size: 1.5rem;
}
.entry__logo {
    display: block;
    width: 25%;
    margin: 2.3rem auto auto;
}
.entry__description {
    font-size: 1.8rem;
    color: rgb(182,0,47);
    line-height: 3.15rem;
    margin: 2.3rem auto auto;
}
.btn,
a.btn,
button.btn {
  font-size: 2rem;
  position: relative;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  border-radius: 0.5rem;
}

a.btn-flat {
    display: inline-block;
    font-size: 1.4rem;
    background-color: rgb(182,0,47);
    color: white;
    padding: 16px 26px;
    clip-path: polygon(0% 0%, 100% 0%, 100% 40%, 85% 100%, 0% 100%);
    margin: 2rem;
}

a.btn-flat span {
  position: relative;
}

a.btn-flat:before {
  display: none;
  position: absolute;
  top: 0;
  left: 0;

  width: 150%;
  height: 500%;

  content: "";
  -webkit-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out;
  -webkit-transform: translateX(55%) translateY(1%) rotate(45deg);
  transform: translateX(55%) translateY(1%) rotate(45deg);

  background: white;
}

a.btn-flat:hover:before {
    -webkit-transform: translateX(-9%) translateY(-25%) rotate(45deg);
    transform: translateX(-9%) translateY(-25%) rotate(45deg);
  }


/*=========copyright==========*/
.copyright {
    text-align: center;
    font-size: 1rem;
    margin: 2.5rem auto 1.5rem;
}

/*=========fixedEntry==========*/
.entry__btn-fixed {
    position: fixed;
    right: 10px;
    bottom: 10px;
    width: 9rem;
    height: 9rem;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    text-decoration: none;
    opacity: 0;
    transition: all 0.65s;
  }
  .entry__btn-fixed.isActive {
    opacity: 1;
    transition: all 0.65s;
    position: fixed;
    z-index: 99;
  }