.elementor-11165 .elementor-element.elementor-element-1ec380b2{--display:flex;--flex-direction:row;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--align-items:stretch;--gap:10px 10px;--row-gap:10px;--column-gap:10px;--overlay-opacity:0.57;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:93px;--padding-bottom:318px;--padding-left:0px;--padding-right:0px;}.elementor-11165 .elementor-element.elementor-element-1ec380b2:not(.elementor-motion-effects-element-type-background), .elementor-11165 .elementor-element.elementor-element-1ec380b2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://ww3.rics.org/content/dam/rics/images/modus/built-environment/july-2022/sydney-opera-house/Modus_july22_sydneyoperahouse_landscape_header.jpg");background-position:center center;background-repeat:no-repeat;background-size:cover;}.elementor-11165 .elementor-element.elementor-element-1ec380b2::before, .elementor-11165 .elementor-element.elementor-element-1ec380b2 > .elementor-background-video-container::before, .elementor-11165 .elementor-element.elementor-element-1ec380b2 > .e-con-inner > .elementor-background-video-container::before, .elementor-11165 .elementor-element.elementor-element-1ec380b2 > .elementor-background-slideshow::before, .elementor-11165 .elementor-element.elementor-element-1ec380b2 > .e-con-inner > .elementor-background-slideshow::before, .elementor-11165 .elementor-element.elementor-element-1ec380b2 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-color:#000000;--background-overlay:'';}.elementor-11165 .elementor-element.elementor-element-3a4035f6{--display:flex;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );color:var( --e-global-color-primary );}.elementor-11165 .elementor-element.elementor-element-6f00a106 .elementor-heading-title{color:var( --e-global-color-text );}.elementor-11165 .elementor-element.elementor-element-3cb6fdcc{--display:flex;--justify-content:center;}.elementor-widget-button .elementor-button{background-color:var( --e-global-color-accent );font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-11165 .elementor-element.elementor-element-5251c2b2 .elementor-button{background-color:var( --e-global-color-primary );}.elementor-11165 .elementor-element.elementor-element-5251c2b2 .elementor-button:hover, .elementor-11165 .elementor-element.elementor-element-5251c2b2 .elementor-button:focus{background-color:#FF0000;}.elementor-11165 .elementor-element.elementor-element-5251c2b2 .elementor-button-content-wrapper{flex-direction:row-reverse;}.elementor-11165 .elementor-element.elementor-element-5251c2b2 .elementor-button .elementor-button-content-wrapper{gap:10px;}.elementor-11165 .elementor-element.elementor-element-43806dd{--display:flex;--min-height:90px;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-11165 .elementor-element.elementor-element-43806dd:not(.elementor-motion-effects-element-type-background), .elementor-11165 .elementor-element.elementor-element-43806dd > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://thelocalplug.com.au/wp-content/uploads/2024/01/construction-line-shape.png");background-repeat:repeat-x;}.elementor-11165 .elementor-element.elementor-element-81a2b8a{--display:flex;--flex-direction:row;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--align-items:stretch;--gap:10px 10px;--row-gap:10px;--column-gap:10px;--margin-top:-332px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:110px;--padding-left:0px;--padding-right:0px;}.elementor-11165 .elementor-element.elementor-element-e366d0f{--display:flex;}.elementor-11165 .elementor-element.elementor-element-1dc8687{--swiper-slides-to-display:3;--swiper-slides-gap:10px;--arrow-prev-left-align:0%;--arrow-prev-translate-x:0px;--arrow-prev-left-position:0px;--arrow-prev-top-align:50%;--arrow-prev-translate-y:-50%;--arrow-prev-top-position:0px;--arrow-next-right-align:0%;--arrow-next-translate-x:0%;--arrow-next-right-position:0px;--arrow-next-top-align:50%;--arrow-next-translate-y:-50%;--arrow-next-top-position:0px;}.elementor-11165 .elementor-element.elementor-element-1dc8687 .swiper-slide > .elementor-element{height:100%;}@media(max-width:1024px){.elementor-11165 .elementor-element.elementor-element-1dc8687{--swiper-slides-to-display:2;}}@media(max-width:767px){.elementor-11165 .elementor-element.elementor-element-1ec380b2{--padding-top:50px;--padding-bottom:50px;--padding-left:10px;--padding-right:10px;}.elementor-11165 .elementor-element.elementor-element-81a2b8a{--margin-top:-50px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-11165 .elementor-element.elementor-element-e366d0f{--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-11165 .elementor-element.elementor-element-1dc8687{--swiper-slides-to-display:1;}}@media(max-width:1024px) and (min-width:768px){.elementor-11165 .elementor-element.elementor-element-3a4035f6{--width:100%;}.elementor-11165 .elementor-element.elementor-element-3cb6fdcc{--width:100%;}}@media(min-width:1025px){.elementor-11165 .elementor-element.elementor-element-1ec380b2:not(.elementor-motion-effects-element-type-background), .elementor-11165 .elementor-element.elementor-element-1ec380b2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-attachment:scroll;}}/* Start custom CSS for heading, class: .elementor-element-491733ab *//* ========= Eyebrow line (traço antes do título) =========
   Funciona se a classe estiver:
   - no próprio span:        <span class="elementor-heading-title tlp-eyebrow">...</span>
   - no widget (sem 'r'):    <div class="tlp-eyebow elementor-widget-heading">...</div>
*/

/* Alvo principal (span com eyebrow) */
.tlp-eyebrow,
.tlp-eyebow .elementor-heading-title {
  /* Vars para ajustar tudo rápido */
  --eyebrow-line-w: 34px;         /* largura do traço */
  --eyebrow-line-h: 2px;          /* espessura do traço */
  --eyebrow-gap: 10px;            /* espaço entre traço e texto */
  --eyebrow-color: currentColor;  /* cor do traço; currentColor = herda a cor do texto */

  position: relative;
  display: inline-flex;           /* garante alinhamento horizontal */
  align-items: center;            /* centraliza o traço na altura da linha */
  gap: var(--eyebrow-gap);
}

/* O traço em si */
.tlp-eyebrow::before,
.tlp-eyebow .elementor-heading-title::before {
  content: "";
  display: inline-block;
  width: var(--eyebrow-line-w);
  height: var(--eyebrow-line-h);
  background: var(--eyebrow-color);
  flex: 0 0 auto;
  /* Ajuste fino vertical caso precise:
     transform: translateY(0.5px); */
}

/* Versão compacta para telas pequenas (opcional) */
@media (max-width: 767px) {
  .tlp-eyebrow,
  .tlp-eyebow .elementor-heading-title {
    --eyebrow-line-w: 34px;
    --eyebrow-gap: 8px;
  }
}

/* Se o título estiver com display:block por algum motivo, 
   forçamos o inline para não quebrar a linha do traço */
.tlp-eyebrow,
.tlp-eyebow .elementor-heading-title {
  /* fallback caso o tema/Elementor force block */
  white-space: normal;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-81a2b8a *//* =========================================
   SERVICE LOOP CARD - FULL HOVER EFFECT
   ========================================= */

/* Optional smoothing for transitions */
.service-loop-card,
.service-loop-card .loo-service-card-img-container,
.service-loop-card .loo-service-card-info-container,
.service-loop-card .loo-service-card-info-container .elementor-heading-title,
.service-loop-card .loo-service-card-info-container p,
.service-loop-card [id="service-loop-btn"] > .elementor-widget-container,
.service-loop-card [id="service-loop-btn"] .elementor-heading-title,
.service-loop-card [id="service-loop-btn"] .btn-arrow-icon {
  transition:
    background-color 0.28s ease,
    color 0.28s ease,
    transform 0.28s ease,
    max-width 0.38s ease,
    opacity 0.28s ease;
}

/* Card base */
.service-loop-card {
  overflow: hidden;
}

/* =========================================
   IMAGE AREA
   Keep current behavior: image block becomes primary on hover
   ========================================= */
.service-loop-card .loo-service-card-img-container {
  transition: background-color 0.28s ease;
}

.service-loop-card:hover .loo-service-card-img-container {
  background-color: var(--e-global-color-primary) !important;
}

/* =========================================
   INFO AREA
   Base background stays as the original Elementor color,
   and a dark layer slides in from left to right on hover
   ========================================= */
.service-loop-card .loo-service-card-info-container {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background-color: var(--e-global-color-7b6bc7c) !important;
}

/* Sliding dark overlay */
.service-loop-card .loo-service-card-info-container::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--e-global-color-5d1d4df);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.38s ease;
  z-index: 0;
  pointer-events: none;
}

/* Keep all inner content above the overlay */
.service-loop-card .loo-service-card-info-container > * {
  position: relative;
  z-index: 1;
}

/* Hover: dark layer fills from left to right */
.service-loop-card:hover .loo-service-card-info-container::before {
  transform: scaleX(1);
}

/* Neutralize direct background jump on hover */
.service-loop-card:hover .loo-service-card-info-container {
  background-color: var(--e-global-color-7b6bc7c) !important;
}

/* Text turns white on hover */
.service-loop-card:hover .loo-service-card-info-container .elementor-heading-title,
.service-loop-card:hover .loo-service-card-info-container h1,
.service-loop-card:hover .loo-service-card-info-container h2,
.service-loop-card:hover .loo-service-card-info-container h3,
.service-loop-card:hover .loo-service-card-info-container h4,
.service-loop-card:hover .loo-service-card-info-container h5,
.service-loop-card:hover .loo-service-card-info-container h6,
.service-loop-card:hover .loo-service-card-info-container p {
  color: #fff !important;
}

/* =========================================
   BUTTON
   Default: only arrow visible, white background, red text
   Hover: normal Elementor-like state, full text expands from left to right
   ========================================= */

/* Repeated ID exists in the HTML, so use attribute .elementor-11165 .elementor-element.elementor-element-81a2b8a safely */
.service-loop-card [id="service-loop-btn"] {
  width: auto;
  max-width: none;
}

/* Button box */
.service-loop-card [id="service-loop-btn"] > .elementor-widget-container {
  background-color: #fff !important;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 15px !important;
}

/* Hide the real text node, keep layout controlled by pseudo-elements */
.service-loop-card [id="service-loop-btn"] .elementor-heading-title {
  display: inline-flex;
  align-items: center;
  gap: 0.45em;
  margin: 0;
  line-height: 1;
  white-space: nowrap;
  overflow: hidden;
  font-size: 0 !important;
}

/* Fake text label */
.service-loop-card [id="service-loop-btn"] .elementor-heading-title::before {
  content: "Learn More";
  display: inline-block;
  overflow: hidden;
  white-space: nowrap;
  max-width: 0;
  opacity: 0;
  font-family: "Yantramanav", Sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--e-global-color-text);
  transition: max-width 0.38s ease, opacity 0.28s ease;
}

/* Real arrow stays visible by default */
.service-loop-card [id="service-loop-btn"] .btn-arrow-icon {
  display: inline-block;
  font-family: "Yantramanav", Sans-serif;
  font-size: 15px !important;
  font-weight: 600;
  line-height: 1;
  color: var(--e-global-color-primary) !important;
  transform: translateX(0);
}

/* Default state:
   only arrow visible */
.service-loop-card:not(:hover) [id="service-loop-btn"] .elementor-heading-title::before {
  max-width: 0;
  opacity: 0;
}

/* Hover state:
   button returns to normal look and text expands */
.service-loop-card:hover [id="service-loop-btn"] > .elementor-widget-container {
  background-color: var(--e-global-color-primary) !important;
}

.service-loop-card:hover [id="service-loop-btn"] .elementor-heading-title::before {
  max-width: 12ch;
  opacity: 1;
  color: var(--e-global-color-text);
}

.service-loop-card:hover [id="service-loop-btn"] .btn-arrow-icon {
  color: var(--e-global-color-text) !important;
}

/* =========================================
   MOBILE
   Preserve Elementor's mobile font size intention
   ========================================= */
@media (max-width: 767px) {
  .service-loop-card [id="service-loop-btn"] .elementor-heading-title::before,
  .service-loop-card [id="service-loop-btn"] .btn-arrow-icon {
    font-size: 30px !important;
  }
}/* End custom CSS */