@charset "utf-8";

/* index ------------------------------------------------- */

.mainimage {
	margin-bottom: 25px;
}
.mainimage img {
    width: 100%;
    margin-bottom: 0;
	display: block;
}
.mainimage .slick-slide div {
    display: block!important;
}
.slideInner img + div {
	text-shadow: 0px 0px 8px rgba(255, 255, 255, 1);
	top: 0;
	left: 0;
    width: 100%;
	height: 100%;
	position: absolute;
	/*display: flex;
	align-items: center;*/
	/*padding: 80px;*/
	line-height: 4.8rem;
}
.slideInner span {
	text-shadow: 0px 0px 8px rgba(255, 255, 255, 1);
    font-size: 2.0rem;
    color: #000;
}
.ev-Year-title{
	height: calc( 100% - 120px );
	position: relative;
}
.ev-Year-title > h2{
	position: absolute;
    width: 100%;
    height: 50%;
    top: 50%;
    margin-top: -40px;
    text-align: center;
}
span.evTitle {
    text-align: center;
    font-size: 5.6rem;
    font-weight: bold;
}
span.evYear {
    margin-bottom: 20px;
	font-size: 2.4rem;
    font-weight: bold;
    text-align: center;
}
div.evInfo {
	background: rgba(0,0,0,0.30);
	width: 100%;
	height: 120px;
    line-height: 150%;
    left: 0px;
    position: absolute;
    /*font-size: 2.2rem;*/
    font-size: 1.4rem;
    bottom: 0px;
    color: #fff;
}
div.evInfo > div {
	position: absolute;
	height: 50%;
	top: 0;
	bottom: 0;
	margin: auto 2%;
}
img.topcontents_logo {
    width: 250px;
    position: absolute;
    right: 15px;
    margin-bottom: 0;
	top: 0;
	bottom: 0;
	margin: auto 30px;
}
@media only screen and (max-width:768px) {
	.mainimage {
		margin-bottom: 0px;
	}
    .slideInner img + div {
    	padding: 0;
    	line-height: 2rem;
    }
	.ev-Year-title{
		height: calc( 100% - 65px );
		position: relative;
	}
	.ev-Year-title > h2{
		position: absolute;
		width: 100%;
		height: 50%;
		text-align: center;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		margin: auto;
	}
    span.evTitle {
        font-size: 2.6rem;
		display: block;
		margin-bottom: 0;
    }
    span.evYear {
        font-size: 1.3rem;
		display: block;
		margin-bottom: 0;
    }
    div.evInfo {
        font-size: 1.1rem;
        left: 0;
        width: 100%;
        text-align: left;
		height: 65px;
   		padding: 10px;
    }
    img.topcontents_logo {
        /*width: 125px;
        right: 5px;
        bottom: 15px;*/
    }
    .slick-slide img.topcontents_logo {
        display: none;
    }
	.mainimage > .nonePc {
		display: block!important;
	}
}
@media only screen and (max-width:413px) {
    p.evYear {
        margin-bottom: 10px;
    }
}

#jrc2021program ul {
    display: flex;
}
#jrc2021program ul > li:nth-child(1), #jrc2021program ul > li:nth-child(3) {
    display: flex;
    justify-content: center;
    align-items: center;
}
@media only screen and (max-width:768px) {
    #jrc2021program ul {
        display: block;
    }
    #jrc2021program ul > li:nth-child(1), #jrc2021program ul > li:nth-child(3) {
        display: block;
    }
    #jrc2021program .flexBox1 {
        display: flex!important;
    }
}

/* ------------------------------------------------------- */
/* side -------------------------------------------------- */
/* ------------------------------------------------------- */

#entry li a {
	background: #eee;
	display: block;
	margin-bottom: 7px;
	padding: 10px 15px 10px 13px;
	color: #000;
	text-decoration: none;
    transition: all 0.3s ease;
	position: relative;
    font-size: 1.6rem;
}
#entry li a:hover {
	background: #999;
	color: #fff;
}
#entry li a:before {
	position: absolute;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f105";
	top:10px;
	right: 10px;	
}
#entry li a:before { color: #333; }
#entry li a:hover:before { color: #dbeeff; }

@media all and (-ms-high-contrast: none) {
	#entry li a { padding: 10px 10px 8px; }
}


/* info -------------------------------------------------- */

.thumb_sp { display: none; }
#info div.dat {
    font-size: 1.3rem;
    color: #666;
}
#info div.dat:before {
	font-family: "Font Awesome 5 Free";
	content: "\f073";
	font-weight: 900;
    margin-right: 5px;
}
#info li {
    border-bottom: 1px dotted #ccc;
    margin-bottom: 20px;
    padding-bottom: 10px;
}
#info dt {
    width: 280px;
    float: left;
}
#info dt img {
    width: 100%;
    height: auto;
}
#info dd {
}
#info dd div.except {
    font-size: 1.4rem;
}
#info div.except {
    font-size: 1.3rem;
}

@media only screen and (max-width:768px) {
    
    #info dt {
        /*width: 100%;
        float: none;*/
        display: none;
    }
    #info dd {
        width: 100%;
        height: auto;
        float: none;
    }
    #info div.dat {
        margin-bottom: 5px;
        text-align: left;
        font-size: 1.3rem;
    }
    .thumb_sp {
        display: block;
    }
    .thumb_sp img {
        width: 150px;
        height: auto;
        margin: 0 10px 10px 0;
        float: left;
    }
    
}

/* sideBanner -------------------------------------------------- */

.sideBanner a:hover {
    opacity: 0.7;
}
.sideBanner .txtBanner a {
    border: 1px solid #ccc;
    display: block;
    text-decoration: none;
    padding: 15px;
    text-align: center;
    font-size: 1.35rem;
    line-height: 140%;
    color: #000;
}
.sideBanner .txtBanner a:hover {
    background: #ccc;
    border: 1px solid #999;
}

.page pre{
	white-space: pre-wrap;
}