@charset "UTF-8";
@import url("grid.css");
@import "https://use.fontawesome.com/releases/v5.13.0/css/all.css";

img {
	max-width:100%;
	height: auto;/*高さ自動*/
}

/*------------------------------------------------------
       footer
------------------------------------------------------*/

footer {
    background-color: #555555;
    text-align: center;
}

.foot-box {
	background: #555555;
}

.foot-box ul {
  background: #555555;
	max-width: 400px;
	padding: 10px 0 ;
	text-align: center;
	margin: 0 auto ;
}

.foot-box ul li {
	list-style: none;
	padding: 5px 5px;
  display: inline-block;
  font-size: 1.4rem;
}
.foot-box ul li a{
  color: #fff;
}

/*-------------------------------------
　コピーライト
-------------------------------------*/
.copyright {
    text-align: center;
    padding: 1rem 0;
    background-color: #000;
}
.copyright p {
    color: #fff;
    text-decoration: none;
	display: inline;
}

@media screen and (max-width: 768px){
	
/*ヘッダー
-------------------------------------*/
.header-box {
	display: none;
}	
    
/*フッダー
-------------------------------------*/	
footer{
    padding: 0 0;
}
    
.foot-box ul {
    text-align: center;
}	
    
.foot-box ul li {
    float: none;
	display: block;
    border-top: 1px solid #555555;
}	

    
/*お問い合わせ
-------------------------------------*/
.table th {
	width: 100%;
	display: block;
}	
.table td {
	display: block;
}
}

/* 追加記述 --------------------------------*/
:root {
    --color-default: #3a2c22;
    --color-blue: #689bcb;
    --color-red: #ea5e68;
    --color-green: #8abb54;
    --color-orange: #fb902c;
    --color-yellow: #ffed59;
    --color-plan1: #dcb000;
    --color-plan2: #fb902c;
    --lg-basesize: 1440 * 100vw;
    --sm-basesize: 750 * 100vw;
}
.bk03{
  padding-bottom: 1em;
}
.prologue {
    padding: calc(20 / var(--sm-basesize)) 0 calc(20 / var(--sm-basesize));
    background: #fef4ea url(../img/bg_01.jpg) 50% 0 / 200% auto no-repeat;
}
.l-inner {
    padding: 0 calc(30 / var(--sm-basesize));
}
.cta {
    text-align: center;
  }
  .cta-label span {
    position: relative;
    display: inline-block;
    margin-bottom: calc(15 / var(--sm-basesize));
    padding: calc(15 / var(--sm-basesize)) calc(40 / var(--sm-basesize));
    background: var(--color-default);
    border-radius: 100vmax;
    font-size: 0;
  }
  .cta-label span::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    width: 0;
    height: 0;
    border: calc(15 / var(--sm-basesize)) solid transparent;
    border-top-color: var(--color-default);
    transform: translateX(-50%);
  }
  .cta-label img {
    width: auto;
    height: calc(35 / var(--sm-basesize));
  }
  .cta-heading {
    position: relative;
    display: inline-block;
    line-height: 1.5;
    letter-spacing: .05em;
  }
  .cta-heading::before,
  .cta-heading::after {
    content: '';
    position: absolute;
    top: calc(25 / var(--sm-basesize));
    width: calc(3 / var(--sm-basesize));
    height: calc(85 / var(--sm-basesize));
    background: var(--color-default);
  }
  .cta-heading::before {
    left: calc(30 / var(--sm-basesize) * -1);
    transform: rotate(-25deg);
  }
  .cta-heading::after {
    right: calc(30 / var(--sm-basesize) * -1);
    transform: rotate(25deg);
  }
  .cta-heading .fz-large {
    font-size: calc(40 / var(--sm-basesize));
  }
  .cta-action {
    margin-top: calc(20 / var(--sm-basesize));
  }
  .cta-button {
    position: relative;
    display: block;
    padding: calc(16 / var(--sm-basesize)) 0 calc(15 / var(--sm-basesize));
    background: url(../img/bg_cta_01.jpg) 50% 50% / cover no-repeat;
    border-radius: calc(20 / var(--sm-basesize));
    color: #fff;
    line-height: 1.3;
    letter-spacing: .05em;
    text-shadow: calc(5 / var(--sm-basesize) * -1) 0 0 rgba(0, 0, 0, .1);
  }
  .cta-button::after {
    content: '';
    position: absolute;
    top: 50%;
    right: calc(24 / var(--sm-basesize));
    width: calc(22 / var(--sm-basesize));
    height: calc(30 / var(--sm-basesize));
    background: url(../img/icn_cta_01.png) 0 0 / contain no-repeat;
    transform: translateY(-50%);
  }
  @media screen and (min-width: 1024px), print {
    .prologue {
        padding: 20px 0;
        background-size: 100% auto;
    }
  }
  @media (hover: hover) and (pointer: fine) {
    
    .cta-button {
      transition: filter .25s ease;
    }
    .cta-button::after {
      transition: right .25s ease;
    }
    .cta-button:hover {
      filter: brightness(1.075);
    }
    .cta-button:hover::after {
      right: calc(16 / var(--sm-basesize));
    }
}
.cta-button span {
pointer-events: none;
}
.cta-button .price {
color: #f7eb00;
}
.cta-button .price span {
font-size: 160%;
}
@media screen and (min-width: 1024px), print {
    .l-inner {
      width: min(100%, 1080px);
      margin: auto;
      padding: 0 40px;
    }
    .cta {
      width: 640px;
      margin: auto;
    }
    .cta-label span {
      margin-bottom: 10px;
      padding: 10px 25px;
    }
    .cta-label span::after {
      border-width: 8px;
    }
    .cta-label img {
      height: 23px;
    }
    .cta-heading::before,
    .cta-heading::after {
      top: 18px;
      width: 2px;
      height: 55px;
    }
    .cta-heading::before {
      left: -10px
    }
    .cta-heading::after {
      right: -10px;
    }
    .cta-heading .fz-large {
      font-size: 28px;
    }
    .cta-action {
      margin-top: 12px;
    }
    .cta-button {
      padding: 13px 0 24px;
      border-radius: 15px;
      font-size: 28px;
      line-height: 1.2;
      text-shadow: -3px 0 0 rgba(0, 0, 0, .1);
    }
    .cta-button::after {
      right: 30px;
      width: 17px;
      height: 24px;
    }
    @media (hover: hover) and (pointer: fine) {
      .cta-button:hover::after {
        right: 24px;
      }
    }
    .cta-button .price {
      font-size: 33px;
    }
    .cta-button .price span {
      font-size: 42px;
    }
}

.is-sp{
  display: block;
}
@media screen and (min-width: 1024px), print {
    .is-sp{
      display: none;
    }
}
.bk04{
  margin-top: 10rem;
}
/* 追加記述 --------------------------------*/
.video-container {
  max-width: 780px;
  margin: auto;
  text-align: center;
}

input[type="range"] {
  width: 70%;
  inset: 0;
  margin: auto;
  margin-left: 0;
}

.bar-container{
  position:relative;
  padding: 1em 0;
  background-color: #7E2B58;
}

.overlay-button {
  position: absolute;
  bottom: 5px;
  transform: translateX(-50%);
  z-index: 2;
  color: #fff;
  border: none;
  cursor: pointer;
}

#play-pause-button {
  position: absolute;
  z-index: 10;
  width: 5%;
  inset: 0;
  margin: auto;
  margin-left: 8%;
  color: #fff;
  font-size: 1em;
}

#play-pause-button svg{
  width: 16px;
  height: 16px;
}
#settings-button {
  inset: 0;
  margin: auto;
  width: 5%;
  margin-left: 89%;
}

#fullscreen-button {
  inset: 0;
  margin: auto;
  width: 5%;
  margin-left: 95%;
}

#volume-button {
  inset: 0;
  margin: auto;
  width: 5%;
  margin-left: 4%;
}

.overlay-menu {
  position: absolute;
  bottom: 40px;
  left: 85%;
  background-color: rgba(0, 0, 0, 0.7);
  padding: 5px;
  border-radius: 5px;
  z-index: 3;
}

#volume-slider {
  position: absolute;
  bottom: 50px;
  left: 10px;
  z-index: 3;
  transform: rotate(-90deg);
  transform-origin: 0% 65%;
  width: 120px;
}

.speed-option {
  display: block;
  color: white;
  padding: 5px;
  text-align: center;
  border: none;
  background: none;
  cursor: pointer;
}

.speed-option:hover {
  background-color: rgb(255, 255, 255);
}

#progress-bar,
#settings-button,
#fullscreen-button,
#play-pause-button,
#volume-button {
  opacity: 1;
  transition: opacity 0.5s;
}

.video-container:hover #progress-bar,
.video-container:hover #settings-button,
.video-container:hover #fullscreen-button,
.video-container:hover #play-pause-button,
.video-container:hover #volume-button {
  opacity: 1;
}
/* WebKit (Chrome, Safari, Edge, Opera) のスタイル */
#progress-bar {
  -webkit-appearance: none;
  background: #e0e0e0; /* バーの背景色 */
  outline: none; /* デフォルトのアウトラインを消す */
  border-radius: 5px;
  overflow: hidden;
}

#progress-bar::-webkit-slider-runnable-track {
  background: linear-gradient(to right, #fff, #fff); /* バーの色 */
}

#progress-bar::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  background: #DBD5D5; /* つまみの色 */
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 0 2px rgba(0, 0, 0, 0.6); /* つまみの影 */
}

/* Firefox のスタイル */
#progress-bar::-moz-range-track {
  background: linear-gradient(to right, #fff, #fff); /* バーの色 */
}

#progress-bar::-moz-range-thumb {
  width: 16px;
  height: 16px;
  background: #DBD5D5; /* つまみの色 */
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 0 2px rgba(0, 0, 0, 0.6); /* つまみの影 */
}

/* 進行中の色を変更する */
#progress-bar::-ms-fill-lower {
  background: linear-gradient(to right, #fff, #fff); /* バーの色 */
}

video {
  width: 100%;
  height: 100%;
  border: #7E2B58 4px solid;
}
.bar-container::after {
  position: absolute;
  content: "";
  pointer-events: none;
  display: block;
  width: 16%;
  height: 200%;
  background: url(https://nico.team/lp/movie/m001/gsn/img/movie_btn.png) no-repeat center/contain;
  inset: 0;
  margin: auto;
  margin-bottom: 28%;
}
.bar-container.show-overlay::after {
  display: block; /* 停止中は表示 */
}

.bar-container.no-overlay::after {
  display: none; /* 再生中は非表示 */
}

.banner-bottom {
  display: none; /* 初期状態で非表示 */
  position: fixed;
  bottom: 0;
  left: 22%;
  max-width: 780px;
  width: 100%;
  background-color: transparent; /* バナーに合わせて背景透明に */
  padding: 10px;
  text-align: center;
  z-index: 1000;
}

.banner-bottom img {
  max-width: 100%; /* バナー画像を画面幅に収める */
  height: auto;
}

.banner {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #7E2B58;
  color: white;
  padding: 20px;
  z-index: 9999;
  display: none;
}
.banner button {
  position: absolute;
  top: 10px;
  right: 10px;
  background-color: transparent;
  border: none;
  color: #000;
  font-size: 20px;
  cursor: pointer;
}
@media screen and (max-width: 768px){
  .banner-bottom {
    width: 100%;
  }
  #play-pause-button svg{
    width: 12px;
    height: 12px;
  }
  #volume-button svg{
    width: 16px;
    height: 15px;
  }
  #speed-options svg{
    width: 12px;
    height: 12px;
  }
  #fullscreen-button svg{
    width: 15px;
    height: 16px;
  }
  input[type="range"] {
    width: 65%;
  }
  #settings-button{
    margin-left: 87.5%;
  }
  #play-pause-button{
    margin-left: 9%;
    font-size: .8em;
  }

}