@CHARSET "utf-8";
/*------------------------------------------------------------------------------
	共通
------------------------------------------------------------------------------*/
html,body	{
	padding: 0px;
	margin: 0px;
	height:100%;
}

body	{
	min-width: 960px;
}

form {
	display: inline;
}

input[readonly] {
    background-color: unset;
    border: unset !important;
}
/*
select	{
	max-width: 180px;
}
*/
#body_container {
	min-height:100%;
	margin-bottom: -26px;
	height:auto !important;
	height:100%;
	background-color: #FFFFFF;
}

#body_contents	{
	height: auto;
}

#footer-space {
	height:26px;
}

.body	{
	width: 1200px;
	margin: 0px auto;
	padding-bottom: 10px;
}

.bar	{
	padding: 5px 10px;
	background-color: #00A0C6;
	color: #FFFFFF;
	font-size: 16px;
	font-weight: bold;
	font-size: 16px;
	text-shadow:0 -1px #1a6ea0;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius: 5px;
}

.bar2 {
	min-width: 960px;
	width: 100%;
	display: table;
	border-bottom: solid 1px #CCC;
}

.bar2 h1 {
	width: 200px;
	height: 50px;
	display: table-cell;
	vertical-align: middle;
	font-size: 16px;
	font-weight: normal;
	padding-left: 10px;
	/*background-color: #FFFFFF;*/
	background-color:#094AB2;
	text-align: center;
	color: #FFF;
	border-right: solid 1px #FFF;
}

.bar2 .btn_area	{
	display: table-cell;
	vertical-align: middle;
	background-color: #FFF;
	white-space: nowrap;
}

.bar2 .btn_area input:nth-child(n +  2)	{
	border-left: solid 1px #778899;
}

.bar2 .btn_area .btn_or {
	font-size: 12px;
	padding: 0 8px;
	margin: 0;
	line-height: 50px;
	color: #fff;
	background-color: #043c78;
	border: 0;
	border-style: none;
	cursor: pointer;
	-moz-box-shadow: none;
	-webkit-box-shadow: none;
	-moz-border-radius: 0;
	-webkit-border-radius: 0;
	border-radius: 0;
}

.bar2 .btn_area .btn_or:hover {
	opacity: 0.8;
}

.bar2 .btn_area .btn_or:disabled	{
	background-color: #C0C0C0;
}

.bar2 .btn_area .btn_save	{
	padding: 0px 10px 0px 30px !important;
	background-image: url(../image/default/save-icon.png);
	background-repeat: no-repeat;
	background-position: 10px center;
}

.bar2 .btn_area .btn_back	{
	padding: 0px 10px 0px 30px !important;
	background-image: url(../image/default/return2.png);
	background-repeat: no-repeat;
	background-position: 10px center;
	min-width: 85px;
}

.bar2 .btn_area .btn_mail	{
	padding: 0px 10px 0px 30px !important;
	background-image: url(../image/default/mail-icon.png);
	background-repeat: no-repeat;
	background-position: 10px center;
	min-width: 85px;
}

.bar2 .btn_area .btn_clear	{
	padding: 0px 10px 0px 30px !important;
	background-color: #FF0000;
	background-image: url(../image/default/clear-icon.png);
	background-repeat: no-repeat;
	background-position: 10px center;
	min-width: 85px;
}

.bar2 .btn_area .btn_edit	{
	padding: 0px 10px 0px 30px !important;
	background-image: url(../image/default/edit-icon.png);
	background-repeat: no-repeat;
	background-position: 10px center;
	min-width: 85px;
}

.bar2 .btn_area .btn_search	{
	padding: 0px 10px 0px 30px !important;
	background-image: url(../image/default/search-icon.png);
	background-repeat: no-repeat;
	background-position: 10px center;
	min-width: 85px;
}

.bar2 .btn_area .btn_setting	{
	padding: 0px 10px 0px 30px !important;
	background-color: #008800;
	background-image: url(../image/default/setting2.png);
	background-repeat: no-repeat;
	background-position: 10px center;
	min-width: 85px;
}

.bar2 .btn_area .btn_download	{
	padding: 0px 10px 0px 30px !important;
	background-image: url(../image/default/download-icon.png);
	background-repeat: no-repeat;
	background-position: 10px center;
	min-width: 85px;
}

.sub_bar	{
	padding: 5px 10px;
	background-color: #7BBB29;
	color: #FFFFFF;
	font-size: 16px;
	font-weight: bold;
	text-shadow:0 -1px #1a6ea0;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius: 5px;
}

.error	{
	color: red;
	font-weight: bold;
}

.frame	{
	padding: 20px;
	background-color: #F8F8F8;
/*	border: solid 1px #C0C0C0;*/
}

.guide	{
	padding: 10px 20px;
	background-color: #FFFACD;
	border: solid 1px #C0C0C0;
}

.condition	{
	padding: 10px 20px;
	background-color: #EAEEFA;
	border: solid 1px #C0C0C0;
}

.label_alignment label	{
	display: block;
	float: left;
	width: 118px;
}

.btn_off input[type="button"] {
	visibility: hidden;
}

.search_condition	{
	width: 938px;
	padding: 10px;
}

.search_condition	label	{
	display: inline-block;
	vertical-align: top;
	width: 469px;
}

label {
	display: inline-block;
	vertical-align: top;
	cursor: pointer;
}

.user_name	{
	line-height: 18px;
	padding-left: 24px;
	background-image: url(../image/default/user.png);
	background-repeat: no-repeat;
}

.other_name	{
	line-height: 18px;
	padding-left: 24px;
	background-image: url(../image/default/user2.png);
	background-repeat: no-repeat;
}

.pager	img	{
	cursor: pointer;
	vertical-align: -4px;
}

.scroll	{
	width: 100%;
	overflow: auto;
	/* border-left: 1px solid #ccc;
    border-right: 1px solid #ccc; */
}
/*------------------------------------------------------------------------------
	共通(テーブル)
------------------------------------------------------------------------------*/
.form_tb	{
	border-collapse: collapse;
	border-spacing:0;
	table-layout: auto;
	border: solid 1px #C0C0C0;
}

.form_tb	th	{
	padding: 5px;
	background-color: #F5F5DC;
	border: solid 1px #C0C0C0;
	color: #333333;
}

.form_tb	td	{
	padding: 5px;
	border: solid 1px #C0C0C0;
	color: #333333;
	word-break: break-all;
}

.form_tb	caption	{
	margin-bottom: 5px;
	font-size: 14px;
	font-weight: bold;
}
/*------------------------------------------------------------------------------
	リストマーク
------------------------------------------------------------------------------*/
.link_1	{
	padding: 0px 0px 0px 16px;
	background-image: url(../image/ar01.jpg);
	background-repeat: no-repeat;
	background-position: 0px center;
}

.link_1	a	{
	color: #0066FF;
	text-decoration: none;
}

.link_1	a:hover	{
	text-decoration: underline;
}

.link_2	{
	padding: 0px 0px 0px 16px;
	background-image: url(../image/ar02.jpg);
	background-repeat: no-repeat;
	background-position: 0px center;
}

.link_2	a	{
	color: #0066FF;
	text-decoration: none;
}

.link_2	a:hover	{
	text-decoration: underline;
}

.link_3	{
	padding: 0px 0px 0px 14px;
	background-image: url(../image/ar03.gif);
	background-repeat: no-repeat;
	background-position: 0px center;
}

.link_3	a	{
	color: #0066FF;
	text-decoration: none;
}

.link_3	a:hover	{
	text-decoration: underline;
}

.input_fake	{
	min-height: 17px;
	padding: 2px;
	border: solid 1px #CCC;
	background-color: #E0E0E0;
}
/*------------------------------------------------------------------------------
	header
------------------------------------------------------------------------------*/
header {
    position: sticky;
    top: 0;
    z-index: 999;
}
/*------------------------------------------------------------------------------
	main
------------------------------------------------------------------------------*/
.wrapper	{
	width: calc(100% - 40px);
	padding: 10px 20px 20px 20px;
}

.navi	{
	width: 200px;
	margin-right: -200px;
	float: left;
}

.main	{
	width: 100%;
	float: right;
}

.content	{
	margin-left: 100px;
	margin-right: 100px;
}

.navi2	{
	width: 300px;
	margin-right: -300px;
	float: left;
}

.content2	{
	margin-left: 320px;
}
/*------------------------------------------------------------------------------
	footer
------------------------------------------------------------------------------*/
.footer	{
	width: 100%;
	padding: 5px 0px 0px 0px;
	border-top: solid 1px #CCCCCC;
	color: #666666;
	text-align: center;
	height: 20px;
	font-size: 12px;
}
/*------------------------------------------------------------------------------
	メニュー
------------------------------------------------------------------------------*/
.head_menu	{
	background-color: #333;
	min-width: 960px;
	position: relative;
	z-index: 3000;
}

.head_menu_list	{
	margin: 0;
	padding: 0;
	display: inline-block;
	min-width: 760px;
	font-size: 0;
}

.head_menu_list ul	{
	list-style-type: none;
	margin: 0;
	padding: 0;
	font-size: 0;
}

.head_menu_list li	{
	margin: 0;
	padding: 0;
	font-size: 16px;
}


.head_menu_list ul ul	{
	top: 100%;
	left: 0;
	position: absolute;
	display: none;
	min-width: 100%;
}

.head_menu_list li	{
	float: left;
}

.head_menu_list li li {
	clear: both;
	width: 100%;
}

.head_menu_list li li a {
	width: calc(100% - 40px);
}

.head_menu_list > ul > li	{
	position: relative;
}

/*
.head_menu_list li:hover	{
	position: relative;
}
*/

.head_menu_list li:hover > ul	{
/*	display: block;*/
}

.head_menu_list span, .head_menu_list a	{
	display: block;
	padding: 5px 20px;
	color: white;
	background-color: #333;
	white-space: nowrap;
	line-height: 30px;
	cursor: pointer;
}

.head_menu_list ul:last-child:after	{
	content: "";
	clear: both;
	display: block;
}

.head_menu_list span:hover, .head_menu_list a:hover, .head_menu_list .span_selected	{
	background-color: #00a0c6 !important;
}

#dropmenu2	{
	display: inline-block;
	background-color: #FFF;
	width: 150px;
	position: absolute;
	right:0;
}

#dropmenu2	ul	{
	margin: 0;
	padding: 0;
}

#dropmenu2	ul	li	{
	list-style: none;
	margin: 0;
	padding: 0;
	font-size:12px;
	float: left;
	width: 150px;
	height: 39px;
	line-height: 40px;
	text-align: center;
	cursor: pointer;
}

#dropmenu2	ul	li	a	{
	color: black;
	display: block;
	text-decoration: none;
}

#dropmenu2	ul	li:hover, #dropmenu2	ul	li	a:hover	{
	background: #00a0c6;
	color:white;
}

#dropmenu2	ul	li	ul	{
	display: none;
	top: 39px;
	left: 0;
	width: 150px;
	z-index: 100;
	border-bottom: solid 1px #CCC;
}

#dropmenu2	ul	li	ul	li	{
	width: 149px;
	cursor: pointer;
	background-color: white;
	border-left: solid 1px #CCC;
}

#dropmenu2	ul	li	ul li:last-child	{
	border-bottom: solid 1px #CCC;
}
/*------------------------------------------------------------------------------
	メニュー
------------------------------------------------------------------------------*/
#menu	{
	width: 1200px;
	margin: 0px auto 20px auto;
	background-color: #ECECEC;
	font-size: 12px;
	position: relative;
	z-index: 10;
}

#menu	a	{
	color: blue;
}

#menu	span	{
	cursor: pointer;
}

#menu	ul	{
	margin: 0;
	padding: 0;
	display: block;
	list-style-type: none;
}

#menu	ul	ul	{
	top: 100%;
	left: 0;
	position: absolute;
	display: none;
}

#menu	ul	ul	ul	{
   top: 0;
   left: 100%;
}

#menu	li	{
	float: left;
}

#menu	li	li {
	clear: both;
}

#menu	li:hover	{
	position: relative;
}

#menu	li:hover	>	ul	{
	display: block
}

*	html	#menu	li	{
	behavior: expression(
		this.onmouseover = new Function("this.className='column1'"),
		this.onmouseout = new Function("this.className=''"),
		this.style.behavior = 'none'
	);
}

*	html	#menu	li	li	{
	behavior: expression(
		this.onmouseover = new Function("this.className='column2'"),
		this.onmouseout = new Function("this.className=''"),
		this.style.behavior  = 'none'
	);
}

#menu	.column1			{position: relative;}
#menu	.column1	ul 		{display: block;}
#menu	.column1	*	ul	{display: none;}

#menu	.column2			{position: relative;}
#menu	.column2	ul		{display: block;}
#menu	.column2	*	ul	{display: none;}

#menu	li	{
	background: #E7E7E7;
	background-image: url(../image/default/menu01_bg.jpg);
	background-repeat: no-repeat;
	background-position: center 0px;
	border: solid 1px #CCCCCC;
	height:32px;
	text-align: center;
}

#menu	li	li	{
	background: #E7E7E7;
	background-image: url(../image/default/menu02_bg.jpg);
	background-repeat: no-repeat;
	background-position: 0px center;
	text-align: left;
	line-height: 2.4em;
	border: none;
}

#menu	li	a	{
	width: 188px;
	height: 24px;
	padding: 8px 5px 0px;
	display: block;
	font-weight: bold;
	text-decoration: none;
	color: #555555;
}

#menu	li	li	a	{
	width: 177px;
	padding: 0px 0px 0px 23px;
	height: 100%;
	display: block;
	font-weight: normal;
	text-decoration: none;
	color: #555555;
}

#menu	li:hover	{
	background: #E7E7E7;
	background-image: url(../image/default/menu01_bg.jpg);
	background-repeat: no-repeat;
	background-position: center -32px;
	color: #FFFFFF !important;
}

#menu	li	li:hover	{
	background: #E7E7E7;
	background-image: url(../image/default/menu02_bg.jpg);
	background-repeat: no-repeat;
	background-position: -300px center;
}

#menu	li	li	a:hover	{
	color: #555555;
}


#menu	.column1,	#menu	.column2	{
	color: #FFFFFF !important;
}

#menu	.column1	.menu_item	{
	color: #FFFFFF !important;
}

.submenu_item	{
	padding-left: 18px;
	background-image: url(../image/common/ar02.jpg);
	background-repeat: no-repeat;
	background-position: 0px center;
}

.submenu_item	a	{
	color: #2E57A4;
	text-decoration: none;
}
/*------------------------------------------------------------------------------
	ファンクションキー
------------------------------------------------------------------------------*/
.vs-func {
	height: 50px;
	max-height: 50px;
	background: #F2F4F5;
	align-items: center;
	display: flex;
}	

.vs-func > li {
	margin-left: 20px;
}

.vs-func h1 {
	width: 250px;
	line-height: 50px;
	font-size: 16px;
	font-weight: bold;
	border-right: 1px solid #D5D5D5;
}	

.vs-func a,
.vs-func input {
	cursor: pointer;
	font-size: 14px;
}

.vs-func a.back,
.vs-func input.back {
	line-height: 50px;
    font-weight: bold;
    color: #0075B5;
}

.vs-func a.back::before,
.vs-func input.back::before {
	content: '\f359';
	font-family: 'FontAwesome';
	margin-right: 5px;
	color: #0075B5;
	font-size: 20px;
	vertical-align: -3px;
}

.vs-func a:not(.back),
.vs-func input:not(.back) {
	height: 36px;
	padding: 0 20px;
	background: #0075B5;
	border: 1px solid #0075B5;
	border-radius: 5px;
	color: white;
	line-height: 36px;
	font-size: 14px;
	display: inline-block;
}
.vs-func a.disabled,
.vs-func input.disabled{
	background-color: #dbdada;
    border-color: #dbdbdb;
    color: #959595;
}
.vs-func a.fa-times,
.vs-func input.fa-times {
	background: white;
	color: #0075B5;
}

.vs-func a:hover,
.vs-func input:hover {
	opacity: 0.8;	
}
/*------------------------------------------------------------------------------
	ボディ
------------------------------------------------------------------------------*/
main {
	width: 100%;
	padding: 20px;
	font-size: 12px;
	flex: 1;
}

main h2 {
	font-size: 18px;
	font-weight: bold;
}

main h3 {
	padding: 5px 0 5px 10px;
	border-left: 5px solid #0075B5;
	line-height: 1.5;
	font-size: 16px;
	font-weight: bold;
}

main input[type=text],
main input[type=password],
main input[type=date],
main input[type=time],
main select {
	height: 30px;
	line-height: 30px;
	border: 1px solid #ccc;
	border-radius: 3px;
}

main textarea {
	border: 1px solid #ccc;
	border-radius: 3px;
}

select {
	height: 30px;
	background: white;
	border: 1px solid #ccc;
	border-radius: 3px;
}

/*
main th, main td {
	height: 30px;
}*/
/*------------------------------------------------------------------------------
	メニュー
------------------------------------------------------------------------------*/
.vs-menu {
	width: 100%;
}

.vs-menu > ul {
	height: 50px;
	max-height: 50px;
	display: flex;
}

.vs-menu > ul > li {
	background: #0075B5;
	color: white;
	line-height: 50px;
	font-size: 14px;
	text-align: center;
	position: relative;
}

.vs-menu > ul > li.curr {
	background: #E7F5FD;	
	color: #0075B5;
}

.vs-menu > ul > li:first-of-type {
	padding: 0 20px;
	font-weight: bold;
}

.vs-menu > ul > li:nth-child(n+2) {
	width: 180px;
}

.vs-menu > ul > li:nth-last-child(3) {
	padding-right: 20px;
	text-align: right;
	min-width: 160px;
	flex: 1;
}

.vs-menu > ul > li:nth-last-child(2),
.vs-menu > ul > li:last-of-type {
	width: 50px;
	font-size: 20px;
}

.vs-menu > ul > li > img {
	height: 40px;
	margin-top: 5px;
	filter: brightness(0) invert(1);
	color: #fff !important;
	border-color: #fff !important;
	display: inline-block;
}

.vs-menu > ul > li > ul {
	left: 0;
	top: 100%;
	width: 100%;
	position: absolute;
	display: none;
}

.vs-menu > ul > li > ul > li > a {
	height: 50px;
	padding-left: 10px;
	background: #0075B5;
	color: white;
	line-height: 50px;
	font-size: 12px;
	text-align: left;
	position: relative;
	display: block;
}

.vs-menu > ul > li > ul > li > a::after {
	content: '\f061';
	right: 10px;
	top: 50%;
	transform: translateY(-50%); 
	font-family: 'FontAwesome';
	position: absolute;
}

.vs-menu > ul > li:hover ul {
	display: block;
}

.vs-menu > ul > li:not(.empty):hover,
.vs-menu > ul > li > ul > li:hover a {
	background: #E7F5FD;	
	color: #0075B5;
}
/*------------------------------------------------------------------------------
	画面分割
------------------------------------------------------------------------------*/
.vs-split-parent {
	justify-content: space-between;
	display: flex;
}

.vs-split-parent > li:first-of-type {
	width: 180px;
}

.vs-split-parent > li:last-of-type {
	width: calc(100% - 200px);
}

.vs-split-parent > li:last-of-type > ul.vs-split-child {
	justify-content: space-between;
	display: flex;
}

.vs-split-parent > li:last-of-type > ul.vs-split-child > li {
	width: 49%;
	margin-top: 20px;
}
/*------------------------------------------------------------------------------
	アイコン
------------------------------------------------------------------------------*/
.fill-circle.blue::before {
	color: #fff;
	font-size: 18px;
	padding: 6px;
    border-radius: 50%;
    margin: 0 5px 0 0;
	background-color: var(--main-color, #0075B5);
}

.solid-circle.blue::before {
	color: var(--main-color, #0075B5);
    font-size: 12px;
    border: 1px solid var(--main-color, #0075B5);
    border-radius: 50%;
    padding: 2px 3px;
    margin: 0 3px 0 0;
}

.img-circle {
	color: #fff;
	font-size: 18px;
	padding: 6px;
    border-radius: 50%;
    margin: 0 5px 0 0;
	background-color: var(--main-color, #0075B5);
	width: 32px;
	height: 32px;
	vertical-align: middle;
}
/*------------------------------------------------------------------------------
	システムメニュー
------------------------------------------------------------------------------*/
.vs-config-menu > li {
	height: 50px;
	padding: 0 10px;
	background: #F2F4F5;
	line-height: 50px;
	font-weight: bold;
}

.vs-config-menu > li:first-of-type {
	background: #99AAB1;
	color: white;
	text-align: center;
}

.vs-config-menu > li:not(:first-of-type) {
	margin-top: 3px;
}

.vs-config-menu > li:not(:first-of-type):hover {
	background: #E7F5FD;
}

.vs-config-menu a {
	color: #333;
	display: block;
	position: relative;
}

.vs-config-menu a::after {
	content: '\f105';
	right: 0;
	top: 50%;
	transform: translateY(-50%); 
	font-family: 'FontAwesome';
	position: absolute;
	pointer-events: none;
}
/*------------------------------------------------------------------------------
	タブメニュー
------------------------------------------------------------------------------*/
.tab {
	display: flex;
    align-items: center;
    border-bottom: 2px solid var(--main-border-color, #0075B5);
}

.tab > li {
	color: #CCCCCC;
    width: 160px;
    text-align: center;
    padding: 13px 0;
    background: #F2F2F2;
    margin: 0 5px 0 0;
    border-radius: 5px 5px 0px 0px;
    cursor: pointer;
}

.tab > li.active {
	color: #fff;
	background: var(--main-color, #0075B5);
}

.tab.black > li.active {
	background: #666666;
}
/*------------------------------------------------------------------------------
	検索条件
------------------------------------------------------------------------------*/
.search-condition-wrap {
	padding: 0 20px 20px 20px;
	background: #F2F4F5;
	border-radius: 5px 5px 0 0; 
	flex-wrap: wrap;
    display: flex;
}

.search-condition-wrap > li {
	margin: 15px 20px 0 0;
}

.search-condition-wrap p {
	margin-bottom: 5px;
	font-weight: bold;
}

.search-func {
	padding: 5px 0;
	background: #F2F4F5;
	border-top: 1px solid #ccc;	
	border-radius: 0 0 5px 5px; 
	text-align: center;
}

.search-func {
	padding: 5px 0;
	background: #F2F4F5;
	border-top: 1px solid #ccc;	
	border-radius: 0 0 5px 5px; 
	text-align: center;
}

.search-func > a {
	font-size: 14px;
	cursor: pointer;
}

.search-func > a.search {
	height: 36px;
	padding: 0 20px;
	background: #0075B5;
	border: 1px solid #0075B5;
	border-radius: 5px;
	color: white;
	line-height: 36px;
	display: inline-block;	
}

.search-func > a.search::before {
	content: '\f002';
	font-family: 'FontAwesome';
	margin-right: 5px;
}

.search-func > a.clear::before {
	content: '\f057';
	font-family: 'FontAwesome';
	margin-right: 5px;
	color: #0075B5;
	font-size: 16px;
	vertical-align: middle;
}
/*------------------------------------------------------------------------------
	ボタンを表示するエリア
------------------------------------------------------------------------------*/
.switchArea2 {
	line-height    : 22px;	            /* 1行の高さ          */
	letter-spacing : 0;                   /* 文字間             */
	text-align     : center;              /* 文字位置は中央     */
	font-size      : 11px;                /* 文字サイズ         */
	position       : relative;            /* 親要素が基点       */
	margin         : 0;                   /* 中央寄せ           */
	width          : 46px;                /* ボタンの横幅       */
	background     : #fff;                /* デフォルト背景色   */
	display: inline-block;
	font-weight: normal;
}

/* === チェックボックス ==================================== */
.switchArea2 input[type="checkbox"] {
	display        : none;            /* チェックボックス非表示 */
}

/* === チェックボックスのラベル（標準） ==================== */
.switchArea2 label {
	display        : block;               /* ボックス要素に変更 */
	box-sizing     : border-box;          /* 枠線を含んだサイズ */
	height         : 24px;                /* ボタンの高さ       */
	border         : 2px solid #999999;   /* 未選択タブのの枠線 */
	border-radius  : 12px;                /* 角丸               */
	cursor: pointer;
	padding-left: initial;
}

/* === チェックボックスのラベル（ONのとき） ================ */
.switchArea2 input[type="checkbox"]:checked +label {
	border-color   : #333333;             /* 選択タブの枠線     */
}

/* === 表示する文字（標準） ================================ */
.switchArea2 label span:after{
	content        : "OFF";               /* 表示する文字       */
	padding        : 0 0 0 18px;          /* 表示する位置       */
	color          : #999999;             /* 文字色             */
}

/* === 表示する文字（ONのとき） ============================ */
.switchArea2  input[type="checkbox"]:checked + label span:after{
	content        : "ON";                /* 表示する文字       */
	padding        : 0 18px 0 0;          /* 表示する位置       */
	color          : #333333;             /* 文字色             */
}

/* === 丸部分のSTYLE（標準） =============================== */
.switchArea2 .swImg {
	position       : absolute;            /* 親要素からの相対位置*/
	width          : 16px;                /* 丸の横幅           */
	height         : 16px;                /* 丸の高さ           */
	background     : #999999;             /* カーソルタブの背景 */
	top            : 4px;                 /* 親要素からの位置   */
	left           : 4px;                 /* 親要素からの位置   */
	border-radius  : 8px;                 /* 角丸               */
	transition     : .2s;                 /* 滑らか変化         */
}

   /* === 丸部分のSTYLE（ONのとき） =========================== */
.switchArea2 input[type="checkbox"]:checked ~ .swImg {
	transform      : translateX(22px);    /* 丸も右へ移動       */
	background     : #333333;             /* カーソルタブの背景 */
}
/*------------------------------------------------------------------------------
	ラッパー
------------------------------------------------------------------------------*/
.vs-wrapper	{
	min-height: 100%;
	display: flex;
	flex-direction: column;
}

.vs-wrapper * {
	box-sizing: border-box;	
}
/*------------------------------------------------------------------------------
	モーダルウィンドウ
------------------------------------------------------------------------------*/
div#modal {
	display: none;
	position: fixed;
	width: 100%;
	height: 100%;
	top:0;
	left:0;
	z-index: 1000;
}
div#modal div.background {
	position: fixed;
	width: 100%;
	height: 100%;
	background-color: #000000;
	opacity: 0.55;
	filter: alpha(opacity=55);
	-ms-filter: "alpha(opacity=55)";
}

div#modal div.container {
	position: relative;
	width: 300px;
	height: 300px;
	padding: 10px;
	background-color: #333333;
}

.popup_tb th, .popup_tb td	{
	padding: 5px;
	color: #FFFFFF;
}

.popup_tb th	{
	background-color: #808080;
	border: 1px solid #333;
}

.popup_tb td	{
	background-color: #404040;
	border: 1px solid #808080;
}

.popup_tb th:first-child, .popup_tb td:first-child	{
	border-left: none;
}

.popup_tb th:last-child, .popup_tb td:last-child	{
	border-right: none;
}

.popup_bar	{
	border-bottom: solid 1px #FFFFFF;
	position: relative;
}

.popup_bar div	{
	font-size: 16px;
	color: #FFFFFF;
	font-weight: bold;
	line-height: 25px;
}

.popup_bar	p	{
	width: 30px;
	position: absolute;
	top: 0;
	right:0;
	text-align: right;
}

.pu_btn	{
	background: none repeat scroll 0 0 var(--main-color);
	border: medium none;
	cursor: pointer;
	margin: 0;
	padding: 0;
	border-radius: 5px;
	color: #FFFFFF;
	font-size: 14px;
	font-weight: normal;
	height: 26px;
	width: 80px;
}

#popup_body	{
	min-height:100%;
	height:auto !important;
	height:100%;
	background-color: #333333;
}

#popup_body .pager	{
	color: #FFFFFF;
}

#popup_body .pager a	{
	color: #99CCFF;
}
/*------------------------------------------------------------------------------
	ダイアログ
------------------------------------------------------------------------------*/
#confirm_bg	{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height:100%;
	z-index:1000;
	background-color: transparent;
	background-image: url(../image/default/dialog_bg.png);
	background-repeat: repeat;
}

#confirm_dialog	{
	width: 320px;
	background-color: #FFFFFF;
	border: solid 1px #C0C0C0;
	font-size: 12px;
	position: absolute;
	z-index:1001;
}
#confirm_head{
background: var(--main-color);
    font-weight: bold;
    color: white;
}

#confirm_dialog > div > input {
    background: var(--main-color);
    color: white;
    border: 1px solid var(--main-color);
    line-height: 25px;
    cursor: pointer;
}

#confirm_dialog > div > input[value='キャンセル'] {
    background: #E7F5FD;
    color: var(--main-color);
}
/*------------------------------------------------------------------------------
	ボタン
------------------------------------------------------------------------------*/
.btn_bl {
	width: 200px;
	font-size: 16px;
/*
	font-weight: bold;
*/
	padding: 10px 0;
	color: #fff;
	background-color:#49a9d4;
	border-style: none;
	-moz-box-shadow: 2px 2px 3px 1px #666;
	-webkit-box-shadow: 2px 2px 3px 1px #666;
	text-shadow:0 -1px #1a6ea0;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius: 5px;
	background-image: -moz-linear-gradient(
		top,
		#49a9d4 0%,
		#2989d8 40%,
		#2285d6 52%,
		#2989d8);
	background-image: -webkit-gradient(
		linear,left top,left bottom,
		from(#49a9d4),
		color-stop(0.49,#2989d8),
		color-stop(0.52,#2285d6),
		to(#2989d8));
	cursor: pointer;
}

.btn_bl:hover {
	opacity: 0.8;
}

.btn_or {
	font-size: 12px;
	padding: 5px 10px;
	color: #fff;
	background-color:#0075B5;
	border: 1px solid #0075B5;
	border-radius: 5px;
 	cursor: pointer;
 	display: inline-block;
 }

.btn_or:hover {
	opacity: 0.8;
}

.btn_or:disabled	{
	background-color: #D0D6DB;
	cursor: auto;
    border-color: #D0D6DB;
}

.btn_or.rev {
	background-color:white;
	color:#0075B5;
 }
/*------------------------------------------------------------------------------
	login
------------------------------------------------------------------------------*/
.login	{
	position: relative;
	top: 50%;
	margin-top: -150px;
}

.login_bg	{
	width: 500px;
	margin: 0px auto;
	padding: 50px 20px;
	background-color: #00A0C6;
}
/*------------------------------------------------------------------------------
	スクロール(Spreadsheet)
------------------------------------------------------------------------------*/
thead.scrollHead,tbody.scrollBody {
	display: block;
}

tbody.scrollBody{
	background-color: #C0C0C0;
	overflow-y: scroll;
}

.scrollBody	tr	{
	background-color: white;
}
/*------------------------------------------------------------------------------
	loader
------------------------------------------------------------------------------*/
#loader-bg {
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background-color: #000000;
	opacity: 0.55;
	filter: alpha(opacity=55);
	-ms-filter: "alpha(opacity=55)";
	z-index: 1;
}

#loader {
	position: fixed;
	top: 50%;
	left: 50%;
	width: 200px;
	height: 200px;
	margin-top: -100px;
	margin-left: -100px;
	text-align: center;
	color: #fff;
	z-index: 2;
}
/*------------------------------------------------------------------------------
	scroll-container
------------------------------------------------------------------------------*/
.scroll-table-container {
    display: inline-block;
    vertical-align: top;
    overflow-x: scroll;
    width:100%;
    box-sizing: border-box;
 }

#headContainer::-webkit-scrollbar{
    display: none;/* WebKit (Chrome, Safari) */
}
#headContainer{
    -ms-overflow-style: none;  /* Edge, IE */
    scrollbar-width: none;  /* Firefox */
    padding-right: 17px;
}
/*------------------------------------------------------------------------------
	UI-dialog
------------------------------------------------------------------------------*/
.ui-widget-overlay{
    background: #666666 url(../image/jquery_ui/ui-bg_diagonals-thick_20_666666_40x40.png) 50% 50% repeat;
    opacity: .5;
    z-index: 1000 !important;
}
.ui-dialog {
    z-index: 1001 !important;
}
.ui-widget-header{
    border: 1px solid var(--main-color) !important;
    background: var(--main-color) !important;
    color: #ffffff !important;
}
.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default{
    color: var(--main-color);
}
.ui-widget-content{ 
	background: #eeeeee !important;
}
.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default, .ui-button, html .ui-button.ui-state-disabled:hover, html .ui-button.ui-state-disabled:active{
    background: #f6f6f6 !important;
    font-weight: bold !important;
    color: #1c94c4 !important;
}
.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus, .ui-button:hover, .ui-button:focus{
    border: 1px solid #fbcb09 !important;
    background: #fdf5ce !important;
    font-weight: bold !important;
    color: #c77405 !important;
}
.ui-datepicker-trigger{
    box-sizing: border-box;
    vertical-align: middle;
    margin-left: 3px;
    cursor: pointer;
    filter: brightness(0) saturate(100%) invert(29%) sepia(100%) saturate(958%) hue-rotate(172deg) brightness(97%) contrast(103%);
}
.search{
    font-size: 18px;
    line-height: 30px;
    box-sizing: border-box;
    vertical-align: middle;
    margin-left: 3px;
    cursor: pointer;
    color: var(--main-color);
}
/*------------------------------------------------------------------------------
	色選択
------------------------------------------------------------------------------*/
.color-selector-parent	{
	position: relative;
}

.color-selector	{
	width: 20px;
	height: 20px;
	cursor: pointer;
}
/*------------------------------------------------------------------------------

------------------------------------------------------------------------------*/
.menu_color {
	width: 35px;
	height: 20px;
	float: left;
	margin: 5px 0;
	cursor: pointer;
}
#close-color{
    width: 20px;
    height: 20px;
    line-height: 20px;
    margin: 0 0 0 3px;
    cursor: pointer;
    font-size: 18px;
}
/*------------------------------------------------------------------------------

------------------------------------------------------------------------------*/
#ss i {
    color: var(--main-color);
	font-size: 20px;
	cursor: pointer;
}
.scroll:not(.no_change) > table th {
    padding: 5px !important;
}
.scroll:not(.no_change) .tb_custom_bd th,
.scroll:not(.no_change) .tb_custom_bd td{
    border: solid 1px #ccc;
}

.scroll:not(.no_change) .tb_custom_bd select,
.scroll:not(.no_change) .tb_custom_bd input {
    border: unset !important;
    width: 100%;
}
.scroll:not(.no_change) .tb_custom_bd td:nth-child(2) input {
    width: 65px;
}
.scroll:not(.no_change) .tb_custom_bd input.input_calendar {
	width: 85px;
}
.scroll:not(.no_change) .tb_custom_bd thead th{
	background-color: #99AAB1;
	color: white;
}
.scroll:not(.no_change) .tb_custom_bd tbody th,
.scroll:not(.no_change) .tb_custom_bd td{
    padding: 0 !important;
}
main > table.tb_custom_bd input[name="amount"],
main > table.tb_custom_bd input[name="total"],
main > table.tb_custom_bd input[name="weight"]{
	text-align: left;
}
#ss i.disable {
    color: #D0D6DB;
    cursor: initial;
}
#ss i:not(:last-child) {
    margin-right: 7px;
}
@keyframes autofill {
    to {
        background: transparent;
    }
}

input:-webkit-autofill {
    animation-name: autofill;
    animation-duration: 0.01s; 
}
