.elementor-103 .elementor-element.elementor-element-7282f7c{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-103 .elementor-element.elementor-element-703fad0{--display:flex;}.elementor-103 .elementor-element.elementor-element-6bc5d22{--display:flex;--min-height:477px;--justify-content:space-around;}.elementor-103 .elementor-element.elementor-element-812e39a{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-103 .elementor-element.elementor-element-812e39a.elementor-element{--align-self:stretch;}.elementor-103 .elementor-element.elementor-element-783033e{--display:flex;--justify-content:space-around;}.elementor-103 .elementor-element.elementor-element-f54774f.elementor-element{--align-self:stretch;}.elementor-103 .elementor-element.elementor-element-eb77077{--display:flex;--min-height:677px;--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:center;}.elementor-103 .elementor-element.elementor-element-e4dcc47{--display:flex;}.elementor-103 .elementor-element.elementor-element-b7a0003{--display:flex;--overlay-opacity:0.43;box-shadow:0px 0px 10px 0px rgba(0,0,0,0.5);}.elementor-103 .elementor-element.elementor-element-b7a0003::before, .elementor-103 .elementor-element.elementor-element-b7a0003 > .elementor-background-video-container::before, .elementor-103 .elementor-element.elementor-element-b7a0003 > .e-con-inner > .elementor-background-video-container::before, .elementor-103 .elementor-element.elementor-element-b7a0003 > .elementor-background-slideshow::before, .elementor-103 .elementor-element.elementor-element-b7a0003 > .e-con-inner > .elementor-background-slideshow::before, .elementor-103 .elementor-element.elementor-element-b7a0003 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-color:#02010100;--background-overlay:'';}:root{--page-title-display:none;}/* Start custom CSS for html, class: .elementor-element-b77a424 */.elementor-103 .elementor-element.elementor-element-b77a424{
  position: relative;
  z-index: 1;
  font-family: "Outfit", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: #0F172A;
}


/* ===================== HERO ===================== */
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero{
  position: relative;
  overflow: hidden;
  padding: 90px 0 80px;
  background: #F9FAFB;
}
@media (min-width: 1024px){
  .elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero{ padding: 120px 0 110px; }
}

/* blobs de fundo */
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__bg{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-blob{
  position:absolute;
  border-radius:999px;
  filter: blur(48px);
  opacity:.9;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-blob--a{
  width: 430px; height: 430px;
  top: -140px; right: -140px;
  background: rgba(245, 158, 11, .16);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-blob--b{
  width: 370px; height: 370px;
  bottom: -140px; left: -140px;
  background: rgba(59, 130, 246, .14);
}

.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__wrap{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 48px;
  align-items:center;
}
@media (max-width: 980px){
  .elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__wrap{
    grid-template-columns:1fr;
    gap: 34px;
  }
}

/* kicker */
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 8px 14px;
  border-radius:999px;
  background: rgba(245,158,11,.10);
  border: 1px solid rgba(245,158,11,.18);
  color: #B45309;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-dot{
  width: 10px; height: 10px;
  border-radius:999px;
  background: #F59E0B;
  box-shadow: 0 0 0 6px rgba(245,158,11,.18);
  animation: tfPulse 1.8s infinite;
}
@keyframes tfPulse{
  0%, 100% { transform: scale(1); opacity:1; }
  50% { transform: scale(.85); opacity:.85; }
}

/* título */
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__title{
  margin: 18px 0 12px;
  font-family: "Playfair Display", ui-serif, Georgia, "Times New Roman", serif;
  font-size: clamp(40px, 5.2vw, 74px);
  line-height: 1.02;
  letter-spacing: -.02em;
  color: #0F172A;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-grad{
  background-image: linear-gradient(to right, #F59E0B, #D97706);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__subtitle{
  margin: 0 0 18px;
  color: rgba(15,23,42,.68);
  font-size: 18px;
  line-height: 1.65;
  max-width: 54ch;
}

/* botões */
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__cta{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin: 14px 0 18px;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 14px 22px;
  border-radius: 16px;
  font-weight: 800;
  text-decoration:none;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease;
  will-change: transform;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .btn--primary{
  background: #F59E0B;
  color: #fff;
  box-shadow: 0 18px 30px rgba(245,158,11,.25);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .btn--primary:hover{
  background: #D97706;
  transform: translateY(-2px);
  box-shadow: 0 22px 40px rgba(245,158,11,.35);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .btn--ghost{
  background: rgba(255,255,255,.95);
  border: 1px solid rgba(15,23,42,.12);
  color: #0F172A;
  box-shadow: 0 10px 20px rgba(15,23,42,.06);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .btn--ghost:hover{
  background: rgba(255,255,255,1);
  transform: translateY(-2px);
  box-shadow: 0 14px 26px rgba(15,23,42,.10);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .btn .material-symbols-outlined{
  font-size: 18px;
}

/* meta cards (grid tipo Google) */
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__meta{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 10px;
}
@media (max-width: 980px){
  .elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__meta{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 520px){
  .elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__meta{
    grid-template-columns: 1fr;
  }
}

.elementor-103 .elementor-element.elementor-element-b77a424 .tf-pill{
  display:flex;
  align-items:center;
  gap:12px;
  padding: 12px 12px;
  border-radius: 14px;
  text-decoration:none;
  color:#0F172A;

  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 10px 18px rgba(15,23,42,.06);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-pill:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(15,23,42,.10);
  border-color: rgba(15,23,42,.14);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-pill__ic{
  width: 42px; height: 42px;
  display:grid; place-items:center;
  border-radius: 999px;
  background: rgba(15,23,42,.06);
  border: 1px solid rgba(15,23,42,.10);
  flex: 0 0 auto;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-pill__ic .material-symbols-outlined{ font-size: 20px; }

.elementor-103 .elementor-element.elementor-element-b77a424 .tf-pill__tx{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-pill__tx strong{ font-size: 13px; }
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-pill__tx small{
  font-size: 12px;
  color: rgba(15,23,42,.60);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.elementor-103 .elementor-element.elementor-element-b77a424 .tf-pill--wa{
  background: rgba(34,197,94,.10);
  border-color: rgba(34,197,94,.22);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-pill--wa .tf-pill__ic{
  background: rgba(34,197,94,.14);
  border-color: rgba(34,197,94,.22);
  color: rgba(22,163,74,1);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-pill--note{
  background: rgba(245,158,11,.10);
  border-color: rgba(245,158,11,.22);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-pill--note .tf-pill__ic{
  background: rgba(245,158,11,.14);
  border-color: rgba(245,158,11,.22);
  color: #B45309;
}

/* ===================== MEDIA CARD ===================== */
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__media{
  position: relative;
  border-radius: 26px;
  overflow: hidden;
  min-height: 460px;

  border: 4px solid rgba(255,255,255,.95);
  box-shadow: 0 30px 70px rgba(15,23,42,.18);
  background: #fff;
}
@media (max-width: 980px){
  .elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__media{ min-height: 420px; }
}

.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__photo{
  position:absolute;
  inset:0;
  background-image: var(--tf-hero-img);
  background-size: cover;
  background-position: center;
  transform: scale(1);
  transition: transform .7s ease;
  filter: saturate(1.05) contrast(1.02);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__media:hover .tf-hero__photo{
  transform: scale(1.05);
}


/* stamp glass */
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__stamp{
  position:absolute;
  left: 18px;
  bottom: 18px;
  right: 18px;

  display:flex;
  align-items:center;
  gap:14px;
  padding: 14px 14px;
  border-radius: 18px;

  background: rgba(255,255,255,.66);
  border: 1px solid rgba(15,23,42,.10);
  backdrop-filter: blur(2px);
  box-shadow: 0 18px 38px rgba(15,23,42,.14);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__stampImg{
  width: 72px;
  height: 72px;
  border-radius: 14px;
  background-image: var(--tf-logo-img);
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(15,23,42,.12);
  opacity:.92;
  flex: 0 0 auto;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__stampText strong{
  display:block;
  font-size: 16px;
  letter-spacing: -.01em;
  color: #0F172A;
  font-weight: 900;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-hero__stampText small{
  display:block;
  font-size: 12px;
  margin-top: 2px;
  color: rgba(15,23,42,.62);
  font-weight: 600;
}

/* stars */
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-stars{
  display:flex;
  align-items:center;
  gap:2px;
  margin-top: 6px;
  color: #F59E0B;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-stars .material-symbols-outlined{
  font-size: 18px;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-stars__note{
  margin-left: 6px;
  font-size: 12px;
  color: rgba(15,23,42,.55);
  font-weight: 700;
}

/* detalhes decorativos */
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-ring{
  position:absolute;
  border-radius: 999px;
  pointer-events:none;
  z-index: 0;
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-ring--a{
  width: 150px; height: 150px;
  top: -40px; right: -40px;
  border: 4px solid rgba(245,158,11,.18);
}
.elementor-103 .elementor-element.elementor-element-b77a424 .tf-ring--b{
  width: 90px; height: 90px;
  bottom: -26px; left: -26px;
  background: rgba(245,158,11,.18);
  filter: blur(16px);
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-812e39a *//* ===== Torre Forte | Serviços (estilo Google) ===== */
.elementor-103 .elementor-element.elementor-element-812e39a{
  position: relative;
  z-index: 1;
}

/* seção */
.elementor-103 .elementor-element.elementor-element-812e39a .tf-services{
  position: relative;
  padding: 96px 0;
  background: #fff;
}

/* cabeçalho */
.elementor-103 .elementor-element.elementor-element-812e39a .tf-sectionHead{
  text-align:center;
  max-width: 768px;
  margin: 0 auto 64px;
}

.elementor-103 .elementor-element.elementor-element-812e39a .tf-sectionHead__kicker{
  display:inline-block;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: #F59E0B;
  margin-bottom: 8px;
}

.elementor-103 .elementor-element.elementor-element-812e39a .tf-sectionHead h2{
  margin: 0 0 14px;
  font-family: "Playfair Display", ui-serif, Georgia, "Times New Roman", serif;
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -.02em;
  color: #0F172A;
}

.elementor-103 .elementor-element.elementor-element-812e39a .tf-sectionHead p{
  margin: 0;
  font-size: 16px;
  line-height: 1.7;
  color: rgba(15,23,42,.65);
}

/* grid */
.elementor-103 .elementor-element.elementor-element-812e39a .tf-services__grid{
  display:grid;
  gap: 32px; /* igual Google */
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 980px){
  .elementor-103 .elementor-element.elementor-element-812e39a .tf-services__grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 560px){
  .elementor-103 .elementor-element.elementor-element-812e39a .tf-services__grid{ grid-template-columns: 1fr; }
}

/* card */
.elementor-103 .elementor-element.elementor-element-812e39a .tf-svc{
  position: relative;
  overflow:hidden;
  padding: 32px;
  border-radius: 20px; /* 2xl-ish */
  background: #F9FAFB;  /* background-light */
  border: 1px solid transparent;
  box-shadow: none;

  transition:
    transform .28s ease,
    box-shadow .28s ease,
    border-color .28s ease;
}

/* hover do card (levanta + sombra + borda laranja) */
.elementor-103 .elementor-element.elementor-element-812e39a .tf-svc:hover{
  transform: translateY(-8px);
  border-color: rgba(245,158,11,.30);
  box-shadow: 0 22px 45px rgba(15,23,42,.12);
}

/* ícone gigante decorativo (canto superior direito) */
.elementor-103 .elementor-element.elementor-element-812e39a .tf-svc__bgIcon{
  position:absolute;
  top: 0;
  right: 0;
  padding: 18px;
  opacity: .10;
  transition: opacity .28s ease;
  pointer-events:none;
}
.elementor-103 .elementor-element.elementor-element-812e39a .tf-svc:hover .tf-svc__bgIcon{
  opacity: .18;
}

/* deixa o ícone gigante realmente gigante */
.elementor-103 .elementor-element.elementor-element-812e39a .tf-svc__bgIcon .material-symbols-outlined{
  font-size: 110px;
  line-height: 1;
  color: #F59E0B;
}

/* ícone pequeno (quadrado arredondado) */
.elementor-103 .elementor-element.elementor-element-812e39a .tf-svc__ic{
  width: 56px;
  height: 56px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom: 18px;

  background: rgba(245,158,11,.18);
  color: #F59E0B;

  transition:
    background .28s ease,
    color .28s ease,
    transform .28s ease;
}

.elementor-103 .elementor-element.elementor-element-812e39a .tf-svc__ic .material-symbols-outlined{
  font-size: 26px;
  line-height: 1;
}

/* hover: vira laranja sólido com ícone branco */
.elementor-103 .elementor-element.elementor-element-812e39a .tf-svc:hover .tf-svc__ic{
  background: #F59E0B;
  color: #fff;
  transform: translateY(-1px);
}

/* textos */
.elementor-103 .elementor-element.elementor-element-812e39a .tf-svc h3{
  margin: 0 0 12px;
  font-size: 20px;      /* text-xl */
  font-weight: 800;
  letter-spacing: -.01em;
  color: #0F172A;
}

.elementor-103 .elementor-element.elementor-element-812e39a .tf-svc p{
  margin: 0;
  font-size: 14px;      /* text-sm */
  line-height: 1.7;     /* leading-relaxed */
  color: rgba(15,23,42,.62);
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-f54774f *//* ===== Projetos ===== */
.section__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
}
.section__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
@media (max-width: 900px){
  .section__head{flex-direction:column; align-items:flex-start;}
}

.projects{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:16px;
  margin-top: 18px;
}
@media (max-width: 980px){
  .projects{grid-template-columns: repeat(2, minmax(0, 1fr));}
}
@media (max-width: 620px){
  .projects{grid-template-columns: 1fr;}
}

.btn, .btn:link, .btn:visited, .btn:hover, .btn:active{
  text-decoration: none !important;
}
.project{
  border-radius:18px;
  border:1px solid rgba(17,24,39,.08);
  background: rgba(255,255,255,.70);
  box-shadow: 0 10px 30px rgba(17,24,39,.06);
  overflow:hidden;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.project:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 45px rgba(17,24,39,.10);
  border-color: rgba(17,24,39,.12);
}

.project__media{
  position:relative;
  height:160px;
  overflow:hidden;
}
.project__badge{
  position:absolute;
  left:12px;
  top:12px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  color:#111827;
  background: rgba(245,166,35,.95);
  border: 1px solid rgba(0,0,0,.06);
}

.project__body{
  padding:14px 14px 16px;
}
.project__title{
  margin: 2px 0 6px;
  font-size: 16px;
  letter-spacing:-.01em;
}
.project__meta{
  margin:0 0 12px;
  color: rgba(31,41,55,.75);
  font-size: 13px;
}

.project__tags{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.tag{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  color: rgba(17,24,39,.85);
  background: rgba(17,24,39,.04);
  border:1px solid rgba(17,24,39,.08);
}

/* placeholder bonito (se você ainda não tem foto) */
.ph{
  background:
    radial-gradient(900px 420px at 50% -10%, rgba(0,0,0,.06), transparent 60%),
    linear-gradient(180deg, rgba(17,24,39,.06), rgba(17,24,39,.02));
}
.ph::after{
  content:"Foto do projeto";
  position:absolute;
  left:12px;
  bottom:12px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  background: rgba(255,255,255,.85);
  border:1px solid rgba(17,24,39,.10);
  color: rgba(17,24,39,.75);
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-783033e */.project__media{
  position: relative;
  height: 160px;
  overflow: hidden;
  background: none !important; /* mata qualquer placeholder antigo */
}

.project__img{
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  display: block !important;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-9f3e6bc *//* ====== ESQUERDA (Por que escolher) ====== */
.tf-why h2{
  margin:0 0 10px;
  font-size: clamp(26px, 2.2vw, 34px);
  letter-spacing:-.02em;
}
.tf-why__lead{
  margin:0 0 18px;
  color: rgba(31,41,55,.80);
  max-width: 62ch;
}
.tf-why__list{display:flex;flex-direction:column;gap:14px;margin-top:10px}
.tf-why__item{
  display:flex; gap:14px; align-items:flex-start;
  padding:16px;
  border-radius:18px;
  background: rgba(17,24,39,.02);
  border:1px solid rgba(17,24,39,.06);
}
.tf-why__icon{
  width:38px;height:38px;border-radius:14px;
  display:grid;place-items:center;
  background: rgba(245,166,35,.16);
  border:1px solid rgba(245,166,35,.30);
  color:#9a5b00;
  font-weight:900;
  flex:0 0 auto;
}
.tf-why__txt h3{margin:0 0 4px;font-size:16px}
.tf-why__txt p{margin:0;color:rgba(31,41,55,.75);font-size:14px}

/* ====== DIREITA (Painel escuro) ====== */
/* Aplique a classe abaixo no CONTAINER da direita: Advanced > CSS Classes */
.tf-quote-panel{
  background: linear-gradient(180deg, rgba(18,24,38,.96), rgba(18,24,38,.92));
  color:#fff;
  border-radius:24px;
  padding:22px;
  border:1px solid rgba(255,255,255,.10);
  box-shadow: 0 18px 45px rgba(17,24,39,.14);
}
.tf-quote h2{margin:0 0 12px;font-size:22px}
.tf-quote__info{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.tf-pill{
  display:flex; align-items:center; gap:10px;
  padding:12px 14px;
  border-radius:14px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color:#fff;
  text-decoration:none;
}
.tf-pill:hover{opacity:.95}

/* ====== Estilo do FORM do Elementor dentro do painel ====== */
.tf-quote-panel .elementor-form input,
.tf-quote-panel .elementor-form textarea,
.tf-quote-panel .elementor-field{
  border-radius:14px !important;
  border:1px solid rgba(255,255,255,.14) !important;
  background: rgba(255,255,255,.06) !important;
  color:#fff !important;
}
.tf-quote-panel .elementor-form input:focus,
.tf-quote-panel .elementor-form textarea:focus{
  border-color: rgba(245,166,35,.65) !important;
  box-shadow: 0 0 0 4px rgba(245,166,35,.18) !important;
}
.tf-quote-panel .elementor-button{
  border-radius:14px !important;
  font-weight:800 !important;
  background: linear-gradient(180deg, #f5a623, #ff8a00) !important;
  color:#111827 !important;
  border:none !important;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-e4dcc47 */.tf-quote-panel{
  position: relative;
  overflow: hidden;
  border-radius: 24px;

  /* base */
  background: linear-gradient(180deg, #141b2a 0%, #0b1020 100%);
  border: 1px solid rgba(255,255,255,.10);

  /* sombra externa + “profundidade” */
  box-shadow:
    0 18px 45px rgba(17,24,39,.18),
    inset 0 1px 0 rgba(255,255,255,.06),
    inset 0 -1px 0 rgba(0,0,0,.35);
}

/* brilho e vinheta por cima */
.tf-quote-panel:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;

  background:
    /* brilho suave no topo */
    radial-gradient(900px 500px at 50% -10%, rgba(255,255,255,.10), transparent 55%),
    /* glow lateral (tipo luz refletindo) */
    radial-gradient(700px 500px at -10% 40%, rgba(245,166,35,.12), transparent 60%),
    /* vinheta (escurece bordas) */
    radial-gradient(1200px 900px at 50% 50%, transparent 55%, rgba(0,0,0,.35) 100%);

  opacity: 1;
}

/* textura “granulada” (opcional, mas deixa mais real) */
.tf-quote-panel:after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.06;
  mix-blend-mode: overlay;

  background-image:
    repeating-linear-gradient(0deg,
      rgba(255,255,255,.06) 0px,
      rgba(255,255,255,.06) 1px,
      transparent 2px,
      transparent 4px
    ),
    repeating-linear-gradient(90deg,
      rgba(0,0,0,.08) 0px,
      rgba(0,0,0,.08) 1px,
      transparent 2px,
      transparent 5px
    );
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-1c3acff */.elementor-103 .elementor-element.elementor-element-1c3acff .tf-contactCard{
  position: relative;
  overflow: hidden;
  border-radius: 26px;
  padding: 26px;
  background: #0F172A;                 /* dark-blue */
  border: 1px solid rgba(148,163,184,.18);
  box-shadow: 0 28px 70px rgba(0,0,0,.35);
}

@media (min-width: 768px){
  .elementor-103 .elementor-element.elementor-element-1c3acff .tf-contactCard{ padding: 34px; }
}

/* blob laranja no canto (igual google) */
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-contactCard__blob{
  position: absolute;
  width: 340px;
  height: 340px;
  top: -120px;
  right: -120px;
  border-radius: 999px;
  background: rgba(245,158,11,.22);
  filter: blur(48px);
  pointer-events: none;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-contactCard__inner{
  position: relative;
  z-index: 1;
}

/* título e subtítulo */
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-contactCard__title{
  margin: 0 0 6px;
  color: #fff;
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -.02em;
  font-family: "Playfair Display", ui-serif, Georgia, "Times New Roman", serif;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-contactCard__sub{
  margin: 0 0 18px;
  color: rgba(148,163,184,.85);
  font-size: 13px;
  line-height: 1.5;
}

/* lista */
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-contactCard__list{
  display: grid;
  gap: 12px;
  margin-top: 8px;
}

/* row link (tel/wa) */
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;

  padding: 14px 14px;
  border-radius: 16px;

  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  text-decoration: none;

  transition: background .16s ease, border-color .16s ease, transform .16s ease;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-row:hover{
  background: rgba(255,255,255,.09);
  border-color: rgba(255,255,255,.14);
  transform: translateY(-1px);
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-row__left{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 0;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-row__txt{
  min-width: 0;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-row__label{
  margin:0;
  color:#fff;
  font-weight: 800;
  font-size: 13px;
  line-height: 1.2;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-row__value{
  margin:2px 0 0;
  color: rgba(148,163,184,.90);
  font-size: 12px;
  line-height: 1.25;
}

/* chevron */
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-row__chev{
  color: rgba(148,163,184,.85);
  font-size: 22px;
  transition: color .16s ease;
}
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-row:hover .tf-row__chev{
  color: #fff;
}

/* ícones redondos coloridos */
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-ico{
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border: 1px solid rgba(255,255,255,.06);
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-ico .material-symbols-outlined{
  font-size: 20px;
  line-height: 1;
}

/* variantes de cor */
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-ico--blue{
  background: rgba(37, 99, 235, .20);
  color: #60A5FA;
}
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-ico--green{
  background: rgba(34, 197, 94, .20);
  color: #34D399;
}
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-ico--purple{
  background: rgba(168, 85, 247, .20);
  color: #C084FC;
}

/* card email */
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-mail{
  padding: 14px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-mail__top{
  display:flex;
  align-items:flex-start;
  gap: 12px;
  margin-bottom: 10px;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-mail__txt{
  min-width: 0;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-mail__addr{
  display:block;
  margin-top: 2px;
  color: rgba(148,163,184,.95);
  font-size: 12px;
  text-decoration: none;

  /* “break-all” do google */
  word-break: break-all;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-mail__addr:hover{
  color: #fff;
}

/* botão copiar full width */
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-copyBtn{
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.10);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: background .16s ease, transform .16s ease, border-color .16s ease;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-copyBtn:hover{
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.14);
  transform: translateY(-1px);
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-copyBtn.is-copied{
  background: rgba(34,197,94,.20);
  border-color: rgba(34,197,94,.30);
}

/* tags inferiores */
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-tags{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  margin-top: 18px;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-tag{
  display:inline-flex;
  align-items:center;
  gap: 6px;

  padding: 7px 12px;
  border-radius: 999px;

  background: rgba(31,41,55,1); /* cinza escuro */
  border: 1px solid rgba(148,163,184,.22);
  color: rgba(226,232,240,.86);

  font-size: 12px;
  font-weight: 700;
  text-decoration:none;
  transition: transform .16s ease, background .16s ease, border-color .16s ease;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-tag:hover{
  transform: translateY(-1px);
  background: rgba(55,65,81,1);
  border-color: rgba(148,163,184,.28);
}

/* tag destaque “24h” */
.elementor-103 .elementor-element.elementor-element-1c3acff .tf-tag--hot{
  background: rgba(245,158,11,.18);
  border-color: rgba(245,158,11,.30);
  color: #F59E0B;
}

.elementor-103 .elementor-element.elementor-element-1c3acff .tf-tag--hot .material-symbols-outlined{
  font-size: 16px;
  color: #F59E0B;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-b7a0003 *//* DIVISÓRIA / CONTAINER PAI (2 colunas) */
.elementor-103 .elementor-element.elementor-element-b7a0003{
  /* NÃO deixe card aqui */
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;

  /* layout */
  display: grid;
  gap: 28px;
  align-items: start;

  /* se você quiser espaçamento externo do bloco */
  padding: 0 !important;
  margin: 0 !important;
}/* End custom CSS */
/* Start custom CSS */.btn, .btn:link, .btn:visited, .btn:hover, .btn:active{
  text-decoration: none !important;
}

/* Torre Forte Landing - CSS puro (sem dependências) */
:root{
  --bg: #ffffff;
  --soft: #f6f7fb;
  --text: #1f2937;
  --muted: #6b7280;
  --primary: #f5a623;
  --primary-2:#ff8a00;
  --dark: #121826;
  --card: #ffffff;
  --ring: rgba(245,166,35,.35);
  --shadow: 0 12px 30px rgba(17,24,39,.10);
  --shadow2: 0 18px 45px rgba(17,24,39,.14);
  --radius: 18px;
  --radius2: 26px;
  --max: 1180px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Helvetica Neue", Helvetica, "Noto Sans", "Liberation Sans", sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.5;
}

a{color:inherit;text-decoration:none}
a:hover{opacity:.9}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}

/* Topbar */
.topbar{
  background: linear-gradient(90deg, rgba(245,166,35,.22), rgba(245,166,35,.06));
  border-bottom: 1px solid rgba(17,24,39,.06);
}
.topbar__wrap{
  display:flex; gap:12px; justify-content:space-between; align-items:center;
  padding:10px 0;
  flex-wrap:wrap;
}
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(255,255,255,.65);
  border: 1px solid rgba(17,24,39,.06);
  font-size:13px;
  color: rgba(31,41,55,.85);
}

/* Header */
.header{
  position:sticky; top:0; z-index:50;
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(17,24,39,.06);
}
.header__wrap{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
  gap:14px;
}
.brand{display:flex;align-items:center;gap:12px}
.brand__mark{
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  background: linear-gradient(180deg, rgba(245,166,35,.22), rgba(245,166,35,.08));
  border:1px solid rgba(17,24,39,.08);
  box-shadow: 0 10px 25px rgba(245,166,35,.18);
  font-size:20px;
}
.brand__text{display:flex;flex-direction:column;line-height:1.1}
.brand__text strong{font-size:16px}
.brand__text span{font-size:14px;color:var(--muted)}

.nav{
  display:flex; gap:18px; align-items:center;
  color: rgba(31,41,55,.85);
  font-weight:600;
  font-size:14px;
}
.nav a{padding:8px 10px;border-radius:10px}
.nav a:hover{background: rgba(17,24,39,.04)}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  border-radius: 14px;
  padding:12px 16px;
  font-weight:700;
  border:1px solid transparent;
  cursor:pointer;
  transition: transform .08s ease, box-shadow .12s ease, background .12s ease, border-color .12s ease;
  user-select:none;
  white-space:nowrap;
}
.btn:active{transform: translateY(1px)}
.btn--primary{
  background: linear-gradient(180deg, var(--primary), var(--primary-2));
  color: #111827;
  box-shadow: 0 14px 35px rgba(245,166,35,.28);
}
.btn--primary:hover{box-shadow: 0 18px 45px rgba(245,166,35,.34)}
.btn--ghost{
  background: rgba(255,255,255,.8);
  border-color: rgba(17,24,39,.12);
}
.btn--ghost:hover{background: rgba(255,255,255,1)}
.btn--block{width:100%}

.burger{
  width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(17,24,39,.12);
  background: rgba(255,255,255,.8);
  display:none;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
}
.burger span{
  display:block;width:18px;height:2px;background: rgba(31,41,55,.8);
  border-radius:999px;
}
.mobile{
  padding:12px 20px 18px;
  border-top: 1px solid rgba(17,24,39,.06);
  display:flex;
  flex-direction:column;
  gap:10px;
}
.mobile a{
  padding:12px 14px;
  border-radius:14px;
  background: rgba(17,24,39,.03);
  border:1px solid rgba(17,24,39,.06);
  font-weight:700;
}

/* Hero */
.hero{
  position:relative;
  padding: 54px 0 44px;
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(245,166,35,.16), transparent 60%),
    radial-gradient(900px 500px at 90% 10%, rgba(245,166,35,.10), transparent 55%),
    linear-gradient(180deg, #fff, #fff);
  overflow:hidden;
}
.hero__grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:34px;
  align-items:center;
}
.hero__copy h1{
  margin:0 0 14px;
  font-size: clamp(34px, 3.6vw, 56px);
  line-height:1.06;
  letter-spacing:-.02em;
}
.accent{
  color: var(--primary-2);
  background: linear-gradient(180deg, var(--primary), var(--primary-2));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.hero__copy p{
  margin:0 0 18px;
  color: rgba(31,41,55,.80);
  font-size: 16px;
  max-width: 52ch;
}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0 18px}
.hero__badges{display:flex;gap:10px;flex-wrap:wrap}
.badge{
  padding:10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.8);
  border:1px solid rgba(17,24,39,.08);
  font-weight:700;
  font-size:13px;
  color: rgba(31,41,55,.78);
}

.hero__visual{
  position:relative;
  min-height: 420px;
}
.hero__img{
  position:relative;
  width:100%;
  height: 520px;
  border-radius: var(--radius2);
  background:
    linear-gradient(135deg, rgba(255,255,255,.70), rgba(255,255,255,.10)),
    url("assets/hero.jpg") center/cover no-repeat;
  border: 1px solid rgba(17,24,39,.10);
  box-shadow: var(--shadow2);
  overflow:hidden;
}
.hero__img::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(520px 260px at 10% 10%, rgba(255,255,255,.92), rgba(255,255,255,.55) 35%, transparent 70%),
    radial-gradient(400px 220px at 20% 30%, rgba(245,166,35,.18), transparent 65%);
  pointer-events:none;
}
.hero__glow{
  position:absolute;
  inset:auto -30px -40px -30px;
  height: 220px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(245,166,35,.28), transparent 60%);
  filter: blur(16px);
  pointer-events:none;
}

/* Sections */
.section{padding: 78px 0}
.section--soft{
  background:
    radial-gradient(1100px 600px at 20% 0%, rgba(245,166,35,.09), transparent 55%),
    radial-gradient(1000px 600px at 90% 20%, rgba(17,24,39,.06), transparent 55%),
    var(--soft);
}
.section__head{margin-bottom:26px}
.section__head h2{
  margin:0 0 10px;
  font-size: clamp(26px, 2.2vw, 34px);
  letter-spacing:-.02em;
}
.section__head p{margin:0;color:var(--muted)}

/* Cards */
.cards{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:16px;
}
.card{
  background: var(--card);
  border:1px solid rgba(17,24,39,.08);
  border-radius: var(--radius);
  padding:18px 18px 16px;
  box-shadow: var(--shadow);
  transition: transform .10s ease, box-shadow .12s ease;
}
.card:hover{transform: translateY(-2px); box-shadow: 0 18px 45px rgba(17,24,39,.12)}
.card__icon{
  width:48px;height:48px;border-radius:16px;
  display:grid;place-items:center;
  background: rgba(245,166,35,.14);
  border:1px solid rgba(245,166,35,.26);
  color: #9a5b00;
  margin-bottom:10px;
}
.card h3{margin:0 0 8px;font-size:16px}
.card p{margin:0;color:rgba(31,41,55,.75);font-size:14px}

/* Gallery */
.gallery{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
  margin-bottom:22px;
}
.ph{
  aspect-ratio: 16/10;
  border-radius: 16px;
  border:1px solid rgba(17,24,39,.10);
  box-shadow: var(--shadow);
  background:
    linear-gradient(135deg, rgba(255,255,255,.9), rgba(255,255,255,.15)),
    radial-gradient(500px 260px at 20% 20%, rgba(245,166,35,.22), transparent 60%),
    linear-gradient(180deg, rgba(17,24,39,.06), rgba(17,24,39,.02));
  position:relative;
  overflow:hidden;
}
.ph::after{
  content:"Foto do projeto";
  position:absolute; left:12px; bottom:12px;
  padding:8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.82);
  border:1px solid rgba(17,24,39,.08);
  color: rgba(31,41,55,.78);
  font-weight:800;
  font-size:12px;
}

.center{display:flex;justify-content:center}

/* Split */
.split{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:22px;
  align-items:start;
}
.split__left h2{margin:0 0 10px; font-size: clamp(26px, 2.2vw, 34px); letter-spacing:-.02em}
.muted{color:var(--muted)}
.tiny{font-size:12px}
.points{margin-top:18px;display:flex;flex-direction:column;gap:12px}
.point{
  display:flex; gap:12px; align-items:flex-start;
  padding:14px 14px;
  border-radius: 18px;
  background: rgba(17,24,39,.02);
  border:1px solid rgba(17,24,39,.06);
}
.check{
  width:34px;height:34px;border-radius:12px;
  display:grid;place-items:center;
  background: rgba(245,166,35,.16);
  border:1px solid rgba(245,166,35,.26);
  color:#9a5b00;
  font-weight:900;
  flex:0 0 auto;
}
.point h3{margin:0 0 4px; font-size:16px}
.point p{margin:0; color:rgba(31,41,55,.75); font-size:14px}

.panel{
  background: linear-gradient(180deg, rgba(18,24,38,.96), rgba(18,24,38,.92));
  color: #fff;
  border-radius: 24px;
  padding: 22px;
  border:1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow2);
  position:sticky;
  top: 92px;
}
.panel h2{margin:0 0 12px;font-size:22px}
.contact{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.contact__item{
  padding:10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
}
.contact__item a{text-decoration:underline}

.form label{display:block;margin: 10px 0}
.form span{display:block;font-size:12px;color:rgba(255,255,255,.75);margin:0 0 6px}
.form input,.form textarea{
  width:100%;
  padding:12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color:#fff;
  outline:none;
}
.form input:focus,.form textarea:focus{
  border-color: rgba(245,166,35,.65);
  box-shadow: 0 0 0 4px rgba(245,166,35,.18);
}
.form textarea{resize:vertical;min-height:120px}

/* Footer */
.footer{
  background: #0f172a;
  color: rgba(255,255,255,.88);
  padding: 28px 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.footer__wrap{
  display:flex; gap:16px; align-items:center; justify-content:space-between;
  flex-wrap:wrap;
}
.footer__brand{display:flex;align-items:center;gap:12px}
.footer__links{display:flex;gap:14px;flex-wrap:wrap}
.footer__links a{padding:8px 10px;border-radius:12px;background: rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
.footer__copy{opacity:.85}

/* Responsive */
@media (max-width: 980px){
  .nav, .header .btn--primary{display:none}
  .burger{display:flex}
  .hero__grid{grid-template-columns: 1fr; gap:18px}
  .hero__visual{min-height:unset}
  .hero__img{height: 360px}
  .cards{grid-template-columns: repeat(2, 1fr)}
  .gallery{grid-template-columns: repeat(2, 1fr)}
  .split{grid-template-columns: 1fr; gap:18px}
  .panel{position:relative; top:auto}
}

@media (max-width: 520px){
  .cards{grid-template-columns: 1fr}
  .gallery{grid-template-columns: 1fr}
  .topbar__wrap{gap:8px}
}/* End custom CSS */