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

p {margin-bottom: 2%; !important}/*220421*/

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

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

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

/*220421*/
#slideshow-pc {
  display: block; }
#slideshow-sp {
  display: none; }


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

/*220421*/
  #slideshow-pc {
    display: none; }
  #slideshow-sp {
    display: block; }
}

/*
========== slide-wrap(220421) ==========
*/

#slideshow-pc img {
   position: absolute;
   top: 0;
   left:0;
   z-index: 8;
   opacity: 0.0;
}
#slideshow-sp img {
   position: absolute;
   top: 0;
   left:0;
   z-index: 8;
   opacity: 0.0;
}

#slideshow-pc img.active {
   z-index: 10;
   opacity: 1.0;
}
#slideshow-sp img.active {
   z-index: 10;
   opacity: 1.0;
}

#slideshow-pc img.last-active {
   z-index: 9;
}
#slideshow-sp img.last-active {
   z-index: 9;
}


#slideshow-pc, #slideshow-sp {
   position: relative;
   width:  100%; /* 画像の横幅に合わせて記述 */
   height: 600px; /* 画像の高さに合わせて記述 */
}

@media screen and (max-width: 820px) {
	#slideshow-pc, #slideshow-sp {
	   position: relative;
	   width:  100%; /* 画像の横幅に合わせて記述 */
	   height: 460px; /* 画像の高さに合わせて記述 */
	}
}
@media screen and (max-width: 769px) {
	#slideshow-pc, #slideshow-sp {
	   position: relative;
	   width:  100%; /* 画像の横幅に合わせて記述 */
	   height: 420px; /* 画像の高さに合わせて記述 */
	}
}
@media screen and (max-width: 480px) {
	#slideshow-pc, #slideshow-sp {
	   position: relative;
	   width:  100%; /* 画像の横幅に合わせて記述 */
	   height: 430px; /* 画像の高さに合わせて記述 */
	}
}
@media screen and (max-width: 376px) {
	#slideshow-pc, #slideshow-sp {
	   position: relative;
	   width:  100%; /* 画像の横幅に合わせて記述 */
	   height: 390px; /* 画像の高さに合わせて記述 */
	}
}

/*
========================================
*/

.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: 50px;
  margin-top: 80px;
}
.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;
}
#nippounoie .line-section__title,/*220421*/
#ouboyoukou .line-section__title {/*210608*/
    margin-bottom: 50px;
}
#nippounoie h3,/*220421*/
#ouboyoukou h3 {/*210608*/
  font-size: 26px;
  text-align: center;
  font-weight: bold;/*220421*/
}

@media screen and (max-width: 480px) {
  .line-section__title {
    margin-bottom: 22px !important;
  }
  #nippounoie h3 {/*220421*/
  font-size: 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(/ie/assets/images/line/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;
  }
}
