#navigator {
	border-collapse: collapse;
	width: 100%;
	height: 46px;
}
#navigator .prev, #navigator .next {
	width: 40px;
}
#navigator .prev a, #navigator .next a {
	width: 40px;
	height: 46px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
#month {
	text-align: center;
}
#calendar {
	table-layout: fixed;
	border-collapse: collapse;
	width: 100%;
}
#calendar th, #calendar td {
	border: 1px solid #fff;
	border-width: 1px;
	border-style: solid;
	padding: 4px;
}
#calendar thead th {
	font-size: 12px;
}
#calendar td.future {
	opacity: 0.5;
}
#calendar .date {
	vertical-align: top;
	font-size: 12px;
	opacity: 0.8;
}
#calendar .other {
	opacity: 0.4;
}
#calendar .count {
	font-size: 16px;
	height: 16px;
	margin-top: 8px;
	text-align: right;
}
#calendar .count.zero {
	opacity: 0.35;
}
body.light #calendar td, body.light #calendar th {
	border-color: #e3e3e3;
}
body.dark #calendar td, body.dark #calendar th {
	border-color: #212121;
}
body.light #calendar thead th {
	background: rgba(0, 0, 0, 0.05);
}
body.dark #calendar thead th {
	background: rgba(255, 255, 255, 0.05);
}
@media screen and (min-width:400px) {
	#calendar .count {
		font-size: 20px;
		height: 20px;
		margin-top: 10px;
	}
}
@media screen and (min-width:500px) {
	#calendar .count {
		font-size: 24px;
		height: 24px;
		margin-top: 12px;
	}
}