/* ============================================================
   Serra Imóveis — site styles
   Layout fiel ao Figma "Serra Solar - Imóveis" + camada de motion premium
   ============================================================ */

*{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Marca */
  --green:#1E7145;
  --green-dark:#14502F;
  --orange:#EE8A1E;
  --orange-hover:#D9791A;
  --gold:#E0A92E;
  --wa:#25D366;

  /* Neutros quentes (em vez de preto/cinza frios) */
  --ink:#17140F;             /* texto principal: quase-preto quente */
  --ink-soft:#3A352E;        /* texto secundário forte */
  --paper:#FCFBF8;           /* fundo de página: branco quente */
  --gray:#F2F0EA;            /* superfícies/cards: off-white quente */
  --gray-2:#E9E6DE;          /* superfície um tom acima */
  --line:rgba(23,20,15,.10); /* bordas sutis */
  --line-strong:rgba(23,20,15,.16);
  --text-muted:#6B6358;
  --text-muted-2:#7A7268;

  /* Tipografia */
  --font-ui:'Manrope','Segoe UI',system-ui,-apple-system,Arial,sans-serif;
  --font-display:'Playfair Display',Georgia,serif;

  /* Raio (escala consistente) */
  --r-xs:8px; --r-sm:12px; --r:16px; --r-lg:22px; --r-xl:30px;

  /* Elevação (sombras sutis, em camadas) */
  --sh-sm:0 1px 2px rgba(23,20,15,.04), 0 3px 8px rgba(23,20,15,.05);
  --sh-md:0 8px 20px rgba(23,20,15,.07), 0 18px 44px rgba(23,20,15,.07);
  --sh-lg:0 24px 60px rgba(23,20,15,.16);

  --ease:cubic-bezier(.22,.61,.36,1);
  --section-y:clamp(64px,7vw,116px);
  /* Largura de conteúdo: preenche Full HD e centraliza em telas maiores (full-bleed) */
  --maxw:1820px;
  --gut:clamp(20px,4vw,72px);
  --edge:max(var(--gut), calc((100% - var(--maxw)) / 2 + var(--gut)));
}

html{scroll-behavior:smooth}

body{
  background:var(--paper);
  font-family:var(--font-ui);
  color:var(--ink);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:"cv05" 1,"ss01" 1;
  letter-spacing:-0.01em;
  overflow-x:hidden;
}

/* Foco acessível e consistente em todo o site */
:focus-visible{outline:2.5px solid var(--green);outline-offset:2px;border-radius:3px}
:focus:not(:focus-visible){outline:none}

::selection{background:rgba(238,138,30,0.25)}

img,svg{display:block}

.site{
  background:var(--paper);
  width:100%;
  max-width:none;
  margin:0 auto;
  position:relative;
}
/* utilitário: limita e centraliza o conteúdo interno (fundo full-bleed) */
.contain{max-width:var(--maxw);margin-inline:auto;width:100%}

/* Serif display helper */
.serif{font-family:'Playfair Display',serif;font-weight:500;font-style:normal}
.serif em{font-style:italic;font-weight:500}

a{transition:opacity .2s ease,color .2s ease}

.btn{
  font-weight:600;letter-spacing:-0.01em;
  transition:transform .22s var(--ease),background-color .22s ease,box-shadow .25s ease;
  will-change:transform;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(23,20,15,.12)}
.btn:active{transform:translateY(0);box-shadow:0 4px 10px rgba(0,0,0,.12)}
.btn-orange:hover{background-color:var(--orange-hover)!important}
.ico-arrow{transition:transform .25s var(--ease)}
.btn:hover .ico-arrow{transform:translateX(4px)}

/* ====================== STICKY HEADER ======================= */
.sticky-bar{
  position:fixed;top:0;left:0;right:0;z-index:80;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(160%) blur(12px);
  -webkit-backdrop-filter:saturate(160%) blur(12px);
  box-shadow:0 6px 24px rgba(0,0,0,.08);
  transform:translateY(-105%);
  transition:transform .45s var(--ease);
}
.sticky-bar.is-visible{transform:translateY(0)}
.sticky-bar.is-visible.is-hidden{transform:translateY(-105%)}
.sticky-bar__inner{
  max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;
  justify-content:space-between;gap:24px;padding:14px var(--gut);
}
.sticky-bar__logo img{height:32px;width:auto}
.sticky-bar__links{display:flex;align-items:center;gap:34px}
.sticky-bar__links a{text-decoration:none;color:#1a1a1a;font-size:15px}
.sticky-bar__links a:hover{color:var(--green)}
.sticky-bar__cta{
  display:inline-flex;align-items:center;gap:8px;background:var(--green);
  color:#fff;font-size:14px;padding:11px 20px;border-radius:8px;text-decoration:none;
}
@media (max-width:860px){
  .sticky-bar__links{display:none}
}

/* ====================== HERO ================================= */
.hero{padding:12px;background:var(--paper)}
.hero__frame{
  position:relative;border-radius:8px;overflow:hidden;
  min-height:804px;display:flex;flex-direction:column;
}
.hero__media{position:absolute;inset:-8% 0;will-change:transform}
.hero__bg{width:100%;height:100%;object-fit:cover}
.hero__overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(15,13,9,0) 38%, rgba(15,13,9,.32) 72%, rgba(15,13,9,.74) 100%),
    linear-gradient(96deg, rgba(15,13,9,.72) 0%, rgba(15,13,9,.34) 38%, rgba(15,13,9,0) 64%);
}

/* Nav (dentro do hero) */
.nav{
  position:relative;z-index:5;display:flex;align-items:center;
  justify-content:space-between;padding:32px 48px;
}
.nav__logo img{height:38px;width:auto}
.nav__links{display:flex;align-items:center;gap:48px}
.nav__links a{text-decoration:none;color:#fff;font-size:16px;position:relative}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;
  background:#fff;transition:width .28s var(--ease);
}
.nav__links a:hover::after{width:100%}
.nav__menu{
  width:50px;height:50px;border:none;border-radius:90px;background:#fff;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease;flex:0 0 auto;
}
.nav__menu:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(0,0,0,.2)}

/* Botão de menu na sticky bar */
.sticky-bar__menu{
  width:44px;height:44px;border:1px solid rgba(0,0,0,.1);border-radius:10px;background:#fff;
  display:flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 auto;
  transition:background-color .2s ease,transform .2s ease;
}
.sticky-bar__menu:hover{background:var(--gray);transform:translateY(-1px)}

/* ====================== MENU EXPANDIDO ====================== */
.menu{
  position:fixed;inset:0;z-index:200;background:var(--paper);
  display:flex;flex-direction:column;
  opacity:0;transition:opacity .45s var(--ease);
}
.menu[hidden]{display:none}
.menu.is-open{opacity:1}
body.menu-open{overflow:hidden}

.menu__bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:32px 48px;flex:0 0 auto;
}
.menu__logo img{height:38px;width:auto}
.menu__close{
  width:50px;height:50px;border:1px solid rgba(20,80,47,.25);border-radius:12px;background:#fff;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background-color .2s ease,transform .35s var(--ease);
}
.menu__close:hover{background:var(--gray);transform:rotate(90deg)}

.menu__body{
  flex:1;display:grid;
  grid-template-columns:minmax(0,.8fr) minmax(0,1.8fr) minmax(0,.85fr);
  gap:40px;align-items:center;
  padding:0 48px 48px;max-width:var(--maxw);width:100%;margin-inline:auto;overflow-y:auto;
}

/* coluna 1: thumbs sobrepostos */
.menu__visual{position:relative;height:min(440px,52vh);opacity:0;transform:translateY(20px);transition:opacity .55s var(--ease) .12s,transform .55s var(--ease) .12s}
.menu.is-open .menu__visual{opacity:1;transform:none}
.menu__thumb{position:absolute;border-radius:24px;overflow:hidden;box-shadow:0 30px 60px rgba(0,0,0,.18)}
.menu__thumb img{width:100%;height:100%;object-fit:cover}
.menu__thumb--a{width:78%;height:64%;top:0;left:0;z-index:1}
.menu__thumb--b{width:60%;height:52%;bottom:0;right:0;z-index:2;border:6px solid #fff}

/* coluna 2: navegação */
.menu__nav{display:flex;flex-direction:column;gap:26px}
.menu__label{font-size:14px;color:var(--text-muted);letter-spacing:.02em}
.menu__cols{display:flex;gap:56px;flex-wrap:nowrap}
.menu__links{list-style:none;display:flex;flex-direction:column;gap:4px;min-width:0}
.menu__links li{opacity:0;transform:translateY(26px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.menu.is-open .menu__links li{opacity:1;transform:none;transition-delay:calc(.16s + var(--i) * .055s)}
.menu__links a{
  display:inline-block;text-decoration:none;color:#0a0a0a;white-space:nowrap;
  font-size:clamp(22px,2.1vw,38px);line-height:1.25;letter-spacing:-0.02em;
  transition:color .2s ease,transform .3s var(--ease);
}
.menu__links a:hover{color:var(--orange);transform:translateX(8px)}
.menu__cta{
  align-self:flex-start;display:inline-flex;align-items:center;gap:10px;background:var(--green);
  color:#fff;font-size:16px;padding:15px 28px;border-radius:8px;text-decoration:none;margin-top:8px;
  opacity:0;transform:translateY(16px);transition:opacity .55s var(--ease) .4s,transform .55s var(--ease) .4s,background-color .22s ease,box-shadow .25s ease;
}
.menu.is-open .menu__cta{opacity:1;transform:none}

/* coluna 3: contato + social */
.menu__aside{display:flex;flex-direction:column;gap:9px;align-self:center;opacity:0;transform:translateY(20px);transition:opacity .55s var(--ease) .3s,transform .55s var(--ease) .3s}
.menu.is-open .menu__aside{opacity:1;transform:none}
.menu__contact{font-size:18px;color:#0a0a0a;text-decoration:none;transition:color .2s ease}
.menu__contact:hover{color:var(--green)}
.menu__contact--muted{color:var(--text-muted)}
.menu__label--social{margin-top:22px}
.menu__socials{display:flex;gap:10px;margin-top:6px}
.menu__socials a{
  width:42px;height:42px;border-radius:50%;border:1px solid rgba(20,80,47,.25);
  display:flex;align-items:center;justify-content:center;text-decoration:none;
  transition:background-color .2s ease,transform .2s ease;
}
.menu__socials a:hover{background:var(--gray);transform:translateY(-2px)}

@media (max-width:980px){
  .menu__body{grid-template-columns:1fr;align-content:start;gap:30px;padding-bottom:40px}
  .menu__visual{display:none}
  .menu__cols{gap:48px}
  .menu__aside{align-self:start}
}
@media (max-width:560px){
  .menu__bar{padding:22px 24px}
  .menu__body{padding-left:24px;padding-right:24px}
  .menu__cols{flex-direction:column;gap:0}
}

/* ============== HEADER DAS PÁGINAS INTERNAS =============== */
.page-header{position:sticky;top:0;z-index:80;background:#fff;transition:box-shadow .3s ease}
.page-header.is-scrolled{box-shadow:0 6px 24px rgba(0,0,0,.07)}
.page-header__inner{
  max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:16px var(--gut);
}
.page-header__logo img{height:34px;width:auto}
.page-header__links{display:flex;align-items:center;gap:34px}
.page-header__links a{text-decoration:none;color:#1a1a1a;font-size:15px;position:relative}
.page-header__links a:hover{color:var(--green)}
.page-header__links a.is-active{color:var(--green);font-weight:700}
.page-header__actions{display:flex;align-items:center;gap:12px}
.page-header__cta{display:inline-flex;align-items:center;gap:8px;background:var(--green);color:#fff;font-size:14px;padding:11px 20px;border-radius:8px;text-decoration:none}
.page-header__menu{
  width:44px;height:44px;border:1px solid rgba(0,0,0,.1);border-radius:10px;background:#fff;
  display:flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 auto;
  transition:background-color .2s ease,transform .2s ease;
}
.page-header__menu:hover{background:var(--gray);transform:translateY(-1px)}
@media (max-width:860px){.page-header__links{display:none}}
@media (max-width:480px){.page-header__cta{display:none}}

/* Hero content */
.hero__content{
  position:relative;z-index:5;flex:1;display:flex;flex-direction:column;
  justify-content:flex-end;padding:48px;gap:40px;
  max-width:var(--maxw);margin-inline:auto;width:100%;
}
.hero__top{display:flex;justify-content:space-between;align-items:flex-end;gap:24px}
.hero__copy{max-width:850px;display:flex;flex-direction:column;gap:31px}
.hero__pill{
  display:inline-flex;align-items:center;gap:8px;align-self:flex-start;
  font-size:14px;line-height:1;color:#fff;letter-spacing:0;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  padding:9px 16px 9px 13px;border-radius:90px;
}
.hero__pill b{font-weight:700}
.hero__pill svg{color:var(--gold);flex:0 0 auto}
.hero__title{
  font-size:clamp(40px,5.7vw,80px);line-height:1;letter-spacing:-1px;color:#fff;margin:0;
}
.hero__lead{max-width:448px;font-size:16px;line-height:24px;color:#fff}
.hero__actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.btn-white{
  display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--ink);
  font-size:16px;padding:16px 32px;border-radius:8px;text-decoration:none;
}

/* Google rating card */
.gcard{
  flex:0 0 auto;background:#fff;border-radius:16px;
  box-shadow:0 16px 44px rgba(0,0,0,.22);
  padding:16px 20px;display:flex;flex-direction:column;gap:14px;
}
.gcard__head{display:flex;align-items:center;gap:8px}
.gcard__head span{font-weight:700;font-size:18px;color:#1f1f1f}
.gcard__row{display:flex;align-items:center;gap:16px}
.gcard__avatars{display:flex;align-items:center}
.gcard__avatars span{
  width:34px;height:34px;border-radius:50%;border:2px solid #fff;
  margin-left:-10px;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#fff;
}
.gcard__avatars span:first-child{margin-left:0}
.gcard__rating{display:flex;flex-direction:column;gap:2px}
.gcard__stars{color:var(--gold);font-size:15px;letter-spacing:1px}
.gcard__count{font-size:13px;color:#666}

/* Search bar */
.search{
  border-radius:8px;background:rgba(255,255,255,0.13);
  border:1px solid rgba(255,255,255,0.18);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:32px;
}
.search__row{display:flex;gap:20px;align-items:flex-end;flex-wrap:wrap}
.search__field{flex:1 1 220px;display:flex;flex-direction:column;gap:8px}
.search__field>span{font-size:13px;color:#fff;opacity:.85}
.select{position:relative;background:#fff;border-radius:6px;display:flex;align-items:center}
.select__lead{position:absolute;left:14px;top:50%;transform:translateY(-50%);pointer-events:none}
.select select{
  appearance:none;-webkit-appearance:none;border:none;background:transparent;
  width:100%;padding:15px 40px 15px 42px;font-family:inherit;font-size:16px;color:var(--ink);
  cursor:pointer;outline:none;
}
.select__chev{position:absolute;right:14px;top:50%;transform:translateY(-50%);pointer-events:none;transition:transform .25s ease}
.select:hover .select__chev{transform:translateY(-50%) translateY(2px)}
.search .search__go{
  flex:0 0 auto;width:54px;height:52px;background:var(--orange);border:none;border-radius:6px;
  padding:0;gap:0;display:flex;align-items:center;justify-content:center;text-decoration:none;cursor:pointer;
}

/* ================== FAIXA DE CONFIANÇA ================== */
.trust{background:var(--paper);padding:clamp(28px,4vw,52px) 12px 0}
.trust__inner{
  max-width:var(--maxw);margin-inline:auto;display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line);border-radius:var(--r);background:var(--gray);overflow:hidden;
}
.trust__item{
  padding:clamp(22px,2.4vw,34px) clamp(20px,2vw,34px);
  display:flex;flex-direction:column;gap:6px;border-left:1px solid var(--line);
}
.trust__item:first-child{border-left:none}
.trust__item b{font-family:var(--font-display);font-weight:600;font-size:clamp(19px,1.6vw,25px);color:var(--ink);letter-spacing:-0.01em}
.trust__item span{font-size:13.5px;line-height:1.45;color:var(--text-muted)}
@media (max-width:860px){
  .trust__inner{grid-template-columns:1fr 1fr}
  .trust__item:nth-child(odd){border-left:none}
  .trust__item:nth-child(n+3){border-top:1px solid var(--line)}
}
@media (max-width:480px){
  .trust__inner{grid-template-columns:1fr}
  .trust__item{border-left:none;border-top:1px solid var(--line)}
  .trust__item:first-child{border-top:none}
}

/* ================== SEÇÕES GENÉRICAS ===================== */
.section{padding:var(--section-y) var(--edge);background:var(--paper)}
.imoveis__head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:40px;margin-bottom:60px;
}
.imoveis__title-wrap{display:flex;flex-direction:column;gap:20px}
.imoveis__eyebrow{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.13em;color:var(--green)}
.imoveis__title{
  font-size:clamp(40px,5.7vw,80px);line-height:1;letter-spacing:-0.02em;color:var(--orange);margin:0;
}
.imoveis__intro{display:flex;flex-direction:column;align-items:flex-end;gap:34px;max-width:286px}
.imoveis__intro p{
  font-size:16px;line-height:25.6px;letter-spacing:-0.32px;color:var(--text-muted);text-align:right;
}
.btn-orange{
  display:inline-flex;align-items:center;gap:12px;background:var(--orange);color:#fff;
  font-size:16px;padding:12px 25px;border-radius:8px;text-decoration:none;
}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:80px 24px}

/* Property card */
.prop-card{display:flex;flex-direction:column;gap:14px;cursor:pointer;transition:transform .35s var(--ease)}
.prop-card .ps-frame{
  position:relative;border-radius:var(--r-sm);overflow:hidden;aspect-ratio:648/376;
  box-shadow:var(--sh-sm);transition:box-shadow .35s ease;
}
.prop-card:hover{transform:translateY(-6px)}
.prop-card:hover .ps-frame{box-shadow:var(--sh-md)}
.prop-card__img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.prop-card:hover .prop-card__img{transform:scale(1.06)}
/* botão-seta que surge no hover */
.prop-card__go{
  position:absolute;right:14px;bottom:14px;width:44px;height:44px;border-radius:50%;
  background:rgba(252,251,248,.96);display:flex;align-items:center;justify-content:center;
  box-shadow:var(--sh-sm);opacity:0;transform:translateY(8px) scale(.92);
  transition:opacity .3s var(--ease),transform .3s var(--ease);
}
.prop-card__go svg path{stroke:var(--green)}
.prop-card:hover .prop-card__go,.prop-card:focus-visible .prop-card__go{opacity:1;transform:translateY(0) scale(1)}
.badge{
  position:absolute;top:14px;left:14px;border-radius:90px;
  padding:7px 15px;font-weight:700;font-size:11.5px;color:#fff;
  text-transform:uppercase;letter-spacing:.4px;
  box-shadow:0 4px 14px rgba(15,13,9,.22);backdrop-filter:blur(2px);
}
.badge--sale{background:var(--green)}
.badge--rent{background:var(--orange)}
.badge--done{background:rgba(23,20,15,.78)}
.imoveis__empty{font-size:16px;color:var(--text-muted);padding:24px 0;grid-column:1/-1}
a.prop-card{text-decoration:none;color:inherit}
.prop-card__loc{display:flex;align-items:center;gap:6px}
.prop-card__loc span{font-weight:700;font-size:11.3px;color:var(--ink);text-transform:uppercase;letter-spacing:0.2px}
.prop-card__specs{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  border-bottom:1px solid var(--line);padding-bottom:14px;
}
.prop-card__features{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.feat{display:flex;align-items:center;gap:8px}
.feat span{font-weight:700;font-size:12px;color:var(--ink)}
.feat span.is-light{font-weight:600;font-size:11.1px}
.prop-card__price{font-size:21px;font-weight:700;letter-spacing:-0.3px;color:var(--ink)}
.prop-card__foot{display:flex;align-items:center;justify-content:space-between;gap:12px}
.prop-card__name{font-size:18px;letter-spacing:-0.4px;color:var(--ink-soft);font-weight:600}
.prop-card__cue{
  font-size:13px;font-weight:700;color:var(--green);white-space:nowrap;flex:0 0 auto;
  opacity:0;transform:translateX(-4px);transition:opacity .3s ease,transform .3s ease;
}
.prop-card:hover .prop-card__cue{opacity:1;transform:translateX(0)}

.center-cta{display:flex;justify-content:center;margin-top:60px}

/* ================== PROCESSO ============================== */
.process{background:var(--paper);padding:clamp(8px,2vw,24px) clamp(12px,2vw,40px)}
.process__grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-width:var(--maxw);margin-inline:auto}
.process__panel{
  background:var(--green);border-radius:8px;padding:60px;display:flex;
  flex-direction:column;justify-content:center;gap:42px;
}
.process__title{font-size:clamp(30px,3.6vw,48px);line-height:1;letter-spacing:-1px;color:#fff;margin:0}
.process__steps{display:flex;flex-direction:column;gap:0}
.pstep{display:flex;gap:24px}
.pstep__rail{display:flex;flex-direction:column;align-items:center;flex:0 0 48px}
.pstep__num{
  width:48px;height:48px;border-radius:100px;background:var(--orange);
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;
}
.pstep__line{width:2px;flex:1;background:var(--orange);margin:4px 0}
.pstep__body{padding-bottom:28px}
.pstep__body--last{padding-bottom:0}
.pstep h3{font-size:24px;line-height:1.1;color:#fff;font-weight:400;margin:0 0 12px}
.pstep p{font-size:16px;line-height:24px;color:rgba(255,255,255,0.7);max-width:388px}
.process__media{border-radius:8px;overflow:hidden;min-height:600px}
.process__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.process__media:hover img{transform:scale(1.05)}
.process__cta{
  display:inline-flex;align-items:center;justify-content:center;background:var(--orange);
  color:#fff;font-size:16px;padding:12px 32px;border-radius:8px;text-decoration:none;margin-top:8px;align-self:flex-start;
}

/* ================== ETAPAS ================================ */
.steps{background:var(--paper);padding:clamp(28px,4vw,40px) var(--edge);display:flex;flex-direction:column;gap:20px}
.step{display:grid;grid-template-columns:1fr 100px 1fr;gap:30px;align-items:stretch}
.step__img{border-radius:12px;background:var(--gray);padding:8px;min-height:300px}
.step__img>div{border-radius:9px;overflow:hidden;width:100%;height:100%;aspect-ratio:554/293}
.step__img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.step:hover .step__img img{transform:scale(1.05)}
.step__rail{display:flex;flex-direction:column;align-items:center}
.step__num{
  width:64px;height:58px;border-radius:12px;background:#000;display:flex;
  align-items:center;justify-content:center;flex:0 0 auto;
  font-weight:500;font-size:15px;letter-spacing:-0.48px;color:rgba(237,237,237,0.85);
}
.step__line{width:3px;flex:1;background:rgba(0,0,0,0.08)}
.step__card{
  position:relative;border-radius:12px;background:var(--gray);padding:36px 32px;
  display:flex;flex-direction:column;justify-content:center;gap:10px;overflow:hidden;
}
.step__card--right{align-items:flex-end;text-align:right}
.step__tag{
  position:absolute;top:0;background:#000;color:var(--gray);font-weight:700;font-size:13px;
  line-height:1;padding:8px 14px;
}
.step__tag--tr{right:0;border-radius:0 12px 0 14px}
.step__tag--tl{left:0;border-radius:0 0 14px 0}
.step__card h3{font-weight:700;font-size:24px;line-height:1.1;letter-spacing:-1px;color:var(--ink);margin:0;max-width:14em}
.step__card p{font-weight:400;font-size:14.6px;line-height:1.55;letter-spacing:-0.48px;color:rgba(0,0,0,0.7);margin:0}
.steps__cta-wrap{display:flex;justify-content:center;margin-top:8px}
.steps__cta{display:inline-flex;align-items:center;gap:10px;background:var(--orange);color:#fff;font-size:16px;padding:16px 32px;border-radius:8px;text-decoration:none}

/* ================== SOBRE ================================ */
.about{background:var(--gray);padding:clamp(56px,5vw,92px) var(--edge)}
.about__inner{display:flex;gap:90px;align-items:center;flex-wrap:wrap}
.about__copy{flex:1 1 500px;display:flex;flex-direction:column;gap:32px}
.about__quote{font-size:40px;line-height:1.05;letter-spacing:-0.02em;color:var(--orange)}
.about__text{font-size:16px;line-height:1.4;letter-spacing:-0.32px;color:var(--text-muted);white-space:pre-line}
.btn-bordered{align-self:flex-start;border:1px solid rgba(0,0,0,.1)}
.about__media{flex:1 1 550px;border-radius:24px;background:#fff;box-shadow:0 2px 20px -5px rgba(0,0,0,0.15);padding:8px}
.about__media>div{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:618/684;border:1px solid #D1D1D1}
.about__media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.about__media:hover img{transform:scale(1.04)}

/* ================== DEPOIMENTOS ========================== */
.testi__head{display:flex;flex-direction:column;gap:14px;margin-bottom:48px}
.testi__head span{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.13em;color:var(--green)}
.testi__title{font-size:clamp(34px,4.6vw,64px);line-height:1.05;letter-spacing:-0.02em;color:var(--ink);margin:0;max-width:18em}
.testi__grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:stretch}
.testi__big{position:relative;border-radius:20px;overflow:hidden;min-height:500px;display:flex;align-items:flex-end}
.testi__big img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.testi__big:hover img{transform:scale(1.05)}
.testi__big-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,80,47,0.94) 12%,rgba(20,80,47,0.45) 70%,rgba(20,80,47,0.25) 100%)}
.testi__big-body{position:relative;padding:48px;display:flex;flex-direction:column;gap:32px}
.testi__big-quote{font-size:28px;line-height:33.6px;color:#fff}
.testi__author{display:flex;flex-direction:column;gap:9px}
.testi__author-line{display:flex;align-items:center;gap:10px;opacity:.85}
.testi__author-line span:first-child{width:18px;height:2px;background:#fff;display:inline-block}
.testi__author-line span:last-child{font-size:17px;color:#fff}
.testi__author-sub{font-size:15px;color:#fff;opacity:.8}
.testi__big-foot{display:flex;align-items:center;gap:20px;flex-wrap:wrap;padding-top:8px;border-top:1px solid rgba(255,255,255,0.2)}
.testi__big-foot>span:first-child{font-size:15px;color:#fff;opacity:.9;max-width:18em}
.testi__big-foot .rate{font-size:16px;color:var(--gold);white-space:nowrap}
.testi__big-foot .rate b{color:#fff;font-weight:400}
.testi__small-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.testi-card{background:var(--gray);border-radius:20px;padding:26px;display:flex;flex-direction:column;gap:14px;transition:transform .3s var(--ease),box-shadow .3s ease}
.testi-card:hover{transform:translateY(-5px);box-shadow:var(--sh-md)}
.testi-card__stars{font-size:14px;color:var(--gold);letter-spacing:1px}
.testi-card p{font-size:14.5px;line-height:1.5;color:var(--ink);flex:1}
.testi-card__person{display:flex;align-items:center;gap:10px}
.testi-card__avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;flex:0 0 auto}
.testi-card__person div{display:flex;flex-direction:column}
.testi-card__person b{font-size:14px;font-weight:700;color:var(--ink)}
.testi-card__person small{font-size:12px;color:var(--text-muted)}

/* ================== FAQ ================================== */
.faq__grid{display:grid;grid-template-columns:550px 1fr;gap:20px;align-items:flex-end}
.faq__intro{display:flex;flex-direction:column;gap:48px}
.faq__intro-head{display:flex;flex-direction:column;gap:15px}
.faq__intro h2{font-size:40px;line-height:1;letter-spacing:-0.4px;color:var(--ink);margin:0;max-width:10em}
.faq__intro p{font-size:18px;line-height:1.4;letter-spacing:-0.18px;color:var(--text-muted-2);max-width:20em}
.faq__contact{display:flex;flex-direction:column;gap:16px;max-width:272px}
.faq__contact>span{font-size:18px;letter-spacing:-0.36px;color:var(--text-muted-2)}
.faq__card{background:var(--gray);border-radius:20px;padding:24px;display:flex;flex-direction:column;gap:48px}
.faq__card-person{display:flex;flex-direction:column;gap:12px}
.faq__card-person img{width:56px;height:56px;border-radius:8px;object-fit:cover}
.faq__card-person div{display:flex;flex-direction:column;gap:2px}
.faq__card-person div span:first-child{font-size:18px;letter-spacing:-0.18px;color:var(--ink);line-height:1.3}
.faq__card-person div span:last-child{font-size:16px;color:var(--text-muted-2)}
.faq__card-cta{display:inline-flex;align-items:center;justify-content:center;background:var(--green);color:#fff;font-size:16px;padding:14px 26px;border-radius:var(--r-xs);text-decoration:none}
.faq__card-cta:hover{background:var(--green-dark)}
.faq__list{display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--gray);border-radius:16px;overflow:hidden}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  text-align:left;background:transparent;border:none;cursor:pointer;padding:24px 28px;
  font-family:inherit;transition:background-color .2s ease;
}
.faq-q:hover{background-color:#E4E4E4}
.faq-q>span:first-child{font-size:18px;font-weight:700;color:var(--ink)}
.faq-q__icon{
  flex:0 0 auto;width:34px;height:34px;border-radius:50%;background:#000;
  display:flex;align-items:center;justify-content:center;transition:transform .3s var(--ease);
}
.faq-item.is-open .faq-q__icon{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease),padding .35s var(--ease);padding:0 28px;font-size:16px;line-height:1.6;color:var(--text-muted)}
.faq-item.is-open .faq-a{max-height:400px;padding:0 28px 24px}

/* ================== CONTATO ============================== */
.contato{background:var(--paper);padding:0 12px clamp(8px,2vw,24px)}
.contato__bar{background:var(--green);border-radius:20px;padding:35px 60px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;max-width:var(--maxw);margin-inline:auto}
.contato__item{display:flex;align-items:center;gap:16px}
.contato__item--div{border-left:1px solid rgba(255,255,255,0.2);padding-left:24px}
.contato__icon{width:48px;height:48px;border-radius:12px;background:rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;flex:0 0 auto;transition:background-color .25s ease}
.contato__item:hover .contato__icon{background:rgba(255,255,255,0.22)}
.contato__item div{display:flex;flex-direction:column;gap:3px}
.contato__item b{font-size:16px;font-weight:700;color:#fff}
.contato__item span{font-size:15px;color:rgba(255,255,255,0.85)}
.contato__item a{font-size:15px;color:rgba(255,255,255,0.85);text-decoration:none}
.contato__item a:hover{color:#fff}

/* ================== FOOTER ============================== */
.footer{background:var(--paper);padding:clamp(40px,5vw,56px) 12px 12px}
.footer__inner{position:relative;overflow:hidden;border-radius:24px;background:var(--orange);display:flex;flex-direction:column;justify-content:space-between;gap:64px;padding:clamp(28px,4vw,48px);min-height:680px;max-width:var(--maxw);margin-inline:auto}
.footer__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 0%,rgba(0,0,0,0.04) 38%,rgba(0,0,0,0.55) 100%)}
.footer__top{position:relative;z-index:2;display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
.footer__brand{flex:1 1 420px;max-width:648px;display:flex;flex-direction:column;align-items:flex-start;gap:22px}
.footer__brand img{height:54px;width:auto}
.footer__tagline{font-size:clamp(22px,2.3vw,29.5px);line-height:1.1;color:#fff}
.footer__brand p{font-size:14px;line-height:1.4;color:rgba(255,255,255,0.85);max-width:42em}
.footer__form{display:flex;align-items:center;background:#fff;border-radius:90px;padding:4px;max-width:346px}
.footer__form input{flex:1;min-width:0;border:none;background:transparent;padding:0 16px;font-family:inherit;font-size:14px;color:#333;outline:none}
.footer__form button{flex:0 0 auto;background:var(--green);color:#fff;font-weight:700;font-size:14px;padding:12px 28px;border:none;border-radius:90px;cursor:pointer;transition:background-color .2s ease}
.footer__form button:hover{background:var(--green-dark)}
.footer__cols{display:flex;gap:60px;flex-wrap:wrap}
.footer__col{display:flex;flex-direction:column;gap:10px}
.footer__col>span{font-size:12px;color:rgba(255,255,255,0.7);margin-bottom:6px}
.footer__col a{text-decoration:none;color:#fff;font-size:16px;letter-spacing:-0.32px}
.footer__col a:hover{opacity:.78}
.footer__base{position:relative;z-index:2;display:flex;flex-direction:column;gap:24px}
.footer__social{display:flex;gap:10px}
.footer__social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.18);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:background-color .2s ease,transform .2s ease}
.footer__social a:hover{background:rgba(255,255,255,0.32);transform:translateY(-2px)}
.footer__desc{font-size:12px;line-height:1.4;letter-spacing:-0.24px;color:rgba(255,255,255,0.7);max-width:489px}
.footer__rule{height:1px;background:rgba(255,255,255,0.5)}
.footer__credits{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.footer__credits span{font-size:15px;letter-spacing:-0.32px;color:#fff}

/* ================== FLOATING WHATSAPP =================== */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:60;width:60px;height:60px;border-radius:50%;background:var(--wa);display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(37,211,102,0.45);text-decoration:none;transition:transform .25s var(--ease)}
.wa-float:hover{transform:scale(1.08)}
.wa-float__pulse{position:absolute;inset:0;border-radius:50%;background:var(--wa);animation:waPulse 2.2s ease-out infinite}
.wa-float svg{position:relative}
@keyframes waPulse{0%{transform:scale(1);opacity:.5}70%{transform:scale(1.85);opacity:0}100%{opacity:0}}

/* ====================== MOTION ========================== */
[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.12s}
[data-reveal-delay="2"]{transition-delay:.24s}

/* Sequência de steps: a linha desenha e o número surge em ordem */
.pstep__line,.step__line{transform:scaleY(0);transform-origin:top center;transition:transform .7s var(--ease)}
.pstep.is-in .pstep__line,.step.is-in .step__line{transform:scaleY(1)}
.process__steps .pstep:nth-of-type(2) .pstep__line{transition-delay:.22s}
.pstep__num,.step__num{transition:transform .45s var(--ease),opacity .4s ease}
.pstep:not(.is-in) .pstep__num,.step:not(.is-in) .step__num{transform:scale(.55);opacity:.4}

[data-hero-anim]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.hero.ready [data-hero-anim]{opacity:1;transform:none}
.hero.ready [data-hero-anim]:nth-child(1){transition-delay:.05s}
.hero.ready .hero__pill{transition-delay:.15s}
.hero.ready .hero__title{transition-delay:.25s}
.hero.ready .hero__lead{transition-delay:.4s}
.hero.ready .hero__actions{transition-delay:.55s}
.hero.ready .gcard{transition-delay:.5s}
.hero.ready .search{transition-delay:.65s}

/* ============== PÁGINAS INTERNAS: HERO + LISTAGEM ========= */
.page-hero{background:var(--gray);padding:clamp(40px,5vw,72px) var(--edge) clamp(36px,4vw,56px)}
.page-hero__inner{max-width:var(--maxw);margin-inline:auto;display:flex;flex-direction:column;gap:16px}
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}
.crumbs a{color:var(--text-muted);text-decoration:none}
.crumbs a:hover{color:var(--green)}
.crumbs b{color:var(--ink);font-weight:700}
.crumbs span{opacity:.5}
.page-hero__eyebrow{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.13em;color:var(--green)}
.page-hero__title{font-size:clamp(38px,5vw,68px);line-height:1.02;letter-spacing:-0.02em;color:var(--orange);margin:0}
.page-hero__lead{max-width:620px;font-size:16px;line-height:1.55;color:var(--text-muted)}

.filters{
  display:flex;gap:16px;flex-wrap:wrap;background:#fff;border:1px solid rgba(0,0,0,.08);
  border-radius:12px;padding:20px;box-shadow:0 8px 30px rgba(0,0,0,.05);margin-bottom:28px;
}
.filters__field{flex:1 1 200px;display:flex;flex-direction:column;gap:7px}
.filters__field>span{font-size:12px;color:var(--text-muted)}
.filters .select{background:#fff;border:1px solid rgba(0,0,0,.12)}
.filters .select select{padding:13px 40px 13px 16px}
.listing__bar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:26px}
.listing__count{font-size:15px;color:var(--ink);font-weight:700}
.listing__clear{background:none;border:none;color:var(--green);font-size:14px;cursor:pointer;font-family:inherit;text-decoration:underline}
.vend-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:40px}
.vend-stat{background:var(--gray);border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:4px}
.vend-stat b{font-size:clamp(28px,3vw,40px);color:var(--green);letter-spacing:-1px;line-height:1}
.vend-stat span{font-size:14px;color:var(--text-muted)}
@media (max-width:680px){.vend-stats{grid-template-columns:1fr 1fr}}

.values{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.value-card{background:var(--gray);border-radius:18px;padding:34px 30px;display:flex;flex-direction:column;gap:12px;transition:transform .3s var(--ease),box-shadow .3s ease}
.value-card:hover{transform:translateY(-5px);box-shadow:var(--sh-md)}
.value-card__num{width:46px;height:46px;border-radius:100px;background:var(--orange);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;margin-bottom:6px}
.value-card h3{font-size:21px;line-height:1.2;color:var(--ink);font-weight:700;margin:0}
.value-card p{font-size:15px;line-height:1.55;color:var(--text-muted);margin:0}
@media (max-width:860px){.values{grid-template-columns:1fr}}

/* contato (página) */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.contact-channels{display:flex;flex-direction:column;gap:18px}
.contact-channel{display:flex;align-items:center;gap:14px}
.contact-channel .contato__icon{background:var(--gray)}
.contact-channel b{display:block;font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px}
.contact-channel a,.contact-channel span{font-size:17px;color:var(--ink);text-decoration:none}
.contact-channel a:hover{color:var(--green)}
.contact-map{margin-top:8px;border-radius:16px;overflow:hidden;height:230px;border:1px solid rgba(0,0,0,.1)}
.contact-map iframe{width:100%;height:100%;border:0;display:block}
.contact-form{background:var(--gray);border-radius:20px;padding:32px;display:flex;flex-direction:column;gap:18px}
.contact-form__row{display:flex;gap:16px;flex-wrap:wrap}
.contact-field{flex:1 1 200px;display:flex;flex-direction:column;gap:7px}
.contact-field>span{font-size:13px;color:var(--ink);font-weight:700}
.contact-field input,.contact-field textarea{
  border:1px solid rgba(0,0,0,.14);border-radius:8px;background:#fff;padding:13px 14px;
  font-family:inherit;font-size:15px;color:var(--ink);outline:none;transition:border-color .2s ease;resize:vertical;
}
.contact-field input:focus,.contact-field textarea:focus{border-color:var(--green)}
.contact-form .select{background:#fff;border:1px solid rgba(0,0,0,.14)}
.contact-form .select select{padding:13px 40px 13px 14px}
.contact-form__submit{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--green);color:#fff;font-size:16px;font-weight:600;padding:15px 24px;border:none;border-radius:var(--r-xs);cursor:pointer;font-family:inherit;transition:background-color .2s ease,transform .2s var(--ease)}
.contact-form__submit:hover{background:var(--green-dark);transform:translateY(-1px)}
.contact-form__note{font-size:13px;color:var(--text-muted);text-align:center;margin:0}
.contact-form__status{font-size:14px;margin:0;padding:11px 15px;border-radius:var(--r-xs);text-align:center}
.contact-form__status.is-error{background:rgba(176,58,46,.09);color:#9c3327}
.contact-form__status.is-ok{background:rgba(30,113,69,.1);color:var(--green-dark);font-weight:600}
.contact-field input[aria-invalid="true"],.contact-field textarea[aria-invalid="true"]{border-color:#b03a2e;box-shadow:0 0 0 3px rgba(176,58,46,.12)}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr;gap:32px}}

/* ============== BLOG ===================================== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px 28px}
.post-card{display:flex;flex-direction:column;gap:12px;text-decoration:none;color:inherit;transition:transform .3s var(--ease)}
.post-card:hover{transform:translateY(-5px)}
.post-card__img{border-radius:14px;overflow:hidden;aspect-ratio:16/10;background:var(--gray)}
.post-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.post-card:hover .post-card__img img{transform:scale(1.05)}
.post-card__tag{align-self:flex-start;background:var(--gray);color:var(--green);font-size:12px;font-weight:700;padding:6px 12px;border-radius:90px;text-transform:uppercase;letter-spacing:.3px}
.post-card__title{font-size:21px;line-height:1.25;color:var(--ink);margin:2px 0 0;font-weight:700}
.post-card__excerpt{font-size:15px;line-height:1.55;color:var(--text-muted);margin:0}
.post-card__date{font-size:13px;color:var(--text-muted)}
@media (max-width:980px){.blog-grid{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.blog-grid{grid-template-columns:1fr}}

.post-article{max-width:780px;display:flex;flex-direction:column;gap:18px;padding-top:8px;padding-bottom:clamp(40px,5vw,72px)}
.post-article__title{font-size:clamp(32px,4.2vw,56px);line-height:1.06;letter-spacing:-0.02em;color:var(--ink);margin:0}
.post-article__meta{font-size:14px;color:var(--text-muted)}
.post-article__cover{border-radius:16px;overflow:hidden;aspect-ratio:16/9;background:var(--gray);margin:8px 0}
.post-article__cover img{width:100%;height:100%;object-fit:cover}
.post-article__body{display:flex;flex-direction:column;gap:18px}
.post-article__body p{font-size:17px;line-height:1.75;color:#222;margin:0}
.post-article__cta{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;background:var(--gray);border-radius:18px;padding:28px 30px;margin-top:12px}
.post-article__cta b{display:block;font-size:18px;color:var(--ink)}
.post-article__cta span{font-size:14px;color:var(--text-muted)}

/* ============== BAIRROS ================================= */
.bairros-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.bairro-card{display:flex;flex-direction:column;background:var(--gray);border-radius:18px;overflow:hidden;text-decoration:none;color:inherit;transition:transform .3s var(--ease),box-shadow .3s ease}
.bairro-card:hover{transform:translateY(-5px);box-shadow:var(--sh-md)}
.bairro-card__img{aspect-ratio:16/9;overflow:hidden}
.bairro-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.bairro-card:hover .bairro-card__img img{transform:scale(1.05)}
.bairro-card__body{padding:26px 28px;display:flex;flex-direction:column;gap:8px}
.bairro-card__body h2{font-size:24px;color:var(--ink);margin:0}
.bairro-card__body p{font-size:15px;line-height:1.55;color:var(--text-muted);margin:0}
.bairro-card__link{margin-top:6px;font-size:15px;font-weight:700;color:var(--green)}
.bairros-note{margin-top:40px;background:var(--gray);border-radius:16px;padding:26px 30px}
.bairros-note p{font-size:16px;color:var(--text-muted);margin:0}
.bairros-note a{color:var(--green);font-weight:700;text-decoration:none}
@media (max-width:768px){.bairros-grid{grid-template-columns:1fr}}
.listing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px 28px}
@media (max-width:1040px){.listing-grid{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.listing-grid{grid-template-columns:1fr}}

/* ============== PÁGINA DE DETALHE DO IMÓVEL =============== */
.detail__wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--edge);width:100%}
.detail-page .crumbs{padding-top:24px}
.detail{padding:18px 0 clamp(48px,5vw,84px)}
.detail__loading{padding:80px var(--edge);font-size:16px;color:var(--text-muted)}
.detail__notfound{max-width:var(--maxw);margin-inline:auto;padding:80px var(--edge);display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.detail__notfound h1{font-size:clamp(34px,4vw,52px);color:var(--orange);margin:0}
.detail__notfound p{font-size:16px;color:var(--text-muted);max-width:30em}

.dgal{margin-bottom:36px}
.dgal__main{border-radius:16px;overflow:hidden;aspect-ratio:16/9;background:var(--gray);box-shadow:0 12px 40px rgba(0,0,0,.1)}
.dgal__main img{width:100%;height:100%;object-fit:cover}
.dgal__thumbs{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap}
.dgal__thumb{width:104px;height:72px;border-radius:10px;overflow:hidden;border:2px solid transparent;padding:0;cursor:pointer;background:none;transition:border-color .2s ease,transform .2s ease}
.dgal__thumb img{width:100%;height:100%;object-fit:cover}
.dgal__thumb:hover{transform:translateY(-2px)}
.dgal__thumb.is-active{border-color:var(--green)}

.detail__grid{display:grid;grid-template-columns:1.7fr 1fr;gap:48px;align-items:start}
.detail__main{display:flex;flex-direction:column;gap:30px}
.detail__titlerow{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}
.detail__titlerow .badge{position:static;box-shadow:none}
.detail__loc{display:flex;align-items:center;gap:7px;margin-bottom:10px}
.detail__loc span{font-weight:700;font-size:12px;color:var(--ink);text-transform:uppercase;letter-spacing:.2px}
.detail__title{font-size:clamp(30px,3.6vw,50px);line-height:1.05;letter-spacing:-0.02em;color:var(--ink);margin:0}
.detail__specs{display:flex;flex-wrap:wrap;gap:14px 26px;padding:22px 0;border-top:1px solid rgba(0,0,0,.1);border-bottom:1px solid rgba(0,0,0,.1)}
.dspec{display:flex;align-items:center;gap:9px}
.dspec span{font-size:15px;color:var(--ink);font-weight:600}
.detail__desc h2{font-size:22px;color:var(--ink);margin:0 0 12px;font-weight:700}
.detail__desc p{font-size:16px;line-height:1.7;color:var(--text-muted);white-space:pre-line;max-width:60ch}
.detail__back{display:inline-flex;align-items:center;gap:8px;color:var(--green);text-decoration:none;font-size:15px;font-weight:700;align-self:flex-start}
.detail__back:hover{opacity:.8}

.detail__aside{position:sticky;top:96px}
.detail__card{background:var(--gray);border-radius:20px;padding:30px;display:flex;flex-direction:column;gap:14px}
.detail__price-label{font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}
.detail__price{font-size:34px;font-weight:700;letter-spacing:-1px;color:var(--ink);line-height:1}
.detail__quick{display:flex;flex-direction:column;gap:11px;padding:18px 0;border-top:1px solid rgba(0,0,0,.1);margin-top:4px}
.detail__cta{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--green);color:#fff;font-size:16px;padding:16px 24px;border-radius:10px;text-decoration:none}
.detail__tel{font-size:14px;color:var(--text-muted);text-decoration:none;text-align:center}
.detail__tel:hover{color:var(--green)}
.detail__agent{display:flex;align-items:center;gap:12px;margin-top:8px;padding-top:18px;border-top:1px solid rgba(0,0,0,.1)}
.detail__agent img{width:46px;height:46px;border-radius:10px;object-fit:cover;flex:0 0 auto}
.detail__agent b{display:block;font-size:14px;color:var(--ink)}
.detail__agent span{font-size:13px;color:var(--text-muted)}

@media (max-width:900px){
  .detail__grid{grid-template-columns:1fr;gap:32px}
  .detail__aside{position:static}
}

/* ====================== RESPONSIVE ====================== */
@media (max-width:1040px){
  .grid-2{grid-template-columns:1fr!important;gap:40px 24px!important}
  .faq__grid{grid-template-columns:1fr!important}
  .step{grid-template-columns:1fr!important;gap:14px!important}
  .step__rail{display:none!important}
  .step__card--right{align-items:flex-start;text-align:left}
}
@media (max-width:860px){
  .process__grid{grid-template-columns:1fr!important}
  .contato__bar{grid-template-columns:1fr!important}
  .contato__item--div{border-left:none!important;padding-left:0!important}
  .nav__links{display:none!important}
  .footer__top{flex-direction:column!important}
  .hero__top{flex-direction:column;align-items:flex-start}
  .gcard{width:100%;max-width:271px}
}
@media (max-width:560px){
  .hero__content{padding:24px;gap:28px}
  .nav{padding:22px 24px}
  .nav__drop{right:24px}
  .hero__frame{min-height:680px}
  .testi__small-grid{grid-template-columns:1fr}
  .process__panel{padding:36px 26px}
  .about__inner{gap:40px}
}

/* ============== REDUCED MOTION ========================== */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  html{scroll-behavior:auto}
  [data-reveal],[data-hero-anim]{opacity:1!important;transform:none!important}
  .pstep__line,.step__line,.pstep__num,.step__num{transform:none!important;opacity:1!important}
  .hero__media{inset:0}
}
