/*** General CSS ***/
body {
    line-height: 1.9em;
    color: #333;
}
a:hover, a:focus, a:active {
    color: #000;
}

/*** Header Area ***/
/* Header Top */
#sp-top-bar {
    position: relative;
    z-index: 9999;
    box-shadow: 0 0 4px 0 rgb(0 0 0 / 10%);
  	color: #fff;
}
#sp-top-bar a {
  	color: #fff;
}

/* Header Menu */
#sp-header {
    top: 0px;
  	padding: 0px;
    height: inherit;
    background: #fff;
  	box-shadow: none;
}
#sp-header.header-sticky {
    position: fixed;
    top: 0;
  	background: #fff;
  	box-shadow: 0 0 4px 0 rgb(0 0 0 / 10%);
}
body:not(.home) #sp-header {
    background: #fff;
    position: static;
}
body:not(.home) #sp-header.header-sticky {
    position: fixed;    
}
.sp-megamenu-parent .sp-dropdown li.sp-menu-item>a {
    color: #252525;
  	font-size: 14px !important;
    font-weight: 400 !important;
    padding: 10px 0;
}
.sp-megamenu-parent > li > a, .sp-megamenu-parent > li > span {
    text-transform: uppercase;
    position: relative;
    color: #000;
}
.sp-megamenu-parent>li.active>a {
    font-weight: 600;
}

/* Canvas Menu */
.offcanvas-menu .offcanvas-inner .menu-child > li a {
    padding: 12px 10px !important;
    border-bottom: 1px solid rgba(197, 153, 153, 0.21);
    display: inherit;
}
.offcanvas-menu .offcanvas-inner ul.menu>li>a, .offcanvas-menu .offcanvas-inner ul.menu>li>span {
    font-size: 15px;
    font-weight: 500;
}
.burger-icon>span {
    background-color: #000;
}
.offcanvas-menu > .align-items-center {
    background: #fff;
}
.offcanvas-active .burger-icon>span, #modal-menu-toggler.active .burger-icon>span {
    background-color: #000;
}

/*** Block Styles ***/
/* Title */
.title {
	margin-bottom: 45px;
    position: relative;
}
.title.center {
	text-align: center;
}
.title h3::after {
    border: 1px solid #80c32f;
    bottom: -27px;
    content: "";
    left: 0;
    margin: 0 auto;
    position: absolute;
    width: 60px;
    right: 0;
}
.title h4 {
    color: #000;
	position: relative;
    font-weight: 700;
    display: inline;
}
.title h3 {
    display: inline-block;
    font-size: 40px;
    font-weight: 400;
    text-transform: capitalize;
}
.title p {
	margin-top: 8px;
}
.title-top h3,
.title-white h3 {
    font-size: 27px;
    max-width: 800px;
    line-height: 36px;
    font-weight: 700;
    margin: 0 auto;
}
.title-top h3 {
    color: #444;
}
.title-top::after {
    border: 1px solid #80c32f;
    bottom: -27px;
    content: "";
    left: 0;
    margin: 0 auto;
    position: absolute;
    width: 60px;
    right: 0;
}

/* Slider */
a.slider-btn {
  	color: #fff !important;
  	font-size: 15px !important;
  	font-weight: 600 !important;
  	letter-spacing: 1px !important;
  	padding: 14px 45px !important;
  	border-radius: 3px !important;
  	border: 1px solid !important;
  	display: inline-block;
  	cursor: pointer;
  	text-transform: uppercase !important;
  	-moz-transition: ease all 0.55s;
  	-o-transition: ease all 0.55s;
  	-webkit-transition: ease all 0.55s;
  	transition: ease all 0.55s;
  	line-height: 50px;
  	position: relative;
}
a.slider-btn.right, a.slider-btn.left:hover {
  	background: #fff !important;
}
a.slider-btn.right {
  	margin-left: 40px !important;
}
a.slider-btn.right:hover {
  	color: #fff !important;
}

/* bg */
.bg-color,.bg-color-2 {
    position: relative;
    overflow: hidden;
    background: #fff;
    z-index: 1;
}
.bg-color-2::after {
    position: absolute;
    left: 0px;
    top: 0px;
    width: 35.50%;
    height: 100%;
    content: "";
    background: rgba(232,234,237,0.30) none repeat scroll 0 0;
    z-index: -1;
}
.bg-color::after {
    position: absolute;
    right: 0px;
    top: 0px;
    width: 35.50%;
    height: 100%;
    content: "";
    background: rgba(232,234,237,0.30) none repeat scroll 0 0;
    z-index: -1;
}

/* Button */
a.sppb-btn-custom {
    border: 1px solid #80c32f;
    color: #fff;
    cursor: pointer;
    display: inline-block;
    font-size: 14px;
    font-weight: 700;
    padding: 15px 50px;
    text-align: center;
    text-transform: uppercase;
    transition: all 0.4s ease 0s;
    z-index: 222;
    background: #80c32f;
    border-radius: 3px;
}
a.sppb-btn-custom:hover {
    color: #fff;
    background: #80c32f;
    border: 1px solid #80c32f;
    text-decoration: none;
}

/* Service */
#service {
    position: relative;
    padding-bottom: 90px;
}
.service-sub {
    box-shadow: 0 5px 25px rgba(0, 0, 0, 0.1);
    z-index: 1;
    background: #fff;
    overflow: hidden;
    position: relative;
    text-align: center;
}
.service-sub strong {
    display: none;
} 
.service-item {
    position: relative;
    overflow: hidden;
}
.top-icon {
    position: relative;
    right: 15px;
    font-size: 34px;
    bottom: 65px;
    background: #80c32f;
    width: 60px;
    height: 60px;
    float: right;
    line-height: 60px;
    text-align: center;
    color: #fff;
    border-radius: 5px 5px 0px 0px;
    z-index: 9;
}
.content-service a {
    display: block;
    text-align: left;
    position: relative;
    margin-bottom: 10px;
    color: #fff;
    font-size: 14px;
}
.content-service strong {
    display: none;
}
.service-item:hover .content-service {
    position: absolute;
    left: 0;
    top: 0;
    opacity: 1;
    transition: 0.4s;
}
.content-service em {
    border-radius: 50%;
    background: transparent;
    font-size: 20px;
    opacity: 0.90;
    line-height: 30px;
    margin-right: 15px;
}
.content-service {
    position: absolute;
    left: 0;
    top: 100%;
    width: 100%;
    height: auto;
    background: rgba(0,44,87,0.95) none repeat scroll 0 0;
    z-index: 1;
    opacity: 0;
    transition: 0.4s;
    padding: 57px 20px;
}
.main-services {
    display: block;
    padding: 20px;
    position: relative;
    z-index: 1;
}
.service-content h4 {
    display: inline-block;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 0;
    padding: 0 0 10px;
    text-transform: uppercase;
}
.service-item .sppb-img-container {
    overflow: hidden;
    position: relative;
    text-align: center;
}
.service-btn {
    font-weight: 700;
    text-transform: uppercase;
    color: #444;
    position: relative;
    font-size: 13px;
    z-index: 2;
}
.service-btn::after {
    position: absolute;
    content: "\f105";
    font-family: 'Font Awesome 5 Free';
    right: -15px;
    top: -5px;
    font-size: 16px;
}
.service-item .sppb-img-container img {
    transform: scale(1.1);
    transition: 0.4s;
}
.service-item:hover .sppb-img-container img {
    transform: scale(1);
    transition: 0.4s;
}
.service-content h4 {
    display: inline-block;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 0;
    padding: 0 0 10px;
    text-transform: uppercase;
}
.service-btn {
    font-weight: 700;
    text-transform: uppercase;
    color: #444;
    position: relative;
    font-size: 13px;
    z-index: 2;
}
.service-btn::after {
    position: absolute;
    content: "\f105";
    font-family: 'Font Awesome 5 Free';
    right: -15px;
    top: -5px;
    font-size: 16px;
}
.service-item:hover .service-content h4 {
    color: #80c32f;
}
.service-item:hover .service-btn:hover {
    color: #80c32f;
}
.service-item:hover a:hover {
   color: #80c32f;
}

/* Video */
.video-sub {
    border-radius: 10px;
}
.video-sub {
    border-radius: 10px;
    position: relative;
    overflow: hidden;
}
.video-sub::after {
    position: absolute;
    right: -220px;
    top: 0px;
    width: 453px;
    height: 100%;
    content: "";
    background: rgba(0,44,87,0.85) none repeat scroll 0 0;
    transform: rotate(45deg);
}
.video-sub .sppb-icon-inner i {
    font-size: 40px;
    background-color: #fff;
    border-radius: 50%;
    height: 105px;
    width: 105px;
    text-align: center;
    left: 0;
    right: 0;
    margin: auto;
    line-height: 112px;
}
.about-item .sppb-icon i {
    font-size: 34px;
    color: #80c32f;
    float: left;
    line-height: 70px;
    width: 70px;
    height: 70px;
    border: 1px solid #80c32f;
    text-align: center;
    margin-right: 15px;
    border-radius: 3px;
}

/* Ourservice bottom */
.set-service-bottom-sub {
    display: block;
    position: relative;
}
.service-bottom-item {
    cursor: pointer;
    box-shadow: none;
    position: relative;
    z-index: 1;
    border: 1px solid #ddd;
    padding: 30px 30px;
    margin-bottom: 50px;
    z-index: 1;
}
.service-bottom-item .sppb-icon i {
    display: inline-block;
    font-size: 36px;
    line-height: 60px;
    color: #fff;
    transition: 0.4s;
    position: absolute;
    top: -30px;
    z-index: 9999;
    width: 60px;
    height: 60px;
    background: #80c32f;
    text-align: center;
    border-radius: 3px;
    transition: 0.4s;
    border: 1px solid #80c32f;
}
.service-bottom-item::after {
    /* background: #012a51; */
    /* border: 1px solid #012a51; */
    width: 100%;
    height: 100%;
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    opacity: 0;
    transition: 0.4s;
    z-index: -1;
}
 .service-bottom-item:hover::after {
    opacity: 1;
    transition: 0.4s;
}
.service-bottom-item:hover {
    border: 1px solid #012a51;
}
.service-bottom-sub .service-bottom-item h3 {
    font-size: 16px;
    text-transform: uppercase;
    font-weight: 600;
}
.service-bottom-item p {
    margin-bottom: 0px;
}
.service-bottom-item:hover h3, 
.service-bottom-item:hover p {
    color: #fff;
}
.service-bottom-item:hover  .sppb-icon i {
    color: #80c32f;
    background:#fff!important;
    transition: 0.4s;
}
#service-bottom a.sppb-btn-custom:hover {
    background-color: #ffffff!important;
}

/* Counter */
.counter {
   position: relative;
   overflow: hidden;
}
.counter-inner {
    background: #f6f6f6;
    padding: 100px 30px 100px 70px;
}
.counter .counter-content h3 {
    color: #f5f5f5;
    font-size: 26px;
    line-height: 44px;
    margin-bottom: 0px;
    letter-spacing: 1px;
    font-weight: 700;
}
.counter .counter-content {
    position: relative;
    background: rgba(10, 24, 40, 1) none repeat scroll 0 0;
    padding: 99px 0px 108px 87px;
    z-index: 1;
    margin-right: 125px;
}
.counter .counter-content:after {
    content: '';
    position: absolute;
    width: 441px;
    height: 100%;
    background: rgba(10, 24, 40, 1) none repeat scroll 0 0;
    top: 76px;
    right: -180px;
    z-index: -1;
    transform: rotate(60deg);
}
.counter-sub {
    padding-top: 60px;
}
.counter-item .sppb-icon i {
    font-size: 50px;
    color: #80c32f;
    line-height: 50px;
    margin-bottom: 30px;
    display: inline-block;
    width: 80px;
    height: 80px;
    line-height: 76px;
    border: 2px solid #80c32f;
    border-radius: 3px;
}
.counter-item .count {
    color: #444;
    display: block;
    font-size: 36px;
    font-weight: bold;
    padding-bottom: 10px;
    line-height: 40px;
}
.counter-item h4 {
    color: #444;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    margin-bottom: 0;
    letter-spacing: 2px;
}

/* Client */
.client-item {
    cursor: pointer;
    border: 1px solid #666;
    display: block;
    margin: 15px;
    margin-bottom: 30px;
    background: #212D3C
}
#client a.sppb-btn-custom:hover {
    background-color: none!important;
    background: none!important;
}

/* Consultant */
.consultant-item h5 {
    color: #80c32f;
    text-transform: uppercase;
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 5px;
}
.consultant-item h6 {
    font-size: 24px;
    line-height: 34px;
    margin: 0 0 15px;
    color: #444;
    font-weight: 700;
}
.consultant-item p {
    margin: 0 0 15px;
    color: #777;
    line-height: 30px;
}

/* Faq */
.faq-sub {
    display: block;
    overflow: hidden;
    padding: 30px 30px;
    box-shadow: 0 3px 12px #ccc!important;
}
#faq .sppb-panel-modern>.sppb-panel-heading {
    padding: 17px 30px 17px 15px;
    color: #444;
    display: block;
    font-weight: 500;
    text-decoration: none;
    background: #fff;
}
#faq .sppb-toggle-direction i {
    display: none;
}
#faq .et-title h3::after {
    display: none;
}
#faq .et-title {
    margin-bottom: 0px;
}
#faq .et-title h3 {
    font-size: 24px;
    line-height: 34px;
    margin: 0 0 15px;
    color: #444;
    font-weight: 700;
}
.faq-sub-right {
    margin-left: 30px;
    padding: 22px;
    border-radius: 5px;
    border: 1px solid #ccc;
}

/* Testimonial */
.testimonial {
	position: relative;
	z-index: 1;
}
.testimonial:before {
	content: "";
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 50%;
	position: absolute;
	z-index: -1;
	background: #eef3f7;
}

/* Client */
.client .sppb-row-container {
	border-top: 1px solid #ddd;
}

/* Team */
.team-item {
    position: relative;
    overflow: hidden;
    cursor: pointer;
    margin: 0 5px;
    padding-bottom: 10px;
}
.team-item img {
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition:    all 0.4s ease-in-out;
    -ms-transition:     all 0.4s ease-in-out;
    -o-transition:      all 0.4s ease-in-out;
    transition:         all 0.4s ease-in-out;
}
.team-item:hover img {
    transform: rotate(2deg)scale(1.0);
}
.team-item .qx-person-img {
    margin-bottom: 0;
    overflow: hidden;
    width: 100%;
    position: relative;
}
.team-item:hover .qx-person-img:before {
    opacity: .7;
}
.team-item h5 {
    font-size: 18px;
    font-style:italic;
    transition: all .3s linear;
    color: #333;
    font-weight: 400;
    text-transform: capitalize;
}
.team-item h4 {
    padding-top: 20px;
    font-size: 20px;
    text-transform: uppercase;
    font-weight: 600;
    color: #333;
}
.team-item .sppb-addon-text {
    background: #f8f8f8;
    padding: 15px;
    box-shadow: 0 5px 25px rgba(0, 0, 0, 0.1);
}

/* Contact */
.contact-item {
	position: relative;
    display: block;
    padding: 20px 38px 40px;
    max-width: 370px;
    border: 2px solid #1c4069;
    border-top: 0;
    border-bottom-left-radius: 20px;  
    border-bottom-right-radius: 20px; 
}
.contact-item.first {
	border-radius: 20px;
	border-bottom-left-radius: 0px;  
    border-bottom-right-radius: 0px; 
    border-bottom: 0;
    border-top: 2px solid #1c4069;
    padding-bottom: 20px;
    padding-top: 40px;
}
.contact-item.first .sppb-addon-content {
	position: relative;
}
.contact-item.first .sppb-addon-content:after {
	content: "";
	bottom: -20px;
	width: 100%;
	height: 1px;
	background: #1c4069;
	position: absolute;
	left: 0;
	right: 0;
}
#contact-bottom .title h3::after {
    display: none;
}
.contact-item h5,
.contact-item h2 {
	font-weight: 300;
}
.contact-item h6,
.contact-item p {
	color: #8ca4c2;
}
.contact-item .btn-contact {
	color: #fff;
	text-transform: uppercase;
	font-size: 14px;
	margin-top: 15px;
}
.contact-item .btn-contact:after {
	content: "\f054";
    font-family: FontAwesome;
    font-size: 10px;
    border: 1px solid;
    border-radius: 50%;
    padding: 2px 3px 2px 5px;
    margin-left: 5px;
}
.creativecontactform_body {
    padding: 5px 15px 10px 0px !important;
} 
.creativecontactform_footer {
    padding: 0px 15px 15px 0px !important;
}
#contact-bottom .title h3::after {
    display: none;
}
#contact-bottom .title h3 {
    color: #fff;
    font-size: 32px;
    line-height: 44px;
    font-weight: 700;
    max-width: 750px;
    float: left;
    margin-bottom: 0px;
    margin-top: 18px;
}
.contact-bottom-item .sppb-icon i {
    width: 50px;
    height: 50px;
    display: inline-block;
    border: 1px solid #80c32f;
    background: #80c32f;
    text-align: center;
    line-height: 46px;
    color: #fff;
    font-size: 22px;
    margin-bottom: 30px;
    margin-right: 15px;
    border-radius: 3px;
}
.contact-bottom-item h3 {
    color: #fff;
    font-size: 19px;
    font-weight: 500;
    padding-top: 15px;
}

/* Blog */
.jmm-item .jmm-image.mod-article-image {
  	overflow: hidden;
}
.jmm-image.mod-article-image img {
  	transform: scale(1);
  	-webkit-transition: .5s ease-in-out;
    -o-transition: .5s ease-in-out;
    transition: .5s ease-in-out;
}
.jmm-item:hover .jmm-image.mod-article-image img {
  	transform: scale(1.12);
  	filter: grayscale(100%);
}

/* Contact Info */
.contact-info h2, .contact-info h3 {
    font-size: 25px;
}
button.btn.btn-primary.validate {
    color: #fff !important;
    padding: 13px 20px;
}

/* Bottom */
#sp-bottom .sp-module .sp-module-title:before {
    content: "";
    width: 5px;
    height: 15px;
    display: inline-block;
    background: currentColor;
    margin-bottom: -1px;
    margin-right: 8px;
}

/* Footer Copyright */
#sp-footer {
    text-align: center;
    display: inline-block;
    width: 100%;
}
#sp-footer .container-inner {
    border-top: none;
}
#sp-footer1 {
  padding-top: 5px;
}

/*** Responsive Layout ***/
/* Tablet Landscape Layout */
@media (min-width: 1400px) {
    .sppb-row-container {
      	max-width: 1320px;
    }
}

/* Mobile Standard Layout */
@media (max-width: 768px) {
	#sp-header, #sp-header .logo {
        height: 70px;
    }
  	#sp-footer p {
  		text-align: center;
	}
  	body #sp-header {
      	padding: 0;
	}
  	#sp-header {
    	top: 0px;
	}
  	.jm-category-module.default .jmm-rows.rows-3 > div > .jmm-item {
    	width: 98%;
    	margin: 20px 1%;
	}
    .service .sppb-col-md-4 {
      	margin-bottom: 30px;
    }
}

/* Mobile Small Resolution */
@media (max-width: 480px) {
  	.category .sppb-column-addons .clearfix:nth-child(n+2) {
    	width: 100%;
    	margin-right: 0;
	}
  	a.slider-btn.right {
        margin-left: 0px !important;
        margin-top: 20px;
	}
  	.content-service {
    	padding: 30px 20px;
	}
}

/* General color defination
Color value depend on preset color that picking on template settings > Presets
*/

:root {
  --background-color: currentColor;
  --background: currentColor;
  --text-color: currentColor;
}
.page-item.active .page-link,
.slider-item .sppb-btn-success, .sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-info:hover,
.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-overlay-wrapper .sp-simpleportfolio-overlay,
#sp-top-bar, .top-icon, .contact-bottom-item .sppb-icon i, .client-item:hover, .service-bottom-item::after,
.service-bottom-item .sppb-icon i, a.sppb-btn-custom, #sp-bottom .sp-module .sp-module-title:before, a.slider-btn.left, a.slider-btn.right:hover {
 	background-color: var(--background-color) !important;
}
.article-list .article .readmore a:hover, .article-list .article .readmore a:active, .article-list .article .article-header h2 a:hover,
button.btn.btn-primary.validate:hover, .et-title h3 b, .et-service-bottom-item:hover .sppb-icon i, .et-video-sub .sppb-icon-inner i, .et-service-item:hover .service-content h4, .service-item:hover a:hover, .about-item .sppb-icon i, .team-item h4, .consultant-item h5, .sppb-addon-accordion i, .consultant-item h6 strong, .counter-item .sppb-icon i, a.sppb-btn-custom:hover, .service-item:hover .service-btn:hover, .video-sub .sppb-icon-inner i,  .title h3 b,
.slider-title h1, a.slider-btn.right, a.slider-btn.left:hover, #sp-bottom a, #sp-footer a {
  	color: var(--text-color) !important; 
}
.sppb-divider, a.slider-btn, .service-bottom-item:hover, a.sppb-btn-custom:hover {
  	border-color: var(--text-color) !important;
}
