:root{
  --primary:#F8BBD0;
  --primary-soft:#FCE4EC;

  --ink:#0b1220;
  --muted:#667085;

  --border:rgba(17,24,39,.12);

  --shadow-sm:0 10px 26px rgba(17,24,39,.08);
  --shadow:0 26px 70px rgba(17,24,39,.14);

  --radius:18px;
  --radius-lg:26px;

  --container:1140px;
}

/* Reset */
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; min-height:100%; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

/* Fundo premium contínuo (sem corte) */
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--ink);
  background:
    radial-gradient(1400px 700px at 15% -10%, rgba(248,187,208,.35), transparent 60%),
    radial-gradient(1000px 600px at 85% 5%, rgba(252,228,236,.65), transparent 55%),
    #ffffff;
  background-repeat:no-repeat;
}

/* Container */
.container{
  width:min(var(--container), calc(100% - 40px));
  margin:0 auto;
}

/* Grids utilitárias */
.grid{ display:grid; gap:16px; }
.cols-2{ grid-template-columns:repeat(2,1fr); }
.cols-3{ grid-template-columns:repeat(3,1fr); }

@media(max-width:900px){
  .cols-3{ grid-template-columns:repeat(2,1fr); }
}
@media(max-width:680px){
  .cols-2,.cols-3{ grid-template-columns:1fr; }
}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(12px);
  background:rgba(255,255,255,.78);
  border-bottom:1px solid var(--border);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:14px;
}
.brand{ display:flex; flex-direction:column; gap:2px; }
.brand strong{ font-size:16px; font-weight:900; }
.brand span{ font-size:12px; color:var(--muted); }

.navlinks{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.navlinks a{
  padding:10px 14px;
  border-radius:999px;
  font-size:13px;
  font-weight:750;
}
.navlinks a:hover{ background:rgba(252,228,236,.75); }

/* Botões */
.btn{
  padding:12px 18px;
  border-radius:999px;
  font-weight:850;
  border:1px solid rgba(248,187,208,.65);
  background:linear-gradient(180deg,var(--primary),#fad2de);
  box-shadow:0 14px 30px rgba(248,187,208,.22);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.btn:hover{ transform:translateY(-1px); }
.btn-ghost{
  background:rgba(255,255,255,.92);
  border:1px solid var(--border);
  box-shadow:none;
}

/* Seções */
section,.hero,main,.page,.content{ background:transparent; }
.hero{
  margin-top:18px;
  padding:28px;
  border-radius:32px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}

h1{
  font-size:42px;
  line-height:1.05;
  letter-spacing:-.8px;
  margin:0;
}
h2{
  font-size:20px;
  margin:0;
  letter-spacing:-.4px;
}
p{ color:var(--muted); line-height:1.7; }
@media(max-width:680px){ h1{ font-size:32px; } }

/* Cards */
.card{
  background:rgba(255,255,255,.94);
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.card:hover{ box-shadow:var(--shadow); }

/* Util sticky (sidebar) */
.sticky{ position:sticky; top:92px; }

/* Cards de imóvel */
.pcard{ display:flex; flex-direction:column; overflow:hidden; }
.pimg{ position:relative; height:220px; background:#f6f6f6; }
.pimg img{ width:100%; height:100%; object-fit:cover; }
.pbody{ padding:16px; }
.ptitle{ font-size:16px; font-weight:850; }
.ploc{ margin-top:6px; font-size:13px; color:var(--muted); }
.pprice{ margin-top:12px; font-size:20px; font-weight:950; }

/* ===== Características (luxo minimalista) ===== */
.feat-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:10px;
}

/* Ícones pequenos nos meta do card (home/listagem) */
.pmeta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
  color:var(--muted);
  font-size:12px;
}
.pmeta .feat{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.75);
}
.pmeta .feat svg{
  width:16px;
  height:16px;
  flex-shrink:0;
  display:block;
}
@media(max-width:720px){
  .feat-grid{ grid-template-columns:1fr; }
}

.feat-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:9px 10px;
  border-radius:14px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.92);
}
.feat-item .k{
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--muted);
  margin-bottom:4px;
}
.feat-item .v{
  font-size:14px;
  font-weight:900;
  line-height:1.2;
}

/* Ícones: pequenos e controlados (somente nos ícones do site) */
.icon-box{
  width:30px;
  height:30px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  border-radius:10px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.85);
}
.icon-box svg{
  width:16px !important;
  height:16px !important;
  max-width:16px !important;
  max-height:16px !important;
  display:block;
  stroke-width:1.8;
}

/* ===== Página do imóvel (premium) ===== */
.imovel-grid{ display:grid; grid-template-columns: 1.2fr .8fr; gap:14px; align-items:start; }
@media(max-width:980px){ .imovel-grid{ grid-template-columns:1fr; } }

.imovel-actions{ display:grid; gap:10px; margin-top:12px; }

/* Form “Tenho interesse” mais premium */
.lead-form{ gap:10px; }
.lead-form .row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:720px){ .lead-form .row{ grid-template-columns:1fr; } }

.lead-form .btn{ height:48px; }
.lead-form .btn-ghost{ height:48px; }

/* Evita que inputs fiquem “curtos” em browsers teimosos */
.lead-form input,
.lead-form textarea{ box-sizing:border-box; }

/* Footer */
.footer{
  margin-top:32px;
  padding:22px 0;
  border-top:1px solid var(--border);
  background:rgba(255,255,255,.60);
}
.footer .muted{ font-size:12px; color:var(--muted); }

/* ===== Footer (premium) ===== */
.footer .footer-grid{
  display:grid;
  grid-template-columns: 1.3fr 1fr 1fr;
  gap:18px;
  align-items:start;
}
.footer .footer-col h4{
  margin:0 0 10px 0;
  font-size:13px;
  letter-spacing:.2px;
}
.footer .footer-links{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.footer .footer-links a{
  color:inherit;
  text-decoration:none;
  opacity:.9;
}
.footer .footer-links a:hover{ opacity:1; text-decoration:underline; }
.footer .footer-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:14px;
  background: rgba(255,255,255,.85);
}
.footer .footer-bottom{
  margin-top:18px;
  padding-top:14px;
  border-top:1px solid var(--border);
  display:flex;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  font-size:12px;
  color:var(--muted);
}
@media (max-width: 820px){
  .footer .footer-grid{ grid-template-columns: 1fr; }
}


/* ===== HOTFIX PREMIUM (layout + formulários) ===== */

/* garante cards de características com layout em linha */
.feat-item{
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:12px !important;
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 26px rgba(17,24,39,.06);
}

/* evita que algum reset force itens para coluna */
.feat-item > .icon-box{ display:flex !important; }

/* controles de formulário (site público e admin) */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="password"],
input[type="search"],
select,
textarea{
  width:100% !important;
  display:block !important;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(17,24,39,.14);
  background: rgba(255,255,255,.92);
  color: var(--ink);
  outline:none;
  box-shadow: 0 6px 18px rgba(17,24,39,.05);
  font-size:14px;
}

textarea{ min-height:110px; resize:vertical; }

label{
  display:block !important;
  font-size:13px;
  font-weight:800;
  margin:10px 0 6px;
  color: var(--ink);
}

/* “cinto de segurança” — evita qualquer CSS externo quebrar formulário */
label{ display:block !important; }
input, textarea, select{ box-sizing:border-box; }

/* Características ainda mais compactas (luxo minimalista) */
.feat-item{ box-shadow:none; }
.feat-item .k{ font-size:10px; }
.feat-item .v{ font-size:14px; }

form .row{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:14px;
}
@media(max-width:720px){
  form .row{ grid-template-columns:1fr; }
}

button, .btn{
  border:none;
}



/* Formulário "Tenho interesse" (premium) */
.lead-form{
  display:grid;
  gap:12px;
  margin-top:12px;
}
.lead-form label{
  font-size:13px;
  font-weight:800;
  color:var(--ink);
}
.lead-form input,
.lead-form textarea,
.lead-form select{
  width:100%;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(17,24,39,.14);
  background:rgba(255,255,255,.92);
  outline:none;
  font-size:14px;
}
.lead-form textarea{ min-height:120px; resize:vertical; }
.lead-form input:focus,
.lead-form textarea:focus,
.lead-form select:focus{
  border-color: rgba(248,187,208,.9);
  box-shadow:0 0 0 4px rgba(248,187,208,.22);
}
.lead-form .btn{ width:100%; }
.lead-form .btn-ghost{ width:100%; }


/* ===== FORMULÁRIOS (PREMIUM) ===== */
label{
  display:block;
  font-size:12px;
  font-weight:800;
  color:var(--muted);
  margin:12px 0 6px;
}

input, select, textarea{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.92);
  color:var(--ink);
  font-size:14px;
  outline:none;
}

textarea{ min-height:110px; resize:vertical; }

input:focus, select:focus, textarea:focus{
  border-color: rgba(248,187,208,.95);
  box-shadow: 0 0 0 4px rgba(248,187,208,.22);
}

/* Botões em formulários */
.lead-form{
  display:flex;
  flex-direction:column;
}
.lead-form .row{ margin-top:0; }
.lead-form button.btn, .lead-form a.btn{
  width:100%;
}

/* ===== CARACTERÍSTICAS (premium compact) ===== */
.feat-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

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

.feat-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:16px;
  background:rgba(255,255,255,.78);
}

.feat-item .k{
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:900;
  line-height:1.2;
}

.feat-item .v{
  margin-top:2px;
  font-size:14px;
  font-weight:600;
  line-height:1.2;
}

.icon-box{
  width:34px;
  height:34px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  border:1px solid rgba(248,187,208,.35);
  background:rgba(252,228,236,.55);
}

.icon-box svg{
  width:18px !important;
  height:18px !important;
  max-width:18px !important;
  max-height:18px !important;
  display:block;
}

/* Links secundários (premium, sem virar “botão gigante”) */
.link-soft{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:900;
  font-size:14px;
  color:var(--ink);
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.72);
}

.link-soft:hover{
  background:rgba(252,228,236,.65);
}

/* ===== Proteção Leaflet (círculo) ===== */
.leaflet-container svg{
  width:auto !important;
  height:auto !important;
  max-width:none !important;
  max-height:none !important;
}

/* SVG padrão do site (Leaflet sobrescreve via .leaflet-container svg) */
svg{vertical-align:-0.125em}


/* ===== BADGES (CÓDIGO / FINALIDADE) ===== */
.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  line-height:1;
  color:rgba(11,18,32,.92);
  background:rgba(255,255,255,.92);
  border:1px solid rgba(17,24,39,.10);
  box-shadow:0 10px 24px rgba(17,24,39,.10);
}

.pimg{
  position:relative;
  overflow:hidden;
  border-top-left-radius:var(--radius-lg);
  border-top-right-radius:var(--radius-lg);
}

.pchip{
  position:absolute;
  left:12px;
  top:12px;
}

.pchip-right{
  position:absolute;
  right:12px;
  top:12px;
  background:rgba(248,187,208,.92);
  border:1px solid rgba(248,187,208,.55);
}

.pimg img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.pcard{
  overflow:hidden;
}

.pbody{
  padding:16px 16px 18px 16px;
}

.pmeta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}

.feat{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.85);
  font-size:13px;
  font-weight:700;
  color:rgba(11,18,32,.82);
}

.pmeta .feat svg{
  width:16px;
  height:16px;
  flex:0 0 16px;
  display:block;
}

/* Leaflet: não limitar SVG do mapa */
.leaflet-container svg{
  width:auto !important;
  height:auto !important;
  max-width:none !important;
  max-height:none !important;
}


/* ===== FIX BOTÃO ENVIAR (LEAD) ===== */
.lead-form .btn[type="submit"]{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  height:52px;
  border-radius:999px;
  margin-top:10px;
}
.lead-form .btn.btn-ghost{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  height:52px;
  border-radius:999px;
}



/* === PREMIUM: Ajuste final de peso nas Características (não afeta Leaflet) === */
.feat-item .k{font-weight:500;color:#6b7280;}
.feat-item .v{font-weight:600;color:#111827;}
