/* =========================================
   VITRINEUDI IMOBILIÁRIAS - CSS PREMIUM v2.0
   ========================================= */

:root{
    --vudi-primary:#f97316;
    --vudi-primary-dark:#ea580c;
    --vudi-secondary:#8b5cf6;
    --vudi-success:#10b981;
    --vudi-danger:#ef4444;
    --vudi-warning:#f59e0b;
    --vudi-dark:#1e293b;
    --vudi-gray:#64748b;
    --vudi-light:#f8fafc;
    --vudi-border:#e2e8f0;
    --vudi-radius:16px;
    --vudi-shadow:0 4px 20px rgba(0,0,0,.08);
    --vudi-shadow-lg:0 20px 60px rgba(0,0,0,.15);
}

.vudi-container{max-width:1280px;margin:0 auto;padding:0 20px;}

/* === HERO ARCHIVE === */
.vudi-hero{
    background:linear-gradient(135deg,#f97316 0%,#ea580c 50%,#8b5cf6 100%);
    padding:60px 20px;color:#fff;text-align:center;border-radius:0 0 var(--vudi-radius) var(--vudi-radius);margin-bottom:30px;position:relative;overflow:hidden;
}
.vudi-hero::before{content:'';position:absolute;inset:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><circle cx="20" cy="20" r="2" fill="white" opacity="0.1"/><circle cx="80" cy="50" r="3" fill="white" opacity="0.1"/><circle cx="40" cy="80" r="2" fill="white" opacity="0.1"/></svg>');opacity:.3;}
.vudi-hero h1{font-size:42px;font-weight:800;margin:0 0 10px;position:relative;z-index:1;}
.vudi-hero p{font-size:18px;opacity:.95;position:relative;z-index:1;}
.vudi-hero-stats{display:flex;gap:30px;justify-content:center;margin-top:25px;flex-wrap:wrap;position:relative;z-index:1;}
.vudi-hero-stat{background:rgba(255,255,255,.15);backdrop-filter:blur(10px);padding:12px 24px;border-radius:50px;font-weight:600;}

/* === FILTROS === */
.vudi-filtros{background:#fff;border-radius:var(--vudi-radius);padding:20px;box-shadow:var(--vudi-shadow);margin-bottom:30px;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;align-items:end;}
.vudi-filtro label{display:block;font-size:12px;font-weight:600;color:var(--vudi-gray);text-transform:uppercase;margin-bottom:6px;}
.vudi-filtro select,.vudi-filtro input{width:100%;padding:11px 14px;border:2px solid var(--vudi-border);border-radius:10px;font-size:14px;transition:.2s;background:#fff;}
.vudi-filtro select:focus,.vudi-filtro input:focus{border-color:var(--vudi-primary);outline:none;box-shadow:0 0 0 3px rgba(249,115,22,.1);}
.vudi-btn-filtrar{background:linear-gradient(135deg,var(--vudi-primary),var(--vudi-primary-dark));color:#fff;border:none;padding:12px 24px;border-radius:10px;font-weight:700;cursor:pointer;font-size:14px;transition:.2s;}
.vudi-btn-filtrar:hover{transform:translateY(-2px);box-shadow:0 10px 25px rgba(249,115,22,.4);}

/* === GRID DE IMÓVEIS === */
.vudi-grid-imoveis{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;margin-bottom:40px;}

/* === CARD IMÓVEL === */
.vudi-card{background:#fff;border-radius:var(--vudi-radius);overflow:hidden;box-shadow:var(--vudi-shadow);transition:.3s cubic-bezier(.4,0,.2,1);position:relative;}
.vudi-card:hover{transform:translateY(-6px);box-shadow:var(--vudi-shadow-lg);}
.vudi-card-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:#f1f5f9;}
.vudi-card-img img{width:100%;height:100%;object-fit:cover;transition:.5s;}
.vudi-card:hover .vudi-card-img img{transform:scale(1.08);}
.vudi-card-badges{position:absolute;top:12px;left:12px;display:flex;gap:6px;flex-wrap:wrap;z-index:2;}
.vudi-badge{padding:5px 12px;border-radius:50px;font-size:11px;font-weight:700;text-transform:uppercase;color:#fff;backdrop-filter:blur(10px);}
.vudi-badge-venda{background:rgba(16,185,129,.95);}
.vudi-badge-aluguel{background:rgba(59,130,246,.95);}
.vudi-badge-lancamento{background:rgba(249,115,22,.95);}
.vudi-badge-destaque{background:rgba(245,158,11,.95);}
.vudi-badge-premium{background:linear-gradient(135deg,#fbbf24,#f59e0b);}
.vudi-card-fav{position:absolute;top:12px;right:12px;width:38px;height:38px;background:rgba(255,255,255,.95);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s;border:none;font-size:18px;z-index:2;backdrop-filter:blur(10px);}
.vudi-card-fav:hover{transform:scale(1.15);background:#fff;}
.vudi-card-fav.ativo{background:#fee2e2;color:#ef4444;}
.vudi-card-body{padding:18px;}
.vudi-card-preco{font-size:24px;font-weight:800;color:var(--vudi-dark);margin-bottom:4px;line-height:1.2;}
.vudi-card-condominio{font-size:12px;color:var(--vudi-gray);margin-bottom:10px;}
.vudi-card-titulo{font-size:16px;font-weight:600;color:var(--vudi-dark);margin-bottom:8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:44px;}
.vudi-card-titulo a{color:inherit;text-decoration:none;}
.vudi-card-titulo a:hover{color:var(--vudi-primary);}
.vudi-card-local{font-size:13px;color:var(--vudi-gray);margin-bottom:12px;display:flex;align-items:center;gap:5px;}
.vudi-card-infos{display:flex;gap:12px;padding-top:12px;border-top:1px solid var(--vudi-border);flex-wrap:wrap;}
.vudi-info-item{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--vudi-gray);font-weight:500;}
.vudi-info-item strong{color:var(--vudi-dark);}

/* === SINGLE IMÓVEL === */
.vudi-single{max-width:1280px;margin:30px auto;padding:0 20px;}
.vudi-single-galeria{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:repeat(2,250px);gap:8px;border-radius:var(--vudi-radius);overflow:hidden;margin-bottom:30px;}
.vudi-galeria-item{position:relative;cursor:pointer;overflow:hidden;background:#f1f5f9;}
.vudi-galeria-item:first-child{grid-row:span 2;}
.vudi-galeria-item img{width:100%;height:100%;object-fit:cover;transition:.4s;}
.vudi-galeria-item:hover img{transform:scale(1.05);}
.vudi-galeria-mais{position:absolute;inset:0;background:rgba(0,0,0,.6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;}

.vudi-single-layout{display:grid;grid-template-columns:1fr 380px;gap:30px;}
.vudi-single-main h1{font-size:32px;font-weight:800;margin:0 0 10px;color:var(--vudi-dark);}
.vudi-single-local{font-size:16px;color:var(--vudi-gray);margin-bottom:20px;}
.vudi-single-preco-box{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;padding:24px;border-radius:var(--vudi-radius);margin-bottom:24px;}
.vudi-single-preco{font-size:36px;font-weight:800;}
.vudi-single-preco small{font-size:14px;opacity:.85;}

.vudi-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:15px;background:#fff;padding:24px;border-radius:var(--vudi-radius);box-shadow:var(--vudi-shadow);margin-bottom:24px;}
.vudi-feature{text-align:center;padding:12px;}
.vudi-feature-icon{font-size:28px;margin-bottom:6px;}
.vudi-feature-num{font-size:22px;font-weight:800;color:var(--vudi-dark);}
.vudi-feature-label{font-size:12px;color:var(--vudi-gray);text-transform:uppercase;}

.vudi-section{background:#fff;padding:28px;border-radius:var(--vudi-radius);box-shadow:var(--vudi-shadow);margin-bottom:24px;}
.vudi-section h2{font-size:22px;font-weight:700;margin:0 0 16px;color:var(--vudi-dark);}
.vudi-section p{color:#475569;line-height:1.7;}

.vudi-carac-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;list-style:none;padding:0;margin:0;}
.vudi-carac-list li{padding:10px 14px;background:#f8fafc;border-radius:10px;font-size:14px;color:#334155;display:flex;align-items:center;gap:8px;}

/* === SIDEBAR CONTATO === */
.vudi-sidebar{position:sticky;top:20px;align-self:start;}
.vudi-contato-box{background:#fff;border-radius:var(--vudi-radius);padding:24px;box-shadow:var(--vudi-shadow-lg);border:2px solid var(--vudi-border);}
.vudi-contato-imob{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--vudi-border);margin-bottom:16px;}
.vudi-contato-imob img{width:60px;height:60px;border-radius:12px;object-fit:cover;}
.vudi-contato-imob-info h4{margin:0;font-size:15px;color:var(--vudi-dark);}
.vudi-contato-imob-info small{color:var(--vudi-gray);font-size:12px;}
.vudi-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:12px;font-weight:700;text-decoration:none;transition:.2s;border:none;cursor:pointer;font-size:15px;width:100%;margin-bottom:10px;}
.vudi-btn-wpp{background:#25d366;color:#fff;}
.vudi-btn-wpp:hover{background:#1ea952;transform:translateY(-2px);color:#fff;}
.vudi-btn-tel{background:#fff;color:var(--vudi-dark);border:2px solid var(--vudi-border);}
.vudi-btn-tel:hover{background:#f8fafc;border-color:var(--vudi-primary);}
.vudi-btn-form{background:linear-gradient(135deg,var(--vudi-primary),var(--vudi-primary-dark));color:#fff;}
.vudi-btn-form:hover{transform:translateY(-2px);box-shadow:0 10px 25px rgba(249,115,22,.4);color:#fff;}

.vudi-form-contato{margin-top:14px;}
.vudi-form-contato input,.vudi-form-contato textarea{width:100%;padding:11px;border:2px solid var(--vudi-border);border-radius:10px;font-size:14px;margin-bottom:10px;font-family:inherit;box-sizing:border-box;}
.vudi-form-contato input:focus,.vudi-form-contato textarea:focus{border-color:var(--vudi-primary);outline:none;}

/* === IMOBILIÁRIAS GRID === */
.vudi-grid-imobs{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;}
.vudi-card-imob{background:#fff;border-radius:var(--vudi-radius);overflow:hidden;box-shadow:var(--vudi-shadow);transition:.3s;text-align:center;padding:30px 20px;}
.vudi-card-imob:hover{transform:translateY(-6px);box-shadow:var(--vudi-shadow-lg);}
.vudi-card-imob-logo{width:120px;height:120px;border-radius:50%;object-fit:cover;margin:0 auto 16px;border:4px solid #fff;box-shadow:0 4px 20px rgba(0,0,0,.1);}
.vudi-card-imob h3{font-size:18px;margin:0 0 8px;color:var(--vudi-dark);}
.vudi-card-imob h3 a{color:inherit;text-decoration:none;}
.vudi-card-imob-cidade{font-size:13px;color:var(--vudi-gray);margin-bottom:10px;}
.vudi-card-imob-count{display:inline-block;background:#f1f5f9;color:var(--vudi-dark);padding:6px 14px;border-radius:50px;font-size:12px;font-weight:600;margin-top:8px;}

/* === SINGLE IMOBILIÁRIA === */
.vudi-imob-hero{background:linear-gradient(135deg,#8b5cf6,#6366f1);padding:60px 20px;color:#fff;border-radius:var(--vudi-radius);margin-bottom:30px;position:relative;overflow:hidden;}
.vudi-imob-hero-content{display:flex;align-items:center;gap:30px;max-width:1280px;margin:0 auto;position:relative;z-index:2;}
.vudi-imob-logo{width:140px;height:140px;border-radius:20px;object-fit:cover;border:5px solid #fff;box-shadow:0 10px 40px rgba(0,0,0,.2);background:#fff;}
.vudi-imob-info h1{font-size:36px;margin:0 0 10px;font-weight:800;}
.vudi-imob-meta{display:flex;gap:20px;flex-wrap:wrap;font-size:14px;opacity:.95;}

/* === RESPONSIVO === */
@media(max-width:900px){
    .vudi-single-layout{grid-template-columns:1fr;}
    .vudi-sidebar{position:static;}
    .vudi-single-galeria{grid-template-columns:1fr 1fr;grid-template-rows:200px 200px;}
    .vudi-single-galeria .vudi-galeria-item:first-child{grid-column:span 2;grid-row:auto;}
    .vudi-hero h1{font-size:30px;}
    .vudi-imob-hero-content{flex-direction:column;text-align:center;}
}
@media(max-width:600px){
    .vudi-grid-imoveis{grid-template-columns:1fr;}
    .vudi-hero{padding:40px 15px;}
    .vudi-hero h1{font-size:24px;}
    .vudi-single-main h1{font-size:24px;}
    .vudi-single-preco{font-size:28px;}
}

/* === ANIMAÇÕES === */
@keyframes vudiPulse{0%,100%{opacity:1}50%{opacity:.5}}
.vudi-loading{animation:vudiPulse 1.5s ease-in-out infinite;}

/* === VÍDEO RESPONSIVO === */
.vudi-video-wrapper{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:12px;background:#000;}
.vudi-video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0;}

/* === MAPA === */
.vudi-mapa{width:100%;height:400px;border-radius:12px;overflow:hidden;background:#e2e8f0;border:2px solid #e2e8f0;}
.vudi-mapa iframe{width:100%;height:100%;border:0;}

@media(max-width:600px){
    .vudi-mapa{height:300px;}
}