/*
Theme Name: JB Imóveis — Premium (Exato)
Theme URI: https://imoveisjoaobatista.com.br
Author: Imóveis JB – São Francisco do Sul
Description: Tema premium dark + dourado/âmbar, layout arredondado e grid estilo marketplace, com WhatsApp e cadastro fácil de imóveis.
Version: 1.0.0
Text Domain: jb-imoveis-exato
*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  --bg0:#07080b;
  --bg1:#0b0f16;
  --surface: rgba(16,18,22,.70);
  --surface2: rgba(22,24,30,.70);
  --text:#f6f7fb;
  --muted: rgba(246,247,251,.72);
  --muted2: rgba(246,247,251,.55);

  --gold:#f5c24b;   /* âmbar */
  --gold2:#d59a23;
  --line: rgba(245,194,75,.25);

  --radius: 22px;
  --radius2: 28px;
  --shadow: 0 24px 70px rgba(0,0,0,.55);
  --shadow2: 0 10px 40px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  line-height:1.55;
  background:
    radial-gradient(1000px 560px at 20% 10%, rgba(245,194,75,.13), transparent 60%),
    radial-gradient(900px 520px at 92% 24%, rgba(245,194,75,.10), transparent 60%),
    radial-gradient(900px 520px at 12% 86%, rgba(104,82,18,.16), transparent 62%),
    linear-gradient(180deg, var(--bg1), var(--bg0) 60%, #05060a);
  min-height:100vh;
}

/* Layout */
.container{max-width:1200px;margin:0 auto;padding:0 22px}
.section{padding:56px 0}
.section-tight{padding:38px 0}
.grid{display:grid;gap:22px}
@media (min-width: 980px){
  .hero-grid{grid-template-columns: 1.25fr .85fr; align-items:stretch;}
}

/* Topbar */
.topbar{
  position:sticky; top:0; z-index:60;
  background: rgba(5,6,10,.55);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.topbar-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}
.brand{
  display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--text);
}
.brand-badge{
  width:38px; height:38px; border-radius:14px;
  background: radial-gradient(circle at 30% 25%, rgba(245,194,75,.95), rgba(213,154,35,.35) 45%, rgba(63,60,75,.35) 65%, rgba(16,18,22,.9) 100%);
  box-shadow: 0 10px 30px rgba(0,0,0,.45), inset 0 0 0 1px rgba(255,255,255,.06);
}
.brand-title{font-weight:700;font-size:14px;line-height:1.1}
.brand-sub{font-size:12px;color:var(--muted2);margin-top:3px}

.nav{display:none; gap:18px; align-items:center}
.nav a{color:var(--muted); text-decoration:none; font-weight:600; font-size:13px; padding:8px 10px; border-radius:12px}
.nav a:hover{background: rgba(255,255,255,.06); color:var(--text)}
@media (min-width: 980px){.nav{display:flex}}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 16px;
  border-radius:999px;
  text-decoration:none;
  font-weight:700;
  letter-spacing:.2px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  color:var(--text);
  box-shadow: var(--shadow2);
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{transform: translateY(-1px); background: rgba(255,255,255,.09); border-color: rgba(255,255,255,.16)}
.btn-primary{
  background: linear-gradient(90deg, var(--gold2), var(--gold));
  color:#0a0b0e;
  border-color: rgba(245,194,75,.35);
}
.btn-primary:hover{background: linear-gradient(90deg, var(--gold), #ffd27a)}
.btn-ghost{background: rgba(255,255,255,.05)}
.btn-sm{padding:10px 14px; font-size:13px}

/* Hero */
.hero-wrap{
  border-radius: var(--radius2);
  background: linear-gradient(180deg, rgba(16,18,22,.72), rgba(16,18,22,.55));
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.hero-inner{padding:36px 26px}
@media (min-width: 980px){.hero-inner{padding:46px 42px}}
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 12px; border-radius:999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  color: var(--muted);
  font-weight:700; font-size:12px;
}
.h1{
  margin:18px 0 12px;
  font-size: clamp(34px, 4.2vw, 56px);
  line-height:1.05;
  letter-spacing:-.02em;
}
.lead{max-width:56ch; color: var(--muted); margin:0 0 18px}
.cta-row{display:flex; gap:12px; flex-wrap:wrap; margin-top:14px}
.smallline{margin-top:14px; color: var(--muted2); font-size:13px}
.chips{display:flex; flex-wrap:wrap; gap:10px; margin-top:18px}
.chip{
  padding:8px 12px;
  border-radius:999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  font-weight:600;
  font-size:12px;
}

/* Proof card right */
.proof{
  border-radius: var(--radius2);
  background: rgba(0,0,0,.40);
  border: 3px solid rgba(245,194,75,.70);
  box-shadow: var(--shadow);
  display:flex; align-items:center; justify-content:center;
  min-height: 180px;
  padding:28px;
}
.proof-inner{max-width:420px; text-align:center}
.proof-icon{
  width:52px; height:52px; margin:0 auto 14px;
  border-radius:16px;
  display:grid; place-items:center;
  background: rgba(245,194,75,.12);
  border: 1px solid rgba(245,194,75,.30);
}
.proof-text{color:var(--text); font-weight:600}

/* Feature cards */
.feature-grid{grid-template-columns:1fr; gap:18px}
.proof-title{
  margin: 10px 0 10px;
  font-weight: 800;
  font-size: 16px;
  letter-spacing: .2px;
  color: var(--text);
}
.proof-list{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}
.proof-list li{
  display: flex;
  gap: 10px;
  color: rgba(239,242,246,.88);
  font-size: 14px;
  line-height: 1.4;
}
.proof-list li:before{
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 99px;
  margin-top: 6px;
  background: linear-gradient(135deg, rgba(245,158,11,.95), rgba(212,175,55,.75));
  box-shadow: 0 0 0 6px rgba(245,158,11,.10);
}

@media (min-width: 980px){.feature-grid{grid-template-columns: repeat(3, 1fr)}}
.card{
  border-radius: var(--radius2);
  background: rgba(16,18,22,.70);
  border: 1px solid rgba(245,194,75,.22);
  box-shadow: var(--shadow2);
  padding:22px 22px 24px;
}
.card-icon{
  width:40px;height:40px;border-radius:14px;
  display:grid;place-items:center;
  background: rgba(245,194,75,.10);
  border: 1px solid rgba(245,194,75,.25);
  color: var(--gold);
  margin-bottom:14px;
}
.card h3{margin:0 0 8px; font-size:16px}
.card p{margin:0; color:var(--muted); font-size:13px}

/* Listings (marketplace) */
.section-title{display:flex; align-items:flex-end; justify-content:space-between; gap:14px; margin:0 0 16px}
.section-title h2{margin:0; font-size:22px}
.section-title p{margin:0; color:var(--muted2); font-size:13px}
.list-grid{grid-template-columns:1fr; gap:18px}
@media (min-width: 720px){.list-grid{grid-template-columns: repeat(2, 1fr)}}
@media (min-width: 1100px){.list-grid{grid-template-columns: repeat(3, 1fr)}}
.list-card{
  border-radius: var(--radius2);
  overflow:hidden;
  background: rgba(16,18,22,.72);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: var(--shadow2);
  transition: transform .16s ease, border-color .16s ease;
}
.list-card:hover{transform: translateY(-2px); border-color: rgba(245,194,75,.25)}
.list-thumb{
  height: 170px;
  background: radial-gradient(circle at 30% 20%, rgba(245,194,75,.22), transparent 55%),
              linear-gradient(135deg, rgba(255,255,255,.06), rgba(0,0,0,.18));
}
.list-body{padding:16px 16px 18px}
.list-title{font-weight:800; margin:0 0 6px}
.list-meta{color:var(--muted2); font-size:13px; margin:0 0 10px}
.price{color:var(--gold); font-weight:900; margin:10px 0 0; font-size:16px}
.badges{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px}
.badge{
  font-size:12px; font-weight:700;
  padding:7px 10px; border-radius:999px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  color: var(--muted);
}
.actions{display:flex; gap:10px; margin-top:14px}
.actions .btn{flex:1; box-shadow:none}
.actions .btn-primary{flex:1}

/* Footer */
.footer{
  margin-top: 42px;
  padding: 28px 0;
  border-top: 1px solid rgba(245,194,75,.18);
  background: rgba(0,0,0,.28);
}
.footer p{margin:0; color: var(--muted2); font-size:13px}

/* Floating WhatsApp */
.wa-float{
  position:fixed; right:18px; bottom:18px; z-index:80;
  width:54px; height:54px;
  border-radius:18px;
  display:grid; place-items:center;
  background: radial-gradient(circle at 30% 25%, rgba(245,194,75,.95), rgba(213,154,35,.55) 50%, rgba(16,18,22,.95) 100%);
  box-shadow: 0 22px 60px rgba(0,0,0,.55), inset 0 0 0 1px rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.08);
  text-decoration:none;
}
.wa-float span{font-weight:900; color:#0a0b0e; font-size:13px; letter-spacing:.6px}

/* Forms (basic) */
input, select{
  width:100%;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 14px;
  padding: 12px 12px;
  color: var(--text);
  outline: none;
}
input::placeholder{color: rgba(246,247,251,.40)}
label{display:block; font-size:12px; color:var(--muted2); margin:10px 0 6px}

/* Helpers */
.m0{margin:0}
.mt10{margin-top:10px}
.mt14{margin-top:14px}
.mt18{margin-top:18px}


/* ====== PROVA SOCIAL / BOX VENDER IMÓVEL ====== */
.proof--sell{
border:1px solid #d4a437;
background:#0b0f17;
position:relative;
overflow:hidden;
box-shadow:0 20px 50px rgba(0,0,0,.45);
}
.proof--sell:before{
display:none;
}
.proof--sell .proof-inner{
  position: relative;
  z-index: 1;
  width: 100%;
}
.proof--sell .proof-icon{
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  border: 1px solid rgba(245,158,11,.35);
  background: rgba(2,6,23,.55);
  color: rgba(245,158,11,.95);
  margin: 0 auto 12px;
  box-shadow: 0 18px 50px rgba(0,0,0,.35);
}
.proof--sell h3{
  margin: 0 0 10px;
  font-size: 18px;
  letter-spacing: .2px;
}
.proof--sell p{
  margin: 0 0 14px;
  color: rgba(241,245,249,.80);
}
.proof--sell .proof-list{
  margin: 0 0 16px;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}
.proof--sell .proof-list li{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(148,163,184,.16);
  background: rgba(2,6,23,.42);
  color: rgba(241,245,249,.88);
}
.proof--sell .proof-list li:before{
  content:"✓";
  font-weight: 800;
  color: rgba(245,158,11,.95);
}
.btn--sell{
width:100%;
justify-content:center;
padding:14px 18px;
border-radius:16px;
background:linear-gradient(90deg,#d4a437,#ffd27a);
color:#000;
font-weight:600;
border:none;
box-shadow:0 20px 60px rgba(0,0,0,.35);
}

.btn--sell{
width:100%;
justify-content:center;
padding:14px 18px;
border-radius:16px;

background: linear-gradient(90deg, var(--gold), #ffd27a);

color:#000;
font-weight:600;
border:none;

box-shadow:0 20px 60px rgba(0,0,0,.35);
}

.btn--sell{
width:100%;
justify-content:center;
padding:14px 18px;
border-radius:16px;

background: linear-gradient(90deg,#d4a437,#e6b84a);

color:#000;
font-weight:600;
border:none;

box-shadow:0 20px 60px rgba(0,0,0,.35);
}