/* Default media */
body
{
	color: #555555;
	font-size: 14px;
	line-height: 20px;
	font-family: 'Raleway', Helvetica, Arial, sans-serif;
	font-weight: 400;
	font-style: normal;
	text-align: left;
	margin: 0;
	padding: 0;
	background-color: #FFFFFF;
}

a, a:link, a:visited, a:active
{
	color: #666666;
	text-decoration: none;
}  

a:hover
{
	color: #000000;
	text-decoration: none;
}

img { border: none; }

h1
{
	color: #333333;
	font-size: 3.5em;
	line-height: 1em;
	font-weight: 400;
	text-align: center;
}

#hmrails h1 { color: #FFFFFF; }

h2
{
	color: #333333;
	font-size: 2.2em;
	line-height: 1em;
	font-weight: 400;
	margin-top: 0;
}

b, strong { font-weight: 700; }



/* Layout */

#topsocialbar
{
	width: 100%;
	height: 47px;
	margin: 0 auto;
	padding: 0;
	background-color: #FAFAFA;
	border-bottom: 1px #DEDDDD solid;
}

#topsocial
{
	float: right;
	margin: 10px 5%;
	padding: 0;
	font-size: 13px;
	color: #666666;
	font-weight: 700;
}

#topsocial a, #topsocial a:link, #topsocial a:visited, #topsocial a:active { color: #666666; text-decoration: none; }

#topsocial a:hover { color: #000000; text-decoration: none; }

#topbar
{
	width: 90%;
	margin: 0 5%;
	padding: 0;
}

#logo
{
	float: left;
	margin: 0;
	padding: 0;
}

#logo img
{
	width: 133px;
	height: 100px;
	margin: 0;
	padding: 20px 0;
}

#mastheadcanvas
{
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
}

#masthead
{
	margin: 0;
	padding: 0;
	background-color: #000;
}

.hmslide
{
	 background-repeat: no-repeat; background-size: 100% auto;
}

.hmslidetx
{
	height: 80%;
	font-size: 2.8em;
	line-height: 1.2em;
	color: #333;
	margin-left: 10%;
	padding: 8% 0 12% 0;
	float: left;
}

.hmslidebtn
{
	width: 220px;
	height: auto;
	margin-top: 18px;
}

#hmrails
{
	width: 90%;
	margin: 0;
	padding: 25px 5% 40px 5%;
	color: #FFFFFF;
	background-color: #000000;
	background-image: url(../images/bg-rail.jpg);
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: cover;
}

#hmbollards
{
	width: 90%;
	margin: 0;
	padding: 25px 5% 40px 5%;
	color: #555555;
	background-color: #f4f4f4;
	background-image: url(../images/bg-bollard.jpg);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}

#hmrailscontent, #hmbollardscontent
{
	width: 100%;
	margin: 0;
	padding: 0;
	display: inline-block;
}

#hmbollardscontent3col
{
	width: 76%;
	margin: 0;
	padding: 0 12%;
	display: inline-block;
}

.featurebox, .featurebox2
{
	float: left;
	width: 25%;
	margin: 0;
	padding: 0;
	font-size: 13px;
	line-height: 17px;
	text-align: center;
	clear: right;
}

.featurebox2
{
	width: 33.33%;
}

.featurebox .px, .featurebox2 .px
{
	width: 100%;
	margin: 0 auto;
	padding: 0;
}

.featurebox .px img, .featurebox2 .px img
{
	width: 90%;
	max-width: 182px;
	height: auto;
	margin: 0;
	padding: 0 5%;
}

.featurebox .tx, .featurebox2 .tx
{
	width: 90%;
	max-width: 170px;
	margin: 0 auto;
	padding: 10px 5% 20px 5%;
	text-align: center;
}

#aboutuspx
{
	float: left;
	width: 20%;
	margin: 0;
	padding: 5% 0 5% 10%;
}

#aboutuspx img
{
	width: 100%;
	height: auto;
}

#aboutustx
{
	float: left;
	width: 60%;
	margin: 0;
	padding: 5%;
}

#contactusbox
{
	width: 90%;
	margin: 0;
	padding: 50px 5% 0 5%;
	color: #555555;
	background-color: #F4F4F4;
	font-size: 16px;
	line-height: 21px;
	text-align: center;
}

#contactus3col
{
	width: 90%;
	margin: 0;
	padding: 0 5% 50px 5%;
}

.contactcol
{
	float: left;
	width: 33.33%;
	margin: 0;
	padding: 0;
	font-size: 16px;
	line-height: 21px;
	text-align: center;
}

.contacticon
{
	width: 77px; height: 77px; margin-bottom: 15px;
}

#bot
{
	font-size: 12px;
	line-height: 18px;
	width: 100%;
	margin: 0 auto;
	padding: 0;
	background-color: #000000;
	clear: both;
}

#footer
{
	width: 90%;
	margin: 0 auto;
	padding: 2% 0;
	color: #CCC;
	text-align: center;
}

/* Navigation */

.navhide { display: none; }

#navtop { display: none; }

#navigation
{
	float: right;
	margin: 0;
	padding: 0;
	font-size: 14px;
	color: #333333;
	line-height: 140px;
}

/* Top Navigation */

#mainav { text-align: center; text-transform: uppercase; }
#mainav ul { margin: 0; }
#mainav ul ul { z-index: 9999; position: absolute; margin: 0; padding: 0; width: 200px; line-height: 17px; left: 0; }

#mainav li { display: inline-block; position: relative; margin: 0 26px 0 0; padding: 0; }
#mainav li:last-child { margin: 0 0 0 0; }
#mainav li li { width: 100%; margin: 0; text-align: left; text-transform: none; }
#mainav li a { display: block; }
#mainav .drop { padding: 1px 8px 2px 8px; }
#mainav li li a, #mainav li li .drop { display: block; margin: 0; padding: 7px 10px; }
#mainav ul ul { display: none; }
#mainav ul li:hover > ul { display: block; }

/* Navigation */
#mainav li a { color: #333333; text-decoration: none; }
#mainav a:hover, #mainav li:hover > a { color: #999; text-decoration: none; }
#mainav .active a { color: #333333; text-decoration: none; }
#mainav li li a, #mainav .active li a { color: #333333; background-color: rgba(255, 255, 255, .9); border-bottom: 1px solid rgba(255, 255, 255, .9); }
#mainav li li:hover > a, #mainav .active .active > a { color: #000000; background-color: rgba(255, 255, 255); border-bottom: 1px solid rgba(255, 255, 255); }


/* Nav Others */

#btntop
{
	margin: 0 auto;
	padding: 0;
	float: right;
}

#btntopm
{
	display: none;
}

.btntop
{ width: 50px; height: 28px; display: block; }

a.btntop, a.btntop:link, a.btntop:visited, a.btntop:active
{
	background-image: url(../images/btn-top.png); background-repeat: no-repeat; background-position: left bottom; background-size: contain;
}

a.btntop:hover
{
	background-image: url(../images/btn-top-mo.png);
	background-repeat: no-repeat;
	background-position: left bottom;
	background-size: contain;
	background-color: transparent;
}





@-ms-viewport { width: device-width; }


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

body
{
	min-width: 100%;
}

#navtop
{
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	margin: 0;
	padding: 0;
	z-index: 10;
}

#navtop img
{
	width: 20px;
	height: 15px;
	padding: 14px 10px 18px 10px;
}

#navtop a, #navtop a:link, #navtop a:visited, #navtop a:active {
	font-size: 12px;
	line-height: 26px;
}

#navigation, #navigationsub
{
	display: none;
	width: 100%;
	background-color: rgba(0,0,0,.9);
	color: #FFFFFF;
	line-height: 26px;
	margin: 0 auto 10px auto;
	padding: 0;
	position: relative;
	top: 0;
	left: 0;
	z-index: 10;
	-moz-border-radius: 0 0 8px 8px; border-radius: 0 0 8px 8px;
}

/* Top Navigation */
#mainav { text-align: left; text-transform: uppercase; }
#mainav ul { margin: 2% 5% 0 5%; padding: 0;}
#mainav ul ul { display: none; }
#mainav li { display: block; position: relative; margin: 0; padding: 0; }
#mainav li:last-child { margin-bottom: 2%; }
#mainav li a{ display: block; padding: 7px 0; border: solid; border-width: 0 0 1px 0; }
#mainav li:last-child a{ border-width:0; }
#mainav .drop { padding: 7px 0; }
#mainav ul li:hover > ul { display:none; }

/* Navigation */
#mainav li a { color: #ffffff; background-color: none; text-decoration: none; -moz-border-radius: 0; border-radius: 0; border-color: rgba(51,51,51); }
#mainav .active a, #mainav a:hover, #mainav li:hover > a { color: #999; text-decoration: none;  background-color: transparent; text-decoration: none; -moz-border-radius: 0; border-radius: 0; }

h1 { font-size: 2.2em; line-height: 1em; }

h2 { font-size: 1.5em; line-height: 1em; }

#topsocial
{
	font-size: 12px;
	color: #666666;
	font-weight: 700;
}

#logo img
{
	width: 30%;
	height: auto;
}

.featurebox, .featurebox2
{
	float: none;
	width: 100%;
	margin-bottom: 5%;
}

.featurebox2
{
	width: 100%;
}

#aboutuspx
{
	float: none;
	width: 90%;
	margin: 0 auto;
	padding: 5% 0;
}

#aboutustx
{
	float: none;
	width: 90%;
	margin: 0 auto;
	padding: 5% 0;
}

.contactcol
{
	float: none;
	width: 90%;
	margin: 0 auto 40px auto;
}

#footer
{
	padding: 5% 0 10% 0;
}

#btntop { display: none; }

#btntopm
{
	display: block;
	position: fixed;
	right: 5%;
	bottom: 0px;
}

}


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

.hmslidetx
{
	font-size: 1.1em;
	padding: 6% 0 14% 0;
}

.hmslidebtn
{
	width: 120px;
	height: auto;
	margin-top: 5px;
}


}


@media screen and (min-width: 415px) and (max-width: 600px) {

.hmslidetx
{
	font-size: 1.5em;
}

.hmslidebtn
{
	width: 160px;
	height: auto;
	margin-top: 10px;
}


}


@media screen and (min-width: 601px) and (max-width: 900px) {

h1 { font-size: 3em; line-height: 1em; }

h2 { font-size: 2em; line-height: 1em; }

.hmslidetx
{
	font-size: 2em;
}

.hmslidebtn
{
	width: 160px;
	height: auto;
	margin-top: 12px;
}

.contactcol
{
	font-size: 13px;
	line-height: 18px;
}


}
