@charset "UTF-8";
.zen_antique {
  font-family: "Zen Antique", serif;
  font-weight: 400;
  font-style: normal;
}

.garamond {
  font-family: "garamond-premier-pro", serif;
  font-weight: 400;
  font-style: normal;
}

.montserrat {
  font-family: "Montserrat", serif;
  font-weight: 600;
}

.Palatino {
  font-family: "Palatino Linotype";
}

.weight400 {
  font-weight: 400 !important;
}

.text-c {
  text-align: center;
}

.text-r {
  text-align: right !important;
}

.att {
  margin-left: 1em;
  text-indent: -1em;
}

.arrow {
  position: absolute;
  top: 50%;
  right: 0;
  content: "";
  display: block;
  width: 26px;
  height: 10px;
  background: no-repeat 50%/cover url(../img/icon/arrow.svg);
  transform: translateY(-50%);
}

.arrow-wh {
  position: absolute;
  bottom: 35px;
  right: 35px;
  content: "";
  display: block;
  width: 49px;
  height: 10px;
  background: no-repeat 50%/cover url(../img/icon/arrow_wh.svg);
}

/*----------------------------------------------------------------------
ビジュアル
----------------------------------------------------------------------*/
.main-visual {
  position: relative;
  height: 100svh;
  margin-bottom: 110px;
}
.main-visual .photo_img {
  position: absolute;
  bottom: 30px;
  right: 3vw;
  z-index: -1;
  width: 80vw;
  border-radius: 10px;
}
.main-visual .photo_img:before {
  padding-top: calc(100svh - 143px);
}
.main-visual .photo_img img {
  border-radius: 10px;
}
.main-visual .mv-catch {
  position: absolute;
  top: 50%;
  left: 14vw;
  margin: auto;
  color: #2F77BE;
  transform: translateY(-50%);
}
.main-visual .mv-catch p {
  display: inline-block;
  font-size: max(2vw, 62px);
  line-height: 1.6;
  font-weight: 600;
}
.main-visual .mv-catch p span {
  padding: 0 10px;
  background: #fff;
}
.main-visual .mv-catch p span:last-child {
  margin-left: 4em;
}
.main-visual .video-frame {
  background: no-repeat 50%/cover url(../img/parts/mv_img.jpg);
}
.main-visual .video-frame:before {
  display: block;
  content: "";
  padding-top: calc(100svh - 100px);
}
@media screen and (max-width: 764px) {
  .main-visual {
    height: auto;
    margin-bottom: 80px;
  }
  .main-visual .photo_img {
    position: relative;
    bottom: auto;
    left: 10vw;
    margin-top: 80px;
    width: 85vw;
  }
  .main-visual .photo_img:before {
    padding-top: 140%;
  }
  .main-visual .mv-catch {
    left: 2vw;
  }
  .main-visual .mv-catch p {
    margin-bottom: 20px;
    font-size: max(2.6vw, 24px);
  }
}

/*----------------------------------------------------------------------
販売方針
----------------------------------------------------------------------*/
#sales {
  background: no-repeat 0 50%/cover url(../img/parts/bg01.svg);
}
#sales .col_3 {
  margin-bottom: 120px;
  padding-top: 20px;
}
@media screen and (max-width: 764px) {
  #sales {
    margin-bottom: 80px;
  }
}

/*----------------------------------------------------------------------
会社案内
----------------------------------------------------------------------*/
#about {
  position: relative;
  min-height: 100svh;
  margin-bottom: 80px;
}
#about:before {
  position: absolute;
  right: 0;
  z-index: -1;
  display: block;
  content: "";
  width: 55vw;
  height: 100%;
  background: no-repeat 0 50%/cover url(../img/parts/bg02.jpg);
}
#about .images {
  position: sticky;
  top: 0;
  bottom: 0;
  width: 50%;
  padding: 60px 0;
  height: 100svh;
}
#about .images .image_box .photo_img {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  margin: auto;
  width: 100%;
  visibility: hidden;
  opacity: 0;
  /* フェード速度 */
  transition: 0.8s;
  border-radius: 10px;
}
#about .images .image_box .photo_img img {
  border-radius: 10px;
}
#about .images .image_box .photo_img:before {
  padding-top: calc(100svh - 240px);
}
@media screen and (max-height: 730px) {
  #about .images .image_box .photo_img:before {
    padding-top: calc(100svh - 80px);
  }
}
#about .images .image_box .photo_img:first-child,
#about .images .image_box .photo_img.active {
  visibility: visible;
  opacity: 1;
}
#about .images .image_box .box01:before {
  padding-top: 90%;
}
#about .images .image_box .box02 img {
  top: 0;
  transform: translate(-50%, 0);
}
#about .content {
  width: 50%;
  padding-left: 60px;
}
#about .content article {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100svh;
}
#about .content h3 {
  margin-bottom: 60px;
}
#about .content .name {
  margin-bottom: 0;
  text-align: right;
  font-size: 14px;
  font-size: 0.875rem;
}
#about .box02_img {
  margin-bottom: 60px;
  border-radius: 10px;
}
#about .box02_img:before {
  padding-top: 130%;
}
#about .box02_img img {
  border-radius: 10px;
}
@media screen and (max-width: 764px) {
  #about {
    min-height: auto;
    margin-bottom: 0;
  }
  #about .images {
    position: static;
    width: 100%;
    height: 100%;
    margin-bottom: 40px;
    padding: 0;
  }
  #about .content {
    width: 100%;
    padding-left: 0;
  }
  #about .content figure {
    margin-bottom: 20px;
    border-radius: 10px;
  }
  #about .content figure img {
    border-radius: 10px;
  }
  #about .content article {
    margin-bottom: 60px;
    min-height: auto;
  }
  #about .content h3 {
    margin-bottom: 30px;
  }
}

/*----------------------------------------------------------------------
アクセス
----------------------------------------------------------------------*/
#access {
  position: relative;
  padding-bottom: 60px;
}
#access:before {
  position: absolute;
  z-index: -1;
  display: block;
  content: "";
  width: 40vw;
  height: 100%;
  background: no-repeat 0 50%/cover url(../img/parts/bg03.svg);
}
#access .col {
  margin-bottom: 60px;
  align-items: center;
}
#access .col:last-child {
  margin-bottom: 0;
}
#access .maps {
  width: 50%;
}
#access .maps .map iframe {
  height: calc(100svh - 240px);
  border-radius: 10px;
}
#access .content {
  width: 50%;
  padding-left: 60px;
}
#access .content h3 {
  margin-bottom: 20px;
}
#access address {
  font-size: 22px;
  font-size: 1.375rem;
  line-height: 2;
  font-style: normal;
}
@media screen and (max-width: 764px) {
  #access {
    min-height: 100%;
    padding: 0 0 40px;
  }
  #access:before {
    width: 80vw;
  }
  #access .maps {
    width: 100%;
  }
  #access .maps .map {
    margin-bottom: 20px;
  }
  #access .maps .map iframe {
    height: 460px;
  }
  #access .content {
    width: 100%;
    padding-left: 0;
  }
  #access address {
    font-size: 18px;
    font-size: 1.125rem;
    line-height: 2;
    font-style: normal;
  }
}

/*----------------------------------------------------------------------
お知らせ
----------------------------------------------------------------------*/
#news {
  padding: 120px 0;
}
#news .col {
  justify-content: space-between;
}
#news h2 {
  width: 220px;
}
#news .news_content {
  width: calc(100% - 220px);
}
#news .news_content article {
  margin-bottom: 22px;
  padding-bottom: 22px;
  border-bottom: 1px dotted #000;
}
#news .news_content article time {
  display: block;
  margin-bottom: 15px;
  color: #969696;
  font-size: 16px;
  font-size: 1rem;
}
#news .news_content article h3 {
  margin-bottom: 15px;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: 600;
}
@media screen and (max-width: 764px) {
  #news {
    padding: 60px 0;
  }
  #news h2 {
    width: 100%;
  }
  #news .news_content {
    width: 100%;
  }
}/*# sourceMappingURL=index.css.map */