@charset "utf-8";

.img-pc {
    display: none;
}
.pc{
    display: none;
}
#marathon2025 {
	position: relative;
	margin: 0 auto;
	font-family: 'Noto Sans JP', "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 15px;
	line-height: 1.6;
	width: 100%;
}

#marathon2025 img{
	width: 100%;
	vertical-align: top;
}

/*---  メイン画像  ---*/

#marathon2025 #contMainPh {
	overflow: hidden;
	text-indent: -10000px;
	text-decoration: none;
}
#marathon2025 #contMainPh img {
	width:100%;
}
#marathon2025 #mainPh {
	position:relative;
	max-height: 180px;
	margin: 0 auto;
}
#marathon2025 #mainPh li.pc{
    display: none;
}
#marathon2025 #mainPh:after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	background: url(../images/marathon2025_logo.png?250612) no-repeat top center;
	background-size: contain;
	width: 90%;
	/* min-width: 483px; */
	height: 62%;
	margin: 0 auto;
}
#marathon2025 #mainPhNav {
	max-height: 160px;
	margin: 0 auto;
}

#marathon2025 #contSubPh {
	position:relative;
	max-height: 160px;
	margin: 0 auto;
	overflow: hidden;
}
#marathon2025 #contSubPh img {
	width:100%;
}
#marathon2025 #contSubPh:after {
	content:" ";
	position:absolute;
	top:0;
	left:0;
	right: 0;
	bottom: 0;
	z-index:99999;
	background:url("../images/sub_ttl.png") no-repeat;
	background-size: contain;
	margin: auto;
	display: block;
	width: 100%;
	height: 100%;
	max-width: 1000px;
	max-height: 160px;
}

/*---  カウントダウンタイマー  ---*/

#marathon2025 .countdown{
	padding: 10px 0;
	margin: 10px 0;
	color: #fff;
/*	background-color: #034ea2;*/
	background-color: #003e8b;
	text-align: center;
	position: relative;
}
#marathon2025 .countdown::before{
	content: "";
	display: block;
	background: url("../images/clock_line.jpg");
	background-size: cover;
	width: 100%;
	height: 8%;
	position: absolute;
	left: 0;
	top: 0;
}
#marathon2025 .countdown::after{
	content: "";
	display: block;
	background: url("../images/clock_line.jpg");
	background-size: cover;
	background-position: bottom;
	width: 100%;
	height: 8%;
	position: absolute;
	left: 0;
	bottom: 0;
}
#marathon2025 .countdown p {
	margin-bottom:5px;
}
#marathon2025 .countdown .yycountdown-box{
	font-size: 28px;
	line-height: 1.4;
	font-weight: bold;
}
#marathon2025 .countdown .yycountdown-box em{
	font-size: 15px;
	font-style: normal;
	font-weight: normal;
}
#marathon2025 .countdown .yycountdown-box span,.countdown .yycountdown-box em{
	padding: 0 2px;
}
#marathon2025 .countdown > *{
	display:none;
}
#marathon2025 .countdown #before{
	font-size: 18px;
	line-height: 1.4;
	font-weight: bold;
}
#marathon2025 .countdown #start{
	font-size: 28px;
	line-height: 1.4;
	font-weight: bold;
}
#marathon2025 .countdown #end{
	font-size: 18px;
	line-height: 1.4;
	font-weight: bold;
}

/*---  ナビゲーション  ---*/
#marathon2025 #header .nav_inner{
	max-width: 100%;
	background: #003e8b;
}
#marathon2025 #nav {
    color: #fff;
    width: 100%;
    margin: 0 auto;
}
#marathon2025 #nav ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
#marathon2025 #nav li {
    width: 33.3%;
    position: relative;
    border-bottom: 1px solid #ffffff;
}

#marathon2025 #nav li:after {
    content: "";
    position: absolute;
    left: 0;
    width: 1px;
    height: 62%;
    background: #ffffff;
    top: 0;
    bottom: 0;
    margin: auto;
}
#marathon2025 #nav li:first-child:after {
    content: none;
}
#marathon2025 #nav li:nth-last-of-type(-n+2) {
    width: 50%;
}
/*#marathon2025 #nav li:nth-last-of-type(3):after {
   content: none;*/
}
#marathon2025 #nav li:nth-last-of-type(2):after {
/*     content: none; */
}
#marathon2025 #nav li a {
    text-align: center;
    line-height: 1.3;
    padding: 0.55em 0.35em;
    font-weight: bold;
    transition: .5s;
    display: block;
    text-decoration: none;
    font-size: 120%;
    color: inherit;

}
#marathon2025 #nav li a:hover {
    background: rgb(255 255 255 / 25%);
    opacity: 1;
}
#marathon2025 #nav li a.current {
    background: rgb(255 255 255 / 15%);
}
#marathon2025 #nav li a.gray {
    color: rgb(255 255 255 / 50%);
    background: #777777;
    cursor: auto;
}
#marathon2025 #nav li .sub {
    display: block;
    font-size: 42.85%;
    letter-spacing: 0.05em;
    color: #d6d6d6;
}

#marathon2025 #main {
    position: relative;
    max-width: 1280px;
    margin: 0 auto;
}
#marathon2025 #main_inner {
    margin: 0 auto;
    /* background: #fff; */
    z-index: 0;
    width: 100%;
    padding: 5% 15px 10%;
    position: relative;
}
#marathon2025 ul.contents_wrap {
    display: flex;
    flex-wrap: wrap;
    width: 90%;
    margin: 0 auto;
    justify-content: center;
    align-items: center;
    padding: 4% 0;
}
#marathon2025 ul.contents_wrap li {
    width: 100%;
    margin: 2%;
}

#marathon2025 ul.contents_wrap li a.btn {
    font-family: 'Roboto', YakuHanJP_Noto, 'Noto Sans JP', 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
    display: flex;
    flex-direction: column;
    position: relative;
    font-size: 5vw;
    width: calc(100% - 0.24em);
    padding-top: calc(56.25% - 0.24em);
    transition: .3s;
}

#marathon2025 ul.contents_wrap li a.btn .btn_inner {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 600;
    line-height: 1.3;
    letter-spacing: 0.03em;
    padding-top: 0.5em;
    box-sizing: border-box;
    overflow: hidden;
    background: #000;
    z-index: 1;
}

#marathon2025 ul.contents_wrap li a.btn .btn_inner:after {
    content: 'MORE';
    display: block;
    box-sizing: border-box;
    font-size: 70%;
    font-weight: normal;
    margin-top: 0.6em;
    width: 9em;
    max-width: 100%;
    text-align: center;
    border-radius: 2em;
    padding: 0.4em;
    background: linear-gradient(45deg, #004095, #009ed4);
}

#marathon2025 ul.contents_wrap li a.btn.gray .btn_inner:after {
    content: 'Coming soon';
    background: #a9a9a9;
    color: #333333;
}

#marathon2025 ul.contents_wrap li a.btn:before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0.24em;
    left: 0.24em;
    background: url("../images/hm2025_line_bg02.jpg");
    background-position: bottom center;
    background-size: cover;
}

#marathon2025 ul.contents_wrap li a.btn span {
    font-size: 56%;
    display: block;
    color: #d7d7d7;
}

#marathon2025 ul.contents_wrap li a.btn img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 102%;
    max-width: none;
    opacity: 0.5;
    z-index: -1;
}

#marathon2025 #footer::before{
    content: "";
    display: block;
    background: url("../images/bottom_line.jpg") no-repeat;
    background-position: bottom;
    background-size: cover;
    width: 100%;
    height: 5px;
    position: absolute;
    left: 0;
    top: 0;
}
#marathon2025 ul.bn {
    display: flex;
    justify-content: space-evenly;
    align-items: center;
    max-width: 1280px;
    margin: 0 auto;
}
#marathon2025 ul.bn li {
    width: 18%;
}
/*下層ページ共通*/
#marathon2025 .sub_header{
	background: url("../images/sub_header.jpg")no-repeat top center;
	background-size: cover;
	padding-top: 30%;
	position: relative;
}
#marathon2025 .sub_header::after{
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	background: url(../images/marathon2025_logo.png?250612) no-repeat top center;
	background-size: contain;
	width: 64%;
	/* min-width: 500px; */
	height: 70%;
	margin: 0 auto;
}
#marathon2025 .title_wrap {
    background: linear-gradient(90deg, rgba(0,64,152,1) 0%, rgba(0,161,215,1) 100%);
    padding: 0.5em 0.5em;
    font-weight: bold;
    display: flex;
    align-items: baseline;
    margin-bottom: 5%;
}
#marathon2025 .title {
    font-size: 120%;
    color: #fff;
    padding-left: 0.7em;
}
#marathon2025 .title_wrap::after{
	content: "";
	display: block;
	width: 6px;
	height: 28px;
	background: #fff;
	position: absolute;
}
#marathon2025 .title_small {
    color: #999;
    padding-left: 0.5em;
}
/*---　視聴者プレゼント　---*/
#marathon2025 #present{
	width: 100%;
	position: relative;
	margin: 0 auto;
	background-size: auto auto;
	background-color: rgba(222, 247, 255, 1);
	background-image: repeating-linear-gradient(120deg, transparent, transparent 10px, rgba(185, 232, 253, 1) 10px, rgba(185, 232, 253, 1) 20px );
}
#marathon2025 #present .present_inner{
	max-width: 1280px;
	margin: 0 auto;
	position: relative;
	padding: 3%;
}
#marathon2025 #present .present_bg{
	position: relative;
	background: #fff;
	margin: 0% 0;
}
#marathon2025 #present a.shohin_btn{
	display: block;
	background: #fd451a;
	width: 100%;
	padding: 12px;
	text-align: center;
	color: #FFFFFF;
	font-weight: bold;
	transition-duration: 0.3s;
	margin: 3% 0;
}
#marathon2025 #present .present_ttl{
    /* display: flex; */
    justify-content: center;
    align-items: flex-end;
}
#marathon2025 #present .present_logo {
    width: 75%;
    margin: 0 auto;
    padding-top: 5%;
}
#marathon2025 #present .present_ttltxt{
    width: 90%;
    font-size: 3.3rem;
    color: #ff4700;
    font-weight: bold;
    text-shadow: 2px 3px 0px #e1e1e1;
    margin: 0 auto;
    text-align: center;
}

#marathon2025 #present .present_txt{
    width: 90%;
    margin: 0 auto;
    font-weight: bold;
    padding: 3% 0;
    font-size: 1.4rem;
}
#marathon2025 #present .present_detail {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border: 2px solid #fc4619;
    padding: 4%;
    margin: 0% auto 3%;
    width: 96%;
}
#marathon2025 #present .present_goods_wrap{
    display: flex;
    flex-direction: column;
    align-items: baseline;
    justify-content: space-between;
    width: 100%;
}
#marathon2025 #present .present_goods_wrap.t{
    display: flex;
    align-items: baseline;
    justify-content: center;
    width: 100%;
    margin: 0 auto;
}
#marathon2025 #present .present_goods_wrap.t .goods{
    width: 100%;
    margin: 0 auto;
}
#marathon2025 #present .goods{
    width: 55%;
    margin: 0 auto;
}
#marathon2025 #present .goods_img{
    width: 100%;
    position: relative;
}

#marathon2025 #present .goods_name{
    font-weight: bold;
    font-size: 1.4rem;
    text-align: center;
}

#marathon2025 #present .goods_name span.small{
    font-size: 1.1rem;
}

#marathon2025 #present .present_prize_wrap{
    width: 100%;
}
#marathon2025 #present .prize{
    /* display: flex; */
    /* align-items: baseline; */
    justify-content: space-between;
    font-weight: bold;
    margin-bottom: 0%;
    background: #fff1ed;
    padding: 4% 0;
    margin-top: 4%;
}

#marathon2025 #present .prize_name {
  line-height: 22px;
  position: relative;
  height: 22px;
  padding: 0 2rem;
  text-align: center;
  color: #fff;
  background: #fa4141;
  width: 7em;
  margin: 0 auto 2%;
  font-size: 1.5rem;
}

#marathon2025 #present .prize_name:before,
#marathon2025 #present .prize_name:after {
  position: absolute;
  top: 0;
  display: block;
  height: 15px;
  content: '';
  border: 11px solid #fa4141;
}

#marathon2025 #present .prize_name:before {
  left: -10px;
  border-left-width: 10px;
  border-left-color: transparent;
}

#marathon2025 #present .prize_name:after {
  right: -10px;
  border-right-width: 10px;
  border-right-color: transparent;
}

#marathon2025 #present .prize_name span {
  position: relative;
  display: block;
}
#marathon2025 #present .prize_txt {
	text-align: center;
	font-size: 1.4rem;
}
#marathon2025 #present .prize_txt span.red {
    color: #fa4141;
    font-size: 2rem;
    padding-left: 1%;
    display: inline-block;
}
#marathon2025 #present .step_wrap .step_title{
    font-size: 2rem;
    font-weight:600;
    text-align: center;
    background: #803921;
    color:#ffffff;
    width: 50%;
    margin: 10% auto 6%;
    border-radius: 99px;
}
#marathon2025 #present .step_wrap .step_flexwrap{
    width: 100%;
    margin: 0 auto;
}
#marathon2025 #present .step_wrap .step_contentswrap{
    background: #ffffff;
    width: 90%;
    margin: 7% auto;
    padding: 5%;
    border-radius: 10px;
    box-shadow: 0px 2px 8px 0px rgba(0, 0, 0, 0.35);
}
#marathon2025 #present .step_wrap .step_contents_title{
    width: 28%;
    background: #803921;
    color: #ffffff;
    font-size: 1.4rem;
    font-weight: 600;
    text-align: center;
    border-radius: 6px;
}
#marathon2025 #present .step_wrap .step_contents_text{
    /* width: 90%; */
    font-size: 2rem;
    font-weight: 600;
    margin: 1% 0;
    color: #803921;
}
#marathon2025 #present .step_wrap .step_contents_image{
    width: 100%;
    margin: 0 auto;
    display: block;
}
#marathon2025 #present .step_wrap .step_contentswrap ul li{
    text-indent: -1em;
    padding-left: 1em;
    font-size: 1.4rem;
}
#marathon2025 #present .red{
    color:red;
    font-weight:600;
}
#marathon2025 #present .date {
    text-align: left;
    font-size: 1.5rem;
    font-weight: bold;
    padding: 4%;
    margin: 3% 0 6%;
}
#marathon2025 #present .step_wrap .logo_present{
	margin:2% auto;
}

/*---　動画　---*/
#marathon2025 .movie{
	position: relative;
	width: 95%;
	margin: 0 auto;
}
#marathon2025 .movie .movieCon{
	display: block;
	width: 100%;
	padding-top: 56.25%;
	margin: 0 auto;
}
#marathon2025 .movie iframe{
	position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    background-position: center;
    background-repeat: no-repeat;
    -moz-transition: opacity .25s cubic-bezier(0.0,0.0,0.2,1);
    -webkit-transition: opacity .25s cubic-bezier(0.0,0.0,0.2,1);
    transition: opacity .25s cubic-bezier(0.0,0.0,0.2,1);
    background-size: cover;
    -moz-background-size: cover;
    -webkit-background-size: cover;
}
#marathon2025 .movie img{
	display: none!important;
}

#marathon2025 .movie::after{
    content: "";
    display: block;
    background: url("../images/movie_bg02.png")no-repeat top center;
    background-size: cover;
    padding-top: 45%;
    position: absolute;
    top: 7px;
    left: 7px;
    width: 100%;
    height: 100%;
    z-index: -1;
}

/*番組情報*/
#marathon2025 #program {
    width: 100%;
    position: relative;
    z-index: 1;
}
#marathon2025 #program .pro_infowrap {
    padding: 2% 0;
}
#marathon2025 #program .pro_ttl {
    width: 100%;
    margin: 0 auto;
    color: #003e8b;
    font-size: 110%;
    font-weight: bold;
    background: rgb(63 169 245 / 10%);
    padding: 5px 0 0 10px;
}
#marathon2025 #program .pro_ttl:after {
	content: "";
	display: block;
	height: 3px;
	background: linear-gradient(to right, #034ea2, #3fa9f5);
	margin-top: 5px;
	margin-left: -10px;
}
#marathon2025 #program .pro_info {
    padding: 6% 3%;
    font-size: 100%;
    font-weight: bold;
}
#marathon2025 #program span.small {
    font-size: 90%;
}
#marathon2025 #program ul.cast {
	margin: 0 auto;
	display: flex;
	padding: 6% 0;
	flex-wrap: wrap;
}
#marathon2025 #program ul.cast li{
	width: 47%;
	margin: 0 auto;
	font-size: 120%;
	font-weight: bold;
	text-align: center;
	background: #003e8b;
	color: #fff;
	margin-bottom: 3%;
}
#marathon2025 #program .pro_logo{
	width: 100%;
	margin-bottom: 6%;
}
#marathon2025 #program .pro_flex{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
#marathon2025 #program .pro_photo {
    padding: 6% 0 0;
    width: 100%;
}
#marathon2025 #program .pro_info a {
    display: block;
    width: 100%;
    background: #3fa9f5;
    color: #fff;
    text-align: center;
    margin: 6% 0;
    padding: 8%;
    border-radius: 30px;
    font-size: 90%;
}
#marathon2025 #program .mini_data{
	text-align: center;
	width: 100%;
}
#marathon2025 #program .mini_data .mini_data_ttl{
	font-size: 110%;
	font-weight: bold;
	/* background: linear-gradient(90deg, rgba(0,64,152,1) 0%, rgba(0,161,215,1) 100%); */
	background: #003e8b;
	color: #fff;
	margin: 8% 0 3%;
	padding: 0.5%;
}
#marathon2025 #program .mini_data .date_small{
	font-size: 70%;
	color: #cc000a;
	margin: 0 -1.8% 0 -1.8%;
}
#marathon2025 #program .mini_data .mini_data_txt01{
	font-size: 150%;
	font-weight: bolder;
	display: flex;
	align-items: baseline;
	justify-content: center;
	margin-bottom: -1%;
}
#marathon2025 #program .mini_data .mini_data_txt02{
	font-size: 230%;
	font-weight: bold;
}

/*応援番組情報*/
#marathon2025 #special{
	width: 100%;
	position: relative;
	z-index: 1;
}
#marathon2025 #bansen{
	margin-bottom: 10%;
}
#marathon2025 #special .pro_inner{
	background: #f4f4f4;
	position: relative;
	padding-bottom: 5%;
}
#marathon2025 #special .pro_inner::before{
	content: "";
	background: url("../images/pro_bg.png") no-repeat top center / cover;
	padding-top: 12.24%;
	display: block;
	width: 100%;
	position: absolute;
	top: 0%;
}
#marathon2025 #special .pro_logo {
	width: 100%;
	margin: 0% auto;
	padding-top: 7%;
	position: relative;
	z-index: 2;
}
#marathon2025 #special .mini_data{
	text-align: center;
	width: 100%;
}
#marathon2025 #special .mini_data .mini_data_ttl{
	font-size: 110%;
	font-weight: bold;
	/* background: linear-gradient(90deg, rgba(0,64,152,1) 0%, rgba(0,161,215,1) 100%); */
	background: #003e8b;
	color: #fff;
	margin: 8% 0 3%;
	padding: 0.5%;
}
#marathon2025 #special .mini_data .date_small{
	font-size: 70%;
	color: #003e8b;
	margin: 0 -1.8% 0 -1.8%;
}
#marathon2025 #special .mini_data .mini_data_txt01{
	font-size: 145%;
	font-weight: bolder;
	display: flex;
	align-items: baseline;
	justify-content: center;
	margin-bottom: -1%;
}
#marathon2025 #special .mini_data .mini_data_txt02{
	font-size: 230%;
	font-weight: bold;
}
#marathon2025 #special .mini_data .mini_data_txt03{
	font-size: 110%;
	font-weight: bold;
	color: #7e7e7e;
	margin-bottom: 3%;
}
#marathon2025 #special .mini_data_txt04{
	font-size: 100%;
	font-weight: bold;
	color: #f96464;
	margin-bottom: 1%;
}
#marathon2025 #special .mini_data .mini_data_next{
	font-size: 185%;
	font-weight: bold;
	color: #003e8b;
	border: solid 3px;
	padding: 0.4% 0 0.9%;
	line-height: 3.5rem;
}
#marathon2025 #special .mini_data .mini_data_next .data_small_txt{
	font-size: 70%;
}
#marathon2025 #special .pro_visual{
	width: 100%;
	margin: 4% auto;
}
#marathon2025 #special .pro_flexwrap{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
	padding: 5% 0 5%;
}
#marathon2025 #special .pro_flexwrap02{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
	padding: 5%;
	background: rgb(6 63 137 / 15%);
	margin: 2% 0;
}
#marathon2025 #special .pro_img{
	width: 100%;
	margin: 0 auto 2%;
}
#marathon2025 #special .pro_txt{
	width: 58%;
}
#marathon2025 #special .name{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	margin: 0 auto;
	font-weight: bold;
	text-align: center;
	background: linear-gradient(90deg, rgba(0,64,152,1) 0%, rgba(0,161,215,1) 100%);
	color: #fff;
	padding: 2% 0;
}
#marathon2025 #special span.name_navi {
    margin-right: 1em;
    font-size: 80%;
}
#marathon2025 #special .txt_ttl{
	font-weight: bold;
	font-size: 180%;
	text-align: center;
	margin-bottom: 6%;
}
#marathon2025 #special .pro_cont{
	width: 100%;
	margin: 0 0 5%;
}
#marathon2025 #special .pro_txt {
	background: #fff;
	padding: 5%;
	font-weight: bold;
	width: 100%;
}
#marathon2025 #special .title_back {
    color: #FFF;
    background: linear-gradient(90deg, rgba(0,64,152,1) 0%, rgba(0,161,215,1) 100%);
    padding: 0.5em 0em 0.5em 0em;
    font-weight: bold;
    display: flex;
    align-items: baseline;
    margin-bottom: 0%;
    text-align: center;
    justify-content: center;
}
#marathon2025 #special .title {
    font-size: 120%;
    color: #fff;
    padding-left: 1em;
}
#marathon2025 #special .back {
    background: rgb(6 63 137 / 15%);
    padding: 5% 0 10%;
    margin-bottom: 2%;
}
#marathon2025 #special .movie_flex02{
	width: 90%;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#marathon2025 #special .movie_flex02::before{
	content:"";
	display: block;
	width:23%;
	order:1;
	
}
#marathon2025 #special .movie_flex02::after{
	content:"";
	display: block;
	width: 32%;
}
#marathon2025 #special .movie_flex02 .movie02{
    width: 100%;/*親要素の48%,ここを30％くらいにすると動画3つ並ぶ*/
    position: relative;
    margin: 0px 0 5%; /*↑テキストなくて動画中央配置したい場合はつける*/
    color: #fff;
    text-align: center;
}
#marathon2025 #special .movie_flex02 .movieCon02{
    position: relative;
}
#marathon2025 #special .movie_flex02 .movieCon02 a .ytimgCont02:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 1;
	background: rgb(0 0 0 / 0.1);
	transition: .8s;
}
#marathon2025 #special .movie_flex02 .movieCon02 a .ytimgCont02:after {
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f04b";
	font-size: 30px;
	display: flex;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	justify-content: center;
	align-items: center;
	z-index: 1;
	color: rgb(255 255 255 / 0.8);
	transition: .8s;
}

#marathon2025 #special .movie_flex02 .movie02 .movieCon02 iframe{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    background-position: center;
    background-repeat: no-repeat;
    -moz-transition: opacity .25s cubic-bezier(0.0,0.0,0.2,1);
    -webkit-transition: opacity .25s cubic-bezier(0.0,0.0,0.2,1);
    transition: opacity .25s cubic-bezier(0.0,0.0,0.2,1);
    background-size: cover;
    -moz-background-size: cover;
    -webkit-background-size: cover;
}

#marathon2025 #special .movie_flex02 .movie02 .movieCon02 .ytimgCont02{
    width: 100%;
    padding-top: 56.25%;
    position: relative;
    overflow: hidden;
    transition: .3s;
    opacity: 0.8;
}
#marathon2025 #special .movie_flex02 .movie02 .movieCon02 .ytimgCont02:hover{
	opacity: 1;
	transition: .3s;
}
#marathon2025 #special .movie_flex02 .movie02 .movieCon02 .ytimgCont02 img::before{
	content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1;
    background: rgb(0 0 0 / 0.2);
    transition: .4s;
}
    
#marathon2025 #special .movie_flex02 .movie02 .movieCon02 .ytimgCont02 img {
    width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}


#marathon2025 #special .movie02 p{
	font-size: 90%;
	text-align: left;
	color: #251e1d;
}
#marathon2025 #special .movie02 h3{
	text-align: left;
	font-size: 100%;
	color: #999;
	font-weight: 800;
	text-align: right;
}
#marathon2025 #special .movie02 h4{
	text-align: left;
	font-size: 100%;
	color: #464241;
	font-weight: 800;
}
#marathon2025 #special .more {
    max-width: 180px;
    padding: 1px 0 5px 0;
    display: block;
    background: linear-gradient(90deg, rgba(0,64,152,1) 0%, rgba(0,161,215,1) 100%);
    text-align: center;
    letter-spacing: 2px;
    color: #fff;
    font-weight: bold;
    font-size: 120%;
    margin: 2% auto 0;
}
#marathon2025 a.note{
	width: 90%;
	padding: 3%;
	display: block;
	background: #2cb696;
	text-align: center;
	letter-spacing: 2px;
	color: #fff;
	font-weight: bold;
	font-size: 120%;
	margin: 8% auto;
}
/*特別番組情報*/
#marathon2025 #special0819 {
    width: 100%;
    position: relative;
    z-index: 1;
}
#marathon2025 #special0819 .pro_logo {
    width: 100%;
    margin: 0% auto;
    padding: 4% 0;
    position: relative;
    z-index: 2;
}
#marathon2025 #special0819 .pro_flexwrap {
    display: flex;
    flex-direction: column;
    /* justify-content: space-evenly; */
    /* align-items: center; */
    position: relative;
    padding: 0 4%;
}
#marathon2025 #special0819 .pro_img {
    width: 100%;
    margin: 0 auto 2%;
}
#marathon2025 #special0819 .pro_txtwrap {
    background: rgb(63 169 245 / 15%);
    width: 100%;
    margin: 0 auto;
    padding: 4% 0;
}
#marathon2025 #special0819 .pro_txt {
	width: 84%;
	margin: 0 auto;
	font-size: 110%;
	font-weight: bold;
}
#marathon2025 #special0819 .pro_ttl {
    width: 85%;
    margin: 0 auto 4%;
    background: #063f89;
    color: #fff;
    padding: 2px;
    text-align: center;
    border-radius: 30px;
    font-size: 115%;
}
#marathon2025 #special0819 .pro_guestwrap{
	margin-top: 3%;
}
#marathon2025 #special0819 ul.pro_guestlist {
	width: 100%;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
}
#marathon2025 #special0819 ul.pro_guestlist li{
	width: 47%;
	margin: 0 auto;
	font-size: 120%;
	font-weight: bold;
	text-align: center;
	background: #3fa9f5;
	color: #fff;
	margin-bottom: 3%;
	display: flex;
	flex-direction: column;
	align-items: center;
}

/*大会概要*/
#marathon2025 #outline{
	width: 100%;
	margin: 0 auto 5%;
	position: relative;
}
#marathon2025 #outline .ol_flexwrap{
    width: 100%;
    margin: 0 auto;
    background: #f0f6ff;
    border: 1px solid #fff;
}
#marathon2025 #outline .ol_flex{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: inherit;
    padding: 0% 0 0;
    font-size: 110%;
    /* border-top: 1px solid #aaa; */
}

#marathon2025 #outline .ol_flex h3 {
    width: 100%;
    padding: 1px;
    background: #003e8b;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    /* border-radius: 10px; */
    font-weight: bold;
}
#marathon2025 #outline .ol_flex p {
    width: 100%;
    padding: 1.4em;
    font-size: 90%;
}
#marathon2025 #outline .inlineBlock{
	display: inline-block;
}
/*コース紹介*/
#marathon2025 #course{
	width: 100%;
	margin: 0 auto;
	position: relative;
}
#marathon2025 #course .course_inner{
	display: flex;
	justify-content: space-around;
	width: 90%;
	margin: 0 auto;
}
#marathon2025 #course .course_inner img{
	box-shadow: 3px 3px 10px #aaa;
}

#marathon2025 #course .map_img{
	width: 95%;
	margin: 10% auto 0;
}
#marathon2025 #footer{
	width: 100%;
	padding: 5.0322%;
	margin: 0 0;
	background: #003e8b;
	position: relative;
}
#marathon2025 ul.bn{
	display: flex;
	justify-content: space-around;
	align-items: center;
}
#marathon2025 ul.bn li{
	width: 46%;
}
#marathon2025 a.top{
	display: block;
	text-decoration: none;
	width: 200px;
	font-size: 120%;
	margin: 10% auto 0;
	font-weight: bold;
	position: relative;
	overflow: hidden;
	text-decoration: none;
	padding: 10px 30px;
	text-align: center;
	outline: none;
	transition: ease .2s;
	background: #003e8b;
	border-radius: 30px;
}
#marathon2025 a.top span {
  position: relative;
  z-index: 3;
  color: #fff;
}

/*
#marathon2025 a.more_btn{
	margin: 0% auto 14%;
	max-width: 250px;
	 background: #999; 
	background: #ae8a3d;
	border-radius: 40px;
	color: #FFFFFF;
	padding: 20px;
	text-align: center;
	font-weight: 900;
	font-size: 110%;
}
#marathon2025 a.oubo_btn_gray{
	margin: 0% auto 14%;
	max-width: 250px;
	background: #999;
	border-radius: 40px;
	color: #FFFFFF;
	padding: 20px;
	text-align: center;
	font-weight: 900;
	font-size: 110%;
}
#marathon2025 a.oubo_btn{
	margin: 0% auto 14%;
	max-width: 250px;
	background: #ae8a3d;
	border-radius: 40px;
	color: #FFFFFF;
	padding: 20px;
	text-align: center;
	font-weight: 900;
	font-size: 110%;
}
*/

/*中止のとき*/
#marathon2025 .cancel {
    width: 96%;
    margin: 0 auto;
    padding: 4% 0;
}
#marathon2025 .cancel_txt{
	text-align: center;
	border: 2px solid #cc000a;
	background: #ffd4de;
	padding: 4%;
}
#marathon2025 .cancel p {
    color: #cc000a;
    font-size: 90%;
    font-weight: bold;
    margin-bottom: 4%;
}
#marathon2025 .cancel a {
    display: block;
    background: #21009d;
    color: #fff;
    font-weight: bold;
    padding: 3%;
    width: 100%;
    margin: 0 auto;
}

/*配信*/
.movieWrap {
    position: relative;
    margin-bottom: 10%;
}
.comingSoon,.close {
    position: absolute;
    width: 95%;
    z-index: 2;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}