/* 1. Theme */
@import url('https://fonts.googleapis.com/css?family=Poppins:400,400i,500,500i,600,600i,700,700i,800,800i,900,900i|Roboto:400,400i,500,500i,700,700i,900,900i|Comfortaa:300,400,500,600,700|Comfortaa:300,400,500,600,700|Michroma&display=swap');

html {
	scroll-behavior: smooth;
  }
body {
	font-family: 'Poppins', sans-serif;
	font-size: 14px;
	font-weight: normal;
	color: #363636;
	font-style: normal;
}
.img {
	max-width: 100%;
	transition: all 0.3s ease-out 0s;
}
.f-left {
	float: left
}
.f-right {
	float: right
}
.fix {
	overflow: hidden
}
a,
.button {
	-webkit-transition: all 0.3s ease-out 0s;
	-moz-transition: all 0.3s ease-out 0s;
	-ms-transition: all 0.3s ease-out 0s;
	-o-transition: all 0.3s ease-out 0s;
	transition: all 0.3s ease-out 0s;
}
a:focus,
.button:focus {
	text-decoration: none;
	outline: none;
}
a:focus,
a:hover,
.portfolio-cat a:hover,
.footer -menu li a:hover {
	text-decoration: none;
}
.btn.focus, .btn:focus {
	outline: 0;
	box-shadow: none;
}
a,
button {
	color: #1696e7;
	outline: medium none;
}
button:focus,input:focus,input:focus,select:focus,textarea,textarea:focus{outline: none;box-shadow: none;}
.uppercase {
	text-transform: uppercase;
}
.capitalize {
	text-transform: capitalize;
}
h1,
h2,
h3,
h4,
h5,
h6 {
	color: #08434f;
	margin-top: 0px;
	font-style: normal;
	font-weight: 600;
	text-transform: normal;
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
	color: inherit;
}
h1 {
	font-size: 2.5rem;
	font-weight: 500;
}
h2 {
	font-size: 2.2rem;
}
h3 {
	font-size: 1.75rem;
}
h4 {
	font-size: 1.4rem;
}
h5 {
	font-size: 1.2rem;
}
h6 {
	font-size: 1rem;
}
ul {
	margin: 0px;
	padding: 0px;
}
li {
	list-style: none
}
p {
	font-size: 1rem;
	font-weight: normal;
	line-height: 1.5rem;
	color: #2f2f2f;
	margin-bottom: 1rem;
}
hr {
	border-bottom: 1px solid #eceff8;
	border-top: 0 none;
	margin: 1.8rem 0;
	padding: 0;
}
label {
	color: #7e7e7e;
	cursor: pointer;
	font-size: 0.875rem;
	font-weight: 400;
}
.text-checkmark{
	color:#2f9717;
	font-size:1.2rem
}
*::-moz-selection {
	background: #d6b161;
	color: #fff;
	text-shadow: none;
}
::-moz-selection {
	background: #444;
	color: #fff;
	text-shadow: none;
}
::selection {
	background: #444;
	color: #fff;
	text-shadow: none;
}
*::-moz-placeholder {
	color: #555555;
	font-size: 14px;
	opacity: 1;
}
*::placeholder {
	color: #555555;
	font-size: 14px;
	opacity: 1;
}
.theme-overlay {
	position: relative
}
.theme-overlay::before {
	background: #1696e7 none repeat scroll 0 0;
	content: "";
	height: 100%;
	left: 0;
	opacity: 0.6;
	position: absolute;
	top: 0;
	width: 100%;
}
.separator {
	border-top: 1px solid #f2f2f2
}
/* button style */

.btn {
	-moz-user-select: none;
	background: transparent linear-gradient(90deg, #035a6a 0%, #21aebb 100%) 0% 0% no-repeat padding-box;
    box-shadow: 1px 2px 5px #035a6a;
	border: none;
	border-radius: 3.125rem;
	color: #fff;
	display: inline-block;
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: 0;
	padding: 1rem 2.2rem;
	text-align: center;
	text-transform: unset;
	touch-action: manipulation;
	transition: all 0.3s ease 0s;
	vertical-align: middle;
	white-space: nowrap;
	position: relative;
}
.btn:hover{color: #fff;}
.btn:hover::before{opacity: 0;}
.breadcrumb > .active {
	color: #888;
}

/* scrollUp */
#scrollUp {
	background: #ffdd00;
	height: 3rem;
	width: 3rem;
	right: 2vh;
	bottom: 4vh;
	color: #222;
	text-align: center;
	border-radius: 50%;
	font-size: 1.4rem;
	line-height: 3rem;
	transition: .3s;
}
#scrollUp:hover {
	background: #f4bf00;
}

/* 2. header */
#menu-logo{
	width:10rem;
}
.main-menu ul li {
	display: inline-block;
	margin-left: 1.5rem;
	position: relative;
}
.main-menu ul li.active a {
	color: #ffdd00;
}
.main-menu ul li a {
	display: block;
	color: #fff;
	font-family: 'Poppins', sans-serif;
	font-weight: 500;
	padding: 2rem 0;
	position: relative;
	text-decoration: none;
}
.main-menu ul li:first-child {
	margin-left: 0;
}
.main-menu ul li:hover > a{color: #ffdd00;}
.main-menu ul li:hover > a::before{width: 100%;}
.sticky-menu {
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    box-shadow: 0 0 60px 0 rgba(0, 0, 0, .07);
		z-index: 9999;
		background: transparent linear-gradient(45deg, #035a6a 20%, #0f9eb7 100%);
}
.responsive {
	display: none;
}
#mobile-menu {
	display: block;
}
.second-menu {
	position: relative;
	z-index: 9;
}
.sticky-menu .second-menu {
	margin: 0;
	box-shadow: none;
	padding: 0;
}
.sticky-menu .second-menu::before{content: none;}
.second-menu .main-menu ul li{margin-left: 2rem;}
.second-menu .main-menu ul li:first-child{margin-left: 0;}
.second-menu .main-menu ul li a::before{content: none;}
.second-header-btn .btn {
	background: #fff;
	border: 2px solid #fff;
	font-size: 1rem;
	text-transform: uppercase;
	color: #08434f;
}
.second-header-btn .btn:hover {
	color: #fff;
	background: #24adb8;
    border-color: #24adb8;
}
.second-header-btn .btn::before{content: none;}
.menu-close i {
	font-size: 1rem;
	color: #fff;
	transition: .3s;
	cursor: pointer;
}
.menu-close:hover i{
	color: #24adb8;
}

/* 3. slider */
.slider-row {
	padding-top:8rem;
	padding-bottom:2rem;
}
.slider-bg {
	position: relative;
	z-index: 1;
	background-image: url("../img/bg/header-bg.jpg");
	background-position:right 0; 
	background-repeat: no-repeat; 
	background-size: 66%;
	min-height: 100vh;
}
.s-img {
    margin-left: -3rem;    
}
.slick-slider{
    z-index: 999;
}
.small-title {
    background: #f7f4fe;
    display: inline-block;    
    border-radius: 1.25rem;
}
.small-title li{
    display:inline-block;    
    padding: 0.375rem 1.25rem;
    color: #08434f;
}
.small-title li:first-child {
    background: #ffdd00;
    border-radius: 1.5rem;
    color: #222;
	font-weight:600;
	font-family:'Comfortaa';
	font-size:1rem;
}
.slider-bg .slider-content p {
    color:#444;
    font-size: 1rem;
    margin-bottom: 0;
}
.slider-content{
	padding-bottom: 0.3rem;
    z-index: 999;
    position:relative;
}
.slider-content h2 {
	font-size: 6rem;
	line-height: 1.1;
	margin-bottom: 1.5rem;
	color:#08434f;
    padding-right: 5%;
}
.title-secondary-top {
	color: #24adb8;
	font-size: 5.5rem;
}
.slider-btn .btn {
	background: #fff;
	color: #24adb8;
}
.slider-btn .btn::before {
	content: none;
}
.slider-btn .btn {
	box-shadow: 3px 3px 0 0 #24adb8;
}
.slider-btn .btn:hover{box-shadow: none;}
.p-relative{position: relative;}
.btn.ss-btn {
	background: transparent linear-gradient(90deg, #035a6a 0%, #21aebb 100%) 0% 0% no-repeat padding-box;
    box-shadow: 1px 2px 5px #035a6a;
    color: #fff;
}
.btn.ss-btn:hover {background: transparent linear-gradient(90deg, #21aebb 0%, #035a6a 100%) 0% 0% no-repeat padding-box; color:#fff;box-shadow: 2px 3px 10px #035a6a;}

/* 4. Section */
.section-title h2 {
	font-size: 2.5rem;
	padding-bottom: 1rem;
	position: relative;
    line-height: 1.1;
}
.section-img {
	text-align: center;
	padding-top:1.25rem;
	padding-bottom:1.9rem;
}
.section-img img {
	width: 85%;
}
section{
	scroll-margin-top: 5.3rem;
}

/* 5. card */
.card-content h5 {
	font-size: 1.25rem;
	font-weight: 600;
	margin-bottom: 0.7rem;
}
.card-content p {
	margin-bottom: 1.125rem;
	transition: .2s;

}
.card-content a {
	font-size: 1.35rem;
    font-weight: 500;
    color: #24adb8;
    position: relative;
    transition: .5s;
    width: 3.5rem;
    height: 3.5rem;
    display: inline-block;
    line-height: 3.5rem;
    border-radius: 50%;
    background-clip: border-box;
    position: relative;
    background: transparent linear-gradient(90deg, #7D4196 0%, #24adb8 100%) 0% 0% no-repeat padding-box;
    padding: 1px;
}
.card-content a span{
   background: #fff;
    display: inline-block;
    width: 100%;
    border-radius: 50%;
    height: 100%;
}
.card-skeleton.active .card-content a span{
    background: none;
}
.card-content a::after {
	left: -2.5rem;
	right: unset;
	opacity: 0;
}
.card-skeleton {
	transition: .3s;
	border-radius: 2rem;
	border: solid 1px #eee;
	background: #fff;
	box-shadow: 3px 6px 10px #bbbbbb2e;
	text-align:center;
}
.card-skeleton:hover {border: 1px solid #0f515f;	background: #2c7484;}
.card-skeleton:hover .card-content h5{color: #fff;}
.card-skeleton:hover .card-content a{color: #fff;}
.card-skeleton:hover .card-content p{color: #fff;}
.message-card {
	background:transparent linear-gradient(45deg, #035a6a 20%, #0f9eb7 100%); 
	border-radius:0.65rem; 
	padding:1rem; 
	color:white;
	text-align:center
}

/* 6. Contact */
.gray-bg-gradient{
	background: transparent linear-gradient(180deg, #ffffff 35%, #d2d2d2 100%);
}

/* 7. Footer */
#footer-logo{
	width:160px
}
.footer-bg {
	background:  transparent linear-gradient(160deg, #0f9eb7 30%, #0e9ab3 100%) 0% 0% no-repeat padding-box;
}
.footer-text p {
	color: #ddd;
	margin-bottom: 0;
}
.f-widget-title p {
	color: #fff;
	font-size: 1rem;
	font-weight:500;
	position: relative;
}
.copyright-text {
    border-top: 2px solid #ffffff3b;
    padding: 0.7rem 0 1.25rem;
}
.copyright-text p {
	margin-bottom: 0;
	color: #ddd;
	font-size: 0.9rem;
}
.f-contact li {
    float: left;
    margin-bottom: 0.7rem !important;
    width: 100%;
}
.f-contact i {
    width: 1.5rem;
    height: 1.5rem;
    background: #fff;
    line-height: 1.5rem;
    color:#24adb8 !important;
    text-align: center;
    border-radius: 50%;
    float: left;
}
.f-contact span {
    float: left;
    color: #fff;
    margin-left: 0.5rem;
    width: 77%;
	font-size:0.9rem;
	text-decoration:none;
}
/* 8. Menu */
.main-menu ul li.has-sub .current a{
   color:#222;
}
.main-menu ul li.current a{
   color:#24adb8;
}
.main-menu .has-sub > ul {
	display:none;
	position: absolute;
	background-color: #ffff;
	min-width: 15.5rem;
	z-index: 1;
	transition: all 0.3s ease-in-out;
	margin-top: 1rem;
	border-top: 4px solid #24adb8;
	box-shadow: 0 0.675rem 1rem rgba(25, 25, 25, 0.1);
	-webkit-box-shadow: 0 0.675rem 1rem rgba(25, 25, 25, 0.1);
}
.main-menu .has-sub li a{
    padding: 1rem;
    color: #000;

}
.main-menu .has-sub li {
	margin-left: 0 !important;
	float: left;
	border-bottom: 1px solid #ddd;
	width: 100%;
	text-align: left;
}
.main-menu .has-sub a:hover{
	color:#ffdd00;
}
.main-menu .has-sub:hover > ul { display:block; margin-top: 0px;}
.main-menu .has-sub > ul > .has-sub > ul {
  display: none;
  position: absolute;
	background-color: #ffff;
	width: 15.5rem;
	z-index: 1;
	padding: 0;
	margin-left: -15.5rem;
	margin-top: 0;
	top: -0.25rem;
}
.main-menu .has-sub > ul > .has-sub:hover > ul{display: block;}
.main-menu .has-sub > ul > .has-sub > ul > .has-sub > ul {
   display: none;
	position: absolute;
	background-color: #ffff;
	width: 15.5rem;
	z-index: 1;
	padding: 0;
	margin-left: -15.5rem;
	margin-top: 0;
	top: -0.25rem;
}
.main-menu .has-sub > ul > .has-sub > ul > .has-sub:hover > ul {display: block;}


/* 9. Flex  */
.flex-wrapper {
	display: flex;
	flex-direction: row;
	flex-wrap:wrap;
	gap: 2rem;
	padding:1rem;
}
.flex-item-wrapper{
	padding:1.25rem
}
.flex-card-2{
	width:48%; 
	flex-grow: 1;
	display: inline-flex;
	box-sizing: border-box;
}
.flex-card-3{
	width:31%; 
	flex-grow: 1;
	display: inline-flex;
	box-sizing: border-box;
}

/* 10. CTA */
.cta-box {
	font-size:1rem; 
	background:transparent linear-gradient(45deg, #035a6a 20%, #0f9eb7 100%); 
	border-radius:2rem; 
	padding:1.5rem 1rem; 
}
.cta-box-wrapper{
	display:flex;
	flex-direction:row;
}
.cta-box-content{
	flex:3;
	padding: 0 1rem;
}
.cta-box-title {
	font-size:1.3rem; 
	font-weight:600;
	margin-bottom: 1.25rem;
	color:white
}
.cta-box-title:after{
	background-color: #ffdd00;
    content: "";
    display: block;
    height: 0.175rem;
    margin: 0.675rem 0 0;
    width: 5rem;
}
.cta-box-description {
	color:white;
	margin:0
}
.cta-box-button-wrapper{
	align-items: center;
    display: flex;
    justify-content: flex-end;
	min-width:25%;
	padding: 0 1rem;
}
.cta-button{
    background: #ffdd00;
    box-shadow: none;
    color: #262626;	
	padding:1rem 2rem;
	border-radius:3rem
}
.cta-button:hover,
.cta-button:active:hover,
.cta-button:focus{
    background: #fff700;
    color: #262626;	
	transform: scale(0.95);
}
.cta-box-button-wrapper a{
    color: #262626;		
	text-decoration: none;
}

/* 11. Icon */
.solution-icon {
	margin-bottom: 2.2rem;
}
.solution-icon i {
    font-size: 2rem;
	background:#f5f8fa;
	border-radius: 50%;
	color:#08434f;
	height: 4.8rem;
	width: 4.8rem;
	line-height:4.8rem;
	text-align: center;
}
.solution-icon img {
	height:14rem;
}
.services-icon {
	margin-bottom: 2.2rem;
}
.services-icon img{
	height:10rem;
}
::selection {
	color: #fff;
	background: #0f9eb7 ;
}

/* 12.Gradation  */
.section-shadow-top{
	box-shadow: 0px -15px 15px 10px #ffffff
}
.section-shadow-top-in{
	box-shadow: inset 0px 19px 15px 5px #ffffff
}

/* 13. Form */
.form-active, .form-success {
	min-height: 34rem !important;
	width: 100%;
	-webkit-backface-visibility: hidden; /* Safari */
	backface-visibility: hidden;
}
.form-success {
	position: absolute;
	background:transparent linear-gradient(45deg, #035a6a 20%, #0f9eb7 100%); 
	padding:2rem 2rem 2.5rem; 
	border-radius:0.65rem;
	transform: rotateY(180deg);
}
input,
input::placeholder,
textarea,
textarea::placeholder {
    font-size: 0.9rem;
}
.success-message {
	color:white
}
.success-message-top{
	font-size:1.3rem; 
	font-weight:600
}
.success-message-mid{
	font-size:1rem;
}
.success-message-bottom{
	font-size:1.4rem; 
	font-weight:600
}
.error-message {
	color: #ff0000;
	display: inline-block;
	font-size: 0.75rem;
	line-height: 1rem;
	margin: 0.3rem 0 0;
}
.flip-card {
	background-color: transparent;
	min-height: 33rem;
	border: none;
	perspective: 1000px; 
}
.flip-card-inner {
	position: relative;
	width: 100%;
	height: 100%;
	transition: transform 0.8s;
	transform-style: preserve-3d;
}
.checkmark__circle{
	stroke-dasharray: 166;
	stroke-dashoffset: 166;
	stroke-width: 2;
	stroke-miterlimit: 10;
	stroke: #7ac142;
	fill: none;
	animation: stroke 0.6s cubic-bezier(0.65, 0, 0.45, 1) forwards
}
.checkmark{
	width: 3.75rem;
	height: 3.75rem;
	border-radius: 50%;
	display: block;
	stroke-width: 4;
	stroke: #fff;
	stroke-miterlimit: 10;
	margin: 10% auto;
	box-shadow: inset 0px 0px 0px #7ac142;
	animation: fill .4s ease-in-out .4s forwards, scale .3s ease-in-out .9s both
}
.checkmark__check{
	transform-origin: 50% 50%;
	stroke-dasharray: 48;
	stroke-dashoffset: 48;
	animation: stroke 0.3s cubic-bezier(0.65, 0, 0.45, 1) 0.8s forwards
}	
@keyframes stroke{100%{stroke-dashoffset: 0}}
@keyframes scale{0%, 100%{transform: none}50%{transform: scale3d(1.1, 1.1, 1)}}
@keyframes fill{100%{box-shadow: inset 0px 0px 0px 30px #7ac142}}


/* 14. PopUp */
.popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:100000;background: rgba(52, 58, 65, 0.6);backdrop-filter: blur(6px);-webkit-backdrop-filter: blur(6px);transition:opacity 0.1s}
.popup-box,.popup-overlay{opacity:0;pointer-events:none}
.popup-box{position:fixed;max-width:60vh;top:50%;left:50%;width:100%;z-index:1000000;padding:2.5rem 2rem;background:#fff;border-radius:1rem;transform:translate(-50%,-50%) scale(1.2);box-shadow:10px 10px 15px rgba(0,0,0,.06);transition:opacity .2s ease-in-out,transform .2s ease-in-out}
.popup-overlay.show,.popup-overlay.show .popup-box{opacity:1;pointer-events:auto;}
.popup-overlay.show .popup-box{transform:translate(-50%,-50%) scale(1)}
.popup-box .popup-content :where(p,span,a,button){font-family:Poppins,sans-serif}
.popup-box .popup-content,.popup-box .warn-icon{display:flex;align-items:center;justify-content:center}
.popup-box .popup-content .bullet-point{color:#dd2222; list-style-position: outside;padding-left:1.2rem}
.popup-box .popup-content .bullet-point li{list-style: auto; font-size:1rem; line-height: 1.5;}
.popup-box .popup-content .bullet-point li::marker{font-weight: bold;}
.popup-box .popup-content{flex-direction:column}
.popup-box .warn-icon{height:6.5625rem;width:6.5625rem;color:#fff;font-size:3.5rem;border-radius:50%;background:#e94242}
.popup-box .title{font-size:1.9rem;font-weight:600;margin:2.5rem 0 0;font-family:'Comfortaa'; text-align:center; line-height: 1.2;}
.popup-box .description{font-size:1rem;text-align:left;margin:1.5625rem 0 0.625rem;color: black;line-height: 1.4rem;}
.popup-box .dismiss-btn{margin-top:1.5rem;padding:0.8rem 1.7rem;font-size:1rem;border:none;outline:0;color:#fff;cursor:pointer;border-radius:3rem;background:linear-gradient(45deg, #035a6a 20%, #0f9eb7 100%);transition:.3s}
.popup-box .dismiss-btn:active, .popup-box .dismiss-btn:hover{transform:scale(.95)}

/* 15. etc */
body.modal-open {
    overflow: hidden;
}
.usp-title{
	font-family:Comfortaa; 
	font-weight:100; 
	color:#222; 
	font-size:2rem; 
	line-height:1.2; 
	align-self: center;
}
.usp-icon{
	width:20%; 
	margin-right:1.25rem;
}
.usp-description p{
	padding:0;
	font-size:1rem;
}
.usp-bg {
	background-image: url("../img/bg/usp-background.jpg");
	background-attachment: fixed; 
	background-repeat: no-repeat; 
	background-position:center bottom; 
	background-size: cover;
}
.above-footer-icon{
	background-image: url("../img/icon/digital-tree-electric.svg"); 
	background-repeat: no-repeat; 
    background-position: calc(50% - 20.5rem) bottom;
    background-size: 17rem;
}
.consultation-content{
	padding-right:2rem;
}
.consultation-menuitem{
	display:none !important;
}
.absolute-top {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1030;
}
.north-star-logo{
	width:3rem; 
	vertical-align:bottom;
}
.north-star-title{
	font-size:2.5rem; 
	color: #08434f;
	margin-left: 0.4rem;
	font-weight: 600;
	line-height:1.1;
}
.title-secondary-bottom{
	color: #0f9eb7;
	font-size:1.7em
}
textarea {
	resize: none;
 }

