@charset "UTF-8";
/* CSS Document */
html {
	

	}
	
body {
	
	background-color:#29ABE2;
	padding-left:40px;
	padding-top:40px;
	margin:0px;
	font-family:Gotham, "Helvetica Neue", Helvetica, Arial, sans-serif;
	
	}
ul, li,ol,label, dl { /* Due to variations between browsers, it's best practices to zero padding and margin on lists. For consistency, you can either specify the amounts you want here, or on the list items (LI, DT, DD) they contain. Remember that what you do here will cascade to the .nav list unless you write a more specific selector. */
	padding: 0px;
	margin: 0px;
}
h1 {
margin-top: 20px;		
		padding-right: 20px;
	padding-left: 20px; /* adding the padding to the sides of the elements within the blocks, instead of the block elements themselves, gets rid of any box model math. A nested block with side padding can also be used as an alternate method. */
}
h2, h3, h4, h5, h6, p {
	margin-top: 0;	 /* removing the top margin gets around an issue where margins can escape from their containing block. The remaining bottom margin will hold it away from any elements that follow. */
	padding-right: 15px;
	padding-left: 15px; /* adding the padding to the sides of the elements within the blocks, instead of the block elements themselves, gets rid of any box model math. A nested block with side padding can also be used as an alternate method. */
}
a img { /* this selector removes the default blue border displayed in some browsers around an image when it is surrounded by a link */
	border: none;
}
/* ~~ Styling for your site's links must remain in this order - including the group of selectors that create the hover effect. ~~ */
a:link {
	color: #29ABE2;
	text-decoration: none; /* unless you style your links to look extremely unique, it's best to provide underlines for quick visual identification */
}
a:visited {
	color: #29ABE2;
	text-decoration: none; /* unless you style your links to look extremely unique, it's best to provide underlines for quick visual identification */
}
a:hover, a:active, a:focus { /* this group of selectors will give a keyboard navigator the same hover experience as the person using a mouse. */
	text-decoration: none;
		color: red;

}	
.container {
	
	width:960px;
	margin: 0 auto; /* the auto value on the sides, coupled with the width, centers the layout */
		padding-left:25px;	
	padding-right:65px;	

}


.whiteBG {
		
	background-color:#fff;
	border-top-left-radius:150px;
	
	margin-right:0px;
	margin-bottom:0px;
	width:100%;
	height:100%;
	 z-index:0;
	 
}
.cbcIcon {
	position:absolute;
	 z-index:5;
	margin-top:-30px;
	margin-left:-30px;
	background-image:url(images/punch-logo3.png);
        background-repeat: no-repeat;
width:165px;
height:201px; 
	   	background-size: 165px 201px;

}

.icon {
	border-radius:12px;
	-webkit-box-shadow: 0px 0px 2px 1px rgba(0,0,0,0.5);
-moz-box-shadow: 0px 0px 2px 1px rgba(0,0,0,0.5);
box-shadow: 0px 0px 2px 1px rgba(0,0,0,0.5);
	overflow:hidden;
	        background-repeat: no-repeat;
				   	background-size: 80px 80px;

width:80px;
height:80px; 
	display: block;
	margin: 10px auto; /* the auto value on the sides, coupled with the width, centers the layout */
	margin-top: 20px; /* the auto value on the sides, coupled with the width, centers the layout */

	}


.cbcLogo {
	width: 540px; /* Width of new image */
	height: 40px; /* Height of new image */
	z-index: 10;
	margin-top: -20px;
	}
header {
	height:150px;
	width:100%;
		text-align:center;
	display: block;

	}
article {
	padding: 0;
	margin: 0;
display: block;

	}

footer {
	padding-top:20px;	
	text-align:right;
	clear: both; 
	display: block;
	text-align:center;
	line-height:25px;
	font-size:12px;

	}
footer div {
		background-color: #EAEAEA;
		border-radius:20px;
	width:100%;
	overflow:hidden;
	}
.content {
		padding: 0;
	margin: 0;
		border-radius:10px;
		background-color:#F7F7F7;
	
	overflow:hidden;

	width: 750px;
	float: left;
}
.mainText{
	width:100%;
margin-top:20px;
	display: block;
	float:left;
		font-size:14px;

}
.specialBox {
	width: 28%;
		margin:24px;
	margin-left: 3%;
	margin-right:0;
	color: #0D4963;
	background-color: #ADDFF3;
	border-radius: 10px;
	display: block;
	float: left;
	font-size: 14px;
	padding: 5px;
	overflow:visible;

	}


#firstBox {
	margin-left: 2%;

}
#clients{
		width: 92%;

	}
#contact{
		width: 92%;
	background-color: white;

	}	
form    {
margin:auto;
width:650px;
font-size: 14px;
line-height: 24px;
font-weight: bold;
text-decoration: none;
padding:10px;

}
input    {
		width:302px;

	display: block;
	border: 1px solid #999;
	height: 25px;
	background-color: #E5F4FB;
}
textarea {
height:150px;
width:625px;
	background-color: #E5F4FB;

}
textarea.message {
display:block;
}
.button {
width:100px;
right:20px;
bottom:20px;
background:#29ABE2;
color:#fff;
height:30px;
-webkit-border-radius: 25px;
-moz-border-radius: 25px;
border-radius: 25px;
border: 1px solid #29ABE2;
margin:0 auto;
}
.button:hover {
background:#fff;
color:#09C;
}
textarea:focus, input:focus {
border: 1px solid #09C;
-webkit-box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.3);
-moz-box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.3);
box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.3);
background-color:#fff;

}
.specialBox div{
		margin: 10px;

}

.specialHead {
	margin:0px auto;
	padding:0;
	font-size:30px;
	text-align:center;
	color:#29ABE2;
}
#main{
	/* The main container */
	text-align:center;
	width:380px;
	position:relative;
		display:block;
		float:left;
margin:20px;
}

ul {
		padding: 0 15px 15px 20px;

	}

.formBox1{
	width:303px;
	margin: 10px;
	display:block;
	float:left;
	}
.commentBox{
	display:block;
	float:left;
	margin-left: -10px;
	}
.formBox2{
	width:600px;
	float:left;

}
sidebar {
	float: left;
	width: 156px;
	background-color:#EAEAEA;
	padding: 10px;
	border-radius: 10px;
	text-align: center;
	margin-left: 33px;
	margin-bottom: 20px;
	font-size:12px;

	color:#454545;

}
sidebar div {
	margin-bottom: 10px;
	margin-top: 10px;

}
sidebar a:link {
	color: black;
	text-decoration: none; /* unless you style your links to look extremely unique, it's best to provide underlines for quick visual identification */
}
sidebar a:visited {
	color: gray;
	text-decoration: none; /* unless you style your links to look extremely unique, it's best to provide underlines for quick visual identification */
}
sidebar a:hover {
	color: red;
	text-decoration: none; /* unless you style your links to look extremely unique, it's best to provide underlines for quick visual identification */
}
.sidelabel {

	margin-bottom: 20px;

}
.graytext a{
	color:#0D4963;
	text-decoration:underline;
font-weight:bold;
}
.graytext a:hover, .graytext a:visited:hover{
	color:red;

}
.graytext a:visited{
	color:gray;
	text-decoration:underline;
font-weight:bold;
}
.mainicon{
	width:140px;
	height:134px;
	border:none;
	}


.fltrt {  /* this class can be used to float an element right in your page. The floated element must precede the element it should be next to on the page. */
	float: right;
	margin-left: 8px;
}
.fltlft { /* this class can be used to float an element left in your page. The floated element must precede the element it should be next to on the page. */
	float: left;
	margin-right: 8px;
}
.clearfloat { /* this class can be placed on a <br /> or empty block element as the final element following the last floated block (within the .container) if the footer is removed or taken out of the .container */
	clear:both;
	height:0;
	font-size: 1px;
	line-height: 0px;
}


@media screen and (max-width: 768px) {
	#wideBox {
width:688px;
	}
body {
	
	padding-left:5px;
	padding-top:40px;
	margin:0px;
	
	}

.whiteBG {
		
	background-color:#fff;
	border-top-left-radius:150px;
	
	margin-right:0px;
	margin-bottom:0px;
	width:763px;
	height:100%;
	 z-index:0;
	 
}
.container {
	
	width:748px;
	margin: 5px; /* the auto value on the sides, coupled with the width, centers the layout */
	margin-right: 0px; /* the auto value on the sides, coupled with the width, centers the layout */
		padding-left:0px;	
	padding-right:0px;	

}

.content {
 border:0px solid #29ABE2;

outline-offset:0px;

	width:100%;
	float: left;
}
.cbcIcon {
	margin-top:-5px;
	margin-left:0px;
width:123px;
height:150px; 
	   	background-size: 123px 150px;

}


sidebar {
	float: left;
	width:100%;
	padding: 0px;
	padding-bottom: 20px;
	margin:0px;
margin-top: 20px;
}

sidebar div {
	float: left;
	text-align: left;
	padding:0px;
	margin:20px;
	margin-bottom:0px;
}

.icon {
width:80px;
height:80px; 
padding:0px;

	   	background-size: 80px 80px;
	display: block;
	margin: 20px; /* the auto value on the sides, coupled with the width, centers the layout */
	margin-bottom: 0px; /* the auto value on the sides, coupled with the width, centers the layout */

	}


.usalabel {
	padding-top:10px;

	width: 500px;
		height: 60px;
}
.sidelabel {
	width: 100px;
		height: 40px;
margin:0px;
margin-top:20px;
margin-right:25px;
padding-top:30px;
padding-left:0px;
padding-right:0px;
padding-bottom:0px;
}


.fix {
clear:both;
	height:0px;
	font-size: 1px;
	line-height: 0px;
margin:0px;

	}
.clearfloat { /* this class can be placed on a <br /> or empty block element as the final element following the last floated block (within the .container) if the footer is removed or taken out of the .container */
	clear: none;
		height:0;
	font-size: 1px;
	line-height: 0px;
padding:0px;
margin:0px;

}
.clearfloat:nth-child(2) { /* this class can be placed on a <br /> or empty block element as the final element following the last floated block (within the .container) if the footer is removed or taken out of the .container */
	clear: both;
		height:0;
	font-size: 1px;
	line-height: 0px;
padding:0px;
margin:0px;

}
.button {
	background:none;
	color:#29ABE2;
}
}

@media only screen and (-webkit-min-device-pixel-ratio: 1.5),
    only screen and (-o-min-device-pixel-ratio: 3/2),
    only screen and (min--moz-device-pixel-ratio: 1.5),
    only screen and (min-device-pixel-ratio: 1.5) {

.cbcIcon {
	background-image:url(images/punch-logo3@2x.png);

}
}
@media print {

.cbcIcon {
	margin-top:-25px;
	margin-left:-25px;
width:123px;
height:150px; 
	   	background-size: 123px 150px;

}
}