@charset 'utf-8';

/* ==========================================================================

	森から始まる純国産バレルサウナ

   ========================================================================== */


/*--------------------------------
	基本レイアウト
--------------------------------*/

.second_visual {
  background: url(../images/main.jpg) no-repeat center;
  background-size: cover;
  height: 450px;
}

.second_visual h1 img {
  width: 340px;
  height: auto;
  margin: 0 auto 2rem;
}

.inner {
  padding-top: 0;
  padding-bottom: 0;
}
.inner + .inner {
  margin-top: 5em;
}

@media only screen and (max-width: 812px) {
  .second_visual {
    background: url(../images/main_sp.jpg) no-repeat center;
    background-size: cover;
  }

  .second_visual h1 img {
    width: 200px;
    height: auto;
  }

  .second_visual h1 em {
    font-size: 1.8rem;
  }

}

.heading_gr1 b {
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: normal;
  width: 50px;
  height: 50px;
  border: 1px solid #000;
  margin: 0 auto 2rem;
}
.heading_gr1 i {
  display: block;
  font-size: 75%;
  font-style: normal;
}

@media only screen and (max-width: 812px) {
  .heading_gr1 b {
    width: 40px;
    height: 40px;
    margin: 0 auto 1rem;
  }
}

.text_box {
  max-width: 800px;
  margin: 0 auto 5em;
}
.text_box p + p {
  margin-top: 2em;
}

.text_box .explain {
  background-color: #f1f0e9;
  padding: 3em;
  margin-top: 3em;
  border-radius: 20px;
}

.text_box .explain strong {
  display: block;
  font-weight: bold;
  margin-bottom: 1em;
}

.text_box .explain p {
  font-size: 95%;
}

.text_box .explain img {
  width: 100%;
  margin: 2em auto 0;
}

@media only screen and (max-width: 812px) {
  .text_box {
    margin: 0 auto 3em;
  }
  .text_box p + p {
    margin-top: 1.5em;
  }

  .text_box .explain {
    padding: 2em;
    margin-top: 2em;
    border-radius: 10px;
  }

}

.img_box {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.img_box img {
  width: 50%;
}
.img_box_caption {
  text-align: center;
  font-size: 85%;
  margin-top: 1em;
}

@media only screen and (max-width: 812px) {
  .img_box {
    display: block;
  }
  .img_box img {
    width: 100%;
  }
  .img_box img + img{
    margin-top: 1em;
  }
}

.heading_product {
  font-size: 3rem;
  text-align: center;
  font-weight: bold;
  border-top: 2px solid #000;
  padding-top: 1em;
  margin-bottom: 3em;
}

.heading_product span {
  display: block;
  font-size: 75%;
  margin-top: 0.3em;
}

@media only screen and (max-width: 812px) {
  .heading_product {
    font-size: 2.4rem;
    padding-top: 0.5em;
    margin-bottom: 2em;
  }
}


.column_box {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 5%;
}
.column_box + .column_box,
.img_box + .column_box,
.column_box + .img_box {
  margin-top: 7em;
}

.column_box + .img_box img {
  width: 100%;
}

.column_box > div:first-child {
  width: 45%;
}

.column_box > div:last-child {
  width: 50%;
}

@media only screen and (max-width: 812px) {
  .column_box {
    display: block;
  }
  .column_box + .column_box,
  .img_box + .column_box,
  .column_box + .img_box {
    margin-top: 4em;
  }
  .column_box > div:first-child {
    width: 100%;
  }
  .column_box > div:last-child {
    width: 100%;
    margin-top: 2em;
  }
}

.price_table {
  width: 100%;
  font-size: 2.2rem;
  font-weight: bold;
  margin: 0 auto 3rem;
}
.price_table > div {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 0.5em;
}
.price_table > div dt {
  width: 5em;
  margin-right: 1em;
}
.price_table > div dd {
  width: calc(100% - 6em);
}
.price_table > div dd small {
  display: block;
  font-weight: normal;
  font-size: 1.2rem;
}

@media only screen and (max-width: 812px) {
  .price_table {
    font-size: 1.8rem;
    margin: 0 auto 2rem;
  }
  .price_table > div dt {
    width: 4em;
  }
  .price_table > div dd {
    width: calc(100% - 5em);
  }
  .price_table > div dd small {
    font-size: 1.1rem;
  }
}

.spec_table {
  width: 100%;
  font-size: 1.5rem;
  margin: 0 auto;
}
.spec_table > div {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 0.5em;
}
.spec_table > div.no-column {
  display: block;
  margin-bottom: 1.5em;
}
.spec_table > div dt {
  width: 4em;
  margin-right: 1em;
}
.spec_table > div dd {
  width: calc(100% - 5em);
}

.detail_table {
  width: 100%;
  font-size: 2.2rem;
  font-weight: bold;
  margin: 0 auto 3rem;
}

@media only screen and (max-width: 812px) {
  .spec_table {
    font-size: 1.4rem;
  }
  .spec_table > div.no-column {
    margin-bottom: 0.5em;
  }
  .detail_table {
    font-size: 1.8rem;
  }
}

.flow_wrap {
  max-width: 900px;
  margin: 0 auto;
}

.flow_wrap .flow_box {
  position: relative;
  padding: 30px;
  background: #f1f0e9;
  text-align: center;
  -webkit-border-radius: 5px;
  border-radius: 5px;
}

.flow_wrap .flow_box:nth-of-type(n+2) {
  margin-top: 100px;
}

.flow_wrap .flow_box:nth-of-type(n+2)::after {
  content: "";
  display: block;
  width: 26px;
  height: 43px;
  background: url(../images/arrow_flow.svg) no-repeat center;
  background-size: contain;
  position: absolute;
  top: -75px;
  left: calc(50% - 13px);
}

.flow_wrap .flow_box strong {
  display: block;
  font-size: 2.0rem;
  font-weight: normal;
}

.flow_wrap + .link_btn {
  margin: 6em auto 0;
  width: 500px;
  font-size: 2.2rem;
  text-align: center;
}

.flow_wrap + .link_btn a {
    height: 90px;
    padding: 0 8px 0 40px;
    -webkit-border-radius: 6px;
    border-radius:  6px;
}

@media only screen and (max-width: 812px) {

  .flow_wrap .flow_box {
    padding: 20px 3%;
  }
  .flow_wrap .flow_box:nth-of-type(n+2) {
    margin-top: 40px;
  }
  .flow_wrap .flow_box:nth-of-type(n+2)::after {
    width: 13px;
    height: 22px;
    top: -32px;
    left: calc(50% - 6px);
  }
  .flow_wrap .flow_box strong {
    margin-bottom: .3em;
    font-size: 1.6rem;
  }

  .flow_wrap + .link_btn {
    margin:4em auto 0;
    width: 100%;
    font-size: 1.6rem;
  }

  .flow_wrap + .link_btn a {
    height: 50px;
    padding: 0 8px 0 15px;
    -webkit-border-radius: 3px;
    border-radius:  3px;
  }
}