/* ============================================================
 *  De la Rocha · Web pública
 *  Aplica paleta y refinamientos sobre el template original.
 * ============================================================ */

:root {
    --dlr-primary:    #151826;
    --dlr-primary-2:  #0d0f1a;
    --dlr-accent:     #E25858;
    --dlr-accent-2:   #d34141;
    --dlr-text:       #1a1a1a;
    --dlr-muted:      #6b7280;
    --dlr-light:      #f7f7f9;
    --dlr-border:     #e6e8ee;
}

/* ============================================================
 *  Reset overflow + tipografía
 * ============================================================ */
html, body { max-width: 100%; overflow-x: hidden; }
body { font-family: 'Raleway', system-ui, -apple-system, "Segoe UI", sans-serif; color: var(--dlr-text); }
.row { margin-left: 0; margin-right: 0; }
.row > [class*="col-"] { padding-left: 12px; padding-right: 12px; }
.container, .container-fluid { max-width: 1320px; }
img { max-width: 100%; height: auto; }

/* ============================================================
 *  Esconder restos del template original
 * ============================================================ */
header.main-header,
footer.footer:not(.dlr-footer),
.sub-footer,
#full-page-search,
.scroll-area .top-wrap { display: none !important; }

/* ============================================================
 *  Botones (theme = rojo Delarocha)
 * ============================================================ */
.btn.button-theme,
.btn-md.button-theme,
.btn-sm.button-theme,
.button-theme {
    background-color: var(--dlr-accent) !important;
    border-color: var(--dlr-accent) !important;
    color: #fff !important;
    border-radius: 999px !important;
    padding: 11px 26px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: .5px;
    transition: all .2s ease;
    box-shadow: 0 4px 12px rgba(226,88,88,.25);
    border: 0;
}
.btn.button-theme:hover,
.btn-md.button-theme:hover,
.button-theme:hover {
    background-color: var(--dlr-accent-2) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(226,88,88,.35);
    color: #fff !important;
}

/* ============================================================
 *  Cards de inmuebles
 * ============================================================ */
.property-box,
.featured-properties .property-box,
.properties-list .property-box {
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(21,24,38,.05);
    border: 1px solid var(--dlr-border);
    overflow: hidden;
    transition: transform .25s ease, box-shadow .25s ease;
    background: #fff;
    margin-bottom: 24px;
}
.property-box:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 30px rgba(21, 24, 38, 0.12);
}
.property-box .property-thumbnail {
    position: relative;
}
/* Reset agresivo del listing-badges (el template original usaba "cinta diagonal" rotada) */
.property-box .listing-badges,
.property-thumbnail .listing-badges,
.listing-badges {
    display: flex !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
    position: absolute !important;
    top: 12px !important;
    left: 12px !important;
    right: auto !important;
    bottom: auto !important;
    width: auto !important;
    z-index: 5 !important;
    transform: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
}
.property-box .listing-badges .featured,
.property-box .listing-badges span,
.property-thumbnail .listing-badges .featured,
.property-thumbnail .listing-badges span,
.listing-badges .featured,
.listing-badges span {
    background: var(--dlr-accent) !important;
    color: #fff !important;
    border-radius: 999px !important;
    padding: 4px 12px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
    /* Desactivar el "cinta rotada" del template original */
    float: none !important;
    transform: none !important;
    rotate: 0 !important;
    left: auto !important;
    top: auto !important;
    position: static !important;
    width: auto !important;
    height: auto !important;
    text-align: center !important;
    line-height: 1.4 !important;
    margin: 0 !important;
    box-shadow: 0 2px 6px rgba(0,0,0,.15);
    display: inline-flex !important;
    align-items: center;
    gap: 4px;
}
.property-box .listing-badges .students,
.listing-badges .students {
    background: linear-gradient(135deg, #0ea5e9, #0284c7) !important;
    color: #fff !important;
}

/* También el price-box que tiene posición rara con margins/padding del template */
.property-box .price-box,
.property-thumbnail .price-box {
    position: absolute !important;
    bottom: 12px !important;
    left: 12px !important;
    right: auto !important;
    background: rgba(21,24,38,.85) !important;
    color: #fff !important;
    padding: 8px 14px !important;
    border-radius: 8px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    z-index: 5 !important;
    backdrop-filter: blur(6px);
    line-height: 1.2 !important;
}
.property-box .price-box span,
.property-thumbnail .price-box span {
    color: #fff !important;
    font-weight: 800 !important;
    font-size: 16px !important;
}

/* El ::before del .property-thumbnail (overlay verde del template) → quitarlo */
.property-thumbnail::before {
    display: none !important;
}
.property-box .price-box,
.property-box .price-ratings-box .price h3,
.property-box .property-overview .price h3,
.property-box .price h3,
.price h3 {
    color: var(--dlr-primary) !important;
    font-weight: 800;
}

.property-box .detail h1.title,
.property-box .detail .title,
.featured-properties h1.title {
    font-size: 16px !important;
    font-weight: 700 !important;
    margin: 0 0 6px !important;
    line-height: 1.35 !important;
}
.property-box .detail .title a { color: var(--dlr-text); text-decoration: none; }
.property-box .detail .title a:hover { color: var(--dlr-accent); }

.facilities-list {
    display: flex !important;
    gap: 16px !important;
    border-top: 1px solid var(--dlr-border) !important;
    padding: 14px 18px !important;
    background: var(--dlr-light);
    list-style: none;
    margin: 0;
}
.facilities-list li {
    flex: 1;
    text-align: center;
    color: var(--dlr-text);
    font-size: 13px;
    font-weight: 600;
}
.facilities-list li span {
    display: block;
    font-size: 10px;
    text-transform: uppercase;
    color: var(--dlr-muted);
    letter-spacing: .5px;
    margin-bottom: 2px;
    font-weight: 500;
}

/* ============================================================
 *  Forms
 * ============================================================ */
.form-control:focus,
input[type=text]:focus, input[type=email]:focus, input[type=password]:focus,
input[type=number]:focus, input[type=tel]:focus, textarea:focus, select:focus {
    border-color: var(--dlr-accent);
    box-shadow: 0 0 0 3px rgba(226, 88, 88, 0.12);
    outline: none;
}

/* ============================================================
 *  Hero / banner / sub-banner
 * ============================================================ */
.banner-area::before,
.banner::before,
.page-banner-area::before {
    background-color: var(--dlr-primary) !important;
    opacity: 0.55 !important;
}
.breadcrumb-area, .page-banner-area, .sub-banner {
    background-color: var(--dlr-primary) !important;
}
.sub-banner {
    background-image: linear-gradient(135deg, #151826 0%, #0d0f1a 100%) !important;
    padding: 48px 0 32px !important;
}

/* Acentos en titulares */
.section-title h2 span,
.section-title h2 strong,
h2.heading span,
.heading-2 strong, .heading-2 span,
.featured-properties .price-ratings-box span,
.theme-color { color: var(--dlr-accent) !important; }

/* Links genéricos */
a { color: var(--dlr-primary); }
a:hover { color: var(--dlr-accent); }

/* ============================================================
 *  Properties section body / search
 * ============================================================ */
.properties-section-body {
    padding: 40px 0;
}
.option-bar {
    background: #fff;
    border: 1px solid var(--dlr-border);
    border-radius: 10px;
    padding: 14px 20px;
    margin-bottom: 24px;
    box-shadow: 0 2px 6px rgba(21,24,38,.04);
}

/* ============================================================
 *  Esconder bloques antiguos del template ("featured-properties",
 *  "services", "counters" originales). Sus reemplazos están en
 *  .dlr-section-* más abajo.
 * ============================================================ */
.featured-properties.content-area,
.services.content-area,
body > .counters,
.counters.adaptareaMobile,
div.counters > .container { /* el counters viejo */ }
/* Realmente ocultamos los originales sólo si están vacíos / no hemos puesto nada */
body > div.featured-properties,
body > div.services.bg-grea-3,
body > div.counters {
    display: none !important;
}

/* ============================================================
 *  Home: secciones (.dlr-section-*)
 * ============================================================ */
.dlr-section {
    padding: 70px 0;
    background: #fff;
}
.dlr-section-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 20px;
}
.dlr-section-head {
    text-align: center;
    margin-bottom: 44px;
}
.dlr-section-eyebrow {
    display: inline-block;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--dlr-accent);
    margin-bottom: 12px;
    padding: 4px 14px;
    background: rgba(226,88,88,.08);
    border-radius: 999px;
}
.dlr-section-eyebrow.dlr-eyebrow-light {
    color: #fff;
    background: rgba(255,255,255,.10);
}
.dlr-section-title {
    font-size: 36px;
    font-weight: 800;
    color: var(--dlr-text);
    margin: 0 0 12px;
    line-height: 1.15;
    letter-spacing: -0.5px;
}
.dlr-section-title.dlr-title-light { color: #fff; }
.dlr-section-sub {
    font-size: 16px;
    color: var(--dlr-muted);
    margin: 0;
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.5;
}
.dlr-section-sub.dlr-sub-light { color: rgba(255,255,255,.85); }
.dlr-section-cta {
    text-align: center;
    margin-top: 36px;
}

/* Botones outline */
.dlr-btn-outline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 28px;
    border: 2px solid var(--dlr-primary);
    border-radius: 999px;
    color: var(--dlr-primary) !important;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: .5px;
    text-decoration: none;
    transition: all .2s;
    background: transparent;
}
.dlr-btn-outline:hover {
    background: var(--dlr-primary);
    color: #fff !important;
    transform: translateY(-1px);
}
.dlr-btn-outline-light {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    border: 2px solid rgba(255,255,255,.5);
    border-radius: 999px;
    color: #fff !important;
    font-weight: 600;
    font-size: 13px;
    text-decoration: none;
    transition: all .2s;
    background: transparent;
}
.dlr-btn-outline-light:hover {
    background: #fff;
    color: var(--dlr-primary) !important;
    border-color: #fff;
}

/* ============================================================
 *  Featured: cards de viviendas en grid
 * ============================================================ */
.dlr-section-featured { background: var(--dlr-light); }
.dlr-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.dlr-prop-card {
    background: #fff;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 4px 14px rgba(21,24,38,.06);
    border: 1px solid var(--dlr-border);
    text-decoration: none !important;
    color: var(--dlr-text);
    display: flex;
    flex-direction: column;
    transition: all .25s;
}
.dlr-prop-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 36px rgba(21,24,38,.12);
    color: var(--dlr-text);
}
.dlr-prop-card-img {
    aspect-ratio: 4/3;
    background-color: #eee;
    background-size: cover;
    background-position: center;
    position: relative;
}
.dlr-prop-card-badge {
    position: absolute;
    top: 14px;
    left: 14px;
    background: var(--dlr-accent);
    color: #fff;
    padding: 5px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.dlr-prop-card-price {
    position: absolute;
    bottom: 14px;
    left: 14px;
    background: rgba(21,24,38,.92);
    color: #fff;
    padding: 8px 14px;
    border-radius: 8px;
    font-size: 17px;
    font-weight: 800;
    backdrop-filter: blur(6px);
}
.dlr-prop-card-price small { font-size: 12px; font-weight: 500; opacity: .8; }
.dlr-prop-card-body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.dlr-prop-card-title {
    font-size: 17px;
    font-weight: 700;
    margin: 0 0 6px;
    color: var(--dlr-text);
    line-height: 1.3;
}
.dlr-prop-card-loc {
    color: var(--dlr-muted);
    font-size: 13px;
    margin: 0 0 14px;
}
.dlr-prop-card-loc i { color: var(--dlr-accent); margin-right: 4px; }
.dlr-prop-card-stats {
    list-style: none;
    margin: auto 0 0;
    padding: 14px 0 0;
    border-top: 1px solid var(--dlr-border);
    display: flex;
    gap: 18px;
    flex-wrap: wrap;
    color: var(--dlr-muted);
    font-size: 13px;
}
.dlr-prop-card-stats li {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.dlr-prop-card-stats li i { color: var(--dlr-primary); }

/* ============================================================
 *  Values (¿Por qué nosotros?)
 * ============================================================ */
.dlr-section-values {
    background: linear-gradient(135deg, #151826 0%, #0d0f1a 100%);
    color: #fff;
    position: relative;
    overflow: hidden;
}
.dlr-section-values::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 80% 20%, rgba(226,88,88,.10), transparent 50%),
        radial-gradient(circle at 20% 80%, rgba(226,88,88,.08), transparent 50%);
}
.dlr-section-values .dlr-section-inner { position: relative; z-index: 1; }
.dlr-text-light * { color: #fff; }
.dlr-values-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.dlr-value-card {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
    backdrop-filter: blur(8px);
    border-radius: 14px;
    padding: 32px 26px;
    transition: all .25s;
}
.dlr-value-card:hover {
    transform: translateY(-4px);
    background: rgba(255,255,255,.07);
    border-color: var(--dlr-accent);
}
.dlr-value-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: rgba(226,88,88,.18);
    color: var(--dlr-accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    margin-bottom: 18px;
}
.dlr-value-card h3 {
    color: #fff !important;
    font-size: 20px;
    font-weight: 700;
    margin: 0 0 10px;
}
.dlr-value-card p {
    color: rgba(255,255,255,.75) !important;
    font-size: 14px;
    line-height: 1.55;
    margin: 0;
}

/* ============================================================
 *  Servicios (Notaría / Altas-bajas / Certificado / Reformas)
 * ============================================================ */
.dlr-section-services { background: #fff; }
.dlr-services-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
.dlr-service-card {
    text-align: center;
    padding: 32px 24px;
    border-radius: 14px;
    background: var(--dlr-light);
    border: 1px solid var(--dlr-border);
    transition: all .2s;
}
.dlr-service-card:hover {
    background: #fff;
    border-color: var(--dlr-accent);
    transform: translateY(-3px);
    box-shadow: 0 12px 28px rgba(21,24,38,.08);
}
.dlr-service-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 16px;
    background: linear-gradient(135deg, var(--dlr-primary), #2c2f44);
    color: var(--dlr-accent);
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
}
.dlr-service-card h4 {
    margin: 0 0 8px;
    font-size: 16px;
    font-weight: 700;
    color: var(--dlr-text);
}
.dlr-service-card p {
    color: var(--dlr-muted);
    font-size: 13px;
    margin: 0;
    line-height: 1.5;
}

/* ============================================================
 *  CTA final con teléfono
 * ============================================================ */
.dlr-section-cta {
    background: var(--dlr-light);
    padding: 50px 0;
}
.dlr-cta-box {
    background: linear-gradient(135deg, var(--dlr-accent) 0%, #d34141 100%);
    color: #fff;
    border-radius: 20px;
    padding: 48px 56px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
    flex-wrap: wrap;
    box-shadow: 0 20px 50px rgba(226,88,88,.30);
}
.dlr-cta-text { flex: 1; min-width: 280px; text-align: left; }
.dlr-cta-text .dlr-section-eyebrow { background: rgba(255,255,255,.18); color: #fff; }
.dlr-cta-title {
    color: #fff !important;
    font-size: 30px;
    font-weight: 800;
    margin: 0 0 6px;
    line-height: 1.2;
}
.dlr-cta-sub {
    color: rgba(255,255,255,.92) !important;
    font-size: 15px;
    margin: 0;
}
.dlr-cta-actions {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}
.dlr-cta-phone {
    background: #fff;
    color: var(--dlr-primary) !important;
    padding: 14px 26px;
    border-radius: 999px;
    text-decoration: none !important;
    display: inline-flex;
    align-items: center;
    gap: 14px;
    transition: all .2s;
    box-shadow: 0 8px 20px rgba(0,0,0,.15);
}
.dlr-cta-phone:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(0,0,0,.22);
    color: var(--dlr-primary) !important;
}
.dlr-cta-phone i {
    font-size: 22px;
    color: var(--dlr-accent);
}
.dlr-cta-phone span { display: flex; flex-direction: column; line-height: 1.1; }
.dlr-cta-phone small {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--dlr-muted);
    font-weight: 600;
}
.dlr-cta-phone strong {
    font-size: 20px;
    font-weight: 800;
}

/* ============================================================
 *  Mobile
 * ============================================================ */
@media (max-width: 1024px) {
    .dlr-grid, .dlr-values-grid { grid-template-columns: repeat(2, 1fr); }
    .dlr-services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .dlr-section { padding: 50px 0; }
    .dlr-section-title { font-size: 26px; }
    .dlr-grid, .dlr-values-grid, .dlr-services-grid { grid-template-columns: 1fr; }
    .dlr-cta-box { padding: 32px 24px; flex-direction: column; text-align: center; }
    .dlr-cta-text { text-align: center; }
}

/* ============================================================
 *  /search rediseñado: sidebar de filtros + grid de resultados
 * ============================================================ */
.dlr-search-banner {
    background: linear-gradient(135deg, #151826 0%, #0d0f1a 100%);
    color: #fff;
    padding: 60px 0 40px;
    margin-bottom: 32px;
}
.dlr-search-banner-inner {
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 20px;
}
.dlr-search-banner h1 {
    color: #fff;
    font-size: 32px;
    font-weight: 800;
    margin: 0 0 8px;
}
.dlr-search-banner p {
    color: rgba(255,255,255,.75);
    margin: 0;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 600;
}

.dlr-search-page { padding-bottom: 60px; }
.dlr-search-container {
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 20px;
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 28px;
    align-items: start;
}

/* Sidebar */
.dlr-filters {
    background: #fff;
    border-radius: 14px;
    border: 1px solid var(--dlr-border);
    padding: 22px;
    box-shadow: 0 2px 8px rgba(21,24,38,.04);
    position: sticky;
    top: 110px;
}
.dlr-filters-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid var(--dlr-border);
    padding-bottom: 12px;
    margin-bottom: 16px;
}
.dlr-filters-head h3 {
    margin: 0;
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--dlr-text);
}
.dlr-clear-filters {
    color: var(--dlr-muted);
    font-size: 12px;
    text-decoration: none;
    transition: color .15s;
}
.dlr-clear-filters:hover { color: var(--dlr-accent); }

.dlr-filter-group { margin-bottom: 16px; }
.dlr-filter-group > label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--dlr-muted);
    letter-spacing: .8px;
    margin-bottom: 6px;
}
.dlr-filter-group > div > label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--dlr-muted);
    letter-spacing: .8px;
    margin-bottom: 6px;
}
.dlr-filter-group select,
.dlr-filter-group input[type=text],
.dlr-filter-group input[type=number] {
    width: 100%;
    height: 40px;
    padding: 8px 12px;
    border: 1px solid var(--dlr-border);
    border-radius: 8px;
    background: var(--dlr-light);
    color: var(--dlr-text);
    font-size: 13px;
    font-family: inherit;
    transition: all .15s;
}
.dlr-filter-group select:focus,
.dlr-filter-group input:focus {
    border-color: var(--dlr-accent);
    box-shadow: 0 0 0 3px rgba(226,88,88,.12);
    outline: none;
    background: #fff;
}
.dlr-filter-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.dlr-btn-search {
    width: 100%;
    height: 44px;
    background: var(--dlr-accent);
    color: #fff;
    border: 0;
    border-radius: 999px;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 13px;
    letter-spacing: .5px;
    cursor: pointer;
    margin-top: 8px;
    box-shadow: 0 4px 12px rgba(226,88,88,.25);
    transition: all .2s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.dlr-btn-search:hover {
    background: var(--dlr-accent-2);
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(226,88,88,.35);
}

/* Resultados */
.dlr-results { min-width: 0; }
.dlr-order-bar {
    background: #fff;
    border: 1px solid var(--dlr-border);
    border-radius: 12px;
    padding: 14px 20px;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    box-shadow: 0 2px 6px rgba(21,24,38,.04);
}
.dlr-order-count {
    font-size: 13px;
    color: var(--dlr-muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.dlr-order-sort {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
}
.dlr-order-sort label { color: var(--dlr-muted); margin: 0; }
.dlr-order-sort select {
    height: 36px;
    padding: 4px 28px 4px 12px;
    border: 1px solid var(--dlr-border);
    border-radius: 8px;
    background: #fff;
    color: var(--dlr-text);
    font-size: 13px;
    cursor: pointer;
}

.dlr-empty {
    text-align: center;
    padding: 60px 20px;
    background: #fff;
    border-radius: 14px;
    border: 1px solid var(--dlr-border);
}
.dlr-empty i {
    font-size: 56px;
    color: var(--dlr-muted);
    margin-bottom: 16px;
    display: block;
}
.dlr-empty h3 {
    font-size: 18px;
    color: var(--dlr-text);
    margin: 0 0 8px;
}
.dlr-empty p { color: var(--dlr-muted); margin: 0; }
.dlr-empty a { color: var(--dlr-accent); font-weight: 600; }

/* Pagination nueva */
.dlr-pagination {
    margin: 32px 0 0;
    display: flex;
    justify-content: center;
}
.dlr-pagination .pagination {
    display: flex;
    gap: 6px;
    list-style: none;
    margin: 0;
    padding: 0;
}
.dlr-pagination .pagination li a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
    border: 1px solid var(--dlr-border);
    border-radius: 8px;
    background: #fff;
    color: var(--dlr-text);
    text-decoration: none;
    font-weight: 600;
    font-size: 13px;
    transition: all .15s;
}
.dlr-pagination .pagination li a:hover {
    border-color: var(--dlr-accent);
    color: var(--dlr-accent);
}
.dlr-pagination .pagination li a.active {
    background: var(--dlr-accent);
    border-color: var(--dlr-accent);
    color: #fff;
}

/* Mobile */
@media (max-width: 991px) {
    .dlr-search-container {
        grid-template-columns: 1fr;
    }
    .dlr-filters {
        position: static;
    }
    .dlr-search-banner { padding: 40px 0 24px; }
    .dlr-search-banner h1 { font-size: 22px; }
}
@media (max-width: 768px) {
    .dlr-order-bar { flex-direction: column; gap: 10px; align-items: stretch; }
}

/* ============================================================
 *  Ficha de inmueble (NUEVA)
 * ============================================================ */

/* Esconder restos del template viejo en la ficha */
body .properties-details-page,
body .heading-properties-3,
body .properties-description,
body .properties-amenities,
body .floor-plans,
body .dlr-property-extras,
body .sub-banner.overview-bgi,
body .sidebar-right { display: none !important; }
.dlr-prop-page { display: block !important; }

/* Banner superior con migas */
.dlr-prop-banner {
    background: linear-gradient(135deg, #151826 0%, #0d0f1a 100%) !important;
    padding: 32px 0 56px !important;
    margin: 0 !important;
    width: 100% !important;
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
}
.dlr-prop-banner::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 80% 30%, rgba(226,88,88,.08), transparent 50%),
        radial-gradient(circle at 20% 70%, rgba(226,88,88,.05), transparent 60%);
    pointer-events: none;
}
.dlr-prop-banner-inner {
    max-width: 1280px;
    margin: 0 auto !important;
    padding: 0 20px !important;
    position: relative;
    z-index: 1;
}
.dlr-breadcrumb {
    display: flex !important;
    align-items: center;
    gap: 8px;
    color: rgba(255,255,255,.55) !important;
    font-size: 13px !important;
    margin: 0 !important;
    padding: 0 !important;
    flex-wrap: wrap;
}
.dlr-breadcrumb a {
    color: rgba(255,255,255,.85) !important;
    text-decoration: none !important;
    transition: color .15s;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.dlr-breadcrumb a:hover { color: #fff !important; }
.dlr-breadcrumb i {
    font-size: 11px !important;
    color: rgba(255,255,255,.4) !important;
}
.dlr-breadcrumb span:last-child {
    color: #fff !important;
    font-weight: 600 !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 50ch;
}

/* El contenido (.dlr-prop-page) sube sobre el banner para crear el efecto de tarjeta */
.dlr-prop-page {
    background: var(--dlr-light) !important;
    padding-bottom: 80px;
    margin-top: -40px;
    position: relative;
    z-index: 2;
}
.dlr-prop-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 20px;
}
.dlr-prop-header {
    background: #fff;
    border-radius: 16px;
    padding: 28px 32px;
    box-shadow: 0 8px 30px rgba(21,24,38,.12);
    border: 1px solid var(--dlr-border);
    margin: 0 0 24px;
    position: relative;
    z-index: 2;
}

.dlr-prop-header-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}
.dlr-prop-tags {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.dlr-tag {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.dlr-tag-sale { background: #dcfce7; color: #166534; }
.dlr-tag-rent { background: #fef3c7; color: #92400e; }
.dlr-tag-students { background: linear-gradient(135deg, #e0f2fe, #bae6fd); color: #075985; }
.dlr-tag-type { background: var(--dlr-light-2, #eef0f4); color: var(--dlr-text); }

.dlr-prop-actions {
    display: flex;
    gap: 8px;
}
.dlr-action-btn {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--dlr-light);
    border: 1px solid var(--dlr-border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--dlr-text);
    cursor: pointer;
    text-decoration: none !important;
    transition: all .15s;
    font-size: 16px;
}
.dlr-action-btn:hover {
    background: var(--dlr-accent);
    color: #fff;
    border-color: var(--dlr-accent);
    transform: translateY(-1px);
}

.dlr-prop-title {
    font-size: 28px;
    font-weight: 800;
    color: var(--dlr-text);
    margin: 0 0 10px;
    line-height: 1.2;
}
.dlr-prop-meta {
    display: flex;
    gap: 18px;
    align-items: center;
    color: var(--dlr-muted);
    font-size: 14px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.dlr-prop-meta i { color: var(--dlr-accent); }
.dlr-prop-loc { display: inline-flex; align-items: center; gap: 6px; }

.dlr-prop-price-row {
    display: flex;
    align-items: baseline;
    gap: 16px;
    border-top: 1px solid var(--dlr-border);
    padding-top: 16px;
}
.dlr-prop-price-main {
    font-size: 36px;
    font-weight: 900;
    color: var(--dlr-primary);
    line-height: 1;
}
.dlr-prop-price-main small {
    font-size: 16px;
    font-weight: 600;
    color: var(--dlr-muted);
    margin-left: 2px;
}
.dlr-prop-price-sub {
    color: var(--dlr-muted);
    font-size: 14px;
    font-weight: 600;
}

/* Layout principal: 2 columnas */
.dlr-prop-layout {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 28px;
    align-items: start;
}

/* Galería */
.dlr-gallery {
    background: #fff;
    border-radius: 16px;
    padding: 16px;
    box-shadow: 0 4px 14px rgba(21,24,38,.06);
    border: 1px solid var(--dlr-border);
    margin-bottom: 24px;
}
.dlr-gallery-main {
    position: relative;
    border-radius: 12px;
    overflow: hidden;
    aspect-ratio: 16/10;
    background: #000;
    cursor: zoom-in;
}
.dlr-gallery-main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s;
}
.dlr-gallery-main:hover img { transform: scale(1.02); }
.dlr-gallery-counter {
    position: absolute;
    bottom: 14px;
    right: 14px;
    background: rgba(0,0,0,.65);
    color: #fff;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    backdrop-filter: blur(4px);
}
.dlr-gallery-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255,255,255,.95);
    border: 0;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    cursor: pointer;
    color: var(--dlr-text);
    font-size: 18px;
    box-shadow: 0 4px 12px rgba(0,0,0,.15);
    transition: all .15s;
    display: flex;
    align-items: center;
    justify-content: center;
}
.dlr-gallery-arrow:hover { background: var(--dlr-accent); color: #fff; }
.dlr-gallery-prev { left: 14px; }
.dlr-gallery-next { right: 14px; }
.dlr-gallery-thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: 8px;
    margin-top: 12px;
}
.dlr-gallery-thumb {
    aspect-ratio: 4/3;
    border-radius: 8px;
    background-size: cover;
    background-position: center;
    border: 2px solid transparent;
    cursor: pointer;
    transition: all .15s;
    padding: 0;
}
.dlr-gallery-thumb:hover { border-color: var(--dlr-accent); opacity: .9; }
.dlr-gallery-thumb.active {
    border-color: var(--dlr-accent);
    box-shadow: 0 0 0 2px rgba(226,88,88,.25);
}

/* Quick stats (m², habitaciones, etc.) */
.dlr-quick-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 12px;
    margin-bottom: 24px;
}
.dlr-quick-stat {
    background: #fff;
    padding: 18px 20px;
    border-radius: 12px;
    border: 1px solid var(--dlr-border);
    box-shadow: 0 2px 8px rgba(21,24,38,.04);
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.dlr-quick-stat i {
    font-size: 22px;
    color: var(--dlr-accent);
    margin-bottom: 4px;
}
.dlr-quick-stat strong {
    font-size: 19px;
    font-weight: 800;
    color: var(--dlr-text);
}
.dlr-quick-stat span {
    font-size: 12px;
    color: var(--dlr-muted);
    text-transform: uppercase;
    letter-spacing: .5px;
    font-weight: 600;
}

/* Card genérica */
.dlr-card {
    background: #fff;
    border-radius: 16px;
    padding: 28px;
    box-shadow: 0 2px 8px rgba(21,24,38,.04);
    border: 1px solid var(--dlr-border);
    margin-bottom: 20px;
}
.dlr-card-title {
    font-size: 19px;
    font-weight: 800;
    color: var(--dlr-text);
    margin: 0 0 18px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--dlr-light);
    position: relative;
}
.dlr-card-title::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 50px;
    height: 2px;
    background: var(--dlr-accent);
}

/* Descripción */
.dlr-prop-description {
    color: var(--dlr-text);
    font-size: 15px;
    line-height: 1.65;
    white-space: pre-wrap;
}

/* Detalles del inmueble (grid de items con icono) */
.dlr-details-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    gap: 14px;
}
.dlr-detail-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: var(--dlr-light);
    border-radius: 10px;
    border: 1px solid var(--dlr-border);
}
.dlr-detail-item i {
    font-size: 22px;
    color: var(--dlr-accent);
    flex-shrink: 0;
}
.dlr-detail-item div { display: flex; flex-direction: column; }
.dlr-detail-label {
    font-size: 11px;
    color: var(--dlr-muted);
    text-transform: uppercase;
    letter-spacing: .5px;
    font-weight: 600;
}
.dlr-detail-value {
    font-size: 15px;
    font-weight: 700;
    color: var(--dlr-text);
}

/* Características */
.dlr-features-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 10px 24px;
}
.dlr-features-list li {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--dlr-text);
}
.dlr-features-list li i { color: var(--dlr-accent); font-size: 17px; }
.dlr-features-list li em { color: var(--dlr-muted); font-style: normal; font-size: 13px; }

/* Certificado energético */
.dlr-energy-scale {
    display: flex;
    flex-direction: column;
    gap: 4px;
    max-width: 340px;
}
.dlr-energy-step {
    display: flex;
    align-items: center;
    height: 28px;
    border-radius: 4px;
    color: #fff;
    padding: 0 14px;
    font-weight: 800;
    position: relative;
    transition: all .15s;
}
.dlr-energy-step span { font-size: 13px; }
.dlr-energy-step.active {
    height: 38px;
    transform: scale(1.06);
    box-shadow: 0 4px 12px rgba(0,0,0,.20);
    z-index: 2;
}
.dlr-energy-step.active::after {
    content: "← Esta vivienda";
    position: absolute;
    left: 100%;
    top: 50%;
    transform: translateY(-50%);
    margin-left: 14px;
    color: var(--dlr-text);
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}
.dlr-energy-a, .dlr-energy-step.dlr-energy-a { background: #00a651; width: 30%; }
.dlr-energy-b { background: #50b848; width: 40%; }
.dlr-energy-c { background: #aed136; width: 50%; }
.dlr-energy-d { background: #fff200; color: #333; width: 60%; }
.dlr-energy-e { background: #fdb913; color: #333; width: 70%; }
.dlr-energy-f { background: #f37021; width: 80%; }
.dlr-energy-g { background: #ed1c24; width: 90%; }
.dlr-energy-step:not(.active) { opacity: .4; }
.dlr-energy-step.active { opacity: 1; width: auto !important; min-width: 60%; }
.dlr-energy-note { margin: 14px 0 0; color: var(--dlr-muted); font-size: 14px; }
.dlr-energy-pending {
    background: var(--dlr-light);
    padding: 14px 18px;
    border-radius: 10px;
    color: var(--dlr-muted);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 10px;
}
.dlr-energy-pending i { color: var(--dlr-accent); font-size: 18px; }

/* Mapa */
.dlr-map-wrap { border-radius: 12px; overflow: hidden; }
.dlr-map-note {
    margin: 12px 0 0;
    color: var(--dlr-muted);
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.dlr-map-note i { color: var(--dlr-accent); }

/* Sidebar derecha */
.dlr-prop-sidebar {
    position: sticky;
    top: 100px;
}
.dlr-contact-card {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 14px rgba(21,24,38,.06);
    border: 1px solid var(--dlr-border);
    overflow: hidden;
    margin-bottom: 20px;
}
.dlr-contact-head {
    background: linear-gradient(135deg, #151826 0%, #0d0f1a 100%);
    padding: 28px 24px;
    text-align: center;
}
.dlr-contact-logo { height: 50px; width: auto; }
.dlr-contact-body { padding: 22px; }
.dlr-contact-text {
    color: var(--dlr-muted);
    font-size: 14px;
    margin: 0 0 16px;
    text-align: center;
    line-height: 1.5;
}
.dlr-contact-btn {
    display: flex !important;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    border-radius: 12px;
    text-decoration: none !important;
    margin-bottom: 10px;
    transition: all .2s;
    border: 1px solid transparent;
}
.dlr-contact-btn i,
.dlr-contact-btn span,
.dlr-contact-btn small,
.dlr-contact-btn strong {
    color: inherit !important;
}
.dlr-contact-btn i { font-size: 22px; flex-shrink: 0; }
.dlr-contact-btn span {
    display: flex !important;
    flex-direction: column;
    line-height: 1.15;
}
.dlr-contact-btn small {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .5px;
    opacity: .9;
    font-weight: 500;
}
.dlr-contact-btn strong {
    font-size: 15px;
    font-weight: 700;
}

/* Botón Llamar (rojo Delarocha) */
.dlr-contact-call,
.dlr-contact-call:link,
.dlr-contact-call:visited {
    background: var(--dlr-accent) !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(226,88,88,.25);
}
.dlr-contact-call:hover {
    background: var(--dlr-accent-2) !important;
    transform: translateY(-1px);
    box-shadow: 0 8px 20px rgba(226,88,88,.35);
    color: #fff !important;
}

/* Botón WhatsApp (verde) */
.dlr-contact-wa,
.dlr-contact-wa:link,
.dlr-contact-wa:visited {
    background: #25d366 !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(37,211,102,.25);
}
.dlr-contact-wa:hover {
    background: #1da851 !important;
    transform: translateY(-1px);
    color: #fff !important;
}

/* Botón Email/Formulario (gris claro, texto oscuro) */
.dlr-contact-form,
.dlr-contact-form:link,
.dlr-contact-form:visited {
    background: var(--dlr-light) !important;
    color: var(--dlr-text) !important;
    border: 1px solid var(--dlr-border) !important;
}
.dlr-contact-form:hover {
    background: var(--dlr-primary) !important;
    color: #fff !important;
    border-color: var(--dlr-primary) !important;
}
/* Asegurar contraste de los textos hijos en cualquier estado */
.dlr-contact-call small, .dlr-contact-call strong, .dlr-contact-call i,
.dlr-contact-wa small, .dlr-contact-wa strong, .dlr-contact-wa i {
    color: #fff !important;
}
.dlr-contact-form small {
    color: var(--dlr-muted) !important;
}
.dlr-contact-form strong, .dlr-contact-form i {
    color: var(--dlr-text) !important;
}
.dlr-contact-form:hover small,
.dlr-contact-form:hover strong,
.dlr-contact-form:hover i {
    color: #fff !important;
}
.dlr-contact-meta {
    margin: 18px 0 0;
    padding-top: 18px;
    border-top: 1px solid var(--dlr-border);
}
.dlr-contact-meta p {
    margin: 0 0 6px;
    color: var(--dlr-muted);
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.dlr-contact-meta i { color: var(--dlr-accent); }

/* Recientes en sidebar */
.dlr-recent-card {
    background: #fff;
    border-radius: 16px;
    padding: 22px;
    box-shadow: 0 2px 8px rgba(21,24,38,.04);
    border: 1px solid var(--dlr-border);
}
.dlr-recent-card h3 {
    font-size: 14px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin: 0 0 16px;
    color: var(--dlr-text);
}
.dlr-recent-item {
    display: flex;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--dlr-border);
    text-decoration: none !important;
    color: var(--dlr-text) !important;
    transition: opacity .15s;
}
.dlr-recent-item:last-of-type { border-bottom: 0; }
.dlr-recent-item:hover { opacity: .8; }
.dlr-recent-item img {
    width: 70px;
    height: 60px;
    object-fit: cover;
    border-radius: 8px;
}
.dlr-recent-item div { display: flex; flex-direction: column; justify-content: center; }
.dlr-recent-item strong {
    font-size: 13px;
    line-height: 1.3;
    margin-bottom: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.dlr-recent-item span {
    color: var(--dlr-accent);
    font-weight: 700;
    font-size: 14px;
}
.dlr-recent-more {
    display: block;
    text-align: center;
    margin-top: 14px;
    padding: 10px;
    color: var(--dlr-accent);
    font-weight: 700;
    text-decoration: none;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.dlr-recent-more:hover { color: var(--dlr-primary); }

/* Botones flotantes mobile */
.dlr-mobile-cta {
    display: none;
    position: fixed;
    bottom: 16px;
    left: 16px;
    right: 16px;
    z-index: 100;
    gap: 10px;
}
.dlr-mobile-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 18px;
    border-radius: 999px;
    text-decoration: none !important;
    font-weight: 700;
    font-size: 14px;
    color: #fff !important;
    text-transform: uppercase;
    letter-spacing: .5px;
    box-shadow: 0 8px 22px rgba(0,0,0,.20);
}
.dlr-mobile-call { background: var(--dlr-accent); }
.dlr-mobile-wa { background: #25d366; }

/* Lightbox */
.dlr-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.92);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    cursor: zoom-out;
}
.dlr-lightbox.open { display: flex; }
.dlr-lightbox img {
    max-width: 95vw;
    max-height: 90vh;
    border-radius: 6px;
    cursor: default;
    box-shadow: 0 24px 60px rgba(0,0,0,.5);
}
.dlr-lightbox-close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 0;
    background: #fff;
    color: var(--dlr-text);
    cursor: pointer;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.dlr-lightbox-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: rgba(255,255,255,.95);
    border: 0;
    color: var(--dlr-text);
    cursor: pointer;
    font-size: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.dlr-lightbox-arrow:hover { background: var(--dlr-accent); color: #fff; }
.dlr-lightbox-prev { left: 20px; }
.dlr-lightbox-next { right: 20px; }
.dlr-lightbox-counter {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,.7);
    color: #fff;
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    backdrop-filter: blur(4px);
}

/* Mobile */
@media (max-width: 1024px) {
    .dlr-prop-layout { grid-template-columns: 1fr; }
    .dlr-prop-sidebar { position: static; }
}
@media (max-width: 768px) {
    .dlr-prop-header { padding: 20px 18px; margin: -20px 0 18px; }
    .dlr-prop-title { font-size: 22px; }
    .dlr-prop-price-main { font-size: 28px; }
    .dlr-card { padding: 20px 18px; }
    .dlr-card-title { font-size: 16px; }
    .dlr-mobile-cta { display: flex; }
    .dlr-prop-page { padding-bottom: 100px; }
}

/* ============================================================
 *  Bloque legacy (oculto)
 * ============================================================ */
.heading-properties-3 {
    background: #fff;
    padding: 24px;
    border-radius: 14px;
    border: 1px solid var(--dlr-border);
    box-shadow: 0 2px 8px rgba(21,24,38,.04);
    margin-bottom: 24px;
}
.heading-properties-3 h1 {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 10px;
    color: var(--dlr-text);
}
.heading-properties-3 .property-price {
    color: var(--dlr-primary);
    font-weight: 800;
    font-size: 28px !important;
}
.heading-properties-3 .rent {
    background: var(--dlr-accent) !important;
    color: #fff !important;
    border-radius: 999px;
    padding: 4px 12px !important;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.heading-properties-3 .location {
    color: var(--dlr-muted);
    margin-left: 12px;
}
.heading-properties-3 .inforef {
    margin-top: 10px;
    color: var(--dlr-muted);
    font-size: 13px;
}
.heading-properties-3 .inforef i.fa-phone {
    color: var(--dlr-accent) !important;
}

.properties-description, .properties-amenities, .floor-plans {
    background: #fff;
    padding: 24px;
    border-radius: 14px;
    border: 1px solid var(--dlr-border);
    box-shadow: 0 2px 8px rgba(21,24,38,.04);
    margin-bottom: 24px;
}
.heading-2 {
    border-bottom: 1px solid var(--dlr-border);
    padding-bottom: 10px;
    margin-bottom: 18px;
    font-size: 17px;
    font-weight: 700;
    color: var(--dlr-text);
}
.amenities {
    list-style: none;
    padding: 0;
}
.amenities li {
    padding: 6px 0;
    font-size: 14px;
    color: var(--dlr-text);
}
.amenities li span { color: var(--dlr-accent) !important; }

/* Detalles del inmueble (Idealista style) */
.dlr-property-extras {
    background: #fff;
    padding: 24px;
    border-radius: 14px;
    border: 1px solid var(--dlr-border);
    box-shadow: 0 2px 8px rgba(21,24,38,.04);
    margin-bottom: 24px;
}
.dlr-property-extras-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
}
.dlr-property-extra {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 12px 14px;
    background: var(--dlr-light);
    border-radius: 10px;
    border: 1px solid var(--dlr-border);
}
.dlr-property-extra-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--dlr-muted);
}
.dlr-property-extra-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--dlr-text);
    line-height: 1.3;
}

/* Carousel de ficha */
.properties-details-sliders {
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 4px 16px rgba(21,24,38,.08);
}
.imagedetail {
    aspect-ratio: 16 / 10;
    width: 100% !important;
    height: auto !important;
    min-height: 360px;
}

/* ============================================================
 *  Override del verde #40af2c
 * ============================================================ */
[style*="#40af2c"], [style*="40af2c"] { color: var(--dlr-accent) !important; }
span.rent[style*="40af2c"],
span[style*="background:#40af2c"],
span[style*="background: #40af2c"] {
    background: var(--dlr-accent) !important;
    color: #fff !important;
}

/* ============================================================
 *  Cookieconsent (pop-up de cookies)
 * ============================================================ */
.cc-window.cc-banner {
    background: var(--dlr-primary) !important;
    color: #fff !important;
    border-radius: 12px 12px 0 0;
    padding: 18px !important;
}
.cc-btn.cc-dismiss {
    background: var(--dlr-accent) !important;
    color: #fff !important;
    border-radius: 999px !important;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: .5px;
    padding: 8px 18px !important;
    border: 0 !important;
}
.cc-btn.cc-dismiss:hover { background: var(--dlr-accent-2) !important; }

/* ============================================================
 *  Pagination en /search
 * ============================================================ */
.pagination .page-link {
    border: 1px solid var(--dlr-border);
    border-radius: 8px;
    padding: 8px 14px;
    background: #fff;
    color: var(--dlr-text);
    margin: 0 3px;
    font-weight: 500;
    transition: all .15s;
}
.pagination .page-link.active,
.pagination .page-link:hover {
    background: var(--dlr-accent);
    color: #fff;
    border-color: var(--dlr-accent);
}

/* ============================================================
 *  Tipografía detalles
 * ============================================================ */
h1, h2, h3, h4 { color: var(--dlr-text); }
h2.heading-2 strong { color: var(--dlr-accent) !important; }

/* Wrapper de página: sobrescribir el "top: 65px" del template original */
.main {
    padding-top: 0 !important;
    position: static !important;
    top: auto !important;
    padding-bottom: 0 !important;
}

/* ============================================================
 *  Mobile
 * ============================================================ */
@media (max-width: 768px) {
    .heading-properties-3 h1 { font-size: 20px; }
    .heading-properties-3 .property-price { font-size: 22px !important; }
    .properties-description, .properties-amenities, .floor-plans,
    .heading-properties-3 { padding: 16px; }
    .imagedetail { min-height: 240px; }
    .facilities-list { flex-wrap: wrap; }
    .facilities-list li { min-width: 30%; }
}

/* === Características: checkboxes compactos === */
.feature{
    margin-bottom: 4px !important;
    padding-bottom: 0 !important;
}
.feature label{
    font-size: 13px !important;
    line-height: 1.25 !important;
    padding-left: 26px !important;
    margin-bottom: 0 !important;
}
.feature .checkbox-feature{
    transform: scale(.92);
}
.feature .descriptionFeature{
    margin-top: 2px !important;
    margin-bottom: 8px !important;
    padding-left: 26px;
}
.feature .descriptionFeature input{
    height: 28px;
    font-size: 12px;
    padding: 4px 8px;
}
.checkbox.checkbox-theme.checkbox-circle.feature + .checkbox.checkbox-theme.checkbox-circle.feature{
    margin-top: 0 !important;
}
.col-lg-3.col-md-4.col-sm-6 .feature{
    line-height: 1.2;
}

/* === Equipamiento: grid de campos === */
.dlr-eq-grid select.dlr-native-select,
.dlr-eq-grid input[type="number"].input-text,
.dlr-eq-grid input[type="text"].input-text{
    height: 38px;
    font-size: 13px;
}
#dlrAcDetailWrap{ transition: opacity .15s; }

/* === Equipamiento: render en ficha individual === */
.dlr-eq-list{
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 10px 18px;
}
.dlr-eq-item{
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: #f8f8f9;
    border-radius: 8px;
    border: 1px solid #ececef;
    font-size: 13px;
}
.dlr-eq-item i{
    color: #E25858;
    font-size: 16px;
    flex: 0 0 auto;
}
.dlr-eq-item .dlr-eq-k{
    color: #7a7a82;
    font-weight: 500;
    flex: 0 0 auto;
}
.dlr-eq-item .dlr-eq-v{
    color: #1a1a1a;
    font-weight: 600;
    margin-left: auto;
    text-align: right;
}

/* === Vídeos en ficha individual === */
.dlr-video-grid{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 16px;
}
.dlr-prop-video{
    width: 100%;
    border-radius: 12px;
    background: #000;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

/* === Electrodomésticos: formulario === */
.dlr-appl-grid{
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 8px 16px;
}
.dlr-appl-row{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 8px 12px;
    background: #fafafa;
    border: 1px solid #ececef;
    border-radius: 8px;
    transition: background .15s, border-color .15s;
}
.dlr-appl-row:has(.dlr-appl-check:checked){
    background: #fff5f5;
    border-color: #E25858;
}
.dlr-appl-label{
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0 !important;
    cursor: pointer;
    flex: 1 1 auto;
    font-size: 13px;
    font-weight: 500;
    color: #333;
}
.dlr-appl-label i{
    color: #E25858;
    font-size: 16px;
    flex: 0 0 auto;
}
.dlr-appl-check{
    width: 16px;
    height: 16px;
    cursor: pointer;
    accent-color: #E25858;
}
.dlr-appl-qty-wrap{
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: #888;
    flex: 0 0 auto;
}
.dlr-appl-qty{
    width: 56px;
    height: 30px !important;
    text-align: center;
    border: 1px solid #d6d6d6;
    border-radius: 4px;
    font-size: 13px;
    font-weight: 600;
}
.dlr-appl-qty:disabled{
    background: #f0f0f0;
    color: #aaa;
    cursor: not-allowed;
}

/* === Electrodomésticos: ficha individual === */
.dlr-appl-list{
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 10px;
}
.dlr-appl-item{
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: #f8f8f9;
    border: 1px solid #ececef;
    border-radius: 8px;
    font-size: 13px;
}
.dlr-appl-item i{
    color: #E25858;
    font-size: 18px;
    flex: 0 0 auto;
}
.dlr-appl-item .dlr-appl-name{
    flex: 1 1 auto;
    color: #1a1a1a;
    font-weight: 500;
}
.dlr-appl-item .dlr-appl-qty-badge{
    background: #E25858;
    color: #fff;
    font-weight: 700;
    font-size: 12px;
    min-width: 28px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 8px;
    border-radius: 12px;
}

/* Más espacio arriba del contenido de la ficha individual */
.dlr-prop-page{
    padding-top: 40px !important;
    margin-top: -20px !important;
}
@media (max-width: 720px){
    .dlr-prop-page{
        padding-top: 24px !important;
        margin-top: 0 !important;
    }
}

/* ============================================================
 *  DLR FIX 2026-05-25 — Badges "Destacado"/"Solo estudiantes"
 *  Problema: el badge se renderizaba como un círculo rojo gigante
 *  (94x100px). Causa: .listing-badges es flex con altura/stretch
 *  heredados del template; el override previo solo tocaba el <span>,
 *  que se estiraba al alto del contenedor. Se fija el contenedor a
 *  height:auto + align-items:flex-start y se anula aspect-ratio/stretch.
 * ============================================================ */
.property-box .listing-badges,
.property-thumbnail .listing-badges,
.listing-badges {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    align-items: flex-start !important;
}
.property-box .listing-badges .featured,
.property-box .listing-badges span,
.property-thumbnail .listing-badges .featured,
.property-thumbnail .listing-badges span,
.listing-badges .featured,
.listing-badges span {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: auto !important;
    align-self: flex-start !important;
    flex: 0 0 auto !important;
}

/* ============================================================
 *  DLR FIX 2026-05-25 (b) — Imágenes del listado deformadas
 *  Las tarjetas usan width:100% + height:220px fijo sin object-fit,
 *  lo que estira la foto. Se fuerza object-fit:cover para recortar
 *  manteniendo proporción.
 * ============================================================ */
.property-box .property-thumbnail img,
.property-box .property-img img,
.properties-list .property-thumbnail img {
    width: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
}

/* ============================================================
 *  DLR 2026-05-25 (c) — Nombres de foto (galería + panel)
 * ============================================================ */
.dlr-gallery-caption {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(transparent, rgba(21,24,38,.82));
    color: #fff;
    padding: 30px 18px 14px;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.3;
    pointer-events: none;
    text-shadow: 0 1px 3px rgba(0,0,0,.5);
}
/* Panel: campo de nombre bajo cada foto en la lista reordenable */
.dlr-media-item { vertical-align: top; }
.dlr-media-caption {
    display: block;
    width: 100%;
    max-width: 160px;
    margin-top: 6px;
    padding: 5px 8px;
    border: 1px solid var(--dlr-border, #e2e4ea);
    border-radius: 6px;
    font-size: 12px;
    background: #fff;
    box-sizing: border-box;
}
.dlr-media-caption:focus {
    border-color: var(--dlr-accent, #E25858);
    outline: none;
}

/* ============================================================
 *  DLR 2026-05-25 (d) — El <li> de la galería del panel tenía
 *  overflow:hidden y altura fija, recortando el campo de nombre.
 * ============================================================ */
#sortable.list-media li,
#sortable li.dlr-media-item {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
}
#sortable.list-media {
    grid-auto-rows: auto !important;
    align-items: start !important;
}

/* ============================================================
 *  DLR 2026-05-25 (e) — Galería del panel como lista vertical:
 *  cada fila = asa + miniatura + eliminar + campo de nombre.
 *  Sustituye el grid de miniaturas (no apto para los nombres).
 * ============================================================ */
#sortable.list-media {
    display: block !important;
    grid-template-columns: none !important;
    margin: 16px 0 !important;
    max-width: 640px !important;
    padding: 0 !important;
}
#sortable.list-media li.dlr-media-item {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
    width: 100% !important;
    margin: 0 0 10px !important;
    padding: 8px 12px !important;
    border: 1px solid var(--dlr-border, #e2e4ea) !important;
    border-radius: 10px !important;
    background: #fff !important;
    box-shadow: 0 1px 3px rgba(21,24,38,.05) !important;
    list-style: none !important;
}
#sortable.list-media li.dlr-media-item::before {
    content: '\2630';
    color: #b8bcc8;
    font-size: 15px;
    flex: 0 0 auto;
    cursor: grab;
}
#sortable.list-media li.dlr-media-item .mediaPanel {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 0 !important;
    padding: 0 !important;
    flex: 0 0 auto !important;
    position: static !important;
}
#sortable.list-media li.dlr-media-item .mediaPanel img {
    width: 88px !important;
    height: 62px !important;
    object-fit: cover !important;
    border-radius: 6px !important;
}
#sortable.list-media li.dlr-media-item .mediaPanel .action {
    position: static !important;
    float: none !important;
}
#sortable.list-media li.dlr-media-item .dlr-media-caption {
    margin: 0 !important;
    max-width: none !important;
    flex: 1 1 auto !important;
}

/* ============================================================
 *  DLR 2026-05-25 (f) — La tile del panel tenía aspect-ratio:4/3
 *  (640→480px) y .mediaPanel width:100% (aplastaba el nombre).
 * ============================================================ */
#sortable.list-media li.dlr-media-item {
    aspect-ratio: auto !important;
}
#sortable.list-media li.dlr-media-item .mediaPanel {
    width: auto !important;
}

/* ============================================================
 *  DLR 2026-05-25 (g) — Reorden de fotos dinámico:
 *  asa de arrastre real + hueco (placeholder) visible.
 * ============================================================ */
/* quitar el asa antigua hecha con ::before */
#sortable.list-media li.dlr-media-item::before { content: none !important; }

.dlr-drag-handle {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 100%;
    color: #b8bcc8;
    font-size: 18px;
    cursor: grab;
    user-select: none;
    touch-action: none;
}
.dlr-drag-handle:hover { color: var(--dlr-accent, #E25858); }
.dlr-drag-handle:active { cursor: grabbing; }

/* hueco donde caerá la foto al soltar */
.dlr-media-placeholder {
    border: 2px dashed var(--dlr-accent, #E25858) !important;
    border-radius: 10px !important;
    background: rgba(226,88,88,.07) !important;
    margin: 0 0 10px !important;
    box-sizing: border-box !important;
    visibility: visible !important;
    list-style: none !important;
}
/* el elemento que se arrastra: sombra para sensación de "levantado" */
#sortable.list-media li.dlr-media-item.ui-sortable-helper {
    box-shadow: 0 8px 24px rgba(21,24,38,.18) !important;
    border-color: var(--dlr-accent, #E25858) !important;
}

/* ============================================================
 *  DLR (h) — El hueco del reorden heredaba aspect-ratio 4/3
 *  del template y salía gigante. Alto fijo, sin aspect-ratio.
 * ============================================================ */
#sortable.list-media .dlr-media-placeholder,
.dlr-media-placeholder {
    aspect-ratio: auto !important;
    height: 78px !important;
    min-height: 78px !important;
    max-height: 78px !important;
    width: 100% !important;
    display: block !important;
    box-sizing: border-box !important;
    flex: none !important;
}

/* ============================================================
 *  DLR (i) — La fila "saltaba arriba" al arrastrar porque el
 *  offsetParent del <li> era el FORM (lejano). Con el listado
 *  position:relative, el offsetParent pasa a ser el propio
 *  #sortable y jQuery UI posiciona el helper correctamente.
 * ============================================================ */
#sortable.list-media {
    position: relative !important;
}

/* ============================================================
 *  DLR (j) — Reorden con SortableJS (sustituye a jQuery UI).
 * ============================================================ */
/* hueco que marca el destino mientras arrastras */
.dlr-sortable-ghost {
    opacity: 0.5;
    background: rgba(226,88,88,.10) !important;
    border: 2px dashed var(--dlr-accent, #E25858) !important;
}
/* fila elegida / clon que sigue al cursor */
.dlr-sortable-chosen {
    box-shadow: 0 8px 24px rgba(21,24,38,.18) !important;
    border-color: var(--dlr-accent, #E25858) !important;
}
.sortable-fallback {
    box-shadow: 0 10px 28px rgba(21,24,38,.22) !important;
    opacity: 0.97 !important;
}

/* ============================================================
 *  DLR (k) — El clon que se arrastra (SortableJS fallbackOnBody)
 *  vive en el <body> y pierde los estilos de #sortable, saliendo
 *  descuadrado. Le damos estilo propio para que sea una fila limpia.
 * ============================================================ */
li.dlr-media-item.sortable-fallback {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 8px 12px !important;
    border: 1px solid var(--dlr-accent, #E25858) !important;
    border-radius: 10px !important;
    background: #fff !important;
    box-shadow: 0 12px 30px rgba(21,24,38,.22) !important;
    list-style: none !important;
    box-sizing: border-box !important;
    opacity: 0.97 !important;
    cursor: grabbing !important;
}
li.dlr-media-item.sortable-fallback::before { content: none !important; }
li.dlr-media-item.sortable-fallback .dlr-drag-handle {
    flex: 0 0 auto !important;
    width: 26px !important;
    color: var(--dlr-accent, #E25858) !important;
}
li.dlr-media-item.sortable-fallback .mediaPanel {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    flex: 0 0 auto !important;
}
li.dlr-media-item.sortable-fallback .mediaPanel img {
    width: 88px !important;
    height: 62px !important;
    object-fit: cover !important;
    border-radius: 6px !important;
}
li.dlr-media-item.sortable-fallback .mediaPanel .action {
    position: static !important;
    float: none !important;
}
li.dlr-media-item.sortable-fallback .dlr-media-caption {
    flex: 1 1 auto !important;
    margin: 0 !important;
    max-width: none !important;
}

/* ============================================================
 *  DLR — Mapa OSM de la ficha (sustituye al embed de Google
 *  que mostraba POIs de negocios / inmobiliarias).
 * ============================================================ */
.dlr-prop-map {
    height: 380px;
    width: 100%;
    border-radius: 12px;
    overflow: hidden;
    position: relative;
    z-index: 0;
    background: #eef0f4;
}
.dlr-prop-map .leaflet-control-attribution {
    font-size: 10px;
}

/* ============================================================
 *  DLR — Módulo Contactos (CRM propio)
 * ============================================================ */
.dlr-contacts-table .title-container h2 { font-size: 16px; margin: 0 0 4px; }
.dlr-contacts-table .title-container h5 { color: var(--dlr-muted,#6b7280); font-size: 13px; margin: 0 0 8px; font-weight: 500; }

.dlr-contact-badges { display: flex; flex-wrap: wrap; gap: 6px; }
.dlr-cbadge {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 999px;
    background: #eef0f4; color: #3a3f4b; line-height: 1.5; white-space: nowrap;
}
.dlr-cbadge-oferta  { background: #e0f2fe; color: #0369a1; }
.dlr-cbadge-demanda { background: #fde8e8; color: #b23636; }
.dlr-cbadge-op      { background: #f3e8ff; color: #6b21a8; }
.dlr-cbadge-stu     { background: #fef3c7; color: #92400e; }
.dlr-cbadge-zone    { background: #ecfdf5; color: #047857; }
.dlr-cbadge-price   { background: #151826; color: #fff; }
/* estados */
.dlr-cstatus-nuevo       { background: #dcfce7; color: #166534; }
.dlr-cstatus-seguimiento { background: #fef3c7; color: #92400e; }
.dlr-cstatus-activo      { background: #dbeafe; color: #1e40af; }
.dlr-cstatus-cerrado     { background: #e5e7eb; color: #4b5563; }
.dlr-cstatus-descartado  { background: #fee2e2; color: #991b1b; }

/* Cabecera ficha */
.dlr-contact-head { margin-bottom: 16px; }
.dlr-contact-head h3 { margin: 8px 0 0; font-size: 22px; font-weight: 800; color: var(--dlr-text,#151826); }

/* Layout ficha: formulario + seguimiento */
.dlr-contact-layout { display: flex; gap: 24px; align-items: flex-start; }
.dlr-contact-form-col { flex: 1 1 auto; min-width: 0; }
.dlr-contact-side-col { flex: 0 0 340px; max-width: 340px; }
@media (max-width: 991px){
    .dlr-contact-layout { flex-direction: column; }
    .dlr-contact-side-col { flex: 1 1 auto; max-width: none; width: 100%; }
}

/* Seguimiento / timeline */
.dlr-followup { background: #fff; border: 1px solid var(--dlr-border,#e2e4ea); border-radius: 12px; padding: 18px; position: sticky; top: 90px; }
.dlr-followup > h4 { font-size: 15px; font-weight: 700; margin: 0 0 14px; color: var(--dlr-text,#151826); display: flex; align-items: center; gap: 8px; }
.dlr-note-form { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.dlr-note-form textarea { width: 100%; border: 1px solid var(--dlr-border,#e2e4ea); border-radius: 8px; padding: 8px 10px; font-size: 13px; font-family: inherit; box-sizing: border-box; resize: vertical; }
.dlr-note-form .dlr-btn-add { justify-content: center; }
.dlr-timeline { list-style: none; margin: 0; padding: 0; max-height: 460px; overflow-y: auto; }
.dlr-timeline li { display: flex; gap: 10px; padding: 10px 0; border-top: 1px solid var(--dlr-border,#eef0f4); }
.dlr-timeline li.dlr-timeline-empty { justify-content: center; color: var(--dlr-muted,#9aa0ab); font-size: 13px; border: 0; padding: 16px 0; }
.dlr-tl-icon { flex: 0 0 auto; width: 30px; height: 30px; border-radius: 50%; background: #f3e8ff; color: #6b21a8; display: flex; align-items: center; justify-content: center; font-size: 14px; }
.dlr-tl-body { min-width: 0; }
.dlr-tl-meta { font-size: 12px; color: var(--dlr-muted,#6b7280); margin-bottom: 2px; }
.dlr-tl-text { font-size: 13px; color: var(--dlr-text,#151826); line-height: 1.4; word-wrap: break-word; }

/* Mensaje inline al guardar */
.dlr-save-inline-msg { margin-left: 12px; font-size: 14px; font-weight: 600; }
.dlr-save-inline-msg.ok  { color: #16a34a; }
.dlr-save-inline-msg.err { color: #dc2626; }

/* DLR — cabecera de la ficha de contacto (renombrada para no chocar con .dlr-contact-head del sitio) */
.dlr-crm-head { margin-bottom: 16px; background: none !important; padding: 0 !important; }
.dlr-crm-head h3 { margin: 8px 0 0; font-size: 22px; font-weight: 800; color: var(--dlr-text,#151826); }

/* ============================================================
 *  DLR — Rediseño del menú lateral del panel (coherente con
 *  la estética del resto: tarjeta blanca, pills, activo oscuro).
 * ============================================================ */
.dashboard-nav {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 0 24px !important;
    position: sticky;
    top: 90px;
}
.dashboard-nav .dashboard-inner {
    background: #fff !important;
    border: 1px solid var(--dlr-border, #e9eaef) !important;
    border-radius: 16px !important;
    padding: 14px !important;
    box-shadow: 0 2px 12px rgba(21,24,38,.05) !important;
}

/* Etiquetas de sección */
.dashboard-nav .dashboard-inner h4 {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 1.2px !important;
    color: var(--dlr-muted, #9aa0ab) !important;
    margin: 16px 12px 8px !important;
    padding: 0 !important;
    border: 0 !important;
}
.dashboard-nav .dashboard-inner h4:first-child { margin-top: 4px !important; }

/* Lista de ítems */
.dashboard-nav .dashboard-inner ul {
    list-style: none !important;
    margin: 0 0 4px !important;
    padding: 0 !important;
}
.dashboard-nav .dashboard-inner ul li {
    margin: 2px 0 !important;
    border: 0 !important;
    background: none !important;
}
.dashboard-nav .dashboard-inner ul li a {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 11px 14px !important;
    border-radius: 11px !important;
    color: var(--dlr-text, #2a2e3a) !important;
    font-weight: 600 !important;
    font-size: 14.5px !important;
    line-height: 1.2 !important;
    text-decoration: none !important;
    border: 0 !important;
    transition: background .15s ease, color .15s ease !important;
}
.dashboard-nav .dashboard-inner ul li a i {
    font-size: 18px !important;
    width: 22px !important;
    text-align: center !important;
    flex: 0 0 auto !important;
    color: var(--dlr-muted, #9aa0ab) !important;
    margin: 0 !important;
    transition: color .15s ease !important;
}

/* Hover */
.dashboard-nav .dashboard-inner ul li a:hover {
    background: var(--dlr-light, #f5f6f8) !important;
    color: var(--dlr-primary, #151826) !important;
}
.dashboard-nav .dashboard-inner ul li a:hover i {
    color: var(--dlr-accent, #E25858) !important;
}

/* Activo: pill oscuro como la cabecera */
.dashboard-nav .dashboard-inner ul li.active a {
    background: linear-gradient(135deg, #151826 0%, #2a2e44 100%) !important;
    color: #fff !important;
    box-shadow: 0 6px 16px rgba(21,24,38,.20) !important;
}
.dashboard-nav .dashboard-inner ul li.active a i { color: #fff !important; }

/* Cerrar sesión: matiz rojo en hover */
.dashboard-nav .dashboard-inner ul li.dlr-nav-logout a:hover {
    background: #fdecec !important;
    color: var(--dlr-accent, #E25858) !important;
}
.dashboard-nav .dashboard-inner ul li.dlr-nav-logout a:hover i { color: var(--dlr-accent, #E25858) !important; }

/* ===== DLR v26: transiciones dinámicas (público) ===== */
.dlr-prop-card{ overflow:hidden; transition: transform .28s cubic-bezier(.2,.7,.3,1), box-shadow .28s ease; }
.dlr-prop-card:hover{ transform: translateY(-6px); box-shadow: 0 20px 44px rgba(21,24,38,.20); }
.dlr-prop-card .dlr-prop-card-img{ transition: transform .5s ease; }
.dlr-prop-card:hover .dlr-prop-card-img{ transform: scale(1.06); }

.property-box{ transition: transform .28s cubic-bezier(.2,.7,.3,1), box-shadow .28s ease; }
.property-box:hover{ transform: translateY(-5px); box-shadow: 0 18px 40px rgba(21,24,38,.16); }
.property-thumbnail{ overflow:hidden; }
.property-thumbnail img{ transition: transform .5s ease; }
.property-box:hover .property-thumbnail img{ transform: scale(1.06); }

.dlr-value-card{ transition: transform .25s ease, box-shadow .25s ease; }
.dlr-value-card:hover{ transform: translateY(-5px); }

.dlr-btn-outline{ transition: all .2s ease; }
.dlr-btn-outline:hover{ transform: translateY(-2px); }

/* badge precio /mes pequeño en /search */
.price-box small{ font-size:11px !important; font-weight:600 !important; opacity:.8 !important; margin-left:3px; }

/* fade-in suave al cargar (solo opacidad, no rompe el hover) */
@keyframes dlrFade{ from{opacity:0} to{opacity:1} }
.dlr-prop-card, .property-box{ animation: dlrFade .5s ease both; }

/* ===== DLR v27: responsive — stats de tarjeta /search a 3 columnas en móvil (no afecta desktop) ===== */
@media (max-width: 768px){
  .facilities-list{ display:grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 4px !important; flex-wrap: nowrap !important; }
  .facilities-list li{ min-width: 0 !important; width: auto !important; text-align: center; padding: 6px 2px !important; }
  .facilities-list li span{ display:block; }
}

/* ===== DLR v28: badge de precio en rojo de marca (antes azul oscuro, se veía muy oscuro) ===== */
.property-box .price-box, .property-thumbnail .price-box{
  background: var(--dlr-accent) !important;
  box-shadow: 0 6px 16px rgba(226,88,88,.35) !important;
  backdrop-filter: none !important;
}
.dlr-prop-card-price{
  background: var(--dlr-accent) !important;
  box-shadow: 0 6px 16px rgba(226,88,88,.35) !important;
}
