@charset "UTF-8";
figure {
  position: relative;
}
.imgcap {
  padding: 6px 8px;
}
body {
  position: relative;
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 1.6;
  background: #E4E5E8;
  color: #333;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  width: 100%;
  height: 100%;
  margin: auto;
  text-rendering: optimizeLegibility;
  font-kerning: normal;
  font-variant-ligatures: common-ligatures contextual;
  font-feature-settings: "kern", "liga", "clig", "calt";
}
#pxBase sup {
  vertical-align: super;
  font-size: .5em;
}
#pxBase a:link, #pxBase a:visited, #pxBase a:active, #pxBase a:hover {
  text-decoration: none;
}
#pxBase figure {
  position: relative;
}
#pxBase img {
  max-width: 100%;
  width: 100%;
  height: auto;
}
#pxBase img.object-fit {
  object-fit: cover;
  height: 100%;
}
.kvTitle span, .kvCopy {
  color: #F3EEE7;
}

/* visible or hidden
--------------------------------------------------------------------------------*/
.hidden-pc {
  display: none !important;
}
@media only screen and (max-width: 991px) {
  .visible-pc {
    display: none !important;
  }
  .hidden-pc {
    display: block !important;
  }
}
@media only screen and (min-width: 992px) {
  .visible-tbsp {
    display: none !important;
  }
}
@media only screen and (min-width: 768px) {
  .visible-sp {
    display: none !important;
  }
}
.visible-xs, .visible-sm, .visible-md, .visible-lg {
  display: none !important;
}
@media (max-width: 767px) {
  .hidden-xs {
    display: none !important;
  }
  .visible-xs {
    display: block !important;
  }
}


/*
共通パーツ
------------------------------------------*/
.section-title {
  font-size: 72px;
  letter-spacing: 0.01em;
  line-height: 1;
  color: #2F5850;
  text-align: center;
}
.imgCap figure {
  position: relative;
}
.imgCap figure figcaption {
  position: absolute;
  content: "";
  bottom: 5px;
  right: 0;
  padding: 0 5px;
  line-height: 1.2;
  font-size: 1.1rem;
  color: #fff;
}
.imgCap figure figcaption.black {
  color: #000;
  text-shadow:
    1px 1px 0 #fff, -1px 1px 0 #fff, -1px -1px 0 #fff, 1px -1px 0 #fff;
}
@media only screen and (max-width: 767px) {
  .section-title {
    font-size: 50px;
  }
}
.kvTitle {
  margin-bottom: 0px;
}
.kvTitle + .kvTitle {
  margin-bottom: 60px;
}
.kvTitle span {
  font-size: 70px;
  font-weight: 600;
  line-height: 1.6;
}
@media only screen and (max-width:991px) {
  .kvTitle + .kvTitle {
    margin-bottom: 40px;
  }
  .kvTitle span {
    font-size: 2.4rem;
  }
}

/* contentsInner
================================== */
.contentsInner {
  width: calc(100% - 40px);
  margin-inline: auto;
  max-width: 1200px;
  padding: 200px 0 60px
}
.movieContents_wrap {
  padding: 50px 0
}
.movieContents_column {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-column-gap: 40px;
  grid-row-gap: 60px;
  list-style-type: none;
  padding: 0;
  margin: 0
}
.movieThumb {
	position: relative;
	cursor: pointer;
	max-width: 1200px;
	display: block;
	margin: 0 auto;
}
.movieThumb .movieThumbImg { 
  transition: all .4s ease-in-out;
}
.movieThumb:hover .movieThumbImg { 
  opacity: .8;
}
.movie-wrap {
	position: relative;
	max-width: 1240px;
	margin: auto;
	padding: 20px;
}
.movie-wrap > .movie-inner {
	aspect-ratio: 16 / 9;
}
.movieContents_column li .movieTextBox {
  position: relative;
  font-weight: bold;
  display: flex;
  align-items: start;
  margin-top: 20px;
}
.movieContents_column li .movieTextBox p {
  font-size: 20px;
  font-weight: 600;
}
.movieContents_column li .movieTextBox p .num {
  font-size: 24px;
  line-height: 1;
  font-weight: 600;
}
.movieContents_column li .movieTextBox p .subTitle {
  display: block;
  margin-top: 6px;
  font-size: 16px;
  letter-spacing: 0.05em;
  font-weight: 600;
}
.movieContents_column li .movieTextBox p:nth-of-type(1) {
  flex-basis: 56px
}
.movieContents_column li .movieTextBox p:nth-of-type(2) {
  flex-basis: calc(100% - 56px);
}
.movieContents_column li .movieTextBox p:nth-of-type(3) {
  position: absolute;
  right: 0;
  bottom: 0
}

@media only screen and (max-width:767px) {
  .contentsInner {
    padding: 60px 0 60px
  }
  .movieContents_wrap {
    padding: 50px 0
  }
  .movieContents_column {
    grid-template-columns: repeat(1, 1fr);
    row-gap: 30px;
  }
  .movieContents_column li .movieTextBox {
    align-items: start;
    margin-top: 10px;
  }
  .movieContents_column li .movieTextBox p {
    font-size: 16px;
  }
  .movieContents_column li .movieTextBox p .num {
    font-size: 18px;
  }
  .movieContents_column li .movieTextBox p .subTitle {
    margin-top: 6px;
    font-size: 14px;
  }
  .movieContents_column li .movieTextBox p:nth-of-type(1) {
    flex-basis: 30px
  }
  .movieContents_column li .movieTextBox p:nth-of-type(2) {
    flex-basis: calc(100% - 30px);
  }
}