/* カレンダー用
---------------------------------------------------------------------------- */

/* div.cal_wrapper {
	height: 100%;
} */

div.cal_wrapper table {
	inline-size: 100%;
	table-layout: fixed;
}

div.schedule_wrapper {
	padding: 10px 0px;
	width: 100%;
	border: solid 1px #c3c3c3;
	border-radius: 5px;
	box-shadow: 1px 1px 3px #666;
}

div.schedule_wrapper h3 {
	padding: 0px 10px;
	font-weight: normal;
	margin: 0px;
	font-size: 12px;
	color: #666;
}

div.schedule_wrapper div.schedule_list {
	padding: 0px 10px;
	margin: 0px;
}

div.schedule_wrapper div.schedule_list ol {
	padding: 0px;
	margin: 5px auto;
	border-top: solid 1px #c3c3c3;
}

div.schedule_wrapper div.schedule_list ol li {
	padding: 5px 10px 0px 0px;
	margin: 0px 0px 0px 30px;
	font-size: 12px;
	line-height: 1.5em;
}

div.schedule_wrapper div.schedule_list ol li:hover {
	text-decoration: underline;
}

div.cal_wrapper table.cal tr th p {
	margin: 0px;
	color: #000;
	font-size: 16px;
	font-family: "Inter", sans-serif;
	font-weight: 700;
	padding-bottom: 12px;
}

@media (max-width: 480px) {
	div.cal_wrapper table.cal tr th p {
		font-size: 15px;
	}
}

.cal-mm {
	font-size: 30px;
	margin-right: 7px;
}

@media (max-width: 480px) {
	.cal-mm {
		font-size: 24px;
	}
}

.cal-yy {
	margin-left: 7px;
}

div.cal_wrapper table.cal tr th div.cal_ui {
	/* float: right; */
	display: none;
}

div.cal_wrapper table.cal tr th div.cal_ui input {
	border: solid 1px #c3c3c3;
	background-color: #FFF;
	font-size: 12px;
	margin: 0px 1px;
	padding: 1px 5px;
	border-radius: 3px;
}

div.cal_wrapper table.cal tr td {
	font-size: 15px;
	font-weight: 600;
	text-align: center;
}

@media (max-width: 480px) {
	div.cal_wrapper table.cal tr td {
		font-size: 14px;
	}
}

div.cal_wrapper table.cal tr.headline td {
	color: #000;
	padding-bottom: 15px;
}

@media (max-width: 480px) {
	div.cal_wrapper table.cal tr.headline td {
		padding-bottom: 12px;
	}
}

div.cal_wrapper table.cal tr.headline td {
	border-bottom: 1px solid #c3c3c3;
}

div.cal_wrapper table.cal tr.headline td:first-child {
	color: #F00;
}

div.cal_wrapper table.cal tr.headline td:last-child {
	color: #0076ff;
}

div.cal_wrapper table.cal tr.headline {
	border-bottom: 1px solid #c3c3c3;
}

div.cal_wrapper table.cal tr td div {
	position: relative;
	padding: 20px 15px;
	font-size: 16px;
	line-height: 1;
	text-align: center;
	background-color: #FFF;
	border-radius: 3px;
	font-family: "Inter", sans-serif;
	font-optical-sizing: auto;
	font-weight: 600;
}

@media (max-width: 480px) {
	div.cal_wrapper table.cal tr td div {
		padding: 15px 10px;
		font-size: 14px;
	}
}

div.cal_wrapper table.cal tr td div span {
	display: none;
	position: absolute;
	top: 20px;
	left: 0px;
	width: 180px;
	border: solid 1px #EEE;
	background-color: #FFF;
	text-align: left;
	padding: 5px;
	z-index: 10;
	color: #000;
	font-weight: normal;
	line-height: 1.5em;
	box-shadow: 1px 1px 3px #666;
}

/* �ȉ��A�N���X�w�肷��Ƃ��̃A�� */

div.cal_wrapper table.cal tr td div.Sat {
	color: #0076ff;
}

div.cal_wrapper table.cal tr td div.Sun {
	color: #ff0000;
}

div.cal_wrapper table.cal tr td div.Today {
	font-weight: bolder;
}

div.cal_wrapper table.cal tr td div.Deli {
	background-color: #EFE;
}

.Holiday {
	z-index: 1;
}

.Holiday::after {
	content: '';
	position: absolute;
	background-color: #c3c3c3 !important;
	border-radius: 10.0rem !important;
	width: 45px;
	height: 45px;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	margin: auto;
	z-index: -1;
}

@media (max-width: 480px) {
	.Holiday::after {
		width: 30px;
		height: 30px;
	}
}

div.cal_wrapper table.cal tr td div.Birthday {
	font-weight: bolder;
	background-color: #EEF;
	color: #090;
	border-radius: 3px;
}

div.cal_wrapper table.cal tr td div.backward {
	color: #c3c3c3;
	font-weight: normal;
	background-color: #FFF !important;
	border-radius: 3px;
}

div.cal_wrapper table.cal tr td div.backward::after {
	display: none;
}

div.cal_wrapper table.cal tr td div.pointer {
	cursor: pointer;
}

div.cal_wrapper table.cal tr td div.pointer:hover {
	background-color: #EEE;
}

.cal-close {
	font-size: 14px;
	font-weight: 600;
	margin-top: 12px;
	display: flex;
	align-items: center;
}

.cal-close span {
	width: 20px;
	height: 20px;
	border-radius: 10.0rem;
	background-color: #c3c3c3;
	display: inline-block;
	margin-right: 8px;
}

@media (max-width: 480px) {
	.cal-close {
		font-size: 13px;
		margin-top: 10px;
	}
}

@media (max-width: 480px) {
	.cal-close span {
		width: 18px;
		height: 18px;
	}
}