@charset "UTF-8";
/* SCSS Document */
/* 東リファブリックフロア | 施工例 */
/* 施工例固有 */
/* スニペット */
/* .c-nav__bredCrumb */
.c-nav__bredCrumb {
  margin-top: 5.33333vw;
}

@media only screen and (min-width: 768px) {
  .c-nav__bredCrumb {
    margin-top: 40px;
  }
}

/* .c-footer */
.c-footer {
  padding-top: 10.66667vw;
  padding-bottom: 5.33333vw;
}

@media only screen and (min-width: 768px) {
  .c-footer {
    padding-top: 64px;
  }
}

.p-gallery {
  position: relative;
  /*  */
}

.p-gallery.is_pop {
  width: 100%;
  height: 100vh;
  overflow: hidden;
}

.p-gallery.is_pop .c-btn__close {
  width: 13.86667vw;
  height: 13.86667vw;
  opacity: 1;
  transform: rotate(-45deg);
}

@media only screen and (min-width: 768px) {
  .p-gallery.is_pop .c-btn__close {
    width: 71px;
    height: 71px;
  }
}

@media only screen and (min-width: 768px) {
  .p-gallery.is_ie11 .c-gallery {
    justify-content: center;
  }
}

@media only screen and (min-width: 768px) {
  .p-gallery.is_ie11 .c-gallery__item {
    width: 309px;
  }
}

.p-gallery h1 {
  padding-top: 34.66667vw;
  text-align: center;
  font-size: 2.66667vw;
  font-weight: normal;
  line-height: 1.4;
  letter-spacing: 0.392vw;
  color: #221815;
}

@media only screen and (min-width: 768px) {
  .p-gallery h1 {
    width: 100%;
    margin: 0 auto;
    padding-top: 152px;
    font-size: 0.75rem;
    line-height: 1.3;
    letter-spacing: 0.11rem;
    transform-origin: top center;
    transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
    opacity: 0.01;
    transform: translateY(75px);
  }
}

.p-gallery h1.is_active {
  opacity: 1;
  transform: translateY(0);
}

.p-gallery h1 > span:nth-of-type(1) {
  font-family: "Libre Baskerville", serif;
  text-transform: uppercase;
  font-size: 290%;
  letter-spacing: 0.15467vw;
  font-weight: bold;
}

@media only screen and (min-width: 768px) {
  .p-gallery h1 > span:nth-of-type(1) {
    font-size: 350%;
    letter-spacing: 0.0525rem;
  }
}

.p-gallery h1 > span:nth-of-type(1):after {
  content: "\A";
  white-space: pre;
}

.p-gallery h1 > span:nth-of-type(2) {
  display: inline-block;
  vertical-align: bottom;
}

@media only screen and (min-width: 768px) {
  .p-gallery h1 > span:nth-of-type(2) {
    margin-top: 7px;
  }
}

.p-gallery h1 + p {
  margin-top: 8.26667vw;
  font-size: 4vw;
  line-height: 1.87;
  letter-spacing: 0.92vw;
  text-align: center;
}

@media only screen and (min-width: 768px) {
  .p-gallery h1 + p {
    width: 100%;
    margin-top: 46px;
    font-size: 1rem;
    line-height: 2.28;
    letter-spacing: 0.12rem;
    transform-origin: top center;
    transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
    opacity: 0.01;
    transform: translateY(75px);
  }
}

.p-gallery h1 + p.is_active {
  opacity: 1;
  transform: translateY(0);
}

.p-gallery h1 + p > span:before {
  content: "\A";
  white-space: pre;
}

@media only screen and (min-width: 768px) {
  .p-gallery h1 + p > span:before {
    content: none;
  }
}

.p-gallery p {
  letter-spacing: 0.26667vw;
}

@media only screen and (min-width: 768px) {
  .p-gallery p {
    letter-spacing: 0.14688rem;
  }
}

.p-gallery .c-main {
  width: 100%;
}

.p-gallery .c-page__contents {
  /**/
}

.p-gallery .c-gallery {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  width: 93.86667%;
  margin-top: 14.66667vw;
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-gallery {
    display: -ms-flexbox;
    -ms-flex-wrap: wrap;
    -ms-flex-align: start;
    display: grid;
    gap: 0;
    grid-template-columns: repeat(auto-fit, minmax(309px, 1fr));
    width: 90.48316%;
    margin-top: 68px;
  }
}

.p-gallery .c-gallery__item {
  width: 45.17045%;
  margin: 0 2.41477%;
  padding-bottom: 4.53333vw;
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-gallery__item {
    width: auto;
    margin: 0;
    padding-bottom: 30px;
  }
}

.p-gallery .c-gallery__itemImg {
  width: 100%;
  overflow: hidden;
  transform-origin: top center;
  transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
  opacity: 0.01;
  transform: translateY(75px);
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-gallery__itemImg {
    width: 93%;
  }
}

.p-gallery .c-gallery__itemImg.is_active {
  opacity: 1;
  transform: translateY(0);
}

.p-gallery .c-gallery__itemImg a:hover img {
  opacity: 1;
  transform: scale(1.2);
}

.p-gallery .c-gallery__itemImg img {
  transform-origin: center center;
  transition: transform .2s ease-in-out;
}

.p-gallery .c-gallery__itemImg.is_pop + .c-gallery__itemPop {
  position: fixed;
  z-index: 11;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-color: #fff;
  opacity: 1;
  overflow-y: auto;
}

.p-gallery .c-gallery__itemImg.is_pop + .c-gallery__itemPop .c-gallery__itemPop__contents {
  padding-top: 20.26667vw;
  transform: scale(1);
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-gallery__itemImg.is_pop + .c-gallery__itemPop .c-gallery__itemPop__contents {
    padding-top: 2.19619vw;
  }
}

.p-gallery .c-gallery__itemPop {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  height: 0;
  width: 0;
  opacity: 0.01;
  transition: opacity .2s ease;
}

.p-gallery .c-gallery__itemPop__contents {
  display: flex;
  flex-wrap: wrap;
  width: 89.33333%;
  transition: transform 0.2s ease-in .1s;
  transform: scale(0);
  transform-origin: center center;
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-gallery__itemPop__contents {
    align-items: center;
    width: 95.60761%;
    max-width: 1366px;
  }
}

.p-gallery .c-gallery__itemPop__contents > p {
  width: 100%;
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-gallery__itemPop__contents > p {
    width: 54.21133%;
  }
}

.p-gallery .c-gallery__itemPop__contents > div {
  width: 100%;
  margin-top: 9.33333vw;
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-gallery__itemPop__contents > div {
    width: 45.78867%;
    margin-top: 0;
  }
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-gallery__itemPop__contents > div > ul {
    margin-left: 11.03679%;
  }
}

.p-gallery .c-gallery__itemPop__contents > div > ul > li {
  font-size: 3.73333vw;
  letter-spacing: 0.448vw;
  line-height: 2.21;
  text-align: left;
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-gallery__itemPop__contents > div > ul > li {
    font-size: 1.375rem;
    letter-spacing: 0.165rem;
    line-height: 2.82;
  }
}

.p-gallery .c-gallery__itemPop__contents > div > ul > li a {
  text-decoration: underline;
}

.p-gallery .c-gallery__itemPop__contents > div > ul > li a:hover {
  text-decoration: none;
}

.p-gallery .c-gallery__itemPop__contents > div > ul > li .c-link__txt > span {
  margin-left: 0;
}

.p-gallery .c-btn__close {
  position: fixed;
  top: 2.66667vw;
  right: 2.66667vw;
  z-index: 12;
  display: flex;
  align-items: center;
  width: 0;
  height: 0;
  opacity: 0.01;
  transition: transform .2s ease-in-out, opacity .2s ease;
  cursor: pointer;
  overflow: hidden;
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-btn__close {
    top: 16px;
    right: 16px;
  }
}

.p-gallery .c-btn__close:before, .p-gallery .c-btn__close:after {
  position: absolute;
  content: "";
  display: block;
  background-color: #221815;
}

.p-gallery .c-btn__close:before {
  top: 49.03846%;
  left: 0;
  width: 100%;
  height: 1px;
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-btn__close:before {
    height: 2px;
  }
}

.p-gallery .c-btn__close:after {
  top: 0;
  left: 49.03846%;
  width: 1px;
  height: 100%;
}

@media only screen and (min-width: 768px) {
  .p-gallery .c-btn__close:after {
    width: 2px;
  }
}

.p-gallery .c-btn__close > span {
  margin: 0 auto;
  text-indent: 100%;
  overflow: hidden;
  white-space: nowrap;
}

/* コピーライト表示 */
.c-copyRights {
  margin: 26.66667vw 5.33333vw 0;
  transform-origin: top center;
  transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
  opacity: 0.01;
  transform: translateY(75px);
}

@media only screen and (min-width: 768px) {
  .c-copyRights {
    width: 100%;
    margin: 100px 80px 0;
  }
}

.c-copyRights.is_active {
  opacity: 1;
  transform: translateY(0);
}

.c-copyRights ul {
  width: 100%;
}

.c-copyRights ul li {
  margin-bottom: 1.86667vw;
  font-size: 2.66667vw;
  letter-spacing: 0.32vw;
  line-height: 1.4;
}

@media only screen and (min-width: 768px) {
  .c-copyRights ul li {
    margin-bottom: 10px;
    font-size: 0.625rem;
    letter-spacing: 0.075rem;
  }
}
