/**
 * Belle Maison v4 — Compatibilidad CSS Plugins
 * Estilos para: Belle Maison PRO + Leads + Comparador
 * @version 4.1.0 — Adaptado a tema v4 (Cinzel + Josefin Sans)
 *
 * CAMBIOS v4.1.0:
 * - Fuentes: Playfair Display → Cinzel | Poppins → Josefin Sans
 * - bm-radius-lg: 8px → 16px (alineado con tema v4)
 * - bml-*: variables propias de Leads redirigidas a variables del tema
 * - WhatsApp flotante desactivado por defecto (gestión desde tema)
 */

/* ============================================================
   OVERRIDE GLOBAL — Garantizar fuentes correctas del tema v4
   en todos los plugins (por si los CSS de plugin cargan antes)
   ============================================================ */
.bmp-property-card,
.bmp-filter-form,
.bmp-search-bar-inner,
.bml-quick-form-wrap,
.bml-prop-form-wrap,
.bml-popup-overlay,
.bmc-bar,
.bmc-compare-page {
    --bm-font-titles: 'Cinzel', serif;
    --bm-font-body:   'Josefin Sans', sans-serif;
    --bm-radius-lg:   16px;
    --bm-radius-sm:   4px;
    --bm-radius:      4px;
}

/* ============================================================
   BELLE MAISON PRO — Tarjetas y Grid
   ============================================================ */
.bmp-grid { display: grid; gap: 28px; }
.bmp-grid-3 { grid-template-columns: repeat(3,1fr); }
.bmp-grid-2 { grid-template-columns: repeat(2,1fr); }
.bmp-grid-1 { grid-template-columns: 1fr; }
@media(max-width:900px){ .bmp-grid-3{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px){ .bmp-grid-3,.bmp-grid-2{ grid-template-columns:1fr; } }

.bmp-property-card {
    background: var(--bm-white);
    border-radius: var(--bm-radius-lg);
    overflow: hidden;
    box-shadow: var(--bm-shadow-sm);
    transition: var(--bm-transition);
    border: 1px solid var(--bm-gray-lighter);
}
.bmp-property-card:hover { transform: translateY(-8px); box-shadow: var(--bm-shadow-lg); }
.bmp-property-card .bmp-card-image { position:relative; overflow:hidden; height:240px; }
.bmp-property-card .bmp-card-image img { width:100%; height:100%; object-fit:cover; transition: transform .6s ease; }
.bmp-property-card:hover .bmp-card-image img { transform: scale(1.06); }
.bmp-property-card .bmp-card-body { padding: 20px; }
.bmp-property-card .bmp-card-price {
    font-family: var(--bm-font-titles);
    font-size: 1.4rem;
    color: var(--bm-gold);
    font-weight: 700;
    margin-bottom: 6px;
}
.bmp-property-card .bmp-card-title { font-family: var(--bm-font-titles); font-size: 1rem; margin-bottom: 8px; }
.bmp-property-card .bmp-card-title a { color: var(--bm-charcoal); }
.bmp-property-card .bmp-card-title a:hover { color: var(--bm-gold); }
.bmp-property-card .bmp-card-location { font-size: .82rem; color: var(--bm-gray); margin-bottom: 14px; }
.bmp-property-card .bmp-card-features {
    display: flex;
    gap: 14px;
    font-size: .8rem;
    color: var(--bm-gray);
    padding-top: 14px;
    border-top: 1px solid var(--bm-gray-lighter);
}
.bmp-property-card .bmp-card-footer {
    padding: 14px 20px;
    border-top: 1px solid var(--bm-gray-lighter);
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--bm-cream);
}

/* Badges PRO */
.bmp-badge { font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: 4px 10px; border-radius: 2px; }
.bmp-badge-venta    { background: var(--bm-gold); color: #fff; }
.bmp-badge-alquiler { background: var(--bm-charcoal); color: #fff; }
.bmp-badge-vendido  { background: #888; color: #fff; }
.bmp-badge-reservado{ background: #f39c12; color: #fff; }

/* ============================================================
   BELLE MAISON PRO — Filtros AJAX
   ============================================================ */
.bmp-filter-form,
.bmp-filter-wrap {
    background: var(--bm-white);
    border-radius: var(--bm-radius-lg);
    padding: 24px 32px;
    box-shadow: var(--bm-shadow-sm);
    margin-bottom: 32px;
    border: 1px solid var(--bm-gray-lighter);
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: flex-end;
}
.bmp-filter-form select,
.bmp-filter-form input,
.bmp-filter-wrap select,
.bmp-filter-wrap input {
    height: 44px;
    padding: 0 14px;
    border: 1.5px solid var(--bm-gray-lighter);
    border-radius: var(--bm-radius-sm);
    font-family: var(--bm-font-body);
    font-size: .875rem;
    background: var(--bm-cream);
    color: var(--bm-charcoal);
    outline: none;
    min-width: 160px;
    transition: var(--bm-transition-fast);
    appearance: none;
}
.bmp-filter-form select:focus,
.bmp-filter-form input:focus,
.bmp-filter-wrap select:focus,
.bmp-filter-wrap input:focus {
    border-color: var(--bm-gold);
    box-shadow: 0 0 0 3px rgba(201,169,110,.15);
    background: var(--bm-white);
}

.bmp-btn-gold,
.bmp-hero-search-btn {
    background: linear-gradient(135deg, var(--bm-gold), var(--bm-gold-dark));
    color: #fff;
    border: none;
    border-radius: var(--bm-radius-sm);
    font-family: var(--bm-font-body);
    font-weight: 700;
    font-size: .78rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    height: 44px;
    padding: 0 24px;
    cursor: pointer;
    transition: var(--bm-transition);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.bmp-btn-gold:hover,
.bmp-hero-search-btn:hover {
    background: var(--bm-gold-dark);
    transform: translateY(-1px);
}

.bmp-btn-outline {
    background: transparent;
    color: var(--bm-gold);
    border: 1.5px solid var(--bm-gold);
    border-radius: var(--bm-radius-sm);
    font-family: var(--bm-font-body);
    font-weight: 700;
    font-size: .78rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 12px 28px;
    cursor: pointer;
    transition: var(--bm-transition);
}
.bmp-btn-outline:hover { background: var(--bm-gold); color: #fff; }

/* ============================================================
   BELLE MAISON PRO — Mapa Leaflet
   ============================================================ */
.bmp-map-container {
    border-radius: var(--bm-radius-lg);
    overflow: hidden;
    box-shadow: var(--bm-shadow-md);
    margin-bottom: 32px;
}
.bmp-map-toggle-bar { display: flex; gap: 8px; margin-bottom: 20px; }
.bmp-view-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 18px;
    font-family: var(--bm-font-body);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    border: 1.5px solid var(--bm-gray-lighter);
    border-radius: var(--bm-radius-sm);
    background: var(--bm-white);
    color: var(--bm-gray);
    cursor: pointer;
    transition: var(--bm-transition-fast);
}
.bmp-view-btn.active { border-color: var(--bm-gold); color: var(--bm-gold); background: rgba(201,169,110,.06); }

.bmp-results-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.bmp-results-count { font-size: .82rem; color: var(--bm-gray); letter-spacing: .05em; }
.bmp-no-results { text-align: center; padding: 60px 20px; color: var(--bm-gray); }
.bmp-no-results-icon { font-size: 3rem; display: block; margin-bottom: 12px; }
.bmp-pagination { text-align: center; margin-top: 40px; }

/* ============================================================
   BELLE MAISON PRO — Favoritos
   ============================================================ */
.bmp-fav-btn {
    width: 34px;
    height: 34px;
    background: rgba(255,255,255,.92);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    cursor: pointer;
    box-shadow: var(--bm-shadow-xs);
    transition: var(--bm-transition-fast);
    font-size: 1rem;
    line-height: 1;
}
.bmp-fav-btn:hover { background: var(--bm-white); transform: scale(1.1); }

/* ============================================================
   BELLE MAISON PRO — Barra búsqueda hero [bmp_search_bar]
   ============================================================ */
.bmp-search-bar-hero { width: 100%; max-width: 820px; margin: 0 auto; }
.bmp-search-bar-inner {
    background: rgba(255,255,255,.96);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: var(--bm-radius-lg);
    padding: 20px 24px;
    box-shadow: 0 20px 60px rgba(0,0,0,.3);
    border: 1px solid rgba(255,255,255,.6);
}
.bmp-search-bar-tabs { display: flex; gap: 4px; margin-bottom: 16px; }
.bmp-tab {
    padding: 8px 20px;
    font-family: var(--bm-font-body);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    border: none;
    background: transparent;
    color: var(--bm-gray);
    cursor: pointer;
    border-radius: var(--bm-radius-sm);
    transition: var(--bm-transition-fast);
}
.bmp-tab.active { background: var(--bm-gold); color: #fff; }
.bmp-search-bar-fields {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr auto;
    gap: 12px;
    align-items: end;
}
.bmp-search-field label {
    display: block;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--bm-gray);
    margin-bottom: 6px;
}
.bmp-search-field select {
    width: 100%;
    height: 44px;
    padding: 0 14px;
    border: 1.5px solid var(--bm-gray-lighter);
    border-radius: var(--bm-radius-sm);
    font-size: .875rem;
    background: var(--bm-cream);
    color: var(--bm-charcoal);
    outline: none;
    appearance: none;
    font-family: var(--bm-font-body);
}
@media(max-width:768px) { .bmp-search-bar-fields { grid-template-columns: 1fr; } }

/* ============================================================
   BELLE MAISON LEADS — Formulario rápido [bml_quick_form]
   ============================================================ */
.bml-quick-form-wrap {
    background: var(--bm-cream);
    border-radius: var(--bm-radius-lg);
    border: 1px solid var(--bm-gray-lighter);
    padding: 36px 40px;
}
.bml-quick-form-icon { color: var(--bm-gold); margin-bottom: 12px; }
.bml-quick-form-title {
    font-family: var(--bm-font-titles);
    font-size: 1.4rem;
    color: var(--bm-charcoal);
    margin-bottom: 6px;
}
.bml-quick-form-subtitle { font-size: .875rem; color: var(--bm-gray); margin-bottom: 24px; }
.bml-quick-row { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.bml-quick-input {
    flex: 1;
    min-width: 200px;
    height: 48px;
    padding: 0 16px;
    border: 1.5px solid var(--bm-gray-lighter);
    border-radius: var(--bm-radius-md);
    font-family: var(--bm-font-body);
    font-size: .9rem;
    background: var(--bm-white);
    color: var(--bm-charcoal);
    outline: none;
    transition: var(--bm-transition-fast);
}
.bml-quick-input:focus {
    border-color: var(--bm-gold);
    box-shadow: 0 0 0 3px rgba(201,169,110,.15);
}
.bml-quick-btn {
    height: 48px;
    padding: 0 28px;
    background: linear-gradient(135deg, var(--bm-gold), var(--bm-gold-dark));
    color: #fff;
    border: none;
    border-radius: var(--bm-radius-sm);
    font-family: var(--bm-font-body);
    font-weight: 700;
    font-size: .78rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    cursor: pointer;
    transition: var(--bm-transition);
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 8px;
    box-shadow: var(--bm-shadow-gold);
}
.bml-quick-btn:hover { background: var(--bm-gold-dark); transform: translateY(-1px); }
.bml-quick-privacy { margin-top: 12px; }
.bml-quick-privacy label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: .78rem;
    color: var(--bm-gray);
    cursor: pointer;
}
.bml-quick-privacy input[type=checkbox] { accent-color: var(--bm-gold); margin-top: 2px; }
.bml-quick-privacy a { color: var(--bm-gold); }
.bml-quick-feedback {
    margin-top: 12px;
    padding: 10px 14px;
    border-radius: var(--bm-radius-sm);
    font-size: .82rem;
}

/* ============================================================
   BELLE MAISON LEADS — Formulario de propiedad [bml_property_form]
   ============================================================ */
.bml-prop-form-wrap { padding: 28px; }
.bml-prop-form-title { font-family: var(--bm-font-titles); font-size: 1.2rem; margin-bottom: 20px; }
.bml-field-group { margin-bottom: 16px; }
.bml-field-group label {
    display: block;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--bm-gray);
    margin-bottom: 6px;
}
.bml-field {
    width: 100%;
    padding: 12px 16px;
    border: 1.5px solid var(--bm-gray-lighter);
    border-radius: var(--bm-radius-md);
    font-family: var(--bm-font-body);
    font-size: .9rem;
    background: var(--bm-cream);
    color: var(--bm-charcoal);
    outline: none;
    transition: var(--bm-transition-fast);
}
.bml-field:focus {
    border-color: var(--bm-gold);
    background: var(--bm-white);
    box-shadow: 0 0 0 3px rgba(201,169,110,.15);
}
textarea.bml-field { resize: vertical; min-height: 100px; }
.bml-form-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media(max-width:600px){ .bml-form-two-col { grid-template-columns: 1fr; } }
.bml-field-privacy label,
.bml-checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: .78rem;
    color: var(--bm-gray);
    cursor: pointer;
}
.bml-checkbox-label input { accent-color: var(--bm-gold); margin-top: 3px; }
.bml-prop-submit,
.bml-btn-gold {
    width: 100%;
    padding: 14px 24px;
    margin-top: 4px;
    background: linear-gradient(135deg, var(--bm-gold), var(--bm-gold-dark));
    color: #fff;
    border: none;
    border-radius: var(--bm-radius-sm);
    font-family: var(--bm-font-body);
    font-weight: 700;
    font-size: .78rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: var(--bm-transition);
}
.bml-prop-submit:hover,
.bml-btn-gold:hover { background: var(--bm-gold-dark); transform: translateY(-1px); }
.bml-wa-btn-inline {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 13px 20px;
    margin-bottom: 16px;
    background: #25D366;
    color: #fff;
    border-radius: var(--bm-radius-sm);
    font-family: var(--bm-font-body);
    font-weight: 700;
    font-size: .82rem;
    text-decoration: none;
    transition: var(--bm-transition-fast);
}
.bml-wa-btn-inline:hover { background: #1EBF5A; color: #fff; transform: translateY(-1px); }
.bml-or-divider { display: flex; align-items: center; gap: 12px; margin: 0 0 20px; }
.bml-or-divider::before,
.bml-or-divider::after { content: ''; flex: 1; height: 1px; background: var(--bm-gray-lighter); }
.bml-or-divider span { font-size: .72rem; color: var(--bm-gray-light); letter-spacing: .1em; text-transform: uppercase; }
.bml-form-feedback { padding: 10px 14px; border-radius: var(--bm-radius-sm); font-size: .82rem; margin-top: 8px; }
.bml-spin { animation: bm-plugin-spin .7s linear infinite; }
@keyframes bm-plugin-spin { to { transform: rotate(360deg); } }

/* ============================================================
   BELLE MAISON LEADS — WhatsApp flotante DESACTIVADO
   ============================================================ */
.bml-wa-float,
#bml-wa-float { display: none !important; }

/* ============================================================
   BELLE MAISON COMPARADOR — Botón añadir
   ============================================================ */
.bmc-add-btn {
    font-family: var(--bm-font-body);
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--bm-gold);
    border: 1.5px solid var(--bm-gold);
    border-radius: var(--bm-radius-sm);
    background: rgba(255,255,255,.92);
    padding: 5px 12px;
    cursor: pointer;
    transition: var(--bm-transition-fast);
}
.bmc-add-btn:hover,
.bmc-add-btn.bmc-active {
    background: var(--bm-gold);
    color: #fff;
}

/* ============================================================
   BELLE MAISON COMPARADOR — Barra inferior
   ============================================================ */
.bmc-compare-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 400;
    background: var(--bm-charcoal);
    border-top: 2px solid var(--bm-gold);
    padding: 12px 32px;
    display: flex;
    align-items: center;
    gap: 20px;
    box-shadow: 0 -4px 24px rgba(0,0,0,.3);
    font-family: var(--bm-font-body);
}
.bmc-compare-bar-items { display: flex; gap: 16px; flex: 1; }
.bmc-compare-bar-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 16px;
    background: rgba(255,255,255,.06);
    border-radius: var(--bm-radius-sm);
}
.bmc-compare-bar-title {
    font-size: .82rem;
    font-weight: 600;
    color: #fff;
    font-family: var(--bm-font-titles);
}
.bmc-compare-bar-price { font-size: .75rem; color: var(--bm-gold); font-weight: 700; }
.bmc-compare-btn {
    background: linear-gradient(135deg, var(--bm-gold), var(--bm-gold-dark));
    color: #fff;
    border: none;
    border-radius: var(--bm-radius-sm);
    font-family: var(--bm-font-body);
    font-weight: 700;
    font-size: .75rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 10px 24px;
    cursor: pointer;
    transition: var(--bm-transition);
    white-space: nowrap;
}
.bmc-compare-btn:hover { background: var(--bm-gold-dark); }
.bmc-remove-btn {
    background: none;
    border: none;
    color: rgba(255,255,255,.4);
    font-size: 1rem;
    cursor: pointer;
    padding: 4px;
    transition: var(--bm-transition-fast);
}
.bmc-remove-btn:hover { color: #e74c3c; }

/* ============================================================
   BELLE MAISON COMPARADOR — Tabla comparativa
   ============================================================ */
.bmc-compare-table { width: 100%; border-collapse: collapse; font-family: var(--bm-font-body); }
.bmc-compare-table th {
    background: var(--bm-charcoal);
    color: var(--bm-gold);
    font-family: var(--bm-font-titles);
    padding: 16px 20px;
    font-size: 1rem;
    text-align: left;
}
.bmc-compare-table td {
    padding: 12px 20px;
    border-bottom: 1px solid var(--bm-gray-lighter);
    font-size: .875rem;
}
.bmc-compare-table tr:hover td { background: var(--bm-cream); }
.bmc-compare-price {
    font-family: var(--bm-font-titles);
    font-size: 1.3rem;
    color: var(--bm-gold);
    font-weight: 700;
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
    .bml-spin { animation: none; }
}
