@charset "UTF-8";
/* ----------------------------------------------------
ボタン
-----------------------------------------------------*/
.sq-btn a {
  position: relative;
  display: inline-block;
  padding-block: min(3vw, 8px);
  padding-left: min(4vw, 15px);
  padding-right: min(8vw, 35px);
  background-color: #FFFFFF;
  border: 1px solid var(--color-text);
  transition: background-color 0.3s ease;
}
.sq-btn a::after {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f105";
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translate(0, -50%);
}
.sq-btn a:hover {
  background-color: var(--color-dark-gray);
  color: #FFFFFF;
}
.sq-btn a .obl::after {
  content: "";
  display: inline-block;
  width: min(3vw, 15px);
  height: min(3vw, 15px);
  background: url("../../../common/images/ic_obl.svg") no-repeat center center/cover;
  margin-left: min(1vw, 5px);
}
.sq-btn a:hover .obl::after {
  background: url("../../../common/images/ic_obl_w.svg") no-repeat center center/cover;
}

.sq-gray-btn a {
  position: relative;
  display: inline-block;
  padding-block: min(3vw, 8px);
  padding-left: min(4vw, 15px);
  padding-right: min(8vw, 35px);
  color: #FFFFFF;
  background-color: #6E6E6E;
  border: 1px solid #6E6E6E;
  transition: background-color 0.3s ease;
}
.sq-gray-btn a::after {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f105";
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translate(0, -50%);
}
.sq-gray-btn a:hover {
  background-color: #333333;
}
.sq-gray-btn a .obl::after {
  content: "";
  display: inline-block;
  width: min(3vw, 15px);
  height: min(3vw, 15px);
  background: url("../../../common/images/ic_obl_w.svg") no-repeat center center/cover;
  margin-left: min(1vw, 5px);
}

.sq-green-btn a {
  position: relative;
  display: inline-block;
  padding-block: min(3vw, 8px);
  padding-left: min(4vw, 15px);
  padding-right: min(8vw, 35px);
  color: #FFFFFF;
  background-color: #848E60;
  border: 1px solid #848E60;
  transition: background-color 0.3s ease;
}
.sq-green-btn a::after {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f105";
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translate(0, -50%);
}
.sq-green-btn a:hover {
  background-color: #657726;
}
.sq-green-btn a .obl::after {
  content: "";
  display: inline-block;
  width: min(3vw, 15px);
  height: min(3vw, 15px);
  background: url("../../../common/images/ic_obl_w.svg") no-repeat center center/cover;
  margin-left: min(1vw, 5px);
}

/* ----------------------------------------------------
kv
-----------------------------------------------------*/
.fl-kv {
  position: relative;
}
@media screen and (max-width: 767px) {
  .fl-kv {
    background: url(../images/kv.png) no-repeat center center/cover;
    padding-block: 7vw;
  }
}
@media screen and (max-width: 767px) {
  .fl-kv img {
    display: none;
  }
}
.fl-kv__inner {
  width: 100%;
  max-width: 1260px;
  margin-inline: auto;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: grid;
  justify-content: end;
}
@media screen and (max-width: 767px) {
  .fl-kv__inner {
    justify-content: center;
    position: static;
    top: 0;
    left: 0;
    transform: translate(0, 0);
  }
}
.fl-kv__textblock {
  text-align: left;
  background: rgba(255, 255, 255, 0.7);
  padding: min(5vw, 30px);
  margin-right: min(5vw, 30px);
  font-size: min(3vw, 1.8rem);
}
@media screen and (max-width: 767px) {
  .fl-kv__textblock {
    margin-right: 0;
    padding-block: 5vw;
  }
}
.fl-kv__textblock h3 {
  font-size: min(4.4vw, 3.2rem);
}

/* ----------------------------------------------------
製品一覧アンカーリンク
-----------------------------------------------------*/
.prod-anchor a:hover {
  text-decoration: underline;
}
.prod-anchor__title {
  font-size: min(5vw, 2.4rem);
  font-weight: 700;
  text-align: center;
  background-color: #EAEAEA;
  padding: min(4vw, 2rem);
}
.prod-anchor__body {
  background-color: #F2F2F2;
  padding: min(10vw, 3rem);
  display: grid;
  gap: min(10vw, 3rem);
}
.prod-anchor__cat h4 {
  display: flex;
  font-size: min(4.8vw, 2rem);
  font-weight: 700;
  margin-bottom: min(3vw, 1.5rem);
}
.prod-anchor__cat h4 img {
  margin-left: min(3vw, 1rem);
}
.prod-anchor__method {
  padding-left: min(2vw, 2rem);
}
.prod-anchor__method-wrap {
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: min(10vw, 4rem);
       column-gap: min(10vw, 4rem);
  row-gap: min(6vw, 2rem);
}
.prod-anchor__method--name {
  font-weight: 700;
  margin-bottom: min(1vw, 0.3rem);
}
.prod-anchor__method--name img {
  margin-bottom: min(1vw, 1.8rem);
  margin-right: min(2vw, 0.6rem);
}
.prod-anchor__method ul {
  padding-left: min(2vw, 2.2rem);
  display: grid;
  row-gap: min(3vw, 0.8rem);
}
.prod-anchor__method ul li {
  display: flex;
}
.prod-anchor__method ul li::before {
  content: url("../images/ic_triangle.svg");
  display: block;
  margin-right: min(3vw, 0.5rem);
}

/* ----------------------------------------------------
おすすめコンテンツリンク
-----------------------------------------------------*/
.prod-rec {
  background-color: #F2F2F2;
}
.prod-rec a:hover {
  text-decoration: underline;
}
.prod-rec__inner {
  background-color: #F2F2F2;
  border-top: 1px solid #FFFFFF;
  padding-bottom: min(15vw, 7rem);
  padding-top: min(10vw, 5rem);
  padding-inline: min(10vw, 3rem);
  margin-inline: min(10vw, 3rem);
}
@media screen and (max-width: 767px) {
  .prod-rec__inner {
    margin-inline: 0;
  }
}
.prod-rec__title {
  font-size: min(5vw, 2.6rem);
  font-weight: 700;
  text-align: center;
  margin-bottom: min(6vw, 3rem);
}
.prod-rec ul {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  -moz-column-gap: min(10vw, 3rem);
       column-gap: min(10vw, 3rem);
  row-gap: min(3vw, 0.8rem);
}
@media screen and (max-width: 767px) {
  .prod-rec ul {
    display: grid;
  }
}
.prod-rec ul li {
  display: flex;
}
.prod-rec ul li::before {
  content: url("../images/ic_triangle.svg");
  display: block;
  margin-right: min(3vw, 0.5rem);
}

/* ----------------------------------------------------
おすすめ製品
-----------------------------------------------------*/
.rec-prod {
  background-color: #F4F4F4;
  overflow: hidden;
  padding-top: min(10vw, 80px);
  padding-bottom: min(10vw, 40px);
}
@media screen and (max-width: 1320px) {
  .rec-prod {
    padding-inline: 40px;
  }
}
@media screen and (max-width: 767px) {
  .rec-prod {
    padding-inline: 20px;
  }
}
.rec-prod__swipwrap {
  position: relative;
  width: 100%;
  margin-inline: auto;
  max-width: 1200px;
}
.rec-prod__swiper {
  overflow: hidden;
}
.rec-prod__list {
  display: flex;
  row-gap: 5px;
  padding-bottom: min(10vw, 50px);
}
@media screen and (max-width: 767px) {
  .rec-prod__list {
    -moz-column-gap: 0;
         column-gap: 0;
  }
}
.rec-prod__card--img {
  text-align: center;
  margin-bottom: min(5vw, 1.5rem);
}
.rec-prod__card--img img {
  width: 100%;
}
.rec-prod__card--name {
  font-size: 2.2rem;
  font-weight: 700;
  margin-bottom: min(5vw, 1.2rem);
}
.rec-prod__card--text {
  line-height: 1.8;
  margin-bottom: min(5vw, 2rem);
}
.rec-prod__card--btn {
  display: grid;
  justify-content: center;
}
.rec-prod .swiper-button-next {
  color: var(--color-dark-gray);
  top: 40%;
  right: -50px;
}
@media screen and (max-width: 1200px) {
  .rec-prod .swiper-button-next {
    right: -30px;
  }
}
@media screen and (max-width: 767px) {
  .rec-prod .swiper-button-next {
    right: -25px;
  }
}
.rec-prod .swiper-button-prev {
  color: var(--color-dark-gray);
  top: 40%;
  left: -50px;
}
@media screen and (max-width: 1200px) {
  .rec-prod .swiper-button-prev {
    left: -30px;
  }
}
@media screen and (max-width: 767px) {
  .rec-prod .swiper-button-prev {
    left: -25px;
  }
}
.rec-prod .swiper-pagination {
  bottom: 0;
}
.rec-prod .swiper-pagination-bullet {
  width: min(3vw, 12px);
  height: min(3vw, 12px);
  margin-inline: min(3vw, 8px) !important;
}
.rec-prod .swiper-pagination-bullet-active {
  background-color: var(--color-dark-gray);
}

/* ----------------------------------------------------
製品一覧
-----------------------------------------------------*/
.prodlist-method--title {
  font-size: min(5vw, 2.4rem);
  font-weight: 700;
  color: #969696;
  margin-bottom: min(7vw, 30px);
}
.prodlist-block--title {
  font-size: min(4.4vw, 3.2rem);
  padding-bottom: min(3vw, 10px);
  border-bottom: var(--color-text) 1px solid;
  margin-bottom: min(7vw, 40px);
}
.prodlist-block__card--mainimg img {
  width: 100%;
}
.prodlist-block__card--mainimg figure {
  text-align: center;
}
.prodlist-block__card--mainimg p {
  text-align: left;
  font-weight: 700;
}
.prodlist-block__card--mainimg ul {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(65px, 1fr));
  gap: min(3vw, 0.9rem);
}
@media screen and (max-width: 767px) {
  .prodlist-block__card--mainimg ul {
    grid-template-columns: repeat(auto-fill, minmax(65px, 1fr));
  }
}
.prodlist-block__card--name {
  font-size: min(5vw, 2.4rem);
  font-weight: 700;
  color: #696767;
}
.prodlist-block__card--price {
  color: var(--color-gray);
}
.prodlist-block__card--data {
  background-color: #EAE8E8;
  padding: min(3vw, 20px);
}
.prodlist-block__card--appeal {
  display: flex;
  flex-wrap: wrap;
  gap: min(2vw, 10px);
}
.prodlist-block__card--appeal p {
  font-size: min(3.2vw, 1.3rem);
  border-radius: 50px;
  display: inline-block;
  padding-block: min(1vw, 6px);
  padding-inline: min(3vw, 20px);
  background-color: #CCCCCC;
}
.prodlist-block__card--datalink {
  display: grid;
  row-gap: min(3vw, 10px);
}
.prodlist-block__card--datalink-title {
  font-weight: 700;
  margin-bottom: min(3vw, 0.5rem);
}
.prodlist-block__list-or {
  display: grid;
  grid-template-columns: 1fr;
  -moz-column-gap: min(4vw, 30px);
       column-gap: min(4vw, 30px);
  row-gap: min(10vw, 60px);
}
.prodlist-block__list-or .prodlist-block__card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  -moz-column-gap: min(4vw, 30px);
       column-gap: min(4vw, 30px);
}
@media screen and (max-width: 960px) {
  .prodlist-block__list-or .prodlist-block__card {
    -moz-column-gap: min(3vw, 20px);
         column-gap: min(3vw, 20px);
  }
}
@media screen and (max-width: 767px) {
  .prodlist-block__list-or .prodlist-block__card {
    grid-template-columns: 1fr;
  }
}
.prodlist-block__list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
  -moz-column-gap: min(4vw, 30px);
       column-gap: min(4vw, 30px);
  row-gap: min(10vw, 60px);
}
@media screen and (max-width: 960px) {
  .prodlist-block__list {
    -moz-column-gap: min(3vw, 20px);
         column-gap: min(3vw, 20px);
  }
}
@media screen and (max-width: 767px) {
  .prodlist-block__list {
    grid-template-columns: 1fr;
    -moz-column-gap: min(3vw, 20px);
         column-gap: min(3vw, 20px);
  }
}
.prodlist-block__list .prodlist-block__card--name {
  font-size: min(4.6vw, 2rem);
}

/* ----------------------------------------------------
おすすめコンテンツ
-----------------------------------------------------*/
.rec-cont__catch {
  text-align: center;
  font-size: min(5.2vw, 3.8rem);
}
.rec-cont__body {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(5vw, 2.5rem);
}
@media screen and (max-width: 767px) {
  .rec-cont__body {
    grid-template-columns: 1fr;
  }
}
.rec-cont__card--img {
  margin-bottom: min(6vw, 1.5rem);
}
.rec-cont__card--img img {
  width: 100%;
}
.rec-cont__card--name {
  text-align: center;
  font-size: min(5vw, 2.2rem);
  font-weight: 700;
  margin-bottom: min(2vw, 1rem);
}
.rec-cont__card--desc {
  font-size: min(3.6vw, 1.5rem);
  margin-bottom: min(6vw, 1.5rem);
}
.rec-cont__card--prod {
  background-color: #EAE8E8;
  padding: min(6vw, 2.5rem);
}
.rec-cont__card--prod-title {
  font-weight: 700;
  padding-bottom: min(1vw, 0.8rem);
}
.rec-cont__card--prod li {
  display: flex;
}
.rec-cont__card--prod li::before {
  content: url("../images/ic_triangle.svg");
  display: block;
  margin-right: min(3vw, 0.5rem);
}
.rec-cont__card--prod li a:hover {
  text-decoration: underline;
}

/* ----------------------------------------------------
バナーエリア
-----------------------------------------------------*/
.banner {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
  -moz-column-gap: min(5vw, 2.5rem);
       column-gap: min(5vw, 2.5rem);
  row-gap: min(6vw, 4rem);
}
@media screen and (max-width: 900px) {
  .banner {
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  }
}
.banner dt img {
  width: 100%;
}
.banner dd {
  margin-top: min(3vw, 1rem);
}

/* ----------------------------------------------------
追従ボタン
-----------------------------------------------------*/
.follow-btn {
  background-color: #E4EDEA;
  padding-block: 2rem;
  padding-inline: 1.5rem 2rem;
  border-top-right-radius: 1rem;
  border-bottom-right-radius: 1rem;
  transition: all 0.3s ease;
  position: fixed;
  left: 0;
  bottom: 10rem;
  z-index: 1;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.follow-btn span {
  margin-left: min(0.5vw, 1rem);
  display: inline-block;
  text-align: center;
  line-height: min(2vw, 3.3rem);
  width: min(2vw, 3.3rem);
  height: min(2vw, 3.3rem);
  background-color: #FFFFFF;
  border-radius: 50%;
}
.follow-btn:hover {
  background-color: #BFD8D0;
}
.follow-btn.show {
  opacity: 1;
  visibility: visible;
}/*# sourceMappingURL=flooring.css.map */