/* 
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 1.0.1
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/* Improved Animations Stylesheet from https://element.how/elementor-improve-entrance-animations/ , works for the 'fade' animations */
@keyframes fadeDown{from{opacity:0;transform:translate3d(0,-30px,0)}to{opacity:1;transform:none}}.elementor-element.fadeInDown{animation-name:fadeDown}@keyframes fadeLeft{from{opacity:0;transform:translate3d(-30px,0,0)}to{opacity:1;transform:none}}.elementor-element.fadeInLeft{animation-name:fadeLeft}@keyframes fadeRight{from{opacity:0;transform:translate3d(30px,0,0)}to{opacity:1;transform:none}}.elementor-element.fadeInRight{animation-name:fadeRight}@keyframes fadeUp{from{opacity:0;transform:translate3d(0,30px,0)}to{opacity:1;transform:none}}.elementor-element.fadeInUp{animation-name:fadeUp}
select {background-image: linear-gradient(45deg, transparent 50%, gray 50%), linear-gradient(135deg, gray 50%, transparent 50%), linear-gradient(to right, #ccc, #ccc);background-position: calc(100% - 20px) calc(1em + 2px), calc(100% - 15px) calc(1em + 2px), calc(100% - 2.5em) 0.5em;background-size: 5px 5px, 5px 5px, 1px 1.5em;background-repeat: no-repeat;-webkit-appearance:none!important;-moz-appearance: none;appearance: none;}select:focus {background-image: linear-gradient(45deg, #1E3B7F 50%, transparent 50%), linear-gradient(135deg, transparent 50%, #1E3B7F 50%), linear-gradient(to right, #ccc, #ccc);background-position: calc(100% - 15px) 1em, calc(100% - 20px) 1em, calc(100% - 2.5em) 0.5em;background-size: 5px 5px, 5px 5px, 1px 1.5em;background-repeat: no-repeat;}

/*** 
* ===============
* Default Styles 
* ===============
***/
body:not(.elementor-editor-active) .elementor-menu-anchor:before {
  content: "";
  display: block;
  height: 204px; /* height of the sticky header */
  margin: -204px 0 0; /* height of the sticky header */
  visibility: hidden;
  pointer-events: none;
}
a, .elementor-button, [type=button], [type=submit], button,
.elementor-widget-jet-mega-menu > .elementor-widget-container,
.elementor-widget-media-carousel .elementor-swiper-button,
.elementor-posts .elementor-post__card,
.elementor-cta__title, .elementor-icon-list-text {
  -webkit-transition: all ease-in-out 0.3s;
  -moz-transition: all ease-in-out 0.3s;
  transition: all ease-in-out 0.3s;
}
.grecaptcha-badge {
  visibility: hidden;
  opacity: 0;
}
* {
  outline: 0!important;
}
b, strong {
  font-weight: 700;
}
.fa-facebook-f:before {
  content: "\f39e"!important;
}
textarea {
  resize: none!important;
}
ul, ol, p { 
  padding: 0;
  margin: 0;
}
p {
  margin-bottom: 12px;
}
p:last-child {
  margin-bottom: 0;
}
ul li {
  list-style-type: none;
  position: relative;
}
ul.split-two,
ol.split-two {
  padding: 0;
  list-style: none; /* Remove default bullets */
  -webkit-column-count: 2;
  -moz-column-count: 2;
  column-count: 2;
  -webkit-column-gap: 50px;
  -moz-column-gap: 50px;
  column-gap: 50px;
}
.inner-block-content ul, .inner-block-content ol, .inner-block-content p {
  margin-bottom: 1.3rem;
}
.inner-block-content p:last-child, .inner-block-content ul:last-child, .inner-block-content ol:last-child {
  margin-bottom: 0;
}
.inner-block-content ol {
  padding-left: 40px;   
}
.inner-block-content ul ul {
  margin-top: 5px;
}
.inner-block-content ul li {
  margin: 0;
  padding: 0 0 0 16px;
}
.inner-block-content ul li + li, .inner-block-content ol li + li {
  margin-top: 8px;
}
.inner-block-content ul li, .inner-block-content ol li, .inner-block-content p {
  line-height: 30px;
}
.inner-block-content .inherit ul li, .inner-block-content .inherit ol li, .inner-block-content .inherit p {
  line-height: inherit;
}
.inner-block-content ul:not(.elementor-editor-element-settings):not(.elementor-select-preset-list):not(.elementor-icon-list-items) li:before {
  background-color: var( --e-global-color-6b1fa0c );
  border-radius: 50%;
  content: '';
  width: 7px;
  height: 7px;
  left: 0;
  top: 13px;
  position: absolute;
}
.white a {
  color: #ffffff;
}
.white a:hover {
  /*color: #F5AF46;*/
}
.elementor-widget-toggle .elementor-toggle-item {
  border-bottom: 1px solid #dedede;
  padding-bottom: 8px;
}
.elementor-pagination-position-outside .swiper-container {
  padding-bottom: 0;
}
.elementor-pagination-position-outside .swiper-pagination-bullet {
  opacity: .6;
}
.elementor-pagination-position-outside .swiper-pagination-bullet-active {
  opacity: 1;
}
.swiper-pagination-bullet { 
  opacity: .5;
}
.swiper-pagination-bullet-active {
  opacity: 1;
}
.elementor-custom-embed-play {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(237, 28, 36, 0.90);
  border-radius: 50%;
  width: 105px;
  height: 105px;
  -webkit-transition: all .5s;
  -moz-transition: all .5s;
  transition: all .5s;
}
.small-play-btn .elementor-custom-embed-play {
  width: 64px;
  height: 64px;
}
.small-play-btn .elementor-custom-embed-play i {
  font-size: 25px;
}
.elementor-custom-embed-play i {
  font: 900 40px "Font Awesome 5 Free";
  text-shadow: none;
  opacity: 1;
  margin-left: 4px;
}
.elementor-custom-embed-play i:before {
  content: "\f04b";
}
.bg-image-cover-padded,
.bg-image-cover {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  position: relative;
}
.bg-image-cover-padded:after {
  padding-top: 100%;
  display: block;
  content: '';
}
.elementor-nav-menu--dropdown .elementor-item, 
.elementor-sub-item {
  background-color: transparent!important;
}
.elementor-widget-icon-box .elementor-icon-box-title,
.elementor-vertical-align-middle .elementor-image-box-title,
.elementor-vertical-align-top .elementor-image-box-title {
  margin-top: 0;
}
.elementor-widget-media-carousel .swiper-pagination-bullets {
  bottom: 26px;
}
.elementor-widget-media-carousel .elementor-swiper-button {
  color: #fff;
}
.elementor-widget-media-carousel .elementor-swiper-button {
  background-color: rgba(0,0,0,0.5);
  padding: 5px 2px;
  opacity: 0;
}
.elementor-widget-media-carousel:hover .elementor-swiper-button {
  opacity: 1;
}
.main-heading .elementor-heading-title,
.main-heading .elementor-image-box-title {
  font-size: 48px;
  line-height: 48px;
}
.main-heading .elementor-heading-title span {
  /*color: #D9024C;*/
}

.table-responsive {
  display: block;
  text-align: center;
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: -ms-autohiding-scrollbar;
}
table tbody tr > td {
  background-color: transparent!important;
}
.yt-container {
  position: relative;
  overflow: hidden;
  width: 100%;
  padding-top: 56.25%; /* 16:9 Aspect Ratio (divide 9 by 16 = 0.5625) */
}
/* Then style the iframe to fit in the container div with full height and width */
.yt-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

/* display none goes here */
.elementor-lightbox footer .elementor-slideshow__title,
.wpcf7-form-control-wrap span.wpcf7-not-valid-tip,
.elementor-widget-media-carousel .swiper-slide-shadow-left,
.elementor-widget-media-carousel .swiper-slide-shadow-right,
#header-block .sub-arrow {
  display: none!important;
}

.half-img-left {
  margin: 0 0 0 calc(((100vw - var(--content-width) ) / 2) * -1);
}
.half-img-right {
  margin: 0 calc((( 100vw - var(--content-width) ) / 2) * -1) 0 0;
}

/*** 
* ========
* Header 
* ========
***/
#header-block {
  -webkit-box-shadow: 0px 5px 5px 0px rgb(0 0 0 / 5%);
  -moz-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.05);
  box-shadow: 0px 5px 5px 0px rgb(0 0 0 / 5%);
}

/* Inner Hero */
#inner-hero h1 {
  color: inherit;
  font-size: inherit;
  line-height: inherit;
  margin: 0;
}

/* Services Grid */
.services-grid {
  display: flex;
  flex-wrap: wrap;
  padding: 5px;
}
.services-grid .services-item {
  padding: 5px;
  flex-basis: 33.333333%;
  width: 33.333333%;
}
.services-grid a {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  position: relative;
  max-height: 400px;
}
.services-grid a:before {
  background-color: rgba(0,0,0,0.2);
  content: '';
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  position: absolute;
  -webkit-transition: all ease-in-out 0.3s;
  -moz-transition: all ease-in-out 0.3s;
  transition: all ease-in-out 0.3s;
}
.services-grid a:hover:before {
  background-color: rgba(0,0,0,0.4);
}
.services-grid a:after {
  padding-top: 63%;
}
.services-grid a h2 {
  color: #fff;
  margin: 0;
  padding: 15px 20px;
  text-shadow: 0 0 8px #0000002e;
  position: absolute;
}
.services-grid a h2:after {
  background-color: var( --e-global-color-6b1fa0c );
  display: block;
  content: '';
  height: 5px;
  width: 28px;
  bottom: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  position: absolute;
}

/*** 
* ============================
* Contact Form Styles 
* ============================
***/
.wpcf7 input:not([type="submit"]),
.wpcf7 textarea,
.wpcf7 select {
  font-size: 18px;
  color: #2f2e31!important;
  border: 1px solid white;
  border-radius: 0;
  margin-bottom: 11px;
  padding: 13px 18px 14px;
}
.wpcf7 textarea {
  height: 110px;
  margin-bottom: 15px;
}
.wpcf7 .submit-btn { 
  width: 100%;
  position: relative;
}
.wpcf7 input[type="submit"] {
  border: 0;
  background-color: #1e285b;
  letter-spacing: 0.5px;
  padding: 14px 35px 15px;
}
.wpcf7 input[type="submit"]:hover,
.wpcf7 input[type="submit"]:focus { 
  
}
.wpcf7 .wpcf7-spinner {
  
}

.wpcf7 textarea::moz-placeholder,
.wpcf7 input::moz-placeholder,
.wpcf7 select::moz-placeholder {
  color: #2f2e31!important;
}
.wpcf7 textarea::-webkit-input-placeholder,
.wpcf7 input::-webkit-input-placeholder,
.wpcf7 select::-webkit-input-placeholder {
  color: #2f2e31!important;
}
.wpcf7 textarea::placeholder,
.wpcf7 input::placeholder,
.wpcf7 select::placeholder {
  color: #2f2e31!important;
}
.wpcf7 form.invalid .wpcf7-response-output, 
.wpcf7 form.unaccepted .wpcf7-response-output {
  background-color: red;
}
.wpcf7 form .wpcf7-response-output {
  background-color: #f16826;
  color: #fff;
  border: 0;
  font-weight: 500;
  font-size: 15px;
  text-align: center!important;
  line-height: normal;
  position: absolute;
  padding: 10px 20px;
  margin: 10px 0 0;
}
.wpcf7 input.wpcf7-not-valid,
.wpcf7 select.wpcf7-not-valid,
.wpcf7 textarea.wpcf7-not-valid {
  border: 1px solid #f00!important;
}

.raq-form {
  font-size: 16px;
  margin: 0 -6px;
}
.raq-form .col-item {
  padding: 0 6px;
}
.raq-form .col-half {
  float: left;
  width: 50%;
}
.raq-form .full-width {
  clear: both;
}
.raq-form .submit-btn {
  text-align: center;
  margin-top: 20px;
}
.raq-form .submit-btn input[type="submit"] { 
  max-width: 180px;
  width: 100%;
}
.raq-form .wpcf7-spinner {
  right: 0;
  top: 14px;
  position: absolute;
}
.wpcf7 .raq-form input:not([type="submit"]), 
.wpcf7 .raq-form textarea {
  font-size: 16px;
  border-color: #ccc;
  padding: 10px 18px 11px;
}
.wpcf7 .raq-form textarea { 
  height: 90px;
  margin-bottom: 5px;
}
.raq-form .checkbox-opt {
  margin-bottom: 4px;
}
.raq-form .wpcf7-checkbox {
  display: block;
  -webkit-column-count: 3;
  -moz-column-count: 3;
  column-count: 3;
  -webkit-column-gap: 10px;
  -moz-column-gap: 10px;
  column-gap: 10px;
  margin-top: 2px;
}
.raq-form .checkbox-opt label,
.raq-form .textarea label,
.raq-form .file-upload label {
  font-weight: 700;
  display: block;
  margin-bottom: 5px;
}
.raq-form .checkbox-opt label sup {
  color: red;
}
.raq-form .wpcf7-list-item {
  line-height: 18px;
  display: block;
  margin: 0;
  padding: 3px 0 3px 20px;
  position: relative;
}
.wpcf7 form .raq-form .wpcf7-response-output {
  background-color: transparent!important;
  position: static;
  color: red;
  padding: 0 10px 10px;
  margin: 0;
}
.wpcf7 form.sent .raq-form .wpcf7-response-output {
  color: #F06826;
}
.wpcf7-checkbox input[type="checkbox"],
.wpcf7-radio input[type="radio"] {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 2;
}
.raq-form .wpcf7-checkbox .wpcf7-list-item-label:before,
.wpcf7-radio .wpcf7-list-item-label:before {
  position: absolute;
  top: 4px;
  left: 0;
  height: 15px;
  width: 15px;
  border: 1px solid #7f7f7f;
  border-radius: 0;
}
.raq-form .wpcf7-checkbox .wpcf7-list-item-label:after,
.wpcf7-radio .wpcf7-list-item-label:after {
  content: "";
  display: none;
  left: 5px;
  top: 6px;
  width: 5px;
  height: 9px;
  border: solid white;
  border-width: 0 2px 2px 0;
  position: absolute;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
.raq-form .wpcf7-checkbox input[type="checkbox"]:checked ~ .wpcf7-list-item-label:before,
.wpcf7-radio input:checked ~ .wpcf7-list-item-label:before {
  border-color: #2CAE4A; 
  background-color: #2CAE4A;
}
.raq-form .wpcf7-checkbox input[type="checkbox"]:checked ~ .wpcf7-list-item-label:after,
.wpcf7-radio input:checked ~ .wpcf7-list-item-label:after {
  display: block;
}

.wpcf7-radio .wpcf7-list-item {
  padding: 3px 10px 3px 20px;
  margin: 0;
  position: relative;
}
.wpcf7-form .wpcf7-radio {
  display: block;
  -webkit-column-count: 2;
  -moz-column-count: 2;
  column-count: 2;
  -webkit-column-gap: 10px;
  -moz-column-gap: 10px;
  column-gap: 10px;
  margin-bottom: 12px;
}

.alarm-package-form textarea {
  margin-bottom: 6px;
}
.alarm-package-form .wpcf7-radio .wpcf7-list-item {
  color: #fff;
}
.alarm-package-form .wpcf7-radio .wpcf7-list-item-label:before {
  border-color: #fff;
  top: 6px;
}
.alarm-package-form .wpcf7-radio .wpcf7-list-item-label:after {
  top: 8px;
}
.alarm-package-form .wpcf7-radio input:checked ~ .wpcf7-list-item-label:before {
  border-color: #1E285B;
  background-color: #1E285B;
}

.alarm-monitoring-form .wpcf7 input:not([type="submit"]), 
.alarm-monitoring-form .wpcf7 textarea,
.employment-form input:not([type="submit"]),
.employment-form textarea {
  border-color: #ccc;
}

.alarm-monitoring-form  textarea {
  margin-bottom: 5px;
}
.alarm-monitoring-form label {
  font-weight: 700;
  display: block;
  margin-bottom: 8px;
}
.alarm-monitoring-form .wpcf7-radio .wpcf7-list-item-label:before {
  top: 7px;
}
.alarm-monitoring-form .wpcf7-radio .wpcf7-list-item-label:after {
  top: 9px;
}
.alarm-monitoring-form .submit-btn input {
  width: 100%;
}
.alarm-monitoring-form .submit-btn input:hover {
  background-color: var( --e-global-color-6b1fa0c );
}
.alarm-monitoring-form .submit-btn .wpcf7-spinner {
  right: 0;
  top: 15px;
  position: absolute;
}

.employment-form {
  margin: 0 -6px;
}
.employment-form .col-item {
  padding: 0 6px;
}
.employment-form .col-half {
  float: left;
  width: 50%;
}
.employment-form .full-width {
  clear: both;
}
.employment-form label {
  font-weight: 700;
  margin-bottom: 6px;
}
.employment-form .submit-btn {
  margin-top: 30px;
}
.employment-form .submit-btn input {
  max-width: 240px;
  width: 100%;
}

.input-file-overlay {
  display: flex;
  line-height: normal;
}
.input-file-overlay .select-file {
  text-transform: uppercase;
  background: #268037;
  color: #fff;
  font-weight: bold;
  font-size: 15px;
  width: 155px;
  text-align: center;
  line-height: 48px;
  cursor: pointer;
}
.input-file-overlay input {
  padding: 10px 20px 10px 30px !important;
  pointer-events: none;
  margin-bottom: 0!important;
}


/*** 
* ==============
* Media Query
* ==============
***/
@media (min-width: 1025px) {
  .hide-pagination .swiper-pagination-bullets {
    display: none;
  }
  .hide-pagination .elementor-swiper {
    cursor: auto;
    pointer-events: none;
  }   
}
@media (max-width: 1199px) {
  .services-grid a h2 {
    font-size: 35px;
  }
}
@media (max-width: 1024px) {
  .elementor-custom-embed-play {
    width: 75px;
    height: 75px;
  }
  .elementor-custom-embed-play i {
    font-size: 32px;
  }
  .elementor-widget-media-carousel .swiper-pagination-bullets {
    bottom: 10px;
  }
  .main-heading .elementor-heading-title,
  .main-heading .elementor-image-box-title {
    font-size: 38px;
    line-height: 40px;
  }
  .half-img-right {
    margin: 0;
  }

  .services-grid a h2 {
    font-size: 32px;
  }
}
@media (max-width: 991px) {
  .services-grid {
    padding: 2px;
  }
  .services-grid .services-item {
    padding: 2px;
  }
  .services-grid a h2 {
    font-size: 25px;
    padding: 10px;
  }
  .services-grid a h2:after {
    height: 2px;
  }
}
@media (max-width: 767px) {
  .elementor-widget-media-carousel .swiper-pagination-bullets .swiper-pagination-bullet {
    height: 12px!important;
    width: 12px!important;
  }
  ul.split-two,
  ol.split-two {
    -webkit-column-count: 1;
    -moz-column-count: 1;
    column-count: 1;
  }
  .main-heading .elementor-heading-title, 
  .main-heading .elementor-image-box-title {
    font-size: 32px;
    line-height: 32px;
  }

  .inner-block-content ul li, .inner-block-content ol li, .inner-block-content p {
    line-height: 26px;
  }
  .inner-block-content .inherit ul li, .inner-block-content .inherit ol li, .inner-block-content .inherit p {
    line-height: inherit;
  }

  .services-grid .services-item {
    flex-basis: 50%;
    width: 50%;
  }
  .services-grid a h2 {
    font-size: 21px;
    line-height: 19px;
    text-align: center;
  }

  .project-listing .elementor-widget-icon {
    width: 100%;
  }
  .project-listing .elementor-widget-icon .elementor-widget-container {
    max-height: 436px;
  }
  .project-listing .elementor-widget-icon .elementor-widget-container:after {
    padding-top: 60%;
  }

  .wpcf7 form .wpcf7-response-output {
    position: static;
  }

  .elementor-widget-text-editor img.alignright,
  .elementor-widget-text-editor img.alignleft {
    display: block;
    float: none;
    margin: 0 0 10px;
  }

}

@media (max-width: 350px) {  

}