@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
/* リセットcss
========================================================================== */
p {
  margin: 0;
}

.pc {
  display: block;
}
@media only screen and (max-width: 849px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}
@media only screen and (max-width: 849px) {
  .sp {
    display: block;
  }
}

/* common css
========================================================================== */
.post {
  padding-bottom: 70px;
}
@media only screen and (max-width: 849px) {
  .post {
    padding-bottom: 10.6666666667vw;
  }
}
.post .inner {
  max-width: 1080px;
  width: 100%;
  padding: 0 36px;
  margin: 0 auto;
}
@media only screen and (max-width: 849px) {
  .post .inner {
    max-width: 100vw;
    padding: 0 4.5333333333vw;
  }
}
.post img {
  vertical-align: bottom;
}

:root {
  --theme-color: #825538;
  --bg-color-dark: #F5F3E0;
  --bg-color-light: #F9F1D7;
}

/* main
========================================================================== */
.main {
  background-color: #fffcf8;
}
@media only screen and (max-width: 849px) {
  .main {
    margin-top: 86px;
  }
}

.mv {
  margin-bottom: 25px;
}
@media only screen and (max-width: 849px) {
  .mv {
    margin-bottom: 9.0666666667vw;
  }
}
.mv .inner {
  max-width: 1200px;
  margin: auto;
}
@media only screen and (max-width: 849px) {
  .mv .inner {
    max-width: 100vw;
    padding: 0 4.6666666667vw;
  }
}
.mv .mv_img_wrap {
  position: relative;
  background-image: url(../../../img/lifestyle/hiroba/03/mv_img_pc.jpg);
  background-position: top center;
  background-size: cover;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  width: 100vw;
  height: 514px;
}
@media only screen and (max-width: 849px) {
  .mv .mv_img_wrap {
    background-image: url(../../../img/lifestyle/hiroba/03/mv_img_sp.jpg);
    width: 100vw;
    height: auto;
  }
}
.mv .mv_img_wrap h1 {
  position: absolute;
  max-width: 944px;
  width: 100%;
  top: 118px;
  left: 50%;
  transform: translateX(-50%);
}
@media only screen and (max-width: 849px) {
  .mv .mv_img_wrap h1 {
    max-width: 100vw;
    top: 12.8vw;
    position: static;
    width: 100%;
    transform: translateX(0%);
  }
}

.intro {
  max-width: 806px;
  width: 100%;
  margin: 0 auto;
  padding-bottom: 63px;
  font-weight: 400;
}
@media only screen and (max-width: 849px) {
  .intro {
    padding-bottom: 12vw;
    padding-left: 4.5333333333vw;
    padding-right: 4.5333333333vw;
  }
}
.intro_txt {
  font-size: 18px;
  font-weight: 400;
  text-align: left;
  line-height: 2.2;
  color: #142020;
  letter-spacing: 0.04em;
}
@media only screen and (max-width: 849px) {
  .intro_txt {
    font-size: 3.7333333333vw;
    line-height: 1.66666667;
  }
}
.intro_txt + .intro_txt {
  padding-top: 38px;
}
@media only screen and (max-width: 849px) {
  .intro_txt + .intro_txt {
    padding-top: 6.4vw;
  }
}

.post_list {
  max-width: 840px;
  width: 100%;
  margin: 0 auto;
  padding: 0 20px 75px;
  display: flex;
  flex-direction: column;
  gap: 60px;
}
@media only screen and (max-width: 849px) {
  .post_list {
    max-width: 100%;
    padding: 0 10.9333333333vw 13.3333333333vw;
    gap: 18.6666666667vw;
  }
}
.post_list .post {
  max-width: 744px;
  width: 100%;
  margin: 0 auto;
  background-color: #fff;
  padding: 28px 25px 20px;
  font-size: 15px;
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 1.73333333;
  text-align: justify;
  border: 1px solid #000;
}
.post_list .post .postedBy {
  font-size: 15px;
}
.post_list .post.object01 {
  box-shadow: 5px 5px #7fcdd2;
}
@media only screen and (max-width: 849px) {
  .post_list .post.object01 {
    box-shadow: 1.3333333333vw 1.3333333333vw #7fcdd2;
  }
}
.post_list .post.object01::before {
  background-image: url(../../../img/lifestyle/hiroba/03/object01.png);
  width: 68px;
  height: 46px;
  display: block;
  content: "";
  position: absolute;
  top: -35px;
  left: 50%;
  transform: translate(-50%, 0%);
}
@media only screen and (max-width: 849px) {
  .post_list .post.object01::before {
    width: 13.6vw;
    height: 9.0666666667vw;
    top: -6.9333333333vw;
    background-size: cover;
  }
}
.post_list .post.object01 .postedBy {
  color: #0bb3b7;
}
.post_list .post.object02 {
  box-shadow: 5px 5px #90d283;
}
@media only screen and (max-width: 849px) {
  .post_list .post.object02 {
    box-shadow: 1.3333333333vw 1.3333333333vw #90d283;
  }
}
.post_list .post.object02::before {
  background-image: url(../../../img/lifestyle/hiroba/03/object02.png);
  width: 32px;
  height: 52px;
  display: block;
  content: "";
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translate(-50%, 0%);
}
@media only screen and (max-width: 849px) {
  .post_list .post.object02::before {
    width: 6.6666666667vw;
    height: 10.6666666667vw;
    top: -6.6666666667vw;
    background-size: cover;
  }
}
.post_list .post.object02 .postedBy {
  color: #2caa11;
}
@media only screen and (max-width: 849px) {
  .post_list .post {
    max-width: 74.6666666667vw;
    padding: 4vw 4.5333333333vw 4.8vw;
    font-size: 3.7333333333vw;
  }
}
.post_list .post .postedBy {
  font-weight: 500;
  line-height: 1;
  display: block;
  text-align: right;
  padding-top: 10px;
}
@media only screen and (max-width: 849px) {
  .post_list .post .postedBy {
    padding-top: 2.6666666667vw;
  }
}
.post_list .post.left {
  border-top: 6.5px solid #5693aa;
}
@media only screen and (max-width: 849px) {
  .post_list .post.left {
    border-top: 1.3333333333vw solid #5693aa;
  }
}
.post_list .post.left .postedBy {
  color: #ff8300;
}
.post_list .post.right {
  border-top: 6.5px solid #ebc14a;
  margin-inline: auto 0;
}
@media only screen and (max-width: 849px) {
  .post_list .post.right {
    border-top: 1.3333333333vw solid #ebc14a;
  }
}
.post_list .post.right .postedBy {
  color: #5693aa;
}
.post_list .post:has(.post_img) {
  display: flex;
  gap: 20px;
}
@media only screen and (max-width: 849px) {
  .post_list .post:has(.post_img) {
    flex-direction: column;
    gap: 2.9333333333vw;
  }
}
.post_list .post:has(.post_img) .post_img {
  max-width: 240px;
  width: 100%;
}
@media only screen and (max-width: 849px) {
  .post_list .post:has(.post_img) .post_img {
    max-width: 64vw;
    margin: 1.3333333333vw auto 0;
  }
}
.post_list .post:has(.post_img) .post_txt {
  max-width: 270px;
  width: 100%;
}
@media only screen and (max-width: 849px) {
  .post_list .post:has(.post_img) .post_txt {
    max-width: 100%;
  }
}

.closing {
  max-width: 768px;
  width: 100%;
  margin: 0 auto;
  padding: 34px 0px;
  border-top: 2px solid #5693aa;
  border-bottom: 2px solid #5693aa;
}
@media only screen and (max-width: 849px) {
  .closing {
    max-width: 84.5333333333vw;
    padding: 3.7333333333vw 0;
    border-top: 0.2666666667vw solid #5693aa;
    border-bottom: 0.2666666667vw solid #5693aa;
  }
}
.closing_txt {
  max-width: 418px;
  width: 100%;
  margin: 0 auto;
}
@media only screen and (max-width: 849px) {
  .closing_txt {
    max-width: 76.8vw;
  }
}
.closing_txt img {
  vertical-align: middle;
}

.sec_popular {
  margin-top: 0;
}

.l-footer {
  padding-top: 0;
}

.foot_box {
  padding: 40px 0;
  border-top: 2px solid #773d12;
  border-bottom: 2px solid #773d12;
  width: 100%;
  font-weight: 400;
  width: 600px;
  line-height: 1.72;
  margin: 0 auto;
  font-size: 18px;
  line-height: 1.72;
  text-align: center;
}
@media only screen and (max-width: 849px) {
  .foot_box {
    width: 84.5333333333vw;
    padding: 9.0666666667vw 0;
    font-size: 3.7333333333vw;
  }
}