@charset "UTF-8";

/* --------------------------------------------------
  modal overwride
-------------------------------------------------- */
.modal-ajax-open .modaal-wrapper {
  overflow: visible;
}
.modal-ajax-open .modaal-outer-wrapper {
  display: block;
  overflow: auto;
  -webkit-overflow-scrolling: auto;
  overflow-scrolling: auto;
}
.modal-ajax-open .modaal-inner-wrapper {
  display: block;
  margin-right: auto;
  margin-left: auto;
}
.modal-ajax-open .modaal-container {
  max-width: 980px;
}
.modal-ajax-open .modaal-content-container {
  padding: 0;
}
@media screen and (max-width: 767px) {
  .modal-ajax-open .modaal-inner-wrapper {
    padding-right: calc(20 / 750 * 100%);
    padding-left: calc(20 / 750 * 100%);
  }
  .modaal-close {
    right: 2px;
    top: 4px;
  }
}



/* --------------------------------------------------
  message close_wrap
-------------------------------------------------- */
.modaal-wrapper .close_wrap {
  padding-top: 56px;
  padding-bottom: 57px;
  background-color: #ffffff;
}
.modaal-wrapper .close_wrap .btn_close {
  max-width: 300px;
  margin: 0 auto;
}
.modaal-wrapper .close_wrap .btn_close a {
  display: block;
  padding-top: 22px;
  padding-bottom: 22px;
  border: 1px solid #a70c2c;
  text-align: center;
  font-size: 18px;
  color: #a70c2c;
  text-decoration: none;
}
.modaal-wrapper .close_wrap .btn_close .inner {
  vertical-align: middle;
}
.modaal-wrapper .close_wrap .btn_close .icon {
  display: inline-block;
  position: relative;
  top: 3px;
  width: 18px;
  height: 18px;
  vertical-align: middle;
  transform: rotate(45deg);
}
.modaal-wrapper .close_wrap .btn_close .icon:before,
.modaal-wrapper .close_wrap .btn_close .icon:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #a70c2c;
}
.modaal-wrapper .close_wrap .btn_close .icon:after {
  transform: rotate(90deg);
}
/*sp style*/
@media screen and (max-width: 767px) {
  .modaal-wrapper .close_wrap {
    padding-top: 29px;
    padding-bottom: 31px;
  }
  .modaal-wrapper .close_wrap .btn_close {
    max-width: 225px;
  }
  .modaal-wrapper .close_wrap .btn_close a {
    padding-top: 15px;
    padding-bottom: 15px;
    font-size: calc(26 / 750 * 100vw);
  }
  .modaal-wrapper .close_wrap .btn_close .icon {
    top: 3px;
    width: 13px;
    height: 13px;
  }
}



/* --------------------------------------------------
  message report
-------------------------------------------------- */
.modal_report_wrap {
  max-width: 980px;
  margin: 0 auto;
}
.modal_report_wrap .title_wrap {
  padding: 34px 0 33px;
  background-color: #ffffff;
  text-align: center;
}
.modal_report_wrap .title_wrap h3 {
  margin-bottom: 20px;
  font-size: 60px;
  line-height: 1;
  font-weight: bold;
  color: #a70c2c;
  letter-spacing: 0;
}
.modal_report_wrap .title_wrap p {
  font-size: 20px;
  line-height: 1.5;
  font-weight: bold;
  color: #a70c2c;
  letter-spacing: 0;
}
.modal_report_wrap .content_container {
  background-color: #a70c2c;
}
.modal_report_wrap .content_wrap {
  padding: 57px 0 48px;
}
.modal_report_wrap .content_wrap:not(:first-child) {
  border-top: 1px solid #ffffff;
}
.modal_report_wrap .content_wrap:last-child {
  padding-bottom: 66px;
}
.modal_report_wrap .content_wrap h4 {
  margin-bottom: 54px;
  text-align: center;
  font-size: 24px;
  line-height: 1.5;
  font-weight: bold;
  color: #e5cb95;
}
.modal_report_wrap .content_wrap h5 {
  margin-bottom: 25px;
  vertical-align: middle;
  text-align: left;
  font-size: 30px;
  letter-spacing: 0.1em;
  color: #ffffff;
}

  .modal_report_wrap .content_wrap h6 {
  margin-bottom: 24px;
  vertical-align: middle;
  text-align: center;
  font-size: 20px;
  letter-spacing: 0.1em;
  color: #ffffff;
}

.modal_report_wrap .content_block {
  padding: 0 50px;
}
.modal_report_wrap .content_block:not(:last-child) {
  margin-bottom: 36px;
}
.modal_report_wrap .content_block .lead_img_block ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.modal_report_wrap .content_block .lead_img_block li {
  width: 48.3%;
  margin-bottom: 30px;
}
.modal_report_wrap .content_block .img_block {
  max-width: 415px;
  margin-bottom: 48px;
  border: 5px solid #ffffff;
}
.modal_report_wrap .content_block.img_r .img_block {
  float: right;
  margin-left: 48px;
}
.modal_report_wrap .content_block.img_l .img_block {
  float: left;
  margin-right: 48px;
}
.modal_report_wrap .content_block .lead_img_block p {
	display: block; 
	text-align: center; 
	font-weight: 500; 
	color: #fff; 
	font-size: 13px; 
	padding-top: 0.6em;
}
.modal_report_wrap .content_block .lead_text_block {
  margin-bottom: 30px;
}
.modal_report_wrap .content_block .text_block p {
  text-align: justify;
  text-justify: inter-character;
  font-size: 16px;
  line-height: 1.88;
  font-weight: bold;
  letter-spacing: 0.1em;
  color: #ffffff;
}
.modal_report_wrap .content_block .text_block p:not(:last-child) {
  margin-bottom: 30px;
}
/*sp style*/
@media screen and (max-width: 767px) {
  .modal_report_wrap .title_wrap {
    padding: 30px 0 27px;
  }
  .modal_report_wrap .title_wrap h3 {
    margin-bottom: 15px;
    font-size: calc(72 / 750 * 100vw);
  }
  .modal_report_wrap .title_wrap p {
    font-size: calc(28 / 750 * 100vw);
    line-height: 1.29;
  }
  .modal_report_wrap .content_wrap {
    padding: 26px calc(44 / 710 * 100%) 23px;
  }
  .modal_report_wrap .content_wrap:last-child {
    padding-bottom: 21px;
  }
  .modal_report_wrap .content_wrap h4 {
    margin-bottom: 12px;
    font-size: calc(32 / 750 * 100vw);
  }
  .modal_report_wrap .content_wrap h5 {
    margin-bottom: 13px;
    font-size: calc(36 / 750 * 100vw);
  }
  
  .modal_report_wrap .content_wrap h6 {
    position: relative;
    text-align: left;
    margin-bottom: 16px;
    font-size: 15px;
    line-height: 1.2;
  }
  .modal_report_wrap:not(.report_vol) .content_wrap h6 {
    padding-left: 42px;
  }


  .modal_report_wrap .content_block {
    padding: 0;
  }
  .modal_report_wrap .content_block:not(:last-child) {
    margin-bottom: 24px;
  }
  .modal_report_wrap .content_block .img_block {
    max-width: 100%;
    margin-bottom: 18px;
    padding-top: 0;
  }
  .modal_report_wrap .content_block.img_r .img_block {
    float: none;
    margin-left: 0;
  }
  .modal_report_wrap .content_block.img_l .img_block {
    float: none;
    margin-right: 0;
  }
  .modal_report_wrap .content_block .lead_img_block p {
 	display: block; 
	text-align: center; 
	font-weight: 500; 
	color: #fff; 
	font-size: 11px; 
	padding-top: 0.6em;
  }
  .modal_report_wrap .content_block .text_block p {
    font-size: calc(24 / 750 * 100vw);
  }
  .modal_report_wrap .content_block .text_block p:not(:last-child) {
    margin-bottom: 25px;
  }
}



/* --------------------------------------------------
  message supporter
-------------------------------------------------- */
.modal_supporter_wrap {
  max-width: 980px;
  margin: 0 auto;
}
.modal_supporter_inner {
  padding: 26px 25px 50px;
  background-color: #a60d2c;
}
.modal_supporter_wrap .tab_title_wrap {
  display: flex;
  justify-content: space-between;
  margin-bottom: 37px;
}
.modal_supporter_wrap .tab_title_wrap .illust {
  width: calc(300 / 930 * 100%);
}
.modal_supporter_wrap .tab_title_wrap .text_box {
  position: relative;
  width: calc(600 / 930 * 100%);
  color: #ffffff;
}
.modal_supporter_wrap .tab_title_wrap .text_box .plan_text dt {
  width: 140px;
  margin-bottom: 20px;
  padding: 4px 0;
  background-color: #ffffff;
  border-radius: 40px;
  text-align: center;
  font-size: 14px;
  font-weight: 800;
  color: #a60d2c;
}
.modal_supporter_wrap .tab_title_wrap .text_box .plan_text dd {
  font-weight: 100;
}
.modal_supporter_wrap .tab_title_wrap .text_box .plan_text dd.item {
  margin-bottom: 15px;
  font-size: 30px;
}
.modal_supporter_wrap .tab_title_wrap .text_box .plan_text dd.caption {
  font-size: 16px;
  line-height: 1.5;
}
.modal_supporter_wrap .tab_title_wrap .text_box .entry_count {
  display: flex;
  align-items: flex-end;
  position: absolute;
  top: -4px;
  right: 0;
  padding-bottom: 4px;
  border-bottom: 1px solid #ffffff;
}
.modal_supporter_wrap .tab_title_wrap .text_box .entry_count dt,
.modal_supporter_wrap .tab_title_wrap .text_box .entry_count dd {
  font-size: 18px;
  font-weight: 800;
  letter-spacing: 0.1em;
}
.modal_supporter_wrap .tab_title_wrap .text_box .entry_count dt {
  margin-right: 12px;
}
.modal_supporter_wrap .tab_title_wrap .text_box .entry_count dd {
  vertical-align: baseline;
}
.modal_supporter_wrap .tab_title_wrap .text_box .entry_count dd span {
  vertical-align: baseline;
  font-size: calc(48 / 36 * 100%);
  font-weight: 800;
}
.modal_supporter_wrap .tab_list ul {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: -28px;
}
.modal_supporter_wrap .tab_list ul li {
  width: calc(290 / 930 * 100%);
  margin-bottom: 25px;
}
.modal_supporter_wrap .tab_list ul li:not(:nth-child(3n)) {
  margin-right: calc(30 / 930 * 100%);
}
.modal_supporter_wrap .tab_list ul li a {
  text-decoration: none;
}
.modal_supporter_wrap .tab_list ul li p {
  position: relative;
  padding-top: 3px;
  padding-left: 41px;
  font-size: 14px;
  line-height: 1.3;
  font-weight: bold;
  letter-spacing: 0.1em;
  color: #ffffff;
}
.modal_supporter_wrap .tab_list ul li p:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 23px;
  height: 23px;
  background: transparent 0 0 / cover no-repeat;
  vertical-align: baseline;
}
.modal_supporter_wrap .tab_list ul li.insta p:before {
  background-image: url(../img/top/entry_insta_icon.png);
}
.modal_supporter_wrap .tab_list ul li.tw p:before {
  background-image: url(../img/top/entry_twitter_icon.png);
}
/*sp style*/
@media screen and (max-width: 767px) {
  .modal_supporter_wrap {
  }
  .modal_supporter_inner {
    padding: 26px calc(44 / 710 * 100%) 40px;
  }
  .modal_supporter_wrap .tab_title_wrap {
    display: block;
    width: calc(600 / 622 * 100%);
    margin: 0 auto 42px;
  }
  .modal_supporter_wrap .tab_title_wrap .illust,
  .modal_supporter_wrap .tab_title_wrap .text_box {
    width: 100%;
  }
  .modal_supporter_wrap .tab_title_wrap .illust {
    margin-bottom: 29px;
  }
  .modal_supporter_wrap .tab_title_wrap .text_box .plan_text dt {
    width: calc(210 / 600 * 100%);
    margin-bottom: 13px;
    padding: 4px 0;
    font-size: calc(20 / 750 * 100vw);
  }
  .modal_supporter_wrap .tab_title_wrap .text_box .plan_text dd.item {
    margin-bottom: 12px;
    font-size: calc(44 / 750 * 100vw);
  }
  .modal_supporter_wrap .tab_title_wrap .text_box .plan_text dd.caption {
    font-size: calc(24 / 750 * 100vw);
    line-height: 1.5;
  }
  .modal_supporter_wrap .tab_title_wrap .text_box .entry_count dt,
  .modal_supporter_wrap .tab_title_wrap .text_box .entry_count dd {
    font-size: calc(24 / 750 * 100vw);
  }
  .modal_supporter_wrap .tab_title_wrap .text_box .entry_count dd span {
    font-size: calc(32 / 24 * 100%);
  }
  .modal_supporter_wrap .tab_list ul {
    margin-bottom: -19px;
  }
  .modal_supporter_wrap .tab_list ul li {
    width: calc(301 / 622 * 100%);
    margin-bottom: 19px;
  }
  .modal_supporter_wrap .tab_list ul li:not(:nth-child(3n)) {
    margin-right: 0;
  }
  .modal_supporter_wrap .tab_list ul li:not(:nth-child(2n)) {
    margin-right: calc(20 / 622 * 100%);
  }
  .modal_supporter_wrap .tab_list ul li p {
    padding-top: calc(6 / 750 * 100vw);
    padding-left: calc(62 / 750 * 100vw);
    font-size: calc(26 / 750 * 100vw);
  }
  .modal_supporter_wrap .tab_list ul li p:before {
    width: calc(42 / 750 * 100vw);
    height: calc(42 / 750 * 100vw);
  }
}



/* --------------------------------------------------
  768px〜 hover pc + tablet style
  touchデバイスでhoverを使うと2回クリックしないと
  いけないくなるので、.notouchを先頭につけてください
-------------------------------------------------- */
@media screen and (min-width: 768px) {
  
  .notouch .modal_report_wrap .close_wrap .btn_close a {
    transition: opacity 400ms ease;
  }
  .notouch .modal_report_wrap .close_wrap .btn_close a:hover {
    opacity: 0.7;
  }

}