@charset "utf-8";
/**********************************
/*--- リセット ------------------*/
* {margin: 0;padding: 0;}
ul, ol {list-style: none;}
img {vertical-align: middle;border: 0;}
button {font-size: 100%;}
blockquote, q {quotes: none;}
blockquote:before, blockquote:after, q:before, q:after {
	content:'';
	content:none;
}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section {display:block;}

/*--- 全体定義 ------------------*/
html {
	font-family: '-apple-system', 'BlinkMacSystemFont','Hiragino Sans','Hiragino Kaku Gothic ProN',"segoe ui",'游ゴシック  Medium','メイリオ', Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
	font-size : 90%;
	line-height : 1.5;
	color: #333;
}

body {
	-webkit-text-size-adjust: 100%;
	margin: 0;
	padding: 0;
/*--- 各店で背景色変更 -------*/
	background:#fff;
}
img {max-width: 100%!important;height: auto;}
a {
    text-decoration: none;
    color: #00008b;
}
#wrapper{
	margin:0px auto 2em;
}
table{
	border-collapse: separate;
	border-spacing: 0px;
	border-top:1px solid #000;
	border-left:1px solid #000;
	background: #fff;
}
th,td{
	padding:2px 5px;
	border-bottom:1px solid #000;
	border-right:1px solid #000;
}
header{
	padding:10px 5px;
	margin:0 0 1em;
	border-bottom:2px solid #006400;
}
header h1{
	font-size:110%;
	margin:0 0 10px;
	width: 100%;
}
footer{
	margin: 2em 0;
	border-bottom: 2px solid #006400;
}
.header-list{
	display: flex;
	justify-content: flex-end;
	text-align: right;
	width: 100%;
}
.bt-list{
	display: flex;
}
.bt-list li, .header-list li{
	margin-right:7px;
}
.bt-list li:last-child, .header-list li:last-child{
	margin-right:0px;
}
.bt-list a, .header-list a{
	display:inline-block;
	padding:2px 5px;
	border:1px solid #00008b;
	border-radius:4px;
}
article, section{
	margin:0 5px 2em;
}
article h2, section h2, section h3{
	font-size:110%;
	margin:0 0 10px;
	padding: 5px;
	border-bottom: 3px solid #000;
	background: #696969;
	color:#fff;
}
form.data-switch {
    margin: 0 0 1em;
    font-size: 120%;
}
form.data-switch label{
	color: #000;
}
#day_date{
	font-size: 120%;
}
.red{
	color:#ff0000;
}
.yellow {
    background: rgba(0,0,0,0) linear-gradient(transparent 50%,#ff0 0) repeat scroll 0 0;
    font-weight: bold;
    color: #595959;
}
.bold{
	font-weight:bold;
}
.big{
	font-size:110%;
}
.text-right{
	text-align: right;
}
.bottom-margin{
	margin:0 0 5px;
}
.center{
	margin:0 auto;
	text-align: center;
}
.bg-rose{
	background: #ffe4e1;
}
.bg-lightyellow th, .bg-lightyellow td{
	background: #ffffe0;
}
.slide-btn {
  display: block;
  width: 200px;
  margin: 0 auto 1em auto;
  text-align: center;
  padding: 7px;
  border: none;
  color: #000;
  border-radius: 20px;
  background: #ffe4e1;
  cursor: pointer;
}
.slide-btn2 {
  display: inline-block;
  margin: 0 auto 1em auto;
  text-align: center;
  padding: 2px 20px;
  background: none;
  border: 1px solid #282828;
  color: #000;
  border-radius: 3px;
  cursor: pointer;
}
.slide-btn:first-letter,.slide-btn2:first-letter {
  font-weight: bold;
  margin-right: 2px;
}

.slide-contents {
  width: 100%;
  margin: 0 0 1.6em 0;
  display: none;
}
.slide-contents table{
	width: 100%;
}
.slide-contents th{
	background:#fffacd;
	text-align:center;
}
.border-none{
	border:none;
}
/*--- ログイン画面 ------------------*/
.login_form {
    max-width: 600px;
    margin: 2em auto;
    padding: 10px;
    border: 1px solid #000;
    border-radius: 6px;
    background: #fff;
}
/*--- ボタンデザイン ------------------*/
button {
    cursor: pointer;
    border: 1px solid #282828;
    border-radius: 3px;
    color: #000;
    font-weight: normal;
}
.btn-sm{
	padding: 0 5px;
    background: #7fffd4;
}
.btn-change{
	padding: 0 5px;
    background: #808000;
    color: #fff;
}
.btn-bm{
	color:#fff;
	padding: 2px 20px;
    background: #4169e1;
}
.btn-yellow{
	padding: 0 5px;
    background: #ffff00;
}
.btn-blue{
	padding: 0 5px;
    background: #1e90ff;
    color:#fff;
}
/*--- タブ切り替え ------------------*/
.tab-wrap {
  display: flex;
  flex-wrap: wrap;
  margin:20px 0;
}
.tab-wrap:after {
  content: '';
  width: 100%;
  height: 3px;
  background: DeepSkyBlue;
  display: block;
  order: -1;
}
.tab-label {
  color: White;
  background: LightGray;
  font-weight: bold;
  text-shadow: 0 -1px 0 rgba(0,0,0,.2);
  white-space: nowrap;
  text-align: center;
  padding: 2px .5em;
  order: -1;
  position: relative;
  z-index: 1;
  cursor: pointer;
  border-radius: 5px 5px 0 0;
  flex: 1;
}
.tab-label:not(:last-of-type) {
  margin-right: 5px;
}
.tab-content {
  width: 100%;
  height: 0;
  overflow: hidden;
  opacity: 0;
  background: #fff;
}
/* アクティブなタブ */
.tab-switch:checked+.tab-label {
  background: DeepSkyBlue;
}
.tab-switch:checked+.tab-label+.tab-content {
  height: auto;
  overflow: auto;
  padding: 15px;
  opacity: 1;
  transition: .5s opacity;
  box-shadow: 0 0 3px rgba(0,0,0,.2);
}
/* ラジオボタン非表示 */
.tab-switch {
  display: none;
}
/*--- パンクズ ------------------*/
.pankuzu ul{
	display: flex;
    margin: 0 0 10px;
}
.pankuzu ul li{
	margin-left: 5px;
}
.pankuzu ul li a{
	text-decoration: underline;
	color: #0000cd
}
/*--- トップ ------------------*/
article .bt-list, section .bt-list{
	margin:1em 0;
}
.top-profit-box{
	display: flex;
	flex-wrap: wrap;
}
.top-profit-box table{
	width:100%;
	margin: 0 0 1em;
}
.totlal-table, profit-table{
	width:100%;
}
.totlal-table th, .profit-table th{
	background:#fffacd;
}
.profit-table table{
	width:100%;
	margin:0 0 1em;
}
.fix-cost-table{
	width:100%;
}
.today-table{
	margin:0 0 2em;
}
.today-table th, .fix-cost-table th{
	background:#ffe4e1;
}
.today-table .left-colum{
	margin:0 0 10px;
}
.today-table .right-colum{
	display: flex;
	align-items: flex-start;
}
.today-table .right-colum .cost2{
	margin-left:10px;
}
.blank-line{
	height:1em;
	background:#b0c4de;
}
.err-table{
	margin:0 0 1em;
}
.err-table tr{
	background: #fff0f5;
}
.visti-table{
	display: block;
	overflow-x: scroll;
	white-space: nowrap;
	-webkit-overflow-scrolling: touch;
}
.visti-table table tbody {
	width: 100%;
	display:table;
}
.visti-table table{
	position: relative;
}
.ng_time{
	background: #ffe4e1;
}
.visti-table th{
	background:#e6e6fa;
	position: sticky;
	top: 0;
}
.tab-content table tr:nth-of-type(3n),
table.cost tr:nth-of-type(3n),
.slide-contents table tr:nth-of-type(3n){
	background: #ffffe0;
}
.hide{
	background: #c0c0c0 !important;
}
.m-bt{
	display: flex;
}
.m-bt li{
	margin-right:5px;
}
.m-bt li:last-child{
	margin-right:0px;
}
.g_list{
	display: flex;
    flex-wrap: wrap;
    margin:10px 0;
}
.g_list li{
	text-align: center;
	border: 1px solid #000;
    border-radius: 6px;
    box-sizing: border-box;
    margin: 0 5px 10px 0;
}
.g_list li a{
	display: block;
    padding: 5px 10px;
}
.modal_form table{
	margin:0 auto;
	width: 100%;
	border-top:none;
	border-left:none;
}
.modal_form caption{
	font-size: 120%;
	font-weight: bold;
    margin: 0 0 10px;
}
.modal_form th{
	text-align:left;
}
.modal_form th, .modal_form td {
	border-right:none;
	padding:10px;
}
.flex-bt-list{
	display: flex;
}
.flex-bt-list li{
	margin:0 5px 10px 0;
}
.flex-bt-list li button{
	padding: 3px 10px;
}
/*--- カードで追加 ---------------------------------------------------------------*/
.card{
	background: #fffacd;
	color: #ff0000;
}
.card-title{
	background: #ff4500;
    padding: 5px;
    margin: 10px 0;
    color: #fff;
    font-weight: bold;
    text-align: center;
}
.ng-add{
	border: none !important;
	outline: none;
}
.blank{
	display: none;
}
.flex{
	display: flex;
}
.flex li{
	margin-right:5px;
}
.flex li:last-child{
	margin-right:0;
}
/*--- 下層ページ ------------------*/
.sub_page {
    max-width: 640px;
    margin: 0 auto;
    padding: 10px;
    border: 1px solid #000;
    border-radius: 6px;
    background: #fff;
}
.flex {
	display: flex;
}
.space-between{
	justify-content: space-between;
}
.salary_table{
	width:100%;
	padding: 10px;
	margin: 0 0 1em;
	box-sizing: border-box;
}
.salary_table table{
	width:100%;
}
.salary_table table.course{
	margin:0 0 5px;
}
.salary_table table.course th{
	background:#e0ffff;
}
.salary_table table.other th{
	background:#fffff0;
}
.total-salary{
	text-align: center;
    font-size: 120%;
    font-weight: bold;
    border: 1px solid #000;
    margin: 0 0 2em;
    padding: 10px;
    background-color: #f8f8ff;
    background-image: repeating-linear-gradient(-45deg, #fff, #fff 7px, transparent 0, transparent 10px);
}
.name-title{
	border-bottom:2px solid #a9a9a9;
}
.link-area a{
	display: inline-block;
    background: #4169e1;
    margin: 0 auto;
    color: #fff;
    padding: 5px 15px;
}
.check-list{
	display: flex;
    flex-wrap: wrap;
}
.check-list li{
	border: 1px solid #000;
    border-radius: 4px;
    padding: 5px;
    margin: 0 10px 10px 0;
}
.check-list label, input[type='checkbox'] {
    cursor: pointer;
    margin-right: 5px;
}
.rank-area{
	display: flex;
	justify-content: space-around;
	margin: 0 0 1em;
}
/*--- form系 ------------------*/
.new_customers input,.new_customers select,
.c_customers input,.c_customers select
{
	padding:2px;
	font-size:16px;
}
.w50{
	max-width: 100px;
}
.new_customers .w100,
.c_customers .w100
{
	width:100%;
	box-sizing: border-box;
	max-width: 200px;
}
.w200{
	max-width: 300px;
}
#password{
	width: 100%;
    box-sizing: border-box;
    max-width: 120px;
    margin-right: 5px;
}
.new_customers #g_rate,
.new_customers #nomination_fee_g,
.new_customers #nomination_fee_shop,
.new_customers #total_fee,
.new_customers #g_pay,
.new_customers #shop_gain,
.c_customers #g_rate,
.c_customers #c_nomination_fee_g,
.c_customers #c_nomination_fee_shop,
.c_customers #total_fee,
.c_customers #g_pay,
.c_customers #shop_gain
{
	background: #f5f5f5;
    border: 1px solid #696969;
}
.ridio_area{
	margin: 0 auto 10px;
    text-align: center;
}
.ridio_area label{
	margin-right: 10px;
}
.ridio_area label:last-child{
	margin-right: 0;
}

.btn-cansel{
	padding: 2px 20px;
}
.btn-enter{
	padding: 2px 20px;
    background: #98fb98;
}
a.btn-enter{
	display: block;
    cursor: pointer;
    border: 1px solid #282828;
    border-radius: 3px;
    color: #000;
}
.btn-link{
	padding: 2px 20px;
    background: #fffaf0;
}
.btn-red{
	padding: 2px 20px;
    background: #dc143c;
    color:#fff;
}
.bt_form button{
	font-size: 90%;
    padding: 0 5px;
    margin: 5px 0;
    background: #f5f5f5;
}
.bt_right ul{
	display: flex;
    justify-content: flex-end;
    margin: 0 0 10px;
}
.bt_right ul li{
	margin-left: 10px;
}
.bt_center ul{
	display: flex;
    justify-content: center;
    margin: 0 0 10px;
}
.bt_center ul li{
	margin-right: 10px;
}
.bt_center ul li:last-child{
	margin-right: 0;
}
.modal_form {
	max-width:700px;
}
.form_flex{
	display: flex;
	align-items: center;
	border-bottom:1px solid #000;
	padding: 0 0 10px;
    margin: 0 0 10px;
}
.form_flex dt{
	width:35%;
}
.form_flex dd{
	width:65%;
}
.auto-title{
	padding:10px 0;
	margin:0 auto 10px;
	text-align:center;
}
#g_rate, #therapist_back{
	width:35px;
}
input.auto-input{
	background:#fffaf0;
}
.form-bt{
	text-align:center;
	margin: 1em 0;
}
.required{
	background:#dc143c;
	color:#fff;
	font-size:90%;
	font-weight: normal;
	border-radius:4px;
	padding:0 5px 2px;
	margin:0 0 0 2px;
}
.atention{
	font-size: 85%;
    color: #ff0000;
}
.item-err{
	color: #ff0000;
}

/*--- モーダルCSS ------------------*/
.modalArea {
	display: none;
	position: fixed;
	z-index: 10;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.modalBg {
	width: 100%;
	height: 100%;
	background-color: rgba(30,30,30,0.9);
}

.modalWrapper {
	position: absolute;
	top: 50%;
	left: 50%;
	transform:translate(-50%,-50%);
	width: 85%;
	max-width: 600px;
	padding: 10px;
	background-color: #fff;
	border-radius: 6px;
	height : 90%;
	overflow : auto;
}
.minimodal{
	height : 30% !important;
}
.modalContents h1{
	font-size: 130%;
    margin: 0 0 1em;
    border-bottom: 1px solid #000;
    text-align: center;
}
.closeModal {
	position: absolute;
	top: 0.5rem;
	right: 1rem;
	cursor: pointer;
}
/*--- 別ページ開くモーダルCSS ------------------*/
#mdOverlay {
	top: 0;
	left: 0;
	width: 100%;
	position: fixed;
	z-index: 97;
	background: #000;
	display: none;
}

#mdWindow {
	margin-top: -200px;
	margin-left: -250px;
	top: 50%;
	left: 50%;
	width: 500px;
	height: 450px;
	position: fixed;
	z-index: 98;
	background: #fff;
	display: none;
}

#mdWindow > .mdClose {
	top: -15px;
	right: -15px;
	width: 30px;
	height: 30px;
	line-height: 30px;
	color: #fff;
	font-size: 1.5em;
	text-align: center;
	background: #757575;
	border-radius: 30px;
	position: absolute;
	z-index: 99;
	cursor: pointer;
	box-shadow: 0 0 3px 0 #000;
}

#modalInclude {
	display: none;
}

#contWrap {
	margin: 30px auto;
	padding: 0 20px;
	width: 100%;
	height: 100%;
	border: none;
	box-sizing: border-box;
	overflow-y: auto;
}

#modalWrapper h2 {
	margin-bottom: 20px;
	padding: 20px 0;
	font-size: 1.2em;
	font-weight: bold;
	text-align: center;
	border-bottom: #333 1px dotted;
}

#modalWrapper p {
	padding-bottom: 2em;
	font-size: 1em;
}

/*--- ページネーション ------------------*/
ul.pagination{
	display: flex;
	margin: 10px 0;
}
ul.pagination li{
	box-sizing: border-box;
}
ul.pagination li a{
	display:block;
	padding:0 7px;
	border:1px solid #a9a9a9;
}
ul.pagination .active_page{
	background: #007bff;
	color:#fff;
	padding:0 7px;
	border:1px solid #a9a9a9;
}
/********** widht 768px以上 ********************************/
@media screen and (min-width : 768px) {
header{
	display: flex;
	justify-content: space-between;
}
header h1 {
    margin: 0;
    width: 50%;
}
.header-list{
	width: 50%;
}
.totlal-table{
	width:50%;
	padding-right: 10px;
}
.profit-table{
	width:70%;
}
.fix-cost-table{
	width:50%;
}
.visti-table{
	overflow-x: inherit;
}
.today-table{
	display: flex;
}
.today-table .left-colum{
	margin:0 10px 10px 0;
}
.ridio_area{
    text-align: left;
}
form.data-switch {
    font-size: 110%;
}
/********** widht 768px以上 ********************************/
}

/********** widht 888px以上 ********************************/
@media screen and (min-width : 888px) {

.totlal-table{
	width:45%;
}
.fix-cost-table{
	width:45%;
}
/********** widht 888px以上 ********************************/
}