@charset "utf-8";
/*================================
common
================================*/
:root {
  --colo-yellow: #fffd31;
  --colo-blue: #019fe6;
  --color_BLK: #252525;
  --color_red: #cd2438;
	--gap_96px: clamp(32px, 12vw, 96px);
	--gap_80px: clamp(27px, 10vw, 80px);
	--gap_64px: clamp(21px, 8vw, 64px);
	--gap_48px: clamp(16px, 6vw, 48px);
	--gap_32px: clamp(11px, 4vw, 32px);
	--gap_24px: clamp(8px, 3vw, 24px);
	--gap_16px: clamp(5px, 2vw, 16px);
	--gap_8px: clamp(3px, 1vw, 8px);
}

body {
	width: 100%;
	position: relative;
}

body,figure,h1,h2,h3,h4,h5,h6,li,ol,p,ul,dl,dt,dd {
	margin: 0;
	padding: 0;
}
h1,h2,h3,h4,h5,h6,p {
	font-size: inherit;
	font-weight: normal;
}
li,ol,ul {
	list-style-type: none;
}
table {
	width: 100%;
}

#page {
	font-size: clamp(18px, 2.2vw, 20px);
	color: var(--color_BLK);
	font-family: "Noto Sans CJK JP", Lato, "Noto Sans JP", "游ゴシック Medium", 游ゴシック体, "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.6;
	margin: 0 auto;
	/* max-width: 1920px; */
	-webkit-text-size-adjust: 100%;
	font-feature-settings: "palt" 1;
  position: relative;
}

#page * {
	box-sizing: border-box;
}
#page img {
	max-width: 100%;
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
}

#page * {
	box-sizing: border-box;
}

#page a {
	transition: all 0.3s;
	text-decoration: none;
}
#page a[tabindex*="-1"] {
	pointer-events: none;
}
#page a[tabindex*="-1"]:hover {
	opacity: 1;
}
/* リンクとボタンのoutlineを非表示にする */
#page a,
#page button {
	outline: none;
	cursor: pointer;
}
/* ボタンとリンクにフォーカスした時にoutlineが表示されるようにする */
#page a:focus-visible {
	outline: #3683BF solid 2px;
	outline-offset: 2px;
}
#page button:focus-visible {
	outline: #3683BF solid 2px;
	outline-offset: 1px;
}
#page a:hover {
	cursor: pointer;
	text-decoration: none;
	opacity: 0.7;
}
#page label {
	cursor: pointer;
}

#page em {
	font-style: normal;
	font-weight: bold;
  font-size: 1.4em;
}

#page picture { display: block;}

.pc {
  display: block;
}

.sp {
  display: none;
}

.ib {
	font-size: inherit !important;
	display: inline-block;
}

#page_top {
  position: fixed;
  right: 0.5%;
  bottom: 2%;
  display: block;
  width: min(22vw,130px);
  z-index: 999;
}

#page_top img { width: 100%;}

@media not screen and (min-width: 767px) {
  #page_top {
    z-index: 800;
  }
}

/*================================
アニメーションcss
================================*/
.animated {
  animation-fill-mode: both;
  animation-duration: 0.5s;
}

.fadeIn{
  opacity:0;
}


/* その場で */
.fadeIn.animated {
  animation-name:fadeInAnime;
}
  
@keyframes fadeInAnime{
  from {
      opacity: 0;
  }
  to {
      opacity: 1;
  }
}

/* 下から */
.fadeUp {
  opacity:0;
}
.fadeUp.animated{
  animation:fadeUpAnime 1.3s cubic-bezier(0.33, 1, 0.68, 1) forwards;
}

@keyframes fadeUpAnime{
  0% {
  transform: translateY(30px);
  opacity: 0;
}
80% {
  opacity: 1;
}
100% {
  opacity: 1;
  transform: translateY(0);
}
}

/* 上から */

.fadeDown {
  opacity:0;
}

.fadeDown.animated{
  animation-name:fadeDownAnime;
}

@keyframes fadeDownAnime{
  from {
      opacity: 0;
      transform: translateY(-10px);
  }

  to {
      opacity: 1;
      transform: translateY(0);
  }
}

/* 左から */

.fadeLeft {
  opacity:0;
}

.fadeLeft.animated{
  animation-name:fadeLeftAnime;
}

@keyframes fadeLeftAnime{
  from {
      opacity: 0;
      transform: translateX(-10px);
  }

  to {
      opacity: 1;
      transform: translateX(0);
  }
}

/* 右から */

.fadeRight {
  opacity:0;
}

.fadeRight.animated {
  animation-name:fadeRightAnime;
}

@keyframes fadeRightAnime{
  from {
      opacity: 0;
      transform: translateX(10px);
  }

  to {
      opacity: 1;
      transform: translateX(0);
  }
}

.text-focus-in {
opacity:0;
}

/* text出現 fuwa */
.text-focus-in.animated {
-webkit-animation: text-focus-in 0.6s cubic-bezier(0.550, 0.085, 0.680, 0.530) both;
animation: text-focus-in 0.6s cubic-bezier(0.550, 0.085, 0.680, 0.530) both;
}

@-webkit-keyframes text-focus-in {
0% {
  -webkit-filter: blur(12px);
  filter: blur(12px);
  opacity: 0;
}
100% {
  -webkit-filter: blur(0px);
  filter: blur(0px);
  opacity: 1;
}
}
@keyframes text-focus-in {
0% {
  -webkit-filter: blur(12px);
  filter: blur(12px);
  opacity: 0;
}
100% {
  -webkit-filter: blur(0px);
  filter: blur(0px);
  opacity: 1;
}
}

/* text出現 hirogaru */
.tracking-in-expand {
opacity:0;
}

.tracking-in-expand.animated {
-webkit-animation:tracking-in-expand .7s cubic-bezier(.215,.61,.355,1.000) both;
animation:tracking-in-expand .7s cubic-bezier(.215,.61,.355,1.000) both
}

@-webkit-keyframes tracking-in-expand {
0% {
  letter-spacing:-.5em;
  opacity:0
}
40% {
  opacity:.6
}
100% {
  opacity:1
}
}
@keyframes tracking-in-expand {
  0% {
    letter-spacing:-.5em;
    opacity:0
  }
  40% {
    opacity:.6
  }
  100% {
    opacity:1
  }
}

/* 右傾く */
.fadeRotateRight {
opacity: 0;
}
.fadeRotateRight.animated {
animation:fadeRotateRight 1s ease-in-out both;
}

@keyframes fadeRotateRight {
0% {
  opacity: 0;
  rotate: 0deg;
}
25% {
  opacity: 1;
}
50% {
  rotate: -20deg;
}
100% {
  rotate: 0deg;
  opacity: 1;
}
}

/* 左傾く */
.fadeRotateLeft {
opacity: 0;
}
.fadeRotateLeft.animated {
animation:fadeRotateLeft 1s ease-in-out both;
}

@keyframes fadeRotateLeft {
0% {
  opacity: 0;
  rotate: 0deg;
}
25% {
  opacity: 1;
}
50% {
  rotate: 20deg;
}
100% {
  rotate: 0deg;
  opacity: 1;
}
}

/* 滑らかに変形して出現 */
.smoothTrigger {
opacity:0;
}

.smoothTrigger.animated{
animation-name:smoothAnime;
animation-duration:1s;
animation-fill-mode:forwards;
transform-origin: left;
}

@keyframes smoothAnime{
from {
  transform: translate3d(0, 60%, 0) skewY(12deg);
  opacity:0;
}

to {
  transform: translate3d(0, 0, 0) skewY(0);
  opacity:1;
}
}

/*背景→text出現 （span）*/

.bgextend {
opacity: 0;
}
.bgextend.animated{
animation-name:bgextendAnimeBase;
animation-timing-function: ease-in-out;
position: relative;
overflow: hidden;/*　はみ出た色要素を隠す　*/
}
@keyframes bgextendAnimeBase{
0% { opacity:0; }
50% { opacity:0; }
100% { opacity:1; }
}

/*左から*/

.bgLRextend.animated::before{
--band-padding: 0.25em;
animation-name:bgLRextendAnime;
animation-duration: 0.8s;
animation-timing-function: cubic-bezier(0.0, 0.0, 0.2, 1);
animation-fill-mode: both;
content: "";
position: absolute;
width: 100%;
height: calc(100% + var(--band-padding)* 2);
top: calc(var(--band-padding)* -1);
background-color: #fff;/*伸びる背景色の設定*/
z-index: 1;
}
@keyframes bgLRextendAnime{
0% {
transform-origin:left;
transform:scaleX(0);
}
50% {
transform-origin:left;
transform:scaleX(1);
}
50.001% {
transform-origin:right;
}
100% {
transform-origin:right;
transform:scaleX(0);
}
}

/*右から*/
.bgRLextend::before{
animation-name:bgRLextendAnime;
animation-duration:1s;
animation-fill-mode:forwards;
content: "";
position: absolute;
width: 100%;
height: 100%;
background-color: #fff;/*伸びる背景色の設定*/
}
@keyframes bgRLextendAnime{
0% {
transform-origin:right;
transform:scaleX(0);
}
50% {
transform-origin:right;
transform:scaleX(1);
}
50.001% {
transform-origin:left;
}
100% {
transform-origin:left;
transform:scaleX(0);
}
}

/*下から*/
.bgDUextend::before{
animation-name:bgDUextendAnime;
animation-duration:1s;
animation-fill-mode:forwards;
content: "";
position: absolute;
width: 100%;
height: 100%;
background-color: #fff;/*伸びる背景色の設定*/
}
@keyframes bgDUextendAnime{
0% {
transform-origin:bottom;
transform:scaleY(0);
}
50% {
transform-origin:bottom;
transform:scaleY(1);
}
50.001% {
transform-origin:top;
}
100% {
transform-origin:top;
transform:scaleY(0);
}
}

/*上から*/
.bgUDextend::before{
animation-name:bgUDextendAnime;
animation-duration:1s;
animation-fill-mode:forwards;
content: "";
position: absolute;
width: 100%;
height: 100%;
background-color: #666;/*伸びる背景色の設定*/
}
@keyframes bgUDextendAnime{
0% {
transform-origin:top;
transform:scaleY(0);
}
50% {
transform-origin:top;
transform:scaleY(1);
}
50.001% {
transform-origin:bottom;
}
100% {
transform-origin:bottom;
transform:scaleY(0);
}
}

/*text左から右*/
.leftAnime {
  opacity: 0;
  overflow: hidden;
  display: inline-block;
}

.leftAnimeInner {
display: inline-block;
}

.slideAnimeLeftRight {
  animation-name: slideTextX100;
  animation-duration: 1s;
  animation-fill-mode: forwards;
opacity: 0;
}

@keyframes slideTextX100 {
from {
transform: translateX(-100%);
/*要素を左の枠外に移動*/
opacity: 0;
}

to {
transform: translateX(0);
/*要素を元の位置に移動*/
opacity: 1;
}
}

/*================================
共通パーツ
================================*/
.inner_wide {
  padding-inline: min(5vw,80px);
}

.inner_contents {
  max-width: min(85vw,1160px);
  margin-inline: auto;
  padding-inline: 40px;
}

.inner {
  max-width: 1360px;
  margin-inline: auto;
  padding-inline: 40px;
}

.bold {
  font-weight: 700;
}

.red {
  font-weight: 700;
  color: var(--color_red)
}

.y_line {
  background-position: left -100% center;
  padding-bottom: 0.6em;
  padding-inline: .2em;
  background-size: 200% 0.6em;
  background-repeat: repeat-x;
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0) 50%, rgb(255, 255, 102) 50%);
  transition: background-position 2s 0.1s;
}

/*================================
movie
================================*/
.movie {
  position: relative;
  max-width: 900px;
  aspect-ratio: 16/9;
  margin: 0 auto var(--gap_64px);
  overflow: hidden;
}

.streaming_area {
  display: flex;
  justify-content: center;
  gap: var(--gap_64px);
}

.tver_area {
  font-size: .9em;
	text-align: center;
	text-shadow: 0 0 0.2em #fff,0 0 0.2em #fff,0 0 0.3em #fff,0 0 0.3em #fff,0 0 0.3em #fff;
  width: clamp(250px, 45vw, 400px);
}

.tver_info {
  margin-bottom: var(--gap_8px);
}

.tver_info em {
	font-size: 1.3em;
}

.tver_area .tver_info_btm {
  color: inherit;
  margin: var(--gap_16px) auto 0;
  text-align: center;
  line-height: 1.2;
}

.tvo-video {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
}

.youtube_area {
  text-align: center;
	text-shadow: 0 0 0.2em #fff,0 0 0.2em #fff,0 0 0.3em #fff,0 0 0.3em #fff,0 0 0.3em #fff;
  /* margin: var(--gap_64px) auto; */
  width: clamp(250px, 45vw, 400px);
}

.youtube_info_btm {
  font-size: .6em;
  color: inherit;
  margin: var(--gap_16px) auto 0;
}


/*================================
mv
================================*/
.mv__date {
  background: url(/sp/koshino_junko/assets/images/date_bg.jpg);
  padding: var(--gap_32px) var(--gap_16px);
}

.mv__date > p {
  text-align: center;
}

/*================================
about
================================*/
.about {
  padding: 0 0 var(--gap_48px);
}

.about::before {
  content: "";
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  background: url(/sp/koshino_junko/assets/images/bg.jpg) no-repeat center / cover;
  z-index: -1;
}

.contents__bg {
  text-align: center;
	background:  #fff;
	box-shadow: 0 0 20px #696969;
	padding: var(--gap_64px) var(--gap_48px);
	margin: var(--gap_48px) auto var(--gap_64px);
}

.about__textArea01 > p {
  font-size: 1em;
  font-weight: 500;
  line-height: 1.7em;
  letter-spacing: .04em;
  margin: var(--gap_64px) auto;
  text-shadow: 0 0 0.2em #fff,0 0 0.2em #fff,0 0 0.3em #fff,0 0 0.3em #fff,0 0 0.3em #fff;
}

.about__text--lead {
  margin-top: 0 !important;
}

.about__img {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: min(4vw,40px);
}

.about__img > div {
  width: min(38vw, 500px);
}

.about__img > div > img{
  box-shadow: 0 0 10px #696969;
}

/*================================
slide
================================*/
/* .slide {
  padding-top: var(--gap_64px);
} */

.slide__img--list {
  display: flex;
  align-items: center;
  margin-bottom: var(--gap_80px);
}

.slide__img--list > li {
  width: 25vw;
}

.slide__img .slick-slide {
  border-right: 3px solid #fff;
}

@media not screen and (min-width: 768px) {
  /*================================
  共通パーツ
  ================================*/
  #page em {
    font-size: 1.2em;
  }

  .inner {
    width: 90%;
    padding-inline: 0;
  }

  .inner_wide, .inner_contents {
    max-width: 94%;
    padding-inline: 3vw;
    margin-inline: auto;
  }

  .pc {
    display: none;
  }
  
  .sp {
    display: block;
  }

  /*================================
  about
  ================================*/
  .movie {
    width: 100%;
  }

  .streaming_area {
    display: block;
  }

  .streaming_area > div {
    width: 85%;
    margin-inline: auto;
  }

  .tver_area {
    margin-bottom: var(--gap_64px);
  }

  .about__textArea01 > p {
    font-size: .9em;
  }

  .about__img > div {
    width: 100%;
}

  /*================================
  slide img
  ================================*/
  .slide__img--list {
    display: flex;
    align-items: center;
  }

}
