@charset "utf-8";

/* ベース */
body {
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", sans-serif;
  line-height: 1.5;
}

img,
embed,
object,
iframe {
  vertical-align: middle;
}

a,
a img {
  transition-duration: .5s;
}

a:hover {
  color: inherit;
}

/* 共通 */
.l-header__inner,
.l-footer__inner,
.p-hero__inner {
  margin: 0 auto;
}

a.p-header__logo,
a.p-footer__img {
  transition-duration: .5s;
}

a.p-header__logo:hover,
a.p-footer__img:hover {
  opacity: .6;
}

/* ↓↓↓↓↓↓↓↓ レイアウト ↓↓↓↓↓↓↓↓ */
/* ヘッダーレイアウト */
.l-header--blue {
  background-color: #EDF4FF;
}

.l-header__inner {
  padding: 12px 18px 24px;
}

/* メインレイアウト */
.l-main__wrapper {
  position: relative;
  overflow: hidden;
}

.l-main__wrapper::before,
.l-main__wrapper::after {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  content: "";
  width: 100%;
}

.l-main__wrapper::before {
  top: 0;
  height: 160px;
  border-radius: 50% 50% 0 0;
}

.l-main__wrapper::after {
  top: 80px;
  height: 100%;
}

.l-main__wrapper--white {
  background-color: #EDF4FF;
}

.l-main__wrapper--white::before,
.l-main__wrapper--white::after {
  background-color: #fff;
}

.l-main__wrapper--blue {
  background-color: #fff;
}

.l-main__wrapper--blue::before,
.l-main__wrapper--blue::after {
  background-color: #EDF4FF;
}


/* フッターレイアウト */
.l-footer {
  padding: 12px 18px;
}

.l-footer__copy {
  margin: 14px 0 0;
}


/* ↓↓↓↓↓↓↓↓ プロジェクト ↓↓↓↓↓↓↓↓ */
/* ヘッダーコンテンツ */
.p-header__heading {
  font-size: 12px;
}

.p-header__logo {
  display: block;
  max-width: 130px;
}

.p-header__logoImg {
  width: 100%;
}

/* ファーストビュー */
.p-hero {
  position: relative;
  width: 100%;
  z-index: 1000;
}

.p-hero__inner {
  padding: 50px 20px 10px;
}


/* 各セクション */
.p-section {
  position: sticky;
  background-color: #fff;
  margin: 0 auto;
  padding: 0 0 20px;
  z-index: 1000;
}

.p-section__inner {
  margin: 0 auto;
  padding: 0 18px 0px;
}


.p-section__row,
.p-section__col {
  height: 100%;
}

.p-section__banner {
  margin: 30px auto 0;
}

.p-section__conversion {
  margin: 40px auto 0;
}

.p-section__recommend {
  margin: 30px auto 0;
}

.p-section__button {
  margin: 30px auto 0;
}

.p-section__button {
  max-width: 340px;
}

.p-section__button2 {
  margin: 24px auto 0;
}

.p-section__button2 {
  max-width: 340px;
}

.p-section__invi {
  margin: 30px auto 0;
}




/* インフォメーションエリア */
.p-info {
  position: sticky;
  /* background-color: #EDF4FF; */
  z-index: 1000;
}

.p-info__inner {
  padding: 0 18px 48px;
}

.p-info__contents {
  margin: 74px auto 0;
}

.p-info__contents:first-child {
  margin: 100px auto 0;
}

/* フッターコンテンツ */
.p-footer,
.p-footer__col {
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
}

.p-footer__img {
  display: block;
  margin: 0 0 0 18px;
}

.p-footer__img:first-child {
  margin: 0;
}

.p-footer__img--youtube {
  max-width: 30px;
}

.p-footer__img--twitter {
  max-width: 30px;
}

.p-footer__img--itscom {
  max-width: 120px;
}

/* ↓↓↓↓↓↓↓↓ コンポーネント ↓↓↓↓↓↓↓↓ */
/* バナー */
.c-banner {
  -webkit-filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.6));
  filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.6));
  transform: translateZ(0);
  transition-duration: .5s;
  margin: 20px auto 0;
}

.c-banner:hover img {
  transform: scale(1.05);
}

/* カードコンテンツ */
.c-card {
  display: block;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.6);
  border-radius: 10px;
  height: 100%;
  margin: 20px auto 0;
  padding: 20px 10px;
  transition-duration: .5s;
}

.c-card:hover {
  transform: scale(1.05);
}

.c-card__cap {
  display: flex;
  align-items: center;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  background-color: #D21577;
  height: 60px;
  padding: 10px 18px;
}

.c-card__text {
  color: initial;
  font-size: 14px;
  padding: 12px 0;
}


/* インフォメーションコンテンツ */
.c-info {
  position: relative;
  border-radius: 10px;
  padding: 60px 20px 54px;
}

.c-info--twitter,
.c-info--youtube {
  background-image: url("/ch/img/tw_bg.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 0px 96%;
}

.c-info--twitter {
  background-color: #B3DBFD;
}

.c-info--youtube {
  background-color: #ffd6da;
}

/* .c-info--twitter .c-info__contents {
  height: 420px;
} */

.c-info__titleWrap {
  position: absolute;
  top: -34px;
  left: 50%;
  transform: translateX(-50%);
}

.c-info__title {
  position: relative;
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  text-align: center;
  white-space: nowrap;
  background-color: #fff;
  font-weight: bold;
  line-height: 1.8;
  color: #02165A;
  width: 100%;
  height: 70px;
  border-radius: 8px;
  padding: 10px 18px 10px 36px;
}

/* .c-info--twitter .c-info__title::after,
.c-info--youtube .c-info__title::after {
  position: absolute;
  top: 50%;
  left: 14px;
  content: "";
  width: 20px;
  height: 20px;
  background-size: 20px;
  background-repeat: no-repeat;
  transform: translateY(-50%);
}

.c-info--twitter .c-info__title::after {
  background-image: url("/ch/img/logo_twitter@2x.png");
}

.c-info--youtube .c-info__title::after {
  background-image: url("/ch/img/logo_youtube@2x.png");
} */

.c-info__titleSmall {
  font-size: 16px;
}

.c-info__titleLarge {
  font-size: 18px;
}

.c-info__title::before {
  position: absolute;
  content: "";
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 26px;
  height: 16px;
  border-top: solid 16px #fff;
  border-right: solid 13px transparent;
  border-left: solid 13px transparent;
}

.c-info__contents,
.c-info__slider {
  max-width: 300px;
  height: auto;
  margin: 0 auto;
}

.c-info__slider {
  /* height: 196px; */
  height: 168.75px;
}

.c-info__slider a {
  position: relative;
}

.c-info__slider a::before {
  position: absolute;
  top: 50%;
  left: 50%;
  content: "";
  background-image: url("/ch/top/img/logo_youtube@2x.png");
  background-size: 100%;
  background-repeat: no-repeat;
  width: 68px;
  height: 48px;
  transform: translate(-50%, -50%);
}

.c-info__slider iframe {
  width: 100%;
  height: 100%;
}

/* ボタン */
/* .c-button {
  padding: 2vw 8vw;
}

.c-button--small {
  padding: 2vw 6vw;
} */



/* おすすめ番組 */
.c-recommend {
  border: solid 4px #FF7600;
  padding: 18px 14px;
}

.c-recommend__title {
  font-size: 20px;
  font-weight: bold;
  color: #FC7600;
  text-align: center;
}

.c-recommend__leed {
  font-size: 14px;
  max-width: 770px;
  margin: 10px auto 0;
}

.c-recommend__img {
  max-width: 600px;
  margin: 10px auto 0;
}

.c-recommend__conversion {
  margin: 20px auto 0;
}




.c-recommend01 {
  border: solid 2px #0000cc;
  border-radius: 10px;
  padding: 18px 14px;
}


.c-recommend__leed01 {
  font-size: 14px;
  max-width: 770px;
  margin: 0px auto 0;
  color:#0000cc;
}

.p-section01 {
  position: sticky;
  background-color: #fff;
  margin: 0 auto;
  padding: 0 0 0px;
  z-index: 1000;
}



.p-section__inner01{
    margin: 0 auto;
  padding: 0 18px 0px;

}

  span.c-recommend__leed001{
    font-size: 12px;
    color:#0000cc;
  }



@media screen and (min-width: 769px) {

  /* 共通 */
  .l-header__inner,
  .l-footer__inner,
  .p-intro__inner,
  .p-suggest__inner {
    max-width: 1280px;
  }

  /* ↓↓↓↓↓↓↓↓ レイアウト ↓↓↓↓↓↓↓↓ */
  /* ヘッダーレイアウト */
  .l-header__inner {
    padding: 16px 140px 40px;
  }

  /* メインレイアウト */
  .l-main__wrapper::before {
    top: 0;
    height: 340px;
    border-radius: 50% 50% 0 0;
  }

  .l-main__wrapper::after {
    top: 170px;
    height: 100%;
  }


  /* フッターレイアウト */
  .l-footer {
    padding: 30px 0;
  }

  .l-footer__inner {
    padding: 0 140px;
  }

  .l-footer__copy {
    text-align: right;
    margin: 10px 0 0;
    padding: 0 10px 0 0;
  }

  /* ↓↓↓↓↓↓↓↓ プロジェクト ↓↓↓↓↓↓↓↓ */
  /* ヘッダーコンテンツ */
  .p-header__heading {
    font-size: 14px;
  }

  .p-header__logo {
    max-width: 260px;
  }

  /* ファーストビュー */
  .p-hero::before {
    height: 170px;
    border-bottom: solid 170px transparent;
  }

  .p-hero__inner {
    max-width: 1280px;
    padding: 30px 60px;
  }

  .p-hero__img {
    max-width: 1000px;
    margin: 0 auto;
  }


  /* 各セクション */
  .p-section {
    margin: 0 auto;
    padding: 0 0 40px;
  }

  .p-section__inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 140px 0px;
  }

  .p-section__banner {
    max-width: 800px;
    margin: 50px auto 0;
  }

  .p-section__banner2 {
    max-width: 460px;
    margin: 50px auto 0;
  }

  .p-section__conversion {
    margin: 60px auto 0;
  }

  .p-section__recommend {
    margin: 50px auto 0;
  }

  .p-section__button {
    margin: 55px auto 0;
  }

  .p-section__button {
    max-width: 600px;
  }


  .p-section__button2 {
    margin: 40px auto 0;

  }

  .p-section__button2 {
    max-width: 600px;
  }

  /* インフォメーションエリア */
  .p-info__inner {
    max-width: 1120px;
    padding: 84px 0 100px;
    margin: 0 auto;
  }

  .p-info__contents {
    margin: 140px auto 0;
  }

  .p-info__contents:first-child {
    margin: 150px auto 0;
  }


  /* フッターコンテンツ */

  .p-footer__img {
    margin: 0 0 0 40px;
  }

  .p-footer__img--youtube {
    max-width: 50px;
  }

  .p-footer__img--twitter {
    max-width: 50px;
  }

  .p-footer__img--itscom {
    max-width: 220px;
  }


  /* ↓↓↓↓↓↓↓↓ コンポーネント ↓↓↓↓↓↓↓↓ */
  /* カードコンテンツ */
  .c-card {
    margin: 20px auto 0;
    padding: 20px 10px;
  }

  .c-card__cap {
    font-size: 20px;
    height: 70px;
  }

  .c-card__text {
    font-size: 18px;
  }

  /* インフォメーションコンテンツ */
  .c-info {
    border-radius: 30px;
    padding: 160px 60px 74px;
  }

  .c-info__titleWrap {
    top: -70px;
  }

  .c-info__title {
    width: 100%;
    max-width: 900px;
    height: 170px;
    border-radius: 24px;
    padding: 30px 140px 30px 170px;
  }

  .c-info--twitter .c-info__title::after,
  .c-info--youtube .c-info__title::after {
    top: 50%;
    left: 100px;
    width: 56px;
    height: 56px;
    background-size: 56px;
  }

  .c-info__titleSmall {
    font-size: 30px;
  }

  .c-info__titleLarge {
    font-size: 36px;
  }

  .c-info__title::before {
    top: 100%;
    left: 50%;
    width: 52px;
    height: 30px;
    border-top: solid 30px #fff;
    border-right: solid 26px transparent;
    border-left: solid 26px transparent;
  }

  .c-info__contents,
  .c-info__slider {
    max-width: 610px;
    height: auto;
    margin: 0 auto;
  }

  .c-info__slider {
    height: 350px;
  }

  /* ボタン */
  /* .c-button {
    padding: 20px 80px;
  }

  .c-button--small {
    padding: 4px 20px;
  } */


  /* おすすめ番組 */
  .c-recommend {
    padding: 16px 16px 30px;
  }

  .c-recommend__title {
    text-align: center;
    font-size: 36px;
  }

  .c-recommend__leed {
    font-size: 18px;
    margin: 10px auto 0;
  }

  .c-recommend__img {
    margin: 20px auto 0;
  }

  .c-recommend__conversion {
    margin: 30px auto 0;
  }

.c-recommend01 {
  border: solid 2px #0000cc;
  border-radius: 10px;
  padding: 0px ;
}

  .c-recommend__leed01 {
    font-size: 15px;
    margin: 0px auto 0;
    padding: 12px;
  }

    .p-section01 {
    margin: 0 auto;
    padding: 0 0 0px;
  }
  
  .p-section__inner01 {
    max-width: 950px;
    margin: 0 auto;
    padding: 0px 140px 0;
  }

  span.c-recommend__leed001{
    font-size: 13px;
  }

}


/* ↓↓↓↓↓↓↓↓ Swiper ↓↓↓↓↓↓↓↓ */
.swiper {
  position: relative;
  overflow: inherit;
}

.swiper-slide-prev::before,
.swiper-slide-next::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, .6);
}

.swiper-button-prev,
.swiper-button-next,
.swiper-button-prev::before,
.swiper-button-next::before {
  position: absolute;
  top: 50%;
  z-index: 1000;
}

.swiper-button-prev,
.swiper-button-next {
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 36px;
  background-color: #fff;
  opacity: .8;
}

.swiper-button-prev {
  left: -30px;
}

.swiper-button-next {
  right: -30px;
}

.swiper-button-prev::before,
.swiper-button-next::before {
  content: "";
  transform: translate(-50%, -50%);
  left: 50%;
  width: 9px;
  height: 16px;
  border-top: solid 8px transparent;
  border-bottom: solid 8px transparent;
}

.swiper-button-prev::before {
  border-right: solid 9px #000;
}

.swiper-button-next::before {
  border-left: solid 9px #000;
}

@media screen and (min-width: 769px) {

  .swiper-button-prev,
  .swiper-button-next {
    width: 80px;
    height: 80px;
    border-radius: 80px;
  }

  .swiper-button-prev {
    left: -100px;
  }

  .swiper-button-next {
    right: -100px;
  }

  .swiper-button-prev::before,
  .swiper-button-next::before {
    width: 20px;
    height: 36px;
    border-top: solid 18px transparent;
    border-bottom: solid 18px transparent;
  }

  .swiper-button-prev::before {
    border-right: solid 20px #000;
  }

  .swiper-button-next::before {
    border-left: solid 20px #000;
  }
}


/* ↓↓↓↓↓↓↓↓ Modaal ↓↓↓↓↓↓↓↓ */
/*全て共通：hideエリアをはじめは非表示*/
.hide-area {
  display: none;
}

/*全て共通：モーダルのボタンの色を変更したい場合*/
.modaal-close:after,
.modaal-close:before {
  background: #ccc;
}

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before {
  background: #666;
}

/*確認を促すモーダル：タイトルの色を変更したい場合*/
#modaal-title {
  font-size: 1.2rem;
  text-align: center;
  margin: 0 0 20px 0;
}

/*動画表示のモーダル：余白を変更したい場合*/
.modaal-video .modaal-inner-wrapper {
  padding: 0;
}

.modaal-wrapper {
  background-color: rgba(255, 255, 255, .3);
}

.modaal-overlay {
  background-color: inherit !important;
}