
/* general layout */

#topstrip { font-family: 'Lato', sans-serif; font-size:16px; color:#ffffff; padding:5px 0 0 0; }
#topstrip a { color:#ffffff; font-size:18px; }
#topstrip a.emailicon { background-position: 0px 2px; }
#topstrip .social a, #bottomstrip .social a { margin: 0 10px 0 0; padding:0 10px 0 0; border-right:1px solid #ffffff; line-height:17px; }
#topstrip .social a:first-child, #bottomstrip .social a:first-child { border-left:1px solid #ffffff; padding-left:10px; }
#logo { margin-top:15px; }

#topstrip #callus { font-size:22px; color:#ffc300; font-weight:bold; line-height:normal;  }
#bottomstrip #bottomstripcallus { font-size:22px; color:#ffc300; font-weight:bold; text-align: right; }
#bottomstrip .social { text-align: right; }

header { background-color: #ffc300; margin:4px 0; font-family: 'Lato', sans-serif; }
header>.container { position:relative;}
header #logo img { width:150px;}
.navbar-nav>li>a { padding:0 35px 0 0px !important; font-size:12px; }
.nav>li>a:focus {  text-decoration: none;  background-color:inherit  }

header .navbar-header .icon-bar { background-color: #000000; }

#searchcontainer { padding:5px 0;  z-index: 1; position:relative}

#banner1 { margin-bottom:0;  z-index: 1; position:relative}
#banner1 .slick-slide {  position:relative; background-size:cover;  padding:1px 0 0 0;    }
#banner1 .slick-next { right:20px; width:60px; height:60px; background-image: url(media/rightarrow.png); background-color: #4c4c4c }
#banner1 .slick-next:before { content: '';}
#banner1 .slick-prev { left:20px; z-index: 9999; width:60px; height:60px; background-image: url(media/leftarrow.png); background-color: #4c4c4c  }
#banner1 .slick-prev:before { content: '';}
#banner1 .slick-dots { z-index: 9999; bottom:20px;  }
#banner1 .slick-dots li button:before { font-size:0;}
#banner1 .slick-dots li button { width:20px; height:20px; background-color: #7f7f7f; border-radius:20px; }
#banner1 .slick-dots li.slick-active button  {  background-color: #ffc300; }
#banner1 .bannertext { margin-left: auto; margin-right: auto; }
#banner1 .bannertext p { text-align: center; font-size:30px; color:#ffffff;  }
#banner1 .bannertext p:first-of-type { font-size:40px; text-transform: uppercase; font-style:italic; font-weight:500; }
#banner1 .bannertext p a.btn { font-size:20px; text-transform: uppercase; margin-top:10px; }
/* specific overrides */



/* 6 boxes */
.boxes .row>div { margin-bottom: 20px; }
.boxes h2 { font-size:18px;     margin-top: 20px;  margin-bottom: 10px; line-height:normal; }

#whois .container { margin-top:60px; width:90%; }
#whois { background-image:url(media/yellowtruckbackground.jpg); background-size: cover;  position: relative; padding-bottom: 40px;  }
#whois .container {  }
#whois  .greyarrow { width:102px; height:30px; background-image: url(media/greyarrow.png); position:absolute; top:0; left:50%; margin-left:-51px; }
#whois h2 { margin-top:0; text-transform: uppercase; color:#ffffff; text-align: center; font-size:40px; font-style:normal; font-weight:bold; text-shadow: 0 0 8px #080808; margin-bottom: 40px;}
#whois p { font-size:23px; text-align:center; }
#whois a.btn { background-color: #ffffff; font-size:25px; text-decoration:none; text-transform: uppercase; padding:10px 40px; border-radius:25px; color:#000000; margin:15px 0 0 0; display:inline-block; }

#latestnews .row .text { background-color: #f2f2f2; padding:1px 20px 10px 20px; }
#latestnews .row .newsbox:nth-child(3n+1) { clear:both; }
#latestnews h2 { font-size:22px;   margin-top: 20px;  margin-bottom: 10px; line-height:normal; text-transform: none; }

.nofootermargin { margin-bottom: -30px;}

footer { background-image: url(media/footerbackground.jpg); padding:30px 0; margin:30px 0 0 0; }
footer p { color:#ffffff; font-size:15px; line-height:18px; }
footer p a:link, footer p a:visited { color:#ffffff;}
footer h2 { font-size:18px; color:#ffc300; text-transform: uppercase; margin-bottom: 30px; margin-top:0;  }
footer #footerlogo { }
footer #footerservicelinks { float:left;  }
footer #footerservicelinks p { text-transform: uppercase; border-bottom:1px #7d7d77 solid; padding:2px 0 6px 0; }

footer #footergallerylinks {   }
footer #footergallerylinks .gallerylink  {  border:7px solid #333333; background-size: cover; height:62px; width:62px; float:left; margin:0 11px 11px 0;}
footer #footergallerylinks .gallerylink:nth-child(3n) { margin-right: 0; }
footer #footercontact { }
footer #footercontact p { margin:12px 0; padding-left:35px; }

#bottomstrip { padding-top:30px; padding-bottom: 30px;}

#bottomstrip p { color:#ffffff; margin-top:0; }
#bottomstrip .grey { color:#7f7f7f; }
#bottomstrip p a { color:#ffffff; }

#uparrow { width:60px; height:60px;     background-color: #4c4c4c; position:fixed; bottom:20px; right:20px; background-image: url(media/uparrow.png); display: none; }

@media (min-width: 1200px) {

    /* bigger screen, logo and nav bar can be bigger */
    header #logo img { width:auto;}
    .navbar-nav>li>a { padding:0 35px 0 0px !important; font-size:16px; }

}

@media (min-width: 993px) {
    /* core desktop version  */

    #sticky { height:164px; position:fixed; top:0; width:100%; z-index: 99; background-color: #ffffff; }
    #searchcontainer { margin-top:164px; }

    .navbar { border:none; margin-bottom: 0; text-transform: uppercase; font-size:16px; font-weight:bold; position: static;  }
    .navbar  .nav .open>a { background-color: transparent; }
    .navbar-nav>li { position:inherit;}
    .navbar-nav>li>a { height:119px; line-height:119px;  background-image: url(media/navdivider.gif); padding:0 40px 0 0px; background-repeat: no-repeat; background-position:right; color:black; }
    .navbar-nav>li>a:hover { color: #ffffff; background-color: transparent; }

    .navbar-nav>li .dropdown-menu {  position:absolute; width:100%; z-index:99;background-color: #ffffff; margin-top:5px; }
    .navbar-nav .dropdown-menu li { width:33%; float:left; padding:0 10px 0 10px;}
    .navbar-nav .dropdown-menu li a { background-color:#f2f2f2; margin:10px 0; padding:15px 5px; border:1px #cccccc solid; font-size:16px; text-align: center; font-weight:bold; }

    #topstrip { height:37px; }

    #banner1 .bannertext { margin-top:160px; width:900px; height:612px; }
    #banner1 .slick-slide {  height:661px; }

    #dropdown .container { width:1050px; }
    #bottomstrip #copyright { width:700px; margin-top:-10px; }
}




@media (max-width: 992px), (max-width:678px) {
    /* this is where navigation bar no longer fits */
    #logo.pull-left { float:none; }
    #topstrip { text-align: center;  }
    #topstrip #callus { font-size:20px; }
    #topstrip .text-right { text-align: center !important; }

    header { height:100px;  z-index: 2; position: relative;}


    #logo { left:50%; margin-left:-75px; position:absolute;}

    /* nav bar */
    .navbar-header {
        float: none;
    }
    .navbar-left,.navbar-right {
        float: none !important;
        margin-right:auto;
    }
    .navbar-toggle {
        top:22px;
        width:44px;
        height:37px;
        position:absolute;
        left:0px;
        display: block;
        background-image: url(media/cross.png); background-repeat:no-repeat; background-position: 9px 7px;
    }

    .navbar-toggle.collapsed { background-image: none; }
    .navbar-toggle.collapsed .icon-bar { display:block;}

    .navbar-toggle .icon-bar {
        height:3px;
        display:none;
    }
    .navbar-collapse {
        border-top: 1px solid transparent;
        box-shadow: inset 0 1px 0 rgba(255,255,255,0.1);
    }
    .navbar-fixed-top {
        top: 0;
        border-width: 0 0 1px;
    }
    .navbar-collapse.collapse {
        display: none!important;
    }
    .navbar-nav {
        float: none!important;
        margin-top: 105px;
        position:absolute;
        width:100%;
        padding:0 15px;
        background-color: #ffffff;
        border:1px #808080 solid;
        margin-left:auto;
        margin-right:auto;
        z-index: 5;
    }
    .navbar-nav>li {
        float: none;

    }

    .navbar-nav>li>a { color:#000000;  background-color:#ffc300; margin:10px 0; padding:15px 5px !important; border:1px #cccccc solid; font-size:16px; text-align: center; font-weight:bold; text-transform: uppercase; display:block;}


    .navbar-nav .open .dropdown-menu {
        float: none;
        width: auto;
        margin-top: 0;
        background-color: transparent;
        border: 0;
        -webkit-box-shadow: none;
        box-shadow: none;
    }

    .navbar-nav>li>a {
        padding-top: 10px;
        padding-bottom: 10px;
    }
    .navbar-nav>li>a:focus {  background-color:#ffc300 !important; }

    .navbar-nav li.dropdown.open>a { background-image: url(media/cross.png); background-position: right 15px top 15px; background-repeat:no-repeat;}
    .navbar-nav li.dropdown.open>a .caret { display:none; }
    .collapse.in{
        display:block !important;
    }
    .navbar-collapse.in {
        overflow-y:visible;
    }

    .dropdown-menu { position:relative; padding-top:0; }
    .dropdown-menu li a {  color:#000000;  background-color:#f2f2f2; margin:10px 0; padding:15px 5px !important; border:1px #cccccc solid; font-size:16px; text-align: center; font-weight:bold; text-transform: uppercase; }

    /* misc*/
    #banner1 .bannertext p br { display:none; }
    .newsbox { margin-bottom: 20px;}
    #bottomstrip #bottomstripcallus { text-align: left; }
    #bottomstrip .social{ text-align: left; }


}


@media (max-width: 768px) {
    /* mobile */
    .navbar-toggle { display:inherit;  }
    #logo.pull-left { float:none; }
    #topstrip { text-align: center;  }

    .navbar-nav { width:100%; left:0; }

    #banner1 .bannertext p:first-of-type { font-size:20px; }
    #banner1 .bannertext p { font-size:15px; }


    #bottomstrip #bottomstripcallus { text-align: right; }
    #bottomstrip .social{ text-align: left; }
    #bottomstrip p { text-align: center; }

}

@media (max-width: 767px) {
    #bottomstrip #bottomstripcallus { text-align: center; }
    #bottomstrip .social {  text-align: center;  }
    #bottomstrip p {  text-align: center; }
    .btn { display: block;}
}

/* layout - 1 */
#banner2>div { height:180px; background-size: cover; }
#banner2 h1 { text-align: center; font-size:40px; line-height:180px; color:#ffffff; font-style:italic; text-transform:uppercase; margin-top: 0;  }
#banner2 p { text-align: center; font-size:40px; line-height:180px; color:#ffffff; font-style:italic; text-transform:uppercase; margin-top: 0;  }
/* services */
.containerfaq { padding-bottom: 30px;}
.containerfaq h3 { font-size:18px; margin:20px 0; padding-left:50px; position:relative; cursor: pointer; }
.containerfaq h3 .dot { width:33px; height:33px; border-radius:33px; background-color: #f7b71e; margin-left:-50px; position:absolute; top:-3px; font-size:50px; color:#ffffff; text-align: center; line-height:20px; font-weight:normal; }
.containerfaq h3 .dot.on { line-height:15px;}
.containerfaq p  { font-size:27px; line-height:normal margin:20px 0; color:#666666; font-size:15px; padding-left:50px; display:none; }

.containerservicebuttons { padding:30px 0;}
.containerservicebuttons a.btn { display:block; background-color: #000000; border:1px #ffffff solid; color:#f7b71e !important; line-height:47px; font-size:22px; }
.containerservicebuttons a.btn.on { background-color: #f7b71e; color:#000000 !important; }
.serviceareas { display:none; }


/* projects */
#projects {}
#cbprojectsheading { margin-top: 30px;}
#projectcontent p { font-size:15px; line-height:23px;}
.project-menu { list-style-type: none; margin:0; padding:0; font-size:18px; }
.project-menu li { position:relative; }
.project-menu li .arrow { position:absolute; right:0; top:10px;}
.project-menu li a { border-bottom:1px #b7b7b7 solid; display:block; line-height:35px; }
.project-menu ul { list-style-type: none; margin:0; padding:0 }
.project-menu ul li a { padding-left:20px;}

#projects .document { border-bottom:1px #c7c7c7 solid; padding:3px 0 5px 0; font-weight:bold; }
#projects .document img { margin:0 10px 0 0; vertical-align: middle;}
#projects .page.pagehide { display:none; }


/* people */

#people  .image { position:relative;}
#people .image .nameblock { position:absolute; bottom:0; text-align: center; background-color: rgba(255,255,255,0.8); padding:10px; width:100%;}
#people .image img { width:100%;}
#people .image .nameblock p { line-height:16px; font-size:15px; color:#000000;}
#people .image .nameblock p strong { text-transform: uppercase;}
#people .yellowblock { background-color: #e5e5e5; padding:15px; text-align: center;}
#people .yellowblock img  { margin:0 5px;}

#people .list { margin-bottom: 20px;}
#people .list .image a { text-decoration: none; cursor: default;}
#people .list.hover:hover .image .nameblock p, #people .image.on .nameblock p { color:#FFFFFF; }
#people .list.hover:hover .image .nameblock, #people .image.on .nameblock { background-color: rgba(0,0,0,0.8); }

#people .list.hover:hover a {  cursor: pointer;}

#people .list.hover:hover .yellowblock, #people  .yellowblock.on { background-color:#f7b71e; }
#peoplecontent p { font-size:15px; line-height:23px;}

/* contact us */

#contact textarea { height:120px;}

/* accordion */
.accordion { background-color:#f7b71e; font-style:italic; font-family: 'Oswald', sans-serif; margin:0 0 15px 0; font-weight:400; font-size:22px; padding:10px 20px; line-height:35px; color:#000000; position:relative; }
.accordion .action { width:30px; height:22px; position:absolute; right:15px; top:17px; }
.accordion .action span { display: block; height:5px; background-color: #000000; margin:0 0 5px 0;}
.accordion.open p .action { background-image: url(media/cross.png); background-repeat:no-repeat; background-position: right;  }
.accordion.open p span { display:none;}
.accordion-content { padding:15px 0; display:none; margin-top:-15px; }
.accordion-content .contactblock:first-of-type { margin-top: 0;}
.accordion-content.open { display:block; }

/* sub accordion */
.sub-accordion p { text-decoration: underline; cursor:pointer;}
.sub-accordion ul { display:none; }

/* 404 */
.notfound {  background-repeat:no-repeat; background-position: right bottom; padding-bottom: 20px; }
.notfound h1 { font-size:60px; text-align: left; font-style: normal; font-weight:bold; line-height:50px;}
.notfound .h2 { color:#666666; font-size:25px;}
@media (min-width: 993px)  {
    .notfound { background-image: url(media/daza.jpg);}

}

.services>div { padding:0 10px 0 10px; list-style: none;}
.services>div a  { background-color:#f2f2f2; margin:10px 0; padding:15px 5px; border:1px #cccccc solid; color:#000000 !important; font-size:16px; text-align: center; font-weight:bold; display: block; }
.services>div a:hover { background-color: #999999; color:#FFFFFF !important; text-decoration: none; }

/* jobs */

#jobs .list { border:1px #d2d2d2 solid; }
#jobs .list .line { margin:0; height:5px; background-color: #b75e00; border:none;}
#jobs .list h2 { font-size:25px; font-style: normal; margin:15px 0; text-transform: none;  font-family: 'Lato', sans-serif; font-weight:bold; }
#jobs .list p { font-size:16px; margin:15px 0; }
#jobs .list .secondcolumn { background-color: #fff8e5; text-align: center; padding:30px 0; margin:20px 0; }
#jobs .list .secondcolumn .jobtitlerepeat { font-size:25px; font-weight:bold;  }
#jobs .list .secondcolumn .jobapply { font-size:30px; color:#000000; margin-top:5px; display: block;}
#jobs .list .secondcolumn .jobapply:hover { text-decoration: none; opacity: 0.5;}

#jobs .item-content h1 { font-size:25px; font-style: normal; margin:15px 0; text-align: left;   font-family: 'Lato', sans-serif; font-weight:bold; }
#jobs  .applybuttons .btn { font-size:17px !important; padding:5px 40px; color:#FFFFFF !important; }
#jobs .item-content h2 { font-size:25px; font-style: normal; margin:15px 0; text-align: left; text-transform: none;  font-family: 'Lato', sans-serif; font-weight:bold; }
#jobs .item-content table { font-size:16px; margin:-15px 0 10px 0; }
#jobs .item-content table tr { border-bottom:1px #9a9a9a solid; }
#jobs .item-content table tr td { padding:10px;}
#jobs .item-content table tr td:first-child { font-weight:bold; }
#jobs .item-content strong { color:#b75e00 }

#gallery-images .item-images { margin-bottom:7px;}

/* misc */

.container-black { background-color: #000000; }
.container-grey { background-color: #b2b2b2; }
.container-lightgrey { background-color: #f2f2f2; }
.container-lightgrey2 { background-color: #e5e5e5; }

.line { margin:30px 0; height:1px; border-top:1px #b75e00 dotted; }

.compulsory { color:#F00; font-size:22px; float:right; margin:-5px 0 0 10px; }
.icon { background-repeat: no-repeat; }
.emailicon { background-image: url(media/mailicon.gif); padding-left:30px; }
.emailiconsmall { background-size:20px;}
.yellowarrow { background-image: url(media/yellowarrow.png); padding-left:25px; }
.phoneicon { background-image: url(media/phoneicon.png); padding-left:25px; }
.worldicon { background-image: url(media/worldicon.png); padding-left:25px; }
.markericon { background-image: url(media/markericon.png); padding-left:25px; }
.locationicon { background-image: url(media/locationicon.png); padding-left:25px; }
.make-image-responsive img { width:100% !important; height:auto !important;}
.breadcrumb { background-color: transparent;  font-size:14px; text-transform: uppercase; color:#b75e00; padding:0; margin:18px 0 12px 0; }
.breadcrumb a {  color:#b75e00;}

.parallax {
    background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

/* form tweaks */

.form-control { border-radius:5px;  }
.btn { border-radius:0; background-color: #ffc300; color:#000000 !important; }
.btn:hover { opacity:0.5; }
.btn-photogallery {  font-size:25px; line-height:35px; color:#000000 !important; margin:33px 0 28px 0; display:block; font-style:italic; text-align: center; background-color: #ffffff;  border:1px #e9e9e9 solid;  }
.btn-photogallery img { vertical-align: bottom; }
.btn.btn-red { background-color: #ff0000 !important; color:#FFFFFF !important; }
.btn-lg { font-size:16px; text-transform: uppercase; }


.form-group.labellast .field { display: inline-block; float:left; margin-right:10px; } /* mostly used for "terms" buttons */
.form-group.labellast label { font-weight:normal; }

.form-group.hidelabel .labeldiv { opacity: 0;}
.form-group.nolabel .fielddiv { padding-left:0; }
.form-group .control-label {  text-align: left;  }
.form-group.form-horizontal .labeldiv { padding:0; }
.form-group.nolabel .labeldiv, .form-group.nolabel label { display:none; }
form + button { margin-top: 10px; }

label { color:#a0a0a0; font-weight:normal; font-size:15px; }
input, select { padding:20px 10px !important; }


/* contentarea */
.linktocms { position:absolute;  padding:0 5px 0 5px; text-align:center; background-color:#ff0000; color:#FFFFFF; z-index:999; text-shadow:none; line-height:25px; }
.linktocms.relative { position:relative; display:inline-block; }
td .linktocms { margin-top:-20px; }
.linktocms a { color:#FFFFFF !important; text-decoration:none !important; padding:10px; font-size:20px; }
.linktocms a:hover {  zoom: 1; filter: alpha(opacity=50); opacity: 0.5; cursor:pointer; }
#adminlink { background-color:#0066CB; margin-top:1px; position:absolute; padding:5px; color:#FFFFFF; z-index:1000; top:0; width:100%;}
#adminlink img#logintoadmin { float:left; margin-right:5px; }
#adminlink a:link, #adminlink a:visited { color: #FFFFFF; }
#adminlink a:hover { color: #f2f7fc; }
#adminlink .pageattributes { margin:0 0 0 30px; }
#adminlink .pageattributes strong { color:#03a9f4 }
.editable { border:1px #FF0000 dotted; position:relative; margin-top:20px; min-height:20px; }
.editable.off { border:none; margin:0; min-height:0; }
.editableoptions { position:absolute; top:-20px; }
.editinline.disabled, .editnewwindow.disabled { opacity:0.2; }


.inlineaddpreview { display:none; }
.inlineaddsave { display:none; }


#debugcontainer { position:absolute; top:10px; right:20px; background-color:#e6e6e6; padding:10px; z-index:1000; max-width:800px; }
#debug p { margin-top:5px; margin-bottom:5px; }
#debug h3 { margin-top:5px; margin-bottom:5px; }

