body, input, select, textarea {
	color: #000;
	font-size: 14px;
	font-family: Helvetica, Meiryo, 'Hiragino Kaku Gothic ProN', sans-serif;
	background-color: #fff;
}
input[type=text],
input[type=email],
input[type=url],
input[type=tel],
input[type=password] {
	width: 100%;
	height: 24px;
	font-size: 14px;
	line-height: 22px;
	background-color: #fff;
	border: 1px solid #ddd;
	padding: 0 4px;
}
input[type=number],
input[type=date] {
	width: 100%;
	height: 24px;
	font-size: 14px;
	line-height: 22px;
	background-color: #fff;
	border: 1px solid #ddd;
	padding: 0 0 0 4px;
}
input[type=checkbox],
input[type=radio] {
	vertical-align: middle;
	cursor: pointer;
}
select {
	width: 100%;
	height: 24px;
	color: #000;
	font-size: 14px;
	line-height: 22px;
	background-color: #fff;
	border: 1px solid #ddd;
	padding: 0;
}
select option.week0 {
	background-color: #fde;
}
select option.week6 {
	background-color: #def;
}

.test {
	padding: 10px 15px;
	color: #fff;
	height: 40px;
	background-color: #555;
}

textarea {
	width: 100%;
	color: #000;
	font-size: 14px;
	line-height: 18px;
	background-color: #fff;
	border: 1px solid #ddd;
	padding: 2px;
	resize: vertical;
}
input[readonly],
select[readonly],
input[disabled],
select[disabled] {
	color: #333;
	background-color: #eee;
	cursor: auto;
}
a {
	color: inherit;
	font-weight: inherit;
	display: block;
}
img {
	width: 100%;
	height: auto;
	display: block;
}
button {
	color: #fff;
	background-color: #555;
	box-shadow: -1px -1px 0 rgba(0,0,0,0.2) inset, 1px 1px 0 rgba(255,255,255,0.2) inset;
	display: block;
}
button.hover {
	background-image: linear-gradient(rgba(255,255,255,0.3), rgba(255,255,255,0));
}
label {
	cursor: pointer;
}
#shade {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background-color: #666;
	opacity: 0.25;
	z-index: 1000;
}
#header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 80px;
	background-color: #555;
}
#header_top {
	height: 40px;
	background-color: #035;
	box-shadow: -1px -1px 0 rgba(0,0,0,0.2) inset, 1px 1px 0 rgba(255,255,255,0.2) inset;
	padding: 10px 15px;
	display: flex;
	overflow: hidden;
}
#header_top h1 {
	color: #fff;
	font-size: 14px;
	font-weight: normal;
	line-height: 20px;
	overflow: hidden;
}
#header_top h1 a {
	color: #fff;
}
#header_top button {
	width: 30px;
	height: 20px;
	background: transparent;
	margin-left: auto;
	display: none;
}
#header_menu {
	background-color: #555;
	display: flex;
}
#header_menu > * {
	width: 20%;
}
#header_menu a {
	height: 40px;
	color: #fff;
	font-size: 14px;
	line-height: 20px;
	background: #555 url('./img/icon_link0.png') no-repeat 0 0;
	box-shadow: -1px -1px 0 rgba(0,0,0,0.2) inset, 1px 1px 0 rgba(255,255,255,0.2) inset;
	padding: 10px 10px 10px 33px;
	overflow: hidden;
}
#header_menu a.hover {
	background-image: url('./img/icon_link1.png'), linear-gradient(rgba(255,255,255,0.2), rgba(255,255,255,0));
}
#header_menu p {
	height: 40px;
	color: #999;
	font-size: 14px;
	line-height: 20px;
	background-color: #555;
	box-shadow: -1px -1px 0 rgba(0,0,0,0.2) inset, 1px 1px 0 rgba(255,255,255,0.2) inset;
	padding: 10px 10px 10px 33px;
	overflow: hidden;
}
#header_menu .list {
	position: relative;
}
#header_menu .list p {
	color: #fff;
	background: #555 url('./img/icon_open0.png') no-repeat 0 0;
	cursor: pointer;
}
#header_menu .list p.hover {
	background-image: url('./img/icon_open1.png'), linear-gradient(rgba(255,255,255,0.2), rgba(255,255,255,0));
}
#header_menu .list ul {
	position: absolute;
	top: 40px;
	left: 0;
	width: 100%;
	height: calc(100vh - 160px);
	display: none;
	overflow-y: auto;
}
#header_menu ul li {
}
#header_menu ul li a {
	background-color: #777;
}
#main {
	width: 100%;
	max-width: 1100px;
	min-height: 100vh;
	/* padding: 95px 15px 45px 15px; */
	padding: 135px 15px 45px 15px;
	margin: 0 auto;
}
#main h2 {
	color: #fff;
	font-size: 14px;
	font-weight: normal;
	line-height: 20px;
	background-color: #05a;
	padding: 7px 15px;
	margin-bottom: 10px;
}
#main h2.list {
	background-color: #075;
}
#main h3 {
	color: #fff;
	font-size: 14px;
	font-weight: normal;
	line-height: 20px;
	background-color: #075;
	padding: 7px 15px;
	margin-bottom: 10px;
}
#main .mess {
	color: #fff;
	font-size: 14px;
	line-height: 20px;
	background-color: #c33;
	padding: 7px 15px;
	margin-bottom: 10px;
}
#main .mess_text {
	font-size: 14px;
	line-height: 20px;
	background-color: #eee;
	padding: 7px 15px;
	margin-bottom: 10px;
}
#main .hint {
	color: #039;
	font-size: 12px;
	line-height: 18px;
	background-color: #eee;
	padding: 5px 12px;
	margin-bottom: 10px;
}
.edit_tbl {
	width: calc(100% + 2px);
	margin: -1px -1px 9px -1px;
}
.edit_tbl caption {
	color: #039;
	font-size: 12px;
	line-height: 20px;
	text-align: center;
	background-color: #cde;
	border-left: 1px solid #fff;
	border-right: 1px solid #fff;
	padding: 6px 10px;
}
.edit_tbl tr {
}
.edit_tbl tr th {
	width: 90px;
	min-height: 33px;
	color: #039;
	font-size: 12px;
	font-weight: normal;
	line-height: 20px;
	text-align: center;
	vertical-align: middle;
	background-color: #cde;
	border: 1px solid #fff;
	padding: 6px 0;
	cursor: default;
	overflow: hidden;
}
.edit_tbl tr td {
	min-height: 33px;
	text-align: left;
	vertical-align: top;
	background-color: #eee;
	border: 1px solid #fff;
	padding: 2px 4px;
	cursor: default;
	overflow: hidden;
}
.edit_tbl tr td.title {
	background-color: #cde;
}
.edit_tbl tr td .flex {
	display: flex;
	flex-wrap: wrap;
}
.edit_tbl tr td .flex > * {
	margin: 2px;
	display: block;
}
.edit_tbl tr td .flex img {
	width: calc(100% - 4px);
	height: auto;
}
.edit_tbl tr td .cap {
	color: #039;
	font-size: 12px;
	line-height: 20px;
	padding: 2px 0;
	display: inline-block;
}
.edit_tbl tr td .war {
	color: #c00;
}
.edit_tbl tr td p.cap {
	padding: 4px;
}
.edit_tbl tr td p.text {
	font-size: 14px;
	line-height: 20px;
	padding: 4px;
}
.edit_tbl tr td a.butt {
	color: #fff;
	width: 60px;
	height: 24px;
	font-size: 12px;
	line-height: 24px;
	text-align: center;
	background-color: #05a;
}
.edit_tbl tr td button {
	width: 70px;
	height: 24px;
	font-size: 12px;
}
.edit_tbl tr td select option.off {
	display: none;
}
.edit_tbl tr td label.file {
	width: 100px;
	height: 24px;
	color: #fff;
	font-size: 12px;
	line-height: 14px;
	text-align: center;
	background-color: #05a;
	box-shadow: -1px -1px 0 rgba(0,0,0,0.2) inset, 1px 1px 0 rgba(255,255,255,0.2) inset;
	padding: 5px 10px;
}
.edit_tbl tr td label.file input[type=file] {
	display:none;
}
.edit_tbl tr td .file_text {
	max-width: 160px;
}
.edit_tbl tr td.list {
	padding: 0;
}
.edit_tbl tr td.list .check_list {
	width: calc(100% + 1px);
	margin: 0 -1px -1px 0;
	max-height: 330px;
	display: flex;
	flex-wrap: wrap;
	overflow-x: hidden;
	overflow-y: auto;
}
.edit_tbl tr td.list .check_list li {
	width: 100%;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
}
.edit_tbl tr td.list .check_list.list2 li {
	width: 50%;
}
.edit_tbl tr td.list .check_list.list3 li {
	width: 33.33%;
}
.edit_tbl tr td.list .check_list.list4 li {
	width: 25%;
}
.edit_tbl tr td.list .check_list li label {
	min-height: 32px;
	font-size: 14px;
	line-height: 24px;
	padding: 4px 6px;
	display: block;
}
.edit_tbl tr td.list .check_list li label.sm {
	font-size: 12px;
	line-height: 24px;
}
.edit_tbl tr td.list .check_list li label.set_hover.hover {
	background-color: #f6f6cc;
}
.edit_tbl tr td label.list {
	min-width: 60px;
}
.edit_tbl tr td.list .album_list {
	width: calc(100% + 1px);
	margin: 0 -1px -1px 0;
	display: flex;
	flex-wrap: wrap;
}
.edit_tbl tr td.list .album_list li {
	width: 25%;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
	padding: 4px 6px;
	display: flex;
	flex-direction: column;
}
.edit_tbl tr td.list .album_list li label {
	font-size: 14px;
	line-height: 24px;
	margin: 4px 0;
	display: block;
}
.edit_tbl tr td.list .album_list li label.file {
	width: 100%;
	height: 24px;
	color: #fff;
	font-size: 12px;
	line-height: 14px;
	margin: auto 0 4px 0;
}
.edit_tbl tr td.list .album_list li .file_text {
	width: 100%;
	max-width: initial;
}
.list_box {
	width: 100%;
	margin-bottom: 10px;
}
.list_tbl {
	width: calc(100% + 2px);
	max-width: 1100px;
	margin: -1px -1px 9px -1px;
}
.list_tbl caption {
	color: #039;
	font-size: 12px;
	line-height: 20px;
	text-align: left;
	background-color: #ced;
	border-left: 1px solid #fff;
	border-right: 1px solid #fff;
	padding: 6px 10px;
}
.list_tbl tr {
}
.list_tbl tr th {
	min-height: 31px;
	color: #039;
	font-size: 12px;
	line-height: 20px;
	font-weight: normal;
	text-align: center;
	vertical-align: middle;
	background-color: #ced;
	border: 1px solid #fff;
	padding: 5px;
	cursor: default;
	overflow: hidden;
}
.list_tbl tr td {
	width: auto;
	min-height: 31px;
	color: #000;
	font-size: 14px;
	line-height: 20px;
	text-align: left;
	vertical-align: top;
	background-color: #eee;
	border: 1px solid #fff;
	padding: 5px;
	cursor: default;
	overflow: hidden;
}
.list_tbl tr td .war {
	color: #c00;
}
.list_tbl tr.stop td,
.list_tbl tr td.stop {
	background-color: #ddd;
}
.list_tbl tr.week0 td {
	background-color: #fcd;
}
.list_tbl tr.week6 td {
	background-color: #cdf;
}
.list_tbl tr.holi1 td {
	background-color: #fcd;
}
.list_tbl tr td.cap {
	min-width: 200px;
	color: #039;
	font-size: 12px;
	line-height: 20px;
}
.list_tbl tr td .war {
	color: #c00;
}
.list_tbl tr td.auto {
	min-width: 250px;
}
.list_tbl tr th.w10,
.list_tbl tr td.w10 {
	width: 10px;
	min-width: 10px;
}
.list_tbl tr th.w20,
.list_tbl tr td.w20 {
	width: 20px;
	min-width: 20px;
}
.list_tbl tr th.w30,
.list_tbl tr td.w30 {
	width: 30px;
	min-width: 30px;
}
.list_tbl tr th.w40,
.list_tbl tr td.w40 {
	width: 40px;
	min-width: 40px;
}
.list_tbl tr th.w50,
.list_tbl tr td.w50 {
	width: 50px;
	min-width: 50px;
}
.list_tbl tr th.w60,
.list_tbl tr td.w60 {
	width: 60px;
	min-width: 60px;
}
.list_tbl tr th.w70,
.list_tbl tr td.w70 {
	width: 70px;
	min-width: 70px;
}
.list_tbl tr th.w80,
.list_tbl tr td.w80 {
	width: 80px;
	min-width: 80px;
}
.list_tbl tr th.w90,
.list_tbl tr td.w90 {
	width: 90px;
	min-width: 90px;
}
.list_tbl tr th.w100,
.list_tbl tr td.w100 {
	width: 100px;
	min-width: 100px;
}
.list_tbl tr th.w110,
.list_tbl tr td.w110 {
	width: 110px;
	min-width: 110px;
}
.list_tbl tr th.w120,
.list_tbl tr td.w120 {
	width: 120px;
	min-width: 120px;
}
.list_tbl tr th.w130,
.list_tbl tr td.w130 {
	width: 130px;
	min-width: 130px;
}
.list_tbl tr th.w140,
.list_tbl tr td.w140 {
	width: 140px;
	min-width: 140px;
}
.list_tbl tr th.w150,
.list_tbl tr td.w150 {
	width: 150px;
	min-width: 150px;
}
.list_tbl tr th.w160,
.list_tbl tr td.w160 {
	width: 160px;
	min-width: 160px;
}
.list_tbl tr th.w170,
.list_tbl tr td.w170 {
	width: 170px;
	min-width: 170px;
}
.list_tbl tr th.w180,
.list_tbl tr td.w180 {
	width: 180px;
	min-width: 180px;
}
.list_tbl tr th.w190,
.list_tbl tr td.w190 {
	width: 190px;
	min-width: 190px;
}
.list_tbl tr th.w200,
.list_tbl tr td.w200 {
	width: 200px;
	min-width: 200px;
}
.list_tbl tr th.w250,
.list_tbl tr td.w250 {
	width: 250px;
	min-width: 200px;
}
.list_tbl tr th.w300,
.list_tbl tr td.w300 {
	width: 300px;
	min-width: 250px;
}
.list_tbl tr td.lt {
	text-align: left;
}
.list_tbl tr td.rt {
	text-align: right;
}
.list_tbl tr td.ct {
	text-align: center;
}
.list_tbl tr td.sm {
	font-size: 12px;
}
.list_tbl tr td.box {
	padding: 3px 5px;
}
.list_tbl tr td.chk_box {
	width: 40px;
	min-width: 40px;
	text-align: center;
}
.list_tbl tr td.butt_box {
	width: 60px;
	min-width: 60px;
	padding: 3px 5px;
}
.list_tbl tr td.butt_box a {
	width: 100%;
	height: 24px;
	color: #fff;
	font-size: 12px;
	line-height: 14px;
	text-align: center;
	background-color: #05a;
	padding: 5px 0;
}
.list_tbl tr td.butt_box a.hover {
	background-image: linear-gradient(rgba(255,255,255,0.3), rgba(255,255,255,0));
}
.list_tbl tr.hover td:not(.rows) {
	background-color: #f6f6cc;
}
.list_tbl tr td.list {
	padding: 0;
}
.list_tbl tr td.list .list_tbl {
	margin: -1px;
}
.cale_list {
	width: calc(100% + 4px);
	min-width: 524px;
	margin: -2px;
	display: flex;
	flex-wrap: wrap;
}
.cale_list li {
	width: 14.28%;
	background-color: #eee;
	border: 2px solid #fff;
}
.cale_list li.col0 {
	background-color: #ddd;
}
.cale_list li p {
	height: 27px;
	font-size: 14px;
	line-height: 20px;
	text-align: center;
	padding: 3px;
	overflow: hidden;
}
.cale_list li p.week {
	font-size: 12px;
	background-color: #ddd;
}
.cale_list li p.day {
	background-color: #ddd;
}
.cale_list li.col0 p.day {
	color: #999;
}
.cale_list li p.holi {
	font-size: 12px;
	background-color: #ddd;
	border-top: 1px dotted #fff;
}
.cale_list li p.name {
	color: #039;
	font-size: 12px;
	background-color: #cde;
	border-top: 1px solid #fff;
}
.cale_list li p.data {
	border-top: 1px dotted #fff;
}
.cale_list li p.blank {
	border-top: 1px solid #fff;
}
.cale_list li p.col0 {
	background-color: #fcd;
}
.cale_list li p.col6 {
	background-color: #cdf;
}
#footer {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 40px;
	background-color: #333;
	display: flex;
}
#footer button {
	width: 20%;
	height: 40px;
	font-size: 14px;
}
#footer p {
	width: 20%;
	height: 40px;
	background-color: #333;
	box-shadow: -1px -1px 0 rgba(0,0,0,0.2) inset, 1px 1px 0 rgba(255,255,255,0.2) inset;
}
.grecaptcha-badge {
    margin-bottom: 40px;
}
button {
	box-shadow: -1px -1px 0 rgba(0,0,0,0.2) inset, 1px 1px 0 rgba(255,255,255,0.2) inset;
}
button.back {
	background-color: #666;
}
button.new {
	background-color: #e08;
}
button.edit {
	background-color: #f50;
}
button.link {
	background-color: #05a;
}
button.print {
	background-color: #50a;
}
button[disabled] {
	color: #ccc;
	background-color: #666;
}
button[disabled].hover {
	background-image: none;
}

@media screen and (max-width: 740px) {
#header {
	height: 40px;
}
#main {
	/* padding-top: 50px; */
	padding-top: 90px;
}
#header_top button {
	display: block;
}
#header_menu {
	position: absolute;
	top: 40px;
	right: 0;
	width: 240px;
	height: auto;
	max-width: 100%;
	max-height: calc(100vh - 80px);
	overflow-x: hidden;
	overflow-y: auto;
	display: none;
}
#header_menu > * {
	width: 100%;
}
#header_menu .list ul {
	position: static;
	height: auto;
}
.list_box {
	overflow-x: auto;
	overflow-y: hidden;
}
.list_box table {
	width: auto;
	min-width: calc(100% + 2px);
}
.edit_tbl tr td.list .check_list.list3 li {
	width: 50%;
}
.edit_tbl tr td.list .check_list.list4 li {
	width: 50%;
}
.edit_tbl tr td.list .album_list li {
	width: 50%;
}
input[type=text],
input[type=email],
input[type=url],
input[type=tel],
input[type=password],
input[type=number],
input[type=date],
select,
textarea {
	font-size: 16px;
	line-height: 22px;
}
}
@media screen and (max-width: 420px) {
.edit_tbl tr td.list .check_list.list2 li {
	width: 100%;
}
.edit_tbl tr td.list .check_list.list3 li {
	width: 100%;
}
.edit_tbl tr td.list .check_list.list4 li {
	width: 100%;
}
.edit_tbl tr td.list .album_list li {
	width: 100%;
}
}
