/* グローバル */

.text-red {
	color: #ff0000;
}

.text-blue {
	color: #466feb;
}

.font-weight-bold {
	font-weight: 700;
}

table.table-fluid {
	width: 100%;
}

.mr-1 {
	margin-right: .25rem;
}

.mr-2 {
	margin-right: .5rem;
}

.mr-3 {
	margin-right: 1rem;
}

.mt-1 {
	margin-top: .25rem;
}

.mt-2 {
	margin-top: .5rem;
}

.my-3, .mt-3 {
	margin-top: 1.0rem;
}

.mt-4 {
	margin-top: 1.5rem;
}

.mt-5 {
	margin-top: 2rem;
}

.mt-6 {
	margin-top: 3rem;
}

.mb-1 {
	margin-bottom: .25rem;
}

.mb-2 {
	margin-bottom: .5rem;
}

.my-3, .mb-3 {
	margin-bottom: 1.0rem;
}

.mb-4 {
	margin-bottom: 1.5rem;
}

.mb-5 {
	margin-bottom: 2rem;
}

.mb-6 {
	margin-bottom: 3rem;
}

/* END グローバル */

/* 空情報 */

table.cal-monthly-0 tbody th.sites {
	background: #f8f9f0;
}

table.cal-monthly-1 tbody th.sites {
	background: #e0e0e0;
}

table.cal-monthly-2 tbody th.sites {
	background: #fcffae;
}

table.cal-monthly-3 tbody th.sites {
	background: #c3cc94;
}

table.cal-monthly-4 tbody th.sites {
	background: #b8d2a6;
}

.bgfull {
	background-color: #d7f6d6;
}

table.w100p {
	width: 100%;
}

table.w100p tr:hover {
	background-color: #FFFFFF !important;
	/* マウスオーバー時の行の背景色 */
}

a.btn {
	text-decoration: none;
}

.btn {
	background-color: #ecc573;
	border-radius: 5px;
	padding: 5px 10px;
	border: 1px #c0c0c0 solid;
}

.btn.btnwide {
	background-color: #ecc573;
	border-radius: 5px;
	padding: 5px 10px;
	border: 1px #c0c0c0 solid;
	font-size: 120%;
}

.table-scroll {
	overflow: auto;
	/*スクロールさせる*/
	white-space: nowrap;
	/*文字の折り返しを禁止*/
	width: 200px;
	/*今回の設置を分かりやすくするためワザと狭い幅を指定。本来は不必要な指定です。*/
}

/* 以下、スクロールバーを追加 */

.sticky_table_wrapper {
	overflow: scroll;
	width: calc(100vw - 1rem);
	height: 75vh;
}

.sticky_table_wrapper .fixed01 {
	position: sticky;
	left: 0;
}

.sticky_table_wrapper .fixed01:before {
	content: "";
	position: absolute;
	top: -1px;
	left: -1px;
	width: 100%;
	height: 100%;
	border: 1px solid #ccc;
}

.table-scroll::-webkit-scrollbar {
	height: 5px;
}

.table-scroll::-webkit-scrollbar-track {
	background: #333;
}

.table-scroll::-webkit-scrollbar-thumb {
	background: #999;
}

/* END 空情報 */

.box-section:first-child {
	margin-bottom: 2em;
}

h3.icon-plus-squared:before, h3.icon-minus-squared:before {
	margin-left: 0em;
	margin-right: 1em;
}

.innerTable {
	margin-bottom: 1rem;
}

.sp-br {
	font-size: 80%;
}

.box_legend {
	margin: 2rem 0;
}

.box_legend span, span.grpH, span.grpS, span.grpL, span.grpF {
	border: 1px #CCCCCC solid;
}

.calendar_box {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 3rem;
}

.cal_table_outer, .cal_navigation_outer {
	color: #898989;
	padding: 10px;
	margin: 3px 3%;
	border: 1px #cccccc solid;
	background-color: #EEEEEE;
	width: 94%;
}

.cal_navigation_outer {
	padding: 5px 10px;
}

.cal_month {
	font-size: 24px;
	text-align: center;
	line-height: 200%
}

table.cal_matrix, table.cal_matrix_youbi {
	border-collapse: separate;
	border-spacing: 2px;
	width: 100%;
	table-layout: fixed;
}

table.cal_matrix tr td {
	width: 14.2%;
	background-color: #FFFFFF;
}

table.cal_matrix tr td.grpH, .grpH {
	background-color: #ffe3ff;
}

table.cal_matrix tr td.grpS, .grpS {
	background-color: #cfe9ff;
}

table.cal_matrix tr td.grpL, .grpL {
	background-color: #ceffe2;
}

table.cal_matrix tr:hover {
	background-color: #FFFFFF !important;
	/* マウスオーバー時の行の背景色 */
}

td.colomn {
	padding: 0;
	/* border: 1px #cccccc solid; */
}

td.colomn .tit {
	padding: 0 5px;
	background-color: #cccccc;
	color: #FFFFFF;
}

td.colomn .dat {
	padding: 5px;
	text-align: center;
}

table.cal_matrix tr td.hide {
	opacity: 0.35
}

table.cal_list tr td.hide {
	/* opacity: 0.35 */
}

table.cal_list tr.hide, table.cal_list tr th.hide, table.cal_list tr td.hide {
	background-color: #f0f0f0;
}

table.cal_matrix tr td.full, .grpF {
	background-color: #ffc0cb
}

table.cal_matrix_youbi {
	border: none;
	background-color: #EEEEEE;
}

table.cal_matrix_youbi tr td {
	width: 14.2%;
	text-align: center;
	border: none;
	padding: 0;
}

form {
	margin-bottom: 2rem
}

form dl dt small {
	color: #777777;
	font-weight: 400;
	display: block;
	font-size: 85%;
}

input[type="number"] {
	text-align: right;
}

ul.disc {
	margin: 0 7em;
}

ul.disc li {
	list-style: disc;
}

#Kiyaku {
	margin: 0 10em;
}

form.checkboxRequired .checkP {
	margin-bottom: 10px;
	padding-left: 2em;
	text-indent: -1.5em;
}

.inactive {
	opacity: 0.5;
}

input[type="submit"] {
	background-color: #b1d6c8;
}

input[type="submit"]:hover {
	background-color: #89aea0;
}

input.backbutton {
	background-color: #ffe1f3;
	border-color: #ffc0cb;
	;
}

input.backbutton:hover {
	background-color: #ffc0cb;
}

form.checkboxRequired .checkP ul {
	margin-left: 0em;
	list-style: circle;
	margin-top: 0.5em;
}

form.checkboxRequired .checkP ul li {
	text-indent: 0;
	margin-left: 1em;
}

form.checkboxRequired .txtKome {
	margin: 0.5em 0 1em 3em
}

form.checkboxRequired input[type="checkbox"] {
	width: 16px;
	height: 16px;
	position: relative;
	top: 3px;
}

form.checkboxRequired label {
	display: inline;
}

form.checkboxRequired label span {
	font-size: 110%;
	font-weight: 700;
}

.txtCenter {
	text-align: center;
	display: block
}

/* ラベルのスタイル　*/

.size-L label {
	padding-left: 3rem;
	/* ラベルの位置 */
	font-size: 24px;
	line-height: 24px;
	display: inline-block;
	cursor: pointer;
	position: relative;
}

/* ボックスのスタイル */

.size-L label:before {
	content: '';
	width: 20px;
	/* ボックスの横幅 */
	height: 20px;
	/* ボックスの縦幅 */
	display: inline-block;
	position: absolute;
	left: 0;
	background-color: #fff;
	box-shadow: inset 1px 2px 3px 0px #000;
	border-radius: 6px 6px 6px 6px;
}

/* 元のチェックボックスを表示しない */

.size-L input[type=checkbox] {
	display: none;
}

/* チェックしsize-Lた時のスタイル */

.size-L input[type=checkbox]:checked+label:before {
	content: '\2713';
	/* チェックの文字 */
	font-size: 22px;
	/* チェックのサイズ */
	color: #fff;
	/* チェックの色 */
	background-color: #f00;
	/* チェックした時の色 */
}

.button-L {
	font-size: 150%;
}

@media screen and (min-width: 481px) {
	.flex-items {
		width: 50%;
		margin-bottom: 10px;
	}
}

@media screen and (max-width: 480px) {
	.flex-items {
		width: 100%;
	}
	#Kiyaku {
		margin: 0;
	}
	ul.disc {
		margin: 0 0.5em;
	}
	.innerTable {
		width: 100%;
	}
	.sp-br {
		display: block;
	}
}

/* モーダルウィンドウ全体のレイアウト（画面いっぱいに表示）*/

.c-modal {
	display: none;
	height: 100vh;
	position: fixed;
	top: 0;
	width: 100%;
	top: 0;
	left: 0;
	z-index: 9999;
}

/* 黒背景の設定 */

.c-modal_bg {
	background: rgba(0, 0, 0, 0.6);
	height: 100vh;
	width: 100%;
}

/* ウィンドウの設定 */

.c-modal_content {
	background: #fff;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	border-radius: 5px;
}

.c-modal_content._sm {
	width: 30%;
}

.c-modal_content._md {
	width: 50%;
}

.c-modal_content._lg {
	width: 70%;
}

.c-modal_content_inner {
	position: relative;
	padding: 25px;
}

/* 閉じるボタン */

.c-modal_close {
	position: absolute;
	top: 15px;
	right: 25px;
}

/* 新しいモーダル */

.modal_open {
	/*
	display: inline-block;
	margin: 3vw;
	float: left;
*/
}

.modal_box {
	position: fixed;
	z-index: 9999;
	display: none;
	width: 80%;
	max-width: 960px;
	margin: 0;
	padding: 60px 2vw 80px;
	border: 2px solid #aaa;
	text-align: center;
	background: #fff;
	box-sizing: border-box;
}

.modal_close {
	position: absolute;
	top: 0;
	right: 0;
	display: block;
	cursor: pointer;
	width: 36px;
	font-size: 22px;
	color: #000;
	line-height: 36px;
	text-align: center;
	background: #e6e6e6;
}

.modal_close i {
	line-height: 62px;
	vertical-align: bottom;
}

.modal_bg {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 6666;
	display: none;
	width: 100%;
	height: 120%;
	background-color: rgba(0, 0, 0, 0.7);
}

.link_area {
	overflow: hidden;
	max-width: 410px;
	margin: 60px auto 0;
	text-align: center;
}

.link_area .modal_link {
	display: inline;
}

.link_area .modal_link a {
	display: inline-block;
	width: 180px;
	color: #000;
	line-height: 2.5;
	text-decoration: none;
	margin: 0 10px;
	background: #e6e6e6;
}

.link-area ul li.modal_link:first-child a {
	float: left;
}

.link-area ul li.modal_link:last-child a {
	float: right;
}

.pc-only {
	display: block;
}

.mobile-only {
	display: none;
}

.no-wrap {
	white-space: nowrap;
}

@media screen and (max-width: 769px) {
	.pc-only {
		display: none;
	}
	.mobile-only {
		display: block;
	}
	/*  ウィンドウサイズ769px以下の時のスタイル  */
	.modal_box {
		padding: 40px 1vw 20px;
	}
	.modal_box .modal_box_inner {
		height: 65vh;
		overflow: scroll;
	}
	.modal_close {
		position: absolute;
		width: 40px;
		line-height: 32px;
		font-size: 24px;
	}
	.modal_close i {
		line-height: 32px;
	}
	.link_area {
		margin: 25px auto 0;
	}
	.link_area .modal_link a {
		margin: 15px auto 0;
	}
	.link_area ul li.modal_link:first-child a {
		float: none;
		margin-top: 0;
	}
	.link_area ul li.modal_link:last-child a {
		float: none;
	}
}