@charset "utf-8";
/*================================================
CSS for ヴィジュアルページ
下階層ページ向けCSS
2015 atali.inc(telime)
This style is released under the MIT License
use "Twitter Bootstrap v3.0.2"
================================================*/
.content .container h2.title{ color:#002e33; }
#page-visual {
	background: #2b4484;
	text-align: center;
}
s #page-visual .main_title {
	max-width: 80%;
	margin: 10px auto;
}
#page-visual .keirinjp {
	position: absolute;
}
h1,h2,h3,h4,h5{
    color: #330A0F;
}
/* inner vivid */
.row>.col5 {
	display: block;
	float: left;
	padding: 0 6px;
	position: relative;
	width: 20%;
	z-index: 2;
}
.inner-vivid {
	-webkit-background-size: 20px 20px;
	background-size: 20px 20px;
	background-color: #3159bd;
}
.inner-vivid .container>.body {
	color: #330A0F;
	background: transparent none;
	padding: 0;
	position: relative;
	z-index: 2;
}
.inner-vivid .container>.body>h3, .inner-vivid .container>.body .vivid-title {
	color: #330A0F;
	margin: 0;
	padding: 8px;
	letter-spacing: 0.2em;
	font-weight: bold;
}
.inner-vivid .container>.body>h3 {
	font-size: 1.55em;
    border-bottom: 3px solid #330A0F;
}
.inner-vivid .container>.body>h3#history01 {
    width: 580px;
}
.inner-vivid .container>.body>h3#history02 {
	width: 940px;
}
.inner-vivid .container>.body>h3#history03 {
	width: 580px;
}
.inner-vivid .container>.body>h3::before{
	content: "・"
}
.inner-vivid .container>.body>h4 {
	font-size: 1.2em;
	margin: 30px 0 0 0;
	padding: 0;
}
.inner-vivid .container>.body .btn{
	color: #fff;
}
.inner-vivid .container>.body .vivid-title {
	display: inline-block;
	padding: 10px 15px;
}
.inner-vivid .menu .button {
    display: block;
	background: linear-gradient(to left,#707ec5 40%,rgba(254,254,254,1) 60%);
    background-size: 1200px auto;
    background-repeat: no-repeat;
    background-position: right;
    border: 3px solid #fefefe;
	color: #fff;
	font-size: 1.5em;
	padding: 0.7em 0 0.8em 0;
    margin-bottom: 4px;
	text-decoration: none;
	position: relative;
    border-radius: 8px;
    transition: .5s cubic-bezier(0.45, 0, 0.55, 1);
}
.inner-vivid .menu .button:hover {
	background-position: left;
    border: 3px solid #707ec5;
    color: #707ec5;
    transition: .5s cubic-bezier(0.45, 0, 0.55, 1);
}

/* vivid-bundle */
.body>.vivid-bundle {
	margin-top: 32px;
	overflow: hidden;
	color: #330A0F;
    border: 2px solid #330A0F;
	font-size: 1.2em;
}
.body>h1+.vivid-bundle, .body>h2+.vivid-bundle {
	border-top: 0 none;
}
.body>.vivid-bundle>header {
	font-weight: bold;
	font-size: 1.05em;
	padding: 5px;
	background: #E95B9A url(../img/bg_sec7_1.png) repeat scroll 0 0;
	-webkit-background-size: 8px 8px;
	background-size: 8px 8px;
	display: table;
	table-layout: fixed;
	width: 100%;
}
.body>.vivid-bundle>header>* {
	line-height: 1;
	height: 2em;
	padding: 0 10px;
	margin: 0;
	vertical-align: middle;
	display: table-cell;
}
.body>.vivid-bundle>header .place, .body>.vivid-bundle>header .date {
	font-size: 0.98em;
	border-left: 1px solid #fff;
}
.body>.vivid-bundle>.body {
	margin: 15px;
}
.body>.vivid-bundle>.body p {
	line-height: 1.4;
}
.body>.vivid-bundle>.body .h4 {
	font-size: 1.2em;
	font-weight: bold;
}
.inner-vivid .menu {
	margin-top: 30px;
	margin-bottom: 60px;
}

/* dl */
/*
.vivid-bundle>dl.row {
	border-top: 1px solid #fff;
	margin: 0;
	font-size: 1.4em;
	font-weight: bold;
}
.vivid-bundle>dl.row {
	font-size: 1.4em;
    padding: 4px 16px;
}
.vivid-bundle>dl.row:first-child {
	border-top: 0 none;
    padding: 0;
}
.vivid-bundle>dl.row:nth-child(2) {
	padding-top: 24px;
}
.vivid-bundle>dl.row:last-child {
	padding-bottom: 24px;
}
.vivid-bundle>dl.row>dt {
	border-right: none;
}
*/
.vivid-date {
	overflow: hidden;
    margin-bottom: 20px;
}
.vivid-date>h1 {
	line-height: 1.5;
	margin: 0;
	padding: 5px 15px;
}
.vivid-date>.body {
	padding: 15px;
}

.vivid-bundle.for-pc .col-6 {
	font-size: 1.4em;
    padding: 4px 16px;
}

/*image*/
.vivid-bundle .image-bundle {
	text-align:center;
}
.vivid-bundle .image-bundle>img, .vivid-bundle .image-bundle>span {
	display: inline-block;
	width: 100%;
	margin-right: 3px;
	margin-bottom: 5px;
}
/* ul */
.content ul.points {
	list-style-type: none;
}
.content ul.points li {
	text-indent: -1em;
	line-height: 1.6;
	margin: 0.3em 0;
}
.sns>.container{
    padding: 0;
}
.sns>.container>div{
    margin-bottom: 12px;
}
.sns>.container>div>a:hover,#page-links .flags a:hover{
    opacity: 0.8;
}
.pc {display: block !important;}
.sp {display: none !important;}

/* sabpage */
.sabpage{
    margin-bottom: 48px!important;
}

.sabpage h3{
    border: none!important;
    background-color: #0a2633;
    color: #fff!important;
    text-align: center;
    padding: 16px 0!important;
}

.sabpage h3::before{
    display: none;
}

.sabpage h4{
    font-size: 1.5em;
    border-bottom: 3px solid #707ec5;
    padding-bottom: 8px;
    width: 500px;
}

.sabpage h4::before{
    content: "・"
}

.sabpage .vivid-bundle{
    margin-top: 0!important;
    border: none!important;
    background-color: #ffffff;
    color: #330a0f;
}

.sabpage .vivid-bundle .row,
.sabpage .vivid-bundle p{
    margin: 12px 0;
}

.sabpage .btn-primary{
    background-color: #727ec3;
    border: 2px solid #e2eff7;
    border-radius: 10px;
}

.sabpage .btn-primary:hover{
    background-color: #e2eff7;
    border: 2px solid #727ec3;
    color: #727ec3!important;
}

.sabpage .btn-danger:hover{
    background-color: #727ec3!important;
}

.sabpage.seat h4{
    width: 100%;
}

.sabpage.seat h4::before{
    display: none;
}

.sabpage.seat .row{
    margin-bottom: 24px;
}

.sabpage table{
	border-collapse:separate;
	border-spacing:0px 6px;
}

#event_stage table{
	margin-top: 12px;
}

.sabpage table.text{
	margin-bottom: 0!important;
}

.sabpage table td,.sabpage table th{
	vertical-align: top;
}

.sabtext{
	margin-bottom: 0!important;
}

/*================================================
 Media Query
 デバイスの幅毎にCSS値変更
================================================*/
@media (min-width: 768px) {
	#page-visual {
		text-align: left;
		margin-bottom: 80px;
		background-color: #3859bb;
	}
	#page-visual .main_title {
		margin-left: 80px;
	}
	#page-visual .keirinjp {
		bottom: 0;
		right: 2px;
	}
	.sabpage{
		padding-top: 60px!important;
		margin-top: -60px!important;
	}
	.mt70{margin-top: 70px;}
}
@media (min-width: 768px) and (max-width: 991px) {
	.inner-vivid .menu .button {font-size: 1.2em;}
	.vivid-bundle>dl.row {font-size: 1.2em;}
}
@media (max-width: 767px) {
	#page-visual {
		background-size: auto 100%;
	}
	#page-visual .keirinjp img {
		width: 45px;
		height: auto;
	}
	#page-visual .keirinjp {
		top: 0;
		left: 0;
	}
	.row>.col5 {
		display: block;
		float: none;
		padding: 0 10px;
		width: 100%;
	}
	.inner-vivid .container>.body>h3 {
		margin: 0;
		padding: 5px;
		font-size: 1.4em;
        line-height: 1.3;
	}
	.inner-vivid .container {
		padding-left: 10px;
		padding-right: 10px;
	}
	.inner-vivid .container>.row {
		margin-left: -10px;
		margin-right: -10px;
	}
	.inner-vivid .container>.body {
		margin: 30px 0;
	}
	.inner-vivid .container>.body>h2 {
		text-align: center;
		font-size: 1.0em;
	}
	.inner-vivid .menu {
		font-size: 0.8em;
		margin-bottom: 0;
	}
	.body>.vivid-bundle>header {
		padding: 15px;
		display: block;
		width: auto;
		background: transparent none;
	}
	.body>.vivid-bundle>header>* {
		line-height: 1.2;
		height: auto;
		width: auto!important;
		padding: 0;
		margin: 0;
		display: block;
	}
	.body>.vivid-bundle>header .place, .body>.vivid-bundle>header .date {
		border: 0 none;
	}
	.body>.vivid-bundle>.body {
		margin: 0 15px 15px;
		padding-top: 15px;
		border-top: 1px solid #fff;
	}
	.body>.vivid-bundle>.body .h4 {
		font-size: 1em;
	}
	.vivid-bundle>dl.row {
		font-size: 1.4em;
	}
	.vivid-bundle>dl.row>dt, .vivid-bundle>dl.row>dd {
		padding: 5px;
		border: 0 none;
	}
	.vivid-bundle>dl.row>dd {
		font-size: 0.9em;
	}
	.content .vivid-date h1 {
		font-size: 0.95em;
	}
	.body>article.vivid-bundle:nth-child(2n) .vivid-date>h1, .body>article.vivid-bundle:nth-child(2n+1) .vivid-date>.body {
		background: #fff;
		-webkit-background-image: 8px 8px;
		background-image: 8px 8px;
	}
	.body>article.vivid-bundle:nth-child(2n+1) .vivid-date {
		background: #e95b9a url("../img/bg_sec7_1.png") repeat scroll 0 0;
		-webkit-background-image: 8px 8px;
		background-image: 8px 8px;
	}
	.vivid-date>.body {
		font-size: 0.95em;
		padding: 10px 15px 15px 15px;
	}
	.vivid-bundle .image-bundle>img, .vivid-bundle .image-bundle>span {
		margin-right: 3px;
		margin-bottom: 5px;
	}
    .sabpage.seat h4{
        font-size: 1.2em;
    }
}
@media screen and (min-width: 1000px) {
	.br-pc {display: block;}
	.br-sp {display: none;}
}
@media screen and (max-width: 1000px) {
	.br-pc {display: none;}
	.br-sp {display: block;}
    .inner-vivid .container>.body>h3{
        width: 100%!important;
    }
    .sabpage h4{
        width: 100%!important;
    }
}
/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media only screen and (max-width: 750px) {
	.pc {display: none !important;}
	.sp {display: block !important;}
}

/* テキスト調整&フォントサイズ */

.text{
    text-indent: 1.0em;
    margin: 0px;
    font-weight: bold;
}

.fw-regular{ font-weight: 500;}

.text-indent{ text-indent: 1em;}
.text-noindent{text-indent: 0;}

@media (min-width : 768px) {
	.text{ font-size: 1.3em!important;}
}

/*サブタイトル*/

.history_why{
    width: 100%;
    min-width: 720px;
    background-color: #330A0F;
    color: #fff!important;
    font-weight: bold; 
    margin: 10px auto 0;
    text-align: center;
}

.vivid-bundle .history_why{
    margin: 0;
    font-size: 1.0em;
    padding: 12px 0!important;
}

.history_why h4{
    font-size: 1.8em; 
    padding: 8px 0;
    color: #fff!important;
}

@media (max-width : 767px) {
	.history_why{
        width: 100%;
        min-width: 100%;
    }
    
    .history_why h4{
        font-size: 1.5em; 
        padding: 8px 0;
        margin: 12px auto 0;
        line-height: 1.3;
    }
}

#inner-events .text,#inner-service .text{
    text-indent: 0;
    margin-bottom: 20px;
}

/*余白調整*/

.m5{margin: 5px;}
.m10{margin: 10px;}
.m15{margin: 15px;}
.m20{margin: 20px;}
.m30{margin: 30px;}

.mt5{margin-top: 5px;}
.mt10{margin-top: 10px;}
.mt15{margin-top: 15px;}
.mt20{margin-top: 20px;}
.mt30{margin-top: 30px;}

.p15{padding: 15px;}
.fs-1{font-size: 1em;}
.fs-2{font-size: 1.2em;}
.fs-3{font-size: 1.4em;}
.fs-4{font-size: 1.6em;}

/*スマホで見た時のヘッダー画像*/
.visual  img{
	width:100%;
}

.border-event {
	border: 3px dashed #727ec3;
	border-radius: 15px;
}

@media screen and (min-width: 768px) {
	.outline-blur {
		height: 100%; /* 任意サイズ */
	/* 左右だけフェードするマスク */
	-webkit-mask-image: linear-gradient(to right, 
		transparent 0%, 
		black 2%, 
		black 98%, 
		transparent 100%);
		
	mask-image: linear-gradient(to right, 
		transparent 0%, 
		black 2%, 
		black 98%, 
		transparent 100%);
	
	mask-mode: alpha;
	-webkit-mask-mode: alpha;
	}
}