/**
 * Theme Name: Construction - Ultimate Construction Template
 * Version: 1.0
 * Description: HTML5 Template for Construction and Building Company
 * Author: BlogWP
 * Theme URI: http://www.blogwp.com/construction
 * Author URI: http://www.blogwp.com
 */

@import url("http://fonts.googleapis.com/css?family=Lato:400,400i|Montserrat:300,400,500,600,700&amp;subset=latin");
@import "assets/css/bootstrap.min.css";
@import "assets/css/animsition.css";
@import "assets/css/animate.css";
@import "assets/css/fontello.css";
@import "assets/css/font-awesome.min.css";
@import "assets/css/cubeportfolio.min.css";
@import "assets/css/magnific-popup.css";
@import "assets/css/flexslider.css";
@import "assets/css/vegas.css";
@import "assets/css/owl.carousel.css";
@import "includes/rev-slider/css/settings.css";
@import "includes/rev-slider/css/layers.css";
@import "includes/rev-slider/css/navigation.css";
@import "assets/css/woocommerce.css";
@import "assets/css/shortcodes.css";

/* Reset Browsers
-------------------------------------------------------------- */
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;font:inherit;vertical-align:baseline;font-family:inherit;font-size:100%;font-style:inherit;font-weight:inherit;}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}
html{font-size:62.5%;overflow-y:scroll;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;}
*,*:before,*:after{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;}
body{background:#fff;line-height:1;}
article,aside,details,figcaption,figure,footer,header,main,nav,section{display:block}
ol,ul{list-style:none}
table{border-collapse:collapse;border-spacing:0;}
caption,th,td{font-weight:normal;text-align:left;}
blockquote:before,blockquote:after,q:before,q:after{content:'';content:none;}
blockquote,q{quotes:none}
a:focus{outline:none}
a:hover,a:active{outline:0}
a img{border:0}
img{max-width:100%;height:auto;}
select{max-width:100%}

/* General
-------------------------------------------------------------- */
body,
button,
input,
select,
textarea { font-family: "Lato", sans-serif; color: #777; font-size: 14px; line-height: 1.875; background-color: #fff; -webkit-font-smoothing: antialiased; overflow-x: hidden; overflow-y: auto; }
img { height: auto; max-width: 100%; vertical-align: middle; -ms-interpolation-mode: bicubic }
p { margin: 0 0 20px; }
strong,
b { font-weight: bold; }
dfn,
cite,
em,
i,
blockquote { font-style: italic; }
blockquote { border: 2px solid #233a5f; font-style: italic; padding: 35px 30px; }
blockquote:before,
blockquote:after,
q:before,
q:after { content: ""; }
blockquote > p:last-child { margin-bottom: 0; }
blockquote .small { display: inline-block; }
blockquote cite { }
blockquote em,
blockquote i { font-style: normal; }
abbr,
acronym { border-bottom: 1px dotted #d1d1d1; cursor: help; }
mark,
ins { text-decoration: none; }
sup,
sub { font-size: 75%; height: 0; line-height: 0; position: relative; vertical-align: baseline; }
sup { top: -6px; }
sub { bottom: -3px; }
small { font-size: 75%; }
big { font-size: 125%; }
address { font-style: italic; margin: 0 0 20px; }
code,
kbd,
tt,
var,
samp,
pre { font-family: Inconsolata, monospace; -webkit-hyphens: none; -moz-hyphens: none; hyphens: none; background: #f9f9f9; border: 1px solid #e1e1e1; border-radius: 0; height: auto; margin: 0 0 20px; overflow-x: auto; padding: 20px; }

/* Elements
-------------------------------------------------------------- */
html { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
*,
*:before,
*:after { -webkit-box-sizing: inherit; -moz-box-sizing: inherit; box-sizing: inherit; }
hr { background-color: #f6f6f6; border: 0; height: 1px; margin-bottom: 20px; }

/* Media */
embed,
iframe,
object,
video { margin-bottom: 20px; max-width: 100%; vertical-align: middle; }
p > embed,
p > iframe,
p > object,
p > video { margin-bottom: 0; }

/* Accessibility - Text meant only for screen readers */
.screen-reader-text { clip: rect(1px, 1px, 1px, 1px); position: absolute !important; height: 1px; width: 1px; overflow: hidden; }
.screen-reader-text:focus { background-color: #f1f1f1; border-radius: 3px; box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6); clip: auto !important; color: #21759b; display: block; height: auto; left: 5px; line-height: normal; padding: 15px 23px 14px; text-decoration: none; top: 5px; width: auto; z-index: 100000; }

/* Forms
 * -------------------------------------------------------------- *//* Remove chrome yellow autofill */
input:-webkit-autofill { -webkit-box-shadow: 0 0 0px 1000px #f7f7f7 inset }

/* Button */
button,
input[type="button"],
input[type="reset"],
input[type="submit"] { font-family: "Montserrat", sans-serif; font-weight: 500; background-color: #233a5f; color: #fff; padding: 1.285em 2.642em; border-radius: 3px; display: inline-block; -webkit-appearance: none; -webkit-transition: all ease .238s; -moz-transition: all ease .238s; transition: all ease .238s; }

/* Button hover + focus */
button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover,
button:focus,
input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus { outline: 0; background-color: #1c2e4d; color: #fff; }

/* Placeholder color */
::-webkit-input-placeholder { color: #c1c1c1; }
:-moz-placeholder { color: #c1c1c1; }
::-moz-placeholder { color: #c1c1c1; opacity: 1; /* Since FF19 lowers the opacity of the placeholder by default */ }
:-ms-input-placeholder { color: #c1c1c1; }

/* Links */
a { color: #233a5f; outline: 0; text-decoration: none; -webkit-transition: all ease .238s; -moz-transition: all ease .238s; transition: all ease .238s; }

a:hover,
a:focus,
a:active { outline: 0; color: #1c2e4d; text-decoration: none }

/* Typography
-------------------------------------------------------------- */
h1,
h2,
h3,
h4,
h5,
h6 { font-family: "Montserrat", sans-serif; color: #252525; line-height: 1.5; margin: 0 0 10px; font-weight: 500; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; }

h1 { font-size: 2.428em; } /* 34px */
h2 { font-size: 2.142em; } /* 30px */
h3 { font-size: 1.857em; } /* 26px */
h4 { font-size: 1.571em; } /* 22px */
h5 { font-size: 1.285em; } /* 18px */
h6 { font-size: 1.142em; } /* 16px */

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a { color: inherit }

h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
h5 a:hover,
h6 a:hover { text-decoration: none }

.text-accent-color { color: #233a5f !important; }
.text-white { color: #fff !important; }
.text-grey { color: #aeaeae !important; }
.text-heading-color { color: #252525 !important; }
.text-shadow { text-shadow: 1px 1px 3px rgba(0,0,0,.3); }

.text-muted { color: #aaa !important; }
.text-primary { color: #233a5f !important; }
.text-success { color: #51a351 !important; }
.text-info { color: #56b5ce !important; }
.text-warning { color: #dfa048 !important; }
.text-danger { color: #cb4d49 !important; }

p.dropcap-contrast span.first-letter { font-size: 24px; float: left; color: white; background-color: #233a5f; text-align: center; vertical-align: middle; margin: 5px 10px 0 0; line-height: 60px; width: 60px; height: 60px; -webkit-border-radius: 50%; -moz-border-radius: 50%; border-radius: 50%; }
p.dropcap span.first-letter { font-size: 55px; float: left; color: #233a5f; text-align: left; line-height: 45px; margin-right: 18px; width: 45px; height: 45px; }

.construction-icons > span { font-size: 40px; }

/* Extra classes
-------------------------------------------------------------- */
.line-height-normal { line-height: normal; }
.no-padding { padding: 0 !important; }
.no-margin { margin: 0 !important; }

.margin-bottom-0 { margin-bottom: 0px; }
.margin-bottom-5 { margin-bottom: 5px; }
.margin-bottom-10 { margin-bottom: 10px; }
.margin-bottom-15 { margin-bottom: 15px; }
.margin-bottom-20 { margin-bottom: 20px; }
.margin-bottom-25 { margin-bottom: 25px; }
.margin-bottom-30 { margin-bottom: 30px; }
.margin-bottom-35 { margin-bottom: 35px; }
.margin-bottom-40 { margin-bottom: 40px; }
.margin-bottom-45 { margin-bottom: 45px; }
.margin-bottom-50 { margin-bottom: 50px; }
.margin-bottom-55 { margin-bottom: 55px; }
.margin-bottom-60 { margin-bottom: 60px; }
.margin-bottom-65 { margin-bottom: 65px; }
.margin-bottom-70 { margin-bottom: 70px; }
.margin-bottom-75 { margin-bottom: 75px; }
.margin-bottom-80 { margin-bottom: 80px; }
.margin-bottom-85 { margin-bottom: 85px; }
.margin-bottom-90 { margin-bottom: 90px; }
.margin-bottom-95 { margin-bottom: 95px; }
.margin-bottom-100 { margin-bottom: 100px; }

.margin-top-0 { margin-top: 0px; }
.margin-top-5 { margin-top: 5px; }
.margin-top-10 { margin-top: 10px; }
.margin-top-15 { margin-top: 15px; }
.margin-top-20 { margin-top: 20px; }
.margin-top-25 { margin-top: 25px; }
.margin-top-30 { margin-top: 30px; }
.margin-top-35 { margin-top: 35px; }
.margin-top-40 { margin-top: 40px; }
.margin-top-45 { margin-top: 45px; }
.margin-top-50 { margin-top: 50px; }
.margin-top-55 { margin-top: 55px; }
.margin-top-60 { margin-top: 60px; }
.margin-top-65 { margin-top: 65px; }
.margin-top-70 { margin-top: 70px; }
.margin-top-75 { margin-top: 75px; }
.margin-top-80 { margin-top: 80px; }
.margin-top-85 { margin-top: 85px; }
.margin-top-90 { margin-top: 90px; }
.margin-top-95 { margin-top: 95px; }
.margin-top-100 { margin-top: 100px; }

.font-weight-300 { font-weight: 300; }
.font-weight-400 { font-weight: 400; }
.font-weight-500 { font-weight: 500; }
.font-weight-600 { font-weight: 600; }
.font-weight-700 { font-weight: 700; }
.letter-spacing-1px { letter-spacing: 1px; }
.letter-spacing-2px { letter-spacing: 2px; }
.letter-spacing-3px { letter-spacing: 3px; }
.letter-spacing-4px { letter-spacing: 4px; }
.letter-spacing-5px { letter-spacing: 5px; }
.letter-spacing-6px { letter-spacing: 6px; }
.letter-spacing-7px { letter-spacing: 7px; }
.letter-spacing-8px { letter-spacing: 8px; }
.font-family-body { font-family: 'Lato', sans-serif !important; }
.font-family-heading { font-family: 'Montserrat', sans-serif !important; }
.font-size-13 { font-size: 13px; }
.font-size-14 { font-size: 14px; }
.font-size-15 { font-size: 15px; }
.font-size-16 { font-size: 16px; }
.font-size-17 { font-size: 17px; }
.font-size-18 { font-size: 18px; }
.font-size-19 { font-size: 19px; }
.font-size-20 { font-size: 20px; }
.font-size-21 { font-size: 21px; }
.font-size-22 { font-size: 22px; }
.font-size-23 { font-size: 23px; }
.font-size-24 { font-size: 24px; }
.font-size-25 { font-size: 25px; }
.font-size-26 { font-size: 26px; }
.font-size-27 { font-size: 27px; }
.font-size-28 { font-size: 28px; }
.font-size-29 { font-size: 29px; }
.font-size-30 { font-size: 30px; }
.font-size-35 { font-size: 35px; }
.font-size-40 { font-size: 40px; }
.font-size-45 { font-size: 45px; }
.font-size-50 { font-size: 50px; }
.font-size-55 { font-size: 55px; }
.font-size-60 { font-size: 60px; }
.font-size-65 { font-size: 65px; }
.font-size-70 { font-size: 70px; }
.font-size-75 { font-size: 75px; }
.font-size-80 { font-size: 80px; }
.font-size-85 { font-size: 85px; }
.font-size-90 { font-size: 90px; }
.font-size-95 { font-size: 95px; }
.font-size-100 { font-size: 100px; }

.parallax { width: 100%; background-position: 50% 0; }

/* Clearfix */
.clearfix { *zoom: 1; }
.clearfix:before,
.clearfix:after,
.wprt-container:before,
.wprt-container:after { clear: both; display: table; line-height: 0; content: ""; }
.clearfix:after,
.wprt-container:after { clear: both; }

/* Layout
-------------------------------------------------------------- */
.wprt-container { width: 1170px; margin: 0 auto; max-width: 90%; }
#page { background: #fff; }
#main-content { padding: 80px 0; }

/* Inner Content */
#inner-content,
#inner-sidebar { position: relative; z-index: 1; }
#inner-content:after,
#inner-sidebar:after { content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 100%; border-style: solid; border-width: 0; z-index: -1; }

/* No Sidebar */
.no-sidebar #site-content { width: 100% !important; max-width: none !important; float: none !important; }

/* Hero Background SlideShow
-------------------------------------------------------------- */
#hero-section {
    position: relative;
}
#hero-section .hero-content {
    position: relative;
    padding-top: 0px;
    text-align: center;
}
#hero-section .hero-title {
    overflow: hidden;
    height: 50px;
    vertical-align: baseline;
}
#hero-section .hero-title h1 {
    font-size: 52px;
    color: #fff;
    height: 50px;
    line-height: 50px;
    margin: 0;
    text-shadow: 1px 1px 3px rgba(0,0,0,.3);
    -webkit-transition: margin-top 0.5s ease-in-out;
       -moz-transition: margin-top 0.5s ease-in-out;
            transition: margin-top 0.5s ease-in-out;
}
#hero-section .links { margin-top: 57px; }
#hero-section .links .link {
    padding: 17px 30px 17px 50px;
    font-family: "Montserrat", sans-serif;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: #fff;
    position: relative;
    text-shadow: 1px 1px 3px rgba(0,0,0,.3);
}
#hero-section .links .link:after {
    content: "\f18e";
    font-family: "FontAwesome";
    font-size: 20px;
    position: absolute;
    right: 0;
    top: 50%;
    line-height: normal;
    -webkit-transform: translate3d(0,-50%,0); -moz-transform: translate3d(0,-50%,0); transform: translate3d(0,-50%,0);
}
#hero-section .links .link:hover,
#hero-section .links .link:hover:after {
    color: #233a5f;
}
#hero-section .arrow {
    position: absolute;
    bottom: 35px;
    left: 50%;
    margin-left: -25px;
    width: 50px;
    height: 50px;
    z-index: 999;
}
#hero-section .arrow:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 50px;
    height: 50px;
    background: url(assets/img/arrow.png) no-repeat center center;
    -webkit-animation: rotate 3s infinite linear;
       -moz-animation: rotate 3s infinite linear;
         -o-animation: rotate 3s infinite linear;
            animation: rotate 3s infinite linear;
}
#hero-section .arrow:after {
    content: "\f107";
    font-family: "FontAwesome";
    font-size: 22px;
    color: #fff;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 50px;
    line-height: 50px;
    text-align: center;
}
#hero-section .arrow:hover:after {
    color: #233a5f;
}
@-webkit-keyframes rotate {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(-360deg);
        transform: rotate(-360deg);
    }
}
@keyframes rotate {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(-360deg);
        transform: rotate(-360deg);
    }
}

/* Top Bar
-------------------------------------------------------------- */
#top-bar { font-size: 0.857em; position: relative; z-index: 1; }
#top-bar:after { content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 100%; background-color: #252525; z-index: -1; }
#top-bar,
#top-bar a { color: #fff; }
#top-bar a:hover { text-decoration: underline; }
#top-bar-inner { padding-top: 13px; padding-bottom: 13px; }
#top-bar .top-bar-inner-wrap { display: table; overflow: hidden; width: 100%; }
#top-bar .top-bar-content { display: table-cell; margin: 0; text-align: left; vertical-align: middle; width: 75%;}
#top-bar .top-bar-socials { display: table-cell; text-align: right; vertical-align: middle; width: 25%;}
#top-bar .top-bar-socials .texts { padding-right: 5px; }

/* Header
-------------------------------------------------------------- */
#site-header { position: relative; background-color: #f2f2f2; }
#site-header-inner { position: relative; padding-top: 30px; padding-bottom: 30px; height: 100%; }
#site-logo { float: left; }
#site-logo .site-logo-text { color: #000000; font-size: 22px; line-height: 34px; font-weight: 700; }
#site-logo .site-logo-text:hover { color: #233a5f; }

/* Header Styles */
#site-header.style-1 #main-nav .menu-fallback,
#site-header.style-5 #main-nav .menu-fallback { padding-right: 24px; }
#site-header.style-1 #main-nav,
#site-header.style-5 #main-nav { position: absolute; right: -3px; top: 50%; z-index: 10; -webkit-transform: translateY(-50%); -moz-transform: translateY(-50%); transform: translateY(-50%); }
#site-header.style-1 #main-nav > ul > li > a,
#site-header.style-5 #main-nav > ul > li > a { height: 50px; line-height: 50px; }
#site-header.style-2 #site-header-inner { padding-top: 38px; padding-bottom: 44px; }
#site-header.style-2 #site-logo,
#site-header.style-3 #site-logo { margin-top: 2px; }
#site-header.style-2 .site-navigation-wrap,
#site-header.style-4 .site-navigation-wrap { border-style: solid; }
#site-header.style-2 .site-navigation-wrap { background-color: #000000; }
#site-header.style-2 .site-navigation-wrap .inner { position: relative; }
/* Header Search */
#site-header #header-search { position: absolute; right: 15px; top: 50%; z-index: 10; -webkit-transform: translateY(-50%); -moz-transform: translateY(-50%); transform: translateY(-50%); }
#site-header .header-search-form { position: absolute; right: 30px; top: -6px; width: 290px; display: none; }
#site-header .header-search-field { margin: 0; padding-top: 5px; padding-bottom: 5px; background-color: #fff; }
#site-header .header-search-submit { position: absolute; right: 0; top: 0; filter: alpha(opacity=0); opacity: 0; visibility: hidden; display: none; }
#site-header .header-search-form.show { filter: alpha(opacity=100); opacity: 1; visibility: visible; }
#site-header .header-search-form header-search-field { width: 273px; height: 43px; }
/* Navigation */
#main-nav .menu-fallback { position: relative; color: #000000; text-decoration: underline; display: inline-block; height: 50px; line-height: 50px; }
#main-nav { display: block; }
#main-nav ul { margin: 0; }
#main-nav ul li { position: relative; list-style: none; padding-top: 0; padding-bottom: 0; }
#main-nav > ul > li { float: left; padding: 0 18px; }
#main-nav > ul > li:first-child { padding-left: 0; }
#main-nav > ul > li > a { display: block; font-family: "Montserrat", sans-serif; font-size: 13px; font-weight: 500; color: #f5f5f5; text-transform: uppercase; }
#main-nav > ul > li > a:hover { color: #233a5f; }
#main-nav > ul > li.current-menu-item > a { position: relative; }
#main-nav > ul > li.current-menu-item > a:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 11px;
    width: 100%;
    height: 2px;
    background-color: #233a5f;
}
/* Header sticky */
#site-header.is-sticky {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 999999;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
#site-header.is-sticky:after { opacity: 0.8; }

/* Mobile Navigation */
#main-nav-mobi { display: block; margin: 0 auto; width: 100%; position: absolute; left: 0; top: 100%; z-index: 99999; background-color: #262626; }
#main-nav-mobi ul { display: block; list-style: none; margin: 0; padding: 0; }
#main-nav-mobi ul li { margin:0; position: relative; text-align: center; cursor: pointer; border-top: 1px solid #333; padding-top: 0; padding-bottom: 0; }
#main-nav-mobi ul > li > a { color: #ffffff; display: inline-block; font-family: "Montserrat", sans-serif; font-size: 14px; text-transform: uppercase; line-height: 50px; text-decoration: none; }
#main-nav-mobi ul > li > a:hover { color: #233a5f; }
#main-nav-mobi .menu-item-has-children .arrow { cursor: pointer; display: inline-block; font-family: "FontAwesome"; font-size: 20px; line-height: 50px; position: absolute; right: 0; text-align: center; top: 0; width: 50px; }
#main-nav-mobi .menu-item-has-children .arrow:before { content: "\f105"; color: #aaa; }
#main-nav-mobi .menu-item-has-children .arrow.active:before { content: "\f107"; }
#main-nav-mobi ul ul li { background-color: #292929; }
#main-nav-mobi ul ul ul li { background-color: #323232; }

/* Mobile Menu Button */
.mobile-button { display: none; float: right; position: relative; background: transparent; cursor: pointer; margin-top: 8px; width: 26px; height: 16px; -webkit-transition: all ease .238s; -moz-transition: all ease .238s; transition: all ease .238s; }
.mobile-button:before,
.mobile-button:after,
.mobile-button span { background-color: #FFFFFF; -webkit-transition: all ease .238s; -moz-transition: all ease .238s; transition: all ease .238s; }
.mobile-button:before,
.mobile-button:after { content: ''; position: absolute; top: 0; height: 3px; width: 100%; left: 0; top: 50%; -webkit-transform-origin: 50% 50%; -ms-transform-origin: 50% 50%; transform-origin: 50% 50%; }
.mobile-button span { position: absolute; width: 100%; height: 3px; left: 0; top: 50%; overflow: hidden; text-indent: 200%; }
.mobile-button:before { -webkit-transform: translate3d(0,-7px,0); -moz-transform: translate3d(0,-7px,0); transform: translate3d(0,-7px,0); }
.mobile-button:after { -webkit-transform: translate3d(0,7px,0); -moz-transform: translate3d(0,7px,0); transform: translate3d(0,7px,0); }
.mobile-button.active span { opacity: 0; }
.mobile-button.active:before { -webkit-transform: rotate3d(0, 0, 1, 45deg); -moz-transform: rotate3d(0, 0, 1, 45deg); transform: rotate3d(0, 0, 1, 45deg); }
.mobile-button.active:after { -webkit-transform: rotate3d(0, 0, 1, -45deg); -moz-transform: rotate3d(0, 0, 1, -45deg); transform: rotate3d(0, 0, 1, -45deg); }

/* Featured Title
-------------------------------------------------------------- */
#featured-title { background: #f7f7f7; border-style: solid; border-width: 1px 0; border-color: #f1f1f1; }
#featured-title .featured-title-inner-wrap { padding: 52px 0; display: table; overflow: hidden; width: 100%; }
#featured-title .featured-title-heading-wrap { display: table-cell; margin: 0; text-align: left; vertical-align: middle; width: 65%;}
#featured-title #breadcrumbs { font-size: 0.928em; display: table-cell; text-align: right; vertical-align: middle; width: 35%;}
#featured-title .featured-title-heading { color: #777; z-index: 1; position: relative; display: inline-block; font-size: 30px; margin: 0; }
#featured-title .featured-title-heading.has-shadow { text-shadow: rgba(0, 0, 0, 0.3) 0px 1px 1px }
#featured-title .featured-title-heading:after,
#featured-title #breadcrumbs .breadcrumbs-inner:after { content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 100%; z-index: -1; border-style: solid; border-width: 0px; }
#featured-title #breadcrumbs .breadcrumbs-inner { z-index: 1; position: relative; display: inline-block; }
#featured-title #breadcrumbs a { color: #233a5f; }
#featured-title #breadcrumbs a:hover { color: #252525; }
#featured-title #breadcrumbs .sep { padding: 0 4px; }
/* Featured Title other styles */
#featured-title.featured-title-right .featured-title-heading-wrap { text-align: right; }
#featured-title.featured-title-right #breadcrumbs { text-align: left; }
#featured-title.featured-title-centered1 .featured-title-inner-wrap,
#featured-title.featured-title-centered2 .featured-title-inner-wrap { display: block; }
#featured-title.featured-title-centered1 .featured-title-heading-wrap,
#featured-title.featured-title-centered2 .featured-title-heading-wrap { display: block; width: 100%; text-align: center; }
#featured-title.featured-title-centered1 #breadcrumbs { display: block; width: 100%; text-align: center; margin-top: 5px; }
#featured-title.featured-title-centered2 #breadcrumbs { display: block; width: 100%; text-align: center; margin-bottom: 5px;}
#featured-title.featured-title-centered2 .featured-title-heading-wrap { margin-top: 5px; }
#featured-title.featured-title-centered1 .featured-title-heading-wrap { margin-bottom: 5px;}
.header-style-3 #featured-title .featured-title-inner-wrap { padding-top: 82px; padding-bottom: 58px; }
.header-style-5 #featured-title .featured-title-inner-wrap { padding-top: 250px; padding-bottom: 30px; }

/* Override for Front-Page and One-Page
-------------------------------------------------------------- */
.one-page #site-header-inner { padding-top: 15px; padding-bottom: 15px; }
.front-page #main-content { padding: 0; }

/* Post media */
.post-media { margin-bottom: 25px; position: relative; }
.hentry .post-media img { width: 100%; height: auto; }
.hentry .post-media iframe { margin-bottom: 0; }

/* Post title */
.hentry .post-title { font-size: 1.785em; margin-bottom: 20px; }
.hentry .post-title-inner { z-index: 1; position: relative; display: inline-block; }
.hentry .post-title-inner:before { content: ""; position: absolute; left: 0; top: 0; z-index: -1; width: 100%; height: 100%; border: 1px solid transparent; }
.hentry .post-title-inner:after { content: ""; position: absolute; left: 0; top: 100%; width: 0; height: 0; background-color: transparent; }
.hentry .post-title a:hover { color: #233a5f; }

/* Post meta */
.hentry .post-meta { padding: 7px 12px; background-color: #f7f7f7; border: 1px solid #f1f1f1; color: #777; font-size: 0.857em; margin-bottom: 22px; }
.hentry .post-meta a { color: #252525; }
.hentry .post-meta a:hover { color: #233a5f; }
.hentry .post-meta .item { display: inline-block; margin-left: 18px; border: 1px solid transparent; }
.hentry .post-meta .item:first-child { margin-left: 0; }
.hentry .post-meta .item .inner { position: relative; padding-left: 20px; }
.hentry .post-meta .item .inner:before { content: ""; font-family: "FontAwesome"; font-size: 13px; position: absolute; left: 0; top: 50%; -webkit-transform: translate3d(0,-50%,0); -moz-transform: translate3d(0,-50%,0); transform: translate3d(0,-50%,0); }
.hentry .post-meta .item.post-by-author .inner:before { content: "\f017"; }
.hentry .post-meta .item.post-date .inner:before { content: "\f007"; }
.hentry .post-meta .item.post-comment .inner:before { content: "\f27a"; }
.hentry .post-meta .item.post-meta-categories .inner:before { content: "\f02b"; }
.hentry .post-meta .post-categories { color: #233a5f; }
.hentry .post-meta .post-categories span,
.hentry .post-meta .post-categories:before { color: #777; }

/* Title Widget */
#sidebar .widget .widget-title,
#footer-widgets .widget .widget-title { font-size: 1.428em; margin-bottom: 25px; z-index: 1; position: relative; }
#sidebar .widget .widget-title > span,
#footer-widgets .widget .widget-title > span { display: block; position: relative; }
#sidebar .widget .widget-title > span:before,
#footer-widgets .widget .widget-title > span:before { background-color: transparent; border: 1px solid transparent; content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 100%; z-index: -1; }
#sidebar.style-1 .widget .widget-title > span:after,
#sidebar.style-2 .widget .widget-title > span:after,
#footer-widgets.style-1 .widget .widget-title > span:after,
#footer-widgets.style-2 .widget .widget-title > span:after { width: 0; height: 1px; background-color: #585252; content: ""; position: absolute; left: 0; top: 100%; z-index: -2; }

/* Widget Socials */
#sidebar .widget.widget_socials .socials a,
#footer-widgets .widget.widget_socials .socials a { position: relative; display: inline-block; width: 35px; height: 35px; color: #777; line-height: 35px; text-align: center; margin-right: 6px; margin-bottom: 6px; z-index: 1; }
#sidebar .widget.widget_socials .socials a:before,
#footer-widgets .widget.widget_socials .socials a:before { content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 100%; z-index: -1; border: 1px solid #eaeaea; background-color: transparent; -webkit-border-radius: 50%; -moz-border-radius: 50%; border-radius: 50%; -webkit-transition: all ease .238s; -moz-transition: all ease .238s; transition: all ease .238s; }
#sidebar .widget.widget_socials .socials a:hover:before,
#footer-widgets .widget.widget_socials .socials a:hover:before { background-color: #233a5f; border-color: #233a5f; }
#sidebar .widget.widget_socials .socials a:hover,
#footer-widgets .widget.widget_socials .socials a:hover { color: #fff; }

/* Categories & Archive Widget */
.widget.widget_categories ul li:before,
.widget.widget_categories ul li:after,
.widget.widget_archive ul li:before,
.widget.widget_archive ul li:after { content: ""; clear: both; display: table; }
.widget.widget_categories ul li,
.widget.widget_archive ul li { position: relative; text-align: right; }
.widget.widget_categories ul li a,
.widget.widget_archive ul li a { float: left; }

/* Instagram & Flickr widget */
.widget.widget_instagram .instagram-wrap,
.widget.widget_flickr .flickr-wrap { margin: 0 -0.5px; }
.widget.widget_instagram .instagram-wrap .instagram_badge_image,
.widget.widget_flickr .flickr-wrap .flickr_badge_image { padding: 0 0.5px !important; margin: 0 0 1px 0 !important; width: 33.333%; float: left; height: auto !important; }
.widget.widget_instagram .instagram-wrap .instagram_badge_image img,
.widget.widget_flickr .flickr-wrap .flickr_badge_image img { width: 100%; height: auto; }
.widget.widget_instagram .instagram-wrap .instagram_badge_image a,
.widget.widget_flickr .flickr-wrap .flickr_badge_image a { position: relative; display: block; }
.widget.widget_instagram .instagram-wrap .instagram_badge_image a:after,
.widget.widget_flickr .flickr-wrap .flickr_badge_image a:after { content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 100%; background-color: transparent; -webkit-transition: all ease .238s; -moz-transition: all ease .238s; transition: all ease .238s; }
.widget.widget_instagram .instagram-wrap .instagram_badge_image a:hover:after,
.widget.widget_flickr .flickr-wrap .flickr_badge_image a:hover:after { background: #233a5f url(assets/img/icon-plus.png) no-repeat center center; }

/* Footer
-------------------------------------------------------------- */
#footer { background-color: #1a1a1a; padding: 80px 0 70px; position: relative; z-index: 1; border-style: solid; }
.one-page #footer-widgets .widget.widget_socials .socials a {
    position: relative;
    display: inline-block;
    width: 60px;
    height: 60px;
    font-size: 20px;
    line-height: 60px;
    text-align: center;
    color: #979797;
    margin: 0 15px 15px;
    z-index: 1;
}
.one-page #footer-widgets .widget.widget_socials .socials a:before {
    content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 100%; z-index: -1;
    border: 2px solid #474747; background-color: transparent;
    -webkit-border-radius: 50%; -moz-border-radius: 50%; border-radius: 50%;
    -webkit-transition: all ease .238s; -moz-transition: all ease .238s; transition: all ease .238s; }
.one-page #footer-widgets .widget_socials .socials a:hover:before {
    color: #233a5f;
    border-color: #233a5f;
}

/* Bottom Bar
-------------------------------------------------------------- */
#bottom { font-size: 0.857em; background-color: #101010; padding: 19px 0; color: #484848; font-family: "Montserrat", sans-serif; }
#bottom a:hover { color: #fff; }
#bottom .bottom-bar-inner-wrap { display: table; overflow: hidden; width: 100%; }
#bottom .bottom-bar-content { display: table-cell; margin: 0; text-align: left; vertical-align: middle; width: 50%;}
#bottom .bottom-bar-menu { display: table-cell; text-align: right; vertical-align: middle; width: 50%;}
#bottom.style-1 .bottom-bar-menu li:last-child a { padding-right: 0; }
/* Bottom Style 2 */
#bottom.style-2 .bottom-bar-content { text-align: right; }
#bottom.style-2 .bottom-bar-menu { text-align: left; }
#bottom.style-2 .bottom-bar-menu li:first-child a { padding-left: 0; }
/* Bottom Style 3 */
#bottom.style-3 .bottom-bar-inner-wrap,
#bottom.style-3 .bottom-bar-menu,
#bottom.style-3 .bottom-bar-content { display: block; width: 100%; text-align: center; }

/* Bottom Navigation */
#bottom ul.bottom-nav { list-style: none; margin: 0; }
#bottom ul.bottom-nav > li { display: inline-block; }
#bottom ul.bottom-nav > li > a { display: block; color: #484848; padding: 0 10px; position: relative; }
#bottom ul.bottom-nav > li > a:hover { color: #233a5f; }
#bottom ul.bottom-nav ul ul { display: none; }

/* Scroll Top
-------------------------------------------------------------- */
#scroll-top {
    position: fixed !important;
    right: 25px;
    bottom: 0;
    background-color: #233a5f;
    color: #fff;
    font-family: "Montserrat", sans-serif;
    display: block;
    font-size: 11px;
    width: 40px;
    height: 40px;
    line-height: 40px;
    text-align: center;
    filter: alpha(opacity=0);
    opacity: 0;
    visibility: hidden;
    z-index: 9999;
    cursor: pointer;
    -webkit-border-radius: 3px;
       -moz-border-radius: 3px;
            border-radius: 3px;
}
#scroll-top:hover {
    background-color: #1c2e4d;
    color: #fff;
}
#scroll-top.show {
    filter: alpha(opacity=100);
    opacity: 1;
    visibility: visible;
    bottom: 45px;
}

/* Media Queries
-------------------------------------------------------------- */
@media only screen and (min-width: 1930px) {
    .parallax {
        background-size: cover;
    }
}
@media only screen and (max-width: 1340px) {
    .wprt-partners .owl-theme .owl-controls .owl-buttons div { display: none; }
}
@media only screen and (min-width: 1200px) {
    .container {
        width: 1200px;
    }
}
@media only screen and (max-width: 991px) {
    h1 { font-size: 1.857em; } /* 26px */
    h2 { font-size: 1.571em; } /* 22px */
    h3 { font-size: 1.428em; } /* 20px */
    .font-size-25 { font-size: 18px; }
    .font-size-30 { font-size: 20px; }
    .font-size-35 { font-size: 26px; }
    .font-size-40 { font-size: 28px; }
    .font-size-45 { font-size: 30px; }
    .font-size-50 { font-size: 26px; }
    .font-size-55 { font-size: 30px; }
    .font-size-60 { font-size: 35px; }
    .font-size-70 { font-size: 40px; }
    .font-size-80 { font-size: 45px; }
    .font-size-90 { font-size: 50px; }
    .font-size-100 { font-size: 55px; }
    #hero-section .links .link  { display: none; }
    #hero-section .links { margin-top: 30px; }
    #site-header .mobile-button { display: block; }
    .text-left-mobile { text-align: left !important; }
    .text-center-mobile { text-align: center !important; }
    #main-nav,
    #site-header #header-search,
    .nav-top-cart-wrapper,
    .site-navigation-wrap,
    #header-aside,
    #sidebar { display: none; }
    #site-content,
    #sidebar { width: 100% !important; max-width: none !important; float: none; }
    #inner-content { padding-left: 0 !important; padding-right: 0 !important; }
    #main-content { padding: 40px 0; }
    #site-header #site-header-inner,
    #site-header.style-2 #site-header-inner,
    #site-header.style-3 #site-header-inner,
    #site-header.style-4 #site-header-inner { padding-top: 15px; padding-bottom: 15px; }
    #site-header.style-2 #site-logo { margin-top: 0; }
    #site-header.style-4 #site-logo { text-align: left; float: left; }
    .hentry { margin-top: 40px; }
    .hentry .post-title { font-size: 1.428em; }
    .hentry .post-link a { padding: 0.425em 1.75em; font-size: 0.928em; }
    .comment-respond #comment-reply { padding: 1.08em 1.75em; font-size: 0.928em; }
    #footer-widgets .widget .widget-title { font-size: 1.142em; margin-bottom: 28px; }
    .one-page #footer-widgets .widget.widget_socials .socials a { margin: 0 6px 6px; width: 45px; height: 45px; line-height: 45px; font-size: 16px;}
}
@media only screen and (max-width: 767px) {
    #top-bar .top-bar-inner-wrap,
    #top-bar .top-bar-content,
    #top-bar .top-bar-socials { display: block; width: 100%; text-align: center; }
    #top-bar .top-bar-content { display: none; }
    #featured-title .featured-title-inner-wrap { padding: 30px 0; }
    #featured-title .featured-title-heading { font-size: 24px; }
    #hero-section .links { margin-top: 10px; }
    .hentry .post-author { text-align: center; }
    .hentry .post-author .author-avatar { float: none; margin: 0 auto 20px; }
    .hentry .post-read-more, .hentry .post-link, .hentry .post-link-share { display: block; width: 100%; float: none; text-align: left; }
    .hentry .post-link { margin-bottom: 10px; }
    .hentry .post-link-share { margin-top: 20px; }
    .wprt-pagination { margin-top: 30px; }
    .comments-area { margin-top: 40px; }
    .comment-respond { margin-top: 0; }
    .comments-area .comments-title, .comments-area .comment-reply-title { margin-bottom: 20px; }
    .comment-list article .gravatar { width: 50px; float: none; margin: 0 0 17px; }
    .comment-list .children > li { padding-left: 35px; }
    .name-wrap, .email-wrap { width: 100%; float: none; }
    .name-wrap input, .email-wrap input, .message-wrap textarea { margin-bottom: 20px; }
    .woocommerce-page .content-woocommerce .woocommerce-result-count { display: none; }
    .woocommerce-page .content-woocommerce .products { padding-top: 20px; }
    .woocommerce-page.shop-col-3 .content-woocommerce .products li,
    .woocommerce-page.shop-col-4 .content-woocommerce .products li,
    .woocommerce-page.shop-col-5 .content-woocommerce .products li { width: 100%; margin-bottom: 30px; }
    .woocommerce-page .shop_table.cart .product-remove { width: 20px; }
    .woocommerce-page .shop_table.cart .product-thumbnail { width: 50px; }
    .woocommerce-page .shop_table.cart .cart_item .product-thumbnail img { width: 30px; }
    .woocommerce-page .shop_table.cart .product-name { width: 120px; }
    .woocommerce-page .shop_table.cart .coupon { display: none; }
    .woocommerce-page .cart_totals { width: 100%; float: none; }
    .woocommerce-page .cart_totals .wc-proceed-to-checkout a { padding: 7px 0; }
    .wprt-contact-form .left-side { float: none; width: 100%; }
    .wprt-contact-form .message-wrap { position: relative; width: 100%; }
    .wprt-contact-form .message-wrap textarea { height: 150px; margin-bottom: 10px; }
    .wprt-contact-form .input-wrap input { margin-bottom: 10px; }
    #footer { padding: 50px 0 20px; }
    #footer-widgets [class^="col-md-"] .widget:last-child { margin-bottom: 30px; }
    #bottom .bottom-bar-content,
    #bottom .bottom-bar-menu { width: 100%; display: block; text-align: center; padding: 5px 0; }
}
@media only screen and (max-width: 479px) {
    #top-bar { display: none; }
}

/* Retina Devices
-------------------------------------------------------------- */
@media 
only screen and (-webkit-min-device-pixel-ratio: 2),
only screen and (   min--moz-device-pixel-ratio: 2),
only screen and (   -moz-min-device-pixel-ratio: 2),
only screen and (     -o-min-device-pixel-ratio: 2/1),
only screen and (        min-device-pixel-ratio: 2),
only screen and (                min-resolution: 192dpi),
only screen and (                min-resolution: 2dppx){
    #hero-section .arrow:before {
        background: url(assets/img/arrow%402x.png) no-repeat center center;
        background-size: 50px 50px;
    }
    .wprt-testimonials .customer:after {
        background: url(assets/img/5-stars%402x.png) no-repeat center center ;
        background-size: 97px 15px;
    }
    .wprt-partners .owl-theme .owl-controls .owl-buttons div {
        background: url(assets/img/prev%402x.png) no-repeat center center;
        background-size: 10px 24px;
    }
    .wprt-partners .owl-theme .owl-controls .owl-buttons div.owl-next {
        background: url(assets/img/next%402x.png) no-repeat center center;
        background-size: 10px 24px;
    }
}

#site-logo img {
    height: 70px;
    width: auto;
}

#site-logo {
    display: flex;
    align-items: center;
}

#site-header-wrap {
    background-color: #f2f2f2;
    border-bottom: 1px solid #e0e0e0;
}

#site-header-wrap,
#site-header,
#site-header-inner {
    background-color: #9b9b9b !important;
}

#site-header-wrap {
    background: #f2f2f2 !important;
}

#site-header {
    background: #000000 !important;
}

#site-header-inner {
    background: #000000 !important;
}

#site-header.style-1:after {
    display: none !important;
}

#site-header-inner.container {
    max-width: 1200px;
    margin: 0 auto;
}

#site-header-wrap {
    background-color: #f2f2f2;
    border-bottom: 1px solid #e6e6e6;
}

/* 1. SECTION HEADER LINES */
.wprt-lines.style-2 .line-1 {
    background-color: #233a5f !important;
}

/* 2. IMAGE/PORTFOLIO HOVER OVERLAY */
.cbp-caption-activeWrap {
    background-color: rgba(35, 58, 95, 0.8) !important;
}

/* 3. ICON BOXES & WHAT WE OFFER (The Hover Effect) */
/* Default state: Icons are dark */
.wprt-icon-box .icon-wrap i, 
.service-item .icon-wrap i,
.wprt-icon-box .icon-wrap:before {
    color: #333 !important; 
    transition: all 0.3s ease;
}

/* Hover state: Icon turns accent color */
.wprt-icon-box:hover .icon-wrap,
.service-item:hover .icon-wrap {
    background-color: transparent !important;
    background: none !important;
    border-color: #233a5f !important;
}

.wprt-icon-box:hover .icon-wrap i,
.service-item:hover .icon-wrap i,
.wprt-icon-box:hover .icon-wrap:before {
    color: #233a5f !important;
    background-color: transparent !important;
}

/* 4. FAQ / TOGGLES (Accent only when Active) */
.wprt-toggles .toggle-title a,
.wprt-toggles .toggle-title:before {
    color: #333;
}

.wprt-toggles .toggle-title.active,
.wprt-toggles .toggle-title.active a,
.wprt-toggles .toggle-title.active:before,
.wprt-toggles .toggle-title.active .toggle-icon i {
    color: #233a5f !important;
    background-color: transparent !important;
}

.wprt-toggles .toggle-title.active:after {
    background-color: #233a5f !important;
}

/* WHAT WE OFFER - 2x3 Grid Improvements */
.wprt-icon-text {
    padding: 20px 15px;
    margin-bottom: 30px;
    transition: all 0.3s ease;
}

.wprt-icon-text .icon {
    font-size: 48px;
    margin-bottom: 15px;
    color: #233a5f;
}

.wprt-icon-text h3 {
    font-size: 15px !important;     /* Smaller text to prevent wrapping */
    font-weight: 600;
    margin: 0;
    line-height: 1.3;
    color: #252525;
}

/* Hover effect */
.wprt-icon-text:hover {
    transform: translateY(-5px);
}

.wprt-icon-text:hover .icon {
    color: #1c2e4d;
}

/* Responsive spacing */
@media (max-width: 991px) {
    .wprt-icon-text {
        margin-bottom: 25px;
    }
}

/* WHAT WE OFFER - Improved 2x3 + 2x2 Layout */
.wprt-icon-text {
    padding: 25px 15px;
    margin-bottom: 30px;
    transition: all 0.3s ease;
}

.wprt-icon-text .icon {
    font-size: 52px;
    margin-bottom: 18px;
    color: #233a5f;
}

.wprt-icon-text h3 {
    font-size: 15px !important;   /* Smaller to prevent wrapping */
    font-weight: 600;
    line-height: 1.3;
    margin: 0;
    color: #252525;
}

.wprt-icon-text:hover {
    transform: translateY(-6px);
}

.wprt-icon-text:hover .icon {
    color: #1c2e4d;
}

/* Bottom icon boxes spacing */
.wprt-icon-box {
    margin-bottom: 30px;
}

@media (max-width: 991px) {
    .wprt-icon-text {
        margin-bottom: 25px;
    }
    .wprt-icon-box {
        margin-bottom: 25px;
    }
}
#features .row.align-items-center {
    display: flex;
    align-items: center;
}

#features img {
    max-height: 500px;
    object-fit: contain;
}