@charset "UTF-8";

.main {
  overflow: clip;
  position: relative;
}
.othercontentsWrap,
.foot {
  background-color: #fff;
}
@media all and (min-width: 681px) {
  .head {
    background-color: rgba(255, 255, 255, 0.7);
    transition: 0.3s ease;
  }
  .pageScroll .head {
    background-color: rgba(255, 255, 255, 1);
  }
}

/* bg1
***************************************************************/
.bg1 {
  width: 100%;
  height: 100lvh;
  position: fixed;
  z-index: -1;
  top: 0;
  left: 0;
  background: no-repeat center / cover;
}
@media all and (min-width: 681px) {
  .bg1 {
    background-image: url(../../img/kominka/bg1.jpg);
  }
}
@media all and (max-width: 680px) {
  .bg1 {
    background-image: url(../../img/kominka/bg1_sp.jpg);
  }
}
@media all and (max-width: 370px) {
}

/* fvWrap
***************************************************************/
.fvWrap {
  width: 100%;
  height: 400vh;
  position: relative;
}
.mv_scroll {
  display: block;
  position: fixed;
  z-index: 3;
  bottom: 0;
  left: 0;
  right: 38px;
  margin: auto;
  width: 38px;
  height: 86px;
  transition: opacity 1s ease;
  pointer-events: none;
}
.mv_scroll.off {
  opacity: 0;
}
.mv_scroll-txt {
  position: absolute;
  top: 0;
  left: 0;
  /* transform: translateY(-50%); */
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  color: #fff;
  font-size: 14px;
}
.mv_scroll-bar {
  width: 2px;
  height: 100%;
  background-color: #acacac;
  position: absolute;
  top: 0;
  right: 0;
}
.mv_scroll-bar::after {
  content: "";
  width: 2px;
  height: 0px;
  background-color: #fff;
  position: absolute;
  top: 0;
  right: 0;
  transition: height 0.3s ease;
  animation: scroll1 2s ease 0s infinite backwards;
}
@keyframes scroll1 {
  0% {
    height: 0;
  }
  75% {
    height: 100%;
  }
  100% {
    height: 100%;
  }
}
@media all and (min-width: 681px) {
}
@media all and (max-width: 680px) {
  .fvWrap {
    height: 520vh;
  }
  .mv_scroll {
    left: 8px;
    right: auto;
    width: 26px;
    height: 80px;
  }
  .mv_scroll-txt {
    font-size: 12px;
  }
}

/* mv1
***************************************************************/
.mv1 {
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  opacity: 1;
  transition: opacity 1s ease;
  pointer-events: none;
}
.mv1.off {
  opacity: 0;
}
@keyframes opacity1 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.mv1_tit1 {
  width: 100px;
  margin-bottom: 50px;
  opacity: 0;
  transition: opacity 1s ease;
  animation: opacity1 cubic-bezier(0.215, 0.61, 0.355, 1) 1s forwards 1s;
}
@media all and (min-width: 681px) {
}
@media all and (max-width: 680px) {
  .mv1_tit1 {
    width: 66.22px;
    margin-bottom: 50px;
  }
}
@media all and (max-width: 370px) {
}

/* concept
***************************************************************/
.concept {
  width: 100%;
  height: 100vh;
  background-color: rgba(26, 23, 18, 0.55);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  opacity: 0;
  transition: opacity 1s ease;
  pointer-events: none;
}
.concept.on1 {
  opacity: 1;
}
.concept.off {
  opacity: 0;
}
.concept_bg1 {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: no-repeat center top / cover;
  pointer-events: none;
}
.concept_inner {
  width: 1100px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}
.concept_h2 {
  width: 380px;
  opacity: 0;
  transition: opacity 1s ease;
}
.concept_h2 img {
  width: 202px;
  display: block;
  margin: 0 auto;
}
.concept_txtBox1 {
  opacity: 0;
  transition: opacity 1s ease;
}
.concept_txt1 {
  color: #fff;
  font-size: 17px;
  font-weight: 400;
  text-align: justify;
  letter-spacing: 0.05em;
  line-height: calc(34 / 17);
}
.concept_txt1 + .concept_txt1 {
  margin-top: 30px;
}
.concept.on2 .concept_h2,
.concept.on3 .concept_txtBox1 {
  opacity: 1;
}
@media all and (min-width: 681px) {
  .concept_bg1 {
    background-image: url(../../img/kominka/bg2.png);
    mix-blend-mode: multiply;
  }
}
@media all and (max-width: 680px) {
  .concept_bg1 {
    background-image: url(../../img/kominka/bg2_sp.png);
  }
  .concept_inner {
    width: 100%;
    height: 100%;
    display: block;
    position: relative;
  }
  .concept_h2 {
    width: 100%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .concept_h2 img {
    width: 140.4px;
  }
  .concept_txtBox1 {
    padding-left: 10px;
    position: absolute;
    top: 40px;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .concept_txt1 {
    font-size: clamp(11px, 2vh, 15px);
    letter-spacing: 0;
    line-height: calc(30 / 15);
  }
  .concept_txt1 + .concept_txt1 {
    margin-top: 20px;
  }

  .concept.on2_off .concept_h2,
  .concept.on3_off .concept_txtBox1 {
    opacity: 0;
  }

  .pageScroll .h_conversion {
    bottom: -54px;
  }
  .pageScroll .h_conversion.on {
    bottom: 0;
  }
}
@media all and (max-width: 370px) {
}

/* works
***************************************************************/
.works {
  padding: 180px 0 115px;
  background-color: #f4eee7;
}
.works_item {
  position: relative;
}
.works_item + .works_item {
  margin-top: 150px;
}
.works_item_box1 {
  width: 1200px;
  margin: 0 auto;
  padding-top: 110px;
}
.works_item_box1_txtBox1 {
  width: 521px;
  background-color: #fff;
  padding: 60px 50px;
  position: relative;
  z-index: 1;
}
.works_item_box1_txtBox1_label {
  font-size: 17px;
  font-weight: 400;
  text-align: justify;
  letter-spacing: 0.1em;
  line-height: 1.7;
  margin-bottom: 5px;
}
.works_item_box1_txtBox1_tit {
  font-size: 27px;
  font-weight: 500;
  text-align: justify;
  letter-spacing: 0.05em;
  line-height: calc(50 / 27);
}
.works_item_box1_txtBox1_txt {
  font-size: 16px;
  font-weight: 400;
  text-align: justify;
  letter-spacing: 0;
  line-height: calc(32 / 16);
  margin-top: 20px;
}
.works_item_box1_txtBox1_sml {
  font-size: 16px;
  font-weight: 400;
  text-align: justify;
  letter-spacing: 0;
  margin-top: 20px;
}
.works_item_box1_txtBox1_link {
  display: flex;
  justify-content: flex-end;
  margin-top: 20px;
}
.works_item_box1_txtBox1_link_btn {
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.1em;
  display: block;
  position: relative;
  padding-right: 20px;
  padding-bottom: 5px;
}
.works_item_box1_txtBox1_link_btn::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-color: #000;
  transition: width 0.3s ease;
}
.works_item_box1_txtBox1_link_btn::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 2px;
  width: 6px;
  height: 1px;
  background-color: #000;
  transform: rotate(45deg);
  transition: right 0.3s ease;
}
@media all and (min-width: 681px) {
  .works_item_box1_img {
    position: absolute;
    top: 0;
    width: calc(((100vw - 1200px) / 2) + 760px);
    min-width: 760px;
  }
  .works_item_box1_img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .works .works_item:nth-of-type(odd) .works_item_box1_txtBox1 {
    margin-left: auto;
  }
  .works .works_item:nth-of-type(odd) .works_item_box1_img {
    left: 0;
  }
  .works .works_item:nth-of-type(even) .works_item_box1_img {
    right: 0;
  }
  .works_item_box1_img.img1 {
    height: 526px;
  }
  .works_item_box1_img.img2 {
    height: 526px;
  }
  .works_item_box1_img.img3 {
    height: 590px;
  }

  a.works_item_box1_txtBox1_link_btn:hover::before {
    width: calc(100% + 10px);
  }
  a.works_item_box1_txtBox1_link_btn:hover::after {
    right: -10px;
  }
}
@media all and (max-width: 680px) {
  .works {
    padding: 58px 0 70px;
  }
  .works_item + .works_item {
    margin-top: 70px;
  }
  .works_item_box1 {
    width: 100%;
    padding-top: 0;
  }
  .works_item_box1_txtBox1 {
    width: calc(100% - 32px);
    margin: 0 auto -30px;
    padding: 42px 35px 48px;
    position: relative;
    top: -30px;
  }
  .works_item_box1_txtBox1_label {
    font-size: 13px;
    margin-bottom: 5px;
  }
  .works_item_box1_txtBox1_tit {
    font-size: 20px;
    letter-spacing: 0;
    line-height: calc(34 / 20);
    word-break: keep-all;
  }
  .works_item_box1_txtBox1_txt {
    font-size: 15px;
    line-height: calc(30 / 15);
    margin-top: 20px;
  }
  .works_item_box1_txtBox1_sml {
    font-size: clamp(13px, 3.55vw, 15px);
    margin-top: 20px;
  }
  .works_item_box1_txtBox1_link {
    display: flex;
    justify-content: center;
    margin-top: 30px;
  }
  .works_item_box1_txtBox1_link_btn {
    font-size: 14px;
    padding-left: 10px;
    padding-right: 20px;
  }
}
@media all and (max-width: 370px) {
}

/* works_slide
***************************************************************/
:root {
  --profile-slide-width: 330px;
  --profile-slide-gap: 10px;
  --profile-slide-widthSP: 226px;
  --profile-slide-gapSP: 7px;
}
@keyframes scrollSlide1 {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc((var(--profile-slide-width) * -5) + (var(--profile-slide-gap) * -5)));
  }
}
@keyframes scrollSlide1_i4 {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc((var(--profile-slide-width) * -4) + (var(--profile-slide-gap) * -4)));
  }
}
@keyframes scrollSlide1SP {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc((var(--profile-slide-widthSP) * -5) + (var(--profile-slide-gapSP) * -5)));
  }
}
@keyframes scrollSlide1SP_i4 {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc((var(--profile-slide-widthSP) * -4) + (var(--profile-slide-gapSP) * -4)));
  }
}
.works_slide {
  margin-top: 64px;
}
.works_slide_in {
  display: flex;
  gap: 0 var(--profile-slide-gap);
  width: calc((var(--profile-slide-width) * 15) + (var(--profile-slide-gap) * 15));
}
.works_slide_in.i4 {
  display: flex;
  gap: 0 var(--profile-slide-gap);
  width: calc((var(--profile-slide-width) * 12) + (var(--profile-slide-gap) * 12));
}
.works_slide_item {
  width: var(--profile-slide-width);
  height: 210px;
  overflow: clip;
}
.works_slide_item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media all and (min-width: 681px) {
  .works_slide_in {
    animation: scrollSlide1 30s linear infinite;
  }
  .works_slide_in.i4 {
    animation: scrollSlide1_i4 24s linear infinite;
  }
}
@media all and (max-width: 680px) {
  .works_slide {
    margin-top: 30px;
  }
  .works_slide_in {
    gap: 0 var(--profile-slide-gapSP);
    width: calc((var(--profile-slide-widthSP) * 15) + (var(--profile-slide-gapSP) * 15));
    animation: scrollSlide1SP 24s linear infinite;
  }
  .works_slide_in.i4 {
    gap: 0 var(--profile-slide-gapSP);
    width: calc((var(--profile-slide-widthSP) * 12) + (var(--profile-slide-gapSP) * 12));
    animation: scrollSlide1SP 21.6s linear infinite;
  }
  .works_slide_item {
    width: var(--profile-slide-widthSP);
    height: 137px;
  }
}
@media all and (max-width: 370px) {
}

/* promise
***************************************************************/
.promise {
  width: 100%;
  height: 730px;
  background: no-repeat center / cover;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}
.promise_tit {
  font-size: 34px;
  font-weight: 500;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: calc(60 / 34);
  padding-bottom: 26px;
  position: relative;
}
.promise_tit::after {
  content: "";
  width: 52px;
  height: 3px;
  background-color: #fff;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
.promise_txt {
  font-size: 17px;
  font-weight: 400;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: calc(42.5 / 17);
  margin-top: 45px;
}
@media all and (min-width: 681px) {
  .promise {
    background-image: url(../../img/kominka/promise_bg1.jpg);
  }
}
@media all and (max-width: 680px) {
  .promise {
    height: auto;
    background-image: url(../../img/kominka/promise_bg1_sp.jpg);
    display: block;
    padding: 60px 34px;
  }
  .promise_tit {
    font-size: 22px;
    letter-spacing: 0.05em;
    line-height: calc(40 / 22);
    padding-bottom: 20px;
  }
  .promise_tit::after {
    width: 40px;
    height: 2px;
  }
  .promise_txt {
    font-size: 15px;
    text-align: justify;
    letter-spacing: 0.05em;
    line-height: calc(30 / 15);
    margin-top: 24px;
  }
}
@media all and (max-width: 370px) {
}

/* flow
***************************************************************/
.flow {
  background-color: #f8f8f8;
  padding: 150px 0 134px;
}
.flow_tit {
  font-size: 30px;
  font-weight: 500;
  text-align: center;
  letter-spacing: 0.1em;
}
.flow_txt {
  font-size: 20px;
  font-weight: 500;
  text-align: center;
  letter-spacing: 0.1em;
  margin-top: 10px;
}
.flow_list1 {
  padding-top: 80px;
  width: 930px;
  margin: 0 auto;
}
.flow_list1 .li1 {
  position: relative;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px;
}
.flow_list1 .li1 + .li1 {
  margin-top: 40px;
}
.flow_list1 .li1 + .li1::after {
  content: "";
  background-color: #908679;
  width: 3px;
  height: 40px;
  position: absolute;
  top: -40px;
  left: 0;
  right: 0;
  margin: auto;
}
.flow_list1_tit {
  display: flex;
  align-items: center;
  gap: 0 34px;
  padding-left: 54px;
}
.flow_list1_tit .num {
  color: #908679;
  font-size: 70px;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1;
}
.flow_list1_tit .tit {
  font-size: 26px;
  font-weight: 500;
  letter-spacing: 0.05em;
}
.flow_list1_img {
  width: 356px;
}
@media all and (min-width: 681px) {
}
@media all and (max-width: 680px) {
  .flow {
    padding: 60px 0;
  }
  .flow_tit {
    font-size: 22px;
    line-height: calc(37.4 / 22);
  }
  .flow_txt {
    font-size: 16px;
    margin-top: 5px;
  }
  .flow_list1 {
    padding: 40px 15px 0;
    width: 100%;
  }
  .flow_list1 .li1 {
    padding: 12px;
    display: block;
  }
  .flow_list1 .li1 + .li1 {
    margin-top: 30px;
  }
  .flow_list1 .li1 + .li1::after {
    width: 2px;
    height: 30px;
    top: -30px;
  }
  .flow_list1_tit {
    padding-left: 8px;
    padding-top: 6px;
    gap: 0 10px;
  }
  .flow_list1_tit .num {
    font-size: 33px;
  }
  .flow_list1_tit .tit {
    font-size: 18px;
  }
  .flow_list1_img {
    width: 100%;
    margin-top: 10px;
  }
}
@media all and (max-width: 370px) {
}

/* house
***************************************************************/
.house {
  background-color: #f4eee7;
  padding: 120px 0 95px;
  overflow: clip;
}
.house_lead {
  font-size: 20px;
  font-weight: 500;
  text-align: center;
  letter-spacing: 0.1em;
  margin-bottom: 24px;
}
.house_tit {
  font-size: 34px;
  font-weight: 500;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: calc(60 / 34);
  padding-bottom: 26px;
  position: relative;
}
.house_tit::after {
  content: "";
  width: 52px;
  height: 3px;
  background-color: #908679;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
.house_txt {
  margin-top: 35px;
  margin-bottom: 75px;
  font-size: 17px;
  font-weight: 400;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: calc(42.5 / 17);
}
:root {
  --house-slide-width: 537px;
  --house-slide-gap: 10px;
  --house-slide-widthSP: 222px;
  --house-slide-gapSP: 10px;
}
@keyframes house_scrollSlide1 {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc((var(--house-slide-width) * -4) + (var(--house-slide-gap) * -4)));
  }
}
@keyframes house_scrollSlide1SP {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc((var(--house-slide-widthSP) * -4) + (var(--house-slide-gapSP) * -4)));
  }
}
@keyframes house_scrollSlide1_rev {
  0% {
    /* transform: translateX(calc((var(--house-slide-width) * -4) + (var(--house-slide-gap) * -4))); */
    transform: translateX(calc((var(--house-slide-width) * -3) + (var(--house-slide-gap) * -3)));
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes house_scrollSlide1SP_rev {
  0% {
    /* transform: translateX(calc((var(--house-slide-widthSP) * -4) + (var(--house-slide-gapSP) * -4))); */
    transform: translateX(calc((var(--house-slide-widthSP) * -3) + (var(--house-slide-gapSP) * -3)));
  }
  100% {
    transform: translateX(0);
  }
}
.house_slide + .house_slide {
  margin-top: 10px;
}
.house_slide_in {
  display: flex;
  gap: 0 var(--house-slide-gap);
  width: calc((var(--house-slide-width) * 12) + (var(--house-slide-gap) * 12));
}
.house_slide_in.i3 {
  display: flex;
  gap: 0 var(--house-slide-gap);
  width: calc((var(--house-slide-width) * 9) + (var(--house-slide-gap) * 9));
}
.house_slide_item {
  width: var(--house-slide-width);
  height: 353px;
  overflow: clip;
}
.house_slide_item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media all and (min-width: 681px) {
  .house_slide_in {
    animation: house_scrollSlide1 35s linear infinite;
  }
  .rev .house_slide_in {
    /* animation: house_scrollSlide1_rev 35s linear infinite; */
    animation: house_scrollSlide1_rev 26.25s linear infinite;
  }
}
@media all and (max-width: 680px) {
  .house {
    padding: 60px 0 55px;
  }
  .house_lead {
    font-size: 15px;
    margin-bottom: 6px;
  }
  .house_tit {
    font-size: 20px;
    letter-spacing: 0;
    line-height: calc(30 / 20);
    padding-bottom: 22px;
  }
  .house_tit::after {
    width: 40px;
    height: 2px;
  }
  .house_txt {
    margin-top: 25px;
    margin-bottom: 30px;
    font-size: 15px;
    text-align: justify;
    letter-spacing: 0.06em;
    line-height: calc(30 / 15);
    padding: 0 34px;
  }
  .house_slide + .house_slide {
    margin-top: 10px;
  }
  .house_slide_in {
    gap: 0 var(--house-slide-gapSP);
    width: calc((var(--house-slide-widthSP) * 12) + (var(--house-slide-gapSP) * 12));
    animation: house_scrollSlide1SP 24s linear infinite;
  }
  .house_slide_in.i3 {
    gap: 0 var(--house-slide-gapSP);
    width: calc((var(--house-slide-widthSP) * 9) + (var(--house-slide-gapSP) * 9));
  }
  .rev .house_slide_in {
    /* animation: house_scrollSlide1SP_rev 24s linear infinite; */
    animation: house_scrollSlide1SP_rev 18s linear infinite;
  }
  .house_slide_item {
    width: var(--house-slide-widthSP);
    height: 146px;
  }
}
@media all and (max-width: 370px) {
}

/* コンテンツ
***************************************************************/
@media all and (min-width: 681px) {
}
@media all and (max-width: 680px) {
}
@media all and (max-width: 370px) {
}
