/*kv*/
#kv {width: 100%;margin: 0 auto}
#kv .kv_inner {
 position: relative;
}
#kv .kv_swiper {
 overflow: hidden
}
#kv .kv_swiper_navwrap {
align-items: center;
display: flex;
flex-direction: row;
flex-wrap: nowrap;
justify-content: space-between;
width: 120px;
margin: 0;
padding: 15px;
position: absolute;
bottom: -60px;
left: 50%;
transform: translate(-50%, -50%);
z-index: 10;
}
#kv .kv_swiper-pagination {
align-items: center;
display: flex;
justify-content: center;
gap: 20px;
margin: 0 auto;
}
#kv .swiper-pagination-bullet {
 background-color: transparent;
 border: 1px solid #333;
 opacity: 1;
}
#kv .swiper-pagination-bullet-active {
 background-color: #333;
}
#kv .kv_swiper-button-prev ,
#kv .kv_swiper-button-next {
 display: block;
 width: 9px;
 height: 11px;
 cursor: pointer;
 z-index: 2;
 background-image: url("../img/common/icon_arrow.png");
 background-repeat: no-repeat;
 background-size: contain;
 position: absolute;
}
#kv .kv_swiper-button-prev {
 left: 0;
 top: calc(50% - 5.5px);
}
#kv .kv_swiper-button-next {
 transform: rotate(180deg);
 right: 0;
 top: calc(50% - 5.5px);
}

/*bnr*/
#bnr {
 width: 100%;
 margin: 0 auto;
 padding: 9% 0 1%;
 position: relative;
 background-image: url("../img/top/bg_line01.png");
 background-position: top -20px center;
 background-repeat: no-repeat;
 background-size: 100% auto;
}
#bnr .bnr_mov {
 width: 70%;
 max-width: 1400px;
 margin: 0 auto 110px;
}
@media (max-width: 768px) {
 #bnr {
 padding: 15% 0 12%;
 background-image: url("../img/top/bg_line01_SP.png");
 background-position: bottom  right -30px;
}
#bnr .bnr_mov {
 width: 90%;
 margin: 0 auto;
}
}

/*special*/
#special {
 width: 100%;
 background-color: #e6e6e6;
 border-radius: 100px;
 padding: 11% 0;
}
#special .special_inner {
 width: 80%;
 max-width: 1400px;
 margin: 0 auto 150px;
 display: flex;
 align-items: flex-start;
 justify-content: space-between;
 flex-wrap: nowrap;
 position: relative;
}
#special .special_inner .ttl_wrap {
 width: 44%;
 margin: 0 auto 0 0;
}
#special .special_inner .special_ttl01 {
 margin-bottom: 12%;
}
#special .special_inner .special_body {
 font-size: 15px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.18em;
 line-height: 2.25;
}
#special .special_inner .img_wrap {
 width: 62%;
 margin: 0 -12.6% 0 auto;
}
#special .special_inner .txt_wrap {
 width: 49%;
 margin: 0 auto 0 0;
}
#special .special_inner .txt_wrap h2 {
 font-size: 80px;
 line-height: 1.1;
 font-family: "Roboto", sans-serif;
 font-weight: 900;
 font-style: italic;
 letter-spacing: 0.02em;
 margin-bottom: 30px;
}
#special .special_inner .txt_wrap h2 span {
 font-size: 14px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 margin-left: 0.5em;
}
#special .special_inner .mov_wrap {
 width: 51%;
 margin: 0 0 0 auto;
}
@media (max-width: 768px) {
#special {
 width: 100%;
 border-radius: 30px;
 padding: 15% 0;
}
#special .special_inner {
 width: 90%;
 margin: 0 auto;
 display: block;
}
#special .special_inner .ttl_wrap {
 width: 100%;
 margin: 0 auto 0 0;
}
#special .special_inner .special_ttl01 {
 width: 90%;
 margin-bottom: 30px;
}
#special .special_inner .special_body {
 font-size: 13px;
 letter-spacing: 0.15em;
 line-height: 2.25;
}
#special .special_inner .img_wrap {
 width: 111.15%;
 margin: 45px 0 90px -5.56%;
}
#special .special_inner .txt_wrap {
 width: 100%;
 margin: 0 auto;
}
#special .special_inner .txt_wrap h2 {
 font-size: 54px;
 line-height: 1.1;
 letter-spacing: 0.02em;
 margin-bottom: 20px;
}
#special .special_inner .txt_wrap h2 span {
 font-size: 11px;
 letter-spacing: 0.1em;
}
#special .special_inner .mov_wrap {
 width: 100%;
 margin: 18px auto 0;
}
}

/*news*/
#news {
 width: 80%;
 max-width: 1400px;
 margin: 0 auto 150px;
}
#news h2 {
 font-size: 80px;
 line-height: 1.1;
 font-family: "Roboto", sans-serif;
 font-weight: 900;
 font-style: italic;
 letter-spacing: 0.02em;
 margin-bottom: 30px;
}
#news h2 span {
 font-size: 14px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 margin-left: 0.5em;
}
#news .news_inner {
 width: 100%;
 margin: 0 auto;
}
#news .news_list_wrap li a ,
#news .news_list_wrap li button {
 width: 100%;
 display: flex;
 background-color: #FFF;
 padding: 0;
 margin: 0 auto 25px;
 position: relative;
 text-align: left;
}
#news .news_list_wrap li a::after ,
#news .news_list_wrap li button::after {
 content: "";
 display: block;
 width: 30px;
 height: 30px;
 background-image: url("../img/common/ico_arrow_R.svg");
 background-size: 100% auto;
 background-repeat: no-repeat;
 position: absolute;
 right: 20px;
 bottom: 20px;
}
#news .news_list_wrap .thumb_wrap {
 width: 22%;
 margin: 0 auto 0 0;
 overflow: hidden;
}
 #news .news_list_wrap .thumb_wrap img {
  height: 100%;
  width: 100%;
  object-fit: cover;
  object-position: center;
 }
#news .news_list_wrap .txt_wrap {
 width: 75%;
 margin: 0 0 0 auto;
 display: flex;
 flex-wrap: wrap;
 align-items: center;
 align-content: center;
 padding: 20px 50px 20px 0;
}
#news .news_list_wrap .txt_wrap .news_date {
 width: 100%;
 font-size: 14px;
 font-family: "Red Hat Text", sans-serif;
 font-weight: 400;
 letter-spacing: 0.05em;
 margin-bottom: 6px;
}
#news .news_list_wrap .txt_wrap .news_cate {
 margin: 0 auto 5px 0;
 display: inline-block;
 border-bottom: 1px solid #000;
 font-size: 15px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
}
#news .news_list_wrap .txt_wrap .news_body {
 width: 100%;
 font-size: 20px;
 line-height: 1.3;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
}
@media (max-width: 768px) {
 #news {
 width: 90%;
 margin: 100px auto;
}
#news h2 {
 font-size: 54px;
 line-height: 1.1;
 letter-spacing: 0.02em;
 margin-bottom: 20px;
}
#news h2 span {
 font-size: 11px;
 letter-spacing: 0.1em;
}
#news .news_inner {
 width: 100%;
 margin: 0 auto;
}
#news .news_list_wrap li a ,
#news .news_list_wrap li button {
 display: flex;
 background-color: #FFF;
 padding: 0;
 margin: 0 auto 25px;
 position: relative;
}
#news .news_list_wrap li a::after ,
#news .news_list_wrap li button::after {
 content: "";
 display: block;
 width: 18px;
 height: 18px;
 background-image: url("../img/common/ico_arrow_R.svg");
 background-size: 100% auto;
 background-repeat: no-repeat;
 position: absolute;
 right: 10px;
 bottom: 10px;
}
#news .news_list_wrap .thumb_wrap {
 width: 34%;
 aspect-ratio: 1.125;
 margin: 0 auto 0 0;
 overflow: hidden;
}
 #news .news_list_wrap .thumb_wrap img {
  height: 100%;
  width: 100%;
  object-fit: cover;
  object-position: center;
 }
#news .news_list_wrap .txt_wrap {
 width: 63%;
 margin: 0 0 0 auto;
 display: flex;
 flex-wrap: wrap;
 align-items: center;
 align-content: center;
 padding: 15px 30px 15px 0;
}
#news .news_list_wrap .txt_wrap .news_date {
 width: 100%;
 font-size: 12px;
 line-height: 1.2;
 margin-bottom: 6px;
}
#news .news_list_wrap .txt_wrap .news_cate {
 margin: 0 auto 6px 0;
 display: inline-block;
 border-bottom: 1px solid #000;
 font-size: 10px;
 line-height: 1.3;
 letter-spacing: 0.1em;
}
#news .news_list_wrap .txt_wrap .news_body {
 width: 100%;
 font-size: 13px;
 line-height: 1.35;
 letter-spacing: 0.1em;
}
}

/*movie*/
#movie {
 width: 80%;
 max-width: 1400px;
 margin: 0 auto 120px;
}
#movie h2 {
 font-size: 80px;
 line-height: 1.1;
 font-family: "Roboto", sans-serif;
 font-weight: 900;
 font-style: italic;
 letter-spacing: 0.02em;
 margin-bottom: 30px;
}
#movie h2 span {
 font-size: 14px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 margin-left: 0.5em;
}
#movie .movie_wrap {
 width: 100%;
 white-space: nowrap;
 padding-bottom: 75px;
 overflow-x: hidden;
}
#movie .swiper-slide .movie_thumb {
 box-sizing: border-box;
 margin-bottom: 25px;
}
#movie .swiper-slide p {
 font-size: 20px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 text-wrap: auto;
 text-align: left;
}
#movie .swiper-slide p span {
 font-size: 0.7em;
}
/*swiper*/
#movie .swiper {
 margin-left: auto;
 margin-right: auto;
 position: relative;
 list-style: none;
 padding: 0;
 z-index: 1;
}
#movie .swiper--wrapper {
 width: 100%;
 height: 300px;
}
#movie .swiper-slide {
 width: 100%;
 height: 100%;
}
#movie .swiper-pagination-progressbar {
 width: 32%;
 background-color: #FFF;
 top: unset;
 left: 115px;
 bottom: -45px;
 display: none;
}
#movie .swiper-pagination-progressbar-fill {
 background-color: #000;
}
#movie .swiper-button-prev {
 width: 30px;
 height: 30px;
 position: absolute;
 top: unset;
 bottom: -58px;
 left: 0; 
 display: none;
}
#movie .swiper-button-next {
 width: 30px;
 height: 30px;
 position: absolute;
 top: unset;
 bottom: -58px;
 left: 50px; 
 display: none;
}
#movie .swiper-button-prev:after {
 content: "";
 background-image: url("../img/common/ico_arrow_L.svg");
 background-size: 30px 30px;
 width: 30px;
 height: 30px;
}
#movie .swiper-button-next:after {
 content: "";
 background-image: url("../img/common/ico_arrow_R.svg");
 background-size: 30px 30px;
 width: 30px;
 height: 30px;
}
@media (max-width: 768px) {
#movie {
 width: 95%;
 margin: 0 auto 80px;
}
#movie h2 {
 font-size: 54px;
 line-height: 1.1;
 letter-spacing: 0.02em;
 margin-bottom: 20px;
}
#movie h2 span {
 font-size: 11px;
 letter-spacing: 0.1em;
}
#movie .movie_wrap {
 width: 100%;
 white-space: nowrap;
 padding-bottom: 75px;
}
#movie .swiper-slide .movie_thumb {
 box-sizing: border-box;
 margin-bottom: 20px;
}
#movie .swiper-slide p {
 font-size: 18px;
 line-height: 1.33;
 letter-spacing: 0.1em;
 text-wrap: auto;
}
/*swiper*/
#movie .swiper {
 margin-left: auto;
 margin-right: auto;
 position: relative;
 list-style: none;
 padding: 0;
 z-index: 1;
}
#movie .swiper--wrapper {
 width: 100%;
 height: 300px;
}
#movie .swiper-slide {
 width: 100%;
 height: 100%;
 padding-right: 5%;
}
#movie .swiper-pagination-progressbar {
 width: 32%;
 background-color: #FFF;
 top: unset;
 left: 115px;
 bottom: -45px;
 display: block;
}
#movie .swiper-pagination-progressbar-fill {
 background-color: #000;
}
#movie .swiper-button-prev {
 width: 30px;
 height: 30px;
 position: absolute;
 top: unset;
 bottom: -58px;
 left: 0; 
 display: block;
}
#movie .swiper-button-next {
 width: 30px;
 height: 30px;
 position: absolute;
 top: unset;
 bottom: -58px;
 left: 50px; 
 display: block;
}
#movie .swiper-button-prev:after {
 content: "";
 background-image: url("../img/common/ico_arrow_L.svg");
 background-size: 30px 30px;
 width: 30px;
 height: 30px;
 display: block;
}
#movie .swiper-button-next:after {
 content: "";
 background-image: url("../img/common/ico_arrow_R.svg");
 background-size: 30px 30px;
 width: 30px;
 height: 30px;
 display: block;
} 
}

/*message*/
#message {
 width: 80%;
 max-width: 1400px;
 margin: 0 auto;
}
#message h2 {
 font-size: 80px;
 line-height: 1.1;
 font-family: "Roboto", sans-serif;
 font-weight: 900;
 font-style: italic;
 letter-spacing: 0.02em;
 margin-bottom: 30px;
}
#message h2 span {
 font-size: 14px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 margin-left: 0.5em;
}
#message .message_wrap {
 width: 100%;
}
#message .message_inner p {
 font-size: 15px;
 line-height: 2;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 500;
 letter-spacing: 0.05em;
}
#message .profile_wrap {
 width: 100%;
 background-color: #FFF;
 padding: 4%;
 margin-top: 40px;
}
#message .profile_inner {
 width: auto;
 white-space: normal;
}
#message .profile_inner h3 {
 display: inline-block;
 border-bottom: 1px solid #000;
 font-size: 15px;
 line-height: 1.4;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 margin-bottom: 15px;
}
#message .profile_inner h3 span {
 font-size: 0.8em;
}
#message .profile_inner li {
 font-size: 12px;
 line-height: 1.8;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 400;
 padding-left: 1em;
 text-indent: -1em;
}
@media (max-width: 768px) {
#message {
 width: 90%;
 margin: 0 auto;
}
#message h2 {
 font-size: 54px;
 line-height: 1.1;
 letter-spacing: 0.02em;
 margin-bottom: 20px;
}
#message h2 span {
 font-size: 11px;
 letter-spacing: 0.1em;
 margin: 0.5em 0 0 0;
 display: block;
}

#message .message_inner p {
 font-size: 13px;
 line-height: 1.8;
 letter-spacing: 0.05em;
}
#message .profile_wrap {
 width: 100%;
 background-color: #FFF;
 padding: 20px;
 margin-top: 30px;
}
#message .profile_inner {
 width: auto;
 white-space: normal;
}
#message .profile_inner h3 {
 display: inline-block;
 border-bottom: 1px solid #000;
 font-size: 13px;
 line-height: 1.4;
 letter-spacing: 0.1em;
 margin-bottom: 15px;
}
#message .profile_inner li {
 font-size: 12px;
 line-height: 1.8;
 padding-left: 1em;
 text-indent: -1em;
}
}

/*report*/
#report {
 width: 100%;
 margin: 0 auto;
 padding: 9% 0 5%;
 position: relative;
 background-image: url("../img/top/bg_line03.png");
 background-position: top center;
 background-repeat: no-repeat;
 background-size: 100% auto;
}
#report h2 {
 font-size: 80px;
 line-height: 1.1;
 font-family: "Roboto", sans-serif;
 font-weight: 900;
 font-style: italic;
 letter-spacing: 0.02em;
 margin-bottom: 15px;
}
#report h2 span {
 font-size: 28px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 margin-left: 0.5em;
 display: block;
}
#report  .report_body {
 font-size: 15px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.18em;
 line-height: 1.6;
 margin-bottom: 30px;
}
#report .repot_wrap {
 width: 80%;
 max-width: 1400px;
 margin: 0 auto;
}
.report_cardwrap {
 align-items: stretch;
 justify-content: flex-start;
 gap: 25px;
 padding: 0 0 50px;
 display: grid;
 grid-template-columns: repeat(3, 1fr)
}
.report_cardwrap li {
 background-color: #e6e6e6;
 background-image: url("../img/common/ico_arrow_R.svg");
 background-position: right 20px bottom 20px;
 background-repeat: no-repeat;
 background-size: 30px 30px;
}
.report_cardwrap li .card_txt_wrap {
 padding: 20px 20px 10px 20px;
}
.report_cardwrap li .card_txt_inner {
 display: flex;
 justify-content: space-between;
 align-items: center;
 margin-bottom: 10px;
}
.report_cardwrap li .card_cate span {
 color: #FFF;
 font-size: 13px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 500;
 letter-spacing: 0.1em;
 padding: 3px 5px;
 border-radius: 5px;
 margin-right: 5px;
}
.report_cardwrap li .card_date {
 font-size: 14px;
 font-family: "Red Hat Text", sans-serif;
 font-weight: 400;
 letter-spacing: 0.05em;
}
.report_cardwrap li .card_subttl {
 font-size: 15px;
 line-height: 1.33;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 margin-bottom: 10px;
 padding-right: 30px;
}
.report_cardwrap li .card_ttl {
 font-size: 18px;
 line-height: 1.33;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 margin-bottom: 10px;
 padding-right: 30px;
}
.btn_more {
 width: 300px;
 margin: 0 auto;
}
.btn_more a {
 color: #FFF;
 text-align: center;
 font-size: 24px;
 font-family: "Roboto", sans-serif;
 font-weight: 900;
 font-style: italic;
 letter-spacing: 0.02em;
 padding: 20px 35px 20px 15px;
 display: block;
 background-color: #000;
 border-radius: 999px;
 background-image: url("../img/common/ico_arrow_R_wh.svg");
 background-position: right 20px center;
 background-size: 35px 35px;
 background-repeat: no-repeat;
}
@media (max-width: 992px) {
.report_cardwrap {
 align-items: stretch;
 justify-content: flex-start;
 gap: 20px;
 padding: 0 0 30px;
 display: grid;
 grid-template-columns: repeat(2, 1fr);
}
}
@media (max-width: 768px) {
#report {
 width: 100%;
 margin: 0 auto;
 padding: 100px 0 100px;
 position: relative;
 background-image: url("../img/top/bg_line03_SP.png");
 background-position: top center;
 background-repeat: no-repeat;
 background-size: 100% auto;
}
#report h2 {
 font-size: 54px;
 line-height: 1.1;
 letter-spacing: 0.02em;
 margin-bottom: 10px;
}
#report h2 span {
 font-size: 18px;
 letter-spacing: 0.1em;
 display: block;
}
#report .repot_wrap {
 width: 90%;
 margin: 0 auto;
}
.report_cardwrap {
 max-width: 420px;
 margin: 0 auto;
 align-items: stretch;
 justify-content: flex-start;
 gap: 20px;
 padding: 0 0 30px;
 display: grid;
 grid-template-columns: repeat(1, 1fr);
}
.report_cardwrap li {
 background-color: #e6e6e6;
 background-image: url("../img/common/ico_arrow_R.svg");
 background-position: right 10px bottom 10px;
 background-repeat: no-repeat;
 background-size: 30px 30px;
}
.report_cardwrap li .card_txt_wrap {
 padding: 20px 20px 10px 20px;
}
.report_cardwrap li .card_txt_inner {
 display: flex;
 justify-content: space-between;
 align-items: center;
 margin-bottom: 10px;
}
.report_cardwrap li .card_cate span {
 color: #FFF;
 font-size: 13px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 500;
 letter-spacing: 0.1em;
 padding: 3px 5px;
 border-radius: 5px;
 margin-right: 5px;
}
.report_cardwrap li .card_date {
 font-size: 14px;
 font-family: "Red Hat Text", sans-serif;
 font-weight: 400;
 letter-spacing: 0.05em;
}
.report_cardwrap li .card_subttl {
 font-size: 14px;
 line-height: 1.33;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 margin-bottom: 10px;
 padding-right: 30px;
}
.report_cardwrap li .card_ttl {
 font-size: 18px;
 line-height: 1.33;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 margin-bottom: 10px;
 padding-right: 30px;
}
.btn_more {
 width: 300px;
 margin: 0 auto;
}
.btn_more a {
 color: #FFF;
 text-align: center;
 font-size: 18px;
 font-family: "Roboto", sans-serif;
 font-weight: 900;
 font-style: italic;
 letter-spacing: 0.02em;
 padding: 20px 35px 20px 15px;
 display: block;
 background-color: #000;
 border-radius: 999px;
 background-image: url("../img/common/ico_arrow_R_wh.svg");
 background-position: right 20px center;
 background-size: 30px 30px;
 background-repeat: no-repeat;
}
}

/*statement*/
#statement {
 width: 100%;
 margin: 0 auto;
 padding: 9% 0 22%;
 position: relative;
 background-image: url("../img/top/bg_line02.png");
 background-position: bottom center;
 background-repeat: no-repeat;
 background-size: 100% auto;
}
#statement .statement_inner {
 width: 75%;
 max-width: 1400px;
 margin: 0 auto;
 display: flex;
 align-items: flex-start;
 justify-content: space-between;
 flex-wrap: nowrap;
}
#statement .ttl_area {
 width: 37%;
 margin: 0 auto 0 0;
}
#statement .copy_area {
 width: auto;
 margin: 0 0 0 auto;
 text-align: left;
 display: flex;
 justify-content: center;
}
#statement .copy_area p {
 font-size: 16px;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.18em;
 line-height: 2.5;
}
@media (max-width: 768px) {
 #statement {
 padding: 0 0 150px;
 background-image: url("../img/top/bg_line02_SP.png");
}
#statement .bnr_mov {
 width: 90%;
 margin: 0 auto;
}
#statement .statement_inner {
 width: 90%;
 margin: 0 auto;
 display: block;
}
#statement .ttl_area {
 width: 82%;
 margin: 0 auto 35px 0;
}
#statement .copy_area {
 width: 100%;
 margin: 0 auto;
 text-align: left;
 display: block;
}
#statement .copy_area p {
 font-size: 14px;
 letter-spacing: 0.15em;
 line-height: 2.5;
}
}

/*modal*/
body.modal_lock{
 overflow:hidden;
}
.modal_mov {
 width: 100vw;
 height: 100vh;
 position: fixed;
 top: 0;
 left: 0;
 z-index: 1000;
 display: none;
}
.modal_mov.show {
 display: block;
}
.modal_mov .bg {
 width: 100%;
 height: 100%;
 position: absolute;
 top: 0;
 left: 0;
 background: rgba(0, 0, 0, .9);
 z-index: 0;
}
.modal_mov .mov_wraaper {
 width: 90%;
 max-width: 900px;
 margin: 0 auto;
 overflow-x: hidden;
 overflow-y: auto;
 position: relative;
 pointer-events: none;
}
.modal_mov .mov_inner {
 height: 900px;
 margin: calc(50vh - 300px) auto 0 auto;
 position: relative;
 pointer-events: none;
}
.modal_mov .btn_close_wrap {
 width: 30px;
 height: 30px;
 display: block;
 position: absolute;
 top: 0;
 right: 0;
 pointer-events: all;
}
.modal_mov .btn_close_wrap button {
 width: 100%;
 height: 100%;
 background-image: url("../img/common/btn_close.svg");
 background-position: 0 0;
 background-size: 100% auto;
 background-repeat: no-repeat;
}
.modal_mov .mov_ttl {
 color: #FFF;
 text-align: center;
 font-size: 26px;
 line-height: 1.33;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
 margin-bottom: 15px;
}
.modal_mov .mov_frame {
 width: 100%;
 aspect-ratio: 16 / 9;
 margin: 0 auto;
}
.modal_mov .mov_frame iframe {
 width: 100%;
 height: 100%;
 pointer-events: all;
}
.modal_mov .mov_thumb_inner {
 max-width: 580px;
 margin: 30px auto;
 pointer-events: all;
}
.modal_mov .mov_thumb_inner ul {
 width: 100%;
 margin: 0 auto;
 display: flex;
 align-items: center;
 justify-content: space-between;
}
.modal_mov .mov_thumb_inner ul li {
 width: 30%;
 margin: 0 auto;
 text-align: center;
}
.modal_mov .mov_thumb_inner ul li a .thumb_img.active {
 border: 4px solid #FFF;
 box-sizing: border-box;
}
.modal_mov .mov_thumb_inner ul li a .thumb_cap {
 color: #FFF;
 text-align: center;
 font-size: 20px;
 line-height: 1.33;
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-weight: 700;
 letter-spacing: 0.1em;
}
.modal_mov .mov_thumb_inner ul li a .thumb_cap span {
 font-size: 0.7em;
}
@media (max-width: 768px) {
.modal_mov .mov_wraaper {
 width: 100%;
}
.modal_mov .mov_inner {
 height: 100%;
 margin: 0 auto;
 position: relative;
 padding: 35% 0 60px;
}
.modal_mov .btn_close_wrap {
 width: 25px;
 height: 25px;
 top: unset;
 bottom: 0;
 right: calc(50% - 12.5px);
}
.modal_mov .mov_ttl {
 font-size: 16px;
 line-height: 1.33;
 margin-bottom: 15px;
}
.modal_mov .mov_frame {
 width: 100%;
 aspect-ratio: 16 / 9;
 margin: 0 auto;
}
.modal_mov .mov_frame iframe {
 width: 100%;
 height: 100%
}
.modal_mov .mov_thumb_inner {
 max-width: 90%;
 margin: 30px auto 0;
}
.modal_mov .mov_thumb_inner ul {
 width: 100%;
 margin: 0 auto;
 display: flex;
 align-items: center;
 justify-content: space-between;
}
.modal_mov .mov_thumb_inner ul li {
 width: 30%;
 margin: 0 auto;
 text-align: center;
}
.modal_mov .mov_thumb_inner ul li a .thumb_img.active {
 border: 2px solid #FFF;
 box-sizing: border-box;
}
.modal_mov .mov_thumb_inner ul li a .thumb_cap {
 font-size: 15px;
}
}
@media (orientation: landscape) and (max-width: 768px) {
 .modal_mov.show{
 position:fixed;
 inset:0;
 display:flex;
 align-items:center;
 justify-content:center;
}

.modal_mov .mov_wraaper{
 max-height:100vh;
 overflow-y:auto;
 -webkit-overflow-scrolling:touch;
 width: 100%;
}
.modal_mov .mov_inner {
 width: 100%;
 height: 100%;
 margin: 0 auto;
 position: relative;
 padding: 20px 0 60px;
}
.modal_mov .btn_close_wrap {
 width: 25px;
 height: 25px;
 top: 20px;
 bottom: unset;
 right: 20px;
}
.modal_mov .mov_ttl {
 font-size: 16px;
 line-height: 1.33;
 margin-bottom: 15px;
}
.modal_mov .mov_frame {
 width: 60%;
 aspect-ratio: 16 / 9;
 margin: 0 auto;
}
.modal_mov .mov_frame iframe {
 width: 100%;
 height: 100%
}
.modal_mov .mov_thumb_inner {
 max-width: 60%;
 margin: 30px auto 0;
}
.modal_mov .mov_thumb_inner ul {
 width: 100%;
 margin: 0 auto;
 display: flex;
 align-items: center;
 justify-content: space-between;
}
.modal_mov .mov_thumb_inner ul li {
 width: 30%;
 margin: 0 auto;
 text-align: center;
}
.modal_mov .mov_thumb_inner ul li a .thumb_img.active {
 border: 2px solid #FFF;
 box-sizing: border-box;
}
.modal_mov .mov_thumb_inner ul li a .thumb_cap {
 font-size: 15px;
}
}