:root {
  --cprim: #E8741E;
  --cseco: #707070;
  --text: #1f2937;
  --muted: #6b7280;
  --border: #e5e7eb;
  --bg: #ffffff;
}

* {
  box-sizing: border-box;
  /*   margin: 0;
  padding: 0; */
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

.search-box {
  background: rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  padding: 1rem 1.2rem 1.2rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
  color: #333;

  width: 100%;
  max-width: 720px;
  margin: 0 auto;
  overflow-x: hidden;
}

.search-box * {
  min-width: 0;
  overflow-wrap: anywhere;
}

/* .search-box input,
.search-box select,
.search-box textarea,
.search-box button {
  width: 100%;
  max-width: 100%;
} */


.hide {
  display: none !important;
}

body {
  margin: 0;
  padding: 0;
  color: #333;
  background-color: #fff;
}

a {
  text-decoration: none;
  color: inherit;
}

header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.06);
}

.header-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.6rem 0 0.6rem 0;
}

.orange-square {
  width: 30px;
  height: 30px;
  background-color: var(--cprim);
}

.logo img,
.logo-footer img {
  height: 30px;
}

.logo-footer img {
  width: 130px;
  height: auto;
}

.main-nav {
  display: flex;
  align-items: center;
  gap: 2rem;
  font-size: 0.9rem;
}

.main-nav a {
  color: var(--cseco);
}

.main-nav a:hover {
  color: var(--cprim);
}

.header-right {
  color: var(--cseco);
  display: flex;
  align-items: center;
  gap: 1.5rem;
  font-size: 0.85rem;
}

.header-right a:hover {
  color: var(--cprim);
}

.header-right span {
  cursor: pointer;
}

.menu-toggle {
  display: none;
  cursor: pointer;
}

.menu-toggle span {
  display: block;
  width: 20px;
  height: 2px;
  background: #333;
  margin: 3px 0;
}

/*PADRÂO CSS*/

.botao-padrao-site {
  margin-top: 1rem;
  border: none;
  border-radius: 999px;
  padding: 0.6rem 1.6rem;
  background: var(--cprim);
  color: #fff;
  font-size: 0.9rem;
  cursor: pointer;
  width: 100%;
}

.botao-padrao-site:hover {
  transform: translateY(-2px);
  transition: transform 0.3s ease;
  /* box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3); */
  background-color: var(--cseco) !important;

}

/*property leads*/

.box {
  /* border: 1px solid #e5e7eb;
        border-radius: 12px; 
        padding: 14px;*/
  margin-bottom: 12px
}

.grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px
}

@media(max-width:900px) {
  .grid {
    grid-template-columns: 1fr
  }
}

label {
  display: block;
  font-size: 12px;
  color: #6b7280;
  margin: 10px 0 6px
}

input,
select,
textarea {
  width: 100%;
  border: 1px solid #ddd;
  border-radius: 8px;
  padding: 10px 12px;
  font-size: 14px
}

textarea {
  min-height: 120px
}

.ok {
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  color: #14532d;
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 12px
}

.err {
  background: #fff5f5;
  border: 1px solid #fecaca;
  color: #7f1d1d;
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 12px
}


/* hero section */

.hero {
  margin-top: 53px;
  position: relative;
  height: 700px
    /*520px*/
  ;
  color: #fff;
  display: flex;
  align-items: end;
  justify-content: center;
  text-align: center;
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("../hero.jpg");
  background-size: cover;
  background-position: bottom;
  /*   filter: brightness(0.55); */
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  /*background: linear-gradient(to bottom, rgba(55,0,20,0.7), rgba(0,0,0,0.3));*/
  mix-blend-mode: multiply;
}

.hero-content {
  width: 600px;
  position: relative;
  z-index: 2;
  max-width: 900px;
  /* padding: 0 1rem; */
}

.hero-title {
  font-size: 1.6rem;
  margin-bottom: 1.4rem;
}

/* search */

/* .search-box {
  background: rgba(255, 255, 255, 0.96);
  border-radius: 8px;
  padding: 1rem 1.2rem 1.2rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
  color: #333;
} */

.search-tabs {
  justify-content: space-between;
  width: 100%;
  display: inline-flex;
  /* background: #f3f3f3; */
  border-radius: 999px;
  padding: 3px;
  margin-bottom: 0.9rem;
}

.search-tab {
  color: white;
  border-radius: 999px;
  /* padding: 0.3rem 1.2rem; */
  padding: 0.6rem 0.6rem;
  font-size: 0.85rem;
  cursor: pointer;
  border: none;
  background: var(--cseco);
}

.search-tab.active {
  background: var(--cprim);
  color: white;
}

.search-form {
  display: flex;
  gap: 0.6rem;
  align-items: center;
  flex-wrap: wrap;
}

/*.search-form input[type="text"] {*/
.search-form input[type="text"],
[name="type"],
[name="city"],
[name="min_price"],
[name="max_price"],
[name="bedrooms"] {
  flex: 1;
  padding: 0.65rem 0.75rem;
  border-radius: 4px;
  border: 1px solid #ddd;
  font-size: 0.9rem;
}

.search-form button {
  color: white;
  padding: 0.65rem 1.4rem;
  border-radius: 4px;
  border: none;
  background: var(--cprim);
  cursor: pointer;
  font-size: 0.9rem;
  font-weight: 600;
}

.search-form button:hover {
  background: var(--cseco);
}

/* carrousel */

.imoveis-swiper {
  padding: 12px 0 28px;
}

.swiper-slide {
  height: auto;
  /* mantém o card como você já desenhou */
}

.swiper-button-next,
.swiper-button-prev {
  color: var(--cprim) !important;
  /* ou a cor da sua marca */
}

.swiper-button-next::after,
.swiper-button-prev::after {
  font-size: 20px;
}

/*SLIDE*/

.info-track {
  display: flex;
  gap: 24px;
  /* mantenha igual ao gap que você usa no JS */
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  /* obrigatório p/ “pular” */
  scroll-snap-stop: always;
  /* força parar em um snap */
  scroll-behavior: smooth;
  touch-action: pan-x;
}

.info-item {
  flex: 0 0 auto;
  scroll-snap-align: start;
}


/* container de referência */
.imoveis-swiper-shell {
  position: relative;
}

/* swiper continua cortando os slides */
.imoveis-swiper {
  overflow: hidden;
}

/* setas fora do swiper */
.imoveis-nav .swiper-button-prev,
.imoveis-nav .swiper-button-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 6px 18px rgba(0, 0, 0, .18);
  color: var(--cprim);
  z-index: 20;
}

/*carroussel footer*/

/* Track horizontal sem scrollbar */
.info-track {
  display: flex;
  gap: 24px;
  overflow: hidden;
  /* remove a barra */
  scroll-behavior: smooth;
}

/* esconde scrollbar caso algum browser force */
.info-track {
  scrollbar-width: none;
}

.info-track::-webkit-scrollbar {
  display: none;
}

/* Cada item do carrossel */
.info-item {
  flex: 0 0 calc(33.333% - 16px);
  /* 3 por linha */
  text-decoration: none;
}

/* Responsivo igual ao seu slider */
@media (max-width:1024px) {
  .info-item {
    flex-basis: calc(50% - 12px);
  }

  /* 2 */
}

@media (max-width:640px) {
  .info-item {
    flex-basis: 85%;
  }

  /* 1.1 */
}

/* Mantém as setas fora e clicáveis (se já tiver no seu CSS, isso só reforça) */
.info-shell {
  position: relative;
}

.info-shell .imoveis-nav {
  pointer-events: none;
  /* só as setas recebem clique */
}

.info-shell .info-prev,
.info-shell .info-next {
  pointer-events: auto;
  cursor: pointer;
}


/* ícone */
.imoveis-nav .swiper-button-prev::after,
.imoveis-nav .swiper-button-next::after {
  font-size: 16px;
  font-weight: 700;
}

/* joga para o branco */
.imoveis-nav .swiper-button-prev {
  left: -56px;
}

.imoveis-nav .swiper-button-next {
  right: -56px;
}

/* mobile */
@media (max-width: 640px) {
  .imoveis-nav {
    display: none;
  }
}


/**/


/*font aw*/
.icon-feature {
  font-size: 5em;
  /* controle total */
  color: var(--cprim);
  /* cor da sua marca */
}

/* sections */

section {
  padding: 2rem 1rem;
}

.section-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.section-title {
  text-align: center;
  font-size: 1.5rem;
  margin-bottom: 0.3rem;
  text-transform: uppercase;
}

.section-subtitle {
  text-align: center;
  font-size: 0.9rem;
  color: #777;
  margin-bottom: 1.8rem;
}

.cards-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.card {
  position: relative;
  width: 100%;
  height: 460px;
  background-size: cover;
  background-position: center;
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  transition: transform 0.3s ease;
}

.card-imo-destaque {
  position: relative !important;
  width: 100%;
  height: 460px !important;
  background-size: cover;
  background-position: center;
  border-radius: 12px;
  overflow: hidden;
  display: flex !important;
  align-items: flex-end;
  transition: transform 0.3s ease;
}

.card-arquitetos {
  position: relative !important;
  width: 100%;
  height: 325px !important;
  background-size: cover;
  background-position: center;
  border-radius: 12px;
  overflow: hidden;
  display: flex !important;
  align-items: flex-end;
  transition: transform 0.3s ease;
}

.card-informacoes {
  position: relative !important;
  width: 100%;
  height: 230px !important;
  background-size: cover;
  background-position: center;
  border-radius: 12px;
  overflow: hidden;
  display: flex !important;
  align-items: flex-end;
  transition: transform 0.3s ease;
}

.card-imo-destaque .card-link {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: block;
  text-decoration: none;
}

/* Garanta que o conteúdo fique acima do fundo, mas abaixo do clique, se quiser:
   aqui eu deixo o texto acima do link, para permitir seleção/hover em elementos.
   Se você quer o card inteiro clicável SEM impedir clicar em botão interno,
   eu ajusto o z-index conforme seu objetivo. */
.card-imo-destaque .card-overlay {
  position: relative;
  z-index: -1;
}


.card:hover,
.card-informacoes:hover {
  transform: scale(1.03);
}

.card::after {
  content: "";
  position: absolute;
  inset: 0;
  /* background: rgba(0, 0, 0, 0.35); */
  /* escurece a imagem para o texto ficar legível */
}

.card-overlay {
  position: relative;
  z-index: 2;
  color: #fff;
  padding: 20px;
}

.card-overlay-arquitetos {
  position: relative;
  z-index: 2;
  color: #fff;
  padding: 20px;
  margin: 0 auto;
}

.card-overlay-informacoes {
  position: relative;
  z-index: 2;
  color: #fff;
  padding: 20px;
  margin: 0 auto;
}

.card-title {
  font-size: 1.6rem;
  margin: 0;
  font-weight: bold;
}

.card-title-arquitetos {
  font-size: 1.6rem;
  margin: 0;
  font-weight: bold;
  text-shadow: 1px 1px 1px #000;
}

.card-title-informacoes {
  font-size: 1.6rem;
  margin: 0;
  font-weight: bold;
  text-shadow: 1px 1px 1px #000;
}

.card-meta {
  margin: 6px 0 15px;
  font-size: 1rem;
}

.card-button {
  display: inline-block;
  padding: 10px 18px;
  background-color: var(--cprim);
  color: #000;
  border-radius: 6px;
  font-weight: bold;
  text-decoration: none;
  backdrop-filter: blur(4px);
}

.card-button:hover {
  background-color: var(--cprim);
}

.card-link {
  display: block;
  height: 100%;
  width: 100%;
  color: inherit;
  text-decoration: none;
}

/*lightbox*/

/* estilos mínimos para a lightbox/carrossel */
.property-gallery {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.property-gallery img {
  width: 110px;
  height: 80px;
  object-fit: cover;
  border-radius: 4px;
  cursor: pointer;
  transition: transform .2s, box-shadow .2s;
}

.property-gallery img:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, .2);
}

.lightbox-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .85);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.lightbox-overlay img {
  max-width: 90vw;
  max-height: 90vh;
  border-radius: 8px;
}

.lightbox-overlay .lb-close,
.lightbox-overlay .lb-prev,
.lightbox-overlay .lb-next {
  position: absolute;
  color: #fff;
  font-size: 32px;
  cursor: pointer;
  user-select: none;
}

.lightbox-overlay .lb-close {
  top: 20px;
  right: 30px;
}

.lightbox-overlay .lb-prev {
  left: 30px;
  top: 50%;
  transform: translateY(-50%);
}

.lightbox-overlay .lb-next {
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
}

.contact-section {
  background: #f7f4f6;
  padding: 2rem 0;
  /*margin-top:2rem;*/
}

.contact-section h2 {
  text-align: left;
  margin-bottom: 1rem;
}

.contact-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.contact-form-grid .full {
  grid-column: 1 / -1;
}

.contact-form-grid label {
  font-size: 0.85rem;
  display: block;
  margin-bottom: 0.25rem;
}

.contact-form-grid input,
.contact-form-grid textarea {
  width: 100%;
  padding: 0.5rem 0.7rem;
  border-radius: 6px;
  border: 1px solid #ccc;
  font-size: 0.9rem;
}

.alert {
  padding: 0.6rem 0.8rem;
  border-radius: 6px;
  font-size: 0.85rem;
  margin-bottom: 1rem;
}

.alert-success {
  background: #e6ffed;
  color: #1b7a3c;
}

.alert-error {
  background: #ffe5e5;
  color: #8c1a1a;
}



.property-list {
  margin-top: 1.5rem;
}

.property-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
}

.property-card img {
  width: 100%;
  height: 180px;
  object-fit: cover;
}

.property-card-body {
  padding: 0.9rem 1rem 1rem;
}

.property-price {
  font-weight: 700;
  margin-bottom: 0.3rem;
  color: var(--cprim);
}

.property-meta-line {
  /*   font-size: 0.8rem;
  color: #666; 
  padding: 0 0 11px 0;*/
  margin: 0;
  font-size: 1.6rem;
  color: #666;
  font-weight: 700;
}

.property-meta-line-endereco {
  /*   font-size: 0.8rem;
  color: #666; 
  padding: 0 0 11px 0;*/
  margin: 0;
  font-size: 1.1rem;
  color: #666;
  /*   font-weight: 700; */
}

.property-meta-line-iinfo,
.property-meta-line-baci {
  font-weight: 700;
  font-size: 1.1rem;
}

.property-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.2rem;
}

.property-gallery {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.5rem;
  margin-top: 1rem;
}

.property-gallery img {
  width: 100%;
  height: 120px;
  object-fit: cover;
  border-radius: 4px;
}

@media (max-width: 1024px) {
  .cards-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .property-grid {
    /*ORIGINAL*/
    /* grid-template-columns: repeat(2, minmax(0, 1fr)); */
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .contact-grid {
    grid-template-columns: 1fr;
  }
}

/**/


/* condos */

.cards-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.2rem;
}

/* partners */

.partners-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  align-items: center;
}

.partner-card {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
  padding: 0.8rem 1.2rem;
  display: flex;
  justify-content: center;
  align-items: center;
}

.partner-card img {
  height: 50px;
  width: auto;
}

/* CTA cards */

.cta-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
  margin-top: 2rem;
}

.cta-card {
  background: #f7f4f6;
  border-radius: 10px;
  padding: 1.4rem 1.6rem;
  text-align: center;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.04);
}

.cta-card-title {
  font-size: 0.95rem;
  font-weight: 600;
  margin-bottom: 0.4rem;
}

.cta-card-sub {
  font-size: 0.8rem;
  color: #777;
  margin-bottom: 0.9rem;
}

.cta-card button {
  border: none;
  border-radius: 999px;
  padding: 0.45rem 1.4rem;
  background: var(--cprim);
  color: #000;
  font-size: 0.8rem;
  cursor: pointer;
}

.cta-card button:hover {
  background: var(--cprim);
}

/* contact & links */

.contact-section {
  background: #f4f4f6;
}

.contact-grid {
  display: grid;
  grid-template-columns: 2fr 3fr;
  gap: 2rem;
}

.address-card {
  background: #fff;
  border-radius: 8px;
  padding: 1.2rem 1.6rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  font-size: 0.85rem;
}

.address-card h4 {
  font-size: 0.95rem;
  margin-bottom: 0.3rem;
}

.address-card p {
  margin-bottom: 0.3rem;
}

.links-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.6rem;
  font-size: 0.8rem;
}

.links-columns h4 {
  font-size: 0.9rem;
  margin-bottom: 0.5rem;
}

.address-card ul,
.links-columns ul {
  padding: 10px 0 10px 0;
  border-top: 3px solid;
  border-bottom: 3px solid;
  list-style: none;
}

.links-columns li+li {
  margin-top: 0.25rem;
}

.links-columns a {
  width: 100%;
  color: var(--cseco);
  text-align: center;
}

.links-columns a:hover {
  color: var(--cprim);
}

a.btn.btn-primary {
  color: white;
}

a.btn.btn-primary:hover {
  background-color: var(--cseco);
}

/* =========================
   LINKS ÚTEIS (iframes)
   Cores: --cprim (primária) | --cseco (secundária)
========================= */

.lu-page { padding: 0; }

.lu-hero{
  padding: 2.2rem 0 1.6rem;
  background:
    radial-gradient(1200px 520px at 20% 10%, color-mix(in srgb, var(--cprim) 18%, transparent), transparent 60%),
    radial-gradient(900px 420px at 90% 20%, color-mix(in srgb, var(--cseco) 18%, transparent), transparent 60%);
}

.lu-hero-inner{
  display:grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 1.2rem;
  align-items: stretch;
}

.lu-kicker{
  display:inline-flex;
  padding:.35rem .75rem;
  border-radius:999px;
  background: color-mix(in srgb, var(--cprim) 14%, transparent);
  color: var(--cprim);
  font-weight: 800;
  font-size: .85rem;
}

.lu-title{
  margin:.75rem 0 .4rem;
  font-size: clamp(1.6rem, 2.7vw, 2.2rem);
  line-height:1.15;
  color:#121212;
}

.lu-subtitle{
  margin:0 0 1rem;
  color: color-mix(in srgb, var(--cseco) 85%, #000);
  line-height:1.65;
  max-width: 75ch;
}

.lu-actions{
  margin-top: 1.05rem;
  display:flex;
  gap:.7rem;
  flex-wrap: wrap;
}

.lu-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  border-radius:999px;
  padding:.82rem 1.15rem;
  font-weight:900;
  text-decoration:none;
  border:1px solid transparent;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.lu-btn-primary{
  background: var(--cprim);
  color:#fff;
  box-shadow:0 14px 28px color-mix(in srgb, var(--cprim) 35%, transparent);
}
.lu-btn-primary:hover{
  background: var(--cseco);
  color:#fff;
  box-shadow:0 14px 28px color-mix(in srgb, var(--cseco) 40%, transparent);
}

.lu-btn-ghost{
  background:#fff;
  color: var(--cseco);
  border-color: color-mix(in srgb, var(--cseco) 25%, transparent);
}
.lu-btn-ghost:hover{
  background: var(--cseco);
  color:#fff;
}

/* Card lateral */
.lu-card{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:14px;
  padding:1.15rem;
  box-shadow:0 18px 40px color-mix(in srgb, var(--cseco) 18%, transparent);
}

.lu-card h3{ margin:0 0 .65rem; color:#151515; }
.lu-card ul{ margin:0; padding:0; list-style:none; display:grid; gap:.55rem; }
.lu-card li{ display:flex; gap:.6rem; color: color-mix(in srgb, var(--cseco) 85%, #000); }
.lu-card li i{ color: var(--cprim); margin-top:.18rem; }
.lu-small{ margin:.9rem 0 0; color: color-mix(in srgb, var(--cseco) 75%, #000); font-size:.92rem; }

/* Grid de iframes */
.lu-section{ padding: 1.6rem 0 2.2rem; }

.lu-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

.lu-tile{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 12px 26px color-mix(in srgb, var(--cseco) 14%, transparent);
}

.lu-tile-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: .75rem;
  padding: .9rem 1rem;
  border-bottom: 1px solid color-mix(in srgb, var(--cseco) 14%, transparent);
}

.lu-tile-title{
  display:flex;
  align-items:baseline;
  gap:.65rem;
}
.lu-tile-head h3{ margin:0; color:#141414; font-size:1.05rem; }

.lu-tag{
  font-size:.78rem;
  font-weight:900;
  padding:.25rem .55rem;
  border-radius:999px;
  background: color-mix(in srgb, var(--cprim) 14%, transparent);
  color: var(--cprim);
}

.lu-open{
  text-decoration:none;
  color: var(--cseco);
  font-weight:900;
  font-size:.9rem;
  display:inline-flex;
  align-items:center;
  gap:.45rem;
}
.lu-open:hover{ color: var(--cprim); }

/* iframe responsivo com fallback */
.lu-frame-wrap{
  position:relative;
  width:100%;
  height: 520px;
  background: color-mix(in srgb, var(--cseco) 6%, transparent);
}

.lu-frame{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}

.lu-fallback{
  position:absolute;
  inset:auto 0 0 0;
  padding:.7rem 1rem;
  background: linear-gradient(to top,
    rgba(0,0,0,.55),
    rgba(0,0,0,0)
  );
  color:#fff;
  pointer-events:none;
}

.lu-fallback-inner{
  display:flex;
  gap:.6rem;
  align-items:flex-start;
  max-width: 70ch;
}
.lu-fallback i{ margin-top:.15rem; }

.lu-note{
  margin-top: 1.1rem;
  display:flex;
  gap:.75rem;
  align-items:flex-start;
  padding: .95rem 1rem;
  border-radius: 14px;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
}
.lu-note i{ color: var(--cprim); margin-top:.15rem; }
.lu-note p{ margin:.15rem 0 0; color: color-mix(in srgb, var(--cseco) 80%, #000); }

@media (max-width: 980px){
  .lu-hero-inner{ grid-template-columns: 1fr; }
  .lu-grid{ grid-template-columns: 1fr; }
  .lu-btn{ width:100%; }
  .lu-frame-wrap{ height: 480px; }
}


/*Simular financiamento*/
/* =========================
   FINANCIAMENTO (miolo)
   Cores: --cprim (primária) | --cseco (secundária)
========================= */

.fin-page {
  padding: 0;
}

/* HERO */
.fin-hero {
  padding: 2.2rem 0 1.6rem;
  background:
    radial-gradient(1200px 500px at 20% 10%, color-mix(in srgb, var(--cprim) 18%, transparent), transparent 60%),
    radial-gradient(900px 420px at 90% 20%, color-mix(in srgb, var(--cseco) 18%, transparent), transparent 60%);
}

.fin-hero-inner {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 1.4rem;
}

/* Kicker / Títulos */
.fin-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 700;
  font-size: 0.85rem;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--cprim) 14%, transparent);
  color: var(--cprim);
}

.fin-title {
  margin: 0.8rem 0 0.5rem;
  font-size: clamp(1.6rem, 2.7vw, 2.25rem);
  line-height: 1.15;
  color: #121212;
}

.fin-subtitle {
  margin-bottom: 1rem;
  color: color-mix(in srgb, var(--cseco) 80%, #000);
  max-width: 56ch;
}

/* Bullets */
.fin-bullets {
  display: grid;
  gap: 0.55rem;
  margin: 1rem 0 1.2rem;
}

.fin-bullet {
  display: flex;
  gap: 0.65rem;
  color: color-mix(in srgb, var(--cseco) 85%, #000);
}

.fin-bullet i {
  color: var(--cprim);
}

/* BOTÕES */
.fin-actions {
  display: flex;
  gap: 0.7rem;
  flex-wrap: wrap;
}

.fin-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.78rem 1.1rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.95rem;
  text-decoration: none;
  border: 1px solid transparent;
  transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

/* Primário */
.fin-btn-primary {
  background: var(--cprim);
  color: #fff;
  box-shadow: 0 14px 28px color-mix(in srgb, var(--cprim) 35%, transparent);
}

.fin-btn-primary:hover {
  background: var(--cseco);
  color: #fff;
  box-shadow: 0 14px 28px color-mix(in srgb, var(--cseco) 40%, transparent);
}

/* Ghost */
.fin-btn-ghost {
  background: #fff;
  color: var(--cseco);
  border-color: color-mix(in srgb, var(--cseco) 25%, transparent);
}

.fin-btn-ghost:hover {
  background: var(--cseco);
  color: #fff;
}

/* CARD LATERAL */
.fin-hero-card {
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius: 14px;
  padding: 1.15rem;
  box-shadow: 0 18px 40px color-mix(in srgb, var(--cseco) 25%, transparent);
}

.fin-card-head h3 {
  margin: 0;
}

.fin-card-head p {
  color: color-mix(in srgb, var(--cseco) 80%, #000);
}

/* Checklist */
.fin-checklist {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 0.55rem;
}

.fin-checklist li {
  display: flex;
  gap: 0.6rem;
  color: color-mix(in srgb, var(--cseco) 85%, #000);
}

.fin-checklist i {
  color: var(--cprim);
}

/* Nota */
.fin-note {
  display: flex;
  gap: 0.75rem;
  padding: 0.85rem;
  margin-top: 15px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--cprim) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--cprim) 25%, transparent);
}

.fin-note i,
.fin-note strong {
  color: var(--cprim);
}

/* SEÇÕES */
.fin-section {
  padding: 1.7rem 0 2.2rem;
}

.fin-section-alt {
  background: color-mix(in srgb, var(--cseco) 20%, transparent);
}

.fin-section-head p {
  color: color-mix(in srgb, var(--cseco) 80%, #000);
}

/* STEPS */
.fin-steps {
  margin-top: 1.1rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.9rem;
}

.fin-step {
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius: 14px;
  padding: 1rem;
}

.fin-step-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--cprim) 15%, transparent);
  color: var(--cprim);
  display: grid;
  place-items: center;
  font-weight: 800;
}

/* TIP */
.fin-tipbox {
  margin-top: 1.1rem;
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 0.9rem;
  padding: 1rem;
  border-radius: 14px;
  background: color-mix(in srgb, var(--cprim) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--cprim) 25%, transparent);
}

.fin-tipbox-icon {
  background: #fff;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: var(--cprim);
}

/* BANCOS */
.fin-bank-grid {
  margin-top: 1.1rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.9rem;
}

.fin-bank {
  display: grid;
  grid-template-columns: 54px 1fr 18px;
  gap: 0.85rem;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius: 14px;
  padding: 0.95rem 1rem;
  text-decoration: none;
  color: inherit;
  transition: transform 0.15s ease, border-color 0.15s ease;
}

.fin-bank:hover {
  transform: translateY(-1px);
  border-color: var(--cprim);
}

.fin-bank-logo {
  background: color-mix(in srgb, var(--cseco) 8%, transparent);
  border-radius: 12px;
  display: grid;
  place-items: center;
}

.fin-bank-logo img {
  width: 100%;
}

.fin-bank-icon {
  color: var(--cseco);
}

/* CTA FINAL */
.fin-footer-cta {
  margin-top: 1.2rem;
  padding: 1.15rem;
  border-radius: 14px;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.fin-footer-cta h3 {
  margin: 0;
}

/* RESPONSIVO */
@media (max-width: 980px) {

  .fin-hero-inner,
  .fin-steps,
  .fin-bank-grid {
    grid-template-columns: 1fr;
  }

  .fin-footer-cta {
    flex-direction: column;
    gap: 1rem;
  }

  .fin-btn {
    width: 100%;
  }
}


/* footer */

footer {
  background: #130811;
  color: #eee;
  font-size: 0.75rem;
}

.footer-top {
  padding: 1.5rem 1rem 0.5rem;
  text-align: center;
}

.footer-top-inner {
  max-width: 900px;
  margin: 0 auto;
}

.footer-bottom {
  text-align: center;
  padding: 0.6rem 1rem 1.2rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  opacity: 0.9;
}

.footer-links-inline {
  margin-top: 0.7rem;
}

.footer-links-inline a {
  margin: 0 0.4rem;
  color: #eee;
}

.footer-links-inline a:hover {
  color: var(--cprim);
}

.blog-post-meta {
  margin: 0 0 10px;
}


/* menu horizontal */
.menu-horizontal {
  width: 100%;
  background: #fff;
  padding: 15px 0;
  display: flex;
  justify-content: center;
}

.menu-horizontal ul {
  list-style: none;
  display: flex;
  gap: 20px;
  padding: 0;
  margin: 0;
  flex-wrap: wrap;
  /* permite quebrar em telas menores */
}

.menu-horizontal li {
  margin: 0;
}

.menu-horizontal a {
  display: block;
  padding: 12px 22px;
  background: var(--cprim);
  /* tom vinho inspirado nos temas anteriores */
  color: #000;
  text-decoration: none;
  font-weight: 600;
  border-radius: 8px;
  transition: 0.3s ease;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

.menu-horizontal a:hover {
  background: var(--cprim);
  /* tom vinho mais claro ao passar o mouse */
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

/* =========================
   SOBRE (Institucional)
   Cores: --cprim (primária) | --cseco (secundária)
========================= */

.ab-page { padding: 0; }

.ab-hero{
  padding: 2.2rem 0 1.6rem;
  background:
    radial-gradient(1200px 520px at 20% 10%, color-mix(in srgb, var(--cprim) 18%, transparent), transparent 60%),
    radial-gradient(900px 420px at 90% 20%, color-mix(in srgb, var(--cseco) 18%, transparent), transparent 60%);
}

.ab-hero-inner{
  display:grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 1.2rem;
  align-items: stretch;
}

.ab-kicker{
  display:inline-flex;
  padding:.35rem .75rem;
  border-radius:999px;
  background: color-mix(in srgb, var(--cprim) 14%, transparent);
  color: var(--cprim);
  font-weight: 800;
  font-size: .85rem;
}

.ab-title{
  margin:.75rem 0 .4rem;
  font-size: clamp(1.6rem, 2.7vw, 2.2rem);
  line-height:1.15;
  color:#121212;
}

.ab-subtitle{
  margin:0 0 1rem;
  color: color-mix(in srgb, var(--cseco) 85%, #000);
  line-height:1.65;
  max-width: 72ch;
}

.ab-highlights{ display:grid; gap:.55rem; margin-top:.9rem; }
.ab-highlight{
  display:flex; gap:.65rem; align-items:flex-start;
  color: color-mix(in srgb, var(--cseco) 85%, #000);
}
.ab-highlight i{ color: var(--cprim); margin-top:.18rem; }

.ab-actions{
  margin-top: 1.05rem;
  display:flex;
  gap:.7rem;
  flex-wrap: wrap;
}

.ab-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  border-radius:999px;
  padding:.82rem 1.15rem;
  font-weight:900;
  text-decoration:none;
  border:1px solid transparent;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease, border-color .2s ease;
  user-select:none;
}

.ab-btn-primary{
  background: var(--cprim);
  color:#fff;
  box-shadow:0 14px 28px color-mix(in srgb, var(--cprim) 35%, transparent);
}
.ab-btn-primary:hover{
  background: var(--cseco);
  color:#fff;
  box-shadow:0 14px 28px color-mix(in srgb, var(--cseco) 40%, transparent);
}

.ab-btn-ghost{
  background:#fff;
  color: var(--cseco);
  border-color: color-mix(in srgb, var(--cseco) 25%, transparent);
}
.ab-btn-ghost:hover{
  background: var(--cseco);
  color:#fff;
}

/* Card lateral */
.ab-card{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:14px;
  padding:1.15rem;
  box-shadow:0 18px 40px color-mix(in srgb, var(--cseco) 18%, transparent);
}

.ab-card h3{ margin:0 0 .65rem; color:#151515; }
.ab-card ul{ margin:0; padding:0; list-style:none; display:grid; gap:.55rem; }
.ab-card li{ display:flex; gap:.6rem; color: color-mix(in srgb, var(--cseco) 85%, #000); }
.ab-card li i{ color: var(--cprim); margin-top:.18rem; }

.ab-note{
  margin-top: 1rem;
  display:flex;
  gap:.75rem;
  padding: .85rem;
  border-radius: 12px;
  background: color-mix(in srgb, var(--cprim) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--cprim) 25%, transparent);
}
.ab-note i{ color: var(--cprim); margin-top:.18rem; }
.ab-note p{ margin:.15rem 0 0; color: color-mix(in srgb, var(--cseco) 80%, #000); }

/* Seções */
.ab-section{ padding: 1.7rem 0 2.2rem; }
.ab-section-alt{ background: color-mix(in srgb, var(--cseco) 6%, transparent); }

.ab-section-head h2{ margin:0 0 .35rem; color:#121212; }
.ab-section-head p{
  margin:0;
  color: color-mix(in srgb, var(--cseco) 80%, #000);
  line-height:1.65;
  max-width: 80ch;
}

/* Cards missão/visão/valores */
.ab-cards{
  margin-top: 1.1rem;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .9rem;
}

.ab-mini{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:14px;
  padding:1rem;
}

.ab-mini-icon{
  width:44px; height:44px;
  border-radius:12px;
  display:grid; place-items:center;
  background: color-mix(in srgb, var(--cprim) 15%, transparent);
  color: var(--cprim);
  margin-bottom:.6rem;
}

.ab-mini h3{ margin:.2rem 0 .35rem; }
.ab-mini p{ margin:0; color: color-mix(in srgb, var(--cseco) 85%, #000); line-height:1.6; }

/* Steps */
.ab-steps{
  margin-top: 1.1rem;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .9rem;
}

.ab-step{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:14px;
  padding:1rem;
}

.ab-step-icon{
  width:44px; height:44px;
  border-radius:12px;
  display:grid; place-items:center;
  background: color-mix(in srgb, var(--cprim) 15%, transparent);
  color: var(--cprim);
  font-weight:900;
  margin-bottom:.55rem;
}

/* Diferenciais grid */
.ab-grid{
  margin-top: 1.1rem;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .9rem;
}

.ab-item{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:14px;
  padding:1rem;
}

.ab-item i{ color: var(--cprim); font-size: 1.15rem; }
.ab-item h3{ margin:.55rem 0 .35rem; }
.ab-item p{ margin:0; color: color-mix(in srgb, var(--cseco) 85%, #000); line-height:1.6; }

/* CTA final */
.ab-cta{
  margin-top: 1.2rem;
  padding: 1.15rem;
  border-radius: 14px;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 1rem;
}

.ab-cta h3{ margin:0; }
.ab-cta p{ margin:.25rem 0 0; color: color-mix(in srgb, var(--cseco) 80%, #000); }

/* Responsivo */
@media (max-width: 980px){
  .ab-hero-inner{ grid-template-columns: 1fr; }
  .ab-cards{ grid-template-columns: 1fr; }
  .ab-steps{ grid-template-columns: 1fr; }
  .ab-grid{ grid-template-columns: 1fr; }
  .ab-btn{ width:100%; }
  .ab-cta{ flex-direction: column; align-items: stretch; }
}


/*trabalhe conosco*/
/* =========================
   TRABALHE CONOSCO
   Cores: --cprim (primária) | --cseco (secundária)
========================= */

.tc-page { padding: 0; }

.tc-hero {
  padding: 2.2rem 0 1.5rem;
  background:
    radial-gradient(1200px 520px at 20% 10%, color-mix(in srgb, var(--cprim) 18%, transparent), transparent 60%),
    radial-gradient(900px 420px at 90% 20%, color-mix(in srgb, var(--cseco) 18%, transparent), transparent 60%);
}

.tc-hero-inner {
  display: grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 1.2rem;
  align-items: stretch;
}

.tc-kicker{
  display:inline-flex; padding:.35rem .75rem; border-radius:999px;
  background: color-mix(in srgb, var(--cprim) 14%, transparent);
  color: var(--cprim);
  font-weight:800; font-size:.85rem;
}

.tc-title{
  margin:.75rem 0 .4rem;
  font-size: clamp(1.6rem, 2.7vw, 2.2rem);
  line-height:1.15; color:#121212;
}

.tc-subtitle{
  margin:0 0 1rem;
  color: color-mix(in srgb, var(--cseco) 85%, #000);
  line-height:1.6; max-width: 68ch;
}

.tc-highlights{
  display:grid; gap:.55rem; margin-top:.9rem;
}

.tc-highlight{
  display:flex; gap:.65rem; align-items:flex-start;
  color: color-mix(in srgb, var(--cseco) 85%, #000);
}

.tc-highlight i{ color: var(--cprim); margin-top:.18rem; }

.tc-card{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:14px;
  padding:1.15rem;
  box-shadow:0 18px 40px color-mix(in srgb, var(--cseco) 18%, transparent);
}

.tc-card h3{ margin:0 0 .65rem; color:#151515; }
.tc-card ul{ margin:0; padding:0; list-style:none; display:grid; gap:.55rem; }
.tc-card li{ display:flex; gap:.6rem; color: color-mix(in srgb, var(--cseco) 85%, #000); }
.tc-card li i{ color: var(--cprim); margin-top:.18rem; }
.tc-small{ margin:.9rem 0 0; color: color-mix(in srgb, var(--cseco) 75%, #000); font-size:.92rem; }

.tc-section{ padding: 1.6rem 0 2.2rem; }

.tc-form-wrap{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:14px;
  padding:1.2rem;
  box-shadow:0 12px 26px color-mix(in srgb, var(--cseco) 14%, transparent);
}

.tc-form-head h2{ margin:0 0 .25rem; color:#121212; }
.tc-form-head p{ margin:0 0 1rem; color: color-mix(in srgb, var(--cseco) 80%, #000); }

.tc-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .9rem;
}

.tc-field{ display:grid; gap:.35rem; }
.tc-field-full{ grid-column: 1 / -1; }

.tc-field label{ font-weight:800; color:#191919; font-size:.92rem; }
.tc-field small{ color: color-mix(in srgb, var(--cseco) 75%, #000); font-size:.85rem; }

.tc-field input,
.tc-field select,
.tc-field textarea{
  width:100%;
  border-radius:12px;
  border:1px solid color-mix(in srgb, var(--cseco) 25%, transparent);
  background:#fff;
  padding:.78rem .9rem;
  outline:none;
  color:#151515;
  transition: border-color .15s ease, box-shadow .15s ease;
}

.tc-field textarea{
  min-height: 130px;
  resize: vertical;
}

.tc-field input:focus,
.tc-field select:focus,
.tc-field textarea:focus{
  border-color: color-mix(in srgb, var(--cprim) 60%, #fff);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--cprim) 18%, transparent);
}

.tc-actions{
  margin-top: 1rem;
  display:flex;
  gap:.7rem;
  flex-wrap:wrap;
}

.tc-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  border-radius:999px;
  padding:.82rem 1.15rem;
  font-weight:900;
  text-decoration:none;
  border:1px solid transparent;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease, border-color .2s ease;
  cursor:pointer;
  user-select:none;
}

.tc-btn-primary{
  background: var(--cprim);
  color:#fff;
  box-shadow:0 14px 28px color-mix(in srgb, var(--cprim) 35%, transparent);
}

.tc-btn-primary:hover{
  background: var(--cseco);
  color:#fff;
  box-shadow:0 14px 28px color-mix(in srgb, var(--cseco) 40%, transparent);
}

.tc-btn-ghost{
  background:#fff;
  color: var(--cseco);
  border-color: color-mix(in srgb, var(--cseco) 25%, transparent);
}

.tc-btn-ghost:hover{
  background: var(--cseco);
  color:#fff;
}

/* Alerts */
.tc-alert{
  display:flex; gap:.75rem; align-items:flex-start;
  padding: .9rem 1rem;
  border-radius: 14px;
  margin-bottom: 1rem;
  border: 1px solid transparent;
  background: #fff;
}

.tc-alert i{ margin-top:.15rem; }

.tc-alert-ok{
  border-color: color-mix(in srgb, var(--cprim) 30%, transparent);
  background: color-mix(in srgb, var(--cprim) 10%, #fff);
}

.tc-alert-ok i{ color: var(--cprim); }

.tc-alert-err{
  border-color: rgba(200, 0, 0, 0.25);
  background: rgba(200, 0, 0, 0.06);
}

.tc-alert-err i{ color: rgba(180, 0, 0, 0.85); }

.tc-disclaimer{
  margin-top:.9rem;
  color: color-mix(in srgb, var(--cseco) 75%, #000);
  font-size:.9rem;
}

/* Honeypot hidden */
.tc-hp{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
}

/* Responsivo */
@media (max-width: 980px){
  .tc-hero-inner{ grid-template-columns: 1fr; }
  .tc-grid{ grid-template-columns: 1fr; }
  .tc-btn{ width:100%; }
}

/* =========================
   PARCERIAS
   Cores: --cprim (primária) | --cseco (secundária)
========================= */

.pz-page { padding: 0; }

.pz-hero{
  padding: 2.2rem 0 1.5rem;
  background:
    radial-gradient(1200px 520px at 20% 10%, color-mix(in srgb, var(--cprim) 18%, transparent), transparent 60%),
    radial-gradient(900px 420px at 90% 20%, color-mix(in srgb, var(--cseco) 18%, transparent), transparent 60%);
}

.pz-hero-inner{
  display:grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 1.2rem;
  align-items: stretch;
}

.pz-kicker{
  display:inline-flex;
  padding:.35rem .75rem;
  border-radius:999px;
  background: color-mix(in srgb, var(--cprim) 14%, transparent);
  color: var(--cprim);
  font-weight: 800;
  font-size: .85rem;
}

.pz-title{
  margin:.75rem 0 .4rem;
  font-size: clamp(1.6rem, 2.7vw, 2.2rem);
  line-height:1.15;
  color:#121212;
}

.pz-subtitle{
  margin:0 0 1rem;
  color: color-mix(in srgb, var(--cseco) 85%, #000);
  line-height:1.6;
  max-width: 70ch;
}

.pz-highlights{ display:grid; gap:.55rem; margin-top:.9rem; }

.pz-highlight{
  display:flex;
  gap:.65rem;
  align-items:flex-start;
  color: color-mix(in srgb, var(--cseco) 85%, #000);
}
.pz-highlight i{ color: var(--cprim); margin-top:.18rem; }

.pz-card{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:14px;
  padding:1.15rem;
  box-shadow:0 18px 40px color-mix(in srgb, var(--cseco) 18%, transparent);
}

.pz-card h3{ margin:0 0 .65rem; color:#151515; }
.pz-card ul{ margin:0; padding:0; list-style:none; display:grid; gap:.55rem; }
.pz-card li{ display:flex; gap:.6rem; color: color-mix(in srgb, var(--cseco) 85%, #000); }
.pz-card li i{ color: var(--cprim); margin-top:.18rem; }
.pz-small{ margin:.9rem 0 0; color: color-mix(in srgb, var(--cseco) 75%, #000); font-size:.92rem; }

.pz-section{ padding: 1.6rem 0 2.2rem; }

.pz-form-wrap{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:14px;
  padding:1.2rem;
  box-shadow:0 12px 26px color-mix(in srgb, var(--cseco) 14%, transparent);
}

.pz-form-head h2{ margin:0 0 .25rem; color:#121212; }
.pz-form-head p{ margin:0 0 1rem; color: color-mix(in srgb, var(--cseco) 80%, #000); }

.pz-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .9rem;
}

.pz-field{ display:grid; gap:.35rem; }
.pz-field-full{ grid-column: 1 / -1; }

.pz-field label{ font-weight:800; color:#191919; font-size:.92rem; }
.pz-field small{ color: color-mix(in srgb, var(--cseco) 75%, #000); font-size:.85rem; }

.pz-field input,
.pz-field select,
.pz-field textarea{
  width:100%;
  border-radius:12px;
  border:1px solid color-mix(in srgb, var(--cseco) 25%, transparent);
  background:#fff;
  padding:.78rem .9rem;
  outline:none;
  color:#151515;
  transition: border-color .15s ease, box-shadow .15s ease;
}

.pz-field textarea{
  min-height: 140px;
  resize: vertical;
}

.pz-field input:focus,
.pz-field select:focus,
.pz-field textarea:focus{
  border-color: color-mix(in srgb, var(--cprim) 60%, #fff);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--cprim) 18%, transparent);
}

.pz-actions{
  margin-top: 1rem;
  display:flex;
  gap:.7rem;
  flex-wrap:wrap;
}

.pz-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  border-radius:999px;
  padding:.82rem 1.15rem;
  font-weight:900;
  text-decoration:none;
  border:1px solid transparent;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease, border-color .2s ease;
  cursor:pointer;
  user-select:none;
}

.pz-btn-primary{
  background: var(--cprim);
  color:#fff;
  box-shadow:0 14px 28px color-mix(in srgb, var(--cprim) 35%, transparent);
}
.pz-btn-primary:hover{
  background: var(--cseco);
  color:#fff;
  box-shadow:0 14px 28px color-mix(in srgb, var(--cseco) 40%, transparent);
}

.pz-btn-ghost{
  background:#fff;
  color: var(--cseco);
  border-color: color-mix(in srgb, var(--cseco) 25%, transparent);
}
.pz-btn-ghost:hover{
  background: var(--cseco);
  color:#fff;
}

.pz-alert{
  display:flex; gap:.75rem; align-items:flex-start;
  padding:.9rem 1rem;
  border-radius:14px;
  margin-bottom:1rem;
  border:1px solid transparent;
  background:#fff;
}
.pz-alert i{ margin-top:.15rem; }

.pz-alert-ok{
  border-color: color-mix(in srgb, var(--cprim) 30%, transparent);
  background: color-mix(in srgb, var(--cprim) 10%, #fff);
}
.pz-alert-ok i{ color: var(--cprim); }

.pz-alert-err{
  border-color: rgba(200,0,0,.25);
  background: rgba(200,0,0,.06);
}
.pz-alert-err i{ color: rgba(180,0,0,.85); }

.pz-disclaimer{
  margin-top:.9rem;
  color: color-mix(in srgb, var(--cseco) 75%, #000);
  font-size:.9rem;
}

/* =========================
   CONTATO
   Cores: --cprim (primária) | --cseco (secundária)
========================= */

.ct-page { padding: 0; }

.ct-hero{
  padding: 2.2rem 0 1.5rem;
  background:
    radial-gradient(1200px 520px at 20% 10%, color-mix(in srgb, var(--cprim) 18%, transparent), transparent 60%),
    radial-gradient(900px 420px at 90% 20%, color-mix(in srgb, var(--cseco) 18%, transparent), transparent 60%);
}

.ct-hero-inner{
  display:grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 1.2rem;
  align-items: stretch;
}

.ct-kicker{
  display:inline-flex;
  padding:.35rem .75rem;
  border-radius:999px;
  background: color-mix(in srgb, var(--cprim) 14%, transparent);
  color: var(--cprim);
  font-weight: 800;
  font-size: .85rem;
}

.ct-title{
  margin:.75rem 0 .4rem;
  font-size: clamp(1.6rem, 2.7vw, 2.2rem);
  line-height:1.15;
  color:#121212;
}

.ct-subtitle{
  margin:0 0 1rem;
  color: color-mix(in srgb, var(--cseco) 85%, #000);
  line-height:1.6;
  max-width: 70ch;
}

.ct-highlights{ display:grid; gap:.55rem; margin-top:.9rem; }

.ct-highlight{
  display:flex;
  gap:.65rem;
  align-items:flex-start;
  color: color-mix(in srgb, var(--cseco) 85%, #000);
}
.ct-highlight i{ color: var(--cprim); margin-top:.18rem; }

.ct-card{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:14px;
  padding:1.15rem;
  box-shadow:0 18px 40px color-mix(in srgb, var(--cseco) 18%, transparent);
}

.ct-card h3{ margin:0 0 .65rem; color:#151515; }
.ct-card ul{ margin:0; padding:0; list-style:none; display:grid; gap:.55rem; }
.ct-card li{ display:flex; gap:.6rem; color: color-mix(in srgb, var(--cseco) 85%, #000); }
.ct-card li i{ color: var(--cprim); margin-top:.18rem; }

.ct-section{ padding: 1.6rem 0 2.2rem; }

.ct-form-wrap{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--cseco) 20%, transparent);
  border-radius:14px;
  padding:1.2rem;
  box-shadow:0 12px 26px color-mix(in srgb, var(--cseco) 14%, transparent);
}

.ct-form-head h2{ margin:0 0 .25rem; color:#121212; }
.ct-form-head p{ margin:0 0 1rem; color: color-mix(in srgb, var(--cseco) 80%, #000); }

.ct-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .9rem;
}

.ct-field{ display:grid; gap:.35rem; }
.ct-field-full{ grid-column: 1 / -1; }

.ct-field label{ font-weight:800; color:#191919; font-size:.92rem; }

.ct-field input,
.ct-field select,
.ct-field textarea{
  width:100%;
  border-radius:12px;
  border:1px solid color-mix(in srgb, var(--cseco) 25%, transparent);
  background:#fff;
  padding:.78rem .9rem;
  outline:none;
  color:#151515;
  transition: border-color .15s ease, box-shadow .15s ease;
}

.ct-field textarea{
  min-height: 150px;
  resize: vertical;
}

.ct-field input:focus,
.ct-field select:focus,
.ct-field textarea:focus{
  border-color: color-mix(in srgb, var(--cprim) 60%, #fff);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--cprim) 18%, transparent);
}

.ct-actions{
  margin-top: 1rem;
  display:flex;
  gap:.7rem;
  flex-wrap:wrap;
}

.ct-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  border-radius:999px;
  padding:.82rem 1.15rem;
  font-weight:900;
  text-decoration:none;
  border:1px solid transparent;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease, border-color .2s ease;
  cursor:pointer;
  user-select:none;
}

.ct-btn-primary{
  background: var(--cprim);
  color:#fff;
  box-shadow:0 14px 28px color-mix(in srgb, var(--cprim) 35%, transparent);
}
.ct-btn-primary:hover{
  background: var(--cseco);
  color:#fff;
  box-shadow:0 14px 28px color-mix(in srgb, var(--cseco) 40%, transparent);
}

.ct-btn-ghost{
  background:#fff;
  color: var(--cseco);
  border-color: color-mix(in srgb, var(--cseco) 25%, transparent);
}
.ct-btn-ghost:hover{
  background: var(--cseco);
  color:#fff;
}

.ct-alert{
  display:flex; gap:.75rem; align-items:flex-start;
  padding:.9rem 1rem;
  border-radius:14px;
  margin-bottom:1rem;
  border:1px solid transparent;
  background:#fff;
}
.ct-alert i{ margin-top:.15rem; }

.ct-alert-ok{
  border-color: color-mix(in srgb, var(--cprim) 30%, transparent);
  background: color-mix(in srgb, var(--cprim) 10%, #fff);
}
.ct-alert-ok i{ color: var(--cprim); }

.ct-alert-err{
  border-color: rgba(200,0,0,.25);
  background: rgba(200,0,0,.06);
}
.ct-alert-err i{ color: rgba(180,0,0,.85); }

.ct-disclaimer{
  margin-top:.9rem;
  color: color-mix(in srgb, var(--cseco) 75%, #000);
  font-size:.9rem;
}

/* Honeypot hidden */
.ct-hp{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
}

@media (max-width: 980px){
  .ct-hero-inner{ grid-template-columns: 1fr; }
  .ct-grid{ grid-template-columns: 1fr; }
  .ct-btn{ width:100%; }
}


/* Honeypot hidden */
.pz-hp{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
}

@media (max-width: 980px){
  .pz-hero-inner{ grid-template-columns: 1fr; }
  .pz-grid{ grid-template-columns: 1fr; }
  .pz-btn{ width:100%; }
}


/*social icons*/
.social-footer-fa {
  padding: 0 0 18px 0;
}

.social-icons-fa {
  display: flex;
  justify-content: center;
  gap: 18px;
}

.social-icons-fa a {
  width: 44px;
  height: 44px;
  background: #ffffff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.social-icons-fa i {
  font-size: 18px;
  color: var(--cprim);
}

.social-icons-fa a:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
  background-color: var(--cseco);
}


/*avaliar-imoveis*/

#imoveis-anuncie {
  padding: 5rem 1rem;

}

.grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 28px;
  align-items: start;
}

@media(max-width:980px) {
  .grid {
    grid-template-columns: 1fr;
  }
}

h1 {
  font-size: 42px;
  line-height: 1.05;
  margin: 0 0 10px;
}

.sub {
  color: var(--muted);
  margin: 0 0 22px;
  font-size: 16px;
}

.steps {
  margin-top: 22px;
}

.step {
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: 14px;
  align-items: start;
  margin: 18px 0;
}

.step .n {
  font-size: 44px;
  color: var(--cprim);
  font-weight: 800;
  line-height: 1;
}

.step p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 14px;
}

.benef {
  margin-top: 42px;
}

.benef h2 {
  margin: 0 0 18px;
  font-size: 22px;
}

.benef-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

@media(max-width:980px) {
  .benef-grid {
    grid-template-columns: 1fr;
  }
}

.benef-card {
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  background: var(--bg);
}

.benef-card b {
  display: block;
  margin-bottom: 6px;
}

.cta {
  margin-top: 26px;
  text-align: left;
}

.cta h3 {
  margin: 0 0 10px;
  font-size: 22px;
}

.btn {
  display: inline-block;
  background: var(--cprim);
  color: #fff;
  text-decoration: none;
  border-radius: 8px;
  padding: 12px 18px;
  /* font-weight: 700; */
}

.form-card {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px;
  background: #fff;
}

.form-card h2 {
  margin: 4px 0 6px;
  font-size: 18px;
}

.form-card .hr {
  height: 1px;
  background: var(--border);
  margin: 14px 0;
}

.row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

@media(max-width:520px) {
  .row {
    grid-template-columns: 1fr;
  }
}

label {
  display: block;
  font-size: 11px;
  color: var(--muted);
  margin: 10px 0 6px;
  text-transform: uppercase;
  letter-spacing: .03em;
}

input,
select {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
  font-size: 14px;
  outline: none;
}

input:focus,
select:focus {
  border-color: #c7cdd6;
}

.checks {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 10px
}

.check {
  display: flex;
  gap: 8px;
  align-items: center;
  color: var(--text);
  font-size: 13px
}

.check input {
  width: auto
}

.actions {
  margin-top: 14px
}

.err {
  background: #fff5f5;
  border: 1px solid #fecaca;
  color: #7f1d1d;
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 12px
}

.ok {
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  color: #14532d;
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 12px
}

.privacy {
  font-size: 12px;
  color: var(--muted);
  margin-top: 12px
}

.float-wa {
  position: fixed;
  right: 16px;
  bottom: 16px;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: #25D366;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: #fff;
  font-weight: 900
}

/*GOOGLE MAPS */
.property-map {
  margin: 0;
  padding: 0;
}

.property-map h2 {
  margin-bottom: 16px;
  font-size: 1.25rem;
}

/*Editor*/
.blog-post-content img {
  padding: 0 0 10px;
  max-width: 100%;
  height: auto;
}

.blog-post-cover {
  width: 100%;
  height: 450px;
  background-position: center;
}

.blog-post-meta-info {
  margin: 0 0 10px;
}

article.blog-post-content p {
  margin: 0;
  padding: 0;
}

/*imoveis financiamento*/
/* =========================
   FINANCIAMENTO (BANCOS)
   ========================= */

.financing-box {
  margin-top: 14px;
  padding-top: 10px;
}

.financing-title {
  display: inline-block;
  font-weight: 800;
  font-size: 1.05rem;
  color: #2b2b2b;
  text-decoration: none;
  margin: 2px 0 12px;
  position: relative;
}

/* “sublinhado” estilizado igual ao print */
.financing-title::after {
  /* content: "";
  display: block;
  width: 38px;
  height: 3px;
  border-radius: 999px;
  background: #7b102c;
  margin-top: 6px;*/
}

.bank-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

/* No mobile fica 2 colunas (mais parecido com a imagem) */
@media (max-width: 520px) {
  .bank-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.bank-card {
  background: #f3f3f3;
  border: 1px solid #d9d9d9;
  border-radius: 8px;
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 64px;
  text-decoration: none;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
  overflow: hidden;
}

.bank-card img {
  max-width: 100%;
  max-height: 75px;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
  filter: saturate(1.05);
}

.bank-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(0, 0, 0, .10);
  border-color: var(--cprim);
}

.bank-card:active {
  transform: translateY(0);
  box-shadow: 0 6px 14px rgba(0, 0, 0, .10);
}

.bank-card:focus-visible {
  outline: 3px solid rgba(123, 16, 44, .25);
  outline-offset: 2px;
}

section.financing-box {
  padding: 0;
}

/* responsive */

@media (max-width: 1024px) {
  .cards-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .contact-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .header-right {
    display: none;
  }

  .main-nav {
    position: fixed;
    top: 60px;
    right: 0;
    flex-direction: column;
    align-items: flex-start;
    background: #fff;
    padding: 0.8rem 1rem 1rem;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    transform: translateY(-20px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease;
  }

  .main-nav.open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }

  .menu-toggle {
    display: block;
  }

  .cards-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cards-grid-3,
  .cta-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .hero {
    height: 460px;
  }

  .hero-title {
    font-size: 1.3rem;
  }

  .cards-grid {
    grid-template-columns: 1fr;
  }
}