@charset "utf-8";
/* ICC Services CSS Document */

body {
	background-color: #1b1464;
	background-repeat: repeat;
	margin: 0px;
	padding: 0px;
    font-family: 'Open Sans', Arial, Helvetica, sans-serif;
}

html{
	height:100%;				/* Force vertical scrollbars in VTz + Opera to prevent 'jumping' */
	margin-bottom:1px;
	overflow-y:scroll;			/* this line is for IE */
}

.Logo {top: 5px; margin-bottom: 5px; margin-left: 15px; position: absolute; z-index: 500; }

#NavContainer { text-align: right; }
.main-menu {
    position: relative;
}
.main-menu {width: 1000px;  margin-right: auto; margin-left: auto; margin-bottom: 5px;}  
.main-menu ul { padding: 0; margin: 0;}
.main-menu li {
    display: inline;
    background-color: #f8c411;
    margin: 0 5px 0px 0;
    padding: 10px 10px 11px 10px;
    border-top-left-radius: 6px;
    border-top-right-radius: 6px;
}
.main-menu li a {
    font-size: 18px;
    color: white;
    margin: 10px 5px 5px 5px;
    text-shadow: 1px 1px #1b1464;
}
.main-menu li.selected  {color: red!important; }
.main-menu li a:link {color: white;}
.main-menu li a:hover {color: 9a9a99;}

#NavBar {
    height: 30px;
    padding-top: 14px;
    background-color: #f8c411;
    border-bottom-style: solid;
    border-bottom-color: #736f7b;
    border-bottom-width: 6px;
    box-shadow: 0px 1px 7px 1px #333;
    text-align: center;
    color: #736f7b;
    font-size: 14px;
    padding-left: 300px;
    letter-spacing: 2px;
}



p {   margin: 0px;   padding: 0px;}

a:link, a:visited, a:active {color: #7a7a7a;	font-weight: bold;	text-decoration: none;}
a:hover {color: #1b1464;	font-weight: bold;	text-decoration: none;}

h1{	
	text-align: center;
	color: #1b1464;	
	font-size: 22px;
	font-weight: bold;
	margin-bottom:20px;
}

h2{	
	text-align: center;
	color: #1b1464;	
	font-size: 20px;
	font-weight: bold;
	margin-bottom:12px;
	}
h3{	
	color: #1b1464;		
	font-size: 18px;
	font-weight: bold;
	display: inline;
}
h4{	
	color: #f8c411;		
	font-size: 18px;
	font-weight: bold;
	display: inline;
}

#Banner{	            /* FULL WIDTH ONLY */
    width: 1000px;
    height: 90px;
    margin: auto;
}

.BkWhite {
	background-color: #fff;
}

.BulletsHoriz {
    clear: both; 
    text-align: center;
    color: #736f7b;
    font-size: 22px;
    letter-spacing: 2px;
    line-height: 22px;
}


.Centered {margin: auto; }
.ContentsCentered {text-align: center;}
.ContentsLeft {text-align: left;}
.ContentsRight {text-align: right;}

.ColorYellow {color: #f8c411;}
.ColorBlue {color: #1b1464;}
.ColorGray {color: #736f7b;}

.Clear {clear: both;}


.CustomerType img {width: 90%; margin-left: auto; margin-right: auto; }
.CustomerType h2 {font-size: 20px; font-weight: bold; color: #f8c411;}
table.CustomerType {width: 30%; display: inline-block; text-align: center; vertical-align: top;}
td.CustomerType {align-content: center;}


#Footer {
	color: #fff;
	font-size: 14px;
	line-height:18px;
	vertical-align:middle;
	font-weight:normal;
    text-align: center;
    padding: 20px;
}
#Footer a {
	color:#fff;
    font-weight:normal;
    }
#Footer a:hover {
	color:#f8c411;
}

.FloatR {float: right;}
.FloatL {float: left;}

.FrameGray {
	background-color: #7a7a7a;
	padding: 6px;
	-webkit-box-shadow: 0 0 8px rgba(132, 132, 132, .75);
	-moz-box-shadow: 0 0 8px rgba(132, 132, 132, .75);
	box-shadow: 0 0 8px rgba(132, 132, 132, .75);
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}

.GalleryPhoto {width: 46%; margin: 1%;}

.MarginR {margin-right: 20px;}
.MarginL {margin-left: 20px;}
.MarginL20 {margin-left: 20px;}
.MarginR20 {margin-right: 20px;}
.MarginB20 {margin-bottom: 20px;}

.PhoneHeader, .PhoneHeader2 {width: 100%; text-align: right; padding-top: 10px; font-size: 22px;}
a.PHONE { color:#fff; font-weight: bold; margin-right: 12px;}
a.PHONE:hover {color:#f8c411; font-weight: bold; }
.Phone-CC {display: inline; color: #1b1464/*alttext*/; font-size: 12px; padding-top: 6px; }
.PhoneHeader2 {display:none;}

.PortfolioBox {	display: inline-block;    	width: 210px;
	text-align: center; vertical-align: top;
    margin: 0 9px 20px 9px;
	font-size: 14px; line-height: 16px;
}
.PortfolioBox h3 {font-size: 16px; line-height: 26px; }
.PortfolioBox h3 a {color: #1b1464;}
.PortfolioBox h3 a:hover {color: #f8c411;}

.ServiceBox {display: inline-block;   width: 100px;
	text-align: center; vertical-align: top;
    margin: 0, 0, 20px, 0;
	font-size: 14px;
    text-align: center;
}
.ServiceBox h3 {font-size: 14px; line-height: 24px; font-weight: normal; }
.ServiceBox h3:hover {color: #9a9a99;!important;}
a.service-link {}

.SlideshowContainer {text-align: center; max-width: 100%; margin-left: auto;
margin-right: auto; margin-bottom: 30px;}
.SlideshowHome, .SlideshowMobile {align-content:center; margin-top: 0px;}
/* .SlideshowPreviewImg {width: 988px; height: 237px; } */
/* that is not needed because img is set to max-width 100% anyway */

.TextBody { padding: 30px 20px 0 20px;
    color: #000000;
	font-size: 16px;
	line-height: 22px;
	text-align: left;
	}


.VertBottom {vertical-align: bottom;}
.VertMid {vertical-align: middle;}
.VertTop {vertical-align: top;}


.table1000 {width: 1000px; margin: auto; }
.table1000 td {min-height: 500px;}



/* HAMBURGER MENU STUFF *****************************/    
.menu-toggle {  display: inline-block; line-height: .8em; font-size: 2.5em; margin-top: -9px; }
.menu-toggle:hover, .menu-toggle:focus { color: #1b1464;}
.sr-only {/* Screen reader only */ position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0;}


/* MEDIA QUERIES *****************************/ 
/* Large devices */ 
@media (min-width: 1020px) { 
	.MobileHide, .MobileSmallHide {display: inline-block;}
	li.MobileShow, .MobileShow, .MobileSmallShow {display: none; background-color: red;} 
	.menu-toggle, .main-menu .menu-close {display: none; } /* hamburger menu */
}
/* Tablets to Desktops */ 
@media all and (max-width: 1019px) {
    .table1000 {width: 99%; margin: auto; min-height: 200px; }
    #Banner {width: 100%; padding-left: 10px; padding-right: 10px;}
    .PhoneHeader {width: auto;}
    .Phone-CC {display: block; margin-right: 30px; }
    .TextBody { padding: 80px 20px 0 20px;}
	.SlideshowContainer {text-align: center; width: 100%;}
	#NavBar {padding-left: 0px; padding-right: 20px; text-align: right;}
    #NavContainer {margin-top: 10px;} /*because tabs disappear*/
	.Footer {padding-left: 10px; padding-right: 10px;}
	li.MobileShow, .MobileShow {display: inline-block;}
	.MobileHide, MobileSmallHide, MobileSmallShow {display: none;}
    .NavServices {display: none;}
	.FrameGray {margin-left: 10px; margin-right: 10px;}
    .GalleryPhoto {width: 40%; margin: 1%;}

    nav {width: 90%; }
    /* Mobile Offscreen menu style */
    .main-menu {
      position: absolute; 
      left: -150px;
      width: 150px; /* should match .main-menu ul */
      top: 0;
      /* height: 100%; */
      /*  overflow-y: scroll;
      overflow-x: visible;*/
      transition: left 0.3s ease,
                  box-shadow 0.3s ease;
      z-index: 999;
    }
    .main-menu ul {
      list-style: none;
      margin: 0;
      padding: 2em 0 0;
      /* Hide shadow w/ -8px while 'closed' */
      -webkit-box-shadow: -8px 0 8px rgba(0,0,0,.5);
         -moz-box-shadow: -8px 0 8px rgba(0,0,0,.5);
              box-shadow: -8px 0 8px rgba(0,0,0,.5);
      min-height: 100%;
      width: 150px;
      background: #736f7b;
    }
    .main-menu li {
        display: inline;
        background-color: unset;
        margin: 0!important;
        padding: 0!important;
        border-top-left-radius: unset;
        border-top-right-radius: unset;
    }    
    .main-menu li a {
      display: block;
      line-height: 1em;
      font-size: 1em;
      color: #fff;
      text-decoration: none;
        margin: 0;
        padding: 15px;
    }
    .main-menu a:hover, .main-menu a:focus { background: #f8c411;}
    .main-menu .menu-close { position: absolute; right: 0; top: 0; }
  /* On small devices, allow it to toggle... */
    /*  :target for non-JavaScript  aria-expanded="true/false" will be for JavaScript */
    .main-menu:target,
    .main-menu[aria-expanded="true"] {
      left: 0;
      outline: none;
      -moz-box-shadow: 3px 0 12px rgba(0,0,0,.25);
      -webkit-box-shadow: 3px 0 12px rgba(0,0,0,.25);
      box-shadow: 3px 0 12px rgba(0,0,0,.25);
    }
    .main-menu:target .menu-close,
    .main-menu[aria-expanded="true"] .menu-close {
      z-index: 1001;
    }
    .main-menu:target ul,
    .main-menu[aria-expanded="true"] ul {
      position: relative;
      z-index: 1000;
    }
    /* We could us `.main-menu:target:after`, but it wouldn't be clickable. */
    .main-menu:target + .backdrop,
    .main-menu[aria-expanded="true"] + .backdrop {
      position: absolute;
      display: block;  
      content: "";
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      z-index: 998;
      background: #000;
      background: rgba(0,0,0,.85);
      cursor: default;
    }

}

/* Tablets */ 
@media all and (max-width: 767px) {
	.MobileHide, MobileSmallHide, .MobileSmallShow { display: none;}
	.MobileShow { display: inline-block;}
	.Facebook2 {height: 18px; padding-left: 12px; padding-top: 4px;}
	.TextBody {font-size: 16px; line-height: 20px; padding: 100px 20px 0 20px;}
	h1{ font-size: 20px;}
	h2 {font-size: 16px; line-height: 20px;}
}
@media all and (max-width: 600px) {  /* when Phone/CC no longer fit next to logo */
    #Banner {margin: auto; text-align: center;}
	.Logo {position: relative; margin-left: -15px;}
    .PhoneHeader {display: none;}
    .PhoneHeader2 {display: block; text-align: center; padding-bottom: 15px;}
    a.PHONE {color: #1b1464; }
    a.PHONE:hover {color: #f8c411; }
}
    
/* Phones */ 
@media all and (max-width: 480px) { 
	.FrameGray {margin-left: 10px; margin-right: 10px;}
	.MobileSmallShow {display: block;}
	.MobileSmallHide {display: none;}
	.ServiceBox {	float: none; width: auto; margin-left: auto; margin-right: auto;} 
    .PortfolioBox {	float: none; width: auto; margin: 0 0 0 0;}
    .Logo {width: 70%;}
    .GalleryPhoto {width: 90%;}

}

@media all and (max-width: 375px) {  /* when logo no longer fits */
    #Banner {height: auto;}
	.Logo {width: 80%;}
    .TextBody { padding: 10px 10px 0 10px;}
     .NavServices {display: inline; font-size: 13px; letter-spacing: normal;
        position: relative;
        top: -15px; padding-left: 20px;
        line-height: 15px;}
}

/* very small devices  */ 
@media all and (max-width: 320px) {
    .TextBody {	font-size: 14px; line-height: 16px;}
   .NavServices {display: none;}
    .ImgMobile {display: block; margin-left: auto; margin-right: auto;}
}


    
    



    
    
