/*---------------*/
/*   basic       */
/*---------------*/
header .navbar-brand { font-size: 1.2rem }
.page-header{ font-size: 1.5em;}
#entry-confirm-screen h4,#entry-complete-screen h4,#payment-screen h4{font-size:1.2em;}
body {
@import url(//fonts.googleapis.com/earlyaccess/notosansjapanese.css);
	font-family: "Noto Sans JP","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","Meiryo UI","メイリオ",Meiryo,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
	font-size: 15px;
	letter-spacing: 0.04em; 
	background: #F4F4F4;
	color: #555;
}
main{padding-bottom: 100px;}
#event-screen .container{
  max-width: 800px;
}
#footer {
    margin-top: 30px;
    padding: 10px 0;
    text-align: center;
    background: #ddd;
}
#footer .copyright{font-size: 13px;
margin: 10px 0;}

#event-thumbnail img {
    display: block;
    width: 100%;
    height: 360px;
    object-fit: cover;
}

.message {
	background: #f2dede;
	color: #d44950;
	padding: 15px 20px;
	margin: 20px 0;
	border-radius: 5px;
	-webkit-border-radius: 5px;
}
.error-message{
	font-size: 85%;
	color:#ff2461;
	padding:5px;
	margin-top: .5em;
    border-radius: 3px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    background: #FFF;
    box-shadow: none;
    -moz-box-shadow: none;
    -webkit-box-shadow: none;

}
.box-notice {
	color: #ffffff;
	background: #e94e77;
	text-align: center;
}
.box-success{
	color: #ffffff;
	background: #8EC0E4;
	text-align: center;
}
.text-deadline {
	color: #e94e77;
}
.box-remarks p{ margin-bottom: 0;}
.box-item-info {
	background:#ffffff;
}
.card-header{border-radius: 0.1rem !important;}
/*---------------*/
/*  seat-select  */
/*---------------*/
#seat-info,#companion-info,#user-info,#payment-info { margin-bottom: 20px;}
.seat-select input[type=radio]{
  display: none;
}
.seat-select{
	margin: 0 0px 5px 0;
    padding: 0px;
    border-radius: 3px;
    background-color: #ffffff;
}
.seat-select .radio{

    display: block;
    padding: 15px 15px 15px 45px;
    margin: 0;
    border: 1px solid #ddd;

}
.seat-select .unit-price{
	float: right;
}
.ch-seat-selected{font-weight:bold;}
#companion-info th,#companion-info td{ border-bottom: none;}
/* 
#event-screen table.active{
	background: #fff;
	border: 1px solid #ddd;
}
#event-screen .table th{ padding: 15px; border-bottom: 1px solid #DDD;}
#event-screen .table td{ border-bottom: 1px solid #DDD;} */
textarea.privacy{ width:100%; height: 300px; border: 1px solid #ccc; font-size: x-small;padding: 15px; background: #f5f5f5;}
/*---------------*/
/*  table       */
/*---------------*/
.table{color: #555; background-color: #ffffff;}
.table > thead > tr > th, .table > tbody > tr > th, .table > tfoot > tr > th, .table > thead > tr > td, .table > tbody > tr > td, .table > tfoot > tr > td{
	border-top: none;
	border-bottom: 1px solid #DDD;
	min-height: 25px;
	vertical-align: middle;
	padding: 15px 8px;
}
#entry-confirm-screen td,#entry-complete-screen td,
#payment-screen td{ font-weight: bold;}
.loggedin-col{ font-weight: bold;}
/*---------------*/
/*  Description  */
/*---------------*/
#bankDesc p{ line-height: 180%; text-align: center;}
.item-desc{font-size: 0.8em;color: #666; margin-top:8px;}
/*---------------*/
/*  btn          */
/*---------------*/
.payBtn {
    text-align: center;
    margin: 20px auto 60px;
}
.payBtn .btn-main, .payBtn .btn-main:focus, .payBtn .btn-main:focus-visible {
	border-radius: 0.5rem;
    padding: 0.8rem 1.5rem;
    font-size: 1rem;
}
.btn-main {
	color: #fff !important;
	background-color: #1B7DC1;
	border-color: #1B7DC1;
}
.btn-main:focus,
.btn-main.focus {

}
.btn-main:hover {
	background-color: #1B7DC1;
	border-color: #1B7DC1;
	color: #fff;
	opacity: 0.8;
}
.btn-main:active,
.btn-main.active,
.open > .dropdown-toggle.btn-main {
  color: #fff;
}
.btn-main:active:hover,
.btn-main.active:hover,
.open > .dropdown-toggle.btn-main:hover,
.btn-main:active:focus,
.btn-main.active:focus,
.open > .dropdown-toggle.btn-main:focus,
.btn-main:active.focus,
.btn-main.active.focus,
.open > .dropdown-toggle.btn-main.focus {
  color: #fff;

}
.btn-main:active,
.btn-main.active,
.open > .dropdown-toggle.btn-main {
  background-image: none;
}
.btn-main.disabled,
.btn-main[disabled],
fieldset[disabled] .btn-main,
.btn-main.disabled:hover,
.btn-main[disabled]:hover,
fieldset[disabled] .btn-main:hover,
.btn-main.disabled:focus,
.btn-main[disabled]:focus,
fieldset[disabled] .btn-main:focus,
.btn-main.disabled.focus,
.btn-main[disabled].focus,
fieldset[disabled] .btn-main.focus,
.btn-main.disabled:active,
.btn-main[disabled]:active,
fieldset[disabled] .btn-main:active,
.btn-main.disabled.active,
.btn-main[disabled].active,
fieldset[disabled] .btn-main.active {
  background-color: #1B7DC1;
  border-color: #1B7DC1;
}
.btn-main .badge {
  color: #1B7DC1;
  background-color: #fff;
}
/*---------------*/
/*  form         */
/*---------------*/
.form-control:disabled, .dataTable-input:disabled, .form-control[readonly], [readonly].dataTable-input {
    background-color: #e0e5ec;
    opacity: 1;
}
.ff_header{ font-size: 1rem;margin-top: 1.5rem; margin-bottom: 0; background: #f6f7f9; padding: 10px 7px;}

#confirm-screen td, .bank-transfer-info td{font-weight: bold;}
th{ font-weight: normal; }
.text input, .input select, .tel input, .cardInputForm input, .cardInputForm select {
    border: 1px solid #CCC;
    height: 46px;
    outline: 0px;
    outline-offset: 0px;
	font-weight: bold;
}
.label-warning {
	color: #fff;
    background-color: #f06d6d;
    border-radius: 1.6em;
    padding: 0.4em 0.8em;
    margin-left: 10px;
    font-weight: lighter !important;
    font-size: 0.8rem;
    line-height: 1;
}
.box-payway label, .card-select label{ display:block; cursor: pointer;}
.box-payway input[type=radio], .card-select input[type=radio], .radiobtn input[type=radio] {
	position:relative;
	margin-left: 3px;
    top: 4px;
    width: 20px;
    height: 20px;
    -moz-transform: scale(1.0);
    -webkit-transform: scale(1.0);
    transform: scale(1.0);
}
.input-head {
    margin-bottom: 4px;
    text-align: left;
    font-size: 12px;
    color: darkgray;
    margin-top: 10px;
}
.panel-heading h3{margin-top: 10px;}
.form-group p{ margin: 8px 0;}
.form-control{border-radius: 2px;box-shadow:none;}
.text input, .input select, .tel input, .cardInputForm input {
    border: 1px solid #DDD;
    height: 46px;
    outline: 0px;
    outline-offset: 0px;
}
.label-warning {
    background-color: #FF2461;
    border-radius: 1.6em;
    padding: 0.4em 0.8em;
    margin-left: 10px;
    font-weight: lighter !important;
    font-size: 0.8rem;
    line-height: 1;
}
a.accordion-toggle{ color:#666;}
a:hover.accordion-toggle,a:focus.accordion-toggle{ text-decoration: none; }

label{ 
	font-weight: normal;
	margin-right: 10px;
}
input[type=radio], input[type=checkbox] {
	margin-right: 5px;
}
/*---------------*/
/*   #checkbox  */
/*---------------*/
.chkcheckbox label{ padding-left: 5px; }
.chkcheckbox input[type=checkbox] {
	margin-left: 3px;
	position: relative;
    top: 4px;
	width:			20px;
	height:			20px;
	-moz-transform:		scale(1.0);
	-webkit-transform:	scale(1.0);
	transform:		scale(1.0);
}
.checkbox label{ padding-left: 33px; }
.checkbox input[type=checkbox]{
	margin-left: -27px;
	margin-top: 0px;
	position: relative;
    top: 4px;
	width:			20px;
	height:			20px;
	-moz-transform:		scale(1.0);
	-webkit-transform:	scale(1.0);
	transform:		scale(1.0);
}

/*---------------*/
/*   #step_bar   */
/*---------------*/
#step_bar_box {
	padding-right: 0;
}
.step_bar {
	margin: 0;
	padding: 15px 0;
	width: 100%;
	background: #f6f6f6;
	border: 1px solid #ddd;
	margin: 20px auto;
	text-align: center;
}
.step_bar li {
	position: relative;
	background: #eee;
	color: #444;
	padding: 10px;
	width: 29%;
	display: inline-block;
	vertical-align: middle;
	font-weight: bold;
}
.step_bar li.current {
	background: #aaa;
	color: #fff;
}
.step_bar li:not(:last-child):after {
	left: 100%;
	top: 50%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(27, 125, 193, 0);
	border-left-color: #eee;
	border-width: 10px;
	margin-top: -10px;
}
.step_bar li.current:after {
	border-left-color: #aaa;

}
.step_bar li:nth-child(2) {
	margin-left: 8px;
	margin-right: 8px;
}
.step_bar li small {
    font-size: 80%;
}

/*---------------*/
/*   #paymentAarea   */
/*---------------*/
#IpsInputForm,#bankDesc{ border: 1px solid #ddd;border-radius: 3px; padding:15px;margin-bottom: 20px;}
.card-select, .box-border{
	margin: 0 0px 5px 0;
    padding: 15px 15px 15px 15px;
    border-radius: 3px;
    background-color: #f6f7f8;
	margin-top: 10px;
}

/*----------------------------
	responsive
------------------------------*/
@media only screen and (max-width:480px){
    #entry-screen th,#entry-screen td,
	#payment-screen th,#payment-screen td,
	#entry-confirm-screen th, #entry-confirm-screen td,
	#entry-complete-screen th, #entry-complete-screen td{
		width: 100%;
		display: block !important;
    }
	#entry-screen th, #entry-confirm-screen th,#entry-complete-screen th,
	#payment-screen th
	{ 
		background: #f6f7f8; font-size: 0.8em; padding: 5px 10px 4px !important;
	}
	.card-body{ padding: 0;}
	/* .table{ margin-bottom: 0; } */
	.label-warning {padding: 0.3em 0.6em;font-size: 0.7rem;}
	.ff_header{ margin-top:0; background: #f6f7f9; border-bottom: 1px solid #ddd;}

}
/* 320px以下 */
@media (max-width: 390px) {
	.step_bar li {
		width: 30%;
	}
	}