/* ═══════════════════════════════════════════════════════════
   JIREH SaaS — Portal Imobiliário Premium
   modules/imoveis/assets/portal.css
   Paleta: Cor primária dinâmica + Dourado + Branco puro
   Tipografia: Cormorant Garamond (display) + DM Sans (corpo)
═══════════════════════════════════════════════════════════ */

:root {
    --gold:    #c9a84c;
    --gold-2:  #e2c478;
    --gold-lt: rgba(201,168,76,.12);
    --white:   #ffffff;
    --whites:   transparent;
    --off-wh:  #f8f6f2;
    --gray:    #888;
    --gray-lt: #ccc;
    --border-d:rgba(0,0,0,.08);
    --r:       8px;
    --r-lg:    16px;
    --sh:      0 8px 40px rgba(0,0,0,.14);
    --sh-lg:   0 20px 80px rgba(0,0,0,.22);
    --dur:     .28s;
    --ease:    cubic-bezier(.4,0,.2,1);
}

/* ── Reset base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body { font-family: 'DM Sans', sans-serif; background: var(--white); color: var(--coal); overflow-x: hidden; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }
h1,h2,h3,h4 { font-family: 'Cormorant Garamond', serif; line-height: 1.1; }

/* ── Utilitários ── */
.container { max-width: 1280px; margin: 0 auto; padding: 0 clamp(20px,4vw,60px); }
.badge-gold { display:inline-flex; align-items:center; gap:6px; background:var(--gold-lt); color:var(--gold); border:1px solid rgba(201,168,76,.3); border-radius:30px; padding:4px 14px; font-size:.75rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; }

/* ── Botões ── */
.btn-gold { display:inline-flex; align-items:center; justify-content:center; gap:10px; background:var(--gold); color:var(--coal); border:none; border-radius:var(--r); padding:14px 32px; font-size:.9rem; font-weight:600; letter-spacing:.04em; transition:all var(--dur) var(--ease); cursor:pointer; }
.btn-gold:hover { background:var(--gold-2); transform:translateY(-2px); box-shadow:0 8px 24px rgba(201,168,76,.35); }
.btn-outline-gold { display:inline-flex; align-items:center; justify-content:center; gap:10px; background:transparent; color:var(--gold); border:1.5px solid var(--gold); border-radius:var(--r); padding:13px 32px; font-size:.9rem; font-weight:600; letter-spacing:.04em; transition:all var(--dur) var(--ease); cursor:pointer; }
.btn-outline-gold:hover { background:var(--gold); color:var(--coal); transform:translateY(-2px); }
.btn-primary-portal { display:inline-flex; align-items:center; justify-content:center; gap:10px; background:var(--coal); color:var(--white); border:none; border-radius:var(--r); padding:14px 32px; font-size:.9rem; font-weight:600; transition:all var(--dur) var(--ease); cursor:pointer; }
.btn-primary-portal:hover { background:var(--coal-3); transform:translateY(-2px); box-shadow:var(--sh); }

/* ════════════════════════════════════════════════════════════
   NAVBAR
════════════════════════════════════════════════════════════ */
.navbar {
    position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
    padding: 0 clamp(20px,4vw,60px);
    height: 72px;
    display: flex; align-items: center; justify-content: space-between;
    transition: all .4s var(--ease);
}
.navbar.scrolled { background: var(--coal); box-shadow: var(--sh); }
.navbar.scrolled .nav-link { color: rgba(255,255,255,.75); }
.navbar.scrolled .nav-link:hover { color: var(--gold); }
.nav-logo { display:flex; align-items:center; gap:14px; }
.nav-logo img { height: 52px; object-fit:contain; filter:none; }
.nav-logo-txt { font-family:'Cormorant Garamond',serif; font-size:1.5rem; font-weight:600; color:var(--white); letter-spacing:.02em; }
.nav-links { display:flex; align-items:center; gap:28px; }
.nav-link { color:rgba(255,255,255,.85); font-size:.88rem; font-weight:500; letter-spacing:.02em; transition:color var(--dur); position:relative; padding-bottom:2px; }
.nav-link::after { content:''; position:absolute; bottom:-2px; left:0; width:0; height:1.5px; background:var(--gold); transition:width var(--dur); }
.nav-link:hover::after { width:100%; }
.nav-link:hover { color:var(--gold); }
.nav-cta { display:flex; align-items:center; gap:12px; }
.nav-hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.nav-hamburger span { display:block; width:24px; height:2px; background:var(--white); transition:all var(--dur); }

/* Mobile menu */
.nav-mobile { display:none; position:fixed; inset:0; background:var(--coal); z-index:999; flex-direction:column; align-items:center; justify-content:center; gap:32px; }
.nav-mobile.open { display:flex; }
.nav-mobile .nav-link { font-size:1.8rem; font-family:'Cormorant Garamond',serif; color:var(--white); }
.nav-mobile-close { position:absolute; top:24px; right:24px; background:none; border:none; color:var(--white); font-size:1.5rem; cursor:pointer; }

/* ════════════════════════════════════════════════════════════
   HERO
════════════════════════════════════════════════════════════ */
.hero { position:relative; min-height:100vh; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.hero-video-wrap { position:absolute; inset:0; z-index:0; }
.hero-video-wrap video, .hero-video-wrap img.hero-bg { width:100%; height:100%; object-fit:cover; }
.hero-overlay {
    position:absolute; inset:0; z-index:1;
    background:linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.3) 50%, rgba(0,0,0,.72) 100%);
}
.hero-overlay::after {
    content:''; position:absolute; inset:0;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
    opacity:.4; pointer-events:none;
}
.hero-content { position:relative; z-index:2; text-align:center; padding:clamp(100px,12vw,160px) clamp(20px,4vw,60px) clamp(60px,8vw,100px); max-width:900px; margin:0 auto; }
.hero-eyebrow { display:inline-flex; align-items:center; gap:10px; color:var(--gold); font-size:.78rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; margin-bottom:24px; }
.hero-eyebrow::before, .hero-eyebrow::after { content:''; display:block; width:32px; height:1px; background:var(--gold); }
.hero-title { font-family:'Cormorant Garamond',serif; font-size:clamp(3rem,7vw,5.5rem); font-weight:300; color:var(--white); line-height:1.05; letter-spacing:-.02em; margin-bottom:20px; }
.hero-title em { font-style:italic; color:var(--gold); }
.hero-sub { font-size:clamp(.95rem,1.4vw,1.1rem); color:rgba(255,255,255,.75); font-weight:300; line-height:1.6; margin-bottom:48px; }

/* Busca hero */
.hero-search { background:var(--white); border-radius:var(--r-lg); padding:8px 8px 8px 24px; display:flex; align-items:center; gap:12px; max-width:760px; margin:0 auto 24px; box-shadow:var(--sh-lg); }
.hero-search-input { flex:1; border:none; outline:none; font-family:inherit; font-size:1rem; color:var(--coal); background:transparent; }
.hero-search-input::placeholder { color:var(--gray); }
.hero-search-divider { width:1px; height:28px; background:var(--border-d); flex-shrink:0; }
.hero-search-select { border:none; outline:none; background:transparent; font-family:inherit; font-size:.88rem; color:var(--coal); cursor:pointer; padding:0 4px; min-width:110px; }
.hero-search-btn { background:var(--gold); color:var(--coal); border:none; border-radius:10px; width:48px; height:48px; display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; transition:all var(--dur); cursor:pointer; }
.hero-search-btn:hover { background:var(--gold-2); transform:scale(1.05); }

.hero-tags { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; }
.hero-tag { color:rgba(255,255,255,.7); font-size:.8rem; cursor:pointer; display:flex; align-items:center; gap:6px; transition:all var(--dur); background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); border-radius:30px; padding:6px 14px; backdrop-filter:blur(8px); }
.hero-tag:hover { color:var(--gold); border-color:var(--gold); background:rgba(201,168,76,.1); }

.hero-scroll { position:absolute; bottom:32px; left:50%; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:8px; color:rgba(255,255,255,.5); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; animation:pulse 2s ease-in-out infinite; }
.hero-scroll-line { width:1px; height:48px; background:linear-gradient(to bottom,transparent,rgba(255,255,255,.4)); }
@keyframes pulse { 0%,100%{opacity:.5;transform:translateX(-50%) translateY(0)} 50%{opacity:1;transform:translateX(-50%) translateY(6px)} }

/* ════════════════════════════════════════════════════════════
   STATS BAR
════════════════════════════════════════════════════════════ */
.stats-bar { background:var(--coal); padding:40px clamp(20px,4vw,60px); }
.stats-grid { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.08); border-radius:var(--r-lg); overflow:hidden; }
.stat-item { background:var(--coal-2); padding:32px 24px; text-align:center; transition:background var(--dur); }
.stat-item:hover { background:var(--coal-3); }
.stat-num { font-family:'Cormorant Garamond',serif; font-size:clamp(2.2rem,4vw,3.2rem); font-weight:600; color:var(--white); line-height:1; margin-bottom:8px; display:block; }
.stat-label { font-size:.8rem; color:rgba(255,255,255,.55); letter-spacing:.06em; text-transform:uppercase; }

/* ════════════════════════════════════════════════════════════
   SEÇÕES COMUNS
════════════════════════════════════════════════════════════ */
.section { padding:clamp(20px,8vw,40px) 0; }
.section-dark { background:var(--coal); color:var(--white); }
.section-off { background:var(--off-wh); }
.section-header { margin-bottom:clamp(40px,5vw,64px); }
.section-eyebrow { display:inline-flex; align-items:center; gap:10px; color:var(--gold); font-size:.75rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; margin-bottom:16px; }
.section-eyebrow::before { content:''; display:block; width:28px; height:1px; background:var(--gold); }
.section-title { font-family:'Cormorant Garamond',serif; font-size:clamp(2rem,4vw,3rem); font-weight:400; line-height:1.15; letter-spacing:-.01em; }
.section-sub { font-size:1rem; color:var(--gray); margin-top:12px; line-height:1.6; max-width:560px; font-weight:300; }
.section-sub-light { color:rgba(255,255,255,.55); }

/* ════════════════════════════════════════════════════════════
   CARROSSEL DE IMÓVEIS
════════════════════════════════════════════════════════════ */
.carousel-wrap { position:relative; overflow:hidden; }
.carousel-track { display:flex; gap:24px; transition:transform .5s var(--ease); will-change:transform; }
.carousel-track .im-card { flex:0 0 calc(33.333% - 16px); min-width:0; }
.carousel-nav { display:flex; align-items:center; justify-content:flex-end; gap:10px; margin-bottom:24px; }
.carousel-btn { width:44px; height:44px; border-radius:50%; border:1.5px solid var(--border-d); background:var(--white); color:var(--coal); display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:.9rem; transition:all var(--dur); box-shadow:var(--sh); }
.carousel-btn:hover { background:var(--gold); border-color:var(--gold); color:var(--coal); transform:scale(1.08); }
.carousel-btn:disabled { opacity:.35; cursor:not-allowed; transform:none; }
.carousel-dots { display:flex; gap:8px; justify-content:center; margin-top:28px; }
.carousel-dot { width:8px; height:8px; border-radius:50%; background:var(--border-d); cursor:pointer; transition:all var(--dur); border:none; padding:0; }
.carousel-dot.active { background:var(--gold); width:24px; border-radius:4px; }

/* ════════════════════════════════════════════════════════════
   CARDS DE IMÓVEL
════════════════════════════════════════════════════════════ */
.imoveis-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(clamp(280px,28vw,380px),1fr)); gap:28px; }
.im-card { background:var(--white); border-radius:var(--r-lg); overflow:hidden; box-shadow:0 2px 16px rgba(0,0,0,.07); transition:all var(--dur) var(--ease); position:relative; cursor:pointer; }
.im-card:hover { transform:translateY(-6px); box-shadow:var(--sh); }
.im-card-img { position:relative; overflow:hidden; aspect-ratio:4/3; }
.im-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.im-card:hover .im-card-img img { transform:scale(1.06); }
.im-card-img-placeholder { width:100%; height:100%; background:linear-gradient(135deg,#f0ede8 0%,#e0dbd0 100%); display:flex; align-items:center; justify-content:center; color:#bbb; font-size:3rem; }
.im-badge { position:absolute; top:14px; left:14px; z-index:2; display:flex; gap:6px; flex-wrap:wrap; }
.im-badge-item { background:var(--gold); color:var(--coal); font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:4px 10px; border-radius:4px; }
.im-badge-item.novo { background:var(--coal); color:var(--white); }
.im-badge-item.exclusivo { background:var(--white); color:var(--coal); }
.im-fav { position:absolute; top:14px; right:14px; z-index:2; width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.9); border:none; display:flex; align-items:center; justify-content:center; color:var(--gray); font-size:.95rem; transition:all var(--dur); cursor:pointer; backdrop-filter:blur(8px); }
.im-fav:hover { background:var(--white); color:var(--gold); transform:scale(1.1); }
.im-card-body { padding:20px 22px 22px; }
.im-card-tipo { font-size:.72rem; color:var(--gray); letter-spacing:.08em; text-transform:uppercase; margin-bottom:6px; font-weight:500; }
.im-card-titulo { font-family:'Cormorant Garamond',serif; font-size:1.25rem; font-weight:600; color:var(--coal); line-height:1.3; margin-bottom:6px; }
.im-card-local { display:flex; align-items:center; gap:5px; font-size:.82rem; color:var(--gray); margin-bottom:14px; }
.im-card-local i { color:var(--gold); font-size:.78rem; }
.im-card-info { display:flex; flex-wrap:wrap; gap:14px; padding:14px 0; border-top:1px solid var(--border-d); border-bottom:1px solid var(--border-d); margin-bottom:14px; }
.im-card-info-item { display:flex; align-items:center; gap:5px; font-size:.8rem; color:var(--coal); font-weight:500; }
.im-card-info-item i { color:var(--gold); font-size:.75rem; }
.im-card-footer { display:flex; align-items:center; justify-content:space-between; }
.im-card-preco { font-family:'Cormorant Garamond',serif; font-size:1.4rem; font-weight:600; color:var(--coal); }
.im-card-preco small { font-size:.7rem; font-family:'DM Sans',sans-serif; color:var(--gray); font-weight:400; }
.im-card-btn { width:38px; height:38px; border-radius:50%; background:var(--gold); color:var(--coal); border:none; display:flex; align-items:center; justify-content:center; font-size:.9rem; transition:all var(--dur); flex-shrink:0; }
.im-card-btn:hover { background:var(--gold-2); transform:rotate(45deg) scale(1.1); }

/* ════════════════════════════════════════════════════════════
   CATEGORIAS
════════════════════════════════════════════════════════════ */
.categorias-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:20px; }
.cat-card { display:flex; flex-direction:column; align-items:center; gap:12px; padding:28px 16px; border-radius:var(--r-lg); background:var(--whites); cursor:pointer; transition:all var(--dur) var(--ease); text-align:center; }
.cat-card:hover { border-color:var(--gold); transform:translateY(-4px); box-shadow:0 8px 32px rgba(201,168,76,.15); }
.cat-ico { width:76px; height:76px; border-radius:50%; background:var(--off-wh); display:flex; align-items:center; justify-content:center; font-size:1.4rem; color:var(--coal); transition:all var(--dur); border:1.5px solid var(--border-d); }
.cat-card:hover .cat-ico { background:var(--gold-lt); border-color:var(--gold); color:var(--gold); }
.cat-label { font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--coal); line-height:1.3; }
.cat-count { font-size:.72rem; color:var(--gray); }

/* Dark version */
.tipo-card { background:var(--coal-2); border:1px solid rgba(255,255,255,.06); border-radius:var(--r-lg); padding:28px 16px; text-align:center; cursor:pointer; transition:all var(--dur) var(--ease); }
.tipo-card:hover { background:var(--coal-3); border-color:var(--gold); transform:translateY(-4px); }
.tipo-ico { width:52px; height:52px; border-radius:50%; background:var(--gold-lt); display:flex; align-items:center; justify-content:center; margin:0 auto 14px; font-size:1.3rem; color:var(--gold); }
.tipo-label { font-size:.82rem; color:rgba(255,255,255,.75); font-weight:500; }
.tipo-count { font-size:.72rem; color:var(--gold); margin-top:4px; }
.tipos-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:16px; }

/* ════════════════════════════════════════════════════════════
   QUEM SOMOS
════════════════════════════════════════════════════════════ */
.sobre-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,80px); align-items:center; }
.sobre-img-wrap { position:relative; border-radius:var(--r-lg); overflow:hidden; aspect-ratio:4/3; }
.sobre-img-wrap img { width:100%; height:100%; object-fit:cover; }
.sobre-img-badge { position:absolute; bottom:24px; left:24px; background:var(--white); border-radius:var(--r); padding:16px 20px; box-shadow:var(--sh); }
.sobre-img-badge strong { font-family:'Cormorant Garamond',serif; font-size:1.8rem; font-weight:700; color:var(--coal); display:block; line-height:1; }
.sobre-img-badge span { font-size:.75rem; color:var(--gray); text-transform:uppercase; letter-spacing:.06em; }
.sobre-valores { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:32px; }
.sobre-valor { display:flex; gap:14px; align-items:flex-start; }
.sobre-valor-ico { width:40px; height:40px; border-radius:var(--r); background:var(--gold-lt); display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:1rem; flex-shrink:0; }
.sobre-valor h4 { font-size:.9rem; font-weight:700; margin-bottom:4px; color:var(--coal); font-family:'DM Sans',sans-serif; }
.sobre-valor p { font-size:.82rem; color:var(--gray); line-height:1.5; }

/* ════════════════════════════════════════════════════════════
   EMPREENDIMENTOS
════════════════════════════════════════════════════════════ */
.emp-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(clamp(300px,30vw,420px),1fr)); gap:28px; }
.emp-card { border-radius:var(--r-lg); overflow:hidden; position:relative; cursor:pointer; aspect-ratio:4/3; transition:transform var(--dur) var(--ease); }
.emp-card:hover { transform:scale(1.02); }
.emp-card img { width:100%; height:100%; object-fit:cover; }
.emp-card-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 60%,transparent 100%); display:flex; flex-direction:column; justify-content:flex-end; padding:28px; }
.emp-card-status { display:inline-block; background:var(--gold); color:var(--coal); font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:4px 10px; border-radius:4px; margin-bottom:10px; }
.emp-card-nome { font-family:'Cormorant Garamond',serif; font-size:1.6rem; font-weight:600; color:var(--white); line-height:1.2; margin-bottom:6px; }
.emp-card-info { font-size:.82rem; color:rgba(255,255,255,.7); display:flex; align-items:center; gap:8px; }

/* ════════════════════════════════════════════════════════════
   CORRETORES
════════════════════════════════════════════════════════════ */
.corretores-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:24px; }
.corretor-card { background:var(--coal-2); border:1px solid rgba(255,255,255,.06); border-radius:var(--r-lg); padding:28px 20px; text-align:center; transition:all var(--dur) var(--ease); }
.corretor-card:hover { border-color:var(--gold); transform:translateY(-4px); background:var(--coal-3); }
.corretor-foto { width:80px; height:80px; border-radius:50%; object-fit:cover; border:2px solid var(--gold); margin:0 auto 14px; display:block; }
.corretor-foto-placeholder { width:80px; height:80px; border-radius:50%; background:var(--gold-lt); border:2px solid var(--gold); margin:0 auto 14px; display:flex; align-items:center; justify-content:center; font-family:'Cormorant Garamond',serif; font-size:2rem; font-weight:600; color:var(--gold); }
.corretor-nome { font-family:'Cormorant Garamond',serif; font-size:1.15rem; font-weight:600; color:var(--white); margin-bottom:4px; }
.corretor-creci { font-size:.75rem; color:var(--gray-lt); margin-bottom:12px; }
.corretor-espec { display:flex; flex-wrap:wrap; gap:6px; justify-content:center; margin-bottom:16px; }
.corretor-espec span { background:var(--gold-lt); color:var(--gold); font-size:.65rem; border-radius:20px; padding:3px 10px; font-weight:500; }
.corretor-wpp { display:inline-flex; align-items:center; gap:6px; background:#25D366; color:var(--white); border:none; border-radius:var(--r); padding:9px 18px; font-size:.82rem; font-weight:600; cursor:pointer; transition:all var(--dur); width:100%; justify-content:center; }
.corretor-wpp:hover { background:#1db954; transform:scale(1.02); }

/* ════════════════════════════════════════════════════════════
   CONTATO / CTA
════════════════════════════════════════════════════════════ */
.cta-section { background:var(--coal); position:relative; overflow:hidden; }
.cta-section::before { content:''; position:absolute; top:-50%; right:-10%; width:600px; height:600px; background:radial-gradient(circle,rgba(201,168,76,.08) 0%,transparent 70%); pointer-events:none; }
.contact-form { background:var(--coal-2); border:1px solid rgba(255,255,255,.08); border-radius:var(--r-lg); padding:clamp(28px,4vw,48px); }
.form-field { display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.form-label-portal { font-size:.8rem; color:rgba(255,255,255,.6); letter-spacing:.05em; text-transform:uppercase; font-weight:500; }
.form-input-portal { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:var(--r); padding:13px 16px; font-family:inherit; font-size:.95rem; color:var(--white); outline:none; transition:border-color var(--dur); }
.form-input-portal::placeholder { color:rgba(255,255,255,.25); }
.form-input-portal:focus { border-color:var(--gold); background:rgba(255,255,255,.08); }
.form-textarea-portal { resize:vertical; min-height:100px; }

/* ════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════ */
.footer { background:#111; padding:clamp(48px,6vw,80px) clamp(20px,4vw,60px) 32px; color:rgba(255,255,255,.55); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; max-width:1280px; margin:0 auto 48px; }
.footer-brand img { height:36px; margin-bottom:16px; }
.footer-brand p { font-size:.88rem; line-height:1.7; max-width:280px; }
.footer-col h4 { font-family:'Cormorant Garamond',serif; font-size:1rem; font-weight:600; color:var(--white); margin-bottom:16px; letter-spacing:.02em; }
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-link { font-size:.85rem; transition:color var(--dur); }
.footer-link:hover { color:var(--gold); }
.footer-social { display:flex; gap:12px; margin-top:20px; }
.footer-social a { width:36px; height:36px; border-radius:50%; border:1px solid rgba(255,255,255,.15); display:flex; align-items:center; justify-content:center; font-size:.9rem; transition:all var(--dur); color:rgba(255,255,255,.55); }
.footer-social a:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }
.footer-bottom { max-width:1280px; margin:0 auto; padding-top:24px; border-top:1px solid rgba(255,255,255,.08); display:flex; align-items:center; justify-content:space-between; font-size:.8rem; flex-wrap:wrap; gap:12px; }
.footer-bottom a { color:var(--gold); }

/* WhatsApp flutuante */
.wpp-float { position:fixed; bottom:28px; right:28px; z-index:900; width:58px; height:58px; border-radius:50%; background:#25D366; color:var(--white); border:none; display:flex; align-items:center; justify-content:center; font-size:1.5rem; cursor:pointer; box-shadow:0 4px 20px rgba(37,211,102,.4); transition:all var(--dur); animation:wppPulse 2.5s ease-in-out infinite; text-decoration:none; }
.wpp-float:hover { transform:scale(1.1); box-shadow:0 6px 28px rgba(37,211,102,.55); }
@keyframes wppPulse { 0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)} 50%{box-shadow:0 4px 32px rgba(37,211,102,.65)} }

/* ════════════════════════════════════════════════════════════
   SCROLL REVEAL — animações laterais
════════════════════════════════════════════════════════════ */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-left { opacity:0; transform:translateX(-48px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal-left.visible { opacity:1; transform:translateX(0); }
.reveal-right { opacity:0; transform:translateX(48px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal-right.visible { opacity:1; transform:translateX(0); }
.reveal-scale { opacity:0; transform:scale(.92); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.reveal-scale.visible { opacity:1; transform:scale(1); }

/* Delay helpers */
.delay-1 { transition-delay:.1s; }
.delay-2 { transition-delay:.2s; }
.delay-3 { transition-delay:.3s; }
.delay-4 { transition-delay:.4s; }
.delay-5 { transition-delay:.5s; }

/* ════════════════════════════════════════════════════════════
   RESPONSIVO
════════════════════════════════════════════════════════════ */
@media(max-width:1024px) {
    .footer-grid { grid-template-columns:1fr 1fr; }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
    .sobre-grid { grid-template-columns:1fr; }
    .carousel-track .im-card { flex:0 0 calc(50% - 12px); }
}
@media(max-width:768px) {
    .nav-links, .nav-cta { display:none; }
    .nav-hamburger { display:flex; }
    .hero-search { flex-direction:column; padding:16px; gap:0; }
    .hero-search-input { width:100%; border-bottom:1px solid var(--border-d); padding:10px 0; }
    .hero-search-divider { display:none; }
    .hero-search-select { width:100%; padding:10px 0; }
    .hero-search-btn { width:100%; height:44px; border-radius:var(--r); margin-top:8px; }
    .footer-grid { grid-template-columns:1fr; }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
    .footer-bottom { flex-direction:column; text-align:center; }
    .sobre-valores { grid-template-columns:1fr; }
    .carousel-track .im-card { flex:0 0 calc(100% - 0px); }
}
@media(max-width:480px) {
    .stats-grid { grid-template-columns:1fr 1fr; }
    .categorias-grid { grid-template-columns:repeat(3,1fr); }
    .tipos-grid { grid-template-columns:repeat(3,1fr); }
}
@media(min-width:2560px) {
    .navbar { height:80px; }
}

/* ════════════════════════════════════════════════════════════
   CORREÇÕES MOBILE
════════════════════════════════════════════════════════════ */
@media(max-width:768px) {
    /* Contato — empilha verticalmente */
    #contato .container > div {
        grid-template-columns: 1fr !important;
    }

    /* Categorias — 3 colunas iguais sem corte */
    .categorias-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 12px;
    }

    /* Hero tags — centraliza e quebra bem */
    .hero-tags {
        justify-content: center;
        gap: 8px;
    }
    .hero-tag {
        font-size: .72rem;
        padding: 5px 10px;
    }

    /* Sobre — empilha */
    .sobre-grid { 
    display:grid; 
    grid-template-columns:1fr 1fr; 
    gap:clamp(40px,6vw,80px); 
    align-items:start;
}

/* Texto justificado */
.sobre-grid p { text-align: justify; }

/* Valores em grid correto */
.sobre-valores {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 24px;
}
.sobre-valor {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    background: var(--off-wh);
    border-radius: var(--r);
    padding: 14px;
}
.sobre-valor-ico {
    width: 36px;
    height: 36px;
    border-radius: var(--r);
    background: var(--gold-lt);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gold);
    font-size: .9rem;
    flex-shrink: 0;
}
.sobre-valor h4 { 
    font-size: .85rem; 
    font-weight: 700; 
    margin-bottom: 3px; 
    color: var(--coal);
    font-family: 'DM Sans', sans-serif;
}
.sobre-valor p { 
    font-size: .78rem; 
    color: var(--gray); 
    line-height: 1.4;
    text-align: left;
}

    /* Footer grid — 2 colunas */
    .footer-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 28px;
    }

    /* Corretores — 2 colunas */
    .corretores-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Stats — 2 colunas */
    .stats-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media(max-width:420px) {
    /* Categorias — 2 colunas em telas muito pequenas */
    .categorias-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    /* Footer — coluna única */
    .footer-grid {
        grid-template-columns: 1fr !important;
    }

    /* Corretores — coluna única */
    .corretores-grid {
        grid-template-columns: 1fr !important;
    }

    /* Stats — 2 colunas */
    .stats-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    /* Contato form grid interno */
    #contato .contact-form > div[style*="grid-template-columns"] {
        display: flex !important;
        flex-direction: column !important;
    }
}