/*
Theme Name: Domingues Empreendimentos
Theme URI: https://dominguesadm.com.br
Author: INNSITE / Orbion Digital
Author URI: https://innsite.com.br
Description: Tema imobiliário premium para Domingues Empreendimentos. CPT de Imóveis, filtros avançados, slider hero e personalização total via Customizer.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: domingues
*/

:root {
    --azul-marinho: #0A192F;
    --azul-royal: #4169E1;
    --amarelo: #FFD700;
    --preto: #111111;
    --cinza-escuro: #334155;
    --cinza-texto: #64748B;
    --cinza-claro: #F8FAFC;
    --cinza-borda: #E2E8F0;
    --branco: #FFFFFF;
    --shadow-sm: 0 4px 6px -1px rgba(0,0,0,0.05), 0 2px 4px -1px rgba(0,0,0,0.03);
    --shadow-md: 0 10px 15px -3px rgba(0,0,0,0.08), 0 4px 6px -2px rgba(0,0,0,0.04);
    --shadow-hover: 0 20px 25px -5px rgba(0,0,0,0.1), 0 10px 10px -5px rgba(0,0,0,0.04);
    --shadow-floating: 0 30px 60px -10px rgba(0,0,0,0.2);
    --radius-lg: 24px;
    --radius-md: 12px;
    --radius-sm: 6px;
}

* { margin: 0; padding: 0; box-sizing: border-box; font-family: 'Inter', sans-serif; }
body { background-color: var(--branco); color: var(--cinza-escuro); line-height: 1.7; overflow-x: hidden; }
a { text-decoration: none; color: inherit; transition: all 0.3s ease; }
ul { list-style: none; }
img { max-width: 100%; height: auto; }

/* TOP BAR */
.top-bar { background-color: var(--azul-marinho); color: var(--cinza-claro); padding: 0.6rem 5%; display: flex; justify-content: space-between; align-items: center; font-size: 0.85rem; font-weight: 500; position: relative; z-index: 1001; }
.top-bar-left, .top-bar-right { display: flex; gap: 1.5rem; align-items: center; }
.top-bar i { color: var(--amarelo); margin-right: 0.4rem; }
.top-bar a:hover { color: var(--amarelo); }

/* HEADER */
header.site-header { background-color: rgba(255,255,255,0.98); backdrop-filter: blur(10px); position: sticky; top: 0; z-index: 1000; box-shadow: var(--shadow-sm); padding: 1.2rem 5%; display: flex; justify-content: space-between; align-items: center; transition: all 0.3s; }
.logo img { height: 48px; object-fit: contain; }
.site-header nav ul { display: flex; gap: 2.2rem; align-items: center; }
.site-header nav a { color: var(--azul-marinho); font-weight: 600; font-size: 0.95rem; position: relative; padding: 0.5rem 0; }
.site-header nav a::after { content: ''; position: absolute; width: 0; height: 2px; bottom: 0; left: 0; background-color: var(--azul-royal); transition: width 0.3s ease; }
.site-header nav a:hover::after, .site-header nav .current-menu-item > a::after { width: 100%; }
.header-actions { display: flex; gap: 1rem; align-items: center; }

.btn-primary { background-color: var(--amarelo); color: var(--preto); padding: 0.8rem 1.8rem; border-radius: var(--radius-md); font-weight: 700; font-size: 0.9rem; box-shadow: var(--shadow-sm); transition: 0.3s; display: inline-block; }
.btn-primary:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); background-color: #f0cb00; }

/* MOBILE TOGGLE */
.menu-toggle { display: none; background: transparent; border: none; font-size: 1.5rem; color: var(--azul-marinho); cursor: pointer; }

/* HERO SLIDER */
.hero { position: relative; height: 85vh; overflow: hidden; background-color: var(--preto); padding: 0; }
.slider { width: 100%; height: 100%; position: relative; }
.slide { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; transition: opacity 1s ease-in-out; background-size: cover; background-position: center; }
.slide::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(90deg, rgba(10,25,47,0.95) 0%, rgba(10,25,47,0.4) 100%); }
.slide.active { opacity: 1; }
.hero-content { position: absolute; top: 40%; left: 5%; transform: translateY(-50%); z-index: 10; max-width: 700px; color: var(--branco); }
.hero-content h2 { color: var(--amarelo); font-size: 1rem; text-transform: uppercase; letter-spacing: 3px; margin-bottom: 1.5rem; font-weight: 700; }
.hero-content h1 { font-size: 4.5rem; line-height: 1.1; font-weight: 800; margin-bottom: 1.5rem; letter-spacing: -1.5px; }
.hero-content p { font-size: 1.2rem; color: #E2E8F0; margin-bottom: 2.5rem; font-weight: 300; max-width: 500px; }

/* FILTRO AVANÇADO */
.advanced-filter { background: var(--branco); width: 90%; max-width: 1200px; margin: -100px auto 4rem; position: relative; z-index: 20; border-radius: var(--radius-lg); box-shadow: var(--shadow-floating); overflow: hidden; }
.filter-header { display: flex; border-bottom: 1px solid var(--cinza-borda); background: var(--cinza-claro); flex-wrap: wrap; }
.location-selector { background: var(--azul-marinho); color: var(--branco); padding: 0 2.5rem; display: flex; align-items: center; gap: 1rem; cursor: pointer; position: relative; }
.location-selector select { appearance: none; background: transparent; border: none; color: var(--branco); font-weight: 700; font-size: 1rem; cursor: pointer; outline: none; padding: 1.5rem 2rem 1.5rem 0; }
.location-selector select option { color: var(--azul-marinho); }
.location-selector i { position: absolute; right: 1.5rem; pointer-events: none; color: var(--amarelo); }
.status-tabs { display: flex; flex: 1; overflow-x: auto; }
.tab-btn { background: transparent; border: none; padding: 1.5rem 2.5rem; font-size: 1rem; font-weight: 600; color: var(--cinza-texto); cursor: pointer; transition: all 0.3s; position: relative; white-space: nowrap; }
.tab-btn:hover { color: var(--azul-marinho); }
.tab-btn.active { color: var(--azul-marinho); background: var(--branco); }
.tab-btn.active::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 4px; background: var(--azul-royal); }
.filter-body { padding: 3rem 2.5rem; background: var(--branco); display: grid; grid-template-columns: 2fr 1fr; gap: 3rem; align-items: center; }
.filter-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.input-group label { font-size: 0.8rem; font-weight: 700; color: var(--cinza-texto); text-transform: uppercase; letter-spacing: 0.5px; display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.8rem; }
.input-group label i { color: var(--azul-royal); }
.custom-select { position: relative; width: 100%; }
.custom-select select { width: 100%; padding: 1.2rem; border: 1px solid var(--cinza-borda); border-radius: var(--radius-md); font-size: 1rem; color: var(--azul-marinho); font-weight: 600; appearance: none; background: transparent; cursor: pointer; transition: all 0.3s; }
.custom-select select:focus { border-color: var(--azul-royal); box-shadow: 0 0 0 3px rgba(65,105,225,0.15); outline: none; }
.custom-select i { position: absolute; right: 1.2rem; top: 50%; transform: translateY(-50%); color: var(--cinza-texto); pointer-events: none; }
.filter-actions { display: flex; flex-direction: column; gap: 1rem; }
.btn-submit { width: 100%; padding: 1.2rem; background: var(--azul-royal); border: none; border-radius: var(--radius-md); color: var(--branco); font-size: 1rem; font-weight: 800; letter-spacing: 1px; cursor: pointer; transition: all 0.3s; display: flex; align-items: center; justify-content: center; gap: 0.8rem; }
.btn-submit:hover { background: var(--azul-marinho); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn-advanced { background: transparent; border: none; color: var(--cinza-texto); font-weight: 600; cursor: pointer; font-size: 0.9rem; text-decoration: underline; transition: 0.3s; }
.btn-advanced:hover { color: var(--azul-marinho); }

/* SEÇÕES */
section { padding: 6rem 5%; }
.section-header { margin-bottom: 4rem; text-align: center; max-width: 700px; margin-left: auto; margin-right: auto; }
.section-subtitle { color: var(--azul-royal); font-weight: 700; text-transform: uppercase; letter-spacing: 2px; font-size: 0.9rem; display: block; margin-bottom: 1rem; }
.section-title { font-size: 2.8rem; color: var(--azul-marinho); font-weight: 800; letter-spacing: -1px; line-height: 1.2; }

/* SERVIÇOS */
.servicos-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 2.5rem; }
.servico-card { background: var(--cinza-claro); padding: 3rem 2.5rem; border-radius: var(--radius-lg); transition: all 0.4s ease; border-top: 4px solid transparent; }
.servico-card:hover { background: var(--branco); box-shadow: var(--shadow-hover); transform: translateY(-10px); border-top-color: var(--amarelo); }
.icon-box { width: 70px; height: 70px; background: var(--branco); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-size: 2rem; color: var(--azul-royal); margin-bottom: 2rem; box-shadow: var(--shadow-sm); transition: 0.4s; }
.servico-card:hover .icon-box { background: var(--azul-royal); color: var(--branco); }
.servico-card h3 { font-size: 1.5rem; color: var(--azul-marinho); margin-bottom: 1.2rem; font-weight: 800; }
.servico-card p { color: var(--cinza-texto); margin-bottom: 1.5rem; font-size: 0.95rem; }
.servico-card ul { margin-bottom: 2rem; }
.servico-card li { display: flex; align-items: flex-start; gap: 0.8rem; margin-bottom: 0.8rem; font-size: 0.95rem; color: var(--cinza-escuro); font-weight: 500; }
.servico-card li i { color: var(--amarelo); margin-top: 4px; }
.link-arrow { color: var(--azul-royal); font-weight: 700; display: inline-flex; align-items: center; gap: 0.5rem; }
.link-arrow:hover { gap: 0.8rem; color: var(--azul-marinho); }

/* IMÓVEIS CARDS */
.property-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 2.5rem; }
.property-card { background: var(--branco); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); transition: all 0.4s ease; position: relative; border: 1px solid rgba(0,0,0,0.04); }
.property-card:hover { transform: translateY(-10px); box-shadow: var(--shadow-hover); border-color: transparent; }
.card-img-wrapper { position: relative; height: 260px; overflow: hidden; }
.card-img-wrapper img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.property-card:hover .card-img-wrapper img { transform: scale(1.08); }
.badge-status { position: absolute; top: 1.2rem; left: 1.2rem; background: var(--azul-royal); color: var(--branco); padding: 0.5rem 1.2rem; border-radius: 30px; font-size: 0.8rem; font-weight: 700; z-index: 2; box-shadow: var(--shadow-sm); }
.badge-status.alugar { background: var(--cinza-escuro); }
.badge-featured { position: absolute; top: 1.2rem; right: 1.2rem; background: var(--amarelo); color: var(--preto); padding: 0.5rem 1.2rem; border-radius: 30px; font-size: 0.8rem; font-weight: 800; z-index: 2; box-shadow: var(--shadow-sm); }
.card-content { padding: 2.2rem 1.8rem; }
.card-location { color: var(--cinza-texto); font-size: 0.85rem; font-weight: 600; margin-bottom: 0.8rem; display: flex; align-items: center; gap: 0.5rem; }
.card-title { font-size: 1.25rem; color: var(--azul-marinho); margin-bottom: 1.5rem; font-weight: 800; line-height: 1.4; }
.card-features { display: flex; gap: 1.5rem; flex-wrap: wrap; border-top: 1px solid var(--cinza-borda); border-bottom: 1px solid var(--cinza-borda); padding: 1.2rem 0; margin-bottom: 1.5rem; }
.feature { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9rem; font-weight: 600; color: var(--azul-marinho); }
.feature i { color: var(--azul-royal); }
.card-footer { display: flex; justify-content: space-between; align-items: center; }
.price { font-size: 1.6rem; font-weight: 800; color: var(--azul-marinho); }
.price span { font-size: 0.9rem; color: var(--cinza-texto); font-weight: 500; }
.btn-outline-small { border: 2px solid var(--cinza-borda); color: var(--cinza-escuro); padding: 0.6rem 1.2rem; border-radius: var(--radius-md); font-weight: 600; font-size: 0.85rem; transition: 0.3s; }
.property-card:hover .btn-outline-small { background: var(--azul-royal); border-color: var(--azul-royal); color: var(--branco); }

/* SOBRE */
.sobre { background-color: var(--azul-marinho); color: var(--branco); border-radius: var(--radius-lg); margin: 0 5%; padding: 0; display: grid; grid-template-columns: 1fr 1fr; overflow: hidden; box-shadow: var(--shadow-md); }
.sobre-img { background-size: cover; background-position: center; min-height: 500px; }
.sobre-content { padding: 5rem 4rem; }
.sobre-content .section-subtitle { color: var(--amarelo); }
.sobre-content .section-title { color: var(--branco); margin-bottom: 2rem; text-align: left; font-size: 2.5rem; }
.sobre-content p { color: #CBD5E0; margin-bottom: 1.5rem; font-size: 1.05rem; font-weight: 300; line-height: 1.8; }
.mvv-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 3rem; }
.mvv-box h4 { color: var(--amarelo); font-size: 1.1rem; margin-bottom: 0.8rem; display: flex; align-items: center; gap: 0.5rem; }
.mvv-box p { font-size: 0.95rem; margin-bottom: 0; line-height: 1.6; }

/* FOOTER */
footer.site-footer { background-color: var(--preto); color: #94A3B8; padding: 6rem 5% 2rem; margin-top: 4rem; font-size: 0.95rem; }
.footer-top { display: grid; grid-template-columns: 2fr 1fr 1.5fr; gap: 5rem; margin-bottom: 4rem; padding-bottom: 4rem; border-bottom: 1px solid rgba(255,255,255,0.05); }
.footer-logo img { height: 65px; margin-bottom: 1.5rem; filter: brightness(0) invert(1); }
.footer-col p { margin-bottom: 2.5rem; line-height: 1.8; max-width: 400px; font-size: 1rem; }
.social-links { display: flex; gap: 1rem; }
.social-links a { width: 45px; height: 45px; background: rgba(255,255,255,0.05); display: flex; align-items: center; justify-content: center; border-radius: var(--radius-sm); color: var(--branco); font-size: 1.1rem; transition: 0.3s; }
.social-links a:hover { background: var(--azul-royal); transform: translateY(-3px); }
.footer-col h4 { color: var(--branco); font-size: 1.1rem; margin-bottom: 1.8rem; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; }
.footer-col ul li { margin-bottom: 1rem; font-size: 1rem; }
.footer-col ul a { position: relative; transition: all 0.3s; }
.footer-col ul a:hover { color: var(--amarelo); padding-left: 5px; }
.contact-list li { display: flex; gap: 1.2rem; margin-bottom: 1.5rem; align-items: flex-start; font-size: 1rem; }
.contact-list i { color: var(--amarelo); margin-top: 5px; font-size: 1.2rem; }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.footer-bottom-links { display: flex; gap: 1.5rem; }
.footer-bottom-links a:hover { color: var(--branco); }

/* SINGLE IMÓVEL */
.single-imovel-hero { position: relative; height: 60vh; min-height: 420px; background-size: cover; background-position: center; background-color: var(--preto); }
.single-imovel-hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(10,25,47,0.95) 0%, rgba(10,25,47,0.2) 100%); }
.single-imovel-hero .hero-info { position: absolute; bottom: 0; left: 0; width: 100%; padding: 4rem 5%; z-index: 5; color: var(--branco); }
.single-imovel-hero .hero-info .badge-status { position: static; display: inline-block; margin-bottom: 1rem; }
.single-imovel-hero h1 { font-size: 3rem; font-weight: 800; line-height: 1.1; margin-bottom: 1rem; }
.single-imovel-hero .loc { display: flex; align-items: center; gap: 0.5rem; font-size: 1.1rem; color: #E2E8F0; }
.single-imovel-hero .loc i { color: var(--amarelo); }
.imovel-layout { display: grid; grid-template-columns: 2fr 1fr; gap: 3rem; max-width: 1200px; margin: 0 auto; padding: 5rem 5%; }
.imovel-main h2 { font-size: 1.8rem; color: var(--azul-marinho); margin-bottom: 1.5rem; font-weight: 800; }
.imovel-desc { color: var(--cinza-escuro); margin-bottom: 3rem; line-height: 1.9; }
.imovel-specs { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 1.2rem; margin-bottom: 3rem; }
.spec-item { background: var(--cinza-claro); padding: 1.5rem; border-radius: var(--radius-md); text-align: center; }
.spec-item i { font-size: 1.5rem; color: var(--azul-royal); margin-bottom: 0.6rem; display: block; }
.spec-item .val { font-size: 1.3rem; font-weight: 800; color: var(--azul-marinho); }
.spec-item .lbl { font-size: 0.8rem; color: var(--cinza-texto); text-transform: uppercase; letter-spacing: 0.5px; font-weight: 600; }
.imovel-gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; margin-bottom: 3rem; }
.imovel-gallery img { width: 100%; height: 200px; object-fit: cover; border-radius: var(--radius-md); cursor: pointer; transition: 0.3s; }
.imovel-gallery img:hover { transform: scale(1.03); }
.amenities-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; margin-bottom: 3rem; }
.amenities-list li { display: flex; align-items: center; gap: 0.8rem; font-weight: 500; color: var(--cinza-escuro); }
.amenities-list li i { color: var(--azul-royal); }
.imovel-sidebar { position: sticky; top: 120px; align-self: start; }
.price-box { background: var(--azul-marinho); color: var(--branco); padding: 2.5rem 2rem; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
.price-box .price-label { font-size: 0.9rem; color: var(--amarelo); text-transform: uppercase; letter-spacing: 1px; font-weight: 700; margin-bottom: 0.5rem; }
.price-box .price-value { font-size: 2.4rem; font-weight: 800; margin-bottom: 1.5rem; }
.price-box .price-value span { font-size: 1rem; color: #CBD5E0; font-weight: 500; }
.price-box .btn-cta { width: 100%; padding: 1.1rem; background: var(--amarelo); color: var(--preto); border-radius: var(--radius-md); font-weight: 800; text-align: center; display: flex; align-items: center; justify-content: center; gap: 0.6rem; margin-bottom: 1rem; transition: 0.3s; }
.price-box .btn-cta:hover { background: #f0cb00; transform: translateY(-2px); }
.price-box .btn-cta.outline { background: transparent; color: var(--branco); border: 2px solid rgba(255,255,255,0.2); }
.price-box .btn-cta.outline:hover { background: rgba(255,255,255,0.1); }
.ref-code { text-align: center; margin-top: 1.5rem; font-size: 0.85rem; color: #94A3B8; }

/* ARCHIVE */
.archive-header { background: var(--azul-marinho); color: var(--branco); padding: 5rem 5% 4rem; text-align: center; }
.archive-header h1 { font-size: 3rem; font-weight: 800; margin-bottom: 1rem; }
.archive-header p { color: #CBD5E0; font-weight: 300; max-width: 600px; margin: 0 auto; }
.archive-grid { padding: 5rem 5%; }
.no-results { text-align: center; padding: 5rem 5%; color: var(--cinza-texto); font-size: 1.2rem; }
.pagination { display: flex; justify-content: center; gap: 0.5rem; margin-top: 4rem; }
.pagination .page-numbers { padding: 0.7rem 1.2rem; border: 1px solid var(--cinza-borda); border-radius: var(--radius-md); color: var(--azul-marinho); font-weight: 600; }
.pagination .page-numbers.current, .pagination .page-numbers:hover { background: var(--azul-royal); color: var(--branco); border-color: var(--azul-royal); }

/* ANUNCIE FORM */
.anuncie-field { display: flex; flex-direction: column; }
.anuncie-field label { font-size: 0.85rem; font-weight: 700; color: var(--cinza-escuro); margin-bottom: 0.6rem; }
.anuncie-field input, .anuncie-field select, .anuncie-field textarea { width: 100%; padding: 1rem 1.1rem; border: 1px solid var(--cinza-borda); border-radius: var(--radius-md); font-size: 1rem; color: var(--azul-marinho); font-family: inherit; transition: all 0.3s; background: var(--branco); }
.anuncie-field input:focus, .anuncie-field select:focus, .anuncie-field textarea:focus { border-color: var(--azul-royal); box-shadow: 0 0 0 3px rgba(65,105,225,0.15); outline: none; }
.anuncie-field textarea { resize: vertical; }

/* WP CORE */
.alignleft { float: left; margin-right: 1.5rem; }
.alignright { float: right; margin-left: 1.5rem; }
.aligncenter { display: block; margin: 0 auto; }
.wp-caption { max-width: 100%; }
.screen-reader-text { position: absolute; clip: rect(1px,1px,1px,1px); width: 1px; height: 1px; overflow: hidden; }

/* RESPONSIVO */
@media (max-width: 1024px) {
    .filter-body { grid-template-columns: 1fr; }
    .sobre { grid-template-columns: 1fr; margin: 0; border-radius: 0; }
    .sobre-img { min-height: 300px; }
    .footer-top { grid-template-columns: 1fr 1fr; gap: 3rem; }
    .imovel-layout { grid-template-columns: 1fr; }
    .imovel-sidebar { position: static; }
}
@media (max-width: 768px) {
    .top-bar { display: none; }
    .site-header nav { position: fixed; top: 0; right: -100%; width: 75%; max-width: 320px; height: 100vh; background: var(--branco); box-shadow: var(--shadow-floating); padding: 5rem 2rem; transition: right 0.4s ease; z-index: 1002; }
    .site-header nav.open { right: 0; }
    .site-header nav ul { flex-direction: column; gap: 1.5rem; align-items: flex-start; }
    .menu-toggle { display: block; }
    .header-actions { display: none; }
    .hero-content h1 { font-size: 3rem; }
    .advanced-filter { margin-top: -50px; width: 95%; }
    .filter-grid { grid-template-columns: 1fr; }
    .location-selector { justify-content: center; }
    .footer-top { grid-template-columns: 1fr; }
    .mvv-grid { grid-template-columns: 1fr; }
    .single-imovel-hero h1 { font-size: 2rem; }
    .archive-header h1 { font-size: 2rem; }
}
