@charset "UTF-8";
/*==========================================
変数 inc.scss
===========================================*/
/*==========================================
変数 fonts.scss
===========================================*/
/*===================================
userSS 追加
=====================================*/
/*==========================================
変数 inc.scss
===========================================*/
/*==========================================
変数 fonts.scss
===========================================*/
/*===================================
userSS 追加
=====================================*/
/*==========================================
　company
===========================================*/
/*==========================================
 会社情報
===========================================*/
.subpage .breadcrumbs_area {
  border: none;
  background-color: transparent;
}

.concept .fv {
  position: relative;
  height: 100vh;
  margin-top: -230px;
  overflow: hidden;
}
@media screen and (max-width: 960px) {
  .concept .fv {
    padding: 30px;
    height: 110vh;
  }
}
.concept .fv .bg_wrap {
  display: flex;
  width: 400%;
  height: 100%;
  animation: slideBg 80s linear infinite;
}
.concept .fv .bg {
  width: 100%;
  height: 100%;
  flex-shrink: 0;
  background-position: center;
}
@media screen and (max-width: 960px) {
  .concept .fv .bg {
    height: 110vh;
  }
}
.concept .fv .bg1 {
  background-image: url(../img/concept/fv01.jpg);
  animation-delay: 0s;
}
.concept .fv .bg2 {
  background-image: url(../img/concept/fv02.jpg);
  animation-delay: 6s;
}
.concept .fv .bg3 {
  background-image: url(../img/concept/fv03.jpg);
  animation-delay: 12s;
}
.concept .fv .bg4 {
  background-image: url(../img/concept/fv04.jpg);
  animation-delay: 18s;
}
.concept .fv .mask {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 1;
}
.concept .fv .fv_inner {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding-top: clamp(100px, 5vh, 150px);
  min-width: 765px;
}
@media screen and (max-width: 960px) {
  .concept .fv .fv_inner {
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-width: 90%;
  }
}
.concept .fv .fv_inner .left {
  width: 75%;
}
@media screen and (max-width: 960px) {
  .concept .fv .fv_inner .left {
    width: 100%;
    padding-top: 35%;
  }
}
@media screen and (max-width: 960px) {
  .concept .fv .fv_inner .left .fv_title {
    font-size: 2.4rem;
    padding-bottom: 20px;
  }
}
.concept .fv .fv_inner .left .txt {
  font-size: clamp(1.6rem, 2vw, 1.8rem);
  line-height: 2;
}
@media screen and (max-width: 960px) {
  .concept .fv .fv_inner .left .txt {
    line-height: 1.8;
  }
}
.concept .fv .fv_inner .left .fv_ttl {
  font-size: clamp(2rem, 5vw, 2.4rem);
}
.concept .fv .fv_inner .right {
  writing-mode: vertical-rl;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 25%;
  text-align: center;
}
@media screen and (max-width: 960px) {
  .concept .fv .fv_inner .right {
    writing-mode: horizontal-tb;
    width: 100%;
    padding-top: 20px;
  }
}
.concept .fv .fv_inner .right p {
  font-size: clamp(2.4rem, 3vw, 3.6rem);
  letter-spacing: 0.2em;
}
.concept .fv .btn-more-flex:has(.btn-more-txt) {
  min-width: 230px;
  max-width: 230px;
}
@keyframes slideBg {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-75%);
  }
}
.concept .concept_block .txt {
  font-size: clamp(1.6rem, 2vw, 1.8rem);
}
.concept .concept_block .concept_item {
  background-color: #f1f0e5;
  display: flex;
  justify-content: center;
  gap: 5%;
}
@media screen and (max-width: 960px) {
  .concept .concept_block .concept_item {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
}
.concept .concept_block .concept_item:nth-child(even) {
  background-color: #fff;
  flex-direction: row-reverse;
}
@media screen and (max-width: 960px) {
  .concept .concept_block .concept_item:nth-child(even) {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
}
.concept .concept_block .concept_item:nth-child(even) .left {
  padding-right: 10%;
  padding-left: 0;
}
@media screen and (max-width: 960px) {
  .concept .concept_block .concept_item:nth-child(even) .left {
    padding-right: 0;
    padding-left: 0;
  }
}
.concept .concept_block .concept_item:nth-child(even) .left .num {
  left: 0;
}
.concept .concept_block .concept_item .left {
  flex: 0 0 40%;
  padding-left: 10%;
  position: relative;
}
@media screen and (max-width: 960px) {
  .concept .concept_block .concept_item .left {
    width: 92%;
    padding-left: 0;
    padding-bottom: 30px;
  }
}
.concept .concept_block .concept_item .left .num {
  color: #e5e5e5;
  font-size: clamp(10rem, 10vw, 20rem);
  position: absolute;
  left: 20%;
  top: 0;
  line-height: 0.7;
  font-family: "Libre Baskerville", serif;
}
.concept .concept_block .concept_item .left .catch {
  display: block;
  margin: clamp(30px, 5vh, 60px) 0 clamp(20px, 5vh, 40px) 0;
  font-size: clamp(1.8rem, 2.5vw, 2.1rem);
  letter-spacing: 0.1em;
  position: relative;
  z-index: 2;
}
.concept .concept_block .concept_item .left .ttl {
  margin-bottom: clamp(20px, 5vh, 60px);
  display: block;
  letter-spacing: 0.1em;
  position: relative;
  z-index: 2;
}
.concept .concept_block .concept_item .left .txt p {
  letter-spacing: 0.1em;
  line-height: 2;
}
@media screen and (max-width: 960px) {
  .concept .concept_block .concept_item .left .btn-more-block .btn-more-wrap {
    justify-content: center;
  }
}
.concept .concept_block .concept_item .left .btn-more-block .left {
  padding-left: 0;
}
@media screen and (max-width: 960px) {
  .concept .concept_block .concept_item .left .btn-more-block .left {
    margin: auto;
  }
}

/*# sourceMappingURL=concept.css.map */
