@charset "UTF-8";
@media screen and (max-width: 480px) {
  html,
body {
    height: 100%;
    /* sp時に高さを画面いっぱいに */
  }
}

/*******************************************************************************
メインビジュアル
*******************************************************************************/

.pcD {/*210608*/
  display: block; }

.spD {/*210608*/
  display: none; }

figure {/*210608*/
    position: relative;
    width: 100%;
    overflow: hidden;
}

@media only screen and (max-width: 768px) {/*210608*/
  .pcD {
    display: none; }
  .spD {
    display: block; } }

/*
==================== top_movieplayer ====================
*/
#top_movieplayer {
	position: relative;
	overflow: hidden;
	width: 100%;
	height: 100%;
	background-color: #fff;
}
.sprite-container {
	position: relative;
}
.cover-image {
	position: absolute;
	width: 100%;
	opacity: 0;
	z-index: 5;
}
#top_movieplayer_inner {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	vertical-align:	bottom;
	/*z-index: 20; opacity: 0;*/
}
.movie-cover {
	cursor: pointer; 
	background-color: #fff;
	width: 100%;
	margin: 0;
	line-height: 0;
	position: relative;
	display: block;
	height: 100%;
	z-index: 2;
	opacity: 1;
}
.playbtn {
    cursor: pointer;
    display: none;
    position: absolute;
    top: 72%;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    width: 48px;
    height: 48px;
    background-image: url("../img/sprites-seaf6b24ff4.png");
    background-position: 0 0;
    background-repeat: no-repeat;
    background-size: 48px,auto;
    z-index: 15;
    opacity: 1;
}

.loading {
    background-image: url("../img/loading.png");
    background-size: 44px,auto;
    width: 44px;
    height: 44px;
    display: block;
    position: absolute;
    top: 72%;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    z-index: 10;
}

/**/
.company dl {
display: flex;
flex-flow: row wrap;
width: 100%;
	margin-bottom: 20px;
}
.company dt {
flex-basis: 15%;
padding: 10px;
background: #8e8e8e;
border-bottom: 1px solid #f7f7f7;
font-size: 14px;
	color: #fff;
	font-weight: bold;
	text-align: center;
}
.company dd {
flex-basis: 85%;
padding: 10px;
background: #fff;
border-bottom: 1px solid #f7f7f7;
font-size: 14px;
}
@media screen and (max-width: 768px) {
.company dl {
flex-flow: column;
}
.playbtn {
cursor: pointer;
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    width: 80px;
    height: 80px;
    background-image: url(../img/sprites-seaf6b24ff4.png);
    background-position: 0 0;
    background-repeat: no-repeat;
    background-size: 80px,auto;
    z-index: 15;
    opacity: 1 !important;
}
.loading {
    background-image: url("../img/loading.png");
    background-size: 44px,auto;
    width: 44px;
    height: 44px;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    z-index: 10;
}
}
/*
========================================
*/


.main-visual {
  /*min-height: 500px;*//*210608*/
  padding: 0 0 0;
  /*padding: 39px 0 0;*//*210608*/
  /*background: #f2f2f2;*//*210608*/
}

@media screen and (max-width: 700px) {
  .main-visual {
    /*padding: 22px 0 20px;*//*210608*/
    min-height: auto;
  }
}
@media screen and (max-width: 480px) {
  .main-visual {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    /*height: calc(100% - 60px);*//*210608*/
    /*min-height: 438px;*//*210608*/
    margin-bottom: 30px !important;
    /*padding-top: 16px;*//*210608*/
  }
}
.main-visual__body {
  display: flex;
  justify-content: center;
}

@media screen and (max-width: 480px) {
  .main-visual__body {
    flex-direction: column;
    justify-content: flex-start;
    /*margin-top: -86px;*//*210608*/
  }
}
@media screen and (max-width: 374px) {
  .main-visual__body {
    margin-top: -130px;
  }
}
.main-visual__figure {
  width: 302px;
  margin: 6px 0 0 !important;
}
@media screen and (max-width: 700px) {
  .main-visual__figure {
    width: 175px;
  }
}
@media screen and (max-width: 480px) {
  .main-visual__figure {
    max-width: 205px;
    width: 24.5vh;
    margin: 0 auto !important;
  }
}
@media screen and (max-width: 374px) {
  .main-visual__figure {
    padding: 0 8px;
  }
}
.main-visual__title {
  width: 390px;
  margin: 72px 0 0 -15px;
}
@media screen and (max-width: 700px) {
  .main-visual__title {
    width: 260px;
    margin: 40px 0 0 -5px;
  }
}
@media screen and (max-width: 480px) {
  .main-visual__title {
    max-width: 330px;
    width: 43vh;
    margin: 1vh auto 0;
  }
}
@media screen and (max-width: 374px) {
  .main-visual__title {
    padding: 0 16px;
  }
}

.main-visual-firefox,
.main-visual-others {
  vertical-align: top;
}

/* firefox以外のブラウザはsvgの画像非表示 */
.main-visual-firefox {
  display: none;
}

/* firefoxのみpngの画像表示 */
@-moz-document url-prefix() {
  .main-visual-firefox {
    display: block;
  }

  .main-visual-others {
    display: none;
  }
}
/*******************************************************************************
メインコンテンツ
*******************************************************************************/
.line-main {
  display: block;
  /* ieのバグ回避 */
  margin-bottom: 65px;
}
@media screen and (max-width: 480px) {
  .line-main {
    margin-bottom: 0;
  }
}

/*******************************************************************************
リード文
*******************************************************************************/
.lead-section {
  max-width: 717px;
  width: 100%;
  margin: 80px auto 80px;
}
@media screen and (max-width: 768px) {
  .lead-section {
    padding: 0 30px;
  }
}
@media screen and (max-width: 700px) {
  .lead-section {
    max-width: 450px;
  }
}
@media screen and (max-width: 480px) {
  .lead-section {
    max-width: 296px;
    width: 100%;
    margin: 30px auto 60px;
    /*margin: 30px auto 90px;*/
    padding: 0;
  }
}
@media screen and (max-width: 374px) {
  .lead-section {
    padding: 0 15px;
  }
}

/*210608*/
/*******************************************************************************
イメージ
*******************************************************************************/
.img-section {
  max-width: 717px;
  width: 100%;
  margin: 80px auto 80px;
}
@media screen and (max-width: 768px) {
  .img-section {
    padding: 0 30px;
  }
}
@media screen and (max-width: 700px) {
  .img-section {
    max-width: 450px;
  }
}
@media screen and (max-width: 480px) {
  .img-section {
    /*max-width: 296px;*/
    width: 100%;
    margin: 30px auto 30px;
    padding: 0;
  }
}
@media screen and (max-width: 374px) {
  .img-section {
    padding: 0 15px;
  }
}

/*******************************************************************************
共通のタイトルのスタイル
*******************************************************************************/
.section-title {
  display: flex;
  width: 269px;
  margin: 0 auto;
}
@media screen and (max-width: 480px) {
  .section-title {
    width: 167px;
  }
}

/*******************************************************************************
友だち追加
*******************************************************************************/
.friend-section {
  margin-bottom: 86px !important;
  text-align: center;
}
.friend-section__title {
  margin-bottom: 64px;
}
.friend-section__figure {
  display: flex;
  width: 200px;
}
.friend-section__txt {
  margin-top: 26px;
  margin-bottom: 0;
  font-size: 15px;
  font-weight: bold;
  line-height: 1.66;
}

/*******************************************************************************
LINEでできること
*******************************************************************************/
.line-section {
  max-width: 660px;
}
@media screen and (max-width: 768px) {
  .line-section {
    max-width: 430px;
  }
}
.line-section__title {
  margin-bottom: 85px;
}
#ouboyoukou .line-section__title {/*210608*/
    margin-bottom: 50px;
}
#ouboyoukou h3 {/*210608*/
  font-size: 26px;
  text-align: center;
}

@media screen and (max-width: 480px) {
  .line-section__title {
    margin-bottom: 22px;
  }
}
.line-section__body {
  display: flex;
  flex-wrap: wrap;
  /*margin-top: -75px;*//*210608*/
  margin-left: -30px;
}

.line-section__body ul.asterisk {/*210608*/
  padding-left: 6em;
  text-indent: -6em;
}

@media screen and (max-width: 480px) {
  .line-section__body {
    /*margin-top: -47px;*//*210608*/
    margin-left: 0;
  }
  
  .line-section__body ul.asterisk p{/*210608*/
    margin-bottom: 8%;
  }
}

/* アイコン */
.line-figure {
  width: 200px;
  margin: 75px 0 0 30px !important;
  text-align: center;
}
@media screen and (max-width: 480px) {
  .line-figure {
    width: 50%;
    margin: 47px 0 0 0 !important;
  }
}
.line-figure img {
  width: 110px;
  margin-bottom: 18px;
}
@media screen and (max-width: 480px) {
  .line-figure img {
    width: 86px;
  }
}
.line-figure--mt10 img {
  margin-top: -10px;
  margin-bottom: 28px;
}
@media screen and (max-width: 768px) {
  .line-figure--mt10 img {
    margin-top: 0;
    margin-bottom: 18px;
  }
}
.line-figure--mb30 img {
  margin-bottom: 30px;
}
.line-figure__caption {
  margin-top: auto;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.61;
}
@media screen and (max-width: 480px) {
  .line-figure__caption {
    font-size: 15px;
    line-height: 1.6;
  }
}

/*******************************************************************************
友だち追加ボタン
*******************************************************************************/
.button-section {
  height: 60px;
  margin-bottom: 0 !important;
  text-align: center;
}
.button-section__button {
  position: fixed;
  bottom: 20px;
  left: 50%;
  z-index: 3;
  transform: translateX(-50%);
  display: inline-block;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  border-radius: 0;
  background: transparent;
}
.button-section__button.is-unfixed {
  /* 固定解除のクラス */
  position: static;
  transform: none;
}
.button-section__button a {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 216px;
  height: 60px;
  padding-right: 44px;
  background: url(../../../img/bg_line.svg) center center/contain no-repeat;
  font-size: 15px;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
}

/*******************************************************************************
要素の表示、非表示
*******************************************************************************/
/* タブレット */
@media screen and (max-width: 768px) {
  .hide-tb {
    display: none;
  }
}

.show-tb {
  display: none;
}
@media screen and (max-width: 768px) {
  .show-tb {
    display: block;
  }
}

/* タブレット スモール */
@media screen and (max-width: 700px) {
  .hide-tb-sm {
    display: none;
  }
}

.show-tb-sm {
  display: none;
}
@media screen and (max-width: 700px) {
  .show-tb-sm {
    display: block;
  }
}

/* スマートフォン */
@media screen and (max-width: 480px) {
  .hide-sp {
    display: none;
  }
}

.show-sp {
  display: none;
}
@media screen and (max-width: 480px) {
  .show-sp {
    display: block;
  }
}
