#calendar {
	width: 100%;
	border-collapse: collapse;
}

#calendar td {
	border: 1px solid #e8e8e8;
	width: 14%;
	height: 100px;
	padding: 2px;
	vertical-align: top;
}

#calendar td p {
	font-size: 80%;
	margin: 0 0 8px 0;
	padding: 2px;
	background-color: LightYellow;
	border: 1px solid #ccc;
}
#calendar td a.btn {
	float: right;
	clear: both;
	font-size: 90%;
	margin-top: 0;
}

#calendar .now {
	color: red;
}

#calendar .day {
	float: right;
	padding: 0 2px;
	font-weight: bold;
	position: relative;
	z-index: 100;
}

#calendar td div div {
	position: relative;
}

#calendar td div.details {
	font-size: 80%;
	line-height: 1.2em;
	border: 1px solid #fce46a;
	padding: 5px;
	background-color: #fff6bf;
	position: absolute;
	left: 103%;
	top: 0;
	width: 100%;
	z-index: 200;
	color: black;
}

#calendar td.sat div.details {
	position: absolute;
	left: -103%;
	top: 0;
	width: 100%;
	z-index: 200;
}

#calendar td div.details p {
	font-size: 100%;
	margin: 1em 0;
	padding: 0;
	background-color: inherit;
	border: none;
	z-index: 100;
}

#calendar td div.details p:first-child {
	margin-top: 0;
}

#calendar td div.details p:last-child {
	margin-bottom: 0;
}

.btn { margin-left: 1em; }

.dirLink {
	color: black;
}

.details h1, .details h2 {
	font-size: 1.1em;
	margin: 1em 0;
	background: none;
}

.details ul, .details ol {
	margin: 0;
}

.themeMonth {
	font-family: 'Open Sans Condensed';
	font-weight: bold;
	font-size: 1.5em;
	color: #16468F;
}

#calendar td p.committeeMeeting {
	background-color: #f9fff2;
}

#calendar td p.district {
	background-color: #f6f6f6;
}
