@charset "utf-8";

body {color: var(--color-white)}
.link-txt.external_link {
  text-decoration: underline;
}
.link-txt.external_link::after {
  display: inline-block;
  right: auto;
  margin-left: 1em;
}
@media screen and (max-width: 820px) {
  .link-txt.external_link::after {top: 60%}
}
/* ------------------------------------------------------
#wrapper
------------------------------------------------------ */
#wrapper {
  background-image:
    -webkit-gradient(linear, left top, left bottom, from(rgba(18, 35, 67, .9)), to(rgba(18, 35, 67, 0.9))),
    -webkit-gradient(linear, left top, left bottom, color-stop(50%, rgba(239, 239, 239, 0)), color-stop(90%, rgba(239, 239, 239, 100%)));
  background-image:
    linear-gradient(rgba(18, 35, 67, .9) 0%, rgba(18, 35, 67, 0.9) 100%),
    linear-gradient(rgba(239, 239, 239, 0) 50%, rgba(239, 239, 239, 100%) 90%);
  background-repeat: no-repeat;
  background-position: left min(62.5vw, 90rem), center top;
  background-size: cover, 100% 63vw;
  overflow: hidden;
}
#wrapper::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: min(62.5vw, 90rem);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(40%, rgba(18, 35, 67, .3)), to(rgba(18, 35, 67, 0.9))) no-repeat center/cover;
  background: linear-gradient(rgba(18, 35, 67, .3) 40%, rgba(18, 35, 67, 0.9) 100%) no-repeat center/cover;
  pointer-events: none;
}
#content-wrap {z-index: 1}

/* ------------------------------------------------------
MAIN
------------------------------------------------------ */
.works-wrap {
  padding: 0 min(4.51vw, 6.5rem);
}
.works-wrap-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 1280px;
  margin: auto;
}
.works-list {
  -ms-flex-item-align: start;
      align-self: flex-start;
  width: 19.53%;
  padding: min(3.06vw, 4.4rem) min(1.25vw, 1.8rem);
  background-color: rgba(255,255,255,.2);
  border: 1px solid  rgba(255,255,255,.5);
  border-radius: 0.69vw;
  font-size: min(0.97vw, 1.4rem);
  letter-spacing: 0.1em;
}
.works-list .btn-all {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  background: var(--gradation-01-left);
  border-radius: 100vh;
  padding: .5em 2em;
  color: #fff;
  line-height: 1.2;
}
.works-list .taglist {
  margin-top: 3.2857em;
  padding: 0 1.2857em;
}
.works-list .taglist> li+ li {
  margin-top: 1.4285em;
}
.works-list .taglist> li a {
  line-height: 1.2
}
.card-wrap {
  width: 71.48%;
}
/* card */
.card {
  position: relative;
  width: 46.9945%;
  padding-bottom: min(4.86vw, 7.0rem);
  opacity: 1;
}
.card:nth-of-type(n + 3) {
  padding-top: min(4.86vw, 7.0rem);
}
.card:nth-of-type(odd)::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: min(63.54vw, 91.5rem);
  height: 1px;
  background-color: #fff;
}/*  */
/* さらに見るボタン */
.card-wrap .card.is-hidden {
  opacity: 0;
  height: 0;
  margin: 0;
  padding: 0;
  overflow: hidden;
}
.card-wrap .btn-wrap.js-more {
  width: 100%;
  margin-top: min(4.86vw, 7.0rem);
}
@media screen and (min-width: 821px) {
  .card-wrap .btn-wrap.js-more .btn-default {
    min-width: 10em;
    min-height: auto;
    padding: .4em 2em;
  }
}
@media screen and (max-width: 820px) {
  .works-wrap { padding: 0 2.67vmin; }
  .works-wrap-inner, .card-wrap, .card {
    display: block;
    width: 100%;
  }
  .works-list {display: none}
  .card:nth-of-type(n + 2) { padding-top: 13.33vmin; }
  .card:nth-of-type(n + 3) {margin: 0;}
  .card:nth-of-type(odd)::after {content: none}
  .card-wrap .btn-wrap.js-more { padding-top: 13.33vmin; }
  .card-wrap .btn-wrap.js-more .btn-default {width: auto;}
}
/* ------------------------------------------------------
詳細ページ　MAIN
------------------------------------------------------ */
.page-item article {
  padding: 0 min(4.51vw, 6.5rem);
}
.page-item .article-inner {
  max-width: 1280px;
  margin: auto;
}
.page-item .article-header .name {
  margin-top: 2.2857em;
  font-size: min(0.97vw, 1.4rem);
}
.page-item .article-header h2 {
  font-size: min(3.47vw, 5.0rem);
  line-height: 1.6
}
.page-item .article-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: min(3.47vw, 5.0rem)
}
.page-item .image-block {
  width: 73.4375%;
}
.page-item .image-wrap {
  border-radius: 1.04vw;
  overflow: hidden;
}
.page-item .body-txt {
  margin-top: 8em;
}
.page-item .body-txt p {
  font-size: min(1.04vw, 1.5rem);
  letter-spacing: .02em;
  line-height: 1.8666;
}
.page-item .link-txt {
  position: relative;
  display: inline-block;
  margin-top: 6em;
  font-size: min(1.04vw, 1.5rem);
  line-height: 1.8666;
}
.page-item .detail-block {
  width: 19.5312%;
}
.page-item .detail-block .tags ul {
  font-size: min(0.97vw, 1.4rem);
}
.page-item .detail-block .tags li+ li {
  margin-top: 2.1428em
}
.page-item .detail-block .tags li> a {
  display: block;
  border: 1px solid #fff;
  border-radius: 100vh;
  text-align: center;
  letter-spacing: .06em;
}
.page-item .description {
  display: block;
  margin-top: 11em;
  font-size: min(0.97vw, 1.4rem);
  letter-spacing: .02em;
  line-height: 1.7142;
}
.page-item .description> div+ div {
  margin-top: 2em
}
.page-item .description> div> dt {
  font-weight: bold;
}
.page-item .description> div> dd {
  margin-top: 1em;
}
.page-item .description .staff> div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
}
.page-item .description .staff dt {
  width: 50%;
  font-size: 0.8571em;
}
.page-item .description .staff dd {
  width: 50%;
  padding-left: 1em;
}
.page-item .imageList-wrap {
  margin-top: min(4.44vw, 6.4rem)
}
.page-item .imageList-wrap ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
}
.page-item .imageList-wrap li {
  width: 46.875%;
  margin-bottom: min(6.25vw, 9.0rem)
}
.page-item .pickup {
  position: relative;
  max-width: 1410px;
  margin: auto;
  margin-top: min(5.83vw, 8.4rem);
  margin-bottom: min(2.08vw, 3.0rem);
  padding-top: min(5.83vw, 8.4rem);
}
.page-item .pickup::after {
  content: "";
  position: absolute;
  top: 0;
  left: calc((100vw - 100%) / -2);
  width: 100vw;
  height: 300%;
  background-color: #646F83;
  z-index: -1;
  pointer-events: none;
}
.page-item .pickup .title-tag {
  margin: auto;
  font-size: min(2.08vw, 3.0rem);
  text-align: center;
  font-weight: bold;
}
.page-item .pickup .title-tag span {
  position: relative;
  display: inline-block;
  height: 100%;
}
.page-item .pickup .title-tag span::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 3px;
  background: var(--gradation-01-left);
}
.page-item .pickup .card-wrap {
  width: 100%;
  margin-top: min(3.47vw, 5.0rem);
}
.page-item .pickup .card {
  width: 30.4964%;
  padding-bottom: min(1.74vw, 2.5rem);
}
.page-item .pickup .card:nth-of-type(n + 3) {
  padding-top: 0;
}
.page-item .pickup .card:nth-of-type(odd)::after {
  content: none;
}
@media screen and (max-width: 820px) {
  .page-item article { padding: 0 2.67vmin;}
  .page-item .article-header .name { font-size: 3.73vmin; }
  .page-item .article-header h2 {
    font-size: 6.4vmin;
    line-height: 1.5;
    letter-spacing: .02em;
  }
  .page-item .article-body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
    margin-top: 8vmin
  }
  .page-item .image-block, .page-item .detail-block {
    width: 100%;
  }
  .page-item .image-block {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    margin-top: 17.07vmin;
  }
  .page-item .detail-block .tags ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: wrap;
        flex-flow: wrap;
    font-size: 3.2vmin;
  }
  .page-item .detail-block .tags li {margin-bottom: 1.0833em}
  .page-item .detail-block .tags li+ li {
    margin-top: 0;
  }
  .page-item .detail-block .tags li a {
    margin-right: 1.8333em;
    padding: 0 1.6666em;
    line-height: 1.5em;
  }
  .page-item .description {
    margin-top: 3.8571em;
    font-size: 3.73vmin
  }
  .page-item .description> div> dd { margin-top: 0.7142em; }
  .page-item .description> div+ div { margin-top: 2.1428em }
  .page-item .description .staff dt { width: auto }
  .page-item .description .staff dd { width: auto; -webkit-box-flex: 1; -ms-flex-positive: 1; flex-grow: 1 }
  .page-item .image-wrap { border-radius: 2.67vmin }
  .page-item .body-txt { margin-top: 11.47vmin;}
  .page-item .body-txt p { font-size: 3.73vmin; line-height: 1.8571; }
  .page-item .body-txt p+ p { margin-top: 1.8571em; }
  .page-item .link-txt { font-size: 3.73vmin; }
  .page-item .imageList-wrap { margin-top: 8vmin }
  .page-item .imageList-wrap li {width: 100%; margin-bottom: 10.67vmin }
  .page-item .pickup { margin-bottom: 0; padding: 14.93vmin 2.67vmin 0; }
  .page-item .pickup .card,.page-item .pickup .card:nth-of-type(n + 3) {
    width: 100%; 
    border-bottom: none;
    padding-top: 6.93vmin;
    padding-bottom: 6.93vmin
  }
  .page-item .pickup .card:last-of-type {padding-bottom: 0;}
  .page-item .pickup .title-tag {font-size: 6.67vmin }
  .page-item .pickup .title-tag span::after { height: 0.54vmin;}
  .page-item .pickup .card-wrap { margin-top: 14.13vmin }
}

/* ------------------------------------------------------
FOOTER
------------------------------------------------------ */
.page-under .footer {
  background-color: rgba(18, 35, 67, 0.9);
}
.page-item .footer {
  background-color: #646F83;
}
#page-top {border-color: #fff;}
#page-top a {
  background-image: url("../img/common/icon_arrow_wht.svg")
}

/* ------------------------------------------------------
公開まで暫定措置
------------------------------------------------------ */
.works-list {
  visibility: hidden
}