@charset "utf-8";

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,p,blockquote,th,td,main,figure{margin:0;padding:0}table{font-size:100%;font-family:inherit}fieldset,img{border:0}img,svg{vertical-align:middle}address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:400}ol,ul{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%}q:before,q:after{content:''}abbr,acronym{border:0}select,input,textarea{font-size:100%}header,footer,nav,main,section,article,figure,aside{display:block}.clearfix:after,.row:after{content:"";display:table;clear:both}.fl{float:left}.fr{float:right}@media screen and (min-width: 769px),print{.pc_fl{float:left}.pc_fr{float:right}}@media screen and (max-width: 768px){.sp_fl{float:left}.sp_fr{float:right}}.tal{text-align:left!important}.tac{text-align:center!important}.tar{text-align:right!important}@media screen and (min-width: 769px),print{.pc_tal{text-align:left!important}.pc_tac{text-align:center!important}.pc_tar{text-align:right!important}}@media screen and (max-width: 768px){.sp_tal{text-align:left!important}.sp_tac{text-align:center!important}.sp_tar{text-align:right!important}}.m00{margin:0!important}.mb00{margin-bottom:0!important}.mb05{margin-bottom:5px!important}.mb08{margin-bottom:8px!important}.mb10{margin-bottom:10px!important}.mb15{margin-bottom:15px!important}.mb20{margin-bottom:20px!important}.mb25{margin-bottom:25px!important}.mb30{margin-bottom:30px!important}.mb35{margin-bottom:35px!important}.mb40{margin-bottom:40px!important}.mb45{margin-bottom:45px!important}.mb50{margin-bottom:50px!important}.mt00{margin-top:0!important}.mt05{margin-top:5px!important}.mt08{margin-top:8px!important}.mt10{margin-top:10px!important}.mt15{margin-top:15px!important}.mt20{margin-top:20px!important}.mt25{margin-top:25px!important}.mt30{margin-top:30px!important}.mt35{margin-top:35px!important}.mt40{margin-top:40px!important}.mt45{margin-top:45px!important}.mt50{margin-top:50px!important}@media screen and (min-width: 769px),print{.pc_m00{margin:0!important}.pc_mb00{margin-bottom:0!important}.pc_mb05{margin-bottom:5px!important}.pc_mb08{margin-bottom:8px!important}.pc_mb10{margin-bottom:10px!important}.pc_mb15{margin-bottom:15px!important}.pc_mb20{margin-bottom:20px!important}.pc_mb25{margin-bottom:25px!important}.pc_mb30{margin-bottom:30px!important}.pc_mb35{margin-bottom:35px!important}.pc_mb40{margin-bottom:40px!important}.pc_mb45{margin-bottom:45px!important}.pc_mb50{margin-bottom:50px!important}.pc_mt00{margin-top:0!important}.pc_mt05{margin-top:5px!important}.pc_mt08{margin-top:8px!important}.pc_mt10{margin-top:10px!important}.pc_mt15{margin-top:15px!important}.pc_mt20{margin-top:20px!important}.pc_mt25{margin-top:25px!important}.pc_mt30{margin-top:30px!important}.pc_mt35{margin-top:35px!important}.pc_mt40{margin-top:40px!important}.pc_mt45{margin-top:45px!important}.pc_mt50{margin-top:50px!important}}@media screen and (max-width: 768px){.sp_m00{margin:0!important}.sp_mb00{margin-bottom:0!important}.sp_mb05{margin-bottom:5px!important}.sp_mb08{margin-bottom:8px!important}.sp_mb10{margin-bottom:10px!important}.sp_mb15{margin-bottom:15px!important}.sp_mb20{margin-bottom:20px!important}.sp_mb25{margin-bottom:25px!important}.sp_mb30{margin-bottom:30px!important}.sp_mb35{margin-bottom:35px!important}.sp_mb40{margin-bottom:40px!important}.sp_mb45{margin-bottom:45px!important}.sp_mb50{margin-bottom:50px!important}.sp_mt00{margin-top:0!important}.sp_mt05{margin-top:5px!important}.sp_mt08{margin-top:8px!important}.sp_mt10{margin-top:10px!important}.sp_mt15{margin-top:15px!important}.sp_mt20{margin-top:20px!important}.sp_mt25{margin-top:25px!important}.sp_mt30{margin-top:30px!important}.sp_mt35{margin-top:35px!important}.sp_mt40{margin-top:40px!important}.sp_mt45{margin-top:45px!important}.sp_mt50{margin-top:50px!important}}.p00{padding:0!important}.pb00{padding-bottom:0!important}.pb05{padding-bottom:5px!important}.pb08{padding-bottom:8px!important}.pb10{padding-bottom:10px!important}.pb15{padding-bottom:15px!important}.pb20{padding-bottom:20px!important}.pb25{padding-bottom:25px!important}.pb30{padding-bottom:30px!important}.pb35{padding-bottom:35px!important}.pb40{padding-bottom:40px!important}.pb45{padding-bottom:45px!important}.pb50{padding-bottom:50px!important}.pt00{padding-top:0!important}.pt05{padding-top:5px!important}.pt08{padding-top:8px!important}.pt10{padding-top:10px!important}.pt15{padding-top:15px!important}.pt20{padding-top:20px!important}.pt25{padding-top:25px!important}.pt30{padding-top:30px!important}.pt35{padding-top:35px!important}.pt40{padding-top:40px!important}.pt45{padding-top:45px!important}.pt50{padding-top:50px!important}@media screen and (min-width: 769px),print{.pc_p00{padding:0!important}.pc_pb00{padding-bottom:0!important}.pc_pb05{padding-bottom:5px!important}.pc_pb08{padding-bottom:8px!important}.pc_pb10{padding-bottom:10px!important}.pc_pb15{padding-bottom:15px!important}.pc_pb20{padding-bottom:20px!important}.pc_pb25{padding-bottom:25px!important}.pc_pb30{padding-bottom:30px!important}.pc_pb35{padding-bottom:35px!important}.pc_pb40{padding-bottom:40px!important}.pc_pb45{padding-bottom:45px!important}.pc_pb50{padding-bottom:50px!important}.pc_pt00{padding-top:0!important}.pc_pt05{padding-top:5px!important}.pc_pt08{padding-top:8px!important}.pc_pt10{padding-top:10px!important}.pc_pt15{padding-top:15px!important}.pc_pt20{padding-top:20px!important}.pc_pt25{padding-top:25px!important}.pc_pt30{padding-top:30px!important}.pc_pt35{padding-top:35px!important}.pc_pt40{padding-top:40px!important}.pc_pt45{padding-top:45px!important}.pc_pt50{padding-top:50px!important}}@media screen and (max-width: 768px){.sp_p00{padding:0!important}.sp_pb00{padding-bottom:0!important}.sp_pb05{padding-bottom:5px!important}.sp_pb08{padding-bottom:8px!important}.sp_pb10{padding-bottom:10px!important}.sp_pb15{padding-bottom:15px!important}.sp_pb20{padding-bottom:20px!important}.sp_pb25{padding-bottom:25px!important}.sp_pb30{padding-bottom:30px!important}.sp_pb35{padding-bottom:35px!important}.sp_pb40{padding-bottom:40px!important}.sp_pb45{padding-bottom:45px!important}.sp_pb50{padding-bottom:50px!important}.sp_pt00{padding-top:0!important}.sp_pt05{padding-top:5px!important}.sp_pt08{padding-top:8px!important}.sp_pt10{padding-top:10px!important}.sp_pt15{padding-top:15px!important}.sp_pt20{padding-top:20px!important}.sp_pt25{padding-top:25px!important}.sp_pt30{padding-top:30px!important}.sp_pt35{padding-top:35px!important}.sp_pt40{padding-top:40px!important}.sp_pt45{padding-top:45px!important}.sp_pt50{padding-top:50px!important}}


/* ========================================================
	template.css => テンプレート用CSS
======================================================== */
html {
	font-size: 62.5%;
}
@media screen and (max-width: 768px) {
	html {
		font-size: 50%;
	}
}
body {
	background-color: #fff;
	font-size: 10px;
	font-size: 1rem;
	line-height: 1.8;
	color: #000000;
	word-wrap: break-word;
	overflow-wrap: break-word;

	font-family: "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", Verdana, Arial, Helvetica, sans-serif;
	font-weight: 400;
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
}
*,
*::before,
*::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	line-height: 1.8;
}
a[href] {
	color: #b0050e;
	text-decoration: underline;
	outline: none;
}
a[href]:hover {
	text-decoration: none;
}
a[href].a_reverse,
.a_reverse a[href] {
	text-decoration: none;
}
@media screen and (min-width: 769px) {
	a[href].a_reverse:hover,
	.a_reverse a[href]:hover {
		text-decoration: underline;
	}
}

a[href^="http"],
a[href^="mailto:"] {
	/*display: inline-block;*/
	word-break: break-all;
	word-wrap : break-word;
	overflow-wrap : break-word;
}

label {
	cursor: pointer;
}
input, select, textarea, button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	max-width: 100%;
	margin: 0;
	border-radius: 0;
	vertical-align: middle;
	font-family: inherit;
	outline: none;
	font-size: 100%;
}
::-webkit-input-placeholder {
	color: #ccc;
}
:-ms-input-placeholder {
	color: #ccc;
}
::-moz-placeholder {
	color: #ccc;
}
select::-ms-expand {
	display: none;
}

button {
	cursor: pointer;
}
iframe {
	max-width: 100%;
	vertical-align: middle;
}
img {
	max-width: 100%;
	height: auto;
}

.hidden {
	display: none;
}
.slick-slider * {
	outline: none;
}
@media screen and (min-width: 769px), print {
}
@media screen and (max-width: 768px) {
	body {
		font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", Verdana, Arial, Helvetica, sans-serif;
	}
}


/* pc / sp
============================================================================================================ */
.sp,
.sps {
	display: none !important;
}
@media screen and (min-width: 769px), print {
	.pc_break {
		position: relative;
		display: block;
		height: 0;
		overflow: hidden;
	}
	.pc_hidden {
		position: relative;
		overflow: hidden;
		display: block;
		height: 0;
	}
}
@media screen and (max-width: 768px) {
	.pc {
		display: none !important;
	}
	.sp {
		display: block !important;
	}
	img.sp, span.sp, br.sp, em.sp, strong.sp {
		display: inline !important;
	}
	td.sp, th.sp {
		display: table-cell !important;
	}
	.sp_break {
		position: relative;
		display: block;
		height: 0;
		overflow: hidden;
	}
}
@media screen and (max-width: 370px) {
	.sps {
		display: block !important;
	}
	img.sps, spsan.sps, br.sps, em.sps, strong.sps {
		display: inline !important;
	}
	.sps_non {
		display: none !important;
	}
}

/* transition
============================================================================================================ */
@media screen and (min-width: 769px) {
	body.init a[href],
	body.init a[href]::before,
	body.init a[href]::after,
	body.init button,
	body.init button::before,
	body.init button::after,
	body.init .basic_trs,
	body.init .basic_trs::before,
	body.init .basic_trs::after,
	body.init .basic_trs *,
	body.init .basic_trs *::before,
	body.init .basic_trs *::after {
		-webkit-transition: color 0.2s ease-in-out, background 0.2s ease-in-out, border 0.2s ease-in-out, opacity 0.2s ease-in-out;
		-o-transition: color 0.2s ease-in-out, background 0.2s ease-in-out, border 0.2s ease-in-out, opacity 0.2s ease-in-out;
		transition: color 0.2s ease-in-out, background 0.2s ease-in-out, border 0.2s ease-in-out, opacity 0.2s ease-in-out;
	}
	body.init a svg {
		-webkit-transition: fill 0.2s ease-in-out;
		-o-transition: fill 0.2s ease-in-out;
		transition: fill 0.2s ease-in-out;
	}
}


/* font family
============================================================================================================ */
.ff_en {
	font-family: 'Barlow', sans-serif;
}


/* color
============================================================================================================ */
.c_theme {
}
.caution {
	color: #b0050e !important;
}
.feature {
	color: #1cb8cb !important;
	font-weight: bold;
}

/* font
============================================================================================================ */
.fwb {
	font-weight: bold;
}
.fwn {
	font-weight: normal;
}


/* display
============================================================================================================ */
.db {
	display: block;
}
.dib {
	display: inline-block;
}

/* position
============================================================================================================ */
.pos-r {
	position: relative;
}

/* object-fit
============================================================================================================ */
img.of {
	object-fit: cover;
}

/* hover
============================================================================================================ */
@media screen and (min-width: 769px), print {
	a.hv_wh,
	button.hv_wh,
	a .hv_wh,
	.hv_wh a {
		position: relative;
		display: inline-block;
		vertical-align: middle;
		overflow: hidden;
	}
	a.hv_wh::after,
	button.hv_wh::after,
	a .hv_wh::after,
	.hv_wh a::after {
		content: "";
		position: absolute;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		background-color: rgba(255,255,255,0);
		z-index: 3;
	}
	body.init a.hv_wh::after,
	body.init button.hv_wh::after,
	body.init a .hv_wh::after,
	body.init .hv_wh a::after {
		-webkit-transition: background 0.2s;
		-o-transition: background 0.2s;
		transition: background 0.2s;
	}
	a[href].hv_wh:hover::after,
	button.hv_wh:hover::after,
	a[href]:hover .hv_wh::after,
	.hv_wh a[href]:hover::after {
		background-color: rgba(255,255,255,0.3);
	}
	a[href].hv_wh.a20:hover::after,
	button.hv_wh.a20:hover::after,
	a[href]:hover .hv_wh.a20::after,
	.hv_wh.a20 a[href]:hover::after {
		background-color: rgba(255,255,255,0.2);
	}
	a[href].hv_wh.a10:hover::after,
	button.hv_wh.a10:hover::after,
	a[href]:hover .hv_wh.a10::after,
	.hv_wh.a10 a[href]:hover::after {
		background-color: rgba(255,255,255,0.1);
	}

	body.init a[href] .hv_op {
		-webkit-transition: opacity 0.2s;
		-o-transition: opacity 0.2s;
		transition: opacity 0.2s;
	}
	a[href].hv_op:hover,
	a[href]:hover .hv_op,
	button.hv_op:hover,
	.hv_op a[href]:hover {
		opacity: 0.7;
	}
	a[href].hv_op.a20:hover,
	a[href]:hover .hv_op.a20,
	.hv_op.a20 a[href]:hover {
		opacity: 0.8;
	}
	a[href].hv_op.a10:hover,
	a[href]:hover .hv_op.a10,
	.hv_op.a10 a[href]:hover {
		opacity: 0.9;
	}
	a[href].hv_op.a50:hover,
	a[href]:hover .hv_op.a50,
	.hv_op.a50 a[href]:hover {
		opacity: 0.5;
	}
}

.hv_zoom {
	position: relative;
	display: block;
	overflow: hidden;
}
.hv_zoom > * {
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	background-repeat: no-repeat;
	background-position: 50%;
	-webkit-background-size: cover;
	background-size: cover;
}
@media screen and (min-width: 769px), print {
	body.init a[href].hv_zoom > *,
	body.init a[href] .hv_zoom > * {
		-webkit-transition: -webkit-transform 0.6s, opacity .3s;
		-o-transition: -o-transform 0.6s, opacity .3s;
		transition: transform 0.6s, opacity .3s;
	}
	a[href]:hover .hv_zoom.s > * {
		-webkit-transform: scale(1.03);
		-ms-transform: scale(1.03);
		-o-transform: scale(1.03);
		transform: scale(1.03);
	}
	a[href]:hover.hv_zoom > *,
	a[href]:hover .hv_zoom > * {
		-webkit-transform: scale(1.05);
		-ms-transform: scale(1.05);
		-o-transform: scale(1.05);
		transform: scale(1.05);
	}
}


/* target
============================================================================================================ */
.target {
	display: block;
	position: relative;
	width: 1px;
	top: -70px;
}
.target.pt {
	top: -100px;
}
@media screen and (max-width: 768px) {
	.target {
		top: -50px;
	}
	.target.pt {
		top: -70px;
	}
}



/* w
============================================================================================================ */
.w {
	position: relative;
}
@media screen and (min-width: 769px), print {
	.w {
		max-width: 1260px;
		margin: 0 auto;
		padding: 0 30px;
	}
	.mw {
		min-width: 1160px;
	}
	.xw {
		max-width: 1430px;
		margin: 0 auto;
		padding: 0 30px;
	}
}
@media screen and (max-width: 768px) {
}


/* spパディング
============================================================================================================ */
@media screen and (max-width: 768px) {
	.sp_pd {
		padding-left: 5vw !important;
		padding-right: 5vw !important;
	}
	.sp_full {
		margin-left: -5vw !important;
		margin-right: -5vw !important;
	}
	.sp_full_l {
		margin-left: -5vw !important;
	}
	.sp_full_r {
		margin-right: -5vw !important;
	}
}


/* header
============================================================================================================ */
#header {
}
@media screen and (min-width: 769px), print {
	#header {
		position: absolute;
		top: 0;
		right: 0;
		left: 0;
		height: 170px;
		background-color: #b0050e;
	}
	#header .w {
		max-width: 1220px;
		padding: 0 10px;
		z-index: 3;
	}
	#header .img {
		overflow: hidden;
		position: absolute;
		top: 0;
		right: 0;
		height: 100px;
		background: url(../images/common/head_img.jpg) 10% no-repeat;
		max-width: 550px;
		min-width: 250px;
		width: calc((100vw - 1200px) / 2 + 280px);
	}
	#header .img::before {
		content: "";
		position: absolute;
		right: 100%;
		top: 0;
		bottom: 0;
		width: 550px;
		background-color: #b0050e;
		-webkit-transform-origin: 100% 100%;
		-moz-transform-origin: 100% 100%;
		-ms-transform-origin: 100% 100%;
		-o-transform-origin: 100% 100%;
		transform-origin: 100% 100%;
		-webkit-transform: skewX(-20deg);
		-ms-transform: skewX(-20deg);
		-o-transform: skewX(-20deg);
		transform: skewX(-20deg);
	}
	#header .head {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		height: 100px;
		-ms-align-items: center;
		align-items: center;
	}
	#header .logo {
		margin-right: 40px;
		margin-right: 20px;
	}
	#header .social {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		-webkit-flex-wrap: wrap;
		-moz-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		-o-flex-wrap: wrap;
		flex-wrap: wrap;
		width: 60px;
		margin-left: 20px;
		padding-top: 5px;
	}
	#header .social li {
		width: 50%;
	}
	#header .social li a {
		display: block;
		text-align: center;
		text-decoration: none;
		color: #fff;
		font-size: 1.8rem;
		line-height: 1.4;
	}

	#header nav {
		position: absolute;
		top: 100px;
		left: 0;
		right: 0;
		background-color: #1a1a1a;
		-webkit-transform: translate3d(0, 0, 0);
		-ms-transform: translate3d(0, 0, 0);
		-o-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		z-index: 1000;
	}
	.head-fix #header nav {
		position: fixed;
		top: 0;
	}
	#header nav .gnav {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		justify-content: center;
	}
	#header nav .gnav > li > a {
		position: relative;
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		height: 70px;
		justify-content: center;
		-ms-align-items: center;
		align-items: center;
		padding: 0 20px;
		color: #fff;
		font-size: 1.6rem;
		font-weight: bold;
		line-height: 1.5;
		text-decoration: none;
	}
	#header nav .gnav > li > a::after {
		content: "";
		position: absolute;
		right: 1px;
		left: 1px;
		top: 50%;
		margin-top: 20px;
		border-top: 3px solid #b0050e;
		-webkit-transform: translateY(3px);
		-ms-transform: translateY(3px);
		-o-transform: translateY(3px);
		transform: translateY(3px);
		opacity: 0;
	}
	body.init #header nav .gnav > li > a::after {
		-webkit-transition: -webkit-transform .2s ease-in-out, opacity .2s ease-in-out;
		-o-transition: -o-transform .2s ease-in-out, opacity .2s ease-in-out;
		transition: transform .2s ease-in-out, opacity .2s ease-in-out;
	}
	#header nav .gnav > li:hover > a::after,
	#header nav .gnav > li > a.current::after {
		-webkit-transform: translateY(0);
		-ms-transform: translateY(0);
		-o-transform: translateY(0);
		transform: translateY(0);
		opacity: 1;
	}
	#header nav .home {
		width: 60px;
		background: url(../images/common/head_ico_home.png) 50% no-repeat;
		-webkit-background-size: 20px;
		background-size: 20px;
	}
	#header nav .home > span {
		display: none;
	}
	#header nav .has_dd > a::before {
		content: "";
		position: absolute;
		bottom: -10px;
		left: 50%;
		width: 20px;
		height: 20px;
		background-color: #1a1a1a;
		-webkit-transform-origin: 0 100%;
		-moz-transform-origin: 0 100%;
		-ms-transform-origin: 0 100%;
		-o-transform-origin: 0 100%;
		transform-origin: 0 100%;
		-webkit-transform: translateY(-10px) rotate(-45deg);
		-ms-transform: translateY(-10px) rotate(-45deg);
		-o-transform: translateY(-10px) rotate(-45deg);
		transform: translateY(-10px) rotate(-45deg);
		opacity: 0;
		pointer-events: none;
		-webkit-transition: -webkit-transform .2s ease-in-out, opacity .2s ease-in-out;
		-o-transition: -o-transform .2s ease-in-out, opacity .2s ease-in-out;
		transition: transform .2s ease-in-out, opacity .2s ease-in-out;
	}
	#header nav .has_dd:hover > a::before {
		opacity: 1;
		-webkit-transform: translateY(0) rotate(-45deg);
		-ms-transform: translateY(0) rotate(-45deg);
		-o-transform: translateY(0) rotate(-45deg);
		transform: translateY(0) rotate(-45deg);
	}
	#header nav .dd {
		position: absolute;
		top: 70px;
		right: 0;
		left: 0;
		background-color: #000000;
		color: #fff;
		height: 0;
		overflow: hidden;
		-webkit-transition: height .3s, opacity .3s;
		-o-transition: height .3s, opacity .3s;
		transition: height .3s, opacity .3s;
		opacity: 0;
		z-index: -1;
	}
	#header nav li:hover .dd {
		opacity: 1;
	}
	#header nav .dd dl {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		font-weight: bold;
		max-width: 950px;
		margin: auto;
		padding: 20px 0;
		font-size: 2rem;
		-webkit-transform: translateY(-10px);
		-ms-transform: translateY(-10px);
		-o-transform: translateY(-10px);
		transform: translateY(-10px);
		-webkit-transition: -webkit-transform .3s;
		-o-transition: -o-transform .3s;
		transition: transform .3s;
	}
	#header nav li:hover .dd dl {
		-webkit-transform: translateY(0);
		-ms-transform: translateY(0);
		-o-transform: translateY(0);
		transform: translateY(0);
	}
	#header nav .dd dt {
		width: 140px;
		padding-top: 5px;
		line-height: 1.5;
	}
	#header nav .dd dd {
		width: calc(100% - 140px);
	}
	#header nav .dd ul {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		-webkit-flex-wrap: wrap;
		-moz-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		-o-flex-wrap: wrap;
		flex-wrap: wrap;
		padding: 3px 0;
	}
	#header nav .dd ul li {
		padding-right: 10px;
	}
	#header nav .dd dd.table {
		display: table;
		width: auto;
	}
	#header nav .dd dd.table > * {
		display: table-row;
	}
	#header nav .dd dd.table > * > * {
		display: table-cell;
	}
	#header nav .dd ul a {
		position: relative;
		display: block;
		padding: 5px 16px;
		color: #999999;
		font-size: 1.6rem;
		font-weight: bold;
		line-height: 1.5;
		text-decoration: none;
	}
	#header nav .dd ul a::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		width: 5px;
		height: 5px;
		margin-top: -3px;
		background-color: #bc111a;
		border-radius: 100%;
	}
	#header nav .dd ul a:hover {
		color: #fff;
	}
	#header nav .social {
		display: none;
	}
}
@media screen and (max-width: 1180px) {
	#header .img {
		width: calc((100vw - 1200px) / 2 + 200px);
	}
}
@media screen and (max-width: 768px) {
	#header {
	}
	#header .logo {
		position: fixed;
		top: 0;
		right: 0;
		left: 0;
		height: 50px;
		background-color: #fff;
		-webkit-box-shadow: 0 0 5px rgba(0,0,0,.2);
		box-shadow: 0 0 5px rgba(0,0,0,.2);
		z-index: 1000;
	}
	#header .logo a {
		display: block;
		width: 260px;
		height: 50px;
		padding: 0 15px;
		background: url(../images/common/logo_sp.png) no-repeat 50%;
		-webkit-background-size: 235px;
		background-size: 235px;
	}
	#header .logo a img {
		display: none;
	}
	#header .date {
		position: absolute;
		top: 50px;
		right: 0;
		left: 0;
		height: 45px;
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		justify-content: center;
		-ms-align-items: center;
		align-items: center;
		background-color: #b0050e;
	}
	#header .date img {
		width: 160px;
	}

	/* nav_btn */
	#header .nav_btn {
		position: fixed;
		right: 0;
		top: 0;
		width: 50px;
		height: 50px;
		background-color: #b0050e;
		z-index: 1001;
	}
	#header .nav_btn a {
		position: relative;
		display: block;
		height: 50px;
	}
	#header .nav_btn:before,
	#header .nav_btn a::before,
	#header .nav_btn a::after {
		content: "";
		position: absolute;
		left: 50%;
		top: 50%;
		width: 24px;
		margin-top: -1px;
		margin-left: -12px;
		border-top: 2px solid #fff;
	}
	body.init #header .nav_btn {
		-webkit-transition: background 0.3s ease-in-out;
		-o-transition: background 0.3s ease-in-out;
		transition: background 0.3s ease-in-out;
	}
	body.init #header .nav_btn:before,
	body.init #header .nav_btn a::before,
	body.init #header .nav_btn a::after {
		-webkit-transition: all 0.3s ease-in-out;
		-o-transition: all 0.3s ease-in-out;
		transition: all 0.3s ease-in-out;
	}
	#header .nav_btn a::before {
		-webkit-transform: translateY(-7px);
		-ms-transform: translateY(-7px);
		-o-transform: translateY(-7px);
		transform: translateY(-7px);
	}
	#header .nav_btn a::after {
		-webkit-transform: translateY(7px);
		-ms-transform: translateY(7px);
		-o-transform: translateY(7px);
		transform: translateY(7px);
	}

	/* nav_btn open */
	#header.open .nav_btn {
		background-color: #1a1a1a;
	}
	#header.open .nav_btn::before {
		opacity: 0;
	}
	#header.open .nav_btn a::before {
		-webkit-transform: translateY(0) rotate(45deg);
		-ms-transform: translateY(0) rotate(45deg);
		transform: translateY(0) rotate(45deg);
	}
	#header.open .nav_btn a::after {
		-webkit-transform: translateY(0) rotate(-45deg);
		-ms-transform: translateY(0) rotate(-45deg);
		transform: translateY(0) rotate(-45deg);
	}

	/* nav */
	#header nav {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		max-height: 100vh;
		background-color: #1a1a1a;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		-webkit-transform: translateY(-110%);
		-ms-transform: translateY(-110%);
		-o-transform: translateY(-110%);
		transform: translateY(-110%);
		-webkit-box-shadow: 0 0 8px rgba(0,0,0,.2);
		box-shadow: 0 0 8px rgba(0,0,0,.2);
		z-index: 900;
	}
	body.init #header nav {
		-webkit-transition: -webkit-transform 0.3s ease-in-out;
		-o-transition: -o-transform 0.3s ease-in-out;
		transition: transform 0.3s ease-in-out;
	}
	/* open */
	#header.open nav {
		-webkit-transform: translateY(0%);
		-ms-transform: translateY(0%);
		-o-transform: translateY(0%);
		transform: translateY(0%);
	}
	nav .gnav {
		padding: 60px 30px 30px;
	}
	nav .gnav li + li {
		border-top: 1px solid #484848;
	}
	nav .gnav a {
		position: relative;
		display: block;
		padding: 14px;
		text-align: center;
		text-decoration: none;
		font-size: 1.5rem;
		line-height: 1.5;
		color: #fff;
		font-weight: bold;
	}
	nav ul .dd {
		overflow: hidden;
		height: 0;
		-webkit-transition: height .3s;
		-o-transition: height .3s;
		transition: height .3s;
	}
	nav ul .dd dt {
		display: none;
	}
	nav ul .dd ul {
		border-top: 1px solid #484848;
		background-color: #0e0e0e;
	}
	nav ul .dd ul a {
		padding: 10px;
		color: #808080;
	}
	nav ul .has_dd > a::before,
	nav ul .has_dd > a::after {
		content: "";
		position: absolute;
		top: 50%;
		right: 10px;
		margin-top: -1px;
		border-top: 2px solid #fff;
		width: 14px;
		-webkit-transition: all .3s;
		-o-transition: all .3s;
		transition: all .3s;
	}
	nav ul .has_dd > a::after {
		-webkit-transform: rotate(90deg);
		-ms-transform: rotate(90deg);
		-o-transform: rotate(90deg);
		transform: rotate(90deg);
	}
	nav ul .has_dd > a.open::before,
	nav ul .has_dd > a.open::after {
		border-color: #b0050e;
	}
	nav ul .has_dd > a.open::after {
		-webkit-transform: rotate(0);
		-ms-transform: rotate(0);
		-o-transform: rotate(0);
		transform: rotate(0);
		opacity: 0;
	}
	nav .social {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		padding: 10px 0;
		justify-content: center;
		background-color: #0d0d0d;
	}
	nav .social a {
		display: block;
		padding: 5px 10px;
		text-decoration: none;
		color: #fff;
		font-size: 20px;
	}
}


/* footer
============================================================================================================ */
#footer {
	position: relative;
	padding: 50px 0;
	background-color: #b0050e;
	text-align: center;
	color: #fff;
	line-height: 1.8;
}
@media screen and (min-width: 769px), print {
}
@media screen and (max-width: 768px) {
	#footer {
		padding: 30px 0 20px;
	}
}


/* contact
------------------------------------------------------------- */
#footer .contact header {
	margin-bottom: 30px;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.5;
}
#footer .contact header .ff_en {
	font-size: 3rem;
	letter-spacing: 0.05em;
}
#footer .contact .pff a {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content: center;
	-ms-align-items: center;
	align-items: center;
	width: 510px;
	height: 130px;
	margin: auto;
	border-radius: 15px;
	background-color: #fff;
	-webkit-box-shadow: 0 0 10px rgba(0,0,0,.1);
	box-shadow: 0 0 10px rgba(0,0,0,.1);
	text-decoration: none;
	color: #00a0e9;
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.5;
}
#footer .contact .pff a .logo {
	margin-right: 40px;
}
#footer .contact .tel {
	margin-top: 20px;
	font-size: 1.6rem;
	font-weight: bold;
}
#footer .contact .tel span {
	font-size: 2rem;
}
@media screen and (max-width: 768px) {
	#footer .contact header {
		margin-bottom: 20px;
		font-size: 1.6rem;
	}
	#footer .contact header .ff_en {
		font-size: 2.6rem;
	}
	#footer .contact .pff a {
		width: 255px;
		height: 65px;
		border-radius: 10x;
		font-size: 1.8rem;
	}
	#footer .contact .pff a .logo {
		margin-right: 20px;
	}
	#footer .contact .pff a .logo img {
		width: 60px;
	}
	#footer .contact .tel {
		margin-top: 20px;
		font-size: 1.5rem;
		font-weight: bold;
	}
	#footer .contact .tel a {
		color: #61ceff;
	}
	#footer .contact .tel span {
		display: block;
		font-size: 1.8rem;
	}
}


/* ページトップ
------------------------------------------------------------- */
#pagetop {
	z-index: 1000;
	font-size: 1.3rem;
	line-height: 1.2;
}
#pagetop a {
	display: block;
	width: 60px;
	height: 65px;
	padding-top: 20px;
	background-color: #1a1a1a;
	border-bottom: 5px solid #0d0d0d;
	border-radius: 10px;
	color: #fff;
	text-decoration: none;
}
#pagetop a::before {
	content: "";
	position: absolute;
	top: 10px;
	left: 50%;
	margin-left: -6px;
	border-style: solid;
	border-width: 0 6px 6px 6px;
	border-color: transparent transparent #8d8d8d transparent;
}
@media print {
	#pagetop {
		display: none;
	}
}
@media screen and (min-width: 769px) {
	#pagetop {
		position: fixed;
		right: 20px;
		bottom: 20px;
		opacity: 0;
		pointer-events: none;
		-webkit-transition: opacity .3s;
		-o-transition: opacity .3s;
		transition: opacity .3s;
	}
	#pagetop a:hover {
		background-color: #444;
	}
	#pagetop.show {
		opacity: 1;
		pointer-events: auto;
	}
	#pagetop.abs {
		position: absolute;
		top: 50px;
		bottom: auto;
	}
}
@media screen and (max-width: 768px) {
	#pagetop {
		position: absolute;
		right: 10px;
		top: 30px;
		-webkit-transform-origin: 100% 0;
		-moz-transform-origin: 100% 0;
		-ms-transform-origin: 100% 0;
		-o-transform-origin: 100% 0;
		transform-origin: 100% 0;
		-webkit-transform: scale(.8);
		-ms-transform: scale(.8);
		-o-transform: scale(.8);
		transform: scale(.8);
		font-size: 13px;
	}
}




/* small
------------------------------------------------------------- */
#footer small {
	display: block;
	margin-top: 50px;
	font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
	#footer small {
		margin-top: 30px;
		font-size: 1.3rem;
	}
}


/* container
============================================================================================================ */
#container {
	position: relative;
	padding-top: 170px;
	font-size: 1.6rem;
}
#container::before,
#container::after {
	content: "";
	display: table;
	clear: both;
}
@media screen and (max-width: 768px) {
	#container {
		padding-top: 95px;
	}
}


/* ===================================================================================================================

	パーツ

=================================================================================================================== */

/* pd_block
============================================================================================================ */
.pd_block {
	padding: 100px 0;
}
@media screen and (max-width: 768px) {
	.pd_block {
		padding: 40px 0;
	}
}

/* bg_gray
============================================================================================================ */
.bg_gray {
	background-color: #eeeeee;
}

/* breadcrumbs
============================================================================================================ */
.breadcrumbs {
	padding: 8px 25px;
	font-size: 1.2rem;
	line-height: 1.4;
}
.breadcrumbs li {
	position: relative;
	padding-right: 30px;
}
.breadcrumbs ol li::after {
	content: "";
	position: absolute;
	right: 15px;
	top: 50%;
	width: 6px;
	height: 6px;
	margin-top: -3px;
	border-top: 1px solid #be1678;
	border-right: 1px solid #be1678;
	-webkit-transform: scaleX(.8) rotate(45deg);
	-ms-transform: scaleX(.8) rotate(45deg);
	-o-transform: scaleX(.8) rotate(45deg);
	transform: scaleX(.8) rotate(45deg);
}
.breadcrumbs ol li a {
	color: #000;
	text-decoration: none;
}
.breadcrumbs ol li:last-child {
	padding-right: 0;
}
.breadcrumbs ol li:last-child::after {
	content: none;
}
@media screen and (min-width: 769px), print {
	.breadcrumbs ol {
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}
	.breadcrumbs li {
		display: inline;
	}
	.breadcrumbs ol li a[href]:hover {
		color: #be1678;
	}
}
@media screen and (max-width: 768px) {
	.breadcrumbs {
		padding: 6px 0;
		font-size: 1.1rem;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
	.breadcrumbs ol {
		display: table;
		white-space: nowrap;
	}
	.breadcrumbs ol li {
		display: table-cell;
		white-space: nowrap;
	}
	.breadcrumbs li {
		padding-right: 20px;
	}
	.breadcrumbs ol li::after {
		right: 7px;
		margin-top: -4px;
	}
}


/* page_title
============================================================================================================ */
.page_title {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content: center;
	-ms-align-items: center;
	align-items: center;
	height: 170px;
	background: #DCC5E6 url(../images/parts/title_bg.png) no-repeat 50%;
	text-align: center;
	line-height: 1.3;
	font-size: 3.2rem;
	padding-left: .4em;
	letter-spacing: 0.4em;
}
@media screen and (min-width: 769px), print {
}
@media screen and (max-width: 768px) {
	.page_title {
		height: 110px;
		padding-top: 30px;
		background-position: 50% -25px;
		-webkit-background-size: 260px;
		background-size: 260px;
		font-size: 1rem;
	}
	.page_title .ff_min {
		font-size: 2.4rem;
	}
}

/* title
============================================================================================================ */
/* en_title */
.en_title {
	margin-bottom: 30px;
	text-align: center;
	line-height: 1.3;
	font-size: 1.2rem;
	letter-spacing: 0.1em;
	color: #A9A9A9;
}
.en_title .ff_min {
	margin-bottom: 15px;
	font-size: 2.6rem;
	color: #000;
}
@media screen and (min-width: 769px), print {
}
@media screen and (max-width: 768px) {
	.en_title {
	}
}

/* lead_text */
.lead_text {
	margin-bottom: 50px;
	font-size: 2.4rem;
	line-height: 1.7;
	text-align: center;
	font-weight: normal;
}
.lead_text.tal {
	margin-bottom: 30px;
	text-align: left;
}
@media screen and (max-width: 768px) {
	.lead_text {
		margin-bottom: 40px;
		text-align: left;
		font-size: 2.2rem;
	}
}


/* para_section (paragraph section)
============================================================================================================ */
.para_section > * + * {
	margin-top: 1.2em;
}


/* table
============================================================================================================ */
.basic_table {
	width: 100%;
	table-layout: fixed;
}
.basic_table tr:nth-child(odd) {
	background-color: #f0f4f7;
}
.basic_table th,
.basic_table td {
	padding: 8px 30px;
	vertical-align: top;
}
.basic_table th {
	padding-right: 0;
}
.basic_table.th15 th {
	width: 15%;
}
.basic_table.th20 th {
	width: 20%;
}
.basic_table.th25 th {
	width: 25%;
}
.basic_table.th30 th {
	width: 30%;
}
@media screen and (max-width: 768px) {
	.basic_table th,
	.basic_table td {
		padding: 8px 20px;
	}
	.basic_table th {
		padding-right: 0;
	}
	.basic_table.sp_th15 th {
		width: 15%;
	}
	.basic_table.sp_th20 th {
		width: 20%;
	}
	.basic_table.sp_th25 th {
		width: 25%;
	}
	.basic_table.sp_th30 th {
		width: 30%;
	}
}


/* box_btn
============================================================================================================ */
button.box_btn,
a.box_btn,
a .box_btn {
	position: relative;
	display: block;
	max-width: 100%;
	width: 290px;
	padding: 15px;
	margin: auto;
	background-color: #fff;
	border: 1px solid #000;
	text-decoration: none;
	text-align: center;
	color: #000;
	font-size: 1.3rem;
	line-height: 1.5;
}
button.box_btn {
	display: inline-block;
}
.box_btn::after {
	content: "";
	position: absolute;
	right: 20px;
	top: 50%;
	margin-top: -4px;
	border-style: solid;
	border-width: 4px 0 4px 12px;
	border-color: transparent transparent transparent #000;
}
.box_btn.back::after {
	left: 20px;
	right: auto;
	-webkit-transform: rotate(180deg);
	-ms-transform: rotate(180deg);
	-o-transform: rotate(180deg);
	transform: rotate(180deg);
}
.box_btn.gray {
	background-color: #dcdcdc;
	border-color: #dcdcdc;
}
@media screen and (min-width: 769px), print {
	button.box_btn:hover,
	a[href].box_btn:hover,
	a[href]:hover .box_btn {
		background-color: #000;
		color: #fff;
	}
	button.box_btn:hover::after,
	a[href].box_btn:hover::after,
	a[href]:hover .box_btn::after {
		border-color: transparent transparent transparent #fff;
	}
}
@media screen and (max-width: 768px) {
	button.box_btn,
	a.box_btn,
	a .box_btn {
	}
}

.btn_group {
	margin-top: 80px;
}
.btn_group.mts {
	margin-top: 30px;
}
@media screen and (min-width: 769px), print {
	.btn_group {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		justify-content: center;
	}
	.btn_group li {
		padding: 0 10px;
	}
}
@media screen and (max-width: 768px) {
	.btn_group {
		margin-top: 60px;
	}
	.btn_group li + li {
		margin-top: 15px;
	}
}

/* ul / ol
============================================================================================================ */
.dot_li > li {
	position: relative;
	padding-left: 1em;.
}
.dot_li > li::before {
	content: "・";
	position: absolute;
	top: 0;
	left: 0;
}

.circle_li > li {
	position: relative;
	padding-left: 1.1em;.
}
.circle_li > li::before {
	content: "●";
	position: absolute;
	top: 0;
	left: 0;
	color: #005f8b;
	-webkit-transform-origin: 0;
	-moz-transform-origin: 0;
	-ms-transform-origin: 0;
	-o-transform-origin: 0;
	transform-origin: 0;
	-webkit-transform: scale(0.8);
	-ms-transform: scale(0.8);
	-o-transform: scale(0.8);
	transform: scale(0.8);
}

.parentheses_li > li {
	position: relative;
	padding-left: 2.8em;
}
.parentheses_li > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}

.parentheses_li_h > li {
	position: relative;
	padding-left: 1.6em;
}
.parentheses_li_h > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}
.parentheses_li_hh > li {
	position: relative;
	padding-left: 2.2em;
}
.parentheses_li_hh > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}

.point_li > li {
	position: relative;
	padding-left: 1.2em;
}
.point_li > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}

.square_li > li {
	position: relative;
	padding-left: 0.8em;
}
.square_li > li::before {
	content: "";
	position: absolute;
	left: 0;
	top: .8em;
	width: 5px;
	height: 5px;
	background-color: #14143c;
}
@media screen and (max-width: 768px) {
	.square_li > li::before {
		top: 0.6em;
	}
}

.num_li {
	margin-left: 1.8em;
	list-style: decimal;
}
.alphabet_li {
	margin-left: 1.8em;
	list-style: lower-latin;
}

.mt_li > li + li {
	margin-top: 0.8em;
}
@media screen and (max-width: 768px) {
	.sp_mt_li > li + li {
		margin-top: 0.8em;
	}
}

.inline_li > li {
	display: inline-block;
	margin-right: 0.3em;
}



/* .wp-pagenavi
============================================================================================================ */
.is-hidden {
	display: none;
}
.pc-hidden {
	display: none;
}
@media only screen and (max-width: 768px) {
	.sp-hidden {
		display: none;
	}
	.pc-hidden {
		display: block;
	}
	.sp-scroll {
		width: 100%;
		overflow-x: auto;
	}
}

@media screen and (min-width: 769px), print {
	.wrapper {
		max-width: 1260px;
		margin: 0 auto;
		padding: 0 30px;
	}
	.mw {
		min-width: 1160px;
	}
}
@media only screen and (max-width: 768px) {
}

.fade-mv {
	opacity: 0;
	transform: translateY(60px);
	transition: opacity 1s ease, transform 1s ease;
}

.mv {
	opacity: 1;
	transform: translateY(0px);
}

.creditArea {
	padding: 60px 30px;
	background: #bc111a;
}

@media only screen and (max-width: 768px) {
	.creditArea {
		padding: 30px 5vw;
	}
}

.creditArea .wrapper {
	max-width: 1200px;
	background: #fff;
	padding: 60px;
}
@media only screen and (max-width: 768px) {
	.creditArea .wrapper {
		padding: 10px 20px;
	}
}

.credit {
	width: calc( 1200px - 100px);
	margin: 0 auto;
	text-align: center;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: stretch;
}

@media only screen and (max-width: 768px) {
	.credit {
		text-align: center;
		display: block;
		width: 100%;
		margin: 0 auto;
		padding: 20px 0;
	}
}

.credit__title {
	width: 180px;
	font-size: 1.4rem;
	font-weight: bold;
	border-right: #ccc 1px solid;
	text-align: left;
	padding: 7px 20px 10px 20px;
	margin-bottom: 20px;
}

@media only screen and (max-width: 768px) {
	.credit__title {
		font-weight: bold;
		text-align: center;
		margin: 0 0 10px;
		padding: 2px 5px;
		display: inline-block;
		border-right: none;
		width: auto;
		margin-bottom: 20px;
		font-size: 1.6rem;
	}
	.credit__title::after {
		content: "";
		display: block;
		width: 20px;
		margin: 10px auto 0;
		border-top: #bc111a 1px solid;
	}
}

@media only screen and (max-width: 768px) {
	.credit__title br {
		display: none;
	}
}

.credit__item {
	width: 900px;
	padding-left: 40px;
	padding-right: 13px;
	margin-bottom: 20px;
}

@media only screen and (max-width: 768px) {
	.credit__item {
		width: 100%;
		padding-left: 0;
		padding-right: 0;
	}
}

.credit__item.shusai .credit__list__item div {
	font-size: 1.3rem;
}

@media only screen and (max-width: 768px) {
	.credit__item.shusai .credit__list__item.kawakita {
		width: 100%;
		display: flex;
		flex-wrap: nowrap;
	}
}

@media only screen and (max-width: 768px) {
	.credit__item.shusai .credit__list__item.kawakita .imgArea {
		width: auto;
	}
}

.credit__item.shusai .credit__list__item.kawakita .textArea {
	text-align: left;
	line-height: 1.25;
}

@media only screen and (max-width: 768px) {
	.credit__item.shusai .credit__list__item.kawakita .textArea {
		width: auto;
		text-align: left;
		padding-left: 1em;
	}
}

.credit__item.shusai .credit__list__item.unijapan {
	display: block;
}

.credit__item.shusai .credit__list__item.unijapan .textArea {
	padding-top: 4px;
}

@media only screen and (max-width: 768px) {
	.credit__item.sp-shien .credit__list__item {
		width: 100%;
		display: flex;
		flex-wrap: nowrap;
	}
}

@media only screen and (max-width: 768px) {
	.credit__item.sp-shien .credit__list__item .imgArea {
		width: auto;
	}
}

.credit__item.sp-shien .credit__list__item .textArea {
	font-size: 1.3rem;
	text-align: left;
	line-height: 1.25;
}

@media only screen and (max-width: 768px) {
	.credit__item.sp-shien .credit__list__item .textArea {
		width: auto;
		text-align: left;
		padding-left: 1em;
	}
}

.credit__item.kyousan .credit__list__item {
	padding: 5px 7px;
}

@media only screen and (max-width: 768px) {
	.credit__item.kyousan .credit__list__item {
		padding: 10px 10px;
	}
}

.credit__item.sanjo .credit__list__item,
.credit__item.kouen .credit__list__item {
	padding: 3px 0;
}

@media only screen and (max-width: 768px) {
	.credit__item.sanjo .credit__list__item,
	.credit__item.kouen .credit__list__item {
		padding: 5px 0;
	}
}

.credit__item.sanjo .credit__list__item div,
.credit__item.kouen .credit__list__item div {
	font-size: 1rem;
	font-weight: normal;
	line-height: 1.25;
}

.credit__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: stretch;
}

@media only screen and (max-width: 768px) {
	.credit__list {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		align-items: center;
	}
}

.credit__list__item {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	padding: 7px 10px;
}

@media only screen and (max-width: 768px) {
	.credit__list__item {
		/* display: block; */
		width: auto !important;
		padding: 10px 10px;
		white-space: nowrap;
	}
}

.credit__list__item div {
	font-size: 1.8rem;
	padding: 0 7px;
}

@media only screen and (max-width: 768px) {
	.credit__list__item div {
		font-size: 1.125rem;
		font-weight: bold;
		width: 100%;
		/* padding: 5px 0; */
		text-align: center;
	}
}

.credit__list__item div img {
	vertical-align: middle;
}

.credit__list__item div a {
	text-decoration: none;
	color: #000;
}

.credit__list__item div a:hover {
	opacity: 0.7;
}

.credit2 {
	border-top: #ccc 1px solid;
	margin-top: 30px;
	padding-top: 30px;
}

.newslist {
	max-width: 980px;
	margin: 0 auto;
	position: relative;
}

@media only screen and (max-width: 768px) {
	.newslist {
		padding: 0 5vw;
	}
}

@media only screen and (max-width: 768px) {
	.newslist__item {
		width: 100%;
	}
}

.newslist__item a {
	zoom: 1;
	width: 100%;
	display: block;
	padding: 20px 25px;
	margin-bottom: 30px;
	text-decoration: none;
	height: 100%;
	/* box-shadow */
	box-shadow: 10px 10px 0px 3px #bc111a;
	/* border */
	border: 1px solid #000000;
	background: #fff;
}
@media only screen and (max-width: 768px) {
	.newslist__item a {
		box-shadow: 5px 5px 0px 3px #bc111a;
	}
}

.newslist__item a:after {
	content: "";
	display: block;
	clear: both;
}

.newslist__item a img {
	transition: all 0.2s linear;
}

.newslist__item a:hover {
	background: #f7f6ef;
	box-shadow: 10px 10px 0px 3px #000;
}

.newslist__item a:hover img {
	transform-origin: center center;
	transform: translate(-50%, -50%) scale(1.05);
}

.newslist__img {
	background: #f7f6ef;
	width: 30%;
	height: 200px;
	overflow: hidden;
	text-align: center;
	position: relative;
	float: left;
}

@media only screen and (max-width: 768px) {
	.newslist__img {
		width: 100%;
		height: 38.5vw;
	}
}

.newslist__img img {
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.newslist__text {
	padding: 10px 0;
	float: right;
	width: 65%;
}

@media only screen and (max-width: 768px) {
	.newslist__text {
		width: 100%;
		float: none;
	}
}

.newslist__text .newIcon {
	background: #cc0000;
	color: #fff;
	font-family: "Roboto", sans-serif;
	font-size: 1.2rem;
	font-style: italic;
	font-weight: 700;
	display: inline-block;
	line-height: 1;
	padding: 3px 6px 3px 4px;
	border-radius: 3px;
}

.newslist__title {
	font-size: 2.0rem;
	font-weight: 700;
}

.newslist__date {
	color: #333;
	font-family: "Roboto", sans-serif;
	font-size: 1.8rem;
	margin-top: 0.5em;
}

#news .newslist {
	display: block;
}

@media only screen and (max-width: 768px) {
	#news .newslist {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		align-items: stretch;
	}
}

#news .newslist__item {
	width: 100%;
	margin-bottom: 20px;
}

@media only screen and (max-width: 768px) {
	#news .newslist__item {
		width: 100%;
		margin-bottom: 0;
	}
}

#news .newslist__item a {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: stretch;
}

@media only screen and (max-width: 768px) {
	#news .newslist__item a {
		display: block;
	}
}

#news .newslist__img {
	width: 180px;
	height: 140px;
}

@media only screen and (max-width: 768px) {
	#news .newslist__img {
		width: 100%;
		height: 38.5vw;
	}
}

#news .newslist__text {
	width: 980px;
}

@media only screen and (max-width: 768px) {
	#news .newslist__text {
		width: auto;
	}
}

#news .newslist__title {
	font-size: 2.4rem;
}

@media only screen and (max-width: 768px) {
	#news .newslist__title {
		font-size: 1.6rem;
	}
}

.newsDetail .wrapper {
	width: 860px;
}

@media only screen and (max-width: 768px) {
	.newsDetail .wrapper {
		width: 100%;
	}
}

@media only screen and (max-width: 768px) {
	.newsDetail {
		padding: 0 5vw;
	}
}

.newsDetail__date {
	font-size: 1.8rem;
	color: #999;
}

@media only screen and (max-width: 768px) {
	.newsDetail__date {
		font-size: 1.2rem;
	}
}

.newsDetail__title {
	font-size: 3rem;
	font-weight: bolder;
	margin-bottom: 60px;
	padding-bottom: 15px;
	border-bottom: #ccc 1px solid;
}

@media only screen and (max-width: 768px) {
	.newsDetail__title {
		font-size: 2.5rem;
		margin-bottom: 30px;
		padding-bottom: 7.5px;
	}
}

.newsDetail__contents {
	width: 100%;
	overflow: hidden;
	font-size: 1.8rem;
	line-height: 1.75;
}

@media only screen and (max-width: 768px) {
	.newsDetail__contents {
		font-size: 1.6rem;
	}
}

.newsDetail__contents img {
	max-width: 100%;
	height: auto;
}

.newsDetail__contents p {
	margin-top: 1em;
	font-size: 1.5rem;
}

@media only screen and (max-width: 768px) {
	.newsDetail__contents p {
		font-size: 2rem;
	}
}

.bottom-link {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
	margin-top: 60px;
	background: #f7f6ef;
	padding: 10px;
	border-bottom: #bc111a 2px solid;
	line-height: 1.4;
}

.prev-btn,
.next-btn {
	position: relative;
	width: 49%;
}
.prev-btn {
	padding-left: 30px;
}
.next-btn {
	padding-right: 30px;
	margin-left: auto;
}

.prev-btn a,
.next-btn a {
	display: inline-block;
	color: #333;
	font-size: 1.4rem;
}

@media only screen and (max-width: 768px) {
	.prev-btn a,
	.next-btn a {
		font-size: 1.2rem;
	}
}

.prev-btn a:hover,
.next-btn a:hover {
	text-decoration: none;
}

.prev-btn i,
.next-btn i {
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	transform: translateY(-50%);
	font-size: 2rem;
	color: #b0050e;
	padding: 0 10px;
	line-height: 1;
}
.prev-btn i {
	left: 0;
}
.next-btn i {
	right: 0;
}

@media only screen and (max-width: 768px) {
	.prev-btn i,
	.next-btn i {
		font-size: 1.2rem;
	}
}

.next-btn {
	text-align: right;
}


/*
-------------------------------- */

.bigtitle {
	font-size: 2.4rem;
	font-weight: 700;
	color: #00a1e9;
	letter-spacing: 0;
}

.midashi {
	font-size: 1.6rem;
	font-weight: 700;
	border-bottom: #333 1px solid;
	margin-bottom: 10px;
}

.event-timetable {
	width: 100%;
	border-collapse: separate;
	border-spacing: 3px;
}

.event-timetable th {
	background: #00a1e9;
	border: #00a1e9 1px solid;
	padding: 5px;
	color: #fff;
	white-space: nowrap;
	font-weight: bold;
}

.event-timetable td {
	border: #999 1px solid;
	padding: 5px;
	font-size: 1.2rem;
}

.event-timetable td p {
	margin-top: 0;
}

.event-timetable td .bigtitle {
	font-size: 1.4rem;
	line-height: 1.25;
}

.slider {
	width: 100%;
}

.slider__list {
	width: 100%;
	position: relative;
	opacity: 0;
	transition: opacity 0.3s linear;
}

@media only screen and (max-width: 768px) {
	.slider__list {
		display: none;
	}
}

.slider__list.slick-initialized {
	opacity: 1;
}

@media only screen and (max-width: 768px) {
	.slider__list.slick-initialized {
		display: block;
	}
}

.slider__list a {
	position: relative;
	transition: all 0.3s linear;
	display: block;
	text-decoration: none;
}

.slider__list a:hover {
	opacity: 0.8;
}

.slider__list .slick-slide:not(.slick-active) {
	transition: 0.2s linear;
	pointer-events: none;
}

.slider__list .slick-slide:not(.slick-active) img {
	opacity: 0.25;
}

@media only screen and (max-width: 768px) {
	.slider__list .slick-slide:not(.slick-active) img {
		opacity: 1;
	}
}

@media only screen and (max-width: 768px) {
	.slider__list .slick-slide img {
		width: 100%;
		height: auto;
	}
}

.slider__list .sliderArrow {
	position: absolute;
	top: 45%;
	z-index: 100;
	cursor: pointer;
	transition: all 0.3s linear;
}

.slider__list .sliderArrow:hover {
	opacity: 0.7;
}

.slider__list .sliderArrow.prev {
	left: 53%;
	transform: translate(-610px, -50%);
}

.slider__list .sliderArrow.next {
	right: 53%;
	transform: translate(610px, -50%);
}

@media only screen and (max-width: 768px) {
	.slider__list .sliderArrow {
		display: none !important;
	}
}

.slider__list .sliderDots {
	text-align: center;
	margin: 20px 0 0;
}

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

.slider__list .sliderDots li {
	display: inline-block;
	margin: 0 5px;
}

.slider__list .sliderDots li button {
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 0;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	position: relative;
	text-indent: -9999px;
	background: #333;
	width: 100px;
	height: 10px;
	cursor: pointer;
	transition: all 0.3s linear;
}

@media only screen and (max-width: 768px) {
	.slider__list .sliderDots li button {
		width: 8px;
		height: 8px;
	}
}

.slider__list .sliderDots li:hover button,
.slider__list .sliderDots li.slick-active button {
	background: #bc111a;
}

.slider__list__text {
	text-decoration: none;
	font-size: 1.8rem;
	font-weight: bolder;
	border-bottom: none;
	background: rgba(0, 0, 0, 0.8);
	display: block;
	padding: 20px 25px 25px;
	position: absolute;
	bottom: 0px;
	left: 0;
	right: 0;
	color: #fff;
}

@media only screen and (max-width: 768px) {
	.slider__list__text {
		height: auto;
		padding: 10px;
		font-size: 1.6rem;
	}
}

.bigBnr {
	text-align: center;
	margin: 60px auto;
}

@media only screen and (max-width: 768px) {
	.bigBnr {
		margin: 30px auto;
		width: 90%;
	}
}

.bigBnr a:hover {
	opacity: 0.8;
}

@media only screen and (max-width: 768px) {
	.bigBnr img {
		width: 100%;
		height: auto;
	}
}

.spSNS {
	display: none;
}

@media only screen and (max-width: 768px) {
	.spSNS {
		display: block;
		background: #bc111a;
		padding: 15px 0;
	}
}

.spSNS .social {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
}

.spSNS .social__item {
	padding: 0 10px;
}

.spSNS .social__item a {
	font-size: 4rem;
	color: #000;
}

.homeNews {
	margin: 60px 0;
	position: relative;
	overflow: hidden;
}

@media only screen and (max-width: 768px) {
	.homeNews {
		margin-top: 30px;
	}
	.homeNews:before {
		content: none;
	}
	.homeNews:after {
		content: none;
	}
}

.homeNews .newslist {
	position: relative;
}

.homeNews .newslist:before {
	content: "";
	position: absolute;
	left: -78px;
	top: 50px;
	background: url(/41st/assets/images/news/bamos_05.png) no-repeat;
	background-size: 100%;
	width: 110px;
	height: 118px;
	z-index: 1;
	transform: rotate(-18deg);
}

.homeNews .newslist:after {
	content: "";
	position: absolute;
	right: -50px;
	bottom: -70px;
	background: url(/41st/assets/images/news/bamos_02.png) no-repeat;
	background-size: 100%;
	width: 170px;
	height: 160px;
	z-index: 1;
}

@media only screen and (max-width: 768px) {
	.homeNews .newslist:before {
		content: none;
	}
	.homeNews .newslist:after {
		content: none;
	}
}

.homeNews__title {
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	color: #333;
	font-size: 4.8rem;
	line-height: 1;
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	margin-bottom: 30px;
}

@media only screen and (max-width: 768px) {
	.homeNews__title {
		font-size: 3rem;
	}
}

.homeNews__title span {
	padding: 0 10px;
}

@media only screen and (max-width: 768px) {
	.homeNews__title span img {
		width: 25px;
		height: auto;
	}
}

.homeNews__footer {
	margin-top: 30px;
}

.btn {
	width: 300px;
	margin: 0 auto;
}

.btn a {
	display: block;
	position: relative;
	text-align: center;
	width: 300px;
	padding: 20px 0;
	background: #bc111a;
	border: #bc111a 2px solid;
	color: #fff;
	font-size: 1.8rem;
	font-weight: 700;
	text-decoration: none;
	transition: all 0.3s linear;
}

@media only screen and (max-width: 768px) {
	.btn a {
		width: 100%;
	}
}

.btn a:hover {
	background: #fff;
	color: #bc111a;
}
.btn a::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 20px;
	width: 8px;
	height: 8px;
	margin-top: -4px;
	border-top: 2px solid;
	border-right: 2px solid;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
	-webkit-transition: none !important;
	-o-transition: none !important;
	transition: none !important;
}


.trailer {
	margin: 60px auto 0 auto;
	padding: 60px 0;
	line-height: 1;
	font-size: 0;
	background: url(/41st/assets/images/common/bg.jpg);
	background-size: cover;
	position: relative;
}

@media only screen and (max-width: 768px) {
	.trailer {
		width: 100%;
		padding: 30px 20px;
		margin: 0;
	}
}

@media only screen and (max-width: 768px) {
	.trailer #ytplayer {
		width: 100%;
		height: 56.25vw;
	}
}

.trailer .wrapper {
	display: flex;
}

@media only screen and (max-width: 768px) {
	.trailer .wrapper {
		display: block;
	}
}

.trailer__inner {
	width: 580px;
	/*margin: 0 10px;*/
	margin: 0 auto;
	padding: 20px;
	background: #fff;
	zoom: 1;
	z-index: 1;
}

.trailer__inner:after {
	content: "";
	display: block;
	clear: both;
}

@media only screen and (max-width: 768px) {
	.trailer__inner {
		width: 100%;
		margin: 0 0 20px 0;
		padding: 10px;
	}
	.trailer__inner:last-child {
		margin: 0;
	}
}

.trailer__img {
	float: left;
	width: 255px;
}

.trailer__img img {
	width: 100%;
}

@media only screen and (max-width: 768px) {
	.trailer__img {
		width: 40%;
	}
}

.trailer__download {
	float: right;
	margin-top: 70px;
	width: 270px;
}

.trailer__download .btn {
	width: auto;
}

.trailer__download .btn a {
	width: 100%;
	margin-bottom: 20px;
}

@media only screen and (max-width: 768px) {
	.trailer__download {
		margin-top: 0;
		width: 55%;
	}
	.trailer__download .btn a {
		margin-bottom: 10px;
	}
}

.trailer__text__title {
	font-size: 2.4rem;
	margin-bottom: 20px;
	text-align: center;
}

.download {
	background: #bc111a;
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	padding: 10px 15px;
	margin: 60px auto;
}

@media only screen and (max-width: 768px) {
	.download {
		width: 100%;
		background: none;
		flex-wrap: wrap;
		margin: 30px auto;
	}
}

.download__title {
	background: #333;
	color: #fff;
	padding: 3px 10px;
	line-height: 1;
	font-size: 1.4rem;
	font-weight: 700;
}

@media only screen and (max-width: 768px) {
	.download__title {
		background: #bc111a;
		color: #333;
		margin: 0 25% 10px;
	}
}

.download__item1,
.download__item2 {
	font-size: 1.5rem;
	font-weight: 500;
	color: #ccc;
}

.download__item1 a,
.download__item2 a {
	color: #000;
	text-decoration: underline;
}

.download__item1 a:hover,
.download__item2 a:hover {
	text-decoration: none;
}

.download__item1 {
	margin: 0 10px 0 20px;
}

.download__item1::after {
	content: "／";
	padding-left: 10px;
	color: #000;
}

.infoArea {
	background: #bc111a;
	background-size: cover;
	padding: 60px 0;
}

@media only screen and (max-width: 768px) {
	.infoArea {
		padding: 30px 20px;
	}
}

.infoArea__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: stretch;
}

@media only screen and (max-width: 768px) {
	.infoArea__list {
		display: block;
	}
}

.infoArea__item {
	width: 585px;
	height: 100px;
	margin-right: 30px;
	margin-bottom: 15px;
	background: #fff;
}

@media only screen and (max-width: 768px) {
	.infoArea__item {
		width: 100%;
		margin-right: 0;
		margin-bottom: 2px;
		height: auto;
	}
}

.infoArea__item:nth-child(even) {
	margin-right: 0;
}

.infoArea__item a {
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
	text-decoration: none;
}

@media only screen and (max-width: 768px) {
	.infoArea__item a {
		padding: 10px;
		align-items: stretch;
	}
}

.infoArea__item a img {
	transition: all 0.2s linear;
}

.infoArea__item a:hover {
	background: #eee;
}

.infoArea__item a:hover img {
	transform: scale(1.05);
}

.infoArea__img {
	width: 140px;
	height: 100px;
	overflow: hidden;
}

@media only screen and (max-width: 768px) {
	.infoArea__img {
		float: left;
		width: 25%;
		height: auto;
	}
}

@media only screen and (max-width: 768px) {
	.infoArea__img img {
		width: 100%;
		height: auto;
	}
}

.infoArea__text {
	padding: 10px 15px;
	width: 445px;
	color: #333;
	font-size: 1.3rem;
}

@media only screen and (max-width: 768px) {
	.infoArea__text {
		width: 75%;
		padding: 0 0 0 10px;
	}
}

.infoArea__text__title {
	font-size: 1.6rem;
	font-weight: 700;
}

.pffArea {
	padding: 60px 0;
	text-align: center;
}

.pffArea a {
	display: inline-block;
	margin: 0 auto;
	text-decoration: none;
	text-align: center;
	transition: all 0.3s linear;
}

@media only screen and (max-width: 768px) {
	.pffArea a {
		display: block;
		width: 100%;
	}
}

.pffArea a:hover {
	opacity: 0.7;
}

@media only screen and (max-width: 768px) {
	.pffArea__img {
		width: 40%;
		margin: 0 auto;
	}
}

@media only screen and (max-width: 768px) {
	.pffArea__img img {
		width: 100%;
		height: auto;
	}
}

.pffArea__text {
	color: #333;
	font-size: 1.8rem;
	font-weight: 500;
	margin-top: 2em;
}

.widgetArea {
	background: url(/41st/assets/images/common/bg.jpg);
	background-size: cover;
	padding: 60px 0;
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: stretch;
}

@media only screen and (max-width: 768px) {
	.widgetArea {
		display: block;
		padding: 30px 20px;
	}
}

.widgetArea__twitter,
.widgetArea__instagram {
	padding: 20px;
	width: 580px;
	margin: 0 10px;
}

@media only screen and (max-width: 768px) {
	.widgetArea__twitter,
	.widgetArea__instagram {
		width: 100%;
		margin: 0;
		padding: 10px;
	}
}

.widgetArea__twitter {
	background: #fff;
}

@media only screen and (max-width: 768px) {
	.widgetArea__twitter {
		margin-bottom: 20px;
	}
}

.widgetArea__instagram {
	background: #fff;
}

.widgetArea__title {
	color: #000;
	font-size: 2.1rem;
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	margin-bottom: 5px;
}

.widgetArea__outer {
	line-height: 1;
	font-size: 0;
}

.insta__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
}

.insta__item {
	width: 33.333%;
}

@media only screen and (max-width: 768px) {
	.insta__item {
		width: 50%;
	}
}

.insta__item a:hover {
	opacity: 0.7;
}

.insta__item img {
	width: 100%;
	height: 180px;
	object-fit: cover;
	font-family: "object-fit: cover;";
}

.outline {
	margin: 60px 0;
}

@media only screen and (max-width: 768px) {
	.outline {
		margin: 15px 20px;
	}
}

.outline__title {
	font-size: 3.6rem;
	color: #b0050e;
	font-weight: 800;
	line-height: 1.25;
	margin-bottom: 30px;
}

@media only screen and (max-width: 768px) {
	.outline__title {
		font-size: 2.2rem;
		line-height: 1.5;
		margin-bottom: 15px;
	}
}

.outline__layout {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: stretch;
}

@media only screen and (max-width: 768px) {
	.outline__layout {
		display: block;
	}
}

.outline__layout__l,
.outline__layout__r {
	width: 580px;
}

@media only screen and (max-width: 768px) {
	.outline__layout__l,
	.outline__layout__r {
		width: 100%;
	}
}

@media only screen and (max-width: 768px) {
	.outline__layout__l {
		margin-bottom: 15px;
	}
}

.outline__award {
	border: #eee 7px solid;
	padding: 15px;
	font-size: 1.8rem;
	font-weight: 500;
	display: block;
	width: 50%;
	margin: 0 auto;
	margin-top: 30px;
}

@media only screen and (max-width: 768px) {
	.outline__award {
		padding: 10px;
		margin-top: 15px;
		width: 100%;
	}
}

.outline p {
	font-size: 1.6rem;
	line-height: 1.75;
}

@media only screen and (max-width: 768px) {
	.outline p {
		line-height: 1.5;
	}
}

.outline__photo {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
	margin-top: 30px;
}

@media only screen and (max-width: 768px) {
	.outline__photo {
		flex-wrap: wrap;
	}
}

.outline__photo__item {
	width: 100%;
}

@media only screen and (max-width: 768px) {
	.outline__photo__item {
		width: 50%;
	}
}

.outline__photo__item img {
	width: 100%;
	height: auto;
}

.outline__tableArea {
	background: #f7f6ef;
	padding: 60px 0;
}

@media only screen and (max-width: 768px) {
	.outline__tableArea {
		padding: 30px 5vw;
	}
}

.btn.column-2 {
	width: 100%;
	text-align: center;
}

.btn.column-2 a {
	margin: 10px;
	display: inline-block;
}
@media only screen and (max-width: 768px) {
	.btn.column-2 {
		margin-top: 20px;
	}
	.btn.column-2 a {
		margin: 5px 0;
	}
}

.award2020 {
	padding-bottom: 60px;
}

@media only screen and (max-width: 768px) {
	.award2020 {
		padding: 0 5vw 30px;
	}
}

.award2020__img {
	float: right;
	margin: 0 0 1em 3em;
}

@media only screen and (max-width: 768px) {
	.award2020__img {
		width: 40%;
		margin: 0 0 0.5em 1em;
	}
}

@media only screen and (max-width: 768px) {
	.award2020__img img {
		width: 100%;
		height: auto;
	}
}

.award2020__img figcaption {
	font-size: 1.2rem;
	margin-top: 3px;
	text-align: right;
}

.award2020 p {
	margin-top: 1em;
	font-size: 1.8rem;
}

@media only screen and (max-width: 768px) {
	.award2020 p {
	}
}

.award2020 p:first-child {
	margin-top: 0;
}

.award2020__title {
	font-weight: bold;
	font-size: 3rem;
	text-align: center;
	color: #000;
	position: relative;
	padding-bottom: 20px;
	margin-bottom: 40px;
}

@media only screen and (max-width: 768px) {
	.award2020__title {
		margin-bottom: 30px;
		font-size: 2rem;
	}
}

.award2020__title::after {
	content: "";
	width: 100px;
	height: 1px;
	border-bottom: #bc111a 3px solid;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
}

.award2020 .btn {
	display: table;
	border-collapse: separate;
	border-spacing: 20px 0;
	width: 600px;
	line-height: 2.4rem;
}
.award2020 .btn a {
	display:table-cell;
	padding:5px 0;
	vertical-align: middle;
}
@media only screen and (max-width: 768px) {
	.award2020 .btn {
		display: block;
		width: 100%;
		line-height: 2.4rem;
	}
	.award2020 .btn a {
		display: block;
		padding: 10px 0;
		margin: 10px 0;
	}
}

.selection,
.selected {
	padding: 60px 0;
}

.selection {
	background: #f7f6ef;
}

@media only screen and (max-width: 768px) {
	.selection {
		padding: 30px 20px;
	}
}

.selection__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: stretch;
}

.selection__item {
	width: 24%;
	margin-bottom: 10px;
	font-size: 1.8rem;
}

@media only screen and (max-width: 768px) {
	.selection__item {
		width: 48%;
		text-align: center;
	}
}

.selection__item span {
	font-size: 1.2rem;
}

@media only screen and (max-width: 768px) {
	.selection__item span {
		display: block;
	}
}

.selection__note {
	margin-top: 2em;
	font-size: 1.2rem;
	text-align: right;
}

@media only screen and (max-width: 768px) {
	.selected {
		padding: 30px 5vw;
	}
}

.selected__table {
	background: #f7f6ef;
	width: 100%;
	border-spacing: 2px;
	border-collapse: separate;
}

.selected__table th,
.selected__table td {
	padding: 20px;
	font-size: 1.8rem;
}

@media only screen and (max-width: 768px) {
	.selected__table th,
	.selected__table td {
		padding: 10px;
	}
}

.selected__table th {
	background: #333;
	color: #fff;
	text-align: left;
}

@media only screen and (max-width: 768px) {
	.selected__table th {
		width: 30%;
	}
}

.selected__table td {
	background: #fff;
	color: #333;
}

.juror__lead {
	text-align: center;
}

@media only screen and (max-width: 768px) {
	.juror__lead {
		padding: 0 5vw;
	}
}

.juror__list {
	margin-top: 60px;
}

@media only screen and (max-width: 768px) {
	.juror__list {
		margin-top: 30px;
	}
}

.juror__item {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
	margin-top: 30px;
}
@media screen and (min-width: 769px), print {
}
@media only screen and (max-width: 768px) {
	.juror__item {
		display: block;
		padding: 35px 5vw;
		margin-top: 0;
		border-bottom: #ccc 1px solid;
	}
	.juror__item:last-child {
		border-bottom: 0;
	}
}

.juror__img {
	background: center center no-repeat;
	background-size: cover;
	width: 280px;
	height: 400px;
}

@media only screen and (max-width: 768px) {
	.juror__img {
		width: 40%;
		height: auto;
		margin: 0 auto;
	}
}

.juror__img img {
	width: 100%;
}

.juror__textArea {
	width: calc(100% - 310px);
}

@media only screen and (max-width: 768px) {
	.juror__textArea {
		width: 100%;
	}
}

.juror__shoulder {
	font-size: 1.6rem;
	font-weight: 500;
	margin-top: -10px;
	padding-bottom: 10px;
	margin-bottom: 10px;
	position: relative;
}

@media only screen and (max-width: 768px) {
	.juror__shoulder {
		margin-top: 20px;
	}
}

.juror__shoulder::after {
	content: "";
	width: 80px;
	height: 1px;
	border-bottom: #bc111a 4px solid;
	position: absolute;
	left: 0;
	bottom: 0;
}

.juror__name {
	font-size: 4.8rem;
	font-weight: 700;
}

@media only screen and (max-width: 768px) {
	.juror__name {
		font-size: 3.6rem;
	}
}

.juror__nameENG {
	font-family: "Roboto", sans-serif;
	font-size: 1.2rem;
	font-weight: 700;
	font-style: italic;
}

.juror__text {
	margin-top: 20px;
	line-height: 1.75;
}

.juror__bnr {
	padding-bottom: 60px;
	border-bottom: #ccc 1px solid;
}

@media only screen and (max-width: 768px) {
	.juror__bnr {
		padding: 0 20px 30px;
	}
}

.juror__bnr__inner a {
	display: block;
	width: 901px;
	height: 459px;
	background: url(/40th/assets/images/award/bnr.png) center center no-repeat;
	background-size: cover;
	margin: 0 auto;
	transition: all 0.3s linear;
}

@media only screen and (max-width: 768px) {
	.juror__bnr__inner a {
		background-size: contain;
		width: 100%;
		height: 50.943vw;
	}
}

.juror__bnr__inner a:hover {
	opacity: 0.7;
}

.juror__bnr__inner a img {
	width: 100%;
	height: 100%;
}

.award .lineup__header {
	border: none !important;
}

@media only screen and (max-width: 768px) {
	.award .lineup__header {
		padding-bottom: 30px;
	}
}

.winnerList {
	width: 100%;
	border-collapse: separate;
	border-spacing: 10px;
	background: #f7f6ef;
}

@media only screen and (max-width: 768px) {
	.winnerList {
		border-spacing: 5px;
	}
}

.winnerList thead th {
	background-color: #333;
	color: #fff;
	text-align: center;
	font-size: 1.8rem;
	font-weight: normal;
	padding: 10px;
	line-height: 1.5;
	letter-spacing: 0.2em;
	border-bottom: #bc111a 3px solid;
}

.winnerList tbody th,
.winnerList tbody td {
	background: #fff;
	padding: 10px;
	font-size: 1.6rem;
	font-weight: normal;
	text-align: left;
	vertical-align: top;
	line-height: 1.75;
}

@media only screen and (max-width: 768px) {
	.winnerList tbody th,
	.winnerList tbody td {
		padding: 5px;
	}
}

.winnerList tbody th {
	width: 50%;
}

@media only screen and (max-width: 768px) {
	.winnerList tbody th {
		font-size: 1.2rem;
	}
}

.winnerList tbody th strong {
	color: #b0050e;
	font-size: 2.1rem;
	font-weight: 700;
}

@media only screen and (max-width: 768px) {
	.winnerList tbody th strong {
		display: block;
		font-size: 1.6rem;
	}
}

.winnerList tbody td {
	width: 50%;
}

.winnerList tbody td a {
	color: #333;
}

.winnerList__work {
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
}

@media only screen and (max-width: 768px) {
	.winnerList__work {
		display: block;
	}
}

.winnerList__photo {
	width: 200px;
	margin-right: 20px;
}

@media only screen and (max-width: 768px) {
	.winnerList__photo {
		width: 100%;
		margin-right: 0;
	}
}

@media only screen and (max-width: 768px) {
	.winnerList__photo img {
		width: 100%;
		height: auto;
	}
}

.winnerList__text {
	line-height: 1.25;
}

@media only screen and (max-width: 768px) {
	.winnerList__text {
		margin-top: 5px;
		font-size: 1.2rem;
	}
}

.winnerList__text strong {
	font-size: 2rem;
	margin-left: -0.5em;
}

@media only screen and (max-width: 768px) {
	.winnerList__text strong {
		font-size: 1.6rem;
	}
}

.winnerList__text strong span {
	font-size: 1.4rem;
	padding-left: 1em;
}

@media only screen and (max-width: 768px) {
	.winnerList__text strong span {
		font-size: 1.2rem;
		padding-left: 0;
	}
}

.special {
	font-size: 1.8rem;
	margin-bottom: 10px;
	font-weight: bold;
}
.special ~ .special {
	margin-top: 50px;
}
@media only screen and (max-width: 768px) {
	.special ~ .special {
		margin-top: 30px;
	}
}


.special2 {
	position: absolute;
	right: 30px;
	top: 0;
	margin-top: 0 !important;
}

@media only screen and (max-width: 768px) {
	.special2 {
		position: static;
		text-align: right;
		margin: -10px 0 5px;
	}
}

@media only screen and (max-width: 768px) {
	.comment_wrapper {
		padding: 0 5vw;
	}
}

#review {
	margin-top: 60px;
}

@media only screen and (max-width: 768px) {
	#review {
		margin-top: 30px;
	}
}

.comment__anchor {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	margin-top: 60px;
	margin-bottom: 60px;
}

@media only screen and (max-width: 768px) {
	.comment__anchor {
		margin-top: 30px;
		margin-bottom: 30px;
	}
}

.comment__anchor__item {
	margin: 0 15px;
	position: relative;
	padding-right: 20px;
	line-height: 1;
}

.comment__anchor__item::after {
	font-size: 1.4rem;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f107";
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-40%);
	color: #245136;
}

.comment__anchor__item a {
	color: #000;
}

.comment__anchor__item a:hover {
	text-decoration: none;
}

.comment__title {
	font-size: 2.4rem;
	font-weight: 700;
	text-align: center;
	margin-bottom: 30px;
	background: #333;
	color: #fff;
	padding: 5px;
}

@media only screen and (max-width: 768px) {
	.comment__title {
		margin-bottom: 15px;
	}
}

.comment__outer {
	overflow: hidden;
	position: relative;
	zoom: 1;
	margin-top: 30px;
}

.comment__outer.line1 {
	border-bottom: #ccc 1px dotted;
	padding-bottom: 30px;
}

.comment__outer p {
	padding-bottom: 1em;
}

@media only screen and (max-width: 768px) {
	.comment__outer p {
		font-size: 2rem;
	}
}

.comment__outer p:last-child {
	padding-bottom: 0;
}

.comment__prize {
	background: #bc111a;
	padding: 5px;
	font-size: 1.8rem;
	text-align: center;
	margin-bottom: 20px;
	color: #fff;
}

@media only screen and (max-width: 768px) {
	.comment__prize {
		margin-bottom: 10px;
	}
}

.comment__img {
	float: right;
	margin: 2em 0 1em 2em;
	width: 540px;
}

@media only screen and (max-width: 768px) {
	.comment__img {
		float: none;
		margin: 0 0 15px;
		width: 100%;
	}
}

#review .comment__img {
	margin-top: 0.5em;
}

@media only screen and (max-width: 768px) {
	#review .comment__img {
		margin-top: 0;
	}
}

.comment__img img {
	width: 100%;
	height: auto;
}

.comment__img.ikuta1 {
	/*			background: url(../../assets/images/award/comment01.jpg) center top no-repeat;*/
	background-size: 100% auto;
}

@media only screen and (max-width: 768px) {
	.comment__img.ikuta1 {
		background-size: cover;
	}
}

.comment__img.ikuta1 img {
	height: 334px;
}

@media only screen and (max-width: 768px) {
	.comment__img.ikuta1 img {
		height: 61.875vw;
	}
}

.comment__img.ikuta2 {
	/*			background: url(../../assets/images/award/comment_juror05.jpg) center top no-repeat;*/
	background-size: 100% auto;
}

@media only screen and (max-width: 768px) {
	.comment__img.ikuta2 {
		background-size: cover;
	}
}

.comment__img.ikuta2 img {
	height: 334px;
}

@media only screen and (max-width: 768px) {
	.comment__img.ikuta2 img {
		height: 61.875vw;
	}
}

.comment__work {
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.25;
	margin-top: 5px;
	margin-bottom: 15px;
}

.comment__work span {
	font-size: 1.8rem;
}

@media only screen and (max-width: 768px) {
	.comment__work span {
		display: inline-block;
		margin-top: 5px;
		padding-left: 0.5em;
	}
}

@media only screen and (max-width: 768px) {
	#review .comment__work span {
		padding-left: 0;
	}
}

.comment__juror {
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 1.25;
	margin-bottom: 20px;
	padding-left: 0.5em;
}

.comment__juror span {
	font-size: 1.2rem;
}

.contents {
	margin: 60px 0;
}

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

.contents__title {
	font-weight: 700;
	color: #333;
	font-size: 4rem;
	line-height: 1;
	margin-bottom: 60px;
	text-align: center;
}
.contents__title::after {
	content: "";
	display: block;
	width: 100px;
	margin: 20px auto 0;
	border-top: #bc111a 5px solid;
}

@media only screen and (max-width: 768px) {
	.contents__title {
		font-size: 2.4rem;
		margin-bottom: 30px;
	}
	.contents__title::after {
		border-top-width: 3px;
	}
}

.contents__title span {
	padding: 0 10px;
}

@media only screen and (max-width: 768px) {
	.contents__title span img {
		width: 25px;
		height: auto;
	}
}

.lineup__header {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: stretch;
	flex-direction: row-reverse;
	padding-bottom: 60px;
	border-bottom: #ccc 1px solid;
}

@media only screen and (max-width: 768px) {
	.lineup__header {
		display: block;
		padding-bottom: 30px;
	}
}

@media only screen and (max-width: 768px) {
	.eiganokotsu .lineup__header,
	.tamuramasaki .lineup__header {
		padding-bottom: 0;
	}
}

.lineup__header__textArea {
	width: 640px;
	font-size: 1.6rem;
	color: #333;
}

@media only screen and (max-width: 768px) {
	.lineup__header__textArea {
		width: 100%;
		padding: 20px;
	}
}

.lineup__header__shoulder {
	font-size: 5rem;
	color: #333;
	font-weight: 700;
	line-height: 1;
	margin-bottom: 30px;
}
.lineup__header__title.s + .lineup__header__shoulder {
	font-size: 7.2rem;
}
@media screen and (min-width: 769px), print {
	.lineup__header__textArea .lineup__header__shoulder {
		font-size: 4rem;
	}
}
@media only screen and (max-width: 768px) {
	.lineup__header__shoulder {
		margin-bottom: 20px;
		font-size: 3rem;
	}
	.lineup__header__title.s + .lineup__header__shoulder {
		font-size: 4.6rem;
	}
	.lineup__header__textArea .lineup__header__shoulder {
		font-size: 2.5rem;
	}
}

.lineup__header__pop {
	background: #24C479;
	color: #fff;
	display: inline-block;
	line-height: 1;
	padding: 5px 10px;
	border-radius: 5px;
	margin-top: 20px;
	margin-bottom: 10px;
	font-size: 1.8rem;
	font-weight: 700;
}

@media only screen and (max-width: 768px) {
	.lineup__header__pop {
		margin-top: 5px;
	}
}

.lineup__header__title {
	font-size: 6.5rem;
	color: #b0050e;
	font-weight: 800;
	line-height: 1.2;
	margin-bottom: 20px;
}
.lineup__header__title.s {
	font-size: 4.6rem;
}

@media screen and (min-width: 769px), print {
	.lineup__header__textArea .lineup__header__title {
		font-size: 6rem;
	}
}
@media only screen and (max-width: 768px) {
	.lineup__header__title {
		font-size: 4rem;
	}
	.lineup__header__title.s {
		font-size: 2.8rem;
	}
}

.aldrich .lineup__header__title,
.eiganokotsu .lineup__header__title {
	color: #24C479;
	font-size: 6rem;
}

@media only screen and (max-width: 768px) {
	.aldrich .lineup__header__title,
	.eiganokotsu .lineup__header__title {
		font-size: 3.4rem;
	}
}

.tamuramasaki .lineup__header__title {
	color: #24C479;
	font-size: 4.2rem;
}

@media only screen and (max-width: 768px) {
	.tamuramasaki .lineup__header__title {
		font-size: 3.4rem;
	}
}

.lineup__header__text {
	line-height: 1.75;
}
@media only screen and (max-width: 768px) {
	.lineup__header__text {
		padding-left: 3vw;
		padding-right: 3vw;
	}
}

.lineup__header__text .btn {
	width: auto;
	margin: 20px 0 0;
}

.lineup__header__text .btn a {
	position: relative;
	text-align: center;
	width: auto;
	height: auto;
	line-height: 1.5;
	background: #1a1a1a;
	border: #1a1a1a 2px solid;
	color: #fff;
	font-size: 1.6rem;
	padding: 10px 40px;
	display: inline-block;
}
.lineup__header__text .btn a i {
	position: absolute;
	right: 10px;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	transform: translateY(-50%);
}

.lineup__header__text .btn a::after {
	display: none;
}

.lineup__header__text .btn a:hover {
	background: #fff;
	color: #1a1a1a;
}

.lineup__header__text .bnr {
	margin-bottom: 20px;
}

.lineup__header__profile {
	margin-top: 30px;
}

@media only screen and (max-width: 768px) {
	.lineup__header__profile {
		margin-top: 30px;
	}
}

.lineup__header__profile__name {
	font-size: 1.8rem;
	font-weight: 700;
	color: #000;
}

.lineup__header__profile__name span {
	font-family: "Roboto", sans-serif;
	font-size: 1.4rem;
	font-weight: 400;
	font-style: italic;
	color: #666;
	padding-left: 15px;
}

.lineup__header__profile__text {
	margin-top: 5px;
	font-size: 1.3rem;
	color: #333;
}

.lineup__header__imgArea {
	width: 500px;
}

@media only screen and (max-width: 768px) {
	.lineup__header__imgArea {
		width: 100%;
	}
}

@media only screen and (max-width: 768px) {
	.lineup__header__imgArea img {
		width: 100%;
		height: auto;
	}
}

.lineup__header__imgArea figcaption {
	font-size: 1.2rem;
	text-align: right;
	margin-top: 5px;
}

@media only screen and (max-width: 768px) {
	.lineup__header__imgArea figcaption {
		padding-right: 10px;
	}
}

.lineup__header .infoBar {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
}

.lineup__header .infoBar__img {
	width: 130px;
}

.lineup__header .infoBar__text {
	width: 480px;
	padding: 20px;
	font-size: 2.1rem;
	font-weight: 500;
	color: #b0050e;
	line-height: 1.25;
}

.lineup__section {
	padding-top: 60px;
}

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

@media only screen and (max-width: 768px) {
	.eiganokotsu .lineup__section,
	.tamuramasaki .lineup__section {
		padding-top: 0;
	}
}

.lineup__section .timeBar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	background: #bc111a;
	padding: 10px 20px;
	margin-bottom: 20px;
	color: #fff;
}

@media only screen and (max-width: 768px) {
	.lineup__section .timeBar {
		display: block;
		margin-bottom: 0;
		text-align: center;
	}
}

@media only screen and (max-width: 768px) {
	.aldrich .lineup__section .timeBar {
		margin-bottom: 15px;
	}
}

.lineup__section .timeBar__title {
	font-size: 2.8rem;
	font-weight: 700;
	margin-right: 20px;
}

.lineup__section .timeBar__date {
	font-size: 1.8rem;
	font-weight: 500;
}

.lineup__section .timeBar__date .icon {
	color: #24C479;
	font-weight: 700;
	font-style: normal;
	font-family: "Roboto", sans-serif;
	padding-right: 10px;
}

.lineup__section .timeBar .buy {
	background: #333;
	color: #fff;
	text-decoration: none;
	font-size: 1.2rem;
	font-weight: 700;
	border-radius: 3px;
	padding: 8px 10px;
	margin-left: auto;
	line-height: 1;
	display: inline-block;
	transition: all 0.3s linear;
}

@media only screen and (max-width: 768px) {
	.lineup__section .timeBar .buy {
		margin-top: 5px;
	}
}

.lineup__section .timeBar .buy:hover {
	background: #00a0ea;
}

.lineup__outer {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: stretch;
}

@media only screen and (max-width: 768px) {
	.lineup__outer {
		display: block;
	}
}

.lineup__card {
	width: calc(50% - 20px);
	border-bottom: #ccc 1px solid;
	padding-bottom: 30px;
	margin-bottom: 30px;
	/*margin-top: -90px;
  padding-top: 90px;*/
}

@media only screen and (max-width: 768px) {
	.lineup__card {
		width: 100%;
		margin-top: calc(-17vw + 10px);
		padding: 30px 5vw;
		padding-top: calc(17vw - 10px + 30px);
	}
}

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

@media only screen and (max-width: 768px) {
	.aldrich .lineup__card:last-child {
		border-bottom: none;
		padding-bottom: 0;
	}
}

.lineup__card.wide {
	width: 100%;
	/*			padding-bottom: $base_margin;
    			margin-bottom: $base_margin;*/
}

@media only screen and (max-width: 768px) {
	.lineup__card.wide {
		padding-bottom: 30px;
		margin-bottom: 0;
	}
}

@media only screen and (max-width: 768px) {
	.lineup__card.wide:last-child {
		border-bottom: none;
		padding-bottom: 0;
	}
}

.lineup__card__img {
	margin-bottom: 20px;
}

@media only screen and (max-width: 768px) {
	.lineup__card__img img {
		width: 100%;
		height: auto;
	}
}

.lineup__card__img figcaption {
	font-size: 1.2rem;
	text-align: right;
	margin-top: 4px;
}

.lineup__card .btn {
	width: auto;
	margin: 0 0 20px;
}

.lineup__card .btn a {
	text-align: center;
	width: auto;
	height: auto;
	line-height: 1;
	background: #b0050e;
	border: #b0050e 2px solid;
	color: #fff;
	font-size: 1.8rem;
	padding: 13px 20px;
	display: inline-block;
}
.lineup__card .btn a i {
	margin-right: 10px;
}
.lineup__card .btn a::after {
	display: none;
}

.lineup__card .btn a:hover {
	background: #fff;
	color: #b0050e;
}

.lineup__card__title {
	font-size: 3rem;
	font-weight: 700;
	color: #000;
	line-height: 1.25;
	margin-bottom: 10px;
}

.lineup__card__title .subtitle {
	font-size: 1.8rem;
}

@media only screen and (max-width: 768px) {
	.lineup__card__title .subtitle {
		font-size: 2rem;
	}
}

.lineup__card__title .subtitle2 {
	font-size: 2.4rem;
}

@media only screen and (max-width: 768px) {
	.lineup__card__title .subtitle2 {
		font-size: 2rem;
	}
}

.lineup__card__title .attention {
	color: #DC4135;
	font-size: 1.8rem;
}

.eiganokotsu .lineup__card__title,
.tamuramasaki .lineup__card__title {
	font-size: 4rem;
	margin-bottom: 20px;
}

@media only screen and (max-width: 768px) {
	.eiganokotsu .lineup__card__title,
	.tamuramasaki .lineup__card__title {
		font-size: 2rem;
		margin: 10px 0;
	}
}

.lineup__card__dir {
	font-size: 1.8rem;
	font-weight: 500;
	color: #000;
	margin-bottom: 20px;
}

.lineup__card__catchcopy {
	font-size: 1.8rem;
	font-weight: 700;
	color: #1cb8cb;
	margin: 10px 0 0 0;
}

.lineup__card__text {
	font-size: 1.5rem;
	font-weight: 400;
	color: #333;
	margin: 10px 0 0 0;
}

.lineup__card__data {
	font-size: 1.2rem;
	font-weight: 400;
	color: #666;
	margin-top: 20px;
}

.lineup__card .guest {
	display: table;
	width: 100%;
	margin: 10px 0 0 0;
	border: 2px solid #ece6a0;
}

.lineup__card .guest dt,
.lineup__card .guest dd {
	display: table-cell;
	vertical-align: middle;
	padding: 5px;
}

.lineup__card .guest dt {
	font-weight: bolder;
	background: #ece6a0;
	text-align: center;
	width: 28%;
	line-height: 1.4;
}

.lineup__card .guest .photo {
	width: 70px;
}

.lineup__card .nav .photo {
	vertical-align: top;
}

.lineup__card .nav div {
	margin-top: 1.0rem;
}

.lineup__column {
	position: relative;
	background: #f2f2f2;
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: stretch;
	margin-top: 20px;
	padding: 15px;
	z-index: 3;
}

.lineup__column figcaption {
	font-size: 1rem;
	text-align: right;
	margin-top: 2px;
}

.lineup__column__imgArea {
	width: 130px;
}

.lineup__column__textArea {
	width: 425px;
	padding-left: 15px;
}

.lineup__column__textArea.nophoto {
	width: auto;
	padding-left: 0;
}

.lineup__column__desc {
    font-size: 1.2rem;
    font-weight: 400;
    line-height: 1.4;
}

.lineup__column__name {
	font-size: 1.8rem;
	font-weight: 700;
	color: #000;
}

.lineup__column__eng {
	font-family: "Roboto", sans-serif;
	font-size: 1.2rem;
	font-weight: 400;
	font-style: italic;
	color: #999;
}

.lineup__column__text {
	font-size: 1.4rem;
	font-weight: 400;
	color: #333;
	margin-top: 10px;
}

.lineup__talk {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: stretch;
}

@media only screen and (max-width: 768px) {
	.lineup__talk {
		display: block;
	}
}

.lineup__talk__textArea {
	width: 760px;
}

@media only screen and (max-width: 768px) {
	.lineup__talk__textArea {
		width: 100%;
	}
}

.lineup__talk__img {
	margin-bottom: 20px;
}

@media only screen and (max-width: 768px) {
	.lineup__talk__img {
		width: 100%;
	}
}

@media only screen and (max-width: 768px) {
	.lineup__talk__img img {
		width: 100%;
		height: auto;
	}
}

.lineup__talk__text {
	font-size: 1.5rem;
	font-weight: 400;
	color: #333;
	margin-bottom: 20px;
}

.lineup__talk__komidashi {
	background: #333;
	padding: 5px 10px;
	font-size: 1.4rem;
	font-weight: 500;
	color: #fff;
	margin-bottom: 10px;
	border-top: #bc111a 4px solid;
}

.lineup__talk__guest {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: stretch;
	padding-bottom: 30px;
	margin-bottom: 30px;
	border-bottom: #ccc 1px solid;
}

@media only screen and (max-width: 768px) {
	.lineup__talk__guest {
		padding-bottom: 15px;
		margin-bottom: 15px;
	}
}

.lineup__talk__guest:last-child {
	padding-bottom: 0;
	margin-bottom: 0;
	border-bottom: none;
}

@media only screen and (max-width: 768px) {
	.lineup__talk__guest:last-child {
		padding-bottom: 15px;
		margin-bottom: 15px;
		border-bottom: #ccc 1px solid;
	}
}

.lineup__talk__guest__imgArea {
	width: 130px;
}

@media only screen and (max-width: 768px) {
	.lineup__talk__guest__imgArea {
		width: 25%;
	}
}

@media only screen and (max-width: 768px) {
	.lineup__talk__guest__imgArea img {
		width: 100%;
		height: auto;
	}
}

.lineup__talk__guest__textArea {
	width: 615px;
	padding-left: 10px;
}

@media only screen and (max-width: 768px) {
	.lineup__talk__guest__textArea {
		width: 75%;
	}
}

.lineup__talk__guest__name {
	font-size: 1.8rem;
	font-weight: 700;
	color: #000;
}

.lineup__talk__guest__eng {
	font-family: "Roboto", sans-serif;
	font-size: 1.2rem;
	font-weight: 400;
	font-style: italic;
	color: #999;
}

.lineup__talk__guest__text {
	font-size: 1.4rem;
	font-weight: 400;
	color: #333;
	margin-top: 10px;
}

.lineup__talk__worksArea {
	width: 400px;
}

@media only screen and (max-width: 768px) {
	.lineup__talk__worksArea {
		width: 100%;
	}
}

.lineup__talk__title {
	font-size: 1.6rem;
	font-weight: 500;
	margin-bottom: 10px;
}

.lineup__talk__title span {
	font-size: 1.2rem;
}

@media only screen and (max-width: 768px) {
	.lineup__talk__workList {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: stretch;
	}
}

@media only screen and (max-width: 768px) {
	.lineup__talk__workList__item {
		width: 100%;
	}
}

@media only screen and (max-width: 768px) {
	.lineup__talk__workList__item.one {
		width: 100%;
	}
}

@media only screen and (max-width: 768px) {
	.lineup__talk__workList__img {
		width: 100%;
	}
}

.lineup__talk__workList__img figcaption {
	font-size: 1rem;
	text-align: right;
	margin-top: 2px;
}

@media only screen and (max-width: 768px) {
	.lineup__talk__workList__img img {
		width: 100%;
		height: auto;
	}
}

.lineup__talk__workList__text {
	font-size: 1.4rem;
	margin-top: 5px;
	margin-bottom: 10px;
}

@media only screen and (max-width: 768px) {
	.lineup__talk__workList__text {
		font-size: 1.2rem;
	}
}

.lineup__talk__workList__text strong {
	font-weight: 500;
	font-size: 1.6rem;
}

@media only screen and (max-width: 768px) {
	.lineup__talk__workList__text strong {
		font-size: 1.4rem;
	}
}

.lineup__talk__workList__text .alert {
	font-weight: 500;
	color: #24C479;
}

.lineup__talk__note {
	font-size: 1.4rem;
	margin-top: 10px;
}

.lineup__talk__note .alert {
	font-size: 1.6rem;
	color: #24C479;
}

.lineup__talk__navigator {
	margin-bottom: 10px;
}

.lineup__talk__navigator__img {
	display: table;
}

.lineup__talk__navigator__img>* {
	display: table-cell;
	vertical-align: middle;
	padding: 5px;
}

.juror__bnr .aoyama {
	margin: 30px auto 0;
	text-align: center;
}

@media only screen and (max-width: 768px) {
	.juror__bnr .aoyama {
		margin-top: 15px;
	}
}

.juror__bnr .aoyama a {
	transition: all 0.3s linear;
}

.juror__bnr .aoyama a:hover {
	opacity: 0.8;
}

@media only screen and (max-width: 768px) {
	.juror__bnr .aoyama a img {
		width: 100%;
		height: auto;
	}
}

.float-left,
.float-right {
	width: 49%;
}

.float-left {
	float: left;
}

.float-right {
	float: right;
}

@media only screen and (max-width: 768px) {
	.float-left,
	.float-right {
		width: 100%;
		float: none;
	}
}

.column-3 {
	display: flex;
}

.column-3>div {
	width: 33%;
	padding: 1%;
}

@media only screen and (max-width: 768px) {
	.column-3 {
		display: block;
	}
	.column-3>div {
		width: 100%;
		padding: 0;
	}
}

.anch {
	text-align: center;
	font-size: 1.4rem;
	margin-bottom: 1em;
}

@media only screen and (max-width: 768px) {
	.anch {
		display: none;
	}
}

.timetable {
	width: 100%;
	border-collapse: separate;
	border-spacing: 5px;
	margin-top: 10px;
}

@media only screen and (max-width: 768px) {
	.timetable {
		border-collapse: collapse;
		border-spacing: 0;
		margin: 10px auto 0;
		width: 95%;
	}
}

.timetable tr.closed td {
	text-align: center;
	background: #ddd;
	padding: 2px 10px;
	font-size: 1.2rem;
	letter-spacing: 1em;
	vertical-align: middle;
}

@media only screen and (max-width: 768px) {
	.timetable tr.closed td {
		letter-spacing: 0;
	}
}

.timetable tr.closed td:first-child {
	letter-spacing: 0;
}

.timetable tr.mini td {
	border-style: dotted;
	border-color: #00a1e9;
	background: rgba(0, 161, 233, 0.01);
}

.timetable tr.even td {
	background: #fcfcfc;
}

.timetable th,
.timetable td {
	border: #ccc 1px solid;
	padding: 10px;
	font-size: 1.6rem;
	vertical-align: top;
	line-height: 1.5;
}

.timetable th {
	background-color: #333;
	color: #ddd;
	text-align: center;
	font-size: 1.2rem;
	font-weight: normal;
	padding: 3px 10px;
	line-height: 1.5;
	letter-spacing: 0.2em;
}

@media only screen and (max-width: 768px) {
	.timetable th {
		padding: 5px;
		white-space: nowrap;
	}
}

.timetable td {
	text-align: center;
	font-size: 1.4rem;
}

@media only screen and (max-width: 768px) {
	.timetable td {
		padding: 5px;
		font-size: 1.2rem;
	}
}

.timetable td.over-color {
	text-align: left;
}

.timetable td a {
	color: #333;
	text-decoration: none;
	display: block;
}

.timetable td strong {
	color: #b0050e;
	font-size: 2.4rem;
	font-weight: bold;
	line-height: 1.25;
}

@media only screen and (max-width: 768px) {
	.timetable td strong {
		font-size: 1.6rem;
		line-height: 1.25;
	}
}

.timetable td em {
	font-size: 1.8rem;
	font-weight: bold;
	color: #333;
}

@media only screen and (max-width: 768px) {
	.timetable td em {
		font-size: 1.2rem;
	}
}

.timetable td ul {
	margin-top: 5px;
}

.timetable td li {
	font-size: 1.8rem;
	line-height: 1.5;
}

@media only screen and (max-width: 768px) {
	.timetable td li {
		font-size: 1.3rem;
	}
}

.timetable td p {
	padding-top: 1.2rem;
	vertical-align: middle;
}

@media only screen and (max-width: 768px) {
	.timetable td p {
		padding-top: 0.5rem;
	}
}

.timetable td p span {
	background: #24C479;
	color: #fff;
	font-size: 1.2rem;
	font-weight: bold;
	border-radius: 10px;
	padding: 1px 10px;
}

@media only screen and (max-width: 768px) {
	.timetable td p span {
		font-size: 1rem;
		padding: 2px 5px 1px;
	}
}

.screening-day {
	width: 110px;
}

@media only screen and (max-width: 768px) {
	.screening-day {
		width: 60px;
	}
}

.screening-hall {
	width: 1em;
}

.screening-time {
	width: 100px;
}

@media only screen and (max-width: 768px) {
	.screening-time {
		width: 60px;
	}
}

.day {
	font-size: 4rem;
	line-height: 1;
}

@media only screen and (max-width: 768px) {
	.day {
		font-size: 2rem;
	}
}

.tate {
	transform: rotate(90deg);
	display: inline-block;
}

.note {
	margin-top: 1em;
	font-size: 1.4rem;
	color: #666;
	background: #fff;
}

@media only screen and (max-width: 768px) {
	.note {
		padding: 0 5vw;
	}
}

.nfaj {
	border: #ccc 1px solid;
	padding: 30px 40px;
	margin-top: 30px;
}

@media only screen and (max-width: 768px) {
	.nfaj {
		padding: 20px;
		margin-left: 20px;
		margin-right: 20px;
	}
}

.nfaj__title {
	font-size: 2.1rem;
	font-weight: 700;
	margin-bottom: 10px;
	color: #24C479;
}

@media only screen and (max-width: 768px) {
	.nfaj__title {
		margin-bottom: 5px;
		line-height: 1.25;
	}
}

.nfaj__text {
	font-size: 1.5rem;
}

.nfaj__text a {
	color: #24C479;
}

.nfaj__text a:hover {
	text-decoration: none;
}

.ticketsBnr {
	display: inline-block;
	background: #24C479;
	color: #fff;
	font-size: 2rem;
	font-weight: 700;
	padding: 10px;
	position: absolute;
	right: 50%;
	margin-right: -590px;
	transform: rotate(10deg);
	border-radius: 10px;
	margin-top: -10px;
}

@media only screen and (max-width: 768px) {
	.ticketsBnr {
		position: static;
		margin-right: 0;
		transform: rotate(0);
		margin: 0 0 10px;
		padding: 5px 10px;
		font-size: 1.4rem;
	}
}

@media only screen and (max-width: 768px) {
	#tickets .wrapper {
		padding: 0 5vw;
	}
	#tickets .selected .wrapper {
		padding: 0 ;
	}
}

.tickets__title {
	font-weight: bold;
	font-size: 2.4rem;
	color: #000;
	line-height: 1.25;
	padding-bottom: 0.25em;
	margin-bottom: 1em;
	border-bottom: #000 1px solid;
}

@media only screen and (max-width: 768px) {
	.tickets__title {
		font-size: 1.8rem;
	}
}

.tickets__desc {
    font-size: 3.6rem;
    font-weight: 800;
    line-height: 1.25;
    margin-bottom: 30px;
}

@media only screen and (max-width: 768px) {
	.tickets__desc {
		font-size: 2.2rem;
    	line-height: 1.5;
    	margin-bottom: 15px;
	}
}

.tickets__title2 {
	font-weight: bold;
	font-size: 3rem;
	text-align: center;
	color: #000;
	position: relative;
	padding-bottom: 20px;
	margin-bottom: 40px;
}

@media only screen and (max-width: 768px) {
	.tickets__title2 {
		font-size: 2rem;
	}
}

.tickets__title2::after {
	content: "";
	width: 100px;
	height: 1px;
	border-bottom: #bc111a 3px solid;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
}

.tickets__exp {
	font-weight: bold;
}

.tickets__table {
	width: 100%;
	margin: 20px 0;
	border-collapse: collapse;
	border-top: #ccc 1px solid;
	border-left: #ccc 1px solid;
}

.tickets__table thead th {
	text-align: center;
	vertical-align: middle;
	padding: 20px 10px;
	border-right: #ccc 1px solid;
	border-bottom: #ccc 1px solid;
	/*white-space : nowrap;*/
	background: #333;
	color: #ccc;
}

@media only screen and (max-width: 768px) {
	.tickets__table thead th {
		font-size: 1.2rem;
		padding: 0px;
	}
	.tickets__table thead th.title {
		width: 40%;
	}
	.tickets__table thead th.general,
	.tickets__table thead th.high,
	.tickets__table thead th.junior {
		width: 20%;
	}
}

.tickets__table thead th.maeuri {
	background: #b41a36;
	color: #fff;
}

.tickets__table thead th.tojitsu {
	background: #03a3d3;
	color: #fff;
}

.tickets__table thead th.tojitsu2 {
	background: #e5f6fb;
	color: #333333;
}

.tickets__table tbody th,
.tickets__table tbody td {
	text-align: left;
	vertical-align: middle;
	padding: 20px 10px;
	border-right: #ccc 1px solid;
	border-bottom: #ccc 1px solid;
}

@media only screen and (max-width: 768px) {
	.tickets__table tbody th,
	.tickets__table tbody td {
		padding: 5px;
		font-size: 1.4rem;
	}
}

.tickets__table tbody th {
	background: #fee6e7;
	line-height: 1.25;
}

@media only screen and (max-width: 768px) {
	.tickets__table tbody th {
		width: auto;
	}
}

.tickets__table tbody th h4 {
	font-size: 2.0rem;
	color: #b0050e;
}

.tickets__table tbody th span.note {
	color: inherit !important;
	background-color: inherit !important;
	padding: 0;
}

.tickets__table tbody th.ippan {
	background: #fefdee;
}

.tickets__table tbody td {
	white-space: nowrap;
	text-align: center;
	font-size: 2rem;
}

@media only screen and (max-width: 768px) {
	.tickets__table tbody td {
		white-space: normal;
		font-size: 1.4rem;
		width: auto;
	}
}

.tickets__table tbody td.sekishu {
	background: #f3f9ec;
	font-size: 1.6rem;
}

@media only screen and (max-width: 768px) {
	.tickets__table tbody td.sekishu {
		font-size: 1.2rem;
		width: 1em;
	}
}

.tickets__table tbody td.maeuri {
	background: #fbf0f5;
}

@media only screen and (max-width: 768px) {
	#tickets p.note {
		padding: 0;
	}
}

.tickets__table tbody td .tickets__mark {
	font-size: 3.6rem;
	line-height: 1.25;
}

.tickets__table tbody td .tickets__text {
	font-size: 1.6rem;
}

@media only screen and (max-width: 768px) {
	.tickets__table tbody td .tickets__mark {
		font-size: 2.2rem;
	}
	.tickets__table tbody td .tickets__text {
		font-size: 1.4rem;
	}
}

.merit {
	background: #bc111a;
	padding: 60px 0;
	margin: 60px 0;
}

@media only screen and (max-width: 768px) {
	.merit {
		padding: 20px 0;
		margin: 30px 0;
	}
}

.merit .wrapper {
	margin: 0 auto;
}

.merit__list {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: stretch;
}

@media only screen and (max-width: 768px) {
	.merit__list {
		display: block;
	}
}

.merit__item {
	width: 32%;
	background: #fff;
	padding: 20px;
}

@media only screen and (max-width: 768px) {
	.merit__item {
		width: auto;
		margin: 10px auto;
	}
}

.merit__item__title {
	color: #fff;
	background: #131313;
	text-align: center;
	padding: 10px;
	font-size: 2.1rem;
	font-weight: bold;
	margin-bottom: 20px;
	border-bottom: #bc111a 3px solid;
}
@media only screen and (max-width: 768px) {
	.merit__item__title {
		margin-bottom: 10px;
	}
}

.merit__item__text {
	font-size: 1.6rem;
	text-align: justify;
	text-justify: inter-ideograph;
}

.merit__item__text__lead {
	font-size: 2.1rem;
	font-weight: bold;
	line-height: 1.25;
	color: #000;
	text-align: center;
}

.merit__item__text p {
	line-height: 1.5;
}

.howto__column {
	padding-bottom: 30px;
}

@media only screen and (max-width: 768px) {
	.howto__column {
		padding: 0 20px 30px;
	}
}

.howto__title {
	font-weight: bold;
	font-size: 1.8rem;
	color: #b0050e;
	margin-bottom: 0.5em;
}

.howto__title a {
	color: #b0050e;
}

.howto__title a:hover {
	text-decoration: none;
}

.howto__item__list {
	margin-bottom: 2em;
	list-style-type: disc;
	list-style-position: outside;
	margin-left: 2em;
}

.howto__item__item {
	font-size: 1.4rem;
}

.tpia {
	margin: 15px 0;
}

.tpia a {
	background: #333;
	border: #333 2px solid;
	color: #fff;
	text-decoration: none;
	font-size: 1.6rem;
	font-weight: 700;
	border-radius: 3px;
	padding: 15px 20px;
	line-height: 1;
	display: inline-block;
	transition: all 0.3s linear;
}

.tpia a:hover {
	background: #fff;
	color: #333;
}

.access {
	line-height: 1;
	width: 100%;
	margin-bottom: 30px;
}

@media only screen and (max-width: 768px) {
	#access .wrapper {
		padding-right: 5vw;
		padding-left: 5vw;
	}
	.access {
		margin-bottom: 15px;
	}
}

.access iframe {
	width: 100%;
}

@media only screen and (max-width: 768px) {
	.access iframe {
		height: 300px;
	}
}

.module__table {
	width: 100%;
	border-collapse: separate;
	background: #fff;
}

.module__table th,
.module__table td {
	border-bottom: 2px solid #eee;
	padding: 20px 30px;
	font-size: 1.6rem;
}

@media only screen and (max-width: 768px) {
	.module__table th,
	.module__table td {
		padding: 10px 20px;
	}
}

.module__table th {
	text-align: left;
	width: 20%;
	padding-right: 5px;
	padding-left: 5px;
	border-bottom: 2px solid #bc111a;
	color: #000;
	color: #bc111a;
	text-align: center;
	font-weight: bolder;
}

@media only screen and (max-width: 768px) {
	.module__table th {
		width: 25%;
	}
}

#loading {
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	background: #fff;
}

#loading .loadIcon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size: 5rem;
	color: #24C479;
}

#loading .loadIcon img {
	max-width: 100%;
	height: auto;
}

/* online */
.online__header__shoulder {
	font-size: 3.6rem;
	color: #333;
	font-weight: 700;
	line-height: 1;
	margin-bottom: 20px;
}
@media only screen and (max-width: 768px) {
	.online__header__shoulder {
		margin-bottom: 10px;
		font-size: 2.2rem;
	}
}

.online__header__title {
	font-size: 4.8rem;
	color: #b0050e;
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 30px;
}

@media only screen and (max-width: 768px) {
	.online__header__title {
		font-size: 3rem;
	}
}

.online__subtitle {
	font-weight: bold;
	font-size: 4.8rem;
	text-align: center;
	color: #000;
	position: relative;
	padding-bottom: 20px;
	margin-bottom: 40px;
	line-height: 1.5
}

@media only screen and (max-width: 768px) {
	.online__subtitle {
		font-size: 3rem;
	}
}

.online__subtitle::after {
	content: "";
	width: 100px;
	height: 1px;
	border-bottom: #bc111a 3px solid;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
}

.online__movie__list__title {
	font-weight: bold;
	font-size: 3rem;
	text-align: center;
	color: #000;
	position: relative;
	margin-top: 30px;
}
@media only screen and (max-width: 768px) {
	.online__movie__list__title {
		font-size: 2rem;
	}
}

.online__header__text {
	line-height: 1.75;
}
@media only screen and (max-width: 768px) {
	.online__header__text {
		padding-left: 3vw;
		padding-right: 3vw;
	}
}

.online__table {
	width: 100%;
	margin: 20px 0;
	border-collapse: collapse;
	border-top: #ccc 1px solid;
	border-left: #ccc 1px solid;
}

.online__table thead th {
	text-align: center;
	vertical-align: middle;
	padding: 20px 10px;
	border-right: #ccc 1px solid;
	border-bottom: #ccc 1px solid;
	/*white-space : nowrap;*/
	background: #333;
	color: #ccc;
}
.online__table thead th.title {
	width: 40%;
}
.online__table thead th.desc {
	width: 60%;
}
.online__table thead th h4 {
	font-size: 2.0rem;
	color: #b0050e;
}
.online__table thead .online__lineup__title th:not(:first-child) {
	color: inherit !important;
	background-color: #fee6e7;
}
@media only screen and (max-width: 768px) {
	.online__table thead th {
		font-size: 1.2rem;
		padding: 0px;
	}
}

.online__table tbody th,
.online__table tbody td {
	text-align: left;
	vertical-align: middle;
	padding: 20px 10px;
	border-right: #ccc 1px solid;
	border-bottom: #ccc 1px solid;
}

@media only screen and (max-width: 768px) {
	.online__table tbody th,
	.online__table tbody td {
		padding: 5px;
		font-size: 1.4rem;
	}
}

.online__table tbody th {
	line-height: 1.25;
}

@media only screen and (max-width: 768px) {
	.online__table tbody th {
		width: auto;
	}
}

.online__table tbody th h4 {
	font-size: 2.0rem;
	color: #b0050e;
}

.online__table tbody th span.note {
	color: inherit !important;
	background-color: inherit !important;
	padding: 0;
}

.online__table tbody td {
	white-space: nowrap;
	font-size: 2rem;
}

@media only screen and (max-width: 768px) {
	.online__table tbody td {
		white-space: normal;
		font-size: 1.4rem;
		width: auto;
	}
}

@media only screen and (max-width: 768px) {
	#online p.note {
		padding: 0;
	}
}

.online__table tbody td.online__price {
	font-weight: bold;
	text-align: center;
}

.online__table tbody td span.note {
	font-size: 1.4rem;
	font-weight: normal;
	color: #b0050e !important;
}

@media only screen and (max-width: 768px) {
	.online__table tbody td span.note {
		font-size: 1.0rem;
		padding: 0;
	}
}

.online__method__title {
	font-size: 2rem;
	font-weight: 700;
	color: #000;
	line-height: 1.25;
	margin-bottom: 10px;
}

.online__method__text {
	margin-bottom: 20px;
}

.online__movie__list {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-o-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-top: 20px;
	margin-bottom: 50px;
}
.online__movie__list a {
	position: relative;
	display: block;
	padding-top: 60%;
	background-repeat: no-repeat;
	background-position: 50%;
	-webkit-background-size: cover;
	background-size: cover;
	text-decoration: none;
}
.online__movie__list a > span {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	-ms-align-items: flex-end;
	align-items: flex-end;
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	padding: 10px;
	color: #fff;
	font-weight: bold;
	line-height: 1.4;
	font-size: 1.6rem;
	background-color: rgba(0,0,0,.6);
	opacity: 0;
}

@media screen and (min-width: 769px), print {
	.online__movie__list {
		margin-left: -10px;
	}
	.online__movie__list > li {
		width: 16.66%;
		padding-left: 10px;
	}
	.online__movie__list > li:nth-child(6) ~ * {
		margin-top: 10px;
	}
	online__movie__list a > span {
		-webkit-transition: opacity .3s;
		-o-transition: opacity .3s;
		transition: opacity .3s;
	}
	.online__movie__list a:hover > span {
		opacity: 1;
	}
}
@media screen and (max-width: 768px) {
	.online__movie__list {
		margin-left: -5px;
		margin-top: 20px;
	}
	.online__movie__list > li {
		width: 33.33%;
		padding-left: 5px;
	}
	.online__movie__list > li:nth-child(3) ~ * {
		margin-top: 5px;
	}
	.online__movie__list a > span {
		display: none;
	}
}

@media screen and (min-width: 769px), print {
	.online__movie__lineup {
		width: 50%;
		margin: 0 auto;
	}
	.online__movie__lineup .online__movie__list > li {
		width: 33.33%;
	}
}

.online__movie__lineup .online__movie__list {
	margin-top: 50px;
	margin-bottom: 0px;
}
