@charset "utf-8";
/* CSS Document */
/*WEB-------------フォント-------------*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP&display=swap');
* {
  font-family: 'Noto Sans JP', sans-serif, "Font Awesome 5 Free";
}
body {
  font-family: 'Noto Sans JP', sans-serif, "Font Awesome 5 Free";
  font-size: 14px;
  color: #333631;
  background-color: transparent;
  overflow-x: hidden;
  line-height: 2;
}
h1, h2, h3, h4, h5, h6, p, td, li {
  font-family: 'Noto Sans JP', sans-serif, "Font Awesome 5 Free";
}
/*-------------アンカー・ボタン アウトラインなし-------------*/
a.active.focus, a.active:focus, a.focus, a:active.focus, a:active:focus, a:focus, button.active.focus, button.active:focus, button.focus, button:active.focus, textarea:active:focus, textarea:focus,button:active:focus, button:focus, .btn.active.focus, .btn.active:focus, .btn.focus, .btn:active.focus, .btn:active:focus, .btn:focus {
  outline: 0;
  outline-color: transparent;
  outline-width: 0;
  outline-style: none;
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
}

/*----文字にアンカー-----------------------*/
.text_link {
    color: #526698;
    text-decoration: none;
    background-color: transparent;
}
.text_link:hover{
    color: #7a4171;
    text-decoration: none;
    background-color: transparent;
}

.container{
  padding: 0;
  line-height: 2.5;
}
.bg_transparent{
  background: rgba(255,255,255,0.7);
  border-radius: 5px;
}
.bg_nav_transparent{
  background: rgba(255,255,255,0.9);

}

.contents_title{
  padding-left: 1rem;
  font-size: 24px;
  color: #1c1c1c;
  padding: 5rem 1rem 5rem ;
}
@media (max-width: 992px){
.contents_title{
  padding: 3rem 1rem 3rem ;
  font-size: 22px;
  line-height: 1.5;
}  
}

.mt_80{}
@media only screen and (max-width: 768px){
.mt_80{
  padding-top: 80px;
}
}

.text_purple{
color: #b15b9b;
line-height: 30px;
}

.text_pink{
  color:#af0858;
}
.text_blue{
  color:#1b61a2;
}
.text_red{
  color:#861030;
}
.text_gold{
  color:#daa520;
}


.line_height_15{
  
 line-height: 1.5;
}

/*------btn-------------------------------*/

.btn-outline-red {
    color: #861030;
    border-color: #861030;
}
.btn-outline-red:hover {
    color: #fff;
    background-color: #861030;
    border-color: #861030;
  }


.btn-outline-blue {
    color: #526698;
    border-color: #526698;
}
.btn-outline-blue:hover {
    color: #fff;
    background-color:#526698;
    border-color: #526698;
  }

/*-----フォントサイズ--------------------------*/
.f12{
  font-size: 12px;
}

.f14{
  font-size: 14px;
}

.f16{
  font-size: 16px;
}

.f18{
  font-size: 18px;
}

.f20{
  font-size: 20px;
}

.f24{
  font-size: 24px;
}
/*-------------　PC・SP画像切り替え------------- */
.toggle-pc { display: block; }
.toggle-sp { display: none; }
@media only screen and (max-width: 768px) {
  .toggle-pc { display: none; }
  .toggle-sp { display: block; }
}


/*-----ナビバー--------------------------*/
/*----dropdown　hoverで開く----*/
.dropdown:hover .dropdown-menu {
  display: block;
}

/*----トグル閉じるボタン----*/
button[aria-expanded="true"] > span {
  position: relative;
  display: none;
}
button[aria-expanded="true"]::after {
  position: absolute;
  top: 10px;
  right: 20px;
  font-size: 28px;
  content: "×";
}
/*----ハンバーガーの枠線を消す-----------*/
.navbar-light .navbar-toggler {
    border-color: rgba(0,0,0,0);
}
.navbar{
  padding: 0;
}
.navbar-light .navbar-nav .nav-link {
    color: #666;
    margin-left: 1.5rem;
}
.navbar-light .navbar-nav .nav-link:focus, .navbar-light .navbar-nav .nav-link:hover {
    color: #9f428e;
}

.nav-link{
  padding: 0;
  margin-top: 0px;
}

.sns{}
@media (max-width: 992px){
  .sns{
    padding-bottom: 1rem;
  }
}
.list-inline {
    line-height: 1.7;
}
/*-------参加登録ボタン-----------------------------*/
.login_square_btn {
  display: block;
  position: relative;
  width: 100px;
  text-align: center;
  text-decoration: none;
  color: #ffffff;
  background: #e83e8c;
  border:1px solid #e83e8c;
  padding-top: 0;
  padding-bottom: : 0;
}
.login_square_btn:hover {
   background: #ffc0cb;
   border:1px solid #ffc0cb;
         color: #fff;
   cursor: pointer;
   text-decoration: none;
}
.list-inline-item:not(:last-child) {
    margin-right: 0;
}


.mark_sakura {
    background-image: url(../img/list_sakura.png);
    background-repeat: no-repeat;
    background-position: left center;
    margin: 0 0.5rem;
    padding-left: 50px;
    font-size: 18px;
    line-height: 30px;
    color: #b15b9b;
    border-bottom: 3px dotted #f2e2e8;
}

@media only screen and (max-width: 768px){
  .mark_sakura{
     margin: 0 ;
  }
}





.bg_pink{
  background: rgba(247,231,218,0.5);
  border-radius: 10px;
  color:#666;
  font-size: 16px;
}

.bg_white{
  background: rgba(253,254,230,0.5);
  border-radius: 10px;
  color:#666;
  font-size: 16px;
}
.bg_blue{
  background: rgba(230,253,254,0.5);
  border-radius: 10px;
  color:#666;
  font-size: 16px;
}



*{
margin:0;
padding:0;  
}
.bg_contents{
padding:5%;
z-index:-10;
}
.bg_contents::before {
content:"";
display:block;
position:fixed;
top:0;
left:0;
z-index:-10;
width:100%;
height:100vh;
background-repeat:no-repeat;
background-position: center top;
background-image:url(../img/bg_contents.png);
background-size:100% auto;
min-height: 300px;
}

@media only screen and (max-width: 768px){
 .bg_contents{
  padding:0;
  z-index: -10;
}

 .bg_contents::before {
  background-image:url(../img/bg_contents_sp.png);
    z-index: -10;
 } 
}


/*.bg_contents{
  background-image: url(../img/bg_contents.png);
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size:100% auto;
  background-position: center top;
  min-height: 300px;
  margin-top: 80px;
}
@media only screen and (max-width: 768px){
.bg_contents{
  background-image: url(../img/bg_contents_sp.png);
}
}*/
/*-------footer-----------------*/
.cpac_footer {
  background: rgba(239,208,232,0.7);
 
 color: #b15b9b;
  text-align: center;
  padding: 2px 0;
  font-size: 14px;
}
/*-------開催概要の項目名-----------------*/
.outline_detaile_title{
  background-color: #e6e6fa;
  border-bottom:1px solid #fff;
  line-height:inherit;
  font-weight: bold;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
/*-------開催概要の詳細-----------------*/
.outline_detaile{
  border-bottom:1px dotted #e6e6fa;
  line-height:inherit;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
@media only screen and (max-width: 768px){
.outline_detaile{
  border-bottom: 0;
}
}

/*-------Complication of the Year 2020-----------------*/
.header_circle {
    margin:  0;                 /* デフォルトCSS打ち消し */
    font-size:  20px;           /* 文字サイズ指定 */
    font-weight: bold;
    position:  relative;        /* 位置調整 */
    display:  inline-block;     /* インラインブロックにする */
    padding-top: 10px;          /* 余白指定 */
    padding-left: 30px;         /* 余白指定 */
    padding-bottom: 10px;       /* 余白指定 */
}
.header_circle:before {
    content:  '';               /* 空白の要素を作る */
    background-color: #b0b314;  /* 背景色指定 */
    display:  block;            /* ブロック要素にする */
    position:  absolute;        /* 位置調整 */
    left:  0;                   /* 位置調整 */
    height: 40px;               /* 高さ指定 */
    width: 40px;                /* 幅指定 */
    border-radius:  50%;        /* 丸くする */
    top: 0;                     /* 位置調整 */
    z-index:  -1;               /* 重なり調整 */
}

.header_circle_p{
  padding-left: 10px;
  font-size: 16px;
  z-index: 5;
}

.card-body{
  padding:0.5rem;
}
.card_width{
  max-width: 800px;
}
.card_text_sm{
  font-size: 16px;
  line-height: 1.5;
}
.card_border{
    border: 1px solid rgba(0, 0, 0, 0.125);
    border-radius: 0.25rem;
}
/*------ボタン--------------*/
section {
  max-width: 300px;
  margin-left: 20px;
  
}
a.recruit_btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 50px;
  box-sizing: border-box;
  background: repeating-linear-gradient(45deg, #ffffff, #ffffff 1px, #e5e750 1px, #e5e750 30px);
  color: #333;
  font-size: 16px;
  letter-spacing: 0.1em;
  text-decoration: none;
  position: relative;
}
a.recruit_btn span {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 50px;
  background: #fff;
  border: 1px solid #b0b314;
  box-sizing: border-box;
  position: absolute;
  top: -4px;
  left: -4px;
  transition-duration: 0.2s;
}
a.recruit_btn:hover span {
  left: -1px;
  top: -1px;
}


.card-header_coy {
    padding: 0.75rem;
    margin-bottom: 0;
    color: inherit;
    background-color: rgba(204, 93, 156, 0.7);
    border-radius: 5px;
    color:#fff;
    line-height: 1.5;
    margin-bottom: 1.5rem;
}









/*------ボタン_参加登録-------------*/
a.btn-radius-solid {
  padding:10px 20px;
  background: #fff;
  background: -webkit-gradient(linear, left top, left bottom, from(#f19ecb), to(#eed3f1));
  background: -webkit-linear-gradient(top, #f19ecb 0%, #eed3f1 100%);
  background: linear-gradient(to bottom, #f19ecb 0%, #eed3f1 100%);
  border-radius: 5px;
  color:#7418ae;
}

a.btn-radius-solid:hover {
  background: -webkit-gradient(linear, left bottom, left top, from(#f19ecb), to(#eed3f1));
  background: -webkit-linear-gradient(bottom, #f19ecb 0%, #eed3f1 100%);
  background: linear-gradient(to top, #f19ecb 0%, #eed3f1 100%);
  text-decoration: none;
  color:#f2148e;
}
a.btn--shadow {
  -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

/*------プログラム詳細----------------------------------------------------------------------*/
.prg_time {
    background: linear-gradient(-45deg, rgba(246, 255, 0, .5), rgba(255, 0, 161, .5));
    color: #fff;
    font-weight: bold;
    font-size: 16px;
    line-height: 1.5;
    padding-top: 15px;
    padding-bottom: 15px;
}

.prg_time2 {
    background: linear-gradient(-45deg, rgba(22, 243, 9, .5), rgba(40, 135, 219, .8));
    color: #fff;
    font-weight: bold;
    font-size: 16px;
    line-height: 1.5;
    padding-top: 15px;
    padding-bottom: 15px;
}

.nav-pills .nav-link1.active, .nav-pills .show > .nav-link1 {

    color: #fff;

    background-color: #ff84ca;

}
.nav-pills .nav-link2.active, .nav-pills .show > .nav-link2 {

    color: #fff;

    background-color: #72b5c4;

}

.nav-pills .nav-link3.active, .nav-pills .show > .nav-link3 {

    color: #fff;

    background-color: orange;

}
/*ALLボタン*/
.btn-outline-all {
  color: orange;
  border-color: orange;
  margin-bottom: 10px;
  background: rgba(255,255,255,0.9);
}
.btn-outline-all:hover {
  color: #ffffff;
  background-color: orange;
  border-color: orange;
  text-decoration: none;
}
.btn-outline-all:active {
  color: #ffffff;
  background-color: orange;
  border-color: orange;
}
.btn-outline-all a:visited {
  color: orange;
  border-color: orange;
  margin-bottom: 10px;
  background-color: #ffffff;
}

/*LIVE A red*/
.btn-outline-live_a {
  color: #ff84ca;
  border-color: #ff84ca;
  margin-bottom: 10px;
  background: rgba(255,255,255,0.9);
}
.btn-outline-live_a:hover {
  color: #fff;
  background-color:#ff84ca;
  border-color: #ff84ca;
}

.btn-outline-live_b {
  color: #72b5c4;
  border-color: #72b5c4;
  margin-bottom: 10px;
  background: rgba(255,255,255,0.9);
  }
.btn-outline-live_b:hover {
  color: #fff;
  background-color: #72b5c4;
  border-color: #72b5c4;
}

.prog_body{
  line-height: 1.5;
  margin-bottom: 0;

}
.kyosan{
  padding-top:1rem;
  text-align: right;
}

.btn_room_a{
  background: linear-gradient(-45deg, rgba(246, 255, 0, .5), rgba(255, 0, 161, .5));
  color: #fff;
  border:none;
}

.btn_room_b{
  background: linear-gradient(-45deg, rgba(22, 243, 9, .5), rgba(40, 135, 219, .8));
  color: #fff;

}
.btn_room_a:hover{
  background: linear-gradient(-45deg, rgba(246, 255, 0, .5), rgba(255, 0, 161, .5));
  color: #fff;
  border:none;
}

.btn .btn_room_b:hover{
  background:linear-gradient(-45deg, rgba(136, 195, 132, .5), rgba(9, 201, 245, .8));
  color: #122bde;
}


.bg-gradient2 span,
.bg-gradient2:before {
  background: #67a8d5;
  background: -webkit-gradient(linear, left top, right top, from(#67a8d5), color-stop(80%, #97f57e), to(#97f57e));
  background: linear-gradient(to right, #67a8d5 0%, #97f57e 80%, #97f57e 100%);
}

.bg-gradient3 span,
.bg-gradient3:before {
  background: #fa6c9f;
  background: -webkit-gradient(linear, left top, right top, from(#fa6c9f), color-stop(80%,#f9bb49));
  background: linear-gradient(to right, #fa6c9f 0%, #f9bb49 100%);
}

.bg-gradientT span,
.bg-gradientT:before {
  background: #abcd32;
  background: -webkit-gradient(linear, left top, right top, from(#abcd32), color-stop(80%, #abcd32), to(#abcd32));
  background: linear-gradient(to right, #abcd32 0%, #abcd32 80%, #abcd32 100%);
}


/* General */

a {
  text-decoration: none;
}
a:hover, a:focus, a:active {
  text-decoration: none;
}

/* fancy Button */
.fancy-button {
  display: inline-block;
  margin: 3px;
  font-size: 17px;
  letter-spacing: 0.03em;
  color: #ffffff;
  position: relative;
}
.fancy-button:before {
  content: '';
  display: inline-block;
  height: 40px;
  position: absolute;
  bottom: -5px;
  left: 30px;
  right: 30px;
  z-index: -1;
  border-radius: 30em;
  -webkit-filter: blur(20px) brightness(0.95);
          filter: blur(20px) brightness(0.95);
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
.fancy-button i {
  margin-top: -1px;
  margin-right: 10px;
  font-size: 1.265em;
  vertical-align: middle;

}
.fancy-button span {
  display: inline-block;
  padding: 0 20px;
  border-radius: 5px;
  position: relative;
  z-index: 2;
  will-change: transform, filter;
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
.fancy-button:focus, .fancy-button:active {
  color: #ffffff;
}
.fancy-button:hover {
  color: #ffffff;
}
.fancy-button:hover span {
  -webkit-filter: brightness(1.05) contrast(1.05);
          filter: brightness(1.05) contrast(1.05);
  -webkit-transform: scale(0.95);
          transform: scale(0.95);
}
.fancy-button:hover:before {
  bottom: 0;
  -webkit-filter: blur(10px) brightness(0.95);
          filter: blur(10px) brightness(0.95);
}
.fancy-button.pop-onhover:before {
  opacity: 0;
  bottom: 10px;
}
.fancy-button.pop-onhover:hover:before {
  bottom: -7px;
  opacity: 1;
  -webkit-filter: blur(20px);
          filter: blur(20px);
}
.fancy-button.pop-onhover:hover span {
  -webkit-transform: scale(1.04);
          transform: scale(1.04);
}
.fancy-button.pop-onhover:hover:active span {
  -webkit-filter: brightness(1) contrast(1);
          filter: brightness(1) contrast(1);
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: all 0.15s ease-out;
  transition: all 0.15s ease-out;
}
.fancy-button.pop-onhover:hover:active:before {
  bottom: 0;
  -webkit-filter: blur(10px) brightness(0.95);
          filter: blur(10px) brightness(0.95);
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}
