/*! =======================================================

  "3mind.co.jp" Case Study Details Styles

======================================================== */
/*!
  Case Study Details
======================================================== */
.l-contents .inner h3.case-title {
  font-size: 36px;
  font-size: 3.6rem;
  letter-spacing: 0.05em;
  margin: 115px 0 130px;
}
.l-contents .case-summary {
  color: #ffffff;
  padding: 0 0 40px;
  margin: 0 0 85px;
  background-color: #ed6d1f;
}
.l-contents .case-summary .inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 120px;
}
.l-contents .case-summary .inner dl {
  margin: 90px 0 0;
  letter-spacing: 0.05em;
}
.l-contents .case-summary .inner dl dt {
  font-size: 20px;
  font-size: 2rem;
  font-weight: 600;
  margin: 0 0 1em;
}
.l-contents .case-summary .inner dl dd {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 300;
  line-height: 2;
}
.l-contents .case-summary .inner figure {
  max-width: 500px;
  flex-shrink: 0;
  margin: -50px 0 0;
}
.l-contents .case-summary .inner figure figcaption {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 300;
  letter-spacing: 0.05em;
  line-height: 1.5;
  text-align: right;
  margin: 1em 0 0;
}
.l-contents .case-summary .inner figure img {
  height: auto;
  object-fit: cover;
}
.l-contents .case-details {
  padding: 0 0 170px;
}
.l-contents .case-details .case-detail:first-of-type {
  margin: 0;
}
.l-contents .case-details .case-detail:not(:first-of-type) {
  margin: 170px 0 0;
}
.l-contents .case-details .case-detail .inner h4 {
  position: relative;
  width: fit-content;
  font-size: 26px;
  font-size: 2.6rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 36px;
  color: #ed6d1f;
  padding: 0.5em 30px 0.5em 0;
  margin: 0 0 50px;
  background-color: #f1f1f1;
}
.l-contents .case-details .case-detail .inner h4::before {
  content: "";
  position: absolute;
  top: 0;
  /*
  left: calc((100vw - 1200px) / 2 * -1);
  width: calc((100vw - 1200px) / 2);
  */
  height: 100%;
  background-color: #f1f1f1;
  display: inline-block;
}
.l-contents .case-details .case-detail .inner dl.qa {
  letter-spacing: 0.05em;
}
.l-contents .case-details .case-detail .inner dl.qa dt {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 600;
  line-height: 2.25;
  border-bottom: solid 2px #000000;
  display: inline;
  padding: 0 0 0.15em;
}
.l-contents .case-details .case-detail .inner dl.qa dd {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.8;
  margin: 1.75em 0 75px;
}
.l-contents .case-details .case-detail .inner figure {
  max-width: 64%;
  text-align: center;
  margin: auto;
}
.l-contents .case-details .case-detail .inner figure img {
  height: auto;
  object-fit: cover;
}

@media screen and (min-width: 1281px) {
  .l-contents .case-details .case-detail .inner h4::before {
    left: calc((100vw - 1200px) / 2 * -1);
    width: calc((100vw - 1200px) / 2);
  }
}
@media screen and (max-width: 1280px) {
  .l-contents .case-details .case-detail .inner h4::before {
    left: -7.6923076923vw;
    width: 7.6923076923vw;
  }
}
@media screen and (max-width: 780px) {
  .l-contents .inner h3.case-title {
    font-size: max(3.8461538462vw, 22px);
    margin: 20.5128205128% 0 11.5384615385%;
  }
  .l-contents .case-summary {
    padding: 0 0 12.1794871795%;
    margin: 0 0 8.3333333333%;
  }
  .l-contents .case-summary .inner {
    flex-direction: column-reverse;
    align-items: flex-end;
    width: 100%;
  }
  .l-contents .case-summary .inner dl {
    width: 100%;
    margin: 8.9743589744% auto 0;
    padding: 0 7.6923076923%;
  }
  .l-contents .case-summary .inner dl dt {
    font-size: 3.8461538462vw;
    margin: 0 0 1em;
  }
  .l-contents .case-summary .inner dl dd {
    font-size: 3.3333333333vw;
    line-height: 1.75;
  }
  .l-contents .case-summary .inner figure {
    max-width: 64.1025641026vw;
    margin: -6.4102564103vw 0 0;
  }
  .l-contents .case-summary .inner figure figcaption {
    font-size: 3.0769230769vw;
    margin: 0.5em 0 0;
    padding: 0 7.6923076923% 0 0;
  }
  .l-contents .case-details {
    padding: 0 0 15.3846153846%;
  }
  .l-contents .case-details .case-detail:not(:first-of-type) {
    margin: 21.7948717949% 0 0;
  }
  .l-contents .case-details .case-detail .inner h4 {
    font-size: max(3.8461538462vw, 22px);
    line-height: 1.3333333333;
    padding: 2.5641025641% 3.8461538462% 2.5641025641% 0;
    margin: 0 0 7.6923076923%;
  }
  .l-contents .case-details .case-detail .inner dl.qa dt {
    font-size: max(3.8461538462vw, 18px);
  }
  .l-contents .case-details .case-detail .inner dl.qa dd {
    font-size: max(3.0769230769vw, 16px);
    /* line-height: calc(40 / 26); */
    margin: 1.75em 0 7.6923076923%;
  }
  .l-contents .case-details .case-detail .inner figure {
    max-width: 100%;
  }
}
/*! Case Study Details - Pagination
-------------------------------------------------------- */
.detail-pager .inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 30px;
  margin: 100px 0 0;
}
.detail-pager .inner a {
  text-decoration: none;
  transition: all 0.3s;
}
.detail-pager .inner a.to-list {
  font-size: 16px;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  width: 400px;
  line-height: 60px;
  color: #ffffff;
  background-color: #000000;
  text-align: center;
  display: block;
}
.detail-pager .inner a.to-list:hover {
  background-color: #ed6d1f;
}
.detail-pager .inner a.prev, .detail-pager .inner a.next {
  color: #ffffff;
  width: 46px;
  height: 46px;
  background-color: #707070;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.detail-pager .inner a.prev span, .detail-pager .inner a.next span {
  font-size: 16px;
  font-size: 1.6rem;
  display: inline-block;
  transform: scale(0.6, 1);
}
.detail-pager .inner a.prev:hover, .detail-pager .inner a.next:hover {
  background-color: #c7c7c7;
}

@media screen and (max-width: 780px) {
  .detail-pager .inner {
    gap: 0 5.7692307692%;
    margin: 12.8205128205% 0 0;
  }
  .detail-pager .inner a.to-list {
    font-size: 3.3333333333vw;
    width: 58.9743589744vw;
    line-height: 11.5384615385vw;
  }
  .detail-pager .inner a.prev, .detail-pager .inner a.next {
    width: 7.1794871795vw;
    height: 7.1794871795vw;
    border-radius: 7.1794871795vw;
  }
  .detail-pager .inner a.prev span, .detail-pager .inner a.next span {
    font-size: 3.0769230769vw;
  }
}
/*!
  WordPress - 'post-navigation' Overwrite
======================================================== */
.detail-pager {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 100px auto 0;
  gap: 0 30px;
}
.detail-pager a.to-list {
  text-align: center;
}
.detail-pager span.prev, .detail-pager span.next {
  color: #ffffff;
  width: 46px;
  height: 46px;
  background-color: #707070;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
}
.detail-pager span.prev:hover, .detail-pager span.next:hover {
  background-color: #ed6d1f;
}
.detail-pager span.prev a, .detail-pager span.next a {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
  color: #ffffff;
  display: block;
  transform: scale(0.6, 1);
}

@media screen and (max-width: 780px) {
  .detail-pager {
    margin: 12.8205128205% auto 0;
    gap: 0 3.8461538462vw;
  }
  .detail-pager span.prev, .detail-pager span.next {
    width: 7.1794871795vw;
    height: 7.1794871795vw;
  }
  .detail-pager span.prev a, .detail-pager span.next a {
    font-size: 3.0769230769vw;
  }
}
