@charset "UTF-8";

body {
  background: #fff;
  font-family:Helvetica, Arial, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, 游ゴシック体, "Yu Gothic", YuGothic, Osaka,  "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  /*font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, sans-serif;*/
  color: #333;
  font-size: 16px;
  line-height: 1.84;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-weight:500;
}

a {
  color: #2c2764;
}

a[href^="tel"] {
  color: inherit;
}

.js-focus-visible :focus:not(.focus-visible) {
  outline: none;
}

/* layout ============================================================ */

.header_in,
.contents_in {
  max-width: 1400px;
  margin: 0 auto;
}

.top_page .header_in {
  /*max-width: none;*/
}

.contents {
  padding: 40px 10px 0;
  margin: 0 0 40px;
}

.top_page .contents {
  margin: 0;
}

@media print, screen and (max-width: 768px) {

}

@media print, screen and (max-width: 640px) {

  .contents {
    padding: 40px 10px 0;
  }

}

@media print, screen and (max-width: 480px) {

  .contents {
    padding: 30px 10px 0;

  }

}

.top_page .contents {
  padding: 0;
}

/* end layout */

/* header  ============================================================ */

.header {
  position: absolute;
  box-sizing: border-box;
  top: 0;
  left: 0;
  z-index: 8000;
  width: 100%;

  -webkit-transition: all 0.3s ease;
  transition: all  0.3s ease;
  height:70px

}
@media print, screen and (max-width: 768px) {
  .header {
    position: absolute;
    box-sizing: border-box;
    top: 0;
    left: 0;
    z-index: 8000;
    width: 100%;

    -webkit-transition: all 0.3s ease;
    transition: all  0.3s ease;
    background: transparent;
    background-image:none;
    height:auto;

  }
}


.header.is-fixed {
  position: fixed;
  /*background: #661772;*/
}

.header_in {
  position: relative;

}


/* hamburger */

#headmenu {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 8002;
}

.hamburger {
  padding: 10px;
  transform: scale(1.5);
  transform-origin: top right;
}
@media print, screen and (max-width: 768px) {
  .hamburger {
    padding: 10px;
    transform: scale(1.5);
    transform-origin: top right;
    display:block;
  }
}


.hamburger-inner,
.hamburger-inner:after,
.hamburger-inner:before {
  background: #ff788e;
  height: 2px;
}

.hamburger.is-active .hamburger-inner,
.hamburger.is-active .hamburger-inner:after,
.hamburger.is-active .hamburger-inner:before {
  background-color: #fff;
}

/* nav */

#headnav {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 8001;
  box-sizing: border-box;
  background: #e62e8b;
  /*background: rgba(201, 12, 0, .9);*/
  overflow: auto;
}

.headnav_in {
  min-height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

#headnav ul {
  padding: 50px 10px;
  width:90%;
  margin:0 auto;
  text-align:center;
}

#headnav li a {
  display: block;
  text-decoration: none;
  text-align: center;
  color: #fff;
  padding: .4em;
  font-size: 30px;
  font-weight: bold;
}


#headnav li a:hover {
  opacity: .6;
}

@media print, screen and (min-width: 993px) {

  .top_page .logo {
    visibility: hidden;
  }

  .top_page #headmenu {
    top: 10px;
    right: 10px;
  }

  .top_page .header {
    padding: 0 0 20px;
    margin: 0;
  }

}

@media print, screen and (max-width: 992px) {

}

@media print, screen and (max-width: 768px) {

}

@media print, screen and (max-width: 640px) {

  .header {
    padding: 10px;
  }

  .header .logo {
    width: 110px;
  }

  #headmenu {
    top: 10px;
  }

  .hamburger {
    padding: 10px;
    transform: scale(1.1);
  }

  #headnav li a {
    font-size: 18px;
  }
  #headnav li#tw,#headnav li#ytb{width:42%; margin:20px 10px;}
  #headnav li#tw a {font-size:16px;}
  #headnav li#ytb a {font-size:16px;}


}

@media print, screen and (max-width: 480px) {

  .header {
    padding: 20px calc( 20 / 375 * 100vw );
  }

  .header .logo {
    width: 70px;
  }

  #headmenu {
    top: 5px;
  }

  .hamburger {
    padding: 0px;
    transform: scale(.8);
  }
  #headnav li#tw,#headnav li#ytb{width:70%; margin:10px 10px 0;}
}

/* end header */

/* contents  ============================================================ */

/* title */

.section_ttl {
  margin: 0 0 80px;
}

.section_sub_ttl {
  margin: 0 0 20px;
}

.section_sub_ttl h2 {
  font-size: 32px;
  font-weight: bold;
  line-height: 1.4;
}

.section_sub_ttl img {
  height: 30px;
}

/* text */

.font_bold {
  font-weight: bold;
}

.txt_hanging {
  margin-left: 1em;
  text-indent: -1em;
}

/* button */

.btn,
.btn-large {
  display: inline-block;
  box-sizing: border-box;
  font-weight: bold;
  line-height: 1.4;
  color: #8b3f85;
  background: #fff;
  text-decoration: none;
  -webkit-transition: all .4s;
  transition: all .4s;
  max-width: 100%;
}

.btn:hover,
.btn-large:hover {
  color: #fff;
  background: #030000;
  text-decoration: none;
}

.btn-large {
  font-size: 24px;
  min-width: calc( 280 / 24 * 1em );
  padding: calc( 18 / 24 * 1em ) calc( 30 / 24 * 1em );
  border-radius: 8px;
  border-radius: calc( 10 / 24 * 1em );
}

.btn_area {
  text-align: center;
  margin: 20px 0 0 0;
  display: block;
}

.news_detail_page .btn_area {
  margin: 100px 0 0;
}

.btn_back,
.btn_back_to_home {
  display: inline-block;
  box-sizing: border-box;
  min-width: 210px;
  padding: 8px 1em;
  font-size: 22px;
  font-weight: bold;
  color: #ff788e;
  border: solid 2px #ff788e;
  text-decoration: none;
  background:#fff;
  /*border-radius: 8px;

  border-radius: calc( 10 / 24 * 1em );*/
}

.btn_back:hover,
.btn_back_to_home:hover {
  color: #661772;
  background: #fff;
  border-color: #661772;
}

.btn_back_to_home {
  display: none;
}

/* img */

.thumb-left {
  float: left;
  margin-right: 60px;
}

.thumb-right {
  float: right;
  margin-left: 60px;
}

/* media */

.media_block {
  display: flex;
}

.media_block .media_thumb {
  margin-right: 60px;
}

.media_block .media_text {
  flex: 1;
}

/* video */

.video,
.video_full {
  position: relative;
  max-width: 100%;
}

.video {
  display: inline-block;
  width: 560px;
  vertical-align: top;
}

.video_full {
  display: block;
  width: 100%;
}

.video:before,
.video_full:before {
  content: '';
  display: block;
  padding: 0 0 calc( 9 / 16 * 100% );
}

.video iframe,
.video_full iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* news pager */

.pager {
  text-align: center;
  margin: 60px auto 0;
}

.pager a {
  padding: 1em;
  color:#c90000;
}

.pager_prevButton {

}

.pager_nextButton {

}

/* movie pager */

.paging {

}

.paging a {
  display: inline-block;
  padding: 1em;
}

/* lity */

.lity-close,
.lity-close:active,
.lity-close:focus,
.lity-close:hover,
.lity-close:visited {
  width: 60px;
  height: 60px;
  font-size: 60px;
}

@media print, screen and (max-width: 768px) {

  .section_sub_ttl h2 {
    font-size: 24px;
  }

  .news_detail_page .btn_area {
    margin-top: calc( 36 / 375 * 100vw );
  }

  .thumb-left,
  .thumb-right {
    float: none;
    margin: 0 0 40px;
    text-align: center;
  }

  .media_block {
    display: block;
  }

  .media_block .media_thumb {
    margin: 0 0 40px;
    text-align: center;
  }

}

@media print, screen and (max-width: 640px) {

  .section_ttl.section_ttl {
    margin: 0 0 calc( 50 / 640 * 100vw );
  }

  .section_ttl img {
    height: calc( 42 / 640 * 100vw );
  }

  .section_sub_ttl {
    margin: 0 0 calc( 20 / 640 * 100vw );
  }

  .section_sub_ttl h2 {
    font-size: 18px;
  }

  .section_sub_ttl img {
    height: calc( 30 / 640 * 100vw );
  }

  .btn-large {
    font-size: 18px;
  }

  .btn_back,
  .btn_back_to_home {
    font-size: 18px;
  }

  .thumb-left,
  .thumb-right {
    margin: 0 0 calc( 40 / 640 * 100vw );
  }

  .media_block .media_thumb {
    margin: 0 0 calc( 40 / 640 * 100vw );
  }

}

@media print, screen and (max-width: 480px) {


}


/* end contents */

/* footer  ============================================================ */

footer {
  text-align: center;
  padding: 20px 0;
}
footer .sns {
  padding-bottom: 20px;
}
footer .sns ul {
  text-align: center;
}
footer .sns ul li {
  width: 64px;
  display: inline-block;
  margin: 5px;
}
footer .sns ul li a {
  transition: all 0.4s;
  display: block;
}
footer .sns ul li a:hover {
  opacity: 0.75;
}
footer .copyright {
  font-size: 13px;
  text-align: center;
}

@media print, screen and (max-width: 768px) {
  footer {
    text-align: center;
    padding: 20px 0;
  }
  footer .sns {
    padding-bottom: 20px;
  }
  footer .sns ul {
    text-align: center;
  }
  footer .sns ul li {
    width: 48px;
    display: inline-block;
    margin: 5px;
  }
  footer .sns ul li a {
    transition: all 0.4s;
    display: block;
  }
  footer .sns ul li a:hover {
    opacity: 0.75;
  }
  footer .copyright {
    font-size: 13px;
    text-align: center;
  }
}
@media print, screen and (max-width: 640px) {
  footer {
    text-align: center;
    padding: 20px 0;
  }
  footer .sns {
    padding-bottom: 20px;
  }
  footer .sns ul {
    text-align: center;
  }
  footer .sns ul li {
    width: 48px;
    display: inline-block;
    margin: 5px;
  }
  footer .sns ul li a {
    transition: all 0.4s;
    display: block;
  }
  footer .sns ul li a:hover {
    opacity: 0.75;
  }
  footer .copyright {
    font-size: 13px;
    text-align: center;
  }
}

@media print, screen and (max-width: 480px) {
  footer {
    text-align: center;
    padding: 20px 0;
  }
  footer .sns {
    padding-bottom: 20px;
  }
  footer .sns ul {
    text-align: center;
  }
  footer .sns ul li {
    width: 48px;
    display: inline-block;
    margin: 5px;
  }
  footer .sns ul li a {
    transition: all 0.4s;
    display: block;
  }
  footer .sns ul li a:hover {
    opacity: 0.75;
  }
  footer .copyright {
    font-size: 11px;
    text-align: center;
  }
}


/* end footer */

/* util ============================================================ */

.inline_block {
  display: inline-block !important;
}

.inline {
  display: inline !important;
}

.clear:after {
  content: '';
  display: block;
  clear: both;
}

.center {
  text-align: center !important;
}

.text_size_xl {
  font-size: 32px !important;
}

.text_size_lll {
  font-size: 28px !important;
}

.text_size_ll {
  font-size: 24px !important;
}

.text_size_l {
  font-size: 21px !important;
}

.text_size_ml {
  font-size: 18px !important;
}

.text_size_s {
  font-size: 15px !important;
}

.text_bold {
  font-weight: bold !important;
}

.text_color_main {
  color: #d11d7d !important;
}

.line_hieght_narrow {
  line-height: 1.4 !important;
}

/* margin */
.m_v_3em {
  margin-top: 3em !important;
  margin-bottom: 3em !important;
}

.m_v_2em {
  margin-top: 2em !important;
  margin-bottom: 2em !important;
}

.m_v_1em {
  margin-top: 1em !important;
  margin-bottom: 1em !important;
}

.m_v_ll {
  margin-top: 40px !important;
  margin-bottom: 40px !important;
}

.m_v_l {
  margin-top: 30px !important;
  margin-bottom: 30px !important;
}

.m_v_ml {
  margin-top: 20px !important;
  margin-bottom: 20px !important;
}

.m_v_m {
  margin-top: 16px !important;
  margin-bottom: 16px !important;
}

.m_v_sm {
  margin-top: 12px !important;
  margin-bottom: 12px !important;
}

.m_v_s {
  margin-top: 8px !important;
  margin-bottom: 8px !important;
}

.m_v_ss {
  margin-top: 4px !important;
  margin-bottom: 4px !important;
}

.m_v_0 {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.m_t_3em {
  margin-top: 3em !important;
}

.m_t_2em {
  margin-top: 2em !important;
}

.m_t_1em {
  margin-top: 1em !important;
}

.m_t_xl {
  margin-top: 60px !important;
}

.m_t_lll {
  margin-top: 50px !important;
}

.m_t_ll {
  margin-top: 40px !important;
}

.m_t_l {
  margin-top: 30px !important;
}

.m_t_ml {
  margin-top: 20px !important;
}

.m_t_m {
  margin-top: 16px !important;
}

.m_t_sm {
  margin-top: 12px !important;
}

.m_t_s {
  margin-top: 8px !important;
}

.m_t_ss {
  margin-top: 4px !important;
}

.m_t_0 {
  margin-top: 0 !important;
}

.m_b_3em {
  margin-bottom: 3em !important;
}

.m_b_2em {
  margin-bottom: 2em !important;
}

.m_b_1em {
  margin-bottom: 1em !important;
}

.m_b_xl {
  margin-bottom: 60px !important;
}

.m_b_lll {
  margin-bottom: 50px !important;
}

.m_b_ll {
  margin-bottom: 40px !important;
}

.m_b_l {
  margin-bottom: 30px !important;
}

.m_b_ml {
  margin-bottom: 20px !important;
}

.m_b_m {
  margin-bottom: 16px !important;
}

.m_b_sm {
  margin-bottom: 12px !important;
}

.m_b_s {
  margin-bottom: 8px !important;
}

.m_b_ss {
  margin-bottom: 4px !important;
}

.m_b_0 {
  margin-bottom: 0 !important;
}

@media print, screen and (max-width: 640px) {

  .m_t_xl {
    margin-top: calc( 42 / 375 * 100vw ) !important;
  }

  .m_t_lll {
    margin-top: calc( 36 / 375 * 100vw ) !important;
  }

  .m_t_ll {
    margin-top: calc( 28 / 375 * 100vw ) !important;
  }

  .m_t_l {
    margin-top: calc( 20 / 375 * 100vw ) !important;
  }

  .m_b_xl {
    margin-bottom: calc( 42 / 375 * 100vw ) !important;
  }

  .m_b_lll {
    margin-bottom: calc( 36 / 375 * 100vw ) !important;
  }

  .m_b_ll {
    margin-bottom: calc( 28 / 375 * 100vw ) !important;
  }

  .m_b_l {
    margin-bottom: calc( 20 / 375 * 100vw ) !important;
  }

  .m_b_ml {
    margin-bottom: calc( 16 / 375 * 100vw ) !important;
  }

  .m_b_m {
    margin-bottom: calc( 8 / 375 * 100vw ) !important;
  }

  .text_size_xl {
    font-size: 21px !important;
  }
  .text_size_lll {
    font-size: 18px !important;
  }
  .text_size_ll {
    font-size: 16px !important;
  }
  .text_size_l {
    font-size: 14px !important;
  }
  .text_size_ml {
    font-size: 14px !important;
  }
  .text_size_s {
    font-size: 12px !important;
  }
}

/* end util */
