.close-i, .nav li a {
    color: #004AC9
}

.nav, .form-submit {
    text-align: center
}

.grid-cheat, .splits {
    grid-template-columns: 100%
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 300;
    src: local('Open Sans Light'), local('OpenSans-Light'), url(https://fonts.gstatic.com/s/opensans/v15/mem5YaGs126MiZpBA-UN_r8OUuhs.ttf) format('truetype')
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 400;
    src: local('Open Sans Regular'), local('OpenSans-Regular'), url(https://fonts.gstatic.com/s/opensans/v15/mem8YaGs126MiZpBA-UFVZ0e.ttf) format('truetype')
}

.nav {
    position: absolute;
    z-index: 99999;
    top: 0;
    left: -150vw;
    margin-top: 119px;
    box-sizing: border-box;
    width: 100%;
    height: 100vh;
    transition: left .4s ease;
    text-decoration: none;
    opacity: .9;
    background-color: #fff
}

.nav.is-open {
    left: 0
}

.nav ul {
    margin-top: 2em;
    list-style: none;
    padding: 5px
}

.nav li {
    font-size: 1.5em;
    padding: 1em 0 .5em
}

.nav img {
    padding: 15px;
    border-bottom: 1px solid gray
}

.close-i {
    font-size: 2em;
    position: right;
    padding-top: 20px
}

input, textarea {
    font-family: 'Open Sans', sans-serif;
    font-size: 1.1rem;
    border: none;
    border-bottom: solid 1px #eee;
    width: 100%;
    padding: 15px 0
}

textarea {
    min-height: 140px;
    height: 100%;
    padding: 15px 0
}

.form-submit {
    font-family: 'Open sans', sans-serif;
    width: 100%;
    font-size: 1em;
    padding: 3%;
    color: #fff;
    background-color: #1A7691;
    box-shadow: none;
    border: none;
    margin-top: 1em
}

@font-face {
    font-family: lightcase;
    src: url(../fonts/lightcase.eot?55356177);
    src: url(../fonts/lightcase.eot?55356177#iefix) format("embedded-opentype"), url(../fonts/lightcase.woff?55356177) format("woff"), url(../fonts/lightcase.ttf?55356177) format("truetype"), url(../fonts/lightcase.svg?55356177#lightcase) format("svg");
    font-weight: 400;
    font-style: normal
}

[class*=lightcase-icon-]:before {
    font-family: lightcase, sans-serif;
    font-style: normal;
    font-weight: 400;
    speak: none;
    display: inline-block;
    text-decoration: inherit;
    width: 1em;
    text-align: center;
    font-variant: normal;
    text-transform: none;
    line-height: 1em
}

.lightcase-icon-play:before {
    content: '\e800'
}

.lightcase-icon-pause:before {
    content: '\e801'
}

.lightcase-icon-close:before {
    content: '\e802'
}

.lightcase-icon-prev:before {
    content: '\e803'
}

.lightcase-icon-next:before {
    content: '\e804'
}

.lightcase-icon-spin:before {
    content: '\e805'
}

@keyframes lightcase-spin {
    0% {
        transform: rotate(0)
    }

    100% {
        transform: rotate(359deg)
    }
}

#lightcase-case {
    display: none;
    position: fixed;
    z-index: 2002;
    top: 50%;
    left: 50%;
    font-family: arial, sans-serif;
    font-size: 13px;
    line-height: 1.5;
    text-align: left;
    text-shadow: 0 0 10px rgba(0, 0, 0, .5)
}

#lightcase-loading>span, a[class*=lightcase-icon-]>span {
    display: inline-block;
    text-indent: -9999px
}

@media screen and (min-width:641px) {
    html:not([data-lc-type=error]) #lightcase-content {
        position: relative;
        z-index: 1;
        text-shadow: none;
        background-color: #fff;
        -o-box-shadow: 0 0 30px rgba(0, 0, 0, .5);
        box-shadow: 0 0 30px rgba(0, 0, 0, .5);
        -webkit-backface-visibility: hidden
    }

    html[data-lc-type=image] #lightcase-content, html[data-lc-type=video] #lightcase-content {
        background-color: #333
    }
}

html[data-lc-type=ajax] #lightcase-content, html[data-lc-type=error] #lightcase-content, html[data-lc-type=inline] #lightcase-content {
    -o-box-shadow: none;
    box-shadow: none
}

html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner, html[data-lc-type=error] #lightcase-content .lightcase-contentInner, html[data-lc-type=inline] #lightcase-content .lightcase-contentInner {
    -o-box-sizing: border-box;
    box-sizing: border-box
}

@media screen and (max-width:640px) {
    html[data-lc-type=ajax] #lightcase-case, html[data-lc-type=inline] #lightcase-case {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        margin: 0 !important;
        padding: 55px 0 70px;
        width: 100% !important;
        height: 100% !important;
        overflow: auto !important
    }

    html[data-lc-type=ajax] #lightcase-content, html[data-lc-type=error] #lightcase-content, html[data-lc-type=inline] #lightcase-content {
        position: relative !important;
        top: auto !important;
        left: auto !important;
        width: auto !important;
        height: auto !important;
        margin: 0 !important;
        padding: 0 !important;
        border: none !important;
        background: 0 0 !important
    }

    html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner, html[data-lc-type=error] #lightcase-content .lightcase-contentInner, html[data-lc-type=inline] #lightcase-content .lightcase-contentInner {
        padding: 15px
    }

    html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner, html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner>*, html[data-lc-type=error] #lightcase-content .lightcase-contentInner, html[data-lc-type=error] #lightcase-content .lightcase-contentInner>*, html[data-lc-type=inline] #lightcase-content .lightcase-contentInner, html[data-lc-type=inline] #lightcase-content .lightcase-contentInner>* {
        width: 100% !important;
        max-width: none !important
    }

    html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner>:not(iframe), html[data-lc-type=error] #lightcase-content .lightcase-contentInner>:not(iframe), html[data-lc-type=inline] #lightcase-content .lightcase-contentInner>:not(iframe) {
        height: auto !important;
        max-height: none !important
    }

    html.lightcase-isMobileDevice[data-lc-type=iframe] #lightcase-content .lightcase-contentInner iframe {
        overflow: auto;
        -webkit-overflow-scrolling: touch
    }
}

@media screen and (max-width:640px) and (min-width:641px) {
    html[data-lc-type=image] #lightcase-content .lightcase-contentInner, html[data-lc-type=video] #lightcase-content .lightcase-contentInner {
        line-height: .75
    }
}

html[data-lc-type=image] #lightcase-content .lightcase-contentInner {
    position: relative;
    overflow: hidden !important
}

@media screen and (max-width:640px) {
    html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner .lightcase-inlineWrap, html[data-lc-type=error] #lightcase-content .lightcase-contentInner .lightcase-inlineWrap, html[data-lc-type=inline] #lightcase-content .lightcase-contentInner .lightcase-inlineWrap {
        position: relative !important;
        top: auto !important;
        left: auto !important;
        width: auto !important;
        height: auto !important;
        margin: 0 !important;
        padding: 0 !important;
        border: none !important;
        background: 0 0 !important
    }

    #lightcase-content h1, #lightcase-content h2, #lightcase-content h3, #lightcase-content h4, #lightcase-content h5, #lightcase-content h6, #lightcase-content p {
        color: #aaa
    }
}

#lightcase-loading, a[class*=lightcase-icon-] {
    width: 1.123em;
    height: auto;
    line-height: 1;
    position: fixed;
    text-align: center
}

@media screen and (min-width:641px) {
    html:not([data-lc-type=error]) #lightcase-content .lightcase-contentInner .lightcase-inlineWrap {
        padding: 30px;
        overflow: auto;
        -o-box-sizing: border-box;
        box-sizing: border-box
    }

    #lightcase-content h1, #lightcase-content h2, #lightcase-content h3, #lightcase-content h4, #lightcase-content h5, #lightcase-content h6, #lightcase-content p {
        color: #333
    }
}

#lightcase-case p.lightcase-error {
    margin: 0;
    font-size: 17px;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #aaa
}

@media screen and (max-width:640px) {
    #lightcase-case p.lightcase-error {
        padding: 30px 0
    }
}

@media screen and (min-width:641px) {
    #lightcase-case p.lightcase-error {
        padding: 0
    }
}

.lightcase-open body {
    overflow: hidden
}

.lightcase-isMobileDevice .lightcase-open body {
    max-width: 100%;
    max-height: 100%
}

#lightcase-info {
    position: absolute;
    padding-top: 15px
}

#lightcase-info #lightcase-caption, #lightcase-info #lightcase-title {
    margin: 0;
    padding: 0;
    line-height: 1.5;
    font-weight: 400;
    text-overflow: ellipsis
}

#lightcase-info #lightcase-title {
    font-size: 17px;
    color: #aaa
}

#lightcase-info #lightcase-caption {
    clear: both;
    font-size: 13px;
    color: #aaa
}

#lightcase-info #lightcase-sequenceInfo {
    font-size: 11px;
    color: #aaa
}

@media screen and (max-width:640px) {
    #lightcase-info #lightcase-title {
        position: fixed;
        top: 10px;
        left: 0;
        max-width: 87.5%;
        padding: 5px 15px;
        background: #333
    }

    .lightcase-fullScreenMode #lightcase-info {
        padding-left: 15px;
        padding-right: 15px
    }

    html:not([data-lc-type=image]):not([data-lc-type=video]):not([data-lc-type=flash]):not([data-lc-type=error]) #lightcase-info {
        position: static
    }
}

#lightcase-loading {
    z-index: 2001;
    top: 50%;
    left: 50%;
    margin-top: -.5em;
    margin-left: -.5em;
    opacity: 1;
    font-size: 32px;
    text-shadow: 0 0 15px #fff;
    -moz-transform-origin: 50% 53%;
    animation: lightcase-spin .5s infinite linear
}

#lightcase-loading, #lightcase-loading:focus {
    text-decoration: none;
    color: #fff;
    -webkit-tap-highlight-color: transparent;
    transition: color, opacity, ease-in-out .25s
}

a[class*=lightcase-icon-] {
    z-index: 9999;
    font-size: 38px;
    text-shadow: none;
    outline: 0;
    cursor: pointer
}

a[class*=lightcase-icon-], a[class*=lightcase-icon-]:focus {
    text-decoration: none;
    color: rgba(255, 255, 255, .6);
    -webkit-tap-highlight-color: transparent;
    transition: color, opacity, ease-in-out .25s
}

a[class*=lightcase-icon-]:hover {
    color: #fff;
    text-shadow: 0 0 15px #fff
}

.lightcase-isMobileDevice a[class*=lightcase-icon-]:hover {
    color: #aaa;
    text-shadow: none
}

a[class*=lightcase-icon-].lightcase-icon-close {
    position: fixed;
    top: 15px;
    right: 15px;
    bottom: auto;
    margin: 0;
    opacity: 0;
    outline: 0
}

a[class*=lightcase-icon-].lightcase-icon-prev {
    left: 15px
}

a[class*=lightcase-icon-].lightcase-icon-next {
    right: 15px
}

a[class*=lightcase-icon-].lightcase-icon-pause, a[class*=lightcase-icon-].lightcase-icon-play {
    left: 50%;
    margin-left: -.5em
}

@media screen and (max-width:640px) {
    a[class*=lightcase-icon-] {
        bottom: 15px;
        font-size: 24px
    }
}

.first-text h1, .top-bar-mobile a, .top-bar-mobile i {
    font-size: 1.5em
}

@media screen and (min-width:641px) {
    a[class*=lightcase-icon-].lightcase-icon-pause, a[class*=lightcase-icon-].lightcase-icon-play {
        opacity: 0
    }

    a[class*=lightcase-icon-] {
        bottom: 50%;
        margin-bottom: -.5em
    }

    #lightcase-case:hover~a[class*=lightcase-icon-], a[class*=lightcase-icon-]:hover {
        opacity: 1
    }
}

#lightcase-overlay {
    display: none;
    width: 100%;
    min-height: 100%;
    position: fixed;
    z-index: 2000;
    top: -9999px;
    bottom: -9999px;
    left: 0;
    background: #333
}

@media screen and (max-width:640px) {
    #lightcase-overlay {
        opacity: 1 !important
    }
}

.wrap, a, body, div, h1, h2, h3, h4, h5, i, img, p {
    padding: 0;
    margin: 0;
    text-decoration: none;
    list-style: none
}

.bckg {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center
}

@media screen and (max-width:780px) {
    .hidden-m {
        display: none !important
    }
}

.limiter-big {
    width: 90%;
    max-width: 1000px;
    margin: auto;
    padding: 20px 0
}

@media screen and (min-width:780px) {
    .hidden-d {
        display: none !important
    }

    .limiter-big-d {
        margin: auto;
        width: 90%;
        max-width: 1000px;
        padding: 20px 0
    }

    .limiter-small-d {
        margin: auto;
        width: 60%;
        max-width: 600px;
        padding: 20px 0
    }
}

.limiter-small {
    margin: auto;
    width: 60%;
    max-width: 600px;
    padding: 20px 0
}

@media screen and (min-width:780px) {
    .extra-v-padding {
        padding: 100px 0
    }
}

a, h1, h2, h3, h4, h5, i, p {
    color: #4E4E4E;
    font-family: 'Open Sans', sans-serif
}

.top-bar-mobile {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.top-bar-mobile img {
    max-height: 5em
}

.banner-container {
    position: relative;
    height: 400px;
    width: 100%
}

.banner {
    height: 100%;
    width: 100%;
    position: absolute
}

.banner-1 {
    background-image: url(/_templates/assets/images/sln/banner-2.jpeg)
}

.banner-2 {
    background-image: url(/_templates/assets/images/sln/banner-1.jpeg)
}

.banner-3 {
    background-image: url(/_templates/assets/images/sln/banner-3.jpeg)
}

.banner-4 {
    background-image: url(/_templates/assets/images/sln/banner-4.jpeg)
}

.first-text h1 {
    color: #004AC9;
    opacity: .7;
    font-weight: 300;
    text-align: center
}

.first-text p {
    padding: 20px 10px 10px;
    color: #4E4E4E
}

.accreditations {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-pack: distribute;
    justify-content: space-around
}

.accreditations img {
    height: 8em;
    width: auto;
    padding: 25px 0
}

.dark-text {
    background-image: url(/_templates/assets/images/sln/dark-text.jpg)
}

.dark-text h2, .dark-text p {
    color: #fff;
    font-weight: 300;
    text-align: right;
    opacity: .8
}

.cctv {
    background-image: url(/_templates/assets/images/sln/van.jpg)
}

.services-first {
    background-image: url(/_templates/assets/images/sln/services-first.jpg)
}

.projects-grid {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-pack: center;
    justify-content: center
}

.projects-grid .project {
    display: -ms-flexbox;
    display: flex;
    height: 12em;
    -ms-flex-align: center;
    align-items: center;
    width: 100%;
    max-width: 200px;
    margin: 20px 5px
}

.projects-grid .project a {
    color: #004AC9;
    font-weight: 300;
    width: 100%;
    text-align: center;
    background-color: #fff;
    opacity: .8;
    padding: 5px;
    font-size: 1.2em
}

.latest-projects h2 {
    color: #004AC9;
    font-weight: 300;
    text-align: center
}

.grid-cheat {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 100%
}

.projects-services {
    -ms-flex-pack: center;
    justify-content: center
}

.projects-services .project {
    margin: 15px
}

.address-footer {
    background-color: #393939;
    padding-top: 15px;
    padding-bottom: 15px
}

.address-footer .limiter-footer {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    max-width: 50%;
    margin: auto
}

.grade, .list-grid {
    display: -ms-flexbox
}

.address-footer i, .address-footer p {
    color: #fff;
    font-size: 1.2em;
    text-align: center;
    padding: 15px 0
}

.footer {
    text-align: center
}

.list-grid {
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-pack: center;
    justify-content: center
}

.list-grid p {
    text-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 100%;
    min-height: 3em
}

@media screen and (max-width:550px) {
    .list-grid p:nth-child(2n+0) {
        background-color: #f2f2f2
    }
}

.testimonial .signature {
    padding: 0 0 20px;
    text-align: center;
    font-weight: lighter
}

.testimonial::after, .testimonial:first-of-type:before {
    display: block;
    width: 55%;
    height: 2px;
    margin: auto;
    content: '';
    opacity: .8;
    background: #004AC9
}

.banner-single-project, .services-address, .single-project-images a, .splits {
    width: 100%
}

.grade {
    display: flex;
    -ms-flex-pack: center;
    justify-content: center
}

.grade i {
    color: gold
}

.commercial h1 {
    padding-top: 20px
}

.banner-single-project {
    min-height: 100%
}

.single-project-images {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.single-project-images img {
    height: 15em;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    padding: 8px 0
}

.button {
    display: block;
    max-width: 100%;
    padding: 15px 25px;
    text-align: center;
    background-color: #004AC9;
    color: #fff;
    margin: 30px auto
}

.splits {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 100%;
    padding-top: 0
}

@media screen and (max-width:760px) {
    .splits .map {
        height: 50vh
    }
}

.splits .address {
    border: 1px solid #e6e6e6;
    padding: 15px
}

.splits .address .field {
    margin: auto;
    overflow: hidden
}

.splits .address form {
    margin: auto;
    display: block
}

.splits .address p {
    padding: 5px 15px;
    text-align: center;
    font-size: 1.2em
}

.splits .address input, .splits .address textarea {
    padding-left: 25px
}

.first-p-contact {
    padding-top: 15px;
    font-size: 1.5em
}

.left-align a, .left-align h1, .left-align h2, .left-align h3, .left-align p {
    text-align: left !important;
    padding-left: 0
}

@media screen and (min-width:500px) {
    .projects-grid {
        -ms-flex-pack: justify;
        justify-content: space-between
    }

    .projects-services {
        -ms-flex-pack: center;
        justify-content: center
    }

    .projects-services .project {
        margin: 15px
    }
}

@media screen and (min-width:550px) and (max-width:780px) {
    .list-grid {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -ms-flex-pack: center;
        justify-content: center
    }

    .list-grid p {
        text-align: center;
        width: 30%;
        min-height: 3em
    }

    .list-grid p:nth-child(4n+0), .list-grid p:nth-child(4n+1) {
        background-color: #f2f2f2
    }
}

@media screen and (min-width:780px) {
    .grid-cheat {
        -ms-grid-columns: 40% 60%;
        grid-template-columns: 40% 60%
    }

    .list-grid p {
        width: 30%
    }

    .list-grid p:nth-child(odd) {
        background-color: #f2f2f2
    }

    .list-grid p:last-of-type {
        background: #fff
    }

    .top-bar-desktop {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -ms-flex-align: center;
        align-items: center
    }

    .top-bar-desktop a {
        font-weight: 300
    }

    .top-bar-desktop img {
        max-height: 5em
    }

    .top-bar-desktop a:last-of-type {
        color: #fff;
        background: #004AC9;
        padding: 13px 8px
    }

    .first-text h1, .first-text p {
        text-align: center
    }

    .first-text h1 {
        font-size: 2em
    }

    .accreditations img {
        height: 5em
    }

    .single-project-images img {
        width: 100%
    }

    .single-project-images a {
        width: 20%
    }

    .button {
        max-width: 30%
    }

    .splits {
        display: -ms-grid;
        display: grid;
        -ms-grid-columns: 50% 50%;
        grid-template-columns: 50% 50%
    }
}