/************************************
	Defaulting Magins & Padding
************************************/
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

/************************************
	Font Declaration
************************************/

@font-face {
	font-family: CopperplateGothicLightRegular;
	src: url('../fonts/Copperplate_Gothic_Light_Regular.ttf') format('truetype');
}

/************************************
	Stucture
************************************/

html, body {
	height: 100%;
	min-height: 100%;
}

body {
	width: 100%;	
	background: #000000;
	font-family: Verdana, Geneva, sans-serif;
}

div#wrapper {
	/*min-height: 100%;*/
	/*margin-bottom: -101px;*/
}

/*div#wrapper:after {
	height: 101px;
	content: "";
  	display: block;
}
*/
div#container {
	height: 100%;
	float: none;
	overflow: hidden;
}

div#content {
	width: 100%;
	margin: 0 auto;
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
	body {
		padding: 0 20px;
	}

	div#container {
		width: auto;
		margin: 20px auto;
	}
	
	div#content {
		padding: 0 10px;
	}
}

@media only screen and (min-width: 768px) and (max-width: 979px) {
	div#container {
		width: 724px;
		margin: 20px auto;
	}
}

@media only screen and (min-width: 980px) {
	div#container {
		width: 940px;
		margin: 20px auto;
	}
}

/************************************
	Header
************************************/
div#header {
	width: 100%;
	background-color: #000000;
}

div#headerWrapper {
	margin: 0 auto;
}

div#headerLogo {
	float: left;
	/*width: 525px;
	height: 142px;*/
}

div#headerLogo img {
	padding-top: 40px;
	/*width: 525px;
	height: 102px;*/
}

div#contactNumber {
	color: #AD0FBE;
    background: transparent;
    text-align: center;
    font-size: 24px;
    line-height: 24px;
}

a.telephoneLink {
	color: #AD0FBE;
	text-decoration: none;
}

@media only screen and (min-width: 0px) and (max-width: 767px) {

	div#contactNumber {
	    width: 215px;
	    height: 35px;
	    padding: 5px 0;
	    margin: 0 auto;
	    clear: both;
	}
}

@media only screen and (min-width: 768px) {

	div#contactNumber {
	    width: 245px;
	    height: 142px;
	    float: right;
	    padding: 59px 15px;
	}
}

@media only screen and (min-width: 0px) and (max-width: 375px) {
	div#header {
		height: 160px;
	}

	div#headerWrapper {
		height: 160px;
		width: auto;
	}
}

@media only screen and (min-width: 376px) and (max-width: 425px) {
	div#header {
		height: 175px;
	}

	div#headerWrapper {
		height: 175px;
		width: auto;
	}
}

@media only screen and (min-width: 426px) and (max-width: 767px) {
	div#header {
		height: 195px;
	}

	div#headerWrapper {
		height: 160px;
		width: auto;
	}
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
	div#headerLogo {
		width: 100%;
		padding: 0 10px;
		max-width: 490px;
		margin: 0 auto;
		float: none;
	}

	div#headerLogo img {
		width: 100%;
	}

}

@media only screen and (min-width: 768px) and (max-width: 979px) {
	div#header {
		height: 179px;
	}

	div#headerWrapper {
		height: 179px;
		width: 740px;
	}

	div#headerLogo {
		width: 100%;
		max-width: 480px;
	}

	div#headerLogo img {
		width: 100%;
	}
}

@media only screen and (min-width: 980px) {
	div#header {
		height: 179px;
	}

	div#headerWrapper {
		height: 179px;
		width: 940px;
	}

	div#headerLogo {
		width: 525px;
		height: 142px;
	}

	div#headerLogo img {
		width: 525px;
		height: 142px;
	}
}

/************************************
	Footer
************************************/
div#footer {
	float: left;
	clear: both;
	width: 100%;
	height: 101px;
	margin-top: 10px;
}

div#footer p {
	text-align: center;
	color: #ffffff;
	height: 19px;
	margin-bottom: 20px;
}

div#footerBannerWrapper {
	height: 62px;
	margin: 0 auto;
}

div#footerBannerLeft {
	background-image: url("../images/bottom_left_banner_bg2.png");
	height: 62px;
	width: 56px;
}

div#footerBannerCenter {
	background-image: url("../images/bottom_centre_banner_bg.png");
	background-repeat: repeat-x;
	height: 62px;
	float: left;
}

div#footerBannerRight {
	background-image: url("../images/bottom_right_banner_bg2.png");
	height: 62px;
	width: 76px;
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
	div#footerBannerWrapper {
		width: auto;
	}

	div#footerBannerLeft {
		position: absolute;
		left: 20px;
	}

	div#footerBannerCenter {
		width: 100%;
		padding-left: 56px;
		padding-right: 76px;
	}

	div#footerBannerRight {
		position: absolute;
		right: 20px;
	}
}

@media only screen and (min-width: 768px) and (max-width: 979px) {
	div#footerBannerWrapper {
		width: 724px;
	}

	div#footerBannerLeft {
		position: relative;
		float: left;
	}

	div#footerBannerCenter {
		width: 81%;
		max-width: 808px;
		padding-left: 56px;
		padding-right: 76px;
	}

	div#footerBannerRight {
		position: relative;
		float: left;
	}
}

@media only screen and (min-width: 980px) {
	div#footerBannerWrapper {
		width: 940px;
	}

	div#footerBannerLeft {
		position: relative;
		float: left;
	}

	div#footerBannerCenter {
		width: 808px;
	}

	div#footerBannerRight {
		position: relative;
		float: left;
	}
}

/************************************
	NavBar
************************************/

div#navBar {
	width: 100%;
	clear: both;
}

span.icon-bar {
    display: block;
    width: 18px;
    height: 2px;
    background-color: #f5f5f5;
    -webkit-border-radius: 1px;
    -moz-border-radius: 1px;
    border-radius: 1px;
    -webkit-box-shadow: 0 1px 0 rgba(0, 0, 0, 0.25);
    -moz-box-shadow: 0 1px 0 rgba(0, 0, 0, 0.25);
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.25);
}

span.icon-bar + span.icon-bar {
    margin-top: 3px;
}

div#navBar a {
	color: #ffffff;
	text-decoration: none;
	text-transform: uppercase;
	padding: 10px 15px;
	font-family: CopperplateGothicLightRegular;
	/*font-family: Verdana, Geneva, sans-serif;*/
	font-weight: normal;
	font-size: 16px;
}

div#navBar a:hover,
div#navBar a:focus,
div#navBar a:active {
	color: #000000;
	background-color: #ffffff;
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
	div#navBar {
		height: 32px;
		float: none;
	}

	div#navBar.active {
		height: 180px;
		z-index: 1000;
	}

	div#navBar ul#menu {
		display: none;
		width: 100%;
		list-style-type: none;
	    margin: 0;
	    padding: 0;
	    position: relative;
    	top: 32px;
    	background: #000000;
		z-index: 1000;
		height: 119px;
		border: 1px solid #ffffff;
	}
	
	div#navBar ul#menu li {
		clear: both;
		width: 100%;
		border-bottom: 1px solid #ffffff;
	}

	div#navBar ul#menu li:last-child {
		border-bottom: none;
	}

	div#navBar ul#menu li a {
		width: 100%;
		padding: 10px 20px;
		text-align: center;
		display: block;
	}
	
	div#navBar button#menuButton {
		display: block;
		position: absolute;
		right: 20px;
		background-color: #000000;
		border: 0;
		padding: 10px 5px;
	}
}

@media only screen and (min-width: 768px) {
	div#navBar {
		height: 19px;
		float: right;
	}

	div#navBar ul#menu {
		display: block;
		width: 349px;
		float: right;
		list-style-type: none;
	    margin: 0;
	    padding: 0;
	}

	div#navBar ul#menu li {
		float: left;
		width: auto;
	}
	
	div#navBar button#menuButton {
		display: none;
	}
}

/************************************
	Gallery
************************************/
div#galleryRow {
	display: block;
	position: relative;
	clear: both;	
	height: 200px;
}

div#galleryRow {
	margin-bottom: 20px;
}

a.galleryBlock {
	float: left;
	display: block;
	width: 314px;
	height: 204px;
	color: #000000;
	margin: 0;
	text-decoration: none;
	position: relative;
	text-align: center;
}

a.galleryBlock:hover {
	border: 2px solid #ffffff;
	border-radius: 3px;
	color: #ffffff;
}

a.galleryBlock h3 {
	position: absolute;
	top: 0;
	left: 0;
	padding: 27% 0;
	width: 100%;
	height: 34px;
	font-size: 1.5em;
	text-align: center;
	color: #ffffff;
	word-wrap: break-word;
	box-sizing: content-box;
}

a.colourBorder1 {
	border-width: 2px;
	border-style: solid;
	border-radius: 3px;
	border-color: #5A109C;
}

a.colourBorder2 {
	border-width: 2px;
	border-style: solid;
	border-radius: 3px;
	border-color: #89C541;
}

a.colourBorder3 {
	border-width: 2px;
	border-style: solid;
	border-radius: 3px;
	border-color: #FF5608;
}

a.colourBorder4 {
	border-width: 2px;
	border-style: solid;
	border-radius: 3px;
	border-color: #1294F6;
}

a.colourBorder5 {
	border-width: 2px;
	border-style: solid;
	border-radius: 3px;
	border-color: #F7412C;
}

a.colourBorder6 {
	border-width: 2px;
	border-style: solid;
	border-radius: 3px;
	border-color: #ffcc00
}

h3.colour1 {
	background: rgba(90, 16, 156, 0.75);
}

h3.colour2 {
	background: rgba(137, 197, 65, 0.75);	
}

h3.colour3 {
	background: rgba(255, 86, 8, 0.75);
}

h3.colour4 {
	background: rgba(18, 148, 246, 0.75);
}

h3.colour5 {
	background: rgba(247, 65, 44, 0.75);	
}

h3.colour6 {
	background: rgba(255,204,0, 0.75);
}	

a.galleryBlock h3.doubleLine {
	padding: 21.5% 0;
	height: 68px;
}

a.galleryBlock h3:hover,
a.galleryBlock h3:active,
a.galleryBlock h3:focus {
	background: rgba(0,0,0,0.30);
}

a.galleryBlock:first-child {
	margin-left: 0;
}

a.galleryBlock:last-child {
	margin-right: 0;
}

a.galleryBlock img {
	margin: 0 auto;
	text-align: center;
	position: relative;
}

div.highslide-thumbstrip h3.overlayed-title {
    display: none;
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
	div#galleryBlockWrapper {
		width: 314px;
		margin: 0 auto;
	}
}
@media only screen and (min-width: 768px) and (max-width: 979px) {
	div#galleryBlockWrapper {
		width: 650px;
		margin: 0 auto;
	}
}
@media only screen and (min-width: 980px) {
	div#galleryBlockWrapper {
		width: 990px;
		margin: 0 auto;
	}
}
/************************************
	About Page
************************************/
p.aboutHeader {
	font-size: 20px;
	margin-bottom: 10px;
}

p.aboutText {
	font-size: 16px;
	margin-bottom: 10px;
}

p.servicesText {
	font-size: 15px;
	margin-bottom: 10px;
	float: left;
	margin-right: 15px
}

p.aboutHeader,
p.aboutText,
p.servicesText {
	color: #ffffff;
}

p.doubleMargin {
	margin-bottom: 20px;
}

div#aboutWrapper {
	margin-top: 10px;
}

div#aboutPhotoWrapper img {
	width: 100%;
	height: 100%;
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
	div#aboutWrapper {
		width: 90%;
		float: none;
		text-align: left;
		margin: 0 auto;
	}

	div#aboutPhotoWrapper {
		width: 270px;
		float: none;
		margin: 20px auto;
		clear: both;
	}

	div#servicesWrapper {
		width: 270px;
		margin: 0 auto;
		float: none;
	}
}

@media only screen and (min-width: 768px) and (max-width: 979px) {
	div#aboutWrapper {
		width: 65%;
		float: left;
	}

	div#aboutPhotoWrapper {
		width: 30%;
		float: right;
		margin: 40px 0 0 0;
	}

	div#servicesWrapper {
		width: 100%;
		float: left;
	}
}

@media only screen and (min-width: 980px) {
	div#aboutWrapper {
		width: 65%;
		float: left;
	}

	div#aboutPhotoWrapper {
		width: 30%;
		float: right;
		margin: 40px 0 0 0;
	}

	div#servicesWrapper {
		width: 100%;
		float: left;
	}
}


/************************************
	Contact Form
************************************/

div#contactFormWrapper {
	height: auto;
	background-color: #C8C8C8;
	padding: 20px;
	border-radius: 8px;
	font-size: 16px;
}

label,
input[type=text],
textarea {
	float: left;
	clear: both;
}

label {
	margin-bottom: 10px;
}

input[type=text],
textarea {
	width: 100%;
	padding: 5px;
	border-radius: 4px;
	border: none;
	font-size: 16px;
}

input[type=text] {
	height: 26px;
	margin-bottom: 10px;
}

textarea {
	height: 100px;
	resize: none;
}

div.field {
	height: 65px;
}

div.textareaField {
	height: 150px;
	clear: both;
}

div.field {
	float: left;
	clear: both;
	width: 100%;
}

div#contactInfoWrapper h1 {
	width: 100%;
	padding-bottom: 5px;
}

div#contactInfoWrapper,
div#contactInfoWrapper h1,
div#contactInfoWrapper a {
	color: #ffffff;	
}

div#contactInfoWrapper a {
	text-decoration: none;
}

div#contactInfoWrapper a:hover {
	text-decoration: underline;
}

div#contactInfoWrapper p {
	padding-bottom: 5px;
}

div#contactInfoWrapper a.telephoneContactLink,
div#contactInfoWrapper a.emailLink {
	display: inline-block;
}

div#contactInfoWrapper p.telephoneInfo,
div#contactInfoWrapper p.locationInfo,
div#contactInfoWrapper p.emailInfo {
	margin-top: 10px;
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
	div#contactFormWrapper {
		width: 100%;
		min-width: 300px;
		float: none;
		clear: both;
		margin: 0 auto;
	}

	div#contactInfoWrapper {
		width: 100%;
		float: none;
		margin: 0 auto 20px;
	}
}
@media only screen and (min-width: 768px) and (max-width: 979px) {
	div#contactFormWrapper {
		width: 330px;
		float: right;
	}

	div#contactInfoWrapper {
		padding: 20px 15px;
		width: 390px;
		float: left;
	}
}
@media only screen and (min-width: 980px) {
	div#contactFormWrapper {
		width: 380px;
		float: right;
	}

	div#contactInfoWrapper {
		padding: 20px 15px;
		width: 390px;
		float: left;
	}
}
/************************************
	Common Styles
************************************/

h1{
	/*color: #fe8f00;*/
	color: #000000;
	font-size: 30px;
	text-align: left;
	position: relative;
	width: 250px;
	font-family: CopperplateGothicLightRegular;
	/*font-family: Verdana, Geneva, sans-serif;*/
}

h2 {
	font-size: 30px;
	margin-bottom: 20px;
}

form {
	width: 100%;
	height: 100%;
	margin: 10px 0;
}

p.welcomeHeader,
p.welcomeText {
	color: #ffffff;
	font-size: 16px;
}

p.welcomeText {
	margin: 10px 0 0;
}

p.servicesText i.fa-check {
	color: #4AA320;
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
	div#welcomeWrapper {
		width: 90%;
		float: none;
		text-align: left;
		margin: 0 auto;
	}

	p.welcomeHeader {
		margin: 20px 0;
	}
}

@media only screen and (min-width: 768px) and (max-width: 979px) {
	div#welcomeWrapper {
		width: 65%;
		float: left;
	}

	p.welcomeHeader {
		margin: 40px 0 0 0;
	}	
}

@media only screen and (min-width: 980px) {
	div#welcomeWrapper {
		width: 65%;
		float: left;
	}

	p.welcomeHeader {
		margin: 40px 0 0 0;
	}
}

/************************************
	Buttons
************************************/

.submitBtn {
	padding: 5px 10px;
	width: 140px;
	height: 35px;
	background-color: #585858;
	border: 1px solid #585858;
	border-radius: 3px;
	color: #FFFFFF;
	font-weight: bold;
	font-size: 18px;
	float: none;
	display: block;
	position: relative;
	margin: 10px auto 0;
	clear: both;
}

.submitBtn:hover,
.submitBtn:focus,
.submitBtn:active {
	background-color: #909090;
	cursor: pointer;
}
