@charset "UTF-8";

/*SP、PC共通スタイルここに*/
/* base */
.ftool-wrapper > .article,
.ftool-wrapper .description,
.ss-article-main-image,
.ftool-wrapper p {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

.ftool-wrapper h3 {
  margin-bottom: 0;
}

.ftool-wrapper #sec01 h2 {
  margin-bottom: 0;
}


.ftool-wrapper #sec01 {
  margin-bottom: 0;
}

/* setting */
html,
body {
  max-width: 100%;
  height: auto;
  margin: 0;
  padding: 0;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

html {
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

ul,
li {
  list-style: none;
  margin: 0;
  padding: 0;
}

p {
  margin-block-start: 0em;
  margin-block-end: 0em;
}

:root {
  --main: #3F443D;
}

@media (hover: hover) {
  a:hover {
    opacity: 0.8;
    cursor: pointer;  
    text-decoration: none;
  }
}

/* credit */
.ref-item  {
  font-size: 11px;
  margin-bottom: 8px;
  .thumb {
      width: 50px;
  }
  .brand {
      display: none;
  }
  .name {
      margin-left: 60px;
  }
  .price {
      margin-left: 60px;
  }
}
.ftool-wrapper .ref-item {
  font-size: 10px;
  margin-bottom: 8px;
}
.ftool-wrapper .ref-item .thumb {
  width: 50px;
}
.ftool-wrapper .ref-item .brand {
  display: none;
}
.ftool-wrapper .ref-item .name {
  margin-left: 60px;
}
.ftool-wrapper .ref-item .price {
  margin-left: 60px;
  font-size: 10px;
}
.ftool-wrapper .line_up_two {
  width: 100%;
}
.ftool-wrapper .col--02--Y {
  max-width: 100%;
}
/* credit */

/* setting */

.contentsWrap {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  font-family: "yu-gothic-pr6n", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: var(--main);
  font-size: 12px;
}

.visual__title {
  position: absolute;
  z-index: 3;
  margin: 0;
  text-align: center;
}

.visual__logo {
  position: absolute;
  z-index: 2;
  top: 2%;
  right: 2%;
}

.visualBlock {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.creditBlock {
  width: 78%;
  margin: 0 auto;
}

.staffCredit {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.contentsWrap img {
  display: block;
}

.lookBlock .credit {
  margin-top: 10px;
}

@media screen and (min-width: 768px) {
/*PC用スタイル*/

.lookBlock--spacing-md { padding-bottom: 120px; }
.lookBlock--spacing-lg { padding-bottom: 160px; }
.lookBlock--spacing-xl { padding-bottom: 200px; }

.creditBlock__inner {
  padding: 20px 0 80px 0;
}

.lookBlock__inner .sp {
  display: none;
}

.visual__title {
  width: 24%;
  top: 11%;
  left: 3%;
}

.contentsBlock {
  margin: 0 auto;
  width: 100%;
}

.br-sp {
  display: none;
}

.sp {
  display: none;
}  

.mainBlock__inner .image.sp {
  display: none;
}

.look01 .image .other {
  transform: translateY(-55%); 
  width: 31%;
  height: auto;
  object-fit: contain;
}

.look06 .image .other {
  transform: translateY(53%); 
  width: 31%;
  height: auto;
  object-fit: contain;
  padding-left: 1%;
}

.look01 .image .pc {
  overflow: hidden;
}

.look01 {
  width: 89%;
}

.look02 {
  width: 78%;
  margin: 0 auto;
}

.look07 {
  width: 78%;
  margin: 0 auto;
}

.look03 {
  width: 66%;
  margin: 0 auto;
}

.look04 {
  width: 78%;
  margin: 0 auto;
}

.look05 {
  width: 60%;
  margin-left: 23%;
}

.lookBlock__inner .row {
  display: flex;
}

.look04 .lookBlock__inner.top .pc {
  width: calc(50% - 0.75%);
  max-width: 100%;
}

.look04 .lookBlock__inner .other {
  width: calc(50% - 0.75%);
  max-width: 100%;
  transform: translateY(100px);
}

.look04 .lookBlock__inner .row {
  gap: 1.5%;
}

.look04 .lookBlock__inner.bottom {
  width: 85%;
  margin: 0 auto;
}

.look04 .lookBlock__inner.top {
  padding-bottom: 160px;
}

.look06 .image .pc {
  overflow: hidden;
  width: 68%;
}

.look06 {
  position: relative;
  padding-bottom: 24.5%; }

}
/*PC用スタイルここまで*/

@media screen and (max-width: 767px) {
/*SP用スタイル*/

.look07 {
  padding-bottom: 80px;
}

.lookBlock .credit {
  width: 95%;
  margin: 10px auto;
}

.lookBlock__inner .image .other {
  width: 95%;
  margin: 10px auto;
}

.lookBlock__inner .pc {
  display: none;
}

.creditBlock__inner {
  padding: 16px 0 6px 0;
}

.creditBlock {
  width: 95%;
}

.mainBlock__inner .image.pc {
  display: none;
}

.contentsWrap {
  font-size: 11px;
}

.visual__logo {
  width: 21%;
}

.visual__title {
  width: 58%;
  top: 6%;
  left: 3%;
}

.br-pc {
  display: none;
}

.pc {
  display: none;
}
}
 /*SP用スタイルここまで*/

/* フェードイン */
.fadeIn {
  transition: 1.8s;
  opacity: 0;
}

.fadeIn.animated {
  opacity: 1;
}

/* ブラー */
.inview-blur {
  opacity: 0;
  -moz-transition: -moz-transform 0.5s linear;
  -webkit-transition: -webkit-transform 0.5s linear;
  -o-transition: -o-transform 0.5s linear;
  -ms-transition: -ms-transform 0.5s linear;
  transition: transform 0.5s linear;
  -webkit-animation-duration: 1.2s;
  animation-duration: 1.2s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.blur {
  -webkit-animation-name: imageBlur;
  animation-name: imageBlur;
  opacity: 1;
  transition: 0.8s;
}

.inview-blur--late {
  opacity: 0;
  transition: transform 0.5s linear, opacity 0.8s;
  animation-duration: 1.2s;
  animation-fill-mode: both;
}

.blur {
  animation-name: imageBlur;
  opacity: 1;
  transition: opacity 0.8s;
  animation-delay: 0.3s;
}

@keyframes imageBlur {
  from {
    opacity: 0;
    filter: blur(15px);
  }
  to {
    opacity: 1;
    filter: blur(0px);
  }
}

@-webkit-keyframes imageBlur {
  from {
      opacity: 0;
      -webkit-filter: blur(15px);
      -moz-filter: blur(15px);
      -ms-filter: blur(15px);
      -o-filter: blur(15px);
      filter: blur(15px);
  }

  to {
      opacity: 1;
      -webkit-filter: blur(0px);
      -moz-filter: blur(0px);
      -ms-filter: blur(0px);
      -o-filter: blur(0px);
      filter: blur(0px);
  }
}

@keyframes imageBlur {
  from {
      opacity: 0;
      -webkit-filter: blur(15px);
      -moz-filter: blur(15px);
      -ms-filter: blur(15px);
      -o-filter: blur(15px);
      filter: blur(15px);
  }

  to {
      opacity: 1;
      -webkit-filter: blur(0px);
      -moz-filter: blur(0px);
      -ms-filter: blur(0px);
      -o-filter: blur(0px);
      filter: blur(0px);
  }
}

