@charset "UTF-8";/* CSS Document */

body{font-family: 'Noto Sans JP', sans-serif; font-size:15px; line-height:1.5;background: linear-gradient(90deg,#DED3B7 0%,#DED3B7 220px,white 100px,white 100%);}



a{transition: background-color 1s;}
a:hover{transition: background-color 1s;text-decoration:none;}
header{background:#606060; display:flex;justify-content: space-between;align-items: center; padding:8px 20px; color:#FFF;}
header .linktop{font-size:14px;}
header > div{display: flex;
    flex-direction: column;align-items: flex-end;}
header .main-title{font-size:14px; margin-bottom:3px;}
header .main-title span{font-size:18px; margin-left:10px;}
header .display-name{}
header .display-name span{background:#FFF; color:#222; font-size:13px;padding:2px 10px; border-radius:25px;  }
.stage{}
main{display:flex;justify-content: space-between;  }
.contents{ margin-right:20px; padding-top:20px; padding-bottom:120px;width: calc(100% - 270px);}

.table th{background:#DED3B7;}
.table td{vertical-align:middle;}
.btn-sm{ padding:3px 5px; font-size:12px;}
input.large[type=checkbox] {
    transform: scale(2.0); margin-right:20px;}
label{cursor:pointer;}

h1 {
  position: relative;
  padding: 0.6em;
  background: #BA9C38;
  font-size:24px;
  margin-bottom:20px;
  color:#FFF;
}

h1:after {
  position: absolute;
  content: '';
  top: 100%;
  left: 30px;
  border: 15px solid transparent;
  border-top: 15px solid #BA9C38;
  width: 0;
  height: 0;
}
.master th{white-space:nowrap;}




/*==============================
グローバルナビ
==============================*/
.gnav{
	width: 220px;
	min-width: 220px;
	background-color: #DED3B7;
	line-height:1;
	overflow:hidden;
	
}

.gnav .logo{
	width: 80px;
	height: auto;
	position: fixed;
    bottom: 20px;
    left: 120px;
}
.gnav ul{}
.gnav ul li{	
	font-size:15px;

}

.gnav ul li.title{
	padding-left: 20px;
	color: #FFF;
	background-color: #BA9C38;
	padding-top:15px;
	padding-bottom:15px;
	font-weight:bold;
	font-size:17px;
}

.gnav ul li a{
	color: #222;
	display: block;
	padding-top: 10px;
	padding-right: 10px;
	padding-bottom: 10px;
	padding-left: 20px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #516070;
	transition: background-color 1s;



}
.gnav ul li a:hover{
	background-color: #c6b372;
	text-decoration:none;


}
.gnav ul li ul{
	background-color: #CCC;
}
.gnav ul li ul li{border:none;}
.gnav ul li.active a{
	background-color: #FFF;
	color:#222;
}
.gnav ul li ul li a{
	border: none;
	padding-top: 15px;
	padding-right: 10px;
	padding-bottom: 15px;
	padding-left: 60px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #516070;
	transition: background-color 0.7s;


}


.gnav ul li .fas{margin-right:10px; width:30px; text-align:center;}

.gnav .acd-check{
    display: none;
}
.gnav .acd-label{
    color: #222;
    display: block;
	padding-top: 12px;
	padding-right: 10px;
	padding-bottom: 12px;
	padding-left: 20px;
    position: relative;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #516070;
	margin:0px;
	transition: background-color 1s;
	transition: border-color 0.9s;

}
.gnav .acd-label:hover{	background-color: #c6b372;
		padding-left: 20px;
}
.gnav .acd-label:after{
    box-sizing: border-box;
    content: '\f067';
    display: block;
    font-family: "Font Awesome 5 Free";
    position: absolute;
    right: 20px;
    top: 13px;
	font-weight:bold;
	
	
}
.gnav .acd-content{
    display: block;
    height: 0;
    opacity: 0;
    transition: .2s;
    visibility: hidden;
}
.gnav .acd-check:checked + .acd-label:after{
    content: '\f068';
	


}
.gnav .acd-check:checked + .acd-label + .acd-content{
    height: auto;
    opacity: 1;
    visibility: visible;
}







/*==============================
キービジュアル
==============================*/
.kv-wrap{overflow:hidden; height:100%;}
.kv{ min-height: 100vh;background-repeat: no-repeat;background-size: cover;background-position: left 0px top;background-image: url(/image/kv.jpg);}
.kv-copy {
  position: absolute;
  top: min(4.5833333333vw, 88px);
  left: min(9.8958333333vw, 190px);
  width: min(35.9895833333vw, 691px);
  height: auto;
  z-index: 11;
}
.kv-copy img{max-width:100%;}

.kv .message{ position:absolute; top:20px; right:50px; display:flex; padding:10px 20px;align-items: center; text-align:center; border:solid 1px #222;font-family: 'Noto Serif JP', serif; width:50%;}
.kv .message h3{font-size:20px; white-space:nowrap;}
.kv .message i{font-size:26px; color:#8ca284;}
.kv .message .text{ margin-top:10px; margin-bottom:10px; border-left:solid 1px #222; padding-left:20px; padding-right:20px; margin-left:20px; text-align:left;text-align:center;}

.login{width:500px; margin:0 auto; position: absolute;    top: 40%;    left: 50%;    transform: translateX(-50%);background-color: rgba( 255, 255, 255, 0.8 ); padding:20px; text-align:center;}
.login h1{color:#305d2a; background:none;font-size:30px; font-weight:500; margin-bottom:0px; padding:0px;}
.login h1:after{content:none;}

.login .ic-id{position:absolute;    top: 100px;    right: 23%;z-index: 2;}
.login .ic-id i{font-size:20px; color:rgba( 0, 0, 0, 0.6 );}
.login .ic-pw{position:absolute;    top: 160px;    right: 23%;z-index: 2;}
.login .ic-pw i{font-size:20px; color:rgba( 0, 0, 0, 0.6 );}
.login form {
    padding: 20px 0;
    position: relative;
    z-index: 2;
  }
.login form input {
    -webkit-appearance: none;
      -moz-appearance: none;
            appearance: none;
    outline: 0;
    border: 1px solid rgba(255, 255, 255, 0.4);
    background-color: rgba(48, 93, 42, 0.6);
    width: 300px;
    border-radius: 3px;
    padding: 10px 15px;
    margin: 0 auto 10px auto;
    display: block;
    text-align: center;
    font-size: 18px;
    color: #FFF;
    transition-duration: 0.25s;
    font-weight: 300;
  }

.login input::placeholder {
  color: #cdd;
}
.login  form input:focus {
    background-color: #305d2a;
    width: 350px;
    color: #FFF;
  }
.login  form button {
            appearance: none;
    outline: 0;
    background-color: #305d2a;
    border: 0;
    padding: 10px 15px;
    color: #FFF;
    border-radius: 25px;
    width: 250px;
    cursor: pointer;
    font-size: 18px;
    transition-duration: 0.25s;
  }
.login  form button:hover {
    background-color: #1a3200;
  }
  
.kv .foot{position: absolute;    bottom: 20px;    left: 50%;    transform: translateX(-50%); text-align:center; color:#FFF;}
.kv .foot span{margin-left:10px; font-size:24px;}






/*==============================
シフト管理
==============================*/
.schedule{}
.schedule .area{display:flex;    align-items: flex-start; margin-bottom:40px;}
.schedule .area .title{font-size:30px;font-family: 'Noto Serif JP', serif; padding-left:10px; margin-right:40px; font-weight:bold; white-space:nowrap;}
.schedule .area .facility-name ul{display:flex;flex-wrap: wrap;}
.schedule .area .facility-name li a{display:block;border-radius:25px; padding:8px 0px;box-shadow: 2px 2px 2px #CCC; margin-right:20px; border:solid 1px #CCC; font-weight:bold; width:180px; text-align:center; margin-bottom:20px;}
.schedule .area .facility-name li a:hover{ color:#FFF !important; }



.schedule .area.area01 .title{border-left:10px solid #AF4424;}
.schedule .area.area01 .facility-name li a{ color:#AF4424; }
.schedule .area.area01 .facility-name li a:hover{ background:#AF4424; }

.schedule .area.area02 .title{border-left:10px solid #7B2A72;}
.schedule .area.area02 .facility-name li a{ color:#7B2A72; }
.schedule .area.area02 .facility-name li a:hover{ background:#7B2A72; }

.schedule .area.area03 .title{border-left:10px solid #1E7C7D;}
.schedule .area.area03 .facility-name li a{ color:#1E7C7D; }
.schedule .area.area03 .facility-name li a:hover{ background:#1E7C7D; }

.schedule .area.area04 .title{border-left:10px solid #A11B64;}
.schedule .area.area04 .facility-name li a{ color:#A11B64; }
.schedule .area.area04 .facility-name li a:hover{ background:#A11B64; }

.schedule .area.area05 .title{border-left:10px solid #2072A7;}
.schedule .area.area05 .facility-name li a{ color:#2072A7; }
.schedule .area.area05 .facility-name li a:hover{ background:#2072A7; }

.schedule .area.area06 .title{border-left:10px solid #45582C;}
.schedule .area.area06 .facility-name li a{ color:#45582C; }
.schedule .area.area06 .facility-name li a:hover{ background:#45582C; }

.schedule .header{background:#efefef; padding:20px 0px;margin-bottom:20px;}
.schedule .header .name{display:flex;justify-content: center;}
.schedule .header .name ul{
	display: flex;
	align-items: center;
	border: solid 1px #CCC;
	border-radius: 25px;
	margin-bottom: 20px;
	background: #FFF;
	padding-top: 0px;
	padding-right: 25px;
	padding-bottom: 0px;
	padding-left: 10px;
}
.schedule .header .name ul li{ padding:5px 20px; text-align:center; font-size:20px;}
.schedule .header .name ul li:first-child{border-left:none !important;}
.schedule .header .name ul li.title{border-right:dashed 1px #CCC; border-left:solid 1px #CCC; font-weight:bold; font-size:22px;}


.schedule .header .name ul li.type {
    background: #BA9C38;
    color: #FFF;
    font-weight: bold;
    border-radius: 3px;
    text-align: center;
	height: 25px;
	width: 25px;
    line-height: 25px;
    font-size: 15px;
	padding:0px;
}




.schedule .header .date{display:flex;justify-content: center;align-items: center;}
.schedule .header .date ul{display:flex;align-items: center;}
.schedule .header .date ul li{font-weight:bold;}
.schedule .header .date .month{ font-size:50px; margin-right:100px; margin-left:100px; font-weight:bold; line-height:1;}
.schedule .header .date .month span{ font-size:30px; margin-right:20px;    margin-top: 5px;}
.schedule .header .date .month a{display:block;display:flex;align-items: center;}
.schedule .header .date .month a:hover{cursor:pointer;}
.schedule .header .date i{color:#BA9C38;font-size:50px;}

.schedule table th, .schedule table td{ font-size:14px; }
.schedule table td{vertical-align: top;}
.schedule table th.date{width:20px; text-align:center; background:#FFF;}
.schedule table th.date span{display:block;}
.schedule table th.sat{color:#7ac0c0;}
.schedule table th.sun{color:#af0404;}
.schedule table th{padding:5px 8px;}
.schedule table td{padding:0px;}
.schedule table td .start-end{text-align:center; font-weight:bold; border-bottom:dashed 1px #CCC; line-height:2; }
.schedule table td .start-end span{display: block;}
.schedule table td .start-end span.holiday1{background:#b1f7d4; color:#093;}
.schedule table td .start-end span.holiday2{background:#fdc0c0; color:#aa3030;}
.schedule table td .start-end span.night1{background:#b5e9f6; color:#0692b3;}

.schedule table td .hour{text-align:center;line-height:2; }

.schedule table th.total{ text-align:left; background:#DED3B7; padding-top:30px;}
.schedule table td.total{ text-align:center; vertical-align:middle;}
.schedule table .tate{writing-mode: vertical-rl;}
.schedule table tr.p-2 td{padding:5px 8px; vertical-align:middle;}
.schedule table td.title{padding:5px 8px;vertical-align:middle;}
.schedule table td.employment{text-align:center;}
.schedule table td.employment span{ background:#BA9C38; color:#FFF; font-weight:bold; padding:5px; border-radius:5px; text-align:center;}

.schedule table.cross-highlight {
  border-spacing: 0;
  border-collapse: collapse;
  border: solid 1px #666;
  overflow: hidden;
}
.schedule table.cross-highlight tr:hover {
  background-color: #DDD;
}
.schedule table.cross-highlight td,
.schedule table.cross-highlight th {
  position: relative;
}
.schedule table.cross-highlight td:hover,
.schedule table.cross-highlight th:hover {
  background-color: #CCC;
}
.schedule table.cross-highlight td:hover:after,
.schedule table.cross-highlight th:hover:after {
  content: "";
  background-color: #EEE;
  width: 100%;
  height: 200vh;
  position: absolute;
  top: -100vh;
  left: 0;
  z-index: -1;
}


.schedule table.cross-highlight td.title:hover:after{background:transparent;}




.schedule .modal .modal-header{ background:#DED3B7; display:block; }
.schedule .modal .modal-header ul{display:flex;justify-content: center;align-items: center;}
.schedule .modal .modal-header ul li i{color:#BA9C38;font-size:40px;}
.schedule .modal .modal-header ul li span{margin-left:40px; margin-right:40px;font-size:40px; font-weight:bold;}

.schedule .modal .modal-body ul.month{display:flex;flex-wrap: wrap;justify-content: space-between;}
.schedule .modal .modal-body ul.month li{width:22%; background:#efefef; text-align:center; margin-bottom:10px; line-height:3; font-weight:bold;font-size:24px;}
/*==============================
スタッフ管理（マスター管理）
==============================*/
.master .facility-name ul{display:flex;flex-wrap: wrap; margin-bottom:20px;}
.master .facility-name li a{display:block;border-radius:25px; padding:3px 10px;box-shadow: 2px 2px 2px #CCC; margin-right:10px; border:solid 1px #CCC; font-weight:bold; width:auto; text-align:center; margin-bottom:10px; font-size:13px;}
.master .facility-name li a:hover{ color:#FFF; background:#BA9C38;}














/*==============================
チェックボックスのデザイン
==============================*/

.select-box {
  position: relative;display:-webkit-box;display:flex;flex-wrap: wrap; }

.select-box input {
 display: none;
}

.select-box label {
	display: block;
	position: relative;
	margin-right: 10px;
	margin-bottom: 10px;
	padding:3px 5px;
	border-radius: 10px;
	color: #666666;
	background-color: #fff;
	box-shadow: 0 0 5px rgba(0, 0, 0, .2);
	white-space: nowrap;
	cursor: pointer;
	user-select: none;
	transition: background-color .2s, box-shadow .2s;
}




.select-box label:hover, input:focus + label {
  box-shadow: 0 0 5px rgba(0, 0, 0, .6);
}

.select-box input:checked + label {
  background-color: #ab576c;
  color:#FFF;
}

.select-box input:checked + label::before {
  background-color: #ab576c;
  border: 3px solid #FFF;
}



/*====================
ボタン（画面下）
=====================*/
.button-submit{z-index: 1;position: fixed;
bottom: 40px;left: 50%;
}
	
	
.button-submit a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  margin: 0 auto;
  padding: 1em 2em;
  width: 300px;
  color: #333;
  font-size: 18px;
  font-weight: 700;
  background-color: #cccccc;
  transition: 0.3s;
  text-decoration:none;
}

.button-submit a::before {
  content: '';
  position: absolute;
  top: calc(50% - 2px);
  right: 1em;
  transform: translateY(calc(-50% - 2px)) rotate(30deg);
  width: 12px;
  height: 2px;
  background-color: #2285b1;
  transition: 0.3s;
}

.button-submit a::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 1em;
  transform: translateY(-50%);
  width: 70px;
  height: 2px;
  background-color: #2285b1;
  transition: 0.3s;
}

.button-submit a:hover {
  text-decoration: none;
  background-color: #bbbbbb;
  cursor:pointer;
}

.button-submit a:hover::before,
.button-submit a:hover::after {
  right: 0.5em;
}

/*==============================
ページトップ
==============================*/

#page_top {
    position: fixed;
    bottom: 30px;
    right: 30px;
	
}
#page_top a {
	background-color: #999;
	color: #fff;
	text-align: center;
	text-decoration: none;
	font-size: 24px;
	padding-top: 6px;
	padding-right: 15px;
	padding-bottom: 10px;
	padding-left: 15px;
}
#page_top a:hover {
    background-color: #666;
    text-decoration: none;
}




/*==============================
ソート
==============================*/
.sort-area{}
.sort-area ul{ display:flex;}
.sort-area ul li{margin-right:10px; background:#BA9C38; border-radius:5px; font-size:13px; padding:3px 5px; color:#FFF;}
.sort-area ul li a{color:#FFF;}
/*==============================
スクロール
==============================*/
.scrollArea{white-space: nowrap;overflow: auto;height: calc(100vh - 250px);}
/*スクロールバーの横幅指定*/
/*スクロールバーの横幅指定*/
.scrollArea.deco::-webkit-scrollbar {    height: 25px;}
/*スクロールバーの背景色・角丸指定*/
.scrollArea.deco::-webkit-scrollbar-track {  border-radius: 10px;	background: #f2f2f2;}
/*スクロールバーの色・角丸指定*/
.scrollArea.deco::-webkit-scrollbar-thumb {  border-radius: 10px;	background:#777;}

/* スクロールの背景の設定 */
.scrollArea.deco::-webkit-scrollbar-track {
  border-radius: 10px;
  box-shadow: 0 0 4px #aaa inset;
}
.scrollArea table th{ position: sticky;
  &:before{
    content: "";
    position: absolute;
    top: -1px;
    left: -1px;
    width: 100%;
    height: 100%;
   border-left: 1px solid #ccc;
	  	z-index: 2;

  }}
.scrollArea table th:before{}
.scrollArea table th.fixed01{ position: sticky;  top: 0;  left: 0;  z-index: 3;}

.scrollArea table td.fixed01{
  left: 200px;
  background-color:#FFF;
  	z-index: 1;
	 position: sticky;
  top: -1px;
  left: -1px;
  &:before{
    content: "";
    position: absolute;
    top: -1px;
    left: -1px;
    width: 100%;
    height: 100%;
  }

}

.scrollArea table,.scrollArea td,.scrollArea th {
    border-collapse: collapse;
    border:1px solid #afafaf;
	vertical-align: middle;
    }
.table-hover tbody tr:hover td.fixed01 {
    color: #212529;
    background-color:#CCC;
	z-index:999;
}	
.table-hover tbody tr:hover td.fixed01 a{position:relative; z-index:1;}	
/*==============================
header　Sticky
==============================*/
h2.sticky{position: -webkit-sticky;/*Safari用ベンダープレフィックス*/
position: sticky;top: 0; z-index:1;}
.th-sticky{}
.th-sticky th{position: -webkit-sticky;/*Safari用ベンダープレフィックス*/
position: sticky;top: 40px;}
.sticky-left{position: -webkit-sticky;/*Safari用ベンダープレフィックス*/
position: sticky;left: 0;}

/*==============================
table header　固定
==============================*/
.scrollArea table th.fixed{ position: sticky;
  top: 0;
  left: 0;
  &:before{
    content: "";
    position: absolute;
    top: -1px;
    left: -1px;
    width: 100%;
    height: 100%;
    border: 1px solid #ccc;
  }}

