@charset "UTF-8";
@media (min-width: 1200px) {
  .pc_none {
    display: none !important;
  }
}
@media (max-width: 520px) {
  .sp_none {
    display: none !important;
  }
}
/* まずはリセット */
* {
  margin: 0;
  padding: 0;
  color: #393939;
}

html {
  scroll-behavior: smooth;
}

.review_ichiran {
  position: relative;
  margin-top: 400px;
  opacity: 0;
  transform: translateY(50px);
  transition: all 1.3s 0s ease-out;
}
@media (min-width: 521px) {
  .review_ichiran {
    margin-top: 450px;
  }
}
.review_ichiran::before {
  content: "";
  position: absolute;
  top: -320px;
  left: 50%;
  transform: translateX(-50%);
  transform-origin: top;
  width: 1px;
  height: 240px;
  background: #58c3e0;
  transition: all 0.6s cubic-bezier(0.23, 1, 0.32, 1);
}
@media (min-width: 521px) {
  .review_ichiran::before {
    top: -360px;
  }
}
.review_ichiran .wrap {
  position: relative;
  background-color: #efefef;
  padding: 18vw 60px 16vw;
}
@media (min-width: 521px) {
  .review_ichiran .wrap {
    padding: clamp(100px, 100px + (180 - 100) * (100vw - 521px)/(1199 - 521), 180px) 60px clamp(80px, 80px + (120 - 80) * (100vw - 521px)/(1199 - 521), 120px);
  }
}
.review_ichiran .wrap h2 {
  position: absolute;
  top: -0.8em;
  left: 50%;
  transform: translateX(-50%);
  font-size: clamp(40px, 40px + (68 - 40) * (100vw - 320px)/(520 - 320), 68px);
  text-align: center;
  font-family: baskerville-display-pt, serif;
  width: 100%;
}
@media (min-width: 521px) {
  .review_ichiran .wrap h2 {
    font-size: clamp(68px, 68px + (128 - 68) * (100vw - 521px)/(1199 - 521), 128px);
  }
}
.review_ichiran .wrap .flex {
  max-width: 1600px;
  margin: 0 auto;
}
@media (min-width: 521px) {
  .review_ichiran .wrap .flex {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}
.review_ichiran .wrap .flex .item {
  position: relative;
  max-width: 600px;
  margin: 0 auto;
  background-color: #ffffff;
  pointer-events: none;
  opacity: 0;
  transform: translateY(80px);
  transition: all 0.8s 0s ease-out;
}
.review_ichiran .wrap .flex .item:not(:first-of-type) {
  margin-top: clamp(40px, 40px + (100 - 40) * (100vw - 320px)/(520 - 320), 100px);
}
@media (min-width: 1200px) {
  .review_ichiran .wrap .flex .item:nth-of-type(3n-2) {
    transition: all 0.8s 0.4s ease-out;
  }
}
@media (min-width: 1200px) {
  .review_ichiran .wrap .flex .item:nth-of-type(3n-1) {
    transition: all 0.8s 0.8s ease-out;
  }
}
@media (min-width: 1200px) {
  .review_ichiran .wrap .flex .item:nth-of-type(3n) {
    transition: all 0.8s 1.2s ease-out;
  }
}
@media (min-width: 1200px) {
  .review_ichiran .wrap .flex .item {
    width: calc((100% - 160px) / 3);
  }
  .review_ichiran .wrap .flex .item:nth-of-type(-n + 3) {
    margin-top: 0;
  }
}
.review_ichiran .wrap .flex .item:hover {
  box-shadow: 0 0 8px 8px #ffffff;
}
.review_ichiran .wrap .flex .item:hover .new {
  top: -50px;
  left: -50px;
}
@media (min-width: 521px) {
  .review_ichiran .wrap .flex .item:hover .img {
    margin-bottom: 2.5em;
  }
}
.review_ichiran .wrap .flex .item .new {
  position: absolute;
  top: -10px;
  left: -30px;
  z-index: 1;
  transition: all 0.3s;
}
.review_ichiran .wrap .flex .item .new img {
  width: 70px;
}
.review_ichiran .wrap .flex .item .img {
  position: relative;
  margin: 0 auto 1em;
  transition: all 0.3s;
}
.review_ichiran .wrap .flex .item .img a {
  transition: all 0.3s;
  pointer-events: auto;
}
.review_ichiran .wrap .flex .item .img a:hover img {
  transform: scale(1.2, 1.2);
}
.review_ichiran .wrap .flex .item .img a img {
  width: 100%;
  transition: all 0.3s;
}
.review_ichiran .wrap .flex .item .img a:hover ~ .opacity {
  transform: scale(1.2, 1.2);
  background-color: rgba(88, 195, 224, 0.8) !important;
  opacity: 1 !important;
}
.review_ichiran .wrap .flex .item .img .opacity {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 8px;
  display: flex;
  align-items: center;
  color: #ffffff;
  background-color: rgba(88, 195, 224, 0);
  text-shadow: 1px 1px 3px #393939;
  font-size: clamp(10px, 10px + (20 - 10) * (100vw - 320px)/(520 - 320), 20px);
  padding: clamp(20px, 20px + (40 - 20) * (100vw - 320px)/(520 - 320), 40px);
  opacity: 0;
  transition: all 0.3s;
}
@media (min-width: 521px) {
  .review_ichiran .wrap .flex .item .img .opacity {
    font-size: clamp(20px, 20px + (30 - 20) * (100vw - 521px)/(1199 - 521), 30px);
  }
}
@media (min-width: 1200px) {
  .review_ichiran .wrap .flex .item .img .opacity {
    font-size: clamp(16px, 16px + (30 - 16) * (100vw - 1200px)/(1920 - 1200), 30px);
  }
}
.review_ichiran .wrap .flex .item .time {
  letter-spacing: 0.05em;
  padding: 0 1rem 0.5rem;
}
@media (min-width: 521px) {
  .review_ichiran .wrap .flex .item .time {
    padding: 0 2rem 0.5rem;
  }
}
.review_ichiran .wrap .flex .item h3 {
  letter-spacing: 0.05em;
  padding: 0 1rem 1rem;
}
@media (min-width: 521px) {
  .review_ichiran .wrap .flex .item h3 {
    padding: 0 2rem 1rem;
  }
}
.review_ichiran .wrap .more {
  margin: 40px auto 0;
  text-align: right;
  max-width: 1600px;
}
.review_ichiran .wrap .more a {
  font-size: 18px;
  font-family: futura-pt, sans-serif;
  color: #58c3e0;
  text-decoration: underline;
  transition: all 0.3s;
}
.review_ichiran .wrap .more a:hover {
  opacity: 0.65;
}/*# sourceMappingURL=review_ichiran.css.map */