/* =========================================================================
   app.css — tema de marca "Casa da Locação" sobre Bootstrap 5.3 + MDI
   Direção: acolhedor / amigável. Paleta nova: verde (#18935A) + laranja (#F58220)
   com neutros quentes. Carregado DEPOIS do bootstrap.css.
   ========================================================================= */

:root {
    /* ---- Verde (cor principal) ---- */
    --brand: #18935a;
    --brand-dark: #127049;
    --brand-darker: #0e5638;
    --brand-soft: #e7f4ec;
    --brand-soft-2: #f1f8f3;

    /* ---- Laranja (acento / CTA) ---- */
    --accent: #f58220;
    --accent-dark: #e06d12;
    --accent-soft: #fff1e1;

    /* ---- Neutros quentes ---- */
    --ink: #26302a;          /* títulos */
    --body-ink: #49524c;     /* texto corrido */
    --muted: #7c857f;        /* texto secundário */
    --cream: #faf8f4;        /* fundo da página */
    --surface: #ffffff;      /* cards / superfícies */
    --line: #ebe7df;         /* bordas suaves */
    --footer-bg: #13241b;    /* rodapé verde-escuro */

    /* ---- Raios e sombras ---- */
    --radius-sm: 12px;
    --radius: 18px;
    --radius-lg: 26px;
    --shadow-sm: 0 2px 10px rgba(20, 36, 27, .06);
    --shadow: 0 10px 30px rgba(20, 36, 27, .09);
    --shadow-lg: 0 18px 48px rgba(20, 36, 27, .16);

    /* ---- Overrides de variáveis do Bootstrap ---- */
    --bs-primary: #18935a;
    --bs-primary-rgb: 24, 147, 90;
    --bs-body-color: #49524c;
    --bs-body-bg: #faf8f4;
    --bs-link-color: #127049;
    --bs-link-color-rgb: 18, 112, 73;
    --bs-link-hover-color: #0e5638;
    --bs-border-color: #ebe7df;
    --bs-border-radius: var(--radius-sm);
    --bs-border-radius-lg: var(--radius);
}

/* =========================================================================
   Base
   ========================================================================= */
body {
    font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    color: var(--body-ink);
    background-color: var(--cream);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
    color: var(--ink);
    font-weight: 700;
    letter-spacing: -.01em;
}

a { text-decoration: none; }
a:hover { text-decoration: none; }

::selection { background: var(--brand-soft); color: var(--brand-darker); }

.text-muted { color: var(--muted) !important; }
.lead { color: var(--body-ink); }

/* Seções com respiro e título de seção */
.section-title {
    font-weight: 800;
    color: var(--ink);
}
.section-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--brand);
}
.section-eyebrow::before {
    content: "";
    width: 26px; height: 2px;
    background: var(--accent);
    border-radius: 2px;
}

/* =========================================================================
   Cores utilitárias da marca
   ========================================================================= */
.text-primary { color: var(--brand) !important; }
.bg-primary { background-color: var(--brand) !important; }
.border-primary { border-color: var(--brand) !important; }
.text-bg-primary { background-color: var(--brand) !important; color: #fff !important; }
.bg-brand-soft { background-color: var(--brand-soft) !important; }
.bg-cream { background-color: var(--cream) !important; }
.text-accent { color: var(--accent) !important; }
.bg-accent { background-color: var(--accent) !important; }
.text-bg-accent { background-color: var(--accent) !important; color: #fff !important; }

/* =========================================================================
   Botões — pílula, com leve elevação no hover
   ========================================================================= */
.btn {
    --bs-btn-border-radius: 50rem;
    --bs-btn-font-weight: 600;
    --bs-btn-padding-x: 1.35rem;
    --bs-btn-padding-y: .6rem;
    transition: transform .15s ease, box-shadow .2s ease, background-color .2s ease, color .2s ease, border-color .2s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn-primary {
    --bs-btn-bg: var(--brand);
    --bs-btn-border-color: var(--brand);
    --bs-btn-hover-bg: var(--brand-dark);
    --bs-btn-hover-border-color: var(--brand-dark);
    --bs-btn-active-bg: var(--brand-darker);
    --bs-btn-active-border-color: var(--brand-darker);
    --bs-btn-disabled-bg: var(--brand);
    --bs-btn-disabled-border-color: var(--brand);
    box-shadow: 0 6px 16px rgba(24, 147, 90, .22);
}
.btn-primary:hover { box-shadow: 0 10px 22px rgba(24, 147, 90, .30); }

.btn-outline-primary {
    --bs-btn-color: var(--brand-dark);
    --bs-btn-border-color: var(--brand);
    --bs-btn-hover-bg: var(--brand);
    --bs-btn-hover-border-color: var(--brand);
    --bs-btn-active-bg: var(--brand-dark);
    --bs-btn-active-border-color: var(--brand-dark);
}

/* CTA laranja (acento) — usado para ações de conversão */
.btn-accent, .btn-warning {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--accent);
    --bs-btn-border-color: var(--accent);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--accent-dark);
    --bs-btn-hover-border-color: var(--accent-dark);
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--accent-dark);
    --bs-btn-active-border-color: var(--accent-dark);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: var(--accent);
    --bs-btn-disabled-border-color: var(--accent);
    font-weight: 700;
    box-shadow: 0 6px 16px rgba(245, 130, 32, .28);
}
.btn-accent:hover, .btn-warning:hover { box-shadow: 0 10px 24px rgba(245, 130, 32, .38); }

.btn-light {
    --bs-btn-bg: #fff;
    --bs-btn-border-color: var(--line);
    --bs-btn-hover-bg: var(--brand-soft);
    --bs-btn-hover-border-color: var(--brand-soft);
    --bs-btn-color: var(--ink);
}

/* =========================================================================
   Ícones MDI
   ========================================================================= */
.mdi { vertical-align: middle; line-height: 1; }

/* =========================================================================
   Navbar
   ========================================================================= */
.navbar {
    background-color: rgba(255, 255, 255, .92) !important;
    backdrop-filter: saturate(180%) blur(8px);
    box-shadow: 0 2px 18px rgba(20, 36, 27, .07);
    padding-top: .5rem;
    padding-bottom: .5rem;
}
.navbar-brand img { max-height: 52px; width: auto; }

.navbar .nav-link {
    font-weight: 600;
    color: var(--body-ink);
    border-radius: 50rem;
    padding: .45rem .95rem !important;
    transition: color .2s ease, background-color .2s ease;
}
.navbar .nav-link:hover { color: var(--brand-dark); background: var(--brand-soft-2); }
.navbar .nav-link.active { color: var(--brand-dark) !important; background: var(--brand-soft); }

/* Barra de contatos no topo da navbar */
.topbar-contacts a {
    color: var(--body-ink);
    font-weight: 600;
    transition: color .2s ease;
}
.topbar-contacts a:hover { color: var(--brand-dark); }
.topbar-contacts .mdi { color: var(--accent); }

/* Ícones sociais circulares */
.social-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px; height: 38px;
    border-radius: 50%;
    transition: transform .2s ease, background-color .2s ease, color .2s ease;
}
.social-icon:hover { transform: translateY(-3px); }
.navbar .social-icon { background: var(--brand-soft); color: var(--brand-dark); }
.navbar .social-icon:hover { background: var(--brand); color: #fff; }
footer .social-icon { background: rgba(255, 255, 255, .10); color: #fff; }
footer .social-icon:hover { background: var(--accent); color: #fff; }

/* =========================================================================
   Hero (cabeçalho com imagem de fundo)
   ========================================================================= */
.site-hero {
    position: relative;
    background-size: cover;
    background-position: center;
    background-color: var(--brand-darker);
    color: #fff;
    overflow: hidden;
}
.site-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(120deg, rgba(14, 86, 56, .92) 0%, rgba(14, 86, 56, .55) 45%, rgba(14, 86, 56, .15) 100%),
        linear-gradient(0deg, rgba(0, 0, 0, .35), rgba(0, 0, 0, .05));
}
.site-hero > * { position: relative; z-index: 1; }
.site-hero h1, .site-hero h2, .site-hero h3 { color: #fff; }
.site-hero .hero-sub { color: rgba(255, 255, 255, .9); }

/* Hero compacto para páginas internas */
.site-hero.hero-compact { padding-top: 1rem; padding-bottom: 1rem; }

/* =========================================================================
   Cards genéricos
   ========================================================================= */
.card {
    --bs-card-border-color: var(--line);
    --bs-card-border-radius: var(--radius);
    --bs-card-inner-border-radius: var(--radius);
    --bs-card-bg: var(--surface);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-sm);
}
.card.shadow-sm { box-shadow: var(--shadow-sm) !important; }
.card.shadow { box-shadow: var(--shadow) !important; }

/* Painel/superfície arredondada genérica (busca, blocos) */
.panel {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 1.5rem;
}

/* =========================================================================
   Card de imóvel
   ========================================================================= */
.imovel-card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--surface);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.imovel-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg) !important;
    border-color: transparent;
}
.imovel-card .imovel-foto {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    width: 100%;
    transition: transform .35s ease;
}
.imovel-card:hover .imovel-foto { transform: scale(1.05); }
.imovel-card .imovel-foto-wrap { overflow: hidden; position: relative; }

/* Preço em destaque */
.imovel-preco {
    color: var(--brand-dark);
    font-weight: 800;
    font-size: 1.25rem;
    line-height: 1.2;
}
.imovel-preco small { font-weight: 600; color: var(--muted); font-size: .8rem; }

/* Chips de características (área / quartos / banheiros) */
.imovel-specs {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
}
.imovel-specs .spec {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    background: var(--brand-soft-2);
    color: var(--body-ink);
    border-radius: 50rem;
    padding: .28rem .7rem;
    font-size: .82rem;
    font-weight: 600;
    white-space: nowrap;
}
.imovel-specs .spec .mdi { color: var(--brand); font-size: 1.05rem; }

/* Badge de negócio (Aluguel / Venda) sobre a foto */
.imovel-badge {
    position: absolute;
    top: .75rem; left: .75rem;
    background: var(--accent);
    color: #fff;
    font-weight: 700;
    font-size: .72rem;
    letter-spacing: .04em;
    text-transform: uppercase;
    padding: .3rem .7rem;
    border-radius: 50rem;
    box-shadow: 0 4px 12px rgba(245, 130, 32, .35);
}

/* Botão favoritar (coração) sobre a foto */
.imovel-fav {
    position: absolute;
    top: .6rem; right: .6rem;
    width: 38px; height: 38px;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(255, 255, 255, .92);
    color: var(--accent);
    border-radius: 50%;
    box-shadow: var(--shadow-sm);
    transition: transform .15s ease, background-color .2s ease, color .2s ease;
}
.imovel-fav:hover { transform: scale(1.1); background: #fff; color: var(--accent-dark); }

/* =========================================================================
   Formulários
   ========================================================================= */
.form-control, .form-select {
    border-radius: var(--radius-sm);
    border-color: var(--line);
    padding: .6rem .9rem;
    background-color: #fff;
    color: var(--ink);
}
.form-control::placeholder { color: #aeb4af; }
.form-control:focus, .form-select:focus {
    border-color: var(--brand);
    box-shadow: 0 0 0 .2rem rgba(24, 147, 90, .18);
}
.form-label, .form-label-static, .form-label-outside {
    font-weight: 600;
    color: var(--body-ink);
    margin-bottom: .3rem;
    font-size: .88rem;
}
.input-group-text {
    background: var(--brand-soft-2);
    border-color: var(--line);
    color: var(--brand-dark);
    border-radius: var(--radius-sm);
}

/* =========================================================================
   Widget de busca (template AngularJS <busca>)
   ========================================================================= */
.busca-widget {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 1.5rem;
}
.busca-widget h3 {
    font-size: 1.15rem;
    font-weight: 800;
    margin-bottom: 1.1rem;
    color: var(--ink);
}
.busca-widget h3 .mdi { color: var(--accent); }
/* Variante sobre o hero (fundo escuro) — usa card branco mesmo, mantém legibilidade */
.busca-widget.busca-hero { box-shadow: var(--shadow-lg); }

/* =========================================================================
   Badges / pílulas
   ========================================================================= */
.badge { font-weight: 600; letter-spacing: .02em; }
.pill {
    display: inline-flex; align-items: center; gap: .35rem;
    background: var(--brand-soft); color: var(--brand-dark);
    border-radius: 50rem; padding: .3rem .8rem; font-weight: 600; font-size: .82rem;
}

/* =========================================================================
   Paginação
   ========================================================================= */
.pagination { --bs-pagination-border-radius: 50rem; gap: .25rem; }
.page-link {
    color: var(--brand-dark);
    border-radius: 50rem !important;
    border-color: var(--line);
    min-width: 40px; text-align: center;
    font-weight: 600;
}
.page-link:hover { background: var(--brand-soft); color: var(--brand-darker); border-color: var(--brand-soft); }
.page-item.active .page-link { background-color: var(--brand); border-color: var(--brand); color: #fff; }

/* =========================================================================
   Tabela de detalhes (página do imóvel)
   ========================================================================= */
.detalhes-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: .6rem;
    list-style: none;
    padding: 0; margin: 0;
}
.detalhes-list li {
    display: flex; align-items: center; gap: .6rem;
    background: var(--brand-soft-2);
    border-radius: var(--radius-sm);
    padding: .7rem .9rem;
}
.detalhes-list .mdi { color: var(--brand); font-size: 1.3rem; }
.detalhes-list .rotulo { color: var(--muted); font-size: .78rem; display: block; }
.detalhes-list .valor { color: var(--ink); font-weight: 700; }

/* =========================================================================
   Rodapé
   ========================================================================= */
footer.site-footer {
    background-color: var(--footer-bg) !important;
    color: rgba(255, 255, 255, .72);
}
footer.site-footer h5 { color: #fff; font-weight: 700; }
footer.site-footer a { color: rgba(255, 255, 255, .78); transition: color .2s ease; }
footer.site-footer a:hover { color: var(--accent); }
footer.site-footer .text-secondary { color: rgba(255, 255, 255, .6) !important; }
footer.site-footer hr { border-color: rgba(255, 255, 255, .12); opacity: 1; }

/* =========================================================================
   Galeria de imóvel — mosaico (estilo Airbnb) + lightbox
   ========================================================================= */
.gallery-mosaic {
    position: relative;
    display: grid;
    gap: 8px;
    height: 460px;
    border-radius: var(--radius);
    overflow: hidden;
}
.gallery-tile {
    position: relative;
    overflow: hidden;
    cursor: pointer;
    display: block;
    background: var(--brand-soft-2);
}
.gallery-tile img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .45s ease;
}
.gallery-tile:hover img { transform: scale(1.06); }
.gallery-tile::after {
    content: ""; position: absolute; inset: 0;
    background: rgba(0, 0, 0, 0); transition: background .2s ease;
}
.gallery-tile:hover::after { background: rgba(0, 0, 0, .12); }

/* "+N fotos" no último tile + botão "ver todas" */
.gallery-more {
    position: absolute; inset: 0; z-index: 2;
    display: flex; align-items: center; justify-content: center;
    background: rgba(14, 86, 56, .55);
    color: #fff; font-weight: 700; font-size: 1.15rem;
    gap: .4rem;
}
/* Quantidades: tile 1 sempre grande (2x2) */
.gallery-mosaic.count-1 { grid-template-columns: 1fr; }
.gallery-mosaic.count-2 { grid-template-columns: 1fr 1fr; }
.gallery-mosaic.count-3 { grid-template-columns: 2fr 1fr; grid-template-rows: 1fr 1fr; }
.gallery-mosaic.count-3 .gallery-tile:first-child { grid-row: 1 / 3; }
.gallery-mosaic.count-4,
.gallery-mosaic.count-5 { grid-template-columns: repeat(4, 1fr); grid-template-rows: 1fr 1fr; }
.gallery-mosaic.count-4 .gallery-tile:first-child,
.gallery-mosaic.count-5 .gallery-tile:first-child { grid-column: 1 / 3; grid-row: 1 / 3; }
.gallery-mosaic.count-4 .gallery-tile:nth-child(4) { grid-column: 3 / 5; }

@media (max-width: 767px) {
    .gallery-mosaic { grid-template-columns: 1fr !important; grid-template-rows: auto !important; height: auto; }
    .gallery-mosaic .gallery-tile:not(:first-child) { display: none; }
    .gallery-mosaic .gallery-tile:first-child { grid-column: auto !important; grid-row: auto !important; aspect-ratio: 4 / 3; }
    .gallery-mosaic .gallery-more { display: none; }
}

/* Lightbox (modal fullscreen com carrossel) */
.gallery-lightbox .modal-content { background: rgba(11, 17, 13, .98); border: none; }
.gallery-lightbox .carousel,
.gallery-lightbox .carousel-inner,
.gallery-lightbox .carousel-item { height: 100vh; }
.gallery-lightbox .carousel-item img { width: 100%; height: 100%; object-fit: contain; }
.gallery-lightbox .btn-close-lightbox {
    position: absolute; top: 1rem; right: 1.25rem; z-index: 10;
    width: 46px; height: 46px; border-radius: 50%;
    background: rgba(255, 255, 255, .14); color: #fff; border: none;
    display: inline-flex; align-items: center; justify-content: center; font-size: 1.5rem;
    transition: background .2s ease;
}
.gallery-lightbox .btn-close-lightbox:hover { background: var(--accent); }
.gallery-lightbox .lightbox-counter {
    position: absolute; bottom: 1.5rem; left: 50%; transform: translateX(-50%); z-index: 10;
    background: rgba(0, 0, 0, .5); color: #fff;
    padding: .35rem 1rem; border-radius: 50rem; font-weight: 600; font-size: .9rem;
}
.gallery-lightbox .carousel-control-prev,
.gallery-lightbox .carousel-control-next { width: 8%; opacity: .85; }
.gallery-lightbox .carousel-control-prev-icon,
.gallery-lightbox .carousel-control-next-icon { width: 2.6rem; height: 2.6rem; }

/* =========================================================================
   InfoWindow do mapa (card do imóvel ao clicar no pin)
   ========================================================================= */
/* Remove o padding/borda padrão feios da InfoWindow do Google Maps */
.gm-style .gm-style-iw-c {
    padding: 0 !important;
    border-radius: var(--radius) !important;
    box-shadow: var(--shadow-lg) !important;
    overflow: hidden;
}
.gm-style .gm-style-iw-d { overflow: hidden !important; padding: 0 !important; }
.gm-style .gm-style-iw-c button.gm-ui-hover-effect {
    top: 6px !important; right: 6px !important;
    background: rgba(255, 255, 255, .9) !important; border-radius: 50% !important;
}

.map-info { width: 240px; font-family: inherit; }
.map-info-img {
    position: relative; display: block; height: 150px; overflow: hidden;
}
.map-info-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.map-info-preco {
    position: absolute; left: 10px; bottom: 10px;
    background: var(--accent); color: #fff; font-weight: 700;
    padding: .25rem .7rem; border-radius: 50rem; font-size: .9rem;
    box-shadow: 0 4px 12px rgba(245, 130, 32, .35);
}
.map-info-body { padding: .85rem 1rem 1rem; }
.map-info-tipo { font-weight: 700; color: var(--ink); }
.map-info-ref { color: var(--muted); font-size: .82rem; margin-bottom: .6rem; }

/* =========================================================================
   Accordion (FAQ)
   ========================================================================= */
.accordion {
    --bs-accordion-border-color: var(--line);
    --bs-accordion-border-radius: var(--radius);
    --bs-accordion-active-bg: var(--brand-soft);
    --bs-accordion-active-color: var(--brand-darker);
    --bs-accordion-btn-focus-box-shadow: 0 0 0 .2rem rgba(24, 147, 90, .18);
    display: flex;
    flex-direction: column;
    gap: .75rem;
}
.accordion-item {
    border: 1px solid var(--line) !important;
    border-radius: var(--radius) !important;
    overflow: hidden;
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}
.accordion-button { font-weight: 600; color: var(--ink); }
.accordion-button:not(.collapsed) { box-shadow: none; }

/* =========================================================================
   Botão "voltar ao topo" — escondido no topo, aparece ao rolar
   ========================================================================= */
.btn-to-top {
    position: fixed; right: 28px; bottom: 94px; z-index: 1030;
    width: 46px; height: 46px;
    display: inline-flex; align-items: center; justify-content: center;
    background: #fff; color: var(--brand-dark);
    border: 1px solid var(--line); border-radius: 50%;
    font-size: 1.4rem; line-height: 1;
    box-shadow: var(--shadow);
    cursor: pointer;
    opacity: 0; visibility: hidden; transform: translateY(12px);
    transition: opacity .25s ease, transform .25s ease, background-color .2s ease, color .2s ease;
}
.btn-to-top.show { opacity: 1; visibility: visible; transform: translateY(0); }
.btn-to-top:hover { background: var(--brand); color: #fff; border-color: var(--brand); }

/* =========================================================================
   Animação de entrada suave (cards)
   ========================================================================= */
@media (prefers-reduced-motion: no-preference) {
    .fade-up { animation: fadeUp .5s ease both; }
    @keyframes fadeUp {
        from { opacity: 0; transform: translateY(12px); }
        to { opacity: 1; transform: translateY(0); }
    }
}
