body { font-family: 'Inter', sans-serif; }
.inter-light { font-weight: 300; }
.inter-bold { font-weight: 700; }
.inter-black { font-weight: 900; }

.container-fluid { padding: 0; }
.rounded { border-radius: 3em !important }
.ribbon { 
    background-color: #F2C500;
    font-weight: bold;
    text-align: center;
    padding: .5em;
}
.vertical-center > p { margin: 0; }

.top {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    padding: 2em 0;
}
.top-item-logo { flex-basis: 40%; }
.top-item-search { 
    flex-basis: 20%;
    padding-left: 3em;
}
.top-item-menu { flex-basis: 40%; }

@media(max-width: 1073px) {
    .top > div { margin-bottom: 1em; }
    .top-item-logo, .top-item-search, .top-item-menu { flex-basis: 100%; }
    .li-link { flex-basis: 100%; }
    .footer > div { flex-basis: 100% !important }
    .mega-menu-container { flex-wrap: wrap; }
    .footer > .one { margin: 2em 0; }
}

@media(max-width: 815px) {
    .top > div { margin-bottom: 1em; }
    .top-item-logo, .top-item-search, .top-item-menu { flex-basis: 100%; }
    .li-link { flex-basis: 100%; }
    .footer > div { 
        flex-basis: 100% !important;
        text-align: center;
    }
    .mega-menu-container { flex-wrap: wrap; }
    .footer > .one { margin: 2em 0; }
}

@media(max-width: 555px) {
    .top > div { margin-bottom: 1em; }
    .top-item-logo, .top-item-search, .top-item-menu { flex-basis: 100%; }
    .li-link { flex-basis: 100%; }
    .footer > div { 
        flex-basis: 100% !important;
        text-align: center;
    }
    .mega-menu-container { flex-wrap: wrap; }
    .footer > .one { margin: 2em 0; }
}

.top-item-logo img { max-width:100%; }

.navigation {
    margin: 1em 0;
    align-items: center;
    display: flex;
    font-size: .85em;
    justify-content: space-between;
    list-style: none; 
    padding-left: 1.5em;   
}
.navigation a { text-decoration: none; }

.li-link a:hover, .li-link a:focus { 
    color: #000000 !important; 
    text-decoration: underline;
}

input#search {
    background-image: url(./Assets/search.png);
    background-position: 8px 7px;
    background-repeat: no-repeat;
    background-size: 1.5em;
    text-indent: 25px;
}

.li-link { flex-basis: 33.33%; }
.li-link > button {
    font-size: 1em;
    font-weight: bold;
    border: none;
    border-radius: 2em;
    background-color: #F2C500;
    padding: .75em 2em; 
}
.li-link .fa-regular, .fa-solid { padding-right: .25em; }
.li-link a {
    align-items: center;
    justify-content: center;
    color: #8C8C8C;
    padding-left: 0.5em;
    display: flex;
    flex-wrap: wrap;
    font-size: 1.1em;
}

.img-link img {
    float: left;
    width: 2em;
}

.button-link { text-align: center;}
.d-block {
    width: auto;
    max-width: 1080px;
    min-height: 300px;
    margin: auto;
}

.navbar {
    color: #292929;
    font-weight: 300;
    text-align: center;
}
.navbar-light .navbar-toggler { border-color: none; }
.nav-item { padding: 0 2.5em; }
.nav-link { color: #000000 !important; }
.nav-link:hover { color: #8C8C8C !important; }

.navbar { list-style: none; }	
.navbar .dropdown-menu {
    left: 0;
    right: 0;
    width: 100%;
    margin-top: 0;
    padding: 1rem;
}
@media all and (min-width: 992px) {
    .navbar .has-mega-dropdown { position:static!important; }
    .navbar .mega-dropdown-menu{ left:0; right:0; width:100%; margin-top:0; }
}

.carousel-inner {
    width:100%;
    max-height: 500px !important;
}
.product-spotlight {
    font-size: 3em;
    font-weight: 900;
    padding: 2.5em .25em 1em;
}

.product-container, .product-spotlight {
    max-width: 1335px;
    margin: 0 auto;
}

.grid-row {
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
}

.grid-item {
    height: 20em;
    flex-basis: 25%;
    -ms-flex: auto;
    width: 259px;
    position: relative;
    padding: .25em;
    box-sizing: border-box;
}

.grid-row a { text-decoration: none; }

.wrapping-link {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    z-index: 2;
    color: currentColor;
}

.grid-item-wrapper {
    -webkit-box-sizing: initial;
    -moz-box-sizing: initial;
    box-sizing: initial;
    margin: 0;
    height: 100%;
    width: 100%;
    overflow: hidden;
    transition: padding 0.15s cubic-bezier(0.4,0,0.2,1), margin 0.15s cubic-bezier(0.4,0,0.2,1), box-shadow 0.15s cubic-bezier(0.4,0,0.2,1);
    position: relative;
}

.grid-item-container {
    height: 100%;
    width: 100%;
    position: relative;
}

.grid-image-top {
    height: 90%;
    width: 120%;
    background-size: cover;
    position: relative;
    background-position: 50% 50%;
    left: -10.5%;
    top: -4.5%;
}

.grid-image-top .centered {
    text-align: center;
    transform: translate(-100%, -100%); 
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    /*top: 54.5%;
    left: 50%;
    width: 60%;
    height: 60%;*/
	
	top: 100%;
    left: 100%;
	
	width: 100%;
	height: 100%;
    background-position: center;
}


.grid-image-top .centered img{
	height: 100%;
	width: 100%;
	object-fit: contain;
}

.grid-image-top { background: linear-gradient(#8C8C8C, #F0F0F0); }

.grid-item-content { padding: 0 20px 20px 20px; }

.more-info {
    position: absolute;
    bottom: 0;
    margin-bottom: 10px;
    padding-left: 0;
    transition-duration: .5s;
    font-size: 1em;
    display: flex;
}

.more-info i {
    padding-left: 5px;
    transition-duration: .5s;
}

.grid-item:hover .more-info i {
    padding-left: 20px;
    transition-duration: .5s;
}

.more-info i::before { font-size: 16px; }

.grid-item:hover .grid-item-wrapper {
    padding: 2% 2%;
    margin: -2% -2%;
}

.about {
    background-color: #F0F0F0 ;
    margin: 8em 0 0;
    padding: 6em 2em;
    display: grid; 
    grid-auto-flow: column; 
    grid-template-columns: 0.5fr 2fr 2fr 0.5fr; 
    grid-template-rows: 1fr; 
    gap: 0px 0px; 
    grid-template-areas: 
        ". . . ."; 
}
.about-text {
    max-width: 1335px;
    margin: 0 auto;
    padding: 2em;
}
.about-text > h3, .survey > h3 {    
    font-size: 2em;
    font-weight: 900;
}
.feedback {
    display: flex;
    flex-wrap: wrap;
}
.feedback > div { flex-basis: 50%; }

.feedback-left { 
    align-items: center;
    justify-content: center;
    margin: auto;
}
.feedback-left img {
    flex-shrink: 0;
    width: 100%;
}
.feedback-left > p {
    line-height: 1;;
    font-size: 5em;
    font-weight: 900;
    color: #FFFFFF;
    padding: .5em 1.5em;
}
.feedback-right {  
    flex-basis: 50%;
    margin: auto;
    text-align: center;
    padding: .75em 2em; 
}
.feedback-right > p { font-size: 1.25em; }

.feedback-right button {
    color: #000;
    background-color: #F0F0F0;
    border-radius: 2em;
    border:none;
    font-weight: bold;
    padding: .75em 2em;
}
.footer {
    background-color: #8C8C8C;
    color: #ffff;
    font-size: .75em;
    display: flex; 
    flex-wrap: wrap;
    padding: 4em;
}
.footer-section { 
    padding-left: 2em;
    flex-basis: 25%; 
}
.footer-logo { margin-bottom: 1em; }

.footer-title {
    font-size: 1.25em;
    font-weight: 600;
}
.footer-section-content { margin-top: 1em; }
.one {
    text-align: left;
    margin-top: 14em;
}
.four { text-align: end; }
.footer-section-content a {
    color: #FFFFFF;
    text-decoration: none;
}
.footer-section-content a:hover { text-decoration: underline; }
@media(max-width: 1333px) { .grid-item { flex-basis: 33.33%; } }

@media(max-width: 1073px) { .grid-item { flex-basis: 33.33%; } }

@media(max-width: 815px) { .grid-item { flex-basis: 50%; } }

@media(max-width: 555px) { .grid-item { flex-basis: 100%; } }
.navbar .mega-dropdown-menu .mega-menu-container ul li { list-style: none; }	
.navbar .dropdown-menu {
    left: 0;
    right: 0;
    width: 100%;
    margin-top: 0;
    padding: 1rem;
    border-top: 3px solid rgba(0,0,0,.05);
}
.mega-menu-container { 
    display: flex;
    align-items: flex-start;
    justify-content: space-evenly;
}
.mega-menu-items a {
    color: #292929;
    text-decoration: none;
}
.mega-menu-items a:hover { 
    color: #8C8C8C;
    text-decoration: underline; 
}
@media all and (min-width: 992px) {
    .navbar .has-mega-dropdown { position:static!important; }
    .navbar .mega-dropdown-menu { left:0; right:0; width:100%; margin-top:0; }
}

/* Product CSS */
.product { margin: 2em; }
.overview, .specs {
    display: flex;
    flex-wrap:wrap; 
    padding-left: 1em;
    padding-top: 2em;
}
.overview > div, .specs > div { flex-basis: 50%; }
@media only screen and (max-width: 800px) {
    .overview > div, .specs > div {   
        flex-basis: 100%;
    }
}
.nav-tabs .nav-link.active {
    color: #8C8C8C;
    background-color: #FFFFFF;
    border-color: #FFFFFF #FFFFFF #000000 ;
    font-weight: bold;
}
.nav-tabs .nav-link {
    background: 0 0;
    border: .15em solid transparent;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}
.tab-content { margin: 4em 0; }

.product-content, .specs-text { padding: 2em; }
.product-content > h2 {
    font-size: 2.5em;
    font-weight: 900;
}
.product-content > ul {
    font-size: 1.05em;
    font-weight: bold;
}
.product-content .request-link {
    color: #000000;
    font-weight: bolder;
    text-decoration: none; 
    cursor: pointer;
}
.product-content .request-link:hover {
    color: #8C8C8C !important;
    text-decoration: underline;
}
.product-image > img { width: 100% }
.related-products {
    text-align: center;
    margin: 3em 2em !important;
}
.related-products > h2 { font-weight: 900; }
.other-products { 
    margin-bottom: 3em;
    padding: 2em 0;
}
.services {
    background-color: #F0F0F0 ;
    margin: 8em 0 0;
    padding: 3em 2em;
    text-align: center;
}
.services-text {
    max-width: 1335px;
    margin: 0 auto;
    padding: 2em;
}
.services-text > h3 {    
    font-size: 2em;
    font-weight: 900;
}
.white-btn { 
    background-color: #FFFFFF;
    border-radius: 1.25rem;
    padding: .5em 2em;
    font-weight: bold;
}
.request-button { 
    margin-top: 1em;
    text-align: center; 
}
.request-button button { 
    font-weight: bold;
    border: none;
    border-radius: 2em;
    background-color: #F0F0F0;
    padding: .75em 2em; 
}
.inner-menu { 
    display: flex;
    flex: 1;
    flex-wrap: wrap;
}
.services-text button {
    background-color: #FFFFFF;
    border: none;
    border-radius: 2em;
    font-weight: bold;
    padding: .75em 2em;
}
