/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: May 20 2026 | 06:21:46 */
/* 1. Colors
------------------------------ */
.bg-primary {
    background-color: var(--global-palette1);
}

.bg-secondary {
    background-color: var(--global-palette2);
}

.bg-dark {
    background-color: var(--global-palette3);
}

.bg-dark-op {
    background-color: var(--global-palette4);
}

.bg-subtle {
    background-color: var(--global-palette7);
}

.bg-light {
    background-color: var(--global-palette8);
}

.bg-white {
    background-color: var(--global-palette9);
}

.bg-gradient {
    background: linear-gradient(35deg, var(--global-palette2) 0%, var(--global-palette1) 100%);
}

.bg-dark, .bg-gradient, .bg-gradient a, .bg-dark .elementor-heading-title,.bg-gradient .elementor-heading-title,
.bg-dark-op, .bg-dark-op a, .bg-dark-op .elementor-heading-title{
    color: var(--global-palette9);
    fill: var(--global-palette9);
}

.bg-primary, .bg-primary .elementor-heading-title,
section .bg-primary, section .bg-primary .elementor-heading-title,
.bg-secondary, .bg-secondary .elementor-heading-title,
section .bg-secondary, section .bg-secondary .elementor-heading-title {
    color: var(--global-palette9);
    fill: var(--global-palette9);
}

.bg-white, .bg-white .elementor-heading-title {
    color: var(--global-palette3) !important;
    text-underline-position: under;
}

.bg-subtle, .bg-subtle .elementor-heading-title,
.bg-subtle a {
    color: var(--global-palette3) !important;
}


.text-primary, .text-primary .elementor-heading-title, .text-primary a {
    color: var(--global-palette1) !important;
}

.text-white, .text-white .elementor-heading-title, .text-white a {
    color: var(--global-palette9) !important;
}

.text-dark, .text-dark a{
	    color: var(--global-palette3) !important;
}


/* 2. Typographics
----------------------------- */
body, html {
    font-size: 16px;
    line-height: 1rem;
}

@media (min-width: 768px) {
    body, html {
        font-size: 20px;
		line-height: 24px;
		font-family: "Barlow Condensed", serif;
    }
}
a {
    text-decoration: underline;
}

h1, h2, h3, h4, h5, h6, .elementor-heading-title {
	margin: 0 !important;
	text-transform: capitalize;
    font-weight: bold;
	color: var(--global-palette3);
}

.lead, .text-small {
	font-family: 'Inter', sans-serif;
	color: var(--global-palette5);
	line-height: 1.4;
	letter-spacing: 0.02em;
}
.lead {
    font-size: 1rem;
}
.text-small {
	font-size: 0.875rem;
	line-height: 1.3rem;
}
.bg-primary .lead, .bg-primary .kicker,.bg-primary .text-small {
	color: var(--global-palette7);
}
.text-capitalize {
    text-transform: capitalize !important;
}

.text-uppercase {
    text-transform: uppercase !important;
}

.kicker {
	display: inline-flex;
  	align-items: center;
  	gap: 4px;
    color: #356b7d;
    font-size: 20px;
    line-height: 20px !important;
    text-transform: capitalize !important;
	font-family: "Josefin Sans", serif;
    font-weight: 700;
    width: auto !important;
    margin-bottom: 1rem !important;
}
.kicker p {
	font-size: 20px;
    line-height: 20px !important;
}

/* 3. Margin & paddings
------------------------------ */
section, .section {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

section section {
    padding-top: 0;
    padding-bottom: 0;
}

.column-gap-wider,
.elementor-column-gap-wider > .elementor-column > .elementor-element-populated {
    padding: 2rem;
}
.column-gap-wide,
    .elementor-column-gap-wide > .elementor-column > .elementor-element-populated {
        padding: 1rem;
    }

@media (min-width: 768px) {
	section, .section {
    	padding-top: 4rem;
   		padding-bottom: 4rem;
  }
/*     .column-gap-wider,
    .elementor-column-gap-wider > .elementor-column > .elementor-element-populated {
        padding: 4rem;
    }
	.column-gap-wide,
    .elementor-column-gap-wide > .elementor-column > .elementor-element-populated {
        padding: 2rem;
    } */
}

.mb-0 {
    margin-bottom: 0 !important;
}
.mb-1 {
    margin-bottom: 1rem !important;
}

.mb-2 {
    margin-bottom: 2rem !important;
}

.mb-3 {
    margin-bottom: 3rem !important;
}
.mx-1 {
	margin-left: 1rem !important;
	margin-right: 1rem !important;
}
.p-medium {
    padding: 2.5rem;
}

.p-large {
    padding: 1.25rem 5rem;
}

.pb-0 {
    padding-bottom: 0 !important;
}


.pt-0 {
    padding-top: 0 !important;
}

.py-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.px-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.elementor-widget-text-editor {
	font-size: 0.8rem;
}

@media (max-width: 1024px) {
	.mb-2 {
		margin-bottom: 1rem !important;
	}
}

@media (max-width: 768px) {
    section, .section {
        padding-top: 2rem;
        padding-bottom: 2rem;
    }
}

/* 4. Buttons
------------------------------------- */
button, .elementor-button, input[type="button"], input[type="reset"], input[type="submit"] {
	border-radius: 0 !important;
	font-weight: 400;
    font-size: 0.875rem;
	padding: 0.75rem 1.5rem;
	box-shadow: none;
	line-height: 1;
	letter-spacing: 0.03em;
	text-transform: capitalize;
	border: 1px solid;
	font-family: "Josefin Sans", sans-serif;
}

/* Btn colors */
.btn-primary .elementor-button {
    background-color: var(--global-palette1);
    border-color: var(--global-palette1);
    color: var(--global-palette9);
}

.btn-secondary .elementor-button,
.btn-secondary-small .elementor-button {
    background-color: transparent;
    border-color: var(--global-palette9);
    color: var(--global-palette9) !important;
}

.btn-primary .elementor-button:hover, .btn-primary .elementor-button:focus, .btn-primary .elementor-button:active {
    background-color: transparent !important;
    border-color: var(--global-palette3) !important;
    color: var(--global-palette3) !important;
}

.btn-secondary .elementor-button:hover, .btn-secondary .elementor-button:focus, .btn-secondary .elementor-button:active,
.btn-secondary-small .elementor-button:hover, .btn-secondary-small .elementor-button:focus, .btn-secondary-small .elementor-button:active{
    background-color: var(--global-palette1) !important;
    border-color: var(--global-palette1) !important;
    color: var(--global-palette9) !important;
}

/* 5. Modificators
------------------------------------- */
.list-unlisted {
    list-style: none;
}

.overflow-h {
    overflow: hidden;
}

.rounded {
    border-radius: 1rem;
    overflow: hidden;
}

.underlined {
    text-decoration: underline;
    text-underline-offset: 5px;
}
.gap10 > div {
	gap: 0.5rem;
}
.gap20 > div {
    gap: 1rem;
}
.gap40 > div {
    gap: 2rem;
}
.green-text  {
	color: var(--global-palette1);
}

/* 6. Header
------------------------------------- */

#masthead {
  position: relative;
  z-index: 10;
}
#masthead .item-is-stuck {
    box-shadow: 0 0 1.5rem rgba(0, 0, 0, .1);
}

/* #masthead::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -2px;
  z-index: -1;
  height: 90px;
  pointer-events: none;
  background: rgba(190, 190, 190, 0.6);
  filter: blur(8px);
} */


/* 7. Hero
------------------------------------- */
#hero h1 {
	line-height: 4.5rem;
}
@media(max-width: 768px) {
	#hero h1 {
	line-height: 1.1;
}
}
#hero .elementor-button {
	font-weight: 600 !important;
}

#hero .kicker {
	text-decoration: underline;
	padding: 0;
	gap: 0;
}
#hero .kicker:before {
	width: 0;
	height: 0;
	background-image: url("");
}

/* 8. HOMEPAGE: About
------------------------------------- */
#about .elementor-icon-list-text {
	font-size: 0.8rem;
	font-weight: 600;
	font-family: "Josefin Sans", sans-serif;
}
#about ul svg {
	fill: var(--global-palette1);
}

/* HOMEPAGE: Features
------------------------------------- */
#features .elementor-icon-box-title {
	font-size: 0.875rem;
	font-weight: 700;
	display: inline-block;
	color: var(--global-palette1);
	text-transform: uppercase;
	font-family: "Josefin Sans", sans-serif;
	margin-bottom: 0.5rem;
}
#features .elementor-icon-box-description {
	font-size: 0.8rem;
}
#features .elementor-icon {
	font-size: 3.25rem;
}
#features .elementor-icon svg{
	fill: var(--global-palette1);
}

/* HOMEPAGE: Counter
------------------------------------- */
#counter .elementor-column:not(:last-child)::after {
	content: '';
	width: 30%;
	height: 100%;
	background-image: url('/wp-content/uploads/icons8-wavy-line-100.png');
	background-repeat: no-repeat;
	transform: rotate(90deg);
	position: absolute;
	right: -2.5rem;
	top: 0;
}
#counter .elementor-counter-number-wrapper {
	color: var(--global-palette1);
	font-size: 3.5rem;
	font-family: "Josefin Sans", serif;
}
#counter .elementor-counter-title {
	font-size: 1.2rem;
	text-transform: capitalize;
	font-weight: 500;
	line-height: 1.1;
}

/* HOMEPAGE: Activities
------------------------------------- */
#our-activities .elementor-cta {
    min-height: 25rem;
}

#our-activities .elementor-cta:hover .elementor-cta__content {
    background: none;
}

#our-activities .elementor-cta .elementor-cta__title {
    font-size: 1.3rem;
}

#our-activities .elementor-cta .elementor-cta__bg-wrapper {
    height: 25rem;
}

#our-activities .elementor-cta .elementor-cta__content {
    height: 25rem;
    text-align: left;
    position: absolute;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 20%);
    bottom: -18rem;
}

#our-activities .elementor-cta__button-wrapper a {
    font-weight: 700;
}
#our-activities .elementor-cta .elementor-cta__content .elementor-cta__content-item p {
    font-size: 0.875rem;
}

#our-activities .elementor-cta .elementor-cta__content .elementor-cta__button-wrapper {
    position: absolute;
    bottom: 0px;
    right: 0px;
    border-radius: 0;
    padding: 1.7rem;
}
#our-activities .elementor-cta  .elementor-cta__button:hover {
    background-color: var(--global-palette8);
	border-color: var(--global-palette8);
}
#our-activities .elementor-cta:hover .elementor-cta__title,
#our-activities .elementor-cta:hover .elementor-cta__description {
    color: var(--global-palette3);
}
#our-activities .elementor-cta:hover .elementor-cta__content {
    bottom: 0;
	background-color: var(--global-palette2);
}

#our-activities .elementor-cta .elementor-cta__content .experience {
    display: block;
    margin-bottom: 9rem;
    text-transform: capitalize;
    font-size: 0.8rem;
    font-weight: 500;
}

#our-activities .elementor-cta .elementor-cta__button {
    width: 100%;
    color: var(--global-palette3) !important;
	padding: 10px;
	padding-top: 15px;
	border-radius: 0;
}
@media(max-width: 1200px){
	#our-activities .elementor-cta .elementor-cta__content .experience {
		margin-bottom: 6rem;
	}
}
@media(max-width: 1024px){
	#our-activities .elementor-cta .elementor-cta__content .experience {
		margin-bottom: 12rem;
	}
}
@media(max-width: 768px){
	#our-activities .elementor-cta .elementor-cta__content .experience {
		margin-bottom: 7.5rem;
	}
}

/* HOMEPAGE: Contact-FAQ
------------------------------------- */
#contact-faq {
	max-height: 650px;
}
#contact-faq > div > div:first-child {
	transform: translateY(-10rem);
}

@media(max-width: 1024px) {
	#contact-faq > div > div:first-child {
	transform: translateY(-2rem);
}
	
	#contact-faq {
	max-height: unset;
}
}

#contact-faq .text-small {
	color: var(--global-palette8);
	font-weight: 700;
}

#contact-faq .forminator-custom-form input, 
#contact-faq .forminator-custom-form textarea {
	background: transparent;
	border-color: var(--global-palette8);
	color: var(--global-palette8);
	font-size: 0.875rem !important;
	border-radius: 0;
	padding: 0.75rem 0.5rem;
}

#contact-faq .forminator-custom-form textarea {
	height: 4.5rem;
}

#contact-faq .forminator-custom-form input::placeholder, 
#contact-faq .forminator-custom-form textarea::placeholder {
	color: var(--global-palette8);
}

#contact-faq .forminator-button {
	width: 100%;
	font-weight: 600 !important;
	font-size: 0.875rem !important;
	border-radius: 0 !important;
}

#contact-faq .elementor-accordion-item {
	border-bottom: 1px solid #61CE7078;
}
#contact-faq .elementor-accordion-title {
	font-weight: 600;
}
#contact-faq .elementor-accordion-item .elementor-tab-content {
	font-size: 0.875rem;
}

/* HOMEPAGE: Our Team
------------------------------------- */
#team .elementor-image-box-img img {
	width: 100%;
}
#team .elementor-image-box-title {
	color: var(--global-palette3);
}

/* HOMEPAGE: Testimonials
------------------------------------- */
#testimonials .elementor-testimonial__text {
	font-size: 1.25rem;
	font-weight: 500;
	font-style: normal;
	color: var(--global-palette8);
	line-height: 1.75rem;
}
#testimonials .elementor-testimonial__name {
	font-size: 0.875rem;
	text-transform: uppercase;
	color: var(--global-palette2);
	font-style: normal;
	font-family: "Josefin Sans", serif;
}
#testimonials .elementor-testimonial__title {
	font-style: normal;
	font-size: 0.8rem;
	font-family: "Josefin Sans", serif;
}
@media(max-width: 768px) {
	#testimonials .elementor-testimonial {
		flex-direction: column-reverse;
    	gap: 1rem;
	}
	#testimonials .elementor-swiper-button-prev {
		left: -5px;
	}
	#testimonials .elementor-swiper-button-next {
		right: -5px;
	}
}

#services-page ol, #services-page ui, #services-page li{
	font-size: 1.1rem;
	line-height: 1.25rem;
}

.post-thumbnail img, .post-thumbnail .post-thumbnail-inner {
	height: 300px;
}
.post-thumbnail img{
	object-fit: contain !important;
}

.wp-site-blocks .post-thumbnail {
	padding-bottom: 50%;
}
#comments {
	display: none;
}

/* Contact Page: Contacts
------------------------------------- */
#contact .text-small {
	color: var(--global-palette3);
	font-family: "Barlow Condensed", serif;
}
#contact img {
	width: max-content;
}

/* 9. FOOTER
------------------------------------- */
footer {
	width: 100%;
	background-image: url("/wp-content/uploads/footer-bg.png");
    background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
footer .site-middle-footer-inner-wrap {
	padding: 0;
}
footer .footer-social-wrap {
	padding-bottom: 1rem;
}
#footer-menu li:nth-child(-n+1) {
    border-right: 1px solid var(--global-palette9);
}
#secondary-menu a {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 0.7rem;
}
#colophon {
	margin-top: 4rem;
}
#colophon .widget_media_image {
	max-width: 250px;
	padding-bottom: 0;
    transform: translateX(-25px);
}

#custom_html-3 {
	padding-top: 0;
}
#custom_html-4, #custom_html-6 {
	padding-bottom: 1rem;
}
#colophon .footer-desc {
	max-width: 80%;
	line-height: 1.4;
	font-size: 1rem;
	color: var(--global-palette8)
}
#colophon .widget-title {
	margin-bottom: 0.5rem !important;
}
#colophon .site-middle-footer-inner-wrap > div:not(:first-child) {
	margin-top: 1rem;
}
#colophon .menu-item a {
	color: var(--global-palette8) !important;
	padding: 5px 0;
	line-height: 1.4;
}
#colophon .menu-item a:hover {
	color: var(--global-palette2) !important;
}
#colophon .footer-contact {
	list-style: none;
	padding: 0;
	margin: 0;
	color: var(--global-palette8);
}
#colophon .footer-contact a {
	color: var(--global-palette8) !important;
	text-decoration: unset !important;
}
#colophon .footer-contact a:hover {
	color: var(--global-palette2) !important;
}
#colophon .site-bottom-footer-inner-wrap .custom-html-widget {
	color: var(--global-palette8) !important;
	font-size:14px;
}