html{
    font-size: 62.5%;
    color: #333333;
    box-sizing: border-box;
    overflow: auto;
}

body{
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    line-height: 1.5;
    font-size: 11.5px;
    letter-spacing: 0.08em;
}

header{
    width: 100%;
    height: 55px;
    padding: 12px 16px;
    position: fixed;
    top: 0;
    z-index: 9999;
}

.login-wrap{
    height: 100vh;
    justify-content: center;
    background-color: #d8d8d8;
    background-image: url(../img/login-bg.jpg);
    position: relative;
    background-size: cover;
}
.login-wrap::before {
    content: '';
    background-color: rgba(0, 0, 0, 0.5);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
  }
.login-container{
    width: 100%;
    max-width: 780px;
    margin: 0 auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}
.proflow-logo{
    max-width: 320px; margin: auto;
}

.body-wrap{
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-positive: 1;
    flex-grow: 1;
    margin-top: 55px;
}

footer{
    height: 64px;
    text-align: center;
    padding: 8px 12px;
    letter-spacing: 0.05em;
}

.site-title{
    font-size: 24px;
    letter-spacing: 2;
}

main{
    width: 100%;
    background-color: rgb(240, 240, 240);
    min-height: calc(100vh - 55px - 64px);
    min-width: 980px;
    flex: 1;
    padding-left: 0;
    /*transition: 0.6s;*/
}
main.sideopen{
    padding-left: 200px;
}

.content-wrap{
    padding: 24px 16px;
    min-height: calc(100vh - 55px - 64px);
}

/* サイドメニュー */
.side-menu{
    width: 0;
    height: calc(100vh - 55px );
    flex: 1;
    position: fixed;
    z-index: 999;
    /*transition: ease 0.6s;*/
}
.side-menu.open{
    width: 200px;
}
/*.side-menu .nav-li{
  width: 0;
  opacity: 0;
}
.side-menu.open .nav-li{
   width: 100%;
  opacity: 1;
}*/

.nav-li{
    border-bottom: solid 1px #fff;
    position: relative;
    transition: ease-in 0.3s;
    min-height: 53px;
}
.nav-li:hover{
    background-color: #005d6d;
}
.nav-item{
    display: flex;
    align-items:baseline;
    padding: 16px 4px 16px 8px;
    color: #fff !important;
    font-size: 14px;
    cursor: pointer;
}
a.nav-item {
  text-decoration: none;
}
.sub-menu-trigger{
    position: relative;
}
.sub-menu-arrow{
    top: 50%;
    position: absolute;
    right: 12px;
    transform: translateY(-50%) rotate(0deg);
    transition: 0.8s;
    color: #fff;
}
.sub-menu-arrow.spin-rotate{
    transform: translateY(-50%) rotate(-180deg);
}

/* サブメニュー */
.sub-menu{
    width:0;
    height: 0;
    position: fixed;
    left: -120%;
    background-color: #6f8488;
    z-index: 1900;
    padding: 48px;
    transition: ease 1s;
    opacity:0;
}
.sub-menu.active{
  width: 40vw;
  min-width: 400px;
  height: 120vh;
    left: 200px;
    opacity:1;
}

.close-btn{
    cursor: pointer;
}
.side-menu-min-btn{
    width: auto;
    padding: 8px;
    background-color: transparent;
    cursor: pointer;
    transition: 0.6s;
    display: flex;
    justify-content: end;
    border: 1px solid #fff;
    border-radius: 12px;
    color: #fff !important;
    opacity: 1 !important;
}
.side-menu-min-btn:hover{
    background-color: #fff !important;
    color:#1195aa !important;
    opacity: 1 !important;
}
.minimize-icon{
    transform: rotate(180deg);
    transition: 0.6s;
}
.side-menu-min-btn.open .minimize-icon{
    transform: rotate(0deg);
}

/* アイコン */
.fa, .far, .fas{
    min-width: 14px;
    text-align: center;
}


/* win-open */
.winopen-wrap{
    background-color: rgb(240, 240, 240);
    width: 100%;
    padding: 24px 12px;
    min-height: 100%;
}


/* 検索 */
.search-acordion-btn{
    /*position: absolute;
    top: 50%;
    right: 12px;
    transform: translateY(-50%);*/
    display:inline-block;
    background-color: #1195aa;
    color: #fff;
    border: solid 1px #fff;
    padding: 4px 8px;
    border-radius: 12px;
    transition: 0.6s;
    cursor: pointer;
}
.search-acordion-btn:hover{
    background-color: #fff;
    color: #1195aa;
    border: solid 1px #1195aa;
}
.search-angle{
    transform: rotate(0deg);
    transition: 0.6s;
}
.search-angle.spin{
    transform: rotate(180deg);
}
.search-wrap{
    /*background-color: rgb(226, 226, 226);
    padding: 24px 8px;*/
    /*position: absolute;*/
    /*right: 0;
    transition: 0.6s;*/
    width: 100%;
    display: none;
    /*z-index: 1000;*/
}
.search-wrap.close{
    /*right: 200%;*/
}
.search-container{
   /*max-height: 64vh;
   overflow-y: scroll;*/
}
.search-result-wrap{
    /*height: 100%;*/
    position: relative;
}
.search-result-disable{
    position: absolute;
    display: block;
    background-color: rgba(0,0,0,0.6);
    height: 100%;
    width: 100%;
    z-index: 999;
}
.search-result-disable.close{
    display: none;
}
.page-link-btn{
    font-size: 12px;
    padding: 4px;
}
/* 
    ----------------------------------------------------------Setting-------------------------------------------------------------
    色の変更をする場合は下記から変更 
*/
header{
    background-color: #1195aa;
    color: #fff;
}
footer{
    background-color: #414141;
    color: #fff;
}
h2 {
color: #fff;
margin-bottom: 10px;
padding: 2px 10px;
border-left: 10px solid #1195aa;
background-color: #a1a1a1;
font-size: 16px;
}
h3 {
color: #fff;
margin-top: 16px;
margin-bottom: 4px;
padding: 2px 8px;
border-left: 10px solid #11aa3f;
background-color: #474747;
font-size: 14px;
}

.side-menu{
    background-color: #00313a !important;
}
thead{
    background-color: #1195aa;
    color: #fff;
}
tbody{
    background-color: #fff;
}

/* -primary-color */
.text-primary{
    color: #1195aa !important;
}

.bg-primary{
    background-color: #1195aa !important;
    color: #fff !important;
}

.badge-primary{
    background-color: #1195aa !important;
    color: #fff !important;
}

/* btn-primary */
.btn-primary {
    color: #fff !important;
    background-color: #1195aa !important;
    border-color: #1195aa !important;
}
.btn-primary:hover {
    color: #fff !important;
    background-color: #0e7383 !important;
    border-color: #0e7383 !important;
}
.btn-outline-primary {
    color: #1195aa !important;
    background-color: transparent !important;
    border-color: #1195aa !important;
}
.btn-outline-primary:hover {
    color: #fff !important;
    background-color: #1195aa !important;
    border-color: #1195aa !important;
}

/* border-primary */
.border-primary {
    border-color: #1195aa!important;
}

/* page-link */
.page-link-btn{
    border: solid 1px #1195aa!important;
    color: #1195aa;
}
.page-link-btn:hover{
    border: solid 1px #1195aa!important;
    background-color: #1195aa!important;
    color: #fff!important;
}
.page-link-btn.active{
    border: solid 1px #1195aa!important;
    background-color: #1195aa!important;
    color: #fff!important;
}

/*
 * Container style
 */
.ps {
  overflow: hidden !important;
  overflow-anchor: none;
  -ms-overflow-style: none;
  touch-action: auto;
  -ms-touch-action: auto;
}

/*
 * Scrollbar rail styles
 */
.ps__rail-x {
  display: none;
  opacity: 0;
  transition: background-color .2s linear, opacity .2s linear;
  -webkit-transition: background-color .2s linear, opacity .2s linear;
  height: 15px;
  /* there must be 'bottom' or 'top' for ps__rail-x */
  bottom: 0px;
  /* please don't change 'position' */
  position: absolute;
}

.ps__rail-y {
  display: none;
  opacity: 0;
  transition: background-color .2s linear, opacity .2s linear;
  -webkit-transition: background-color .2s linear, opacity .2s linear;
  width: 15px;
  /* there must be 'right' or 'left' for ps__rail-y */
  right: 0;
  /* please don't change 'position' */
  position: absolute;
}

.ps--active-x > .ps__rail-x,
.ps--active-y > .ps__rail-y {
  display: block;
  background-color: transparent;
}

.ps:hover > .ps__rail-x,
.ps:hover > .ps__rail-y,
.ps--focus > .ps__rail-x,
.ps--focus > .ps__rail-y,
.ps--scrolling-x > .ps__rail-x,
.ps--scrolling-y > .ps__rail-y {
  opacity: 0.6;
}

.ps .ps__rail-x:hover,
.ps .ps__rail-y:hover,
.ps .ps__rail-x:focus,
.ps .ps__rail-y:focus,
.ps .ps__rail-x.ps--clicking,
.ps .ps__rail-y.ps--clicking {
  background-color: #eee;
  opacity: 0.9;
}

/*
 * Scrollbar thumb styles
 */
.ps__thumb-x {
  background-color: #aaa;
  border-radius: 6px;
  transition: background-color .2s linear, height .2s ease-in-out;
  -webkit-transition: background-color .2s linear, height .2s ease-in-out;
  height: 6px;
  /* there must be 'bottom' for ps__thumb-x */
  bottom: 2px;
  /* please don't change 'position' */
  position: absolute;
}

.ps__thumb-y {
  background-color: #aaa;
  border-radius: 6px;
  transition: background-color .2s linear, width .2s ease-in-out;
  -webkit-transition: background-color .2s linear, width .2s ease-in-out;
  width: 6px;
  /* there must be 'right' for ps__thumb-y */
  right: 2px;
  /* please don't change 'position' */
  position: absolute;
}

.ps__rail-x:hover > .ps__thumb-x,
.ps__rail-x:focus > .ps__thumb-x,
.ps__rail-x.ps--clicking .ps__thumb-x {
  background-color: #999;
  height: 11px;
}

.ps__rail-y:hover > .ps__thumb-y,
.ps__rail-y:focus > .ps__thumb-y,
.ps__rail-y.ps--clicking .ps__thumb-y {
  background-color: #999;
  width: 11px;
}

/* MS supports */
@supports (-ms-overflow-style: none) {
  .ps {
    overflow: auto !important;
  }
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .ps {
    overflow: auto !important;
  }
}


/*----------------------------------------------------------------------
ツールチップ設定
----------------------------------------------------------------------*/
#tooltip {
	position: absolute;
	z-index: 3000;
	border: 1px solid #111;
	background-color: #eee;
	padding: 2px 5px;
	opacity: 0.85;
}
#tooltip h3, #tooltip div { margin: 0; }
/*----------------------------------------------------------------------
グラフィックマップ設定
----------------------------------------------------------------------*/
div.mapTableH, div.mapTableV {margin:5px;}
div.mapTableH table, div.mapTableV table {
	border-collapse:separate;
	border-spacing:0;
	font-size:9px;
	padding:0;
	margin:0;
}
div.mapTableH table {
	width:100%;
}
div.mapTableH td {
	border:none;
	padding:0;
	margin:0;
	text-align:center;
	vertical-align:top;
}
div.mapTableV td {
	border:none;
	padding:0;
	margin:0;
}
div.mapTableH td.icon{width:auto;}
div.mapTableH td.info{padding:0 2px;}
div.mapTableH td.icon img {border:none;}
div.mapTableV td.icon{width:22px;}
div.mapTableV td.info{width:100px;}
/*足*/
div.mapTableH td.topLeg {border-top:solid 2px #999;}
div.mapTableH td.rightLeg {border-right:solid 1px #999;	height:10px;}
div.mapTableH td.bottomLeg {border-bottom:solid 2px #999;}
div.mapTableH td.leftLeg {border-left:solid 1px #999; height:10px;}
div.mapTableV td.topLeg {border-top:solid 1px #999;	width:10px;}
div.mapTableV td.rightLeg {border-right:solid 2px #999;}
div.mapTableV td.bottomLeg {border-bottom:solid 1px #999; width:10px;}
div.mapTableV td.leftLeg {border-left:solid 2px #999;}

div.mapTableH_s, div.mapTableV_s {margin:5px;}
div.mapTableH_s table, div.mapTableV_s table {
	border-collapse:separate;
	border-spacing:0;
	font-size:5%;
	padding:0;
	margin:0;
}
div.mapTableH_s table {
	width:100%;
}
div.mapTableH_s td {
	border:none;
	padding:0;
	margin:0;
	text-align:center;
	vertical-align:top;
}
div.mapTableV_s td {
	border:none;
	padding:0;
	margin:0;
}
div.mapTableH_s td.icon{width:auto;}
div.mapTableH_s td.info{padding:0 1px;}
div.mapTableH_s td.icon img {border:none;}
div.mapTableV_s td.icon{width:22px;}
div.mapTableV_s td.info{width:100px;}
/*足*/
div.mapTableH_s td.topLeg {border-top:solid 1px #999;}
div.mapTableH_s td.rightLeg {border-right:solid 1px #999;	height:5px;}
div.mapTableH_s td.bottomLeg {border-bottom:solid 1px #999;}
div.mapTableH_s td.leftLeg {border-left:solid 1px #999; height:5px;}
div.mapTableV_s td.topLeg {border-top:solid 1px #999;	width:5px;}
div.mapTableV_s td.rightLeg {border-right:solid 1px #999;}
div.mapTableV_s td.bottomLeg {border-bottom:solid 1px #999; width:5px;}
div.mapTableV_s td.leftLeg {border-left:solid 1px #999;}
table.linkToolTip {
	word-break:break-all;
	width:330px;
}
table.linkToolTip td {
	text-align:center;
	border:none;
}
div.map_info {
	position: fixed;
	top:0px; 
	left:0px;
	z-index: 3000;
	padding:15px;
	border: 1px solid #111;
	background-color: #eee;
}
div.map_info2 {
	position: fixed;
	top:0px; 
	right:0px;
	z-index: 3000;
	padding:15px;
	border: 1px solid #111;
	background-color: #eee;
}
div.map_info_TL {
	position: fixed;
	top:20px;
	left:230px;
	z-index: 10000;
	padding:15px;
	border: 1px solid #111;
	background-color: #eee;
}
div.map_info_TR {
	position: fixed;
	top:20px; 
	right:30px;
	z-index: 10000;
	padding:15px;
	border: 1px solid #111;
	background-color: #eee;
}
div.map_info_BL {
	position: fixed;
	bottom:10px; 
	left:0px;
	z-index: 3000;
	padding:15px;
	border: 1px solid #111;
	background-color: #eee;
}
div.map_info_BR {
	position: fixed;
	bottom:10px; 
	right:0px;
	z-index: 3000;
	padding:15px;
	border: 1px solid #111;
	background-color: #eee;
}
div.map_info_none {
	display: none;
}
div.treemap {}
div.treemap table{border-collapse:collapse; padding:0;margin:0;border:solid 0px #aaf;}
div.treemap td{border:solid 0px #faa; empty-cells: show; padding:0; vertical-align:middle; height:1em;}
div.treemap td.borderR{border-right:solid 2px #999 !important; width:7px;} 
div.treemap td.borderB{border-bottom:solid 2px #999 !important; width:30px;}
div.treemap td p.nyukin{margin-left:30px;line-height:1em !important;font-size:0.9em;}
ul.treelist li {line-height:2em;}
/*ツールチップ*/
table.mapIconToolTip {
	word-break:break-all;
	width:450px;
}
table.mapIconToolTip th {
	width:250px;
	text-align:left;
	border:none;
}
table.mapIconToolTip td {
	text-align:right;
	border:none;
}
table.mapIconToolTip td.th {
  width:250px;
  text-align:left;
}
table.linkToolTip {
	word-break:break-all;
	width:330px;
}
table.linkToolTip td {
	text-align:center;
	border:none;
}
div.treemap {}
div.treemap table{border-collapse:collapse; padding:0;margin:0;border:solid 0px #aaf;}
div.treemap td{border:solid 0px #faa; empty-cells: show; padding:0; vertical-align:middle; height:1em;}
div.treemap td.borderR{border-right:solid 2px #999 !important; width:7px;} 
div.treemap td.borderB{border-bottom:solid 2px #999 !important; width:30px;}
div.treemap td p.nyukin{margin-left:30px;line-height:1em !important;font-size:0.9em;}
div.treemap img{border:none;}
ul.treelist li {line-height:2em;}
/*vertical-align:top;background:url(../img/map/line.gif) no-repeat 0 0;*/
/*---------------------------------------------------------------------
カテゴリツリー設定
---------------------------------------------------------------------*/
div.categoryTreeView table, div.categoryTreeView th, div.categoryTreeView td {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	width: auto;
}
.aspNetDisabled {
	pointer-events: none;
}
/*---------------------------------------------------------------------
スケジュール設定
---------------------------------------------------------------------*/
table.calendar {
    margin-top:5px;
    margin-bottom:5px;
	border-collapse:collapse;
	border-spacing:0;
	border-top:2px solid #bebebe;
	border-bottom:4px solid #bebebe;
}
table.calendar td.calendarHeader {
    background:#bebebe;
}
table.calendar td {
	border:1px solid #bebebe;
	padding:0px;
	vertical-align:top;
}
table.calendar th {
	border:1px solid #bebebe;
	padding:0px;
	font-weight:normal;
	text-align:center;
  color: #fff;
	background-color :#1195aa;
	width:14.2857143%;
  font-weight: bold;
}
table.calendar th.sunday {background-color:#f72f2f;}
table.calendar th.saturday {background-color:#2c4fd2;}
table.calendar th.holiday {background:#FFEFE5 url(../img/bg_slash.gif) repeat left top;}
table.calendar th.today {background:#FFF5D8 url(../img/bg_slash.gif) repeat left top;}
table.calendar div.calendarDay {
	color:#fff;
	margin:0px;
	padding:0px 2px 0px 2px;
	vertical-align:top;
	overflow:hidden;
	height:100%;
  font-weight: bold;
}
table.calendar td.day {background-color:#41bdd0;border-bottom:none;}
table.calendar td.sunday2 {background-color:#ff9270;}
table.calendar td.saturday2 {background-color:#778be0;}
table.calendar td.holiday2 {background-color:#ff7c52;}
table.calendar td.off2 {background-color:#929292;}
div.sunday,td.sunday {background-color:#FFEFE5;}
div.saturday,td.saturday {background-color:#EBF0F6;}
div.holiday,td.holiday {background-color:#FFEFE5;}
div.today,td.today {background-color:#fff6c8;}
div.off,td.off {background-color:#DDDDDD}
table.calendar div.calendarBody {
	height:60px;
}
table.calendar div.calendarFooter {
	height:17px;
}
div.calendarScheduleDiv {
	padding-right:1px;
	padding-left:1px;
    padding:2px;
    clear:both;
}
div.calendarScheduleDiv p {
	line-height:1em!important;
}
div.calendarScheduleDiv img {
	border:none;
}
div.calendarScheduleDiv div.small {font-size:0.95em;line-height:1.2;}
div.calendarScheduleDiv div.time {
	white-space:pre;
	height:14px;
}
div.calendarScheduleDiv a:link,
div.calendarScheduleDiv a:visited {
    display:block;
	text-decoration:none;
	padding:1px;
}
div.calendarScheduleDiv a:hover {
    background-color:#FFFFE5;
	border:1px solid #FF9900;
	text-decoration:none;
	padding:0px;
}
table.calendar td.term {
    border-top:none;
	border-bottom:none;
}
table.calendar div.calerndarTermScheduleDiv {
    padding:0px;
    font-weight:normal;
    text-align:center;
	border:1px solid #99cc99;
	background-color:#DDFFDD;
	overflow:hidden;
}
table.calendar td.topNone {
	border-top:none;
}
div.calerndarTermScheduleDiv a:link,
div.calerndarTermScheduleDiv a:visited {
    display:block;
    text-decoration:none;
    padding:1px;
}
div.calerndarTermScheduleDiv a:hover {
    background-color:#FFFFE5;
    border:1px solid #FF9900;
    text-decoration:none;
    padding:0px;
}
/*---------------------------------------------------------------------
ボタン
---------------------------------------------------------------------*/
a.action {
	background-image: url(../img/arrow_action.png); 
	background-repeat: no-repeat;
	padding-left:18px;
}
a.copy {
	background-image: url(../img/button_copy.gif); 
	background-repeat: no-repeat;
	padding-left:18px;
}
/*---------------------------------------------------------------------
コミッション履歴
---------------------------------------------------------------------*/
table.commissionHistory {
	border-collapse:collapse;
	border-spacing:0;
	line-height:1.8em;
	width:auto;
  white-space: nowrap;
}
table.commissionHistory table td,
table.commissionHistory table th{
  height:30px;
}
td.commissionHistoryTitle {
	/*width:160px;*/
	padding:0;
	/*background-color:#eee;*/
}
td.commissionHistoryTitle table {
	border-collapse:collapse;
	border-spacing:0;
	line-height:1.8em;
	width:100%;
  white-space: nowrap;
}
td.commissionHistoryTitle table th {
	font-weight:normal;
	line-height:1.8em;
	border:1px solid #bebebe;
	padding:1px;
	vertical-align:middle;
  background-color:#f2fdff;
}
table.commissionHistory .thRowspan{
	width:14px;
	text-align:center;
	/*border-bottom:3px solid #eee;*/
}
table.commissionHistory .thRowspan2{
  width:14px;
	text-align:center;
  border-left-style:none;
  border-right-style:none;
  /*border-bottom:3px solid #eee;*/
}
td.commissionHistoryDetail {
	width:200px;
	padding:0;
}
td.commissionHistoryDetail table {
	border-collapse:collapse;
	border-spacing:0;
	line-height:1.8em;
	width:100%;
  white-space: nowrap;
}
td.commissionHistoryDetail table td {
	line-height:1.8em;
	border:1px solid #bebebe;
	padding:1px;
	vertical-align:middle;
}

table.confirm_table table {
	width:100%;
	border-collapse:collapse;
}
table.confirm_table td {
	padding:5px;
	border:1px solid #999;
}
table.confirm_table p.title 
{
	font-weight:bold;
	font-size:14px;
}
table.confirm_table p.desc 
{
	padding-left:15px;
}
/*リッチテキストエディタ用リセット*/
div.freeTextBox table,
div.freeTextBox table td,
div.freeTextBox table th {
	margin: 0;
	padding: 0;
	border: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 100%;
	width:auto;
}
table.commissionHistory td,table.commissionHistory th{
  height:2em;
  /*width: 200px;*/
}
.alternationRow {background-color:#f2fdff !important;}
.text-muted {
  color: #666 !important;
}