@charset "UTF-8";

html,body{height:100%;}

body{
	-webkit-text-size-adjust: 100%;
	padding:0;
	margin: 0;
	font-family: 'Noto Sans JP', "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro","メイリオ","Meiryo","ＭＳ Ｐゴシック",sans-serif;
	font-feature-settings: "palt" 1;
	-webkit-font-feature-settings: "palt" 1;
}

/* default */

div,dl,dt,dd,ul,ol,
li,h1,h2,h3,h4,h5,
h6,pre,code,form,fieldset,legend,
input,textarea,p,blockquote,
th,td{margin:0;padding:0;}
table{border-collapse:collapse;border-spacing:0;word-break: break-all;font-size:inherit;width:100%;}
fieldset,img{border:0;}
address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;font-weight:normal;}
li{list-style:none;}
caption,th{text-align:left;}
h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal;}
q::before,q::after{content:'';}
abbr{border:0;font-variant:normal;}
sup{vertical-align:text-top;}
sub{vertical-align:text-bottom;}
input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit;}
input,textarea,select{*font-size:100%;}
legend{color:#000;}
select,input,button,textarea{font:99% arial,helvetica,clean,sans-serif;}
pre,code,kbd,samp{font-family:monospace;*font-size:108%;line-height:100%;}
.aligncenter{text-align:center;}
figure{padding:0;margin:0;}
img{
	vertical-align: bottom;
	line-height: 1;
	max-width:100%;
	height:auto;
}
a{text-decoration: none;color:#000;transition: all .25s ease;}
a:hover{}


.indexwrapper {
	background-color: #f5f6f7;
	width: 100%;
	height: 100vh;
	position: relative;
	box-sizing: border-box;
}

.indexcontent {
}

.indexcontent-inner {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 100%;
}

.indexcontent-title {
	color: #1b7fbe;
	font-size: 4.28vh;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.15em;
	margin-bottom: 0.4vh;
}

.indexcontent-text {
	color: #1b7fbe;
	font-size: 3vh;
	text-align: center;
	font-weight: 500;
	margin-bottom: 3.5vh;
	letter-spacing: 0.08em;
}

.indexcontent-hour {
	color: #1b7fbe;
	font-size: 3vh;
	text-align: center;
	font-weight: 500;
}

.indexcontent-btn {
	width: 644px;
	max-width: 90%;
	margin: 0 auto;
	margin-top: 4.7vh;
	margin-bottom: 6.5vh;
}

.indexcontent-btn a {
	display: block;
	background-color: #26354b;
	padding: 4.8vh 20px 6.1vh;
	border-radius: 15px;
	transition: all .25s ease;
	box-shadow: 15px 0 30px #adafb6;
}

.indexcontent-btn a:hover {
	opacity: 0.7;
}

.indexcontent-btn-title {
	color: #FFF;
	text-align: center;
	font-size: 2.6vh;
	letter-spacing: 0.08em;
}

.indexcontent-btn-image {
	text-align: center;
	margin-top: 2.7vh;
	margin-bottom: 2.4vh;
}

.indexcontent-btn-text {
	color: #FFF;
	text-align: center;
	font-size: 1.85vh;
	letter-spacing: 0.08em;
}

.indexcontent-staffstatus {
	text-align: center;
	color: #ed4949;
	font-size: 2.9vh;
	font-weight: 500;
	margin-bottom: 5.3vh;
}

.indexcontent-logo {
	text-align: center;
}

.indexcontent-logo img {
	height: 10vh;
}

.indexcontent-staffonly {
	position: absolute;
	top: 4.6vh;
	left: 4.6vh;
}

.indexcontent-staffonly a {
	display: block;
	background-color: #fff;
	border: 1px solid #1b7fbe;
	border-radius: 8px;
	padding: 1.3vh 3vh;
	color: #1b7fbe;
	font-size: 1.8vh;
	font-weight: 500;
	transition: all .25s ease;
}

.indexcontent-staffonly a:hover {
	opacity: 0.7;
}



.topwrapper {
	position: relative;
	height:100%
}


/* topnav ---------------------------------------*/

.topnav {
	width: 275px;
	height: 100%;
	position: fixed;
	background-color: #f5f6f7;
	z-index: 11;
	overflow-y: scroll;
	box-sizing:border-box;
	padding: 10px 0 30px;
	box-shadow:5px 0px 5px rgba(0,0,0,0.1);
}

.topnav-list {margin-bottom: 80px;}

.topnav-list-item {
	margin-bottom: 20px;
	margin-top: 20px;
}

.topnav-list-item-operator {margin-bottom: 30px;}

.topnav-list-item a {}

.topnav-list-item-operator a {
	display: block;
	background-color: #26354b;
	color: #FFF;
	width: 210px;
	margin: 0 auto;
	padding: 15px 15px 15px 60px;
	box-sizing: border-box;
	font-size: 20px;
	background:url('../img/icon_operator.svg') #26354b no-repeat 15px center;
	background-size: 35px;
	border-radius: 10px;
	box-shadow: 5px 5px 5px rgba(0,0,0,.2),-5px -5px 5px rgba(255,255,255,.8);
	min-height: 93px;
	letter-spacing: 0.02em;
}

.topnav-list-item-btn {
	display: block;
	width: 210px;
	margin: 0 auto;
	padding: 0px 20px;
	box-sizing: border-box;
	font-size: 19px;
	border-radius: 10px;
	box-shadow: 5px 0px 7px rgba(0,0,0,.2),-3px -5px 3px rgba(255,255,255,.8);
	height: 93px;
	line-height: 93px;
	color: #535353;
	letter-spacing: 0.1em;
	font-weight:500;
	transition: all .25s ease;
}

.topnav-list-item-btn:hover,
.topnav-list li.is-current .topnav-list-item-btn{color: #1b7fbe;}

.topsubnav {
	position:absolute;
	left: 275px;
	top: 0;
	width: 260px;
	padding: 53px 37px;
	z-index: 10;
	height: 100%;
	background: rgb(226,243,254);
	background: linear-gradient(90deg, rgba(226,243,254,1) 0%, rgba(195,229,252,1) 100%);
	box-sizing:border-box;
	box-shadow:5px 0px 5px rgba(0,0,0,0.1) inset;
	overflow-y: scroll;
	transform: translate(-100%,0);
	transition: all .25s ease;
}

.topsubnav.is-active {
	transform: translate(0,0);
}

.topsubnav-list {display: none;}
.topsubnav-list.is-active{display: block;}

.topsubnav-list > li:not(:last-child){margin-bottom: 30px;}

.topsubnav-list > li > a{
	background: #fff;
	display: block;
	padding: 2px;
	color: #4c4948;
	transition: all .25s ease;
}

.topsubnav-list > li > a:hover,
.topsubnav-list > li.is-current > a{color: #1b7fbe;}

.topsubnav-list-image {}

.topsubnav-list-title {
	line-height: 1;
	padding: 11px 0;
	text-align:center;
	font-size:16px;
	font-weight:500;
	letter-spacing:0.05em;
}

.topnav-more{
	background: url('../img/arrow_more.png') no-repeat center center;
	background-size: 33px 15px;
	width: 33px;
	height: 15px;
	text-indent:-99em;
	position:fixed;
	left:133px;
	bottom: 90px;
	transform:translate(-50%,0);
	transition: all .25s ease;
	opacity: 0;
	display: none;
}

.topnav-more.is-active{opacity:1;}

.topnav-finish{
	text-align:center;
	padding-bottom: 30px;
}

.topnav-finish a {
	display: block;
	margin: 0 auto;
	width: 130px;
	height: 40px;
	line-height: 40px;
	text-align:center;
	background: #e9e7e7;
	border:1px solid #778896;
	color: #778896;
	border-radius:5px;
	font-weight:500;
}

/*スクロールバー全体*/
::-webkit-scrollbar {
    width: 6px;
}

/*スクロールバーの軌道*/
::-webkit-scrollbar-track {
  border-radius: 6px;
}

/*スクロールバーの動く部分*/
::-webkit-scrollbar-thumb {
  background-color: rgba(0, 0, 50, .5);
  border-radius: 0px;
  box-shadow:0 0 0 1px rgba(255, 255, 255, .3);
}

.topnav::-webkit-scrollbar-thumb{background: #5E5E5E;}
.topsubnav::-webkit-scrollbar-thumb{background: #1E6CB2;}

.topnav {
	scrollbar-width: thin;
	scrollbar-color: #5E5E5E #f5f6f7;
}

.topsubnav {
	scrollbar-width: thin;
	scrollbar-color: #1E6CB2 #B9DFFC;
}

/* contents ---------------------------------------*/

.topcontents {
	position: fixed;
	width: calc(100% - 275px);
	height: 100%;
	top: 0;
	left: 275px;
	overflow: hidden;
}

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