@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%);overflow-x: hidden;}

.display_message {color:green;white-space: pre-line;}
.display_error {color:red;white-space: pre-line;}
a{transition: background-color 0.5s;}
a:hover{transition: background-color 0.5s;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;margin-right: auto;}
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{font-size: 13px;}
header .display-name span{background:#FFF; color:#222; font-size:13px;padding:2px 10px; border-radius:25px;  }
header .logout{font-size: 13px;    background: #2072a7;   color: #FFF;border-radius:25px; margin-left:10px; padding:2px 10px;}
header .logout a{display:block;}
.stage{}


main{display:flex;justify-content: space-between;  }
.contents{ margin-right:20px; padding-top:20px; padding-bottom:120px;width: calc(100% - 270px);background-color: #FFF;}
.contents.full{margin: 0px;width: 100%;padding-left: 20px;padding-right: 20px;}  

.table td{vertical-align:middle;}
table th.title{background:#DED3B7;}
table th.title2{background:#2072a7; color:#FFF;padding: 5px 4px !important;}
.btn-sm{ padding:3px 5px; font-size:12px;}
input.large[type=checkbox] {
    transform: scale(2.0); margin-right:20px;margin-left: 10px;}
input.large[type=radio] {
    transform: scale(2.0); margin-right:20px;margin-left: 10px;}
label{cursor:pointer;}
select{    font-size: 20px;}

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 .toggle {
	display: none;
}
.gnav .Label {	display: block;	padding-left: 20px;	color: #FFF;	background-color: #BA9C38;	padding-top:15px;	padding-bottom:15px;	font-weight:bold;	font-size:17px;border-bottom: solid 1px #FFF;}
.gnav .Label.admin{background-color: #715f24;}
.gnav .Label::before{
	content:"";
	width: 6px;
	height: 6px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	position: absolute;
	top:calc( 50% - 3px );
	right: 20px;
	transform: rotate(135deg);
}
.gnav .Label,
.gnav ul {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}
.gnav ul {
	height: 0;
	overflow: hidden;
	
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
}
.gnav .toggle:checked + .Label + ul {
	height: auto;
	transition: all .3s;
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 20px;
	padding-left: 0px;
	
}
.gnav .toggle:checked + .Label::before {
	transform: rotate(-45deg) !important;
}





.gnav .logo{
	width: 80px;
	height: auto;
	position: fixed;
    bottom: 20px;
    left: 120px;
}
.gnav ul li{font-size:15px;}


.gnav ul li a{	color: #222;display: block;	padding-top: 10px;padding-right: 10px;padding-bottom: 10px;	padding-left: 10px;	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 i{margin-right:10px; width:30px; text-align:center;}







/*==============================
キービジュアル
==============================*/
.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(/design/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;}




@media screen and (max-width: 430px) {
.kv-wrap{ width:100%;}
.kv-copy{
	position: relative;
	top: inherit;
	left: inherit;
	width: 90%;
	margin-top: 20px;
	margin-right: auto;
	margin-bottom: 20px;
	margin-left: auto;
}

.kv .message{position:static; display:block; width:90%; top:inherit; right:inherit; margin-left:auto; margin-right:auto;padding:10px;}
.kv .message .text{padding:0px; border-left:none; margin:0px;    font-size: 14px;}
.login{position:relative; width:auto; transform:none; top:auto; left:auto; background-color:inherit;}
.login form{padding:10px 0px;}
.login h1{font-size:18px;}
.login .ic-id{display:none;}
.login .ic-pw{display:none;}

.kv .foot{position:static; width:90%; margin:0 auto;transform:none;}
.kv .foot span{display:block;}
}



/*==============================
シフト管理
==============================*/
.office{ margin-bottom:20px; width:50%;}
.office .title{font-size:30px;/*font-family: 'Noto Serif JP', serif;*/ padding-left:10px; margin-right:40px; font-weight:bold;  margin-bottom:20px;font-family: "Kiwi Maru", serif; font-weight:500;}
.office ul{display:flex;flex-wrap: wrap;}
.office li a{display:block;border-radius:25px; padding:8px 0px;box-shadow: 2px 2px 2px #CCC; margin-right:10px; border:solid 1px #CCC; font-weight:bold; width:170px; text-align:center; margin-bottom:20px;}
.office li a:hover{ color:#FFF !important; }



.office.office1 .title{border-left:10px solid #AF4424;}
.office.office1 li a{ color:#AF4424; }
.office.office1 li a:hover{ background:#AF4424; }

.office.office2 .title{border-left:10px solid #7B2A72;}
.office.office2 li a{ color:#7B2A72; }
.office.office2 li a:hover{ background:#7B2A72; }

.office.office3 .title{border-left:10px solid #1E7C7D;}
.office.office3 li a{ color:#1E7C7D; }
.office.office3 li a:hover{ background:#1E7C7D; }

.office.office4 .title{border-left:10px solid #2072A7;}
.office.office4 li a{ color:#2072A7; }
.office.office4 li a:hover{ background:#2072A7; }


.office.office5 .title{border-left:10px solid #45582C;}
.office.office5 li a{ color:#45582C; }
.office.office5 li a:hover{ background:#45582C; }

.office.office6 .title{border-left:10px solid #1c3259;}
.office.office6 li a{ color:#1c3259; }
.office.office6 li a:hover{ background:#1c3259; }

.office.office7 .title{border-left:10px solid #ba9c38;}
.office.office7 li a{ color:#ba9c38; }
.office.office7 li a:hover{ background:#ba9c38; }

.office.office8 .title{border-left:10px solid #606060;}
.office.office8 li a{ color:#606060; }
.office.office8 li a:hover{ background:#606060; }

.office.office9 .title{	border-left-width: 10px;	border-left-style: solid;	border-left-color: #FF6600;}
.office.office9 li a{ color:#FF6600; }
.office.office9 li a:hover{ background:#FF6600; }

.office.office10 .title{	border-left-width: 10px;	border-left-style: solid;	border-left-color: #999900;}
.office.office10 li a{ color:#999900; }
.office.office10 li a:hover{ background:#999900; }

.office.office11 .title{	border-left-width: 10px;	border-left-style: solid;	border-left-color: #FF9966;
}
.office.office11 li a{ color:#FF9966; }
.office.office11 li a:hover{ background:#FF9966; }

.shift .header{background:#efefef; padding:10px 0px;margin-bottom:20px;display:flex;align-items: center;justify-content: space-between;}
.shift .header .name{display:flex;justify-content: center; margin-right:20px;}  
.shift .header .name ul{	display: flex;	align-items: center;	border: solid 1px #CCC;	border-radius: 25px;background: #FFF;padding-top: 0px;		padding-bottom: 0px;	}
.shift .header .name ul li{ padding:5px 20px; text-align:center; font-size:20px;}
.shift .header .name ul li:first-child{border-left:none !important;padding-left: 25px;}
.shift .header .name ul li:last-child{padding-right: 25px;}
.shift .header .name ul li.title{border-right:dashed 1px #CCC; border-left:solid 1px #CCC; font-weight:bold; font-size:22px;}
.shift .header .name ul li.main-title{ border-left:solid 1px #CCC; font-weight:bold; font-size:22px; background-color:#C00; color:#FFF; font-weight:bold;    border-radius: 25px 0px 0px 25px;}


.shift .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;
}




.shift .header .date{display:flex;justify-content: center;align-items: center; margin-right:20px;}
.shift .header .date ul{display:flex;align-items: center;}
.shift .header .date ul li{font-weight:bold;}
.shift .header .date .month{ font-size:30px; margin-right:100px; margin-left:100px; font-weight:bold; line-height:1;}
.shift .header .date .month span{ font-size:20px; margin-right:20px;    margin-top: 5px;}
.shift .header .date .month a{display:block;display:flex;align-items: center;}
.shift .header .date .month a:hover{cursor:pointer;}
.shift .header .date i{color:#BA9C38;font-size:50px;}
.shift .header .date i:hover{cursor:pointer;}

.shift table tr.monthly{}
.shift table tr.monthly td{vertical-align: middle; padding:5px;}
.shift table tr.monthly td.title{text-align:right;}
.shift table th, .shift table td{ font-size:14px; vertical-align:middle; }
.shift table td{vertical-align: top;}

.shift table th.date{width:20px; text-align:center;}
.shift table th.date span{display:block;}
.shift table th .sat{color:#7ac0c0;}
.shift table th .sun{color:#af0404;}
.shift table th{padding:5px 8px;}
.shift table td{padding:0px;}
.shift table td.small{font-size:0.6em !important;}
.shift table td .start-end{text-align:center; font-weight:bold; border-bottom:dashed 1px #CCC; line-height:2; position:relative; height: 2em; }
.shift table td .start-end .tel{position:absolute;  top: 50%;    left: 50%;    transform: translate(-50%, -50%); z-index:1;}
.shift table td .start-end .tel i{position:absolute;  top: 50%;    left: 50%;    transform: translate(-50%, -50%);z-index: -1;}
i.half{color:rgba(246, 97, 93, 0.5) !important;}


.shift table td .start-end span{display: block; cursor:pointer;}
.shift table td .start-end span.holiday1{background:#b1f7d4; color:#093;}
.shift table td .start-end span.holiday2{background:#fdc0c0; color:#aa3030;}
.shift table td .start-end span.night1{background:#b5e9f6; color:#0692b3;}
.shift table td .start-end span.tel i{ color:#f6615d; font-size:22px; vertical-align:middle;}
.shift table td .start-end.empty span{display: block; cursor:default;}
.shift table td .hour{text-align:center;line-height:2; cursor:pointer;}



.shift table td .memo{  position: absolute;  cursor: pointer;  padding: 0 5px;  font-size: 0.9em;  color: #4682b4;right: 7px;}
.shift table td .memo:after{content: "\f06a";    font-weight: 900;    font-family: "Font Awesome 5 Free";display: inline-block;position: absolute; color:red;line-height: 1;    font-size: 12px;}
.description_top {width: auto;position: absolute;left: 50%;  bottom: 80%;transform: translateX(-50%);margin-bottom: 8px;padding: 8px;border-radius: 10px;background-color: #666;color: #fff;text-align: center;visibility: hidden;opacity: 0;z-index: 3;transition: 0.5s all; 
}
.memo:hover .description_top { bottom: 20px;  visibility: visible;  opacity: 1;}


.shift table td .hour.empty{ cursor:default;}
.shift table td .sat{color:#7ac0c0;}
.shift table td .sun{color:#af0404;}
.shift table td.total{ text-align:center; vertical-align:middle;}
.shift table td.total.title{ text-align:left; background:#DED3B7; font-weight:bold;}
.shift table .tate{writing-mode: vertical-rl; cursor:pointer;}
.shift table .tate span.yoko{display: inline-block; background:#FFF;writing-mode: initial; font-size:80%; padding:1px 3px; margin-top:10px;}
.shift table .tate span.full_time_equivalent{display: inline-block; background:#FFF;writing-mode: initial;  padding:2px 5px; margin-top:20px;}
.shift table tr.p-2 td{padding:5px 8px; vertical-align:middle;}
.shift table td.title{padding:5px 8px;vertical-align:middle;}
.shift table td.employment{text-align:center;}
.shift table td.employment span{ background:#BA9C38; color:#FFF; font-weight:bold; padding:5px; border-radius:5px; text-align:center;}

.shift .copy-box{display:flex;align-items: center; margin:10px; }
.shift .copy-box select{width:200px; margin:0 10px;}

tr.narrow td{padding:1px 8px !important; font-size:80% !important; text-align:center;}
tr.narrow td.fixed01{background:#CFF !important;} 

@media screen and (min-width:431px){

.shift table.cross-highlight {
  border-spacing: 0;
  border-collapse: collapse;
  border: solid 1px #666;
  overflow: clip;
}
.shift table.cross-highlight tr:hover {
  background-color: #DDD;
}
.shift table.cross-highlight td,
.shift table.cross-highlight th {
  position: relative;
}
.shift table.cross-highlight td:hover,
.shift table.cross-highlight th:hover {
  background-color: #CCC;
}
.shift table.cross-highlight td:hover:after{
  content: "";
  background-color: rgba(0,0,0,0.10);
  width: 100%;
  height: 200vh;
  position: absolute;
  top: -100vh;
  left: 0;
  z-index: -1;
}
.shift table.cross-highlight th:hover:after {
  content: "";
  background-color: rgba(0,0,0,0.10);
  width: 100%;
  height: 200vh;
  position: absolute;
  top: -100vh;
  left: 0;
  z-index: -1;
}


.shift table.cross-highlight td.title:hover:after{background:transparent;}


}




.renzoku-input {width: 171px;display: block;position: absolute;top: 90px;right: -220px; bottom: 0;transition: all 0.2s;box-shadow: 0px 0px 10px 5px rgba(0, 0, 0, 0.08);background:#FFF; padding:8px; border:solid 1px #CCC; z-index:4;height:auto;overflow-y: auto;}
.open.renzoku-input {right: 0; height:auto; }
.renzoku-input h3{ font-size:18px; font-weight:bold; margin-bottom:20px;}
.renzoku-input .btn-close{position:absolute; top:-5px; right:10px;}
.renzoku-input .btn-close span{font-size:40px;}











/*タブ切り替え全体のスタイル*/
.tabs {
}

/*タブのスタイル*/
.tab_item {
  width: 50%;
  height: 40px;
  border-bottom: 3px solid #BA9C38;
  background-color: #d9d9d9;
  line-height: 40px;
  font-size: 16px;
  text-align: center;
  color: #a0a0a0;
  display: block;
  float: left;
  text-align: center;
  font-weight: bold;
  transition: all 0.2s ease;
}
.tab_item:hover {  opacity: 0.75;}


input[name="tab_item"] {  display: none;}

.tab_content {  display: none;  clear: both;  overflow: hidden;}


#main:checked ~ #main_content,
#sub:checked ~ #sub_content
 {
  display: block;
}

/*選択されているタブのスタイルを変える*/
.tabs input:checked + .tab_item {
  background-color: #BA9C38;
  color: #fff;
}







@media screen and (max-width:430px){
.table-hover tbody tr:hover{background:#FFF;}
body{background:none;}
main{display:block;}
header{display:block; text-align:center;}
header > div{display:block;}
.gnav{display:none;}
.contents{
	width: 100%;
	padding: 0px;
	margin-top: 0px;
	margin-right: auto;
	margin-bottom: 0px;
	margin-left: auto;
}
header .linktop{display:none;}
.shift .header .name ul{margin-bottom:10px;}
.shift .header .name ul li{font-size:15px;    padding: 5px;}
.shift .header .name ul li.title{font-size:15px;}
.shift .header .date .month{font-size:40px; margin-right:40px; margin-left:40px;}
.shift .header .date .month span{font-size:26px;}
.shift table{display:flex;}
.shift table{width:90%; margin:0 auto;}
.shift table thead{display:block;width:20vw;}
.shift table thead tr{width:100%;}
.shift table tbody{display:block; width:auto; overflow-x:auto;width:80vw;display:flex;}
.shift table tbody tr{display:inline-block;vertical-align: top;width:100%; }

.shift table td{display:block; height:60px; border-right:solid 1px #CCC;}
.shift table td.title{height:80px;text-align: center;display: flex;    align-items: center;justify-content: center;}
.shift table th{display:block;  border-bottom:none;border-right:solid 1px #CCC;border-left:solid 1px #CCC;}
.shift table th.date{width:auto; height:60px;   }
.shift table th.title{height:80px; width: 20vw;text-align: center; display: flex;    align-items: center;justify-content: center;}
.shift table th.total{height:60px; }
.shift table .tate{writing-mode: initial;}

.shift table tr.monthly{ width:25vw}
.shift table tr.monthly td{width:20vw;    background: #efefef;}
.shift table tr.monthly td.title{text-align:center; height:240px;writing-mode: initial; }
.shift table tr.monthly td.total{ height:60px;background: #efefef;l }
.shift table td.total{font-size:13px;display: flex;    align-items: center;justify-content: center;}

}









/*==============================
チェックボックスのデザイン
==============================*/

.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: 2;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;
}

/*==============================
モーダル
==============================*/

.modal-header.month{ background:#DED3B7; display:block; }
.modal-header.month ul{display:flex;justify-content: center;align-items: center;}
.modal-header.month ul li i{color:#BA9C38;font-size:40px;}
.modal-header.month ul li span{margin-left:40px; margin-right:40px;font-size:40px; font-weight:bold;}
.modal-header.month ul li i:hover{ cursor:pointer;}



.modal-body.month ul{display:flex;flex-wrap: wrap;justify-content: space-between;}
.modal-body.month ul li{width:22%; background:#efefef; text-align:center; margin-bottom:10px; line-height:3; font-weight:bold;font-size:24px;}
.modal-body.month ul li a{display:block;}
.modal-body.month ul li a:hover{background:#BA9C38; color:#FFF; cursor:pointer;}






.modal-header{ background:#FFF;}
.modal-header h2{font-size:18px; font-weight:bold;}
.modal h4{font-size:16px; font-weight:bold; margin-top:10px; margin-bottom:5px;}

/*==============================
ソート
==============================*/
.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;}

/*==============================
スクロール
==============================*/
@media screen and (min-width:431px){

.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;
}
th.sticky {
	position: sticky !important;
	top: 0;
	left: 0;
	z-index: 3;
	border-bottom: 1px solid #afafaf !important;
	background-color:rgba(222,211,183,1);
}
th.sticky:before {    content: "";    position: absolute;    top: -1px;    left: -1px;    width: 100%;    height: 100%;    border-top: 1px solid #ccc;z-index: 2;}

.scrollArea table th.fixed01{ position: sticky;  top: 0;  left: 0;  z-index: 3;}
.scrollArea table td.fixed01 {    position: sticky;	 background-color: #F5F2E9;  	z-index: 2;	top: 0px;  left: -1px;}
.scrollArea table td.fixed01:before {    content: "";    position: absolute;    top: 0px;    left: 0px;    width: 100%;    height: 100%;border-right: 1px solid #ccc;border-left: 1px solid #ccc;}
.scrollArea table td.fixed01 a{position:relative;}


.scrollArea table,.scrollArea td,.scrollArea th {    border-collapse: collapse;    border:1px solid #afafaf;	vertical-align: middle;}
}

/*==============================
hover td th
==============================*/
table.shift td.hover {background-color: #E0E0E0;}
table.shift td.hover:hover{	background-color: #C6C6C6;}
table.shift th.hover {background-color:#E0E0E0;}


/*==============================
ポップアップ
==============================*/
.box {
  font-size:15px;
}
/*==============================
パスワード変更
==============================*/
.box1{
	width: 600px;
	border: solid 1px #222;
	padding: 40px 80px;
	margin-top: 100px;
	margin-right: auto;
	margin-bottom: 0;
	margin-left: auto;box-shadow: 10px 10px 0px -3px #d1d1d1;
	text-align:center;
}
@media screen and (min-width:431px){
  .box1{
	width: 100%;
  }
}
.box1 h1{position:static; background:none; color:#305d2a; text-align:center; font-weight:bold; font-size:26px;}
.box1 h1:after{content:none;}
input.bg-green{background:#305d2a;}
input.bg-light-green{background:#A5D39E;}

.box1 input{color:#FFF; width:100%; margin-bottom:10px;font-size:18px; text-align:left; }
.box1 input::placeholder {
  color: #FFF; font-size:18px;
}
.box1 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;
	text-align:center;
	margin:0 auto;
  }
.box1 > div{position:relative;}
.box1 > div i{position:absolute; top:15px; right:20px; font-size:30px; color:#333;}

/*==============================
ボタン
==============================*/
.btn-group{padding:0px; margin-bottom:10px;padding:0px;display:flex;width: 100%;}
.btn-group button{padding:10px 20px; border-radius:5px;margin-right:10px;}
.btn-group button.save{background:#F66; color:#FFF;}
.btn-group button.save:hover{background:#C30;}
.btn-group button.reset{background:#222; color:#FFF;}
.btn-group button.reset:hover{background:#CCC;}

button:focus{outline:none;}

button.red{background:#F66; color:#FFF;padding: 5px 10px;border-radius: 5px; margin-left:20px;}
button.red:hover{background:#C30;} 
/*==============================
ボタン（チェックボックス）1
==============================*/
.check-group{}
.check-group h3 {
  position: relative;
  background: #777;
  box-shadow: 0px 0px 0px 4px #777;
  border: dashed 1px white;
  padding: 0.2em 0.5em;
  color: #FFF;
  border-radius:0px;
  margin-left:5px;
  margin-right:8px;
  font-size:0.9rem;
  min-width:47px;
  height:26px;
}

.check-group h3:after {
  position: absolute;
  content: '';
  left: -7px;
  top: -7px;
  border-width: 0 0 13px 13px;
  border-style: solid;
  border-color: #fff #fff #222;
  box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.15);
}

.check-group input[type="checkbox"] {
  display:none; 
}

.check-group label {
	display: inline-block;
	color: #000;
	cursor: pointer;
    padding: 3px 10px;
	border-radius: 5px;
	border: 1px solid #CCC;
	font-weight:normal;
	font-size:0.8rem;
	margin-bottom:10px;
	margin-right: 5px;
	border-radius:25px;
    box-shadow: 2px 2px 2px #CCC;
    border: solid 1px #CCC;
    font-weight: bold;
    text-align: center;
    font-size: 13px;
}

.check-group input[type="checkbox"]:checked + label {
	background-color: #d81b60;
	color:#FFF
}





/*====================
ボタン（ラジオボタン）1
=====================*/
.radio-group {
}
.radio-group input {
  display: none;
}

.radio-group input.memo-input{display:block; border:solid 1px #CCC; width:50%; border-radius:5px; background:#FFF; margin-left:auto; margin-right:auto; padding:5px; text-align:center; color:#000;}
.radio-group .item{background: #f2f2f2;display:flex;border-radius:3px;align-items: center; margin-bottom:10px; border:solid 1px #dedede;   }
.radio-group .item .title{ font-size:15px;font-weight:bold; background:#FFF; padding:5px; border:solid 1px #CCC; border-radius:3px; margin-right:5px;}
.radio-group .item .title i{font-size:22px; vertical-align:middle;}
.radio-group .item input:checked + label {
	color: #fff;
	background: #d81b60;
	display: block;
	width: 100%;
	padding-top: 8px;
	padding-right: 0px;
	padding-bottom: 8px;
	padding-left: 2px;
}

.radio-group .item input:checked + label .title{color: #000;}

label[for="continuous_0"] span{display:block; text-align:center;}
.radio-group .item input:checked + label[for="continuous_0"] .title {margin-left:8px; margin-right:8px;}

label[for="memo_0"] span{display:block; text-align:center;}
.radio-group .item input:checked + label[for="memo_0"] .title {margin-left:8px; margin-right:8px;}


.radio-group .item .color{border:solid 1px #CCC; border-radius:3px; margin-right:5px; width:30px; height:30px;display: inline-block;     padding-top: 4px;
    padding-right: 1px;
    padding-bottom: 1px;
    padding-left: 5px;
}
.radio-group .item.item-color input:checked + label {
	color: #fff;
	background: #d81b60;
	display: block;
	width: auto;
    padding-top: 4px;
    padding-right: 1px;
    padding-bottom: 1px;
    padding-left: 5px;
	
}
.radio-group .item.item-color label{width:auto; padding-right:0px;}



.radio-group .item.inline-block{display:inline-block !important;border:none;}
.radio-group .item.inline-block:hover{border:none;}
.radio-group .item.inline-block .title{margin:0px;}
.radio-group .item.inline-block label{padding:0px;}
.radio-group .item.inline-block input:checked + label{margin:0px;padding:0px;}
.radio-group .item.inline-block input:checked + label .title{background:#d81b60; color:#FFF;margin:0px;padding: 5px;}






.radio-group.col2{display:flex;flex-wrap: wrap;justify-content: space-between;}
.radio-group.col2 .item{width:48%;}
.radio-group label {
  display:block;
  cursor: pointer;
  width: 100%;
	padding-top: 8px;
	padding-right: 0px;
	padding-bottom: 8px;
	padding-left: 2px;
}

.radio-group h4{ font-size:16px;font-weight:bold;margin-top:20px; margin-bottom:5px;    width: 100%;}
.radio-group h4:first-child{margin-top:0px;}



.radio-group .item:hover{border:solid 1px #222; cursor:pointer;}

.radio-group select{font-size:20px; margin-right:10px; margin-left:10px;}
.radio-group select:first-child{margin-left:0px;}





/*====================
ボタン（ラジオボタン）2
=====================*/
.radio-group2{
  display: flex;
  border-radius: 3px;
  overflow: hidden;
  border: 1px solid #b6b6b6;
  width: max-content;
}
.radio-group2 label{ }
.radio-group2 div {
  position: relative;
  flex: 1;
}
.radio-group2 input {
  width: 120px;
  height: 36px;
  opacity: 0;
}
.radio-group2 input:hover{cursor:pointer;}
.radio-group2 label {
  position: absolute;
  top: 0;
  left: 0;
  color: #888;
  width: 100%;
  height: 100%;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  border-right: 1px solid #b6b6b6;
}
.radio-group2 div:last-child label {
  border-right: 0;
}
.radio-group2 input:checked + label {
  background: #d81b60;
  font-weight: 500;
  color: #fff;
}

.radio-group3{
  position: absolute;
  right:0;
}

/*====================
ルーペ
=====================*/
.loupe {
	border-radius:10px; 
	background:#e6e6e6; 
      padding: 10px;
      background-color: #ddd;
	  border-radius:10px;
	   width:300px;
	   padding:10px 0px;
	   position:relative;
	   margin-right:20px;
	   display:flex;
	   align-items: center;
	   
	  
    }
.loupe img{width:140px; height:auto; position:absolute; left:-5px; top:-8px;}
.loupe ul{display:flex;align-items: center;    margin-left: auto; margin-right:10px;}
.loupe li{margin-left:10px; background:#b3b3b3; color:#FFF; border-radius:5px;  height:35px;width:40px;display:flex;justify-content: center;align-items: center;filter: drop-shadow(0px 0px 3px rgba(0,0,0,0.5));}

.loupe li#f-small{ font-size:14px;}
.loupe li#f-medium{ font-size:17px;}
.loupe li#f-large{ font-size:20px;}
.loupe li:hover{background:#2072a7; color:#FFF; cursor:pointer;}

body.f-small .loupe li#f-small{background:#2072a7; color:#FFF;}
body.f-medium .loupe li#f-medium{background:#2072a7; color:#FFF;}
body.f-large .loupe li#f-large{background:#2072a7; color:#FFF;}

body.f-small .shift table th, body.f-small .shift table td{font-size:12px;}
body.f-medium .shift table th, body.f-medium .shift table td{font-size:14px;}
body.f-large .shift table th, body.f-large .shift table td{font-size:20px;}

body.f-small{font-size:12px;}
body.f-medium{font-size:15px;}
body.f-large{font-size:20px;}

/*====================
draggable
=====================*/
.sortable-chosen{background:#ffff00; opacity:1 !imprtant;}
table.sorting tr{cursor:move;}
table.sorting tr td:first-child{position:relative; padding-left:50px;}
table.sorting tr td:first-child:after{content: '\f0dc';
    font-family: "Font Awesome 5 Free";
    position: absolute;
    top: 50%;
    left: 10px;
    transform: translateY(-50%);
    font-size: 1.3rem;
    color: #666;font-weight: bold;}
/*====================
色
=====================*/

.bg-{background:#ffffff; }
.bg-red{background:#C00; color:#FFF;}
.bg-red a{color:#FFF !important;}
.bg-red a:hover{
	background-color: #800 !important;
}
.bg-brown{background-color:#AF4424 !important;}
.bg-brown a:hover{
	background-color: #800 !important;
}

.bg-orange{background:#ffa500;}
.bg-yellow{background:#ffff00;}
.bg-green{background:#008000; color:#FFF;}
.bg-light-blue{background-color:#CFF !important;}
.bg-blue{background:#0000ff; color:#FFF;}
.bg-purple{background:#800080; color:#FFF;}
.text-red{ color:#C00;}
.bold{font-weight:bold;}

.w-50px{width:50px;}
.w-80px{width:80px;}
.w-100px{width:100px;}
.w-150px{width:150px;}
.w-200px{width:200px;}

.vertical-middle{vertical-align:middle !important;}


.form-control {
    font-size: inherit;
}


/* timepicker */
.dp__input {
  width:150px;
}
.monthly_memo {
  width:100%;
  margin-right: 10px;
  border: 1px solid #afafaf;
  padding:10px;
  min-height:100px;
}

.align-center{align-items: center;}


@media screen and (max-width: 430px) {
.pc{display:none !important;}
}

@media screen and (min-width: 431px) {
.sp{display:none !important;} 
}



@media print{
@page { size:landscape; }
body {min-width: 100% !important; background:#FFF !important;}
.table td, .table th {background-color:inherit !important;}
main {    width: 100%;}
.gnav{display:none !important;}
header{display:none;}
.contents{width:100%; margin:0 auto; padding:0px 20px;}
#page_top{display:none;}
.renzoku-input{display:none;}
a:not(.btn) {text-decoration: none;}
.btn-group{display:none;}
table th.title {background-color:rgba(222, 211, 183, 1) !important;   }
table th.date {background-color:rgba(222, 211, 183, 1) !important;   }
#showLeftPush{display:none;}
.shift .header{justify-content: center;}
.shift .header .date .back{display:none;}
.shift .header .date .next{display:none;}
.scrollArea table td.fixed01{background-color: #F5F2E9 !important;}
tr.narrow td.fixed01 {    background: #CFF !important;}
.scrollArea table, .scrollArea td, .scrollArea th {border: 1px solid #afafaf !important;}
body.f-small .shift table th, body.f-small .shift table td{font-size:12px !important;}
body.f-medium .shift table th, body.f-medium .shift table td{font-size:14px !important;}
body.f-large .shift table th, body.f-large .shift table td{font-size:20px !important;}
.shift table td .hour {    white-space: nowrap;}
}

