article {
	margin: 4% 0;
	overflow: hidden;
}
article header {
	width: 33.333%;
	float: left;
	color: #fff;
	text-align: center;
	background: rgb(13,70,71);
	padding: 2%;
}
article.community header {
	background: rgb(32,34,90);
}
article.parish-council header {
	background: rgb(57,18,80);
}
article header .month {
	font-size: 131.25%;
	display: block;
}
article header .day {
	font-size: 375%;
	display: block;
	margin-top: 0.25em;
}
article h2 {
	margin-top: 0;
	padding: 2%;
	color: #fff;
}
article.community h2 {
	background: rgb(32,34,90);
}
article.parish-council h2 {
	background: rgb(57,18,80);
}
article .content {
	width: 66.667%;
	float: right;
}

ul.calendar-nav {
	margin: 0;
	padding: 0;
	list-style-type: none;
}
ul.calendar-nav li {
	float: left;
	width: 33.3333%;
	margin: 0;
	padding: 0;
}
ul.calendar-nav li:nth-of-type(2) {
	text-align: center;
}
ul.calendar-nav li:nth-of-type(3) {
	text-align: right;
}
.events-calendar {
	display: none;
}
.events-listing ul.calendar-nav {
	overflow: hidden;
	padding: 0 2%;
}
.events-listing h3 {
	line-height: 131.25%;
	margin: 1em 2% 0 2%;
}
.events-listing li.vevent {
	background: rgba(13,70,71,0.1);
	padding: 2%;
	margin: 0 0 1% 0;
}
.events-listing span.time, .events-listing span.event {
	font-size: 112.5%;
	line-height: 131.25%;
	font-family:'Cambria W01 Bold';
	font-weight: normal;
	margin: 1em 0 0.5em;
}
.events-listing ul, .events-listing li {
	margin: 0;
	padding: 0;
}
.events-listing li {
	list-style-type: none;
}

.vevent p {
	padding: 0;
}

main .text {
	width: 100%;
	margin-top: 2%;
}

main .visual {
	width: 100%;
	margin-bottom: 2%;
}

main .visual .cmsmap {
	width: 100%;
	height: 300px;
}

.visual img {
	margin-top: 1em;
}

@media screen and (min-width: 420px) {
	.events-listing ul.calendar-nav {
 		padding: 0;
	}
	.events-listing h3 {
		margin: 1em 0 0 0;
	}
	article {
		margin: 0 0 2% 0;
	}
	article p {
		margin: 2%;
	}
	.map, .cmsmap {
		width: 33.333%;
		float: left;
		min-height: 125px;
		clear: left;
	}
}

@media screen and (min-width: 640px) {
	main .text {
		width: 50%;
		float: left;
		margin-top: 0;
	}
	main .visual {
		width: 50%;
		float: right;
		margin-bottom: 0;
	}
}

@media screen and (min-width: 768px) {
	.events-listing {
		display: none;
	}
	.events-calendar {
		display: block;
	}
	table.calendar {
		width:100%;
		border-spacing: 1px;
		border-collapse: separate;
	}
	table.calendar th, table.calendar td {
		width:14.2857%; 
	}
	table.calendar th {
		background: rgb(13,70,71);
	}
	table.calendar td {
		height: 6em;
		background: rgba(13,70,71,0.05);
	}
	table.calendar td.notinmonth {
		background: rgba(0,0,0,0.1);
	}
	table.calendar td.past {
		background: rgba(0,0,0,0.05);
	}
	table.calendar td.has-event {
		background: rgba(13,70,71,0.25);
	}
	table.calendar td.today {
		background: rgba(13,70,71,0.5);
	}
	table.calendar td:hover {
		background: rgba(13,70,71,0.75);
		-webkit-transition: background-color 500ms ease-out;
		-moz-transition: background-color 500ms ease-out;
		-o-transition: background-color 500ms ease-out;
		-ms-transition: background-color 500ms ease-out;
  	transition: background-color 500ms ease-out;
	}
	table.calendar span.day {
		display: block;
		font-family:'Cambria W01 Bold';
		font-weight: normal;
		margin-bottom: 0.25em;
	}
	table.calendar div.event {
		margin-bottom: 1em;
	}
	table.calendar tr:nth-of-type(even) {
		background: none;
	}
	table.calendar tbody tr:hover {
		background: none;
	}
}

@media screen and (min-width: 1440px) {
	main .text {
		width: 60%;
	}
	main .visual {
		width: 40%;
	}
}