@charset "shift_jis";
/*------------------------------
	index.css
------------------------------*/
/*	global
------------------------------*/
.copyright > div {
	text-align: center;
}
.copyright small {
	float: none;
}
.interBooking950 .mdl_lead {
	display: none;
}
.inText.withIcon img {
	vertical-align: middle;
}
.moduleUnit {
	margin: 40px 0;
}
/* button */
.btnWT{
	display:inline-block;
	color:#0f0f69;
	text-decoration:none;
	text-align:center;
	padding:7px 20px 5px!important;
	background-image:none!important;
}
.btnWT{
	background-color:#fff;
	border:1px solid #d0d0d0;
}
.btnWT:link{
	color:#0f0f69;
	text-decoration:none;
}
.btnWT:visited{
	color:#0f0f69;
}
.btnWT:hover,.btnWT:focus{
	color:#cc0000;
	text-decoration:underline;
}
.btnWT:hover span,.btnWT:focus span{
	text-decoration:underline;
	cursor:pointer;
}
.btnWT span{
	padding-left:10px;
	display:inline-block;
	line-height:24px;
}
.btnWT span b{
	color:#cc0000;
}
.btnWT.iconOtherImg span{
	vertical-align:middle;
	padding-left:0;
	background:none;
}
.btnWT.iconOtherImg .extIcon{
	vertical-align:middle;
	margin-right:5px;
}

/*	structure
------------------------------*/
/*-- mainVis --*/
.mainVis {
	width: 100%;
	height: 700px;
	background-color: #000;
	position: relative;
	overflow: hidden;
}
.mainVisBg {
	background: url(../img/pic_main.jpg) repeat 0 0;
	height: 700px;
}
.mainVisBg:after {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background: url(../img/bg_texture_main.png) repeat 0 0;
	position: absolute;
	top: 0;
	left: 0;
}
.mainVisInr {
	width: 950px;
	margin: 0 auto;
	position: relative;
}
.mainVisHead {
	position: relative;
	text-align: center;
	padding-top: 85px;
	z-index: 3;
}

/*-- pageNav --*/
.pageNav {
	background-color: #000;
}

.pageNavItems {
	display: table;
	vertical-align: top;
	width: 950px;
	margin: 0 auto;
}
.pageNavItem {
	display: table-cell;
	width: 475px;
	height: 100px;
	vertical-align:middle;
	text-align: center;
	background: url(../img/bg_nav_side.png) left top no-repeat;
}
.pageNavItem > .inr {
	display: inline-block;
	font-size: 20px;
	color: #fff;
	font-weight: bold;
	background: url(../img/bg_nav_anchor.png) right center no-repeat;
	padding-right: 22px;
	transition: all ease 0.2s;
}
.pageNavItem > a:hover,
.pageNavItem > a:focus {
	color: #bb2228;
	background-image: url(../img/bg_nav_anchor_on.png);
}

/*-- section --*/
.sectionWrap {
	padding-bottom: 120px;
	background-color: #000;
	position: relative;
}
.sectionWrap:after {
	content: "";
	display: block;
	width: 100%;
	height: 120px;
	background: url(../img/bg_texture_head.gif) repeat 0 0;
	position: absolute;
	bottom: 0;
	left: 0;
}
.section img {
	vertical-align: top;
}
.sectionHead {
	background: url(../img/bg_texture_head.gif) repeat 0 0;
	position: relative;
}
.sectionHead:before {
	content: "";
	display: block;
	width: 50%;
	height: 100%;
	background-color: #fff;
	position: absolute;
	right: 50%;
	margin-right: 475px;
}
.sectionHead > .heading {
	width: 950px;
	margin: 0 auto;
	position: relative;
}
.sectionBody {
	width: 950px;
	margin: 0 auto;
	padding-bottom: 120px;
}
.sectionBody > .content {
	padding: 40px 0;
}

/*	layout
------------------------------*/
/*-- photo --*/
.section.photo {
}
.photo .photoBoxes,
.photo .inrBoxes {
	letter-spacing: -0.4em;
	margin: -10px 0 0 -10px;
}
.photo .photoBoxes + .photoBoxes {
	margin-top: 0;
}
.photo .photoBox,
.photo .inrBox {
	letter-spacing: normal;
	display: inline-block;
	vertical-align: top;
	margin: 10px 0 0 10px;
	overflow: hidden;
}
.photo .photoBox img,
.photo .inrBox img {
	width: 100%;
	height: 471px;
}
.photo .photoBox > .inr,
.photo .inrBox > .inr {
	display: block;
	position: relative;
}
.photo .photoBox .grayscale,
.photo .inrBox .grayscale {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	transition: opacity ease 0.4s;
}
.photo .photoBox > .inr:hover .grayscale,
.photo .photoBox > .inr:focus .grayscale,
.photo .inrBox > .inr:hover .grayscale,
.photo .inrBox > .inr:focus .grayscale{
	filter: alpha(opacity=0);
	opacity: 0;
}
.photo .photoBoxes { width: 960px; }
.photo .photoBox { width: 470px; }
.photo .inrBoxes { width: 480px; }
.photo .inrBox,.photo .inrBox img{ width: 230px; height: 230px;}

/*-- schedule --*/
.section.schedule {
	background: url(../img/bg_schedule.jpg) no-repeat center bottom;
	background-size: cover;
}
.section.schedule .sectionBody {
}

.schedule .routeBox + .routeBox {
	margin-top: 50px;
}
.schedule .routeBox .heading {
	height: 32px;
	line-height: 32px;
	padding-left: 10px;
	border-left: 4px solid #000;
	font-size: 18px;
}
.schedule .content .leadTxt{
	font-size: 26px;
}
.schedule .routeBox .heading.inIcon {
	padding-left: 0;
	border: none;
}
.schedule .routeBox .heading.inIcon .icon_new {
	display: inline-block;
	vertical-align: top;
	height: 32px;
	line-height: 32px;
	margin-right: 10px;
	padding: 0 11px;
	background-color: #d61920;
	color: #fff;
	font-size: 15px;
	font-weight: bold;
}
.schedule .routeTbl {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0 4px;
}
.schedule .routeTbl th,
.schedule .routeTbl td {
	box-sizing: border-box;
	vertical-align: middle;
	text-align: center;
	line-height: 1.3;
}
.schedule .routeTbl thead th,
.schedule .routeTbl thead td {
	height: 28px;
	background-color: #000;
	color: #fff;
}
.schedule .routeTbl tbody td {
	height: 60px;
	padding: 0 20px;
	background-color: #fff;
}
.schedule .routeTbl tbody td.cell_arw {
	background: url(../img/icon_schedule_plane.png) no-repeat center center #fff;
}
.schedule .routeTbl col.col_name { width: 140px; }
.schedule .routeTbl col.col_date { width: 160px; }
.schedule .routeTbl col.col_model { width: 140px; }
.schedule .routeTbl col.col_dept { width: 160px; }
.schedule .routeTbl col.col_arw { width: 50px; }
.schedule .routeTbl col.col_arrv { width: 160px; }

/*-- service --*/
.section.service {
}
.section.service .sectionHead:before {
	background-color: #000;
}
.section.service .sectionBody {
	padding: 50px 0 0;
}

.service .classNav {
}
.service .classNavItems {
	display: table;
	width: 950px;
}
.service .classNavItem {
	display: table-cell;
	vertical-align: top;
}
.service .classNavItem .wrap {
	display: table;
	table-layout: fixed;
	width: 100%;
	text-decoration: none;
}
.service .classNavItem .icon {
	display: table-cell;
	width: 68px;
	opacity: 0.7;
	transition: opacity ease 0.2s;
}
.service .classNavItem .inr {
	display: table-cell;
	vertical-align: middle;
	padding: 0 5px 0 10px;
	background: url(../img/bg_service_dot.png) repeat-y right top #000;
	color: #8c8c8c;
	font-size: 15px;
	font-weight: bold;
	line-height: 1.3;
	transition: all ease 0.2s;
}
.service .classNavItem:last-of-type .inr {
	background-image: none;
}
.service .classNavItem.current .icon,
.service .classNavItem .wrap:hover .icon,
.service .classNavItem .wrap:focus .icon {
	opacity: 1.0;
}
.service .classNavItem.current .inr,
.service .classNavItem .wrap:hover .inr,
.service .classNavItem .wrap:focus .inr {
	background-color: #fff;
	color: #000;
}

.service .seatCrsl {
	position:relative;
	height:530px;
}
.service .seatCrslItems {
	background:#fff;
	z-index:0;
}
.service .seatCrslItem {
	position:absolute;
	top:0;
	left:0;
}
.service .seatCrslNav {
	z-index:5;
	margin:10px;
	position:absolute;
	bottom:10px;
	left:50%;
	margin-left:-100px;
}
.service .seatCrslNav li {
	display:inline;
	padding:0 20px;
	background-color:#968f8b;
	color:#ffffff;
	font-size:2px;
	cursor:pointer;
	margin-right:10px;
}
.service .seatCrslNav li.on {
	background-color:#b10000;
}

.service .seatBtm {
	background:#fff;
	padding:20px 30px 40px;
}
.service .seatBtm_desc {
	display:table;
	margin-left: -30px;
}
.service .seatBtm_desc .heading {
	display:table-cell;
	vertical-align:middle;
}
.service .seatBtm_desc .content {
	padding-left:20px;
	display:table-cell;
	vertical-align:middle;
}
.service .btn360 span {
	background:url(../img/icon_service_360deg.png) no-repeat;
	padding-left:23px;
}

.service .foodBox {
	background:#fff;
}
.service .foodBox_lft {
	float:left;
	width:390px;
	padding:50px 40px;
}
.service .foodBox_rgt {
	float:right;
	width:480px;
}
.service .foodBox_desc > .heading {
	text-align:center;
}
.service .foodBox_desc > .content p {
	margin-top:25px;
}

/*-- ticket --*/
.contents .contentsInr.ticket {
	margin-top: 60px;
	margin-bottom: 140px;
}
.ticket .ticket_head {
	margin-bottom: 40px;
	text-align: center;
}
.ticket .ticket_head img {
	vertical-align: top;
}

/*	modal
------------------------------*/
#cboxOverlay {
	background:#000;
	opacity:0.7;
}
#cboxTopLeft,
#cboxTopCenter,
#cboxTopRight,
#cboxMiddleLeft,
#cboxMiddleRight,
#cboxBottomLeft,
#cboxBottomCenter,
#cboxBottomRight {
	background:transparent;
}
#cboxContent {
	margin:58px 50px 0;
	background-color: #000;
	overflow:visible;
}
#cboxLoadedContent {
	margin-bottom:0;
}
#cboxClose {
	width:48px;
	height:48px;
	background:url(../img/icon_modal_close.png) no-repeat center center;
	background-size:100% auto;
	position:absolute;
	top:-58px;
	right:0;
	transition:transform ease 0.2s;
}
#cboxClose:hover {
	background-position:center center;
	transform:scale(1.1);
}
#cboxCurrent,
#cboxSlideshow {
	display: none !important;
}
#cboxPrevious,
#cboxNext {
	-webkit-appearance:none;
	appearance:none;
	width: 37px;
	height: 50px;
	background-repeat: no-repeat;
	background-position: center center;
	position: absolute;
	top: 50%;
	margin-top: -25px;
	transition:transform ease 0.2s;
}
#cboxPrevious:hover,
#cboxNext:hover {
	background-position: center center;
	transform:scale(1.1);
}
#cboxPrevious {
	background-image: url(../img/icon_modal_prev.png);
	left: -50px;
}
#cboxNext {
	background-image: url(../img/icon_modal_next.png);
	left: auto;
	right: -50px;
}

/*	animation
------------------------------*/
.dispPanels .dispPanel {
	opacity: 0;
	transform: scale(1.4) translateZ(0);
	transition: all linear 0.3s;
}
.dispPanels.amimated .dispPanel {
	opacity: 1.0;
	transform: scale(1.0) translateZ(0);
}
.dispPanel.panel01 { transition-delay: 0.0s; }
.dispPanel.panel02 { transition-delay: 0.1s; }
.dispPanel.panel03 { transition-delay: 0.2s; }
.dispPanel.panel04 { transition-delay: 0.3s; }
.dispPanel.panel05 { transition-delay: 0.4s; }
.dispPanel.panel06 { transition-delay: 0.5s; }
.dispPanel.panel07 { transition-delay: 0.6s; }
.dispPanel.panel08 { transition-delay: 0.7s; }
.dispPanel.panel09 { transition-delay: 0.8s; }
.dispPanel.panel10 { transition-delay: 0.9s; }
.dispPanel.panel11 { transition-delay: 1.0s; }
.dispPanel.panel12 { transition-delay: 1.1s; }
.dispPanel.panel13 { transition-delay: 1.2s; }
.dispPanel.panel14 { transition-delay: 1.3s; }
.dispPanel.panel15 { transition-delay: 1.4s; }

button:focus{
	outline:1px dotted #fff;
	display: inline!important;
	overflow: hidden!important;
}
