/*
    PyroCMS Basic 2 Template
    101 Design Pty Ltd
    http://www.101design.com.au
*/

/* ----- Dev Outlines -----
div { outline: 1px dashed #f00; outline: 1px dashed rgba(255, 0, 0, .2); }
h1, h2, h3, h4, h5, h6 { outline: 1px dotted fc3; outline: 1px dotted rgba(255, 204, 51, .2); }
p { outline: 1px dotted #309; outline: 1px dotted rgba(51, 0, 153, .2); }
ol, ul { outline: 1px dotted #096; outline: 1px dotted rgba(0, 153, 102, .5); }
ol > li, ul > li { outline: 1px dotted #3fc; outline: 1px dotted rgba(51, 255, 204, .3); }
li li { outline: 1px dotted #cff; outline: 1px dotted rgba(204, 255, 255, .5); }
a { outline: 1px dashed #363; outline: 1px dashed rgba(51, 102, 51, .5); }
span { outline: 1px dotted #630; outline: 1px dotted rgba(102, 51, 0, .1); }
table { outline: 1px dotted #666; outline: 1px dotted rgba(102, 102, 102, .3); }
th, tr, td { outline: 1px dotted #ccc; outline: 1px dotted rgba(204, 204, 204, .2); }
header, nav, section, footer { outline: 1px dashed #f00; outline: 1px dashed rgba(255, 0, 0, .2); }
*//**/

/* ----- Standard Elements ----- */

body {
    font: normal 14px/1.25, Arial, Helvetica, sans-serif; color: #000;
}

p, h1, h2, h3, h4, h5, h6 {
    line-height: 1.25;
    margin: 0 0 1em 0;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'open_sansbold', Arial, Helvetica, sans-serif; font-weight: normal;
}

h1 {
    margin-bottom: 0.65em;
    font-size: 2em;
}

h2 {
    margin-bottom: 0.9em;
    font-size: 1.5em
}

h3 {
    margin-bottom: 1.3em;
    font-size: 1em;
}

h4 {
    margin-bottom: 1.5em;
    font-size: 0.9em;
}

h5 {
    margin-bottom: 1.65em;
    font-size: 0.8em;
}

h6 {
    margin-bottom: 1.9em;
    font-size: 0.7em;
}

.inline-block {
    display: inline-block; *display: inline; *zoom: 1;
}

.left {
    text-align: left;
}

.center {
    text-align: center;
}

.right {
    text-align: right;
}

.strong {
    font-weight: bold;
}

.em {
    font-style: italic;
}

a:link, a:visited {
    text-decoration: none;
    color: #2D2F91;
}

a:hover, a:active {
    text-decoration: underline;
    color: #2D2F91;
}

a > img {
    border: none;
}

ul, ol {
    margin: 0 0 1em 0; padding: 0 0 0 1em;
}

ul {
    list-style: disc outside none;
}

ol {
    list-style: decimal outside none;
}

ol ol {
    list-style: lower-roman outside none;
}
li {
   margin-left: 1em;
}

ul li ul {
    margin-bottom: 0;
}

ul.left_col,
ul.right_col {
    display: block; float: left;
    width: 50%;
    margin-left: 0;
}

ul.no-bullet{
	list-style-type:none;
	padding:0;
}
ul.no-bullet li{
	margin:0;
}

img.left {
    display: block; float: left;
}

img.right {
    display: block; float: right;
}

img.center {
    display: block;
    margin: 0 auto;
}

.cufon-loading {
    visibility: hidden;
}

.mobile-only {
    display: none;
}

.success {
    color: #252;
}

.error {
    color: #522;
}

iframe {
    position: relative; z-index: 0;
}

/* jQuery UI */

.ui-widget {
    font-size: 0.8em;
}

/* ----- Sections ----- */

.page-width {
    width: 980px;
}

#wrapper {
    z-index: 0;
    margin: 0 auto;
}


/* Header */

.home-header{
    position:absolute;
    top:15%;
    bottom:70%;
    left:0;
    right:0;
    margin:auto 0;
}

.home header.page{
    border-top:2px solid #2d2f91;
    border-bottom:2px solid #2d2f91;
}

header.page {
    position: relative;
    background:#fff;
}

header.page > .inner {
	position: relative;
	margin: 0 auto;
	height: 132px;
}

header.page > .inner .home-link{
	display:block;
	float:left;
	margin:10px 0;
}

header.page > .inner .home-link img{
	width:200px;
	height:auto;
}

header.page > .inner .header-text{
	float:right;
	margin:0;
	color:#fff;
	width:492px;
	height:auto;
}



nav.primary{
	clear:both;
	border-top:2px solid #ff0000;
	border-bottom:2px solid #ff0000;
	background:#ff0000;
}

nav.primary ul.slimmenu {
    width: 980px;
    margin: 0 auto;
}

nav.primary ul.slimmenu li {
    margin-left: 0;
    border-left:none;
    background:url(../img/interface/nav-bullet.png) no-repeat left center;
	background-size:30px auto;
}

nav.primary ul.slimmenu li:first-child{
	background:none;
}

nav.primary ul.slimmenu li a{
	padding: 10px 60px 10px 85px;
	padding:10px 30px 10px 60px;
	color:#fff;
    font-family: 'open_sansbold', Arial, Helvetica, sans-serif; font-weight: normal;
	background:transparent;
	text-transform:uppercase;
	font-size:18px;
}

nav.primary ul.slimmenu li a:hover{
	background:transparent;
	color:#2D2F91;
}

nav.primary ul.slimmenu li.current a{
	color:#2D2F91;
}

nav.primary ul.slimmenu li:first-child a{
	padding-left:15px;
}

nav.primary ul.slimmenu li:last-child a{
	padding-right:15px;
}

nav.primary ul.slimmenu li.first ul {
    margin-left:0;
}

nav.primary ul.slimmenu li ul {
    width: 20em;
    padding-left: 0;
    padding-top:2px;
    z-index:9999;
    margin-left:50px;
}

nav.primary ul.slimmenu li ul li{
	background:none;
}

nav.primary ul.slimmenu li ul li a {
    width: 170px;
    border-bottom:none;
    background:#2D2F91;
    padding:12px 15px !important;
    font-size:12px;
    text-transform:none;
}

nav.primary ul.slimmenu li ul li a:hover {
	border-bottom:none;
	background:#fff;
	color:#2D2F91;
}

nav.primary ul.slimmenu li.current ul li a {
	border:none;
	color:#fff;
}

nav.primary ul.slimmenu li.current ul li a:hover {
	border:none;
	color:#2D2F91;
}

nav.primary ul.slimmenu li ul li.current a {
	border:none;
	color:#fff;
}

nav.primary ul.slimmenu li ul li.current a:hover {
	border:none;
	color:#2D2F91;
}

nav.primary ul.slimmenu li ul li.current a {
	border:none;
}

nav.primary ul.slimmenu.collapsed {
    /* ?? */
}

nav.primary ul.slimmenu .sub-collapser{
	display:none;
}










/* BANNER */
#banner-wrapper{
	width:100%;
	max-height:850px;
	padding:0;
	position:relative;
	border-bottom:#ebeaea solid 1px;
}
.home #banner-wrapper{
	max-height:850px;
}
#banner {
    height: auto;
 	width:100%;
 	min-width:982px;
    max-height:850px;
    overflow: hidden;
    z-index: 0;
    margin:0 auto;
    background:#000;
    position:relative;
}
.home #banner {
    max-height:850px;
}
#banner > div {
    margin: 0 auto;
}
#banner a{
	width:100%;
	height:auto;
}
#banner img {
    display: none;
 	width:100%;
    height:auto;
    border-bottom:1px solid #4e4e4e;
}
#banner img:first-child {
    display: block;
}

#banner .slide .text{
	position:absolute;
	top:0;bottom:0;left:0;right:0;
	margin:auto;
	height:200px;
	width:980px;
	text-align:center;
	z-index:9999;
}

#banner .slide .text a:hover{
	text-decoration:none;
}

#banner .slide .text .caption-text{
	display:block;
	color:#fff;
	text-transform:uppercase;
	font-size:100px;
	font-family: 'open_sans_condensedbold', Arial, Helvetica, sans-serif; font-weight: bold;
	text-shadow: 0px 0px 5px #000;
}

#banner .slide .text .caption-button{
	display:inline-block;
	width:auto;
	color:#fff;
	background:#d42026;
	text-shadow: 0px 0px 2px #000;
	padding:8px 15px 8px 25px;
	font-family: 'open_sansmedium', Arial, Helvetica, sans-serif; font-weight: normal;
	font-size:22px;
	border:1px solid #fff;
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	border-radius: 10px;
	line-height:39px;
}

#banner .slide .text .caption-button span.arrow{
	width:39px;
	height:39px;
	background:url(../img/interface/banner-arrow.png) no-repeat center;
	background-size:39px;
	display:inline-block;
	padding:0 0 0 40px;
}

#banner .banner-left{
	position:absolute;
	top:0;
	bottom:0;
	left:0;
	display:block;
	width:auto;
	height:100%;
	margin:auto;
	z-index:999;
	border:none;
}

#banner .banner-right{
	position:absolute;
	top:0;
	bottom:0;
	right:0;
	display:block;
	width:auto;
	height:100%;
	margin:auto;
	z-index:999;
	border:none;
}


.cycle-pager {
    text-align: center; width: 100%; z-index: 0; position: absolute; bottom: 10px; overflow: hidden;
}
.cycle-pager span {
    font-family: arial; font-size: 50px; width: 16px; height: 16px;
    display: inline-block; color: #ddd; cursor: pointer;
    margin:0 2px;
}
.cycle-pager span.cycle-pager-active { color: #CD1F24;}
.cycle-pager > * { cursor: pointer;}


/* Sub Banner */
#sub-banner-wrapper{
	background-image:url(../img/banner/sub-banner-1.jpg);
	position:relative;
	overflow:hidden;
	background-repeat:no-repeat;
	background-position:center;
}
#sub-banner-wrapper #sub-banner{
	height:251px;
	margin:0 auto;
	background:transparent;
	position:relative;
}
#sub-banner-wrapper #sub-banner h1{
	position:absolute;
	bottom:0;
	left:10px;
	line-height:43px;
	text-transform:uppercase;
	font-size:60px;
	margin-bottom:0;
	font-family: 'open_sans_condensedbold', Arial, Helvetica, sans-serif; font-weight: bold;
	color:rgba(255,255,255,0.7);
	z-index:999;
}







#content > .inner {
    margin: 0 auto;
    background: #fff;
}

#content main {
	position: relative; float: left;
	width: 960px; min-height: 20em;
	padding: 40px 10px;
}

#content main > *:last-child {
	margin-bottom: 0;
}

.contact #content main {
	padding-bottom:0px;
}

#content h3{
	color:#FF0000;
	font-family: 'open_sanslight', Arial, Helvetica, sans-serif; font-weight: 600;
	font-size:1.1em;
	line-height:1.3;
	margin-bottom:0.2em;
}

#content p{
	font-size:1em;
	line-height:1.3em;
	color:#333;
}

#content ul{
	font-size:1em;
	color:#333;
	line-height:1.6;
	padding:0 0 0 5px;
	margin:0;
}

#content ul li h3{
	margin-bottom:0;
}

.home #content{
	display:none;
}

.home #content > .inner{
	background:transparent;
}

.home #content main{
	width:960px;
	min-height:20em;
}

.home .float-left{
	width:47%;
	float:left;
}

.home .float-right{
	width:50%;
	float:right;
}

.home .float-right img{
	width:100%;
	height:auto;
}

.home footer.page{
	position:absolute;
	bottom:0;
	left:0; right:0;
}

.blog #content main{
	width:600px;
}

.blog aside.main-sidebar {
    margin: 50px 0 0 0;
    padding: 0 10px 10px 30px;
	float: right;
	border-left: 1px solid #ccc;
}





footer{
	position: relative;
	color:#fff;
	text-align:center;
}

.home footer{
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
}

footer ul{
	margin:10px 0;
	font-family: 'open_sansbold', Arial, Helvetica, sans-serif; font-weight: normal;
	overflow:hidden;
}

footer a:link, footer a:visited{
	color:#fff;
}

footer #top {
    position: relative;
    background: #2d2f91;
}

footer #top > .inner {
    margin: 0 auto;
}

footer #top > .inner {
	font-size:18px;
}

footer #top > .inner ul li{
	float:left;
	list-style-type:none;
	margin:0;
	padding:0;
}

footer #top > .inner .seperator{
	width:26px;
	display:inline-block;
	background:url(../img/interface/seperator.png) no-repeat center;
	background-size:8px auto;
}

footer #bottom {
    position: relative;
    background: #ff0000;
}

footer #bottom > .inner {
    margin: 0 auto;
}

footer #bottom > .inner ul{
	font-family: 'open_sansregular', Arial, Helvetica, sans-serif; font-weight: normal;
	margin:10px 0;
	overflow:hidden;
}

footer #bottom > .inner ul li{
	float:left;
	list-style-type:none;
	margin:0;
	padding:0;
}

footer #bottom > .inner .seperator{
	width:20px;
	display:inline-block;
	background:url(../img/interface/seperator.png) no-repeat center;
	background-size:5px auto;
}

footer #bottom .yellow{
	color:#FFFF02;
}






/* PROJECTS */
.project-left{
	width:400px;
	float:left;
	overflow:hidden;
}

.project-gallery{
	float:right;
	width:500px;
	height:400px;
	position:relative;
	overflow:hidden;
}

.project-gallery .cycle-slide img{
	width:500px;
	height:auto;
}

.project-gallery .cycle-pager{
	width:500px;
	bottom:0;
}

.project-gallery .cycle-pager .thumb{
	margin:0 5px;
}



/*
#cg_test-gallery{
	width:500px;
	height:400px;
}

#cg_test-gallery .cycle-slide img{
		width:500px;
	height:331px;
}
*/



/* CONTACT */
.contact-left{
	width:350px;
	float:left;
}

.contact-right{
	width:500px;
	float:right;
}

.contact #content h3{
	margin-bottom:1em;
}

#contact_form_row_1,
#contact_form_row_2{
	float:left;
	clear:none;
	width:49%;
}

#contact_form_row_1{
	margin:0 2% 0 0;
}

form.formtools label{
	padding:10px 10px;
}

form.formtools label.infield{
	left:0;
	font-size:14px;
}

form.formtools .input-wrap-email, form.formtools .input-wrap-number, form.formtools .input-wrap-password, form.formtools .input-wrap-select, form.formtools .input-wrap-text, form.formtools .input-wrap-textarea, form.fortmools .input-wrap-tel {
    display: inline-block;
    float: left;
    width: 100%;
}

form.formtools input[type="text"],
form.formtools input[type="password"],
form.formtools input[type="email"],
form.formtools input[type="tel"],
form.formtools textarea {
	width:100%;
	box-sizing:border-box;
	height: 40px;
	background:#fcfcfc;
	border:1px solid #eee;
	box-shadow:none;
	color:#333;
	padding:10px;
	box-shadow: none;
	border-radius:none;
	-webkit-appearance: none
}

form.formtools textarea{
	height:80px;
	box-shadow: none;
	border-radius:none;
	-webkit-appearance: none
}

#contact_form_row_4{
	padding:0;
}

form.formtools .input-wrap-textarea .chars_remain{
	font-size:0.6em;
}

#contact_form-captcha_wrap{
	width:280px;
	float:right;
}

#contact_form-captcha{
	width:90px;
	right:25px;
	top:5px;
}

form.formtools .captcha_block .captcha-refresh {
    top: 15px;
    right: 0;
}

#contact_form-field-submit-label_label{
	display:none;
}

#contact_form-contact_form_submit-input-wrap-submit{
	float:right;
	width:auto;
}

#contact_form-contact_form_submit-input-wrap-submit{
	width:100%;
}

#contact_form-field-submit{
	background: #f00;
	border: 1px solid #f00;
	padding: 10px 0px 9px;
	font-size:14px;
	width: 115px;
	color:#fff;
	border-radius:0;
	-webkit-appearance: none;
	float:right;
	font-family: 'open_sansbold', Arial, Helvetica, sans-serif; font-weight: normal;
}

#contact_form-field-submit:hover{
	background:#d42026;
    text-shadow: none;
	color:#eee;
	border:1px solid #d42026;
}

#contact_form_row_7{
	display:none;
}

#contact_form .clear{
	height:1px;
	margin:0;
}

.contact-map iframe{
	width:100%;
	height:400px;
}

#contact_form .infield.label_captcha {
	top: 5px; right: 55px; left: auto;
}


/* Template Parts */

.breadcrumbs > ul {
    margin: 0 0 1em 0; padding: 0;
    list-style: none outside;
}

.breadcrumbs > ul li {
    display: inline-block; *display: inline; *zoom: 1;
    margin: 0; padding: 0;
    font-size: 0.8em; color: #ccc;
}

.breadcrumbs > ul .before {
    margin-right: 0.4em; *margin-left: 0.4em;
}

.breadcrumbs > ul .current {
    color: #666;
}

/* Tweet Vertical */

.twitterfeed ul.tweet_list li {
    font-size: 0.75em;
}

.twitterfeed ul.tweet_list li .tweet_text {
    display: block;
    margin-bottom: 0.25em;
}

.twitterfeed ul.tweet_list li > a {
    display: block;
    margin-bottom: 0.75em;
    font-size: 0.75em;
}

/* User Profiles */

#user_edit li {
    clear: both;
    margin: 0 0 5px 0;
    list-style: none;
}

#user_edit legend {
    font-weight: bold;
}

#user_edit input[type="text"],
#user_edit input[type="password"],
#user_edit textarea {
  width: 400px;
}

#user_edit select {
    width: 410px !important;
}

#user_edit select[name=dob_month] {
    width: 100px !important;
}

#user_edit select[name=dob_day] {
    width: 50px !important;
}

#user_edit select[name=dob_year] {
    width: 50px !important;
}

#user_edit select[name=gender] {
    width: 100px !important;
}

/* Common Content Styles */

.img_caption {
    font-style: italic;
    text-align: center;
}

.boxout {
    display: inline-block; *display: inline; *zoom: 1;
}

.boxout.right {
    float: right;
    margin: 0 0 0.5em 1em;
}

.boxout.left {
    float: left;
    margin: 0 1em 0.5em;
}


/* RESPONSIVE */

/* ----- RESPONSIVE ------------------------------------------------------------------- */


@media only screen and (min-width: 980px) {
    nav.primary ul.slimmenu {
        display: table;
    }

    nav.primary ul.slimmenu > li {
        display: table-cell;
    }
}

@media only screen and (max-width: 979px) {

	.home-header {
		position: relative;
		top: auto;
		bottom: auto;
	}

	header.page > .inner{
		height:auto;
	}

	header.page > .inner .home-link {
		margin: 10px 0 0 20px;
	}

	header.page > .inner .home-link img {
		width:150px;
		position: relative;
		z-index: 9999;
	}

	header.page > .inner .header-text{
		width:380px;
		height:auto;
		margin:0 50px 0 0;
	}

    .page-width {
        width: auto;
    }

    .inner {
        margin: 0;
    }

	nav.primary{
		width: 100%;
		position: absolute;
		top: 35px;
		left:0; right: 0;
		background: transparent;
		border: none;
	}

	.menu-collapser{
		background:transparent;
	}

	.collapse-button{
		right: 15px;
	}

    nav.primary ul.slimmenu {
        display: block;
        width: auto;
        margin:30px 0 0 0;
        background: #ff0000;
        z-index: 9999;
		position: relative;
    }

    nav.primary ul.slimmenu > li {
        display: block;
    }

	nav.primary ul.slimmenu li,
	nav.primary ul.slimmenu li:first-child {
		background: none;
	}


	nav.primary ul.slimmenu li a,
	nav.primary ul.slimmenu li:first-child a {
		padding: 10px 60px 10px 20px;
		font-size:14px;
    }

	nav.primary ul.slimmenu li ul {
		margin-left: 0;
	}

    nav.primary ul.slimmenu li ul,
    nav.primary ul.slimmenu li ul li a {
        width: auto;
    }

	nav.primary ul.slimmenu li ul li a{
		padding: 10px 60px 10px 20px !important;
		font-size: 12px !important;
	}

    nav.primary ul.slimmenu li a i {
        display: none;
    }

    nav.primary ul.slimmenu .sub-collapser {
		display: block;
		height:43px;
		background:none;
	}

    ul.slimmenu li .sub-collapser > i {
	    color: #2E3091;
    	font-style: normal;
    }

	#content main {
		width: auto;
		padding: 40px 0;
		margin: 0 20px;
	}

    main {
    	display: block;
        float: none;
        width: 100%;
        min-height: auto;
    }

    .project-left{
    	float:none;
    	width:auto;
    }

    .project-gallery{
    	float:none;
    	margin:20px auto 0;
    }



	.contact-left{
		float:none;
		margin:0 0;
	}

	.contact-right{
		float:none;
		margin:30px 0 0;
	}



    footer ul{
    	font-size:12px;
    	margin:10px auto;
    	display:block;
    	width:680px;
    }

    footer #bottom > .inner ul{
    	margin:10px auto;
    	width:740px;
    }

}

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

	header.page > .inner .home-link img {
	    width: 100px;
	}

	header.page > .inner .header-text {
	    width: 290px;
	}

	nav.primary {
	    top: 20px;
	}

	nav.primary ul.slimmenu {
	    margin: 20px 0 0 0;
	}


	#sub-banner-wrapper #sub-banner{
		height:140px;
	}

	#sub-banner-wrapper #sub-banner h1{
		font-size:40px;
		line-height: 30px;
		left:20px;
	}

	.contact-left{
		width:auto;
	}

	.contact-right{
		width:100%;
	}

	#contact_form_row_1, #contact_form_row_2{
		margin:0;
		width:100%;
		float:none;
	}

    .home .backstretch{
    	display:none;
    }

    .home #content{
		display:block;
		background:none;
		min-height:500px;
		background:url(../img/banner/banner1-lrg.jpg) no-repeat center;
		background-size:cover;
	}

    .home footer{
    	position:relative;
    }


	footer #top > .inner,
	footer #bottom > .inner{
		margin:0 20px;
	}

    footer ul{
    	font-size:12px;
    	margin:10px auto;
    	display:block;
    	width:auto;
    	padding:0;
    }

    footer #bottom > .inner ul{
    	margin:10px auto;
    	width:auto;
    }

    footer #top > .inner ul li {
		float: none;
		text-align:center;
		list-style-type: none;
		margin: 0;
		padding: 0;
		line-height:20px;
	}

	footer #top > .inner ul li span.seperator{
		display:none;
	}

	footer #bottom > .inner ul li{
		float:none;
		text-align:center;
		line-height:20px;
	}

	footer #bottom > .inner ul li span.seperator{
		display:none;
	}

}


@media only screen and (max-width: 550px) {

	header.page > .inner .home-link {
		margin: 10px 0 13px 20px;
	}

	header.page > .inner .header-text {
		display:none;
	}

	nav.primary ul.slimmenu {
	    margin: 17px 0 0 0;
	}

	.project-gallery{
		width:auto;
		height:auto;
	}

	.project-gallery .cycle-pager{
		position:relative;
		height:auto !important;
		width:auto;
	}

	.project-gallery .cycle-pager .thumb {
		margin: 10px 1%;
		width: 18%;
		height: auto;
	}

	.home #content{
		min-height:380px;
	}

}


@media only screen and (max-width: 320px) {

	.home #content{
		min-height:270px;
	}

}