/* =============================================================
   devacaciones.com.ar — Estilos de marca sobre Bootstrap 5.3
   Paleta extraída del logo:
   #FFA000 naranja primario · #FF6F00 naranja oscuro
   #37474F petróleo (dark) · #FFFFFF blanco
   ============================================================= */

:root {
    --dv-primary:        #FFA000;
    --dv-primary-rgb:    255, 160, 0;
    --dv-primary-dark:   #FF6F00;
    --dv-primary-soft:   #FFF4E0;
    --dv-dark:           #37474F;
    --dv-dark-rgb:       55, 71, 79;
    --dv-dark-soft:      #ECEFF1;
    --dv-text:           #1F2A30;
    --dv-muted:          #6B7A82;
    --dv-bg:             #FFFFFF;
    --dv-bg-soft:        #F7F8FA;
    --dv-border:         #E6EAED;

    --dv-radius:         14px;
    --dv-radius-sm:      10px;
    --dv-radius-lg:      22px;
    --dv-shadow:         0 6px 18px rgba(55, 71, 79, .08);
    --dv-shadow-hover:   0 12px 30px rgba(55, 71, 79, .15);

    /* Override Bootstrap */
    --bs-primary:        var(--dv-primary);
    --bs-primary-rgb:    var(--dv-primary-rgb);
    --bs-dark:           var(--dv-dark);
    --bs-dark-rgb:       var(--dv-dark-rgb);
    --bs-body-color:     var(--dv-text);
    --bs-body-font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    --bs-link-color:     var(--dv-dark);
    --bs-link-hover-color: var(--dv-primary-dark);
    --bs-border-color:   var(--dv-border);
}

/* Tipografía local Nexa (opcional, si el archivo está disponible) */
@font-face {
    font-family: 'Nexa';
    src: url('../fonts/NexaBold.otf') format('opentype');
    font-weight: 700;
    font-display: swap;
}
@font-face {
    font-family: 'Nexa';
    src: url('../fonts/NexaLight.otf') format('opentype');
    font-weight: 300;
    font-display: swap;
}

body {
    font-family: var(--bs-body-font-family);
    color: var(--dv-text);
    background: var(--dv-bg);
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6, .dv-display {
    font-family: 'Nexa', 'Inter', sans-serif;
    color: var(--dv-dark);
    letter-spacing: -0.01em;
    font-weight: 700;
}

a { text-decoration: none; color: inherit; transition: color .15s ease; }
a:hover { color: var(--dv-primary-dark); }

.text-dv-primary { color: var(--dv-primary) !important; }
.text-dv-dark    { color: var(--dv-dark) !important; }
.text-dv-muted   { color: var(--dv-muted) !important; }
.bg-dv-primary   { background: var(--dv-primary) !important; }
.bg-dv-dark      { background: var(--dv-dark) !important; }
.bg-dv-soft      { background: var(--dv-bg-soft) !important; }

/* ========== Botones ========== */
.btn-dv-primary {
    --bs-btn-bg: var(--dv-primary);
    --bs-btn-border-color: var(--dv-primary);
    --bs-btn-color: #fff;
    --bs-btn-hover-bg: var(--dv-primary-dark);
    --bs-btn-hover-border-color: var(--dv-primary-dark);
    --bs-btn-hover-color: #fff;
    --bs-btn-active-bg: var(--dv-primary-dark);
    font-weight: 600;
    padding: .7rem 1.4rem;
    border-radius: var(--dv-radius-sm);
}
.btn-dv-dark {
    --bs-btn-bg: var(--dv-dark);
    --bs-btn-border-color: var(--dv-dark);
    --bs-btn-color: #fff;
    --bs-btn-hover-bg: #2A3940;
    --bs-btn-hover-border-color: #2A3940;
    --bs-btn-hover-color: #fff;
    font-weight: 600;
    border-radius: var(--dv-radius-sm);
}
.btn-dv-outline {
    --bs-btn-color: var(--dv-dark);
    --bs-btn-border-color: var(--dv-border);
    --bs-btn-hover-bg: var(--dv-dark);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-border-color: var(--dv-dark);
    font-weight: 600;
    padding: .7rem 1.4rem;
    border-radius: var(--dv-radius-sm);
}
/* Cuando se combina con btn-sm, respetar el padding de Bootstrap.
   Mismo trato para btn-dv-primary por consistencia visual. */
.btn-dv-outline.btn-sm,
.btn-dv-primary.btn-sm {
    padding: .25rem .65rem;
    font-size: .875rem;
}

.btn { transition: transform .15s ease, box-shadow .15s ease, background .15s ease; }
.btn:hover { transform: translateY(-1px); }

/* ========== Navbar ========== */
.dv-navbar {
    border-bottom: 1px solid var(--dv-border);
    padding-top: .9rem;
    padding-bottom: .9rem;
    background: rgba(255,255,255,.96);
    backdrop-filter: saturate(180%) blur(8px);
}
/* Mobile: logo centrado, toggler absoluto a la derecha */
@media (max-width: 991.98px) {
    nav.dv-navbar > .container {
        justify-content: center !important;
        position: relative;
        min-height: 38px;
    }
    nav.dv-navbar .navbar-brand.dv-brand {
        margin: 0 !important;
        padding: 0;
    }
    nav.dv-navbar .navbar-toggler {
        position: absolute;
        right: 12px;
        top: 50%;
        transform: translateY(-50%);
        padding: .25rem .5rem;
    }
    nav.dv-navbar .navbar-toggler:focus {
        box-shadow: none;
    }
}
.dv-navbar .nav-link {
    color: var(--dv-dark);
    font-weight: 500;
    padding: .55rem .15rem;
    margin: 0 .55rem;
    border-radius: 0;
    position: relative;
    background: transparent !important;
    transition: color .15s ease;
}
/* Underline propio — usamos un span interno (.dv-underline) para que ::after
   no choque con el caret nativo del dropdown-toggle de Bootstrap */
.dv-navbar .nav-link .dv-underline {
    position: absolute;
    left: 0; right: 0; bottom: 2px;
    height: 2px;
    background: var(--dv-primary);
    border-radius: 2px;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform .25s ease;
    pointer-events: none;
}
.dv-navbar .nav-link:hover .dv-underline,
.dv-navbar .nav-link.active .dv-underline,
.dv-navbar .nav-item.show > .nav-link .dv-underline {
    transform: scaleX(1);
}
.dv-navbar .nav-link:hover,
.dv-navbar .nav-link.active,
.dv-navbar .nav-item.show > .nav-link {
    color: var(--dv-dark);
}
/* Caret del dropdown alineado y discreto */
.dv-navbar .dropdown-toggle::after {
    margin-left: .4rem;
    vertical-align: middle;
    border-top-color: var(--dv-muted);
    transition: border-top-color .15s ease;
}
.dv-navbar .dropdown-toggle:hover::after,
.dv-navbar .nav-item.show .dropdown-toggle::after {
    border-top-color: var(--dv-dark);
}
.dv-btn-publicar {
    border-color: var(--dv-border);
    color: var(--dv-dark);
    font-weight: 600;
    border-radius: 999px;
    padding: .55rem 1.1rem;
}
.dv-btn-publicar:hover {
    background: var(--dv-dark);
    color: #fff;
    border-color: var(--dv-dark);
}
.dv-btn-login {
    border: 1px solid var(--dv-border);
    color: var(--dv-dark);
    font-weight: 600;
    border-radius: 999px;
    padding: .5rem 1rem;
}
.dv-btn-login:hover { background: var(--dv-dark-soft); }
.dv-dropdown-destinos { min-width: 260px; padding: .5rem; border-radius: var(--dv-radius); border: 1px solid var(--dv-border); }
.dv-dropdown-destinos .dropdown-header { color: var(--dv-muted); font-size: .75rem; text-transform: uppercase; letter-spacing: .04em; }
.dv-dropdown-destinos .dropdown-item:hover { background: var(--dv-primary-soft); color: var(--dv-primary-dark); }

/* ========== Hero ========== */
.dv-hero {
    position: relative;
    min-height: 280px;
    color: #fff;
    background-color: #2a4858;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-image: linear-gradient(180deg, rgba(55,71,79,.08) 0%, rgba(55,71,79,.45) 100%);
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    display: flex;
    align-items: center;
    padding-top: 2rem;
    padding-bottom: 3rem;
    /* overflow visible: necesario para que el dropdown del autocomplete no se recorte */
}
.dv-hero[data-bg] {
    background-image:
        linear-gradient(180deg, rgba(20,30,40,.20) 0%, rgba(20,30,40,.55) 100%),
        var(--dv-hero-img);
}
.dv-hero h1 {
    color: #fff;
    font-size: clamp(1.7rem, 4vw, 2.6rem);
    line-height: 1.1;
    font-weight: 700;
    text-shadow: 0 2px 14px rgba(0,0,0,.25);
    margin-bottom: .3rem;
}
.dv-hero p.lead {
    color: #fff;
    font-size: clamp(.95rem, 1.8vw, 1.15rem);
    font-weight: 500;
    text-shadow: 0 2px 14px rgba(0,0,0,.25);
    margin-bottom: 1rem;
}

/* ========== Buscador ========== */
.dv-searchbar {
    background: #fff;
    border-radius: var(--dv-radius);
    box-shadow: var(--dv-shadow);
    padding: .6rem;
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1fr auto;
    gap: .4rem;
    align-items: center;
}
.dv-searchbar .dv-field {
    padding: .55rem .9rem;
    border-radius: var(--dv-radius-sm);
}
.dv-searchbar .dv-field:hover { background: var(--dv-bg-soft); }
.dv-searchbar label {
    display: block;
    font-size: .72rem;
    font-weight: 600;
    color: var(--dv-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 2px;
}
.dv-searchbar input,
.dv-searchbar select {
    border: 0;
    background: transparent;
    width: 100%;
    font-size: .95rem;
    font-weight: 500;
    color: var(--dv-text);
    padding: 0;
}
.dv-searchbar input:focus,
.dv-searchbar select:focus { outline: none; box-shadow: none; }
.dv-searchbar .btn-buscar {
    background: var(--dv-primary);
    color: #fff;
    border: 0;
    border-radius: var(--dv-radius-sm);
    padding: .9rem 1.6rem;
    font-weight: 700;
    transition: background .15s ease, transform .15s ease;
    height: 100%;
}
.dv-searchbar .btn-buscar:hover { background: var(--dv-primary-dark); transform: translateY(-1px); }
@media (max-width: 768px) {
    .dv-searchbar { grid-template-columns: 1fr; gap: .25rem; padding: .8rem; }
    .dv-searchbar .btn-buscar { padding: .8rem 1.2rem; }
    .dv-hero { min-height: auto; padding: 2.5rem 0 4rem; }
}

/* ========== Sections ========== */
.dv-section { padding: 4rem 0; }
.dv-section--soft { background: var(--dv-bg-soft); }
.dv-section h2 {
    font-size: clamp(1.6rem, 3vw, 2.1rem);
    margin-bottom: 1.8rem;
}

/* ========== Cards destinos ========== */
.dv-destino-card {
    display: block;
    background: transparent;       /* sin caja */
    color: inherit;
    transition: transform .25s ease;
}
.dv-destino-card:hover { transform: translateY(-4px); }
.dv-destino-card:hover h5 { color: var(--dv-primary-dark); }

.dv-destino-card .dv-destino-img {
    aspect-ratio: 4/3;
    background-size: cover;
    background-position: center;
    border-radius: var(--dv-radius);
    overflow: hidden;
    transition: box-shadow .25s ease, transform .25s ease;
    box-shadow: 0 1px 3px rgba(55,71,79,.06);
}
.dv-destino-card:hover .dv-destino-img {
    box-shadow: var(--dv-shadow-hover);
}

.dv-destino-card h5 {
    margin: .9rem 0 .15rem;
    padding: 0;
    font-size: 1.1rem;
    color: var(--dv-dark);
    transition: color .15s ease;
}
.dv-destino-card .small {
    color: var(--dv-muted);
    padding: 0;
}

/* Chips de destinos sin foto (destacados extra) */
.dv-destinos-chips {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
}
.dv-destino-chip {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .5rem .9rem;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--dv-border);
    color: var(--dv-dark);
    text-decoration: none;
    font-size: .95rem;
    transition: background .15s ease, border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.dv-destino-chip i { color: var(--dv-primary); }
.dv-destino-chip:hover {
    background: var(--dv-soft, #f8f5f0);
    border-color: var(--dv-primary);
    color: var(--dv-dark);
    transform: translateY(-1px);
    box-shadow: 0 2px 6px rgba(55,71,79,.06);
}

/* Item "Ver todos los destinos" al pie del dropdown */
.dv-dropdown-vermas {
    font-weight: 500;
    color: var(--dv-primary) !important;
}
.dv-dropdown-vermas:hover {
    background: var(--dv-soft, #f8f5f0);
    color: var(--dv-primary-dark) !important;
}

/* Card región (Costa atlántica, etc.) */
.dv-region-card {
    display: flex;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    overflow: hidden;
    background: #fff;
    min-height: 200px;
    transition: box-shadow .2s ease, transform .2s ease;
}
.dv-region-card:hover { box-shadow: var(--dv-shadow); transform: translateY(-2px); }
.dv-region-card .dv-region-img {
    width: 38%;
    background-size: cover;
    background-position: center;
    flex-shrink: 0;
}
.dv-region-card .dv-region-body { padding: 1.25rem; }
.dv-region-card h5 { margin-bottom: .8rem; font-size: 1.1rem; }
.dv-region-card a { color: var(--dv-dark); font-size: .9rem; }
.dv-region-card a:hover { color: var(--dv-primary-dark); text-decoration: underline; }
.dv-region-card .sep { color: var(--dv-border); margin: 0 .4rem; }

/* ========== USPs ========== */
.dv-usp {
    text-align: center;
    padding: 1.5rem 1rem;
}
.dv-usp i {
    font-size: 2.4rem;
    color: var(--dv-primary);
    margin-bottom: .6rem;
}
.dv-usp h6 {
    font-size: 1.05rem;
    margin-bottom: .35rem;
}
.dv-usp p {
    font-size: .9rem;
    color: var(--dv-muted);
    margin: 0;
}

/* ========== Cards "Quiero viajar / publicar" ========== */
.dv-cta-card {
    border-radius: var(--dv-radius-lg);
    overflow: hidden;
    color: #fff;
    min-height: 260px;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    position: relative;
    box-shadow: var(--dv-shadow);
    transition: transform .2s ease, box-shadow .2s ease;
}
.dv-cta-card:hover { transform: translateY(-3px); box-shadow: var(--dv-shadow-hover); }
.dv-cta-card > * { position: relative; z-index: 1; }
.dv-cta-card h3 {
    color: #fff;
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: .4rem;
}
.dv-cta-card p {
    color: rgba(255,255,255,.92);
    font-size: .98rem;
    margin-bottom: 1.1rem;
    max-width: 32em;
}
.dv-cta-card .btn { width: max-content; font-weight: 600; }
.dv-cta-card .btn-light { color: var(--dv-dark); }
.dv-cta-icon {
    position: absolute;
    top: 1.4rem; right: 1.6rem;
    font-size: 3.2rem;
    line-height: 1;
    opacity: .25;
    color: #fff;
}
/* Variantes con gradiente de marca */
.dv-cta-card--viajar {
    background: linear-gradient(135deg, var(--dv-dark) 0%, #54707b 100%);
}
.dv-cta-card--publicar {
    background: linear-gradient(135deg, var(--dv-primary) 0%, var(--dv-primary-dark) 100%);
}
.dv-cta-card--publicar h3,
.dv-cta-card--publicar p { color: #fff; }

/* ========== Testimonios ========== */
.dv-review {
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 1.4rem;
    height: 100%;
}
.dv-review .stars { color: #FFC107; font-size: 1rem; }
.dv-review p { font-size: .92rem; color: var(--dv-text); line-height: 1.5; }
.dv-review .author { font-size: .85rem; color: var(--dv-muted); }

/* ========== Newsletter ========== */
.dv-newsletter {
    background: linear-gradient(135deg, var(--dv-primary), var(--dv-primary-dark));
    border-radius: var(--dv-radius-lg);
    color: #fff;
    padding: 3rem 2rem;
    text-align: center;
}
.dv-newsletter h3 { color: #fff; font-size: 1.6rem; }
.dv-newsletter form {
    max-width: 520px;
    margin: 1.4rem auto 0;
    display: flex;
    gap: .5rem;
    background: #fff;
    padding: .35rem;
    border-radius: var(--dv-radius-sm);
}
.dv-newsletter input {
    border: 0;
    padding: .8rem 1rem;
    border-radius: var(--dv-radius-sm);
    flex: 1;
    color: var(--dv-text);
}
.dv-newsletter input:focus { outline: none; }
.dv-newsletter .btn {
    background: var(--dv-dark);
    color: #fff;
    border: 0;
    font-weight: 600;
    border-radius: var(--dv-radius-sm);
    padding: .8rem 1.4rem;
}
.dv-newsletter .btn:hover { background: #2a3940; }

/* ========== Footer ========== */
.dv-footer {
    background: var(--dv-bg-soft);
    border-top: 1px solid var(--dv-border);
}
/* Mobile: marca del footer centrada */
@media (max-width: 767.98px) {
    .dv-footer .dv-footer-brand {
        text-align: center;
    }
    .dv-footer .dv-footer-brand .d-flex {
        justify-content: center;
    }
}
.dv-footer-title {
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--dv-dark);
    font-weight: 700;
    margin-bottom: 1rem;
}
.dv-footer a { color: var(--dv-muted); }
.dv-footer a:hover { color: var(--dv-primary-dark); }

/* Crédito de autoría */
.dv-credito {
    color: var(--dv-dark) !important;
    font-weight: 600;
    border-bottom: 1px dotted var(--dv-muted);
    transition: color .15s ease, border-color .15s ease;
}
.dv-credito:hover {
    color: var(--dv-primary-dark) !important;
    border-color: var(--dv-primary);
}

/* ========== Listado ========== */
.dv-filtros {
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 1.25rem;
    position: sticky;
    top: 90px;
}
.dv-filtros h6 {
    font-size: .85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: .8rem;
    color: var(--dv-dark);
}
.form-range::-webkit-slider-thumb { background: var(--dv-primary); }
.form-range::-moz-range-thumb     { background: var(--dv-primary); }

.dv-prop-card {
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    overflow: hidden;
    transition: box-shadow .2s ease, transform .2s ease;
    display: flex;
    flex-direction: column;
    height: 100%;
}
.dv-prop-card:hover { box-shadow: var(--dv-shadow-hover); transform: translateY(-2px); }
.dv-prop-card .dv-prop-img {
    aspect-ratio: 4/3;
    background-size: cover;
    background-position: center;
    position: relative;
}
.dv-prop-badge {
    position: absolute;
    top: .7rem;
    left: .7rem;
    background: var(--dv-primary);
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    padding: .25rem .55rem;
    border-radius: 999px;
    letter-spacing: .04em;
}
.dv-prop-badge--dark { background: var(--dv-dark); }
.dv-prop-fav {
    position: absolute;
    top: .7rem;
    right: .7rem;
    width: 36px;
    height: 36px;
    background: rgba(255,255,255,.95);
    border-radius: 50%;
    display: grid;
    place-items: center;
    color: var(--dv-dark);
    font-size: 1.1rem;
    border: 0;
    cursor: pointer;
    transition: color .15s, transform .15s;
}
.dv-prop-fav:hover { color: var(--dv-primary-dark); transform: scale(1.08); }
.dv-prop-body { padding: 1rem 1.1rem 1.2rem; flex: 1; display: flex; flex-direction: column; }
.dv-prop-body h5 { font-size: 1.05rem; margin-bottom: .25rem; }
.dv-prop-loc { font-size: .85rem; color: var(--dv-muted); margin-bottom: .6rem; }
.dv-prop-feat {
    font-size: .82rem;
    color: var(--dv-muted);
    display: flex;
    flex-wrap: wrap;
    gap: .9rem;
    margin-bottom: .8rem;
}
.dv-prop-feat i { color: var(--dv-dark); margin-right: .25rem; }
.dv-prop-price {
    margin-top: auto;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    padding-top: .6rem;
    border-top: 1px dashed var(--dv-border);
}
.dv-prop-price .amount { font-size: 1.2rem; font-weight: 700; color: var(--dv-dark); }
.dv-prop-price .per { font-size: .8rem; color: var(--dv-muted); }
.dv-prop-rating { font-size: .85rem; color: var(--dv-dark); font-weight: 600; }
.dv-prop-rating i { color: #FFC107; }
.dv-prop-tag {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--dv-soft, #f8f5f0);
    color: var(--dv-primary);
    display: grid; place-items: center;
    font-size: .9rem;
}

/* Estado vacío del listado de búsqueda */
.dv-empty-state {
    background: var(--dv-soft, #f8f5f0);
    border: 1px dashed var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 3rem 1.5rem;
}
.dv-empty-state .dv-empty-icon {
    width: 72px; height: 72px;
    margin: 0 auto;
    border-radius: 50%;
    background: #fff;
    display: grid; place-items: center;
    color: var(--dv-primary);
    font-size: 1.8rem;
    box-shadow: 0 2px 6px rgba(55,71,79,.05);
}

/* ========== Detalle alojamiento ========== */
.dv-detail-gallery {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: .5rem;
    border-radius: var(--dv-radius);
    overflow: hidden;
    max-height: 480px;
}
.dv-detail-gallery .g-item {
    background-size: cover;
    background-position: center;
    cursor: pointer;
    border: 0;
    padding: 0;
    position: relative;
    transition: filter .15s ease;
}
.dv-detail-gallery .g-item:hover { filter: brightness(1.05); }
.dv-detail-gallery .g-item:first-child { grid-row: span 2; min-height: 360px; }
.dv-detail-gallery .g-item.last { position: relative; }
.g-item-more {
    position: absolute;
    bottom: .75rem;
    right: .75rem;
    background: rgba(255,255,255,.95);
    color: var(--dv-dark);
    padding: .4rem .85rem;
    border-radius: 999px;
    font-size: .8rem;
    font-weight: 600;
    box-shadow: 0 4px 14px rgba(0,0,0,.18);
    display: inline-flex;
    align-items: center;
    pointer-events: none;
}
@media (max-width: 768px) {
    .dv-detail-gallery { grid-template-columns: 1fr; grid-template-rows: auto; max-height: none; }
    .dv-detail-gallery .g-item { aspect-ratio: 4/3; }
    .dv-detail-gallery .g-item:first-child { grid-row: auto; min-height: 0; }
    .dv-detail-gallery .g-item:nth-child(n+3) { display: none; }
}

/* Lightbox modal */
.dv-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 28, .95);
    z-index: 1080;
    display: flex;
    align-items: center;
    justify-content: center;
}
.dv-lightbox[hidden] { display: none; }
.dv-lightbox-stage {
    max-width: min(92vw, 1200px);
    max-height: 85vh;
    display: flex;
    align-items: center;
    justify-content: center;
}
.dv-lightbox-stage img {
    max-width: 100%;
    max-height: 85vh;
    border-radius: 8px;
    box-shadow: 0 10px 40px rgba(0,0,0,.5);
}
.dv-lightbox-close,
.dv-lightbox-nav {
    position: absolute;
    background: rgba(255,255,255,.12);
    color: #fff;
    border: 0;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    cursor: pointer;
    transition: background .15s ease;
}
.dv-lightbox-close:hover,
.dv-lightbox-nav:hover { background: rgba(255,255,255,.25); }
.dv-lightbox-close { top: 1.25rem; right: 1.25rem; }
.dv-lightbox-prev  { left:  1.25rem; top: 50%; transform: translateY(-50%); }
.dv-lightbox-next  { right: 1.25rem; top: 50%; transform: translateY(-50%); }
.dv-lightbox-counter {
    position: absolute;
    bottom: 1.25rem;
    left: 50%;
    transform: translateX(-50%);
    color: #fff;
    background: rgba(0,0,0,.45);
    padding: .35rem .9rem;
    border-radius: 999px;
    font-size: .85rem;
    letter-spacing: .03em;
}
@media (max-width: 575.98px) {
    .dv-lightbox-close, .dv-lightbox-nav { width: 40px; height: 40px; font-size: 1.1rem; }
    .dv-lightbox-close { top: .75rem; right: .75rem; }
    .dv-lightbox-prev  { left:  .5rem; }
    .dv-lightbox-next  { right: .5rem; }
}

/* Listado de UFs ("Opciones disponibles") */
.dv-uf-list { display: grid; gap: 1rem; }
.dv-uf-item {
    display: grid;
    grid-template-columns: 160px 1fr 180px;
    gap: 1.25rem;
    align-items: stretch;
    padding: 1rem;
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    transition: border-color .15s ease, box-shadow .15s ease;
}
.dv-uf-item:hover { border-color: var(--dv-primary); box-shadow: 0 6px 20px rgba(55,71,79,.08); }
.dv-uf-item.is-selected {
    border-color: var(--dv-primary);
    box-shadow: 0 0 0 3px var(--dv-primary-soft);
}

/* Estado del botón Seleccionar / Seleccionada */
.dv-uf-select-on,
.dv-uf-select-off { display: inline-flex; align-items: center; }
.dv-uf-item .dv-uf-select-on  { display: none; }
.dv-uf-item .dv-uf-select-off { display: inline-flex; }
.dv-uf-item.is-selected .dv-uf-select-btn {
    background: var(--dv-primary);
    color: #fff;
    border-color: var(--dv-primary);
    pointer-events: none;
}
.dv-uf-item.is-selected .dv-uf-select-btn:hover { background: var(--dv-primary); color: #fff; }
.dv-uf-item.is-selected .dv-uf-select-on  { display: inline-flex; }
.dv-uf-item.is-selected .dv-uf-select-off { display: none; }
.dv-uf-item-img {
    background-size: cover;
    background-position: center;
    border-radius: var(--dv-radius-sm);
    min-height: 130px;
    background-color: var(--dv-bg-soft);
}
.dv-uf-item-body { display: flex; flex-direction: column; gap: .5rem; min-width: 0; }
.dv-uf-item-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: .75rem;
    flex-wrap: wrap;
}
.dv-uf-item-head h5 { font-size: 1.05rem; }
.dv-uf-item-tipo {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    padding: .2rem .6rem;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 600;
    white-space: nowrap;
}
.dv-uf-item-stats {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: .55rem 1rem;
    color: var(--dv-muted);
    font-size: .85rem;
}
.dv-uf-item-stats i { color: var(--dv-primary); margin-right: .25rem; }
.dv-uf-item-desc { line-height: 1.35; }
.dv-uf-item-cta {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-end;
    gap: .65rem;
    border-left: 1px solid var(--dv-border);
    padding-left: 1.25rem;
}
.dv-uf-item-price { text-align: right; line-height: 1.1; }
.dv-uf-item-price-amt { display: block; font-size: 1.25rem; font-weight: 700; color: var(--dv-dark); }
.dv-uf-item-price-sfx { font-size: .78rem; color: var(--dv-muted); }
@media (max-width: 767.98px) {
    .dv-uf-item { grid-template-columns: 1fr; }
    .dv-uf-item-img { aspect-ratio: 16/10; min-height: 0; }
    .dv-uf-item-cta { border-left: 0; padding-left: 0; align-items: stretch; flex-direction: row; justify-content: space-between; }
    .dv-uf-item-cta .btn { flex-shrink: 0; }
}

/* Sidebar derecho sticky (envuelve reserva + anfitrión) */
.dv-side {
    position: sticky;
    top: 90px;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.dv-anfitrion-card {
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 1rem 1.1rem;
    box-shadow: 0 2px 8px rgba(55,71,79,.04);
}
.dv-anfitrion-avatar-iniciales {
    width: 56px; height: 56px;
    border-radius: 50%;
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.1rem;
    border: 1px solid var(--dv-border);
    flex-shrink: 0;
}
@media (max-width: 991.98px) {
    .dv-side { position: static; }
}

/* Form de consulta en sidebar: el popover de huéspedes necesita overflow visible */
.dv-reserva-box { overflow: visible; }
.dv-reserva-box .dv-guests.dv-guests-compact { position: relative; }
/* Popover dentro del sidebar: position fixed para escapar del sticky del .dv-side.
   La posición exacta se setea con JS (top/left) al abrir. Botón Aplicar siempre visible. */
.dv-reserva-box .dv-guests.dv-guests-compact .dv-guests-pop {
    position: fixed !important;
    top: auto;
    right: auto;
    left: auto;
    z-index: 1090;
    max-height: 80vh;
    overflow-y: auto;
    width: 320px;
}
.dv-reserva-box .dv-guests.dv-guests-compact .dv-guests-actions {
    position: sticky;
    bottom: -.5rem;
    background: #fff;
    padding-top: .65rem;
    margin: 0 -1rem -.8rem;
    padding-left: 1rem;
    padding-right: 1rem;
    padding-bottom: .8rem;
    border-top: 1px solid var(--dv-border);
    text-align: right;
}
.dv-reserva-box .dv-field.dv-guests-compact { width: 100%; display: block; margin: 0; }
/* Label idéntico al de los inputs Llegada/Salida del sidebar */
.dv-reserva-box .dv-field.dv-guests-compact > label {
    display: block;
    font-size: .78rem;
    color: var(--dv-muted);
    margin: 0 0 .15rem 0;
    font-weight: 400;
    line-height: 1.4;
}
/* Display del huéspedes idéntico a .form-control-sm.
   Doble clase + scope a .dv-reserva-box → specificity (0,3,0)
   le gana al selector original .dv-guests .dv-guests-display (0,2,0). */
.dv-reserva-box .dv-guests-compact .dv-guests-display.dv-guests-display-compact {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: calc(1.5em + .5rem + 2px); /* same as form-control-sm */
    padding: .25rem .5rem;
    font-size: .875rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--bs-body-color, #212529);
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid var(--bs-border-color, #dee2e6);
    border-radius: var(--bs-border-radius-sm, .25rem);
    cursor: pointer;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}
.dv-reserva-box .dv-guests-compact .dv-guests-display.dv-guests-display-compact::after {
    content: '';
    width: 7px; height: 7px;
    margin-left: .35rem;
    border-right: 1.5px solid var(--dv-muted);
    border-bottom: 1.5px solid var(--dv-muted);
    transform: rotate(45deg) translate(-1px, -1px);
    flex-shrink: 0;
    transition: transform .15s ease;
}
.dv-reserva-box .dv-guests-compact .dv-guests-display.dv-guests-display-compact:hover {
    border-color: var(--dv-primary);
}
.dv-reserva-box .dv-guests-compact .dv-guests-display.dv-guests-display-compact:focus,
.dv-reserva-box .dv-guests-compact.is-open .dv-guests-display.dv-guests-display-compact {
    outline: none;
    border-color: var(--dv-primary);
    box-shadow: 0 0 0 3px var(--dv-primary-soft);
}
.dv-reserva-box .dv-guests-compact.is-open .dv-guests-display.dv-guests-display-compact::after {
    transform: rotate(-135deg) translate(-1px, -1px);
}
/* Asegurar que los inputs Llegada / Salida tengan el MISMO border-radius
   que el display de huéspedes (a veces flatpickr cambia esto). */
.dv-reserva-box input.form-control-sm {
    border-radius: var(--bs-border-radius-sm, .25rem);
}

/* Resumen de precio: noches × precio = total */
.dv-resumen-precio {
    margin-top: .25rem;
    padding: .65rem .85rem;
    background: var(--dv-bg-soft);
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
}
.dv-resumen-row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    font-size: .85rem;
    color: var(--dv-text);
    gap: .5rem;
}
.dv-resumen-row + .dv-resumen-row { margin-top: .35rem; }
.dv-resumen-total {
    padding-top: .35rem;
    border-top: 1px solid var(--dv-border);
    font-weight: 700;
    font-size: .95rem;
    color: var(--dv-dark);
}
.dv-resumen-sena {
    padding-top: .55rem;
    margin-top: .55rem !important;
    border-top: 1px dashed var(--dv-border);
    font-weight: 600;
    color: var(--dv-dark);
}
.dv-resumen-sena-pct {
    display: inline-block;
    background: var(--dv-primary-soft, #fff3df);
    color: var(--dv-primary, #FFA000);
    font-size: .68rem;
    font-weight: 700;
    padding: .05rem .4rem;
    border-radius: 999px;
    margin-left: .15rem;
    vertical-align: middle;
}
.dv-resumen-saldo {
    color: #666;
    font-size: .82rem;
}
.dv-resumen-nota {
    font-size: .7rem;
    line-height: 1.3;
    margin-top: .35rem;
    opacity: .85;
}

/* ========== Cards de edición (editar-alojamiento / editar-unidad) ========== */
.dv-edit-form { display: flex; flex-direction: column; gap: 1.25rem; }
.dv-edit-card {
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 1.4rem 1.5rem;
    box-shadow: 0 2px 8px rgba(55,71,79,.04);
}
.dv-edit-card h5 {
    font-size: 1.05rem;
    color: var(--dv-dark);
    border-bottom: 1px solid var(--dv-border);
    padding-bottom: .65rem;
}

/* Bandeja de reseñas pendientes en el dashboard */
.dv-resenas-pendientes {
    background: linear-gradient(135deg, #fff7e6 0%, #fff 100%);
    border: 1px solid #ffd9a8;
    border-radius: var(--dv-radius);
    padding: 1.1rem 1.25rem;
    box-shadow: 0 2px 8px rgba(255,160,0,.08);
}
.dv-resenas-pendientes-head { margin-bottom: .85rem; }
.dv-resena-pend-list { display: flex; flex-direction: column; gap: .75rem; }
.dv-resena-pend {
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    padding: .85rem 1rem;
}
.dv-resena-pend-header { display: flex; align-items: center; gap: .75rem; }
.dv-resena-pend-rating { color: #ffc107; font-size: .95rem; letter-spacing: 1px; flex-shrink: 0; }
.dv-resena-pend-rating .bi-star { color: #d9d9d9; }
.dv-resena-pend-actions { display: flex; gap: .5rem; flex-wrap: wrap; }

/* Rating con estrellas (modal reseña) */
.dv-rating-stars { display: inline-flex; align-items: center; gap: .35rem; }
.dv-rating-star {
    background: transparent; border: 0; padding: 0;
    color: #c8c8c8;
    font-size: 1.7rem;
    cursor: pointer;
    transition: transform .12s ease, color .12s ease;
}
.dv-rating-star:hover { transform: scale(1.1); }
.dv-rating-star.is-active,
.dv-rating-stars:hover .dv-rating-star { color: #ffc107; }

/* Avatar circular para reseñas (iniciales) */
.dv-review-avatar {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: .95rem;
    flex-shrink: 0;
}
.dv-review-respuesta {
    padding: .65rem .85rem;
    background: var(--dv-bg-soft);
    border-left: 3px solid var(--dv-primary);
    border-radius: 0 var(--dv-radius-sm) var(--dv-radius-sm) 0;
}

/* Hero del perfil del usuario */
.dv-perfil-hero {
    display: flex;
    align-items: center;
    gap: 1.1rem;
    padding: 1.1rem 1.3rem;
    background: linear-gradient(135deg, var(--dv-primary-soft) 0%, #fff 100%);
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
}
.dv-perfil-avatar,
.dv-perfil-avatar-iniciales {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    border: 2px solid #fff;
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
    flex-shrink: 0;
}
.dv-perfil-avatar { object-fit: cover; }
.dv-perfil-avatar-wrap { position: relative; }
.dv-perfil-avatar-edit {
    position: absolute;
    bottom: -2px; right: -2px;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--dv-primary);
    color: #fff;
    border: 2px solid #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 2px 6px rgba(0,0,0,.15);
    transition: transform .15s ease;
    font-size: .75rem;
}
.dv-perfil-avatar-edit:hover { transform: scale(1.1); }
.dv-perfil-avatar-iniciales {
    background: var(--dv-primary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.4rem;
    letter-spacing: .02em;
}
@media (max-width: 575.98px) {
    .dv-perfil-hero { flex-wrap: wrap; }
}

/* Editor de fotos existentes (alojamiento) */
.dv-fotos-actuales {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: .75rem;
}
.dv-foto-actual {
    position: relative;
    aspect-ratio: 4/3;
    border-radius: var(--dv-radius-sm);
    overflow: hidden;
    border: 2px solid transparent;
    background: var(--dv-bg-soft);
}
.dv-foto-actual.is-portada {
    border-color: var(--dv-primary);
    box-shadow: 0 0 0 3px var(--dv-primary-soft);
}
.dv-foto-actual img {
    width: 100%; height: 100%; object-fit: cover; display: block;
}
.dv-foto-badge {
    position: absolute;
    top: .5rem; left: .5rem;
    background: var(--dv-primary);
    color: #fff;
    padding: .15rem .5rem;
    border-radius: 999px;
    font-size: .68rem;
    font-weight: 600;
    letter-spacing: .03em;
}
.dv-foto-actions {
    position: absolute;
    top: .4rem; right: .4rem;
    display: flex; gap: .25rem;
    opacity: 0;
    transition: opacity .15s ease;
}
.dv-foto-actual:hover .dv-foto-actions,
.dv-foto-actual:focus-within .dv-foto-actions { opacity: 1; }
.dv-foto-btn {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: rgba(255,255,255,.95);
    color: var(--dv-dark);
    border: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .12s ease, color .12s ease;
    font-size: .85rem;
}
.dv-foto-btn:hover { background: var(--dv-primary); color: #fff; }
.dv-foto-btn-danger:hover { background: #dc3545; }

.dv-uf-edit-list { display: flex; flex-direction: column; gap: .55rem; }
.dv-uf-edit-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .75rem 1rem;
    background: var(--dv-bg-soft);
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    flex-wrap: wrap;
}
.dv-uf-edit-item:hover { border-color: var(--dv-primary); }
.dv-uf-edit-item .dv-uf-item-tipo {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    padding: .1rem .5rem;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 600;
    margin-left: .35rem;
}

/* ========== Modal de consulta ========== */
.dv-modal {
    position: fixed;
    inset: 0;
    z-index: 1090;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}
.dv-modal[hidden] { display: none; }
.dv-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 28, .55);
    backdrop-filter: blur(2px);
}
.dv-modal-dialog {
    position: relative;
    background: #fff;
    border-radius: var(--dv-radius);
    box-shadow: 0 20px 60px rgba(0,0,0,.25);
    width: 100%;
    max-width: 580px;
    padding: 1.6rem 1.6rem 1.4rem;
    max-height: 90vh;
    overflow-y: auto;
    animation: dvModalIn .18s ease-out;
}
@keyframes dvModalIn {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}
.dv-modal-close {
    position: absolute;
    top: .85rem; right: .85rem;
    width: 34px; height: 34px;
    border-radius: 50%;
    border: 0;
    background: var(--dv-bg-soft);
    color: var(--dv-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .15s ease;
}
.dv-modal-close:hover { background: var(--dv-border); }
.dv-modal-resumen {
    padding: .55rem .85rem;
    background: var(--dv-bg-soft);
    border-radius: var(--dv-radius-sm);
    line-height: 1.4;
}
.dv-modal-resumen i { color: var(--dv-primary); }
.dv-btn-loader { display: inline-flex; align-items: center; gap: .35rem; }
.dv-btn-loader i { animation: dvSpin 1s linear infinite; }
@keyframes dvSpin { to { transform: rotate(360deg); } }

@media (max-width: 575.98px) {
    .dv-modal-dialog { padding: 1.2rem 1.1rem 1.1rem; }
}

/* Toast (botón Compartir y otros) */
.dv-toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--dv-dark);
    color: #fff;
    padding: .7rem 1.2rem;
    border-radius: 999px;
    font-size: .9rem;
    box-shadow: 0 10px 30px rgba(0,0,0,.25);
    z-index: 1090;
    opacity: 1;
    transition: opacity .4s ease, transform .4s ease;
}
.dv-toast.is-out { opacity: 0; transform: translate(-50%, 10px); }

.dv-amenity {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .55rem 0;
    color: var(--dv-text);
}
.dv-amenity i { color: var(--dv-primary); font-size: 1.2rem; }

.dv-reserva-box {
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 1.4rem;
    box-shadow: var(--dv-shadow);
    /* El sticky vive ahora en .dv-side (el wrapper de reserva + anfitrión),
       para que ambas cards viajen juntas y no se monten una sobre otra. */
}

/* ========== Publicar ========== */
.dv-plan-card {
    background: #fff;
    border: 2px solid var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 2rem 1.6rem;
    height: 100%;
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.dv-plan-card:hover { transform: translateY(-3px); box-shadow: var(--dv-shadow); }
.dv-plan-card.is-featured {
    border-color: var(--dv-primary);
    box-shadow: 0 8px 30px rgba(255,160,0,.18);
    position: relative;
}
.dv-plan-card.is-featured::before {
    content: 'Más elegido';
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--dv-primary);
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    padding: .3rem .8rem;
    border-radius: 999px;
}
.dv-plan-price { font-size: 2.2rem; font-weight: 700; color: var(--dv-dark); line-height: 1.1; }
.dv-plan-price .currency { font-size: 1rem; color: var(--dv-muted); font-weight: 500; }
.dv-plan-price-equiv {
    font-size: .92rem;
    color: var(--dv-primary-dark);
    background: var(--dv-primary-soft);
    border-radius: var(--dv-radius-sm);
    padding: .5rem .75rem;
    margin: .6rem 0 0;
}
.dv-plan-price-equiv strong { color: var(--dv-primary-dark); }
.dv-plan-features { padding: 0; margin: 1.2rem 0; list-style: none; }
.dv-plan-features li {
    padding: .4rem 0;
    color: var(--dv-text);
    display: flex;
    gap: .55rem;
    align-items: flex-start;
}
.dv-plan-features li i.bi-check2-circle { color: #2e7d32; font-size: 1.1rem; }
.dv-plan-features li i.bi-x-circle { color: #BDC4C9; font-size: 1.1rem; }

.dv-rf-badge {
    background: var(--dv-primary-soft);
    border: 1px dashed var(--dv-primary);
    color: var(--dv-primary-dark);
    border-radius: var(--dv-radius);
    padding: 1rem 1.2rem;
    font-size: .92rem;
}
.dv-rf-badge strong { color: var(--dv-primary-dark); }

/* Card destacada Reservafácil dentro de la sección de planes */
.dv-rf-plancard {
    position: relative;
    background: linear-gradient(135deg, var(--dv-dark) 0%, #2A3940 100%);
    color: #fff;
    border-radius: var(--dv-radius-lg);
    padding: 1.8rem 1.8rem 1.5rem;
    overflow: hidden;
    box-shadow: var(--dv-shadow);
}
.dv-rf-plancard::before {
    content: '';
    position: absolute;
    top: -60px;
    right: -60px;
    width: 220px; height: 220px;
    background: radial-gradient(circle, rgba(255,160,0,.35) 0%, transparent 70%);
    pointer-events: none;
}
.dv-rf-plancard > * { position: relative; z-index: 1; }
.dv-rf-plancard h4 { color: #fff; font-size: 1.35rem; }
.dv-rf-plancard p { color: rgba(255,255,255,.85); font-size: .95rem; margin: 0; }
.dv-rf-plancard p strong { color: #fff; }
.dv-rf-plancard .dv-plan-price { color: #fff; font-size: 2.2rem; }
.dv-rf-plancard .dv-plan-price .currency { color: rgba(255,255,255,.7); }
.dv-rf-plancard-badge {
    display: inline-block;
    background: var(--dv-primary);
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: .3rem .75rem;
    border-radius: 999px;
    margin-bottom: .8rem;
}
.dv-rf-plancard .btn-dv-dark {
    --bs-btn-bg: #fff;
    --bs-btn-border-color: #fff;
    --bs-btn-color: var(--dv-dark);
    --bs-btn-hover-bg: var(--dv-primary);
    --bs-btn-hover-border-color: var(--dv-primary);
    --bs-btn-hover-color: #fff;
}

/* ========== Step cards (landing publicar) ========== */
.dv-step-card {
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 1.6rem 1.4rem;
    height: 100%;
    text-align: left;
    transition: box-shadow .2s ease, transform .2s ease;
}
.dv-step-card:hover { box-shadow: var(--dv-shadow); transform: translateY(-3px); }
.dv-step-card .dv-step-num {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    display: grid; place-items: center;
    font-weight: 700;
    font-size: 1.15rem;
    margin-bottom: 1rem;
}
.dv-step-card h5 { margin-bottom: .35rem; }

/* ========== Type cards (tipo de alojamiento) ========== */
.dv-type-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: .65rem;
    margin-top: .35rem;
}
.dv-type-card {
    display: block;
    position: relative;
    cursor: pointer;
    margin: 0;
}
.dv-type-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.dv-type-card-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .45rem;
    padding: 1rem .8rem;
    background: #fff;
    border: 2px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    transition: border-color .15s ease, background .15s ease, transform .15s ease, box-shadow .15s ease;
    text-align: center;
}
.dv-type-card-inner i {
    font-size: 1.7rem;
    color: var(--dv-dark);
    transition: color .15s ease, transform .2s ease;
}
.dv-type-card-name {
    font-size: .88rem;
    font-weight: 600;
    color: var(--dv-dark);
    line-height: 1.2;
}
.dv-type-card:hover .dv-type-card-inner {
    border-color: var(--dv-primary);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(55,71,79,.08);
}
.dv-type-card input:checked + .dv-type-card-inner {
    border-color: var(--dv-primary);
    background: var(--dv-primary-soft);
    box-shadow: 0 0 0 3px var(--dv-primary-soft);
}
.dv-type-card input:checked + .dv-type-card-inner i {
    color: var(--dv-primary-dark);
    transform: scale(1.1);
}

/* ========== Stepper card (huéspedes, dormitorios, etc.) ========== */
.dv-stepper-card {
    background: #fff;
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    padding: .75rem .9rem;
    transition: border-color .15s ease;
}
.dv-stepper-card:focus-within {
    border-color: var(--dv-primary);
    box-shadow: 0 0 0 3px var(--dv-primary-soft);
}
.dv-stepper-card-label {
    font-size: .78rem;
    color: var(--dv-muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .03em;
    margin-bottom: .35rem;
    display: flex;
    align-items: center;
    gap: .35rem;
}
.dv-stepper-card-label i { color: var(--dv-primary); font-size: 1rem; }
.dv-stepper-card-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .35rem;
}
.dv-stepper-btn {
    width: 32px; height: 32px;
    border-radius: 50%;
    border: 1.5px solid var(--dv-border);
    background: #fff;
    color: var(--dv-dark);
    display: grid; place-items: center;
    font-size: 1rem;
    line-height: 0;
    cursor: pointer;
    transition: background .12s ease, color .12s ease, border-color .12s ease;
    flex-shrink: 0;
}
.dv-stepper-btn:hover:not(:disabled) {
    background: var(--dv-primary);
    color: #fff;
    border-color: var(--dv-primary);
}
.dv-stepper-btn:disabled {
    color: #C9D1D6;
    border-color: #E6EAED;
    cursor: not-allowed;
}
.dv-stepper-card-row input {
    flex: 1;
    border: 0;
    background: transparent;
    text-align: center;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--dv-dark);
    width: 100%;
    padding: 0;
    min-width: 0;
    -moz-appearance: textfield;
    appearance: textfield;
}
.dv-stepper-card-row input::-webkit-outer-spin-button,
.dv-stepper-card-row input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.dv-stepper-card-row input:focus { outline: none; }

/* ========== Chips (comodidades) ========== */
.dv-chip-grid {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.dv-chip {
    display: inline-block;
    cursor: pointer;
    margin: 0;
}
.dv-chip input { position: absolute; opacity: 0; pointer-events: none; }
.dv-chip-inner {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .55rem 1rem;
    background: #fff;
    border: 1.5px solid var(--dv-border);
    border-radius: 999px;
    font-size: .88rem;
    font-weight: 500;
    color: var(--dv-dark);
    transition: all .15s ease;
    user-select: none;
}
.dv-chip-inner i { color: var(--dv-muted); font-size: 1rem; transition: color .15s ease; }
.dv-chip:hover .dv-chip-inner {
    border-color: var(--dv-primary);
    background: var(--dv-bg-soft);
}
.dv-chip input:checked + .dv-chip-inner {
    border-color: var(--dv-primary);
    background: var(--dv-primary);
    color: #fff;
    box-shadow: 0 4px 10px rgba(255,160,0,.25);
}
.dv-chip input:checked + .dv-chip-inner i { color: #fff; }
.dv-chip input:focus-visible + .dv-chip-inner {
    box-shadow: 0 0 0 3px var(--dv-primary-soft);
}

/* ========== Counter horizontal (cantidad de unidades, etc.) ========== */
.dv-counter {
    display: flex;
    align-items: stretch;
    background: #fff;
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    overflow: hidden;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.dv-counter:focus-within {
    border-color: var(--dv-primary);
    box-shadow: 0 0 0 .2rem rgba(var(--dv-primary-rgb), .18);
}
.dv-counter-btn-lg {
    width: 44px;
    background: var(--dv-bg-soft);
    border: 0;
    color: var(--dv-dark);
    font-size: 1.2rem;
    cursor: pointer;
    transition: background .12s ease, color .12s ease;
    display: grid;
    place-items: center;
    line-height: 0;
}
.dv-counter-btn-lg:hover:not(:disabled) {
    background: var(--dv-primary);
    color: #fff;
}
.dv-counter-btn-lg:disabled {
    color: #C9D1D6;
    cursor: not-allowed;
}
.dv-counter-display {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: .3rem .4rem;
    line-height: 1.1;
}
.dv-counter-input {
    border: 0;
    background: transparent;
    text-align: center;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--dv-dark);
    width: 100%;
    padding: 0;
    -moz-appearance: textfield;
    appearance: textfield;
}
.dv-counter-input::-webkit-outer-spin-button,
.dv-counter-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.dv-counter-input:focus { outline: none; }
.dv-counter-suffix {
    font-size: .72rem;
    color: var(--dv-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-top: 2px;
}

/* ========== Google Places — input con ícono ========== */
.dv-places-wrap { position: relative; }
.dv-places-icon {
    position: absolute;
    left: .9rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--dv-primary);
    font-size: 1.05rem;
    pointer-events: none;
    z-index: 2;
}
.dv-places-input { padding-left: 2.4rem !important; }
.dv-places-hint {
    display: block;
    font-size: .78rem;
    color: var(--dv-muted);
    margin-top: 4px;
    transition: color .15s ease;
}
.dv-places-hint.is-warn { color: #c62828; }

/* Google Places dropdown — paleta de marca */
.pac-container {
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    box-shadow: var(--dv-shadow-hover);
    margin-top: 6px;
    font-family: 'Inter', sans-serif;
    padding: .25rem 0;
}
.pac-container::after { display: none !important; } /* sacar logo "Powered by Google" interno */
.pac-item {
    padding: .5rem .9rem;
    cursor: pointer;
    border-top: 0;
    line-height: 1.4;
}
.pac-item:hover, .pac-item-selected { background: var(--dv-primary-soft); color: var(--dv-primary-dark); }
.pac-item .pac-icon { display: none; }
.pac-item-query { font-weight: 600; color: var(--dv-dark); font-size: .92rem; }
.pac-matched { color: var(--dv-primary-dark); font-weight: 700; }

/* ========== WIZARD CARGA DE ALOJAMIENTO ========== */
.dv-stepper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0;
    margin: 2rem 0 2.5rem;
    max-width: 880px;
    margin-left: auto;
    margin-right: auto;
}
.dv-stepper-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .35rem;
    cursor: pointer;
    flex-shrink: 0;
    min-width: 100px;
}
.dv-stepper-circle {
    width: 38px; height: 38px;
    border-radius: 50%;
    background: var(--dv-bg-soft);
    color: var(--dv-muted);
    display: grid; place-items: center;
    font-weight: 700;
    font-size: .95rem;
    border: 2px solid transparent;
    transition: all .2s ease;
}
.dv-stepper-label {
    font-size: .82rem;
    color: var(--dv-muted);
    font-weight: 600;
    text-align: center;
}
.dv-stepper-step.is-active .dv-stepper-circle {
    background: var(--dv-primary);
    color: #fff;
    box-shadow: 0 0 0 6px var(--dv-primary-soft);
}
.dv-stepper-step.is-active .dv-stepper-label { color: var(--dv-dark); }
.dv-stepper-step.is-done .dv-stepper-circle {
    background: #fff;
    color: var(--dv-primary-dark);
    border-color: var(--dv-primary);
}
.dv-stepper-step.is-done .dv-stepper-circle::before {
    content: '\F26B'; /* bi-check */
    font-family: 'bootstrap-icons';
    font-size: 1.1rem;
}
.dv-stepper-step.is-done .dv-stepper-circle { font-size: 0; }
.dv-stepper-step.is-done .dv-stepper-label { color: var(--dv-dark); }
.dv-stepper-line {
    flex: 1;
    height: 2px;
    background: var(--dv-border);
    margin: 0 .5rem;
    margin-bottom: 28px;
    border-radius: 2px;
    transition: background .25s ease;
}
.dv-stepper-line.is-done { background: var(--dv-primary); }
@media (max-width: 768px) {
    .dv-stepper-step { min-width: 70px; }
    .dv-stepper-label { font-size: .72rem; }
    .dv-stepper-line { margin-bottom: 26px; }
}

.dv-wizard-card {
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    box-shadow: var(--dv-shadow);
    padding: 2rem 2rem 2.2rem;
}
@media (max-width: 640px) { .dv-wizard-card { padding: 1.25rem 1rem 1.5rem; } }

.dv-step-panel { display: none; }
.dv-step-panel.is-active { display: block; animation: dvFadeIn .25s ease; }
@keyframes dvFadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.dv-wizard-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-top: 1.5rem;
    padding: 1rem 0;
}
.dv-wizard-progress { font-size: .9rem; color: var(--dv-muted); }
.dv-wizard-progress strong { color: var(--dv-dark); }

/* ========== Price box (precio + moneda) ========== */
.dv-price-box {
    background: #fff;
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    padding: .75rem 1rem 1rem;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.dv-price-box:focus-within {
    border-color: var(--dv-primary);
    box-shadow: 0 0 0 3px var(--dv-primary-soft);
}
.dv-price-label {
    display: block;
    font-size: .78rem;
    color: var(--dv-muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .03em;
    margin-bottom: .25rem;
}
.dv-price-row {
    display: flex;
    align-items: baseline;
    gap: .35rem;
    margin-bottom: .65rem;
}
.dv-price-currency {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--dv-muted);
}
.dv-price-row input {
    border: 0;
    background: transparent;
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--dv-dark);
    flex: 1;
    width: 100%;
    padding: 0;
    -moz-appearance: textfield;
}
.dv-price-row input::-webkit-outer-spin-button,
.dv-price-row input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.dv-price-row input:focus { outline: none; }

.dv-price-pills {
    display: inline-flex;
    background: var(--dv-bg-soft);
    border-radius: 999px;
    padding: 3px;
    gap: 0;
}
.dv-pill {
    border: 0;
    background: transparent;
    color: var(--dv-muted);
    font-size: .82rem;
    font-weight: 600;
    padding: .35rem .8rem;
    border-radius: 999px;
    cursor: pointer;
    transition: background .15s ease, color .15s ease;
}
.dv-pill:hover { color: var(--dv-dark); }
.dv-pill.is-active {
    background: #fff;
    color: var(--dv-dark);
    box-shadow: 0 1px 3px rgba(0,0,0,.08);
}

/* ========== Time card (check-in / check-out) ========== */
.dv-time-card {
    display: flex;
    align-items: center;
    gap: .9rem;
    background: #fff;
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    padding: .85rem 1.1rem;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.dv-time-card:focus-within {
    border-color: var(--dv-primary);
    box-shadow: 0 0 0 3px var(--dv-primary-soft);
}
.dv-time-icon {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    display: grid; place-items: center;
    font-size: 1.3rem;
    flex-shrink: 0;
}
.dv-time-body { flex: 1; min-width: 0; }
.dv-time-label {
    display: block;
    font-size: .78rem;
    color: var(--dv-muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .03em;
    margin-bottom: 0;
}
.dv-time-input {
    border: 0;
    background: transparent;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--dv-dark);
    padding: 0;
    width: 100%;
    font-family: inherit;
}
.dv-time-input:focus { outline: none; }

/* ========== Radio cards (política de cancelación) ========== */
.dv-radio-card {
    display: block;
    padding: 0;
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    cursor: pointer;
    transition: border-color .15s ease, background .15s ease, transform .12s ease;
    overflow: hidden;
    margin: 0;
}
.dv-radio-card:hover { transform: translateY(-1px); background: var(--dv-bg-soft); }
.dv-radio-card input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.dv-radio-card-body {
    display: flex;
    align-items: center;
    gap: .9rem;
    padding: .9rem 1rem;
}
.dv-radio-card-icon {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: var(--dv-bg-soft);
    color: var(--dv-muted);
    display: grid; place-items: center;
    font-size: 1.15rem;
    flex-shrink: 0;
    transition: background .15s ease, color .15s ease;
}
.dv-radio-card:has(input:checked) {
    border-color: var(--dv-primary);
    background: var(--dv-primary-soft);
}
.dv-radio-card:has(input:checked) .dv-radio-card-icon {
    background: var(--dv-primary);
    color: #fff;
}

/* ========== Slider de garantía ========== */
.dv-slider-box {
    background: #fff;
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    padding: 1rem 1.2rem 1.1rem;
    transition: border-color .15s ease;
}
.dv-slider-box:focus-within { border-color: var(--dv-primary); }
.dv-slider-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: .6rem;
}
.dv-slider-val {
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--dv-primary-dark);
    line-height: 1;
}
.dv-slider-unit { font-size: 1.2rem; }
.dv-slider {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 6px;
    border-radius: 999px;
    background: var(--dv-bg-soft);
    outline: none;
    background-image: linear-gradient(var(--dv-primary), var(--dv-primary));
    background-repeat: no-repeat;
    background-size: 30% 100%;
}
.dv-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 22px; height: 22px;
    border-radius: 50%;
    background: #fff;
    border: 3px solid var(--dv-primary);
    box-shadow: 0 2px 6px rgba(0,0,0,.18);
    cursor: pointer;
    transition: transform .12s ease;
}
.dv-slider::-webkit-slider-thumb:hover { transform: scale(1.1); }
.dv-slider::-moz-range-thumb {
    width: 22px; height: 22px;
    border-radius: 50%;
    background: #fff;
    border: 3px solid var(--dv-primary);
    box-shadow: 0 2px 6px rgba(0,0,0,.18);
    cursor: pointer;
}
.dv-slider-marks {
    display: flex;
    justify-content: space-between;
    margin-top: .55rem;
    font-size: .72rem;
    color: var(--dv-muted);
    font-weight: 600;
}

/* ========== Accept card (T&C) ========== */
.dv-accept-card {
    display: flex;
    align-items: center;
    gap: .85rem;
    padding: .9rem 1.1rem;
    background: var(--dv-bg-soft);
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    cursor: pointer;
    transition: border-color .15s ease, background .15s ease;
    margin: 0;
}
.dv-accept-card:hover { border-color: var(--dv-primary); }
.dv-accept-card input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.dv-accept-check {
    width: 28px; height: 28px;
    border-radius: 8px;
    background: #fff;
    border: 2px solid var(--dv-border);
    display: grid; place-items: center;
    flex-shrink: 0;
    color: transparent;
    font-size: 1rem;
    transition: all .15s ease;
}
.dv-accept-card input:checked + .dv-accept-check {
    background: var(--dv-primary);
    border-color: var(--dv-primary);
    color: #fff;
}
.dv-accept-card:has(input:checked) {
    background: var(--dv-primary-soft);
    border-color: var(--dv-primary);
}
.dv-accept-text { font-size: .92rem; color: var(--dv-dark); line-height: 1.4; }

/* Resumen del paso final */
.dv-resumen {
    background: var(--dv-bg-soft);
    border-radius: var(--dv-radius-sm);
    padding: 1rem 1.2rem;
}

/* Tarjeta de identidad cuando el usuario ya está logueado (wizard) */
.dv-user-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: .85rem 1.1rem;
    background: var(--dv-bg-soft);
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
}
.dv-user-card-avatar {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid var(--dv-border);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--dv-muted);
    font-size: 2rem;
}
.dv-user-card-avatar img { width: 100%; height: 100%; object-fit: cover; }
.dv-user-card-body { flex: 1; min-width: 0; line-height: 1.25; }
.dv-user-card-body strong { color: var(--dv-dark); display: block; }
.dv-user-card-aside {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: .15rem;
    flex-shrink: 0;
}
.dv-user-card-aside a { color: var(--dv-primary-dark); text-decoration: none; }
.dv-user-card-aside a:hover { text-decoration: underline; }
@media (max-width: 575.98px) {
    .dv-user-card { flex-wrap: wrap; }
    .dv-user-card-aside { align-items: flex-start; width: 100%; }
}

/* Plan picker (paso 4) */
.dv-plan-pick { display: block; cursor: pointer; }
.dv-plan-pick input { position: absolute; opacity: 0; pointer-events: none; }
.dv-plan-pick-card {
    position: relative;
    border: 2px solid var(--dv-border);
    border-radius: var(--dv-radius);
    background: #fff;
    padding: 1.2rem 1.3rem;
    transition: border-color .2s ease, box-shadow .2s ease, transform .15s ease;
    height: 100%;
}
.dv-plan-pick:hover .dv-plan-pick-card { transform: translateY(-2px); box-shadow: var(--dv-shadow); }
.dv-plan-pick input:checked + .dv-plan-pick-card {
    border-color: var(--dv-primary);
    box-shadow: 0 0 0 4px var(--dv-primary-soft);
}
/* Estado NO seleccionado: gris suave (incluso si la card tiene .is-featured / .is-rf) */
.dv-plan-pick input:not(:checked) + .dv-plan-pick-card {
    border-color: var(--dv-border);
    box-shadow: none;
    opacity: .85;
}
.dv-plan-pick input:not(:checked) + .dv-plan-pick-card.is-rf {
    border-color: var(--dv-border);
    opacity: .9;
}
.dv-plan-pick-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: .5rem;
}
.dv-plan-price-mini { font-size: 1.3rem; font-weight: 700; color: var(--dv-dark); white-space: nowrap; }
.dv-plan-price-mini small { font-size: .8rem; color: var(--dv-muted); font-weight: 500; }
.dv-plan-pick-card.is-featured { border-color: var(--dv-primary); }
.dv-plan-pick-card.is-featured .dv-plan-pick-badge {
    position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
    background: var(--dv-primary); color: #fff;
    font-size: .7rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .05em; padding: .25rem .7rem; border-radius: 999px;
}
.dv-plan-pick-card.is-rf {
    background: linear-gradient(135deg, var(--dv-dark) 0%, #2A3940 100%);
    color: #fff;
    border-color: var(--dv-dark);
}
.dv-plan-pick-card.is-rf .dv-plan-pick-badge {
    position: relative; top: 0; left: 0; transform: none;
    background: var(--dv-primary); color: #fff;
    display: inline-block; font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .05em;
    padding: .25rem .75rem; border-radius: 999px; margin-bottom: .55rem;
}
.dv-plan-pick-card.is-rf h5 { color: #fff; }
.dv-plan-pick-card.is-rf .dv-plan-features li { color: rgba(255,255,255,.85); }
.dv-plan-pick input:checked + .dv-plan-pick-card.is-rf {
    box-shadow: 0 0 0 4px rgba(255,160,0,.45);
}

/* Dropzone */
.dv-dropzone {
    border: 2px dashed var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 1.5rem;
    background: var(--dv-bg-soft);
    transition: border-color .15s ease, background .15s ease;
}
.dv-dropzone.is-drag { border-color: var(--dv-primary); background: var(--dv-primary-soft); }
.dv-dropzone.is-error {
    border-color: #c62828;
    background: #FEEBEC;
    animation: dvShake .35s ease;
}
@keyframes dvShake {
    0%, 100% { transform: translateX(0); }
    20%      { transform: translateX(-6px); }
    40%      { transform: translateX(6px); }
    60%      { transform: translateX(-4px); }
    80%      { transform: translateX(4px); }
}
.dv-fotos-counter {
    font-size: .82rem;
    color: var(--dv-muted);
    background: var(--dv-bg-soft);
    padding: .15rem .55rem;
    border-radius: 999px;
    font-weight: 600;
}
.dv-fotos-counter.is-ok {
    background: #E0F2F1;
    color: #00695C;
}
.dv-fotos-error {
    margin-top: .6rem;
    background: #FEEBEC;
    color: #b71c1c;
    border: 1px solid #F4C7C7;
    border-radius: var(--dv-radius-sm);
    padding: .65rem .9rem;
    font-size: .9rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}
.dv-fotos-error[hidden] { display: none; }
.dv-dropzone-empty {
    text-align: center;
    color: var(--dv-muted);
    padding: 1rem;
}
.dv-dropzone-empty i { font-size: 2.4rem; color: var(--dv-primary); display: block; margin-bottom: .5rem; }
.dv-dropzone-empty .btn-link { color: var(--dv-primary-dark); font-weight: 600; }
.dv-dropzone-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: .55rem;
    margin-top: .5rem;
}
.dv-dropzone-thumb {
    position: relative;
    aspect-ratio: 1;
    border-radius: var(--dv-radius-sm);
    overflow: hidden;
    background: #fff;
    border: 1px solid var(--dv-border);
}
.dv-dropzone-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.dv-dropzone-remove {
    position: absolute; top: 4px; right: 4px;
    width: 24px; height: 24px;
    border-radius: 50%;
    background: rgba(0,0,0,.6);
    color: #fff;
    border: 0;
    display: grid; place-items: center;
    cursor: pointer;
    font-size: 1rem;
    line-height: 0;
}
.dv-dropzone-remove:hover { background: #c62828; }

/* Eyebrow (etiqueta arriba del título de sección) */
.dv-eyebrow {
    display: inline-block;
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: .35rem .8rem;
    border-radius: 999px;
}

/* Mock de pantalla de Reservafácil */
.dv-rf-mock { position: relative; }
.dv-rf-mock::before {
    content: '';
    position: absolute;
    inset: 20px;
    background: linear-gradient(135deg, var(--dv-primary-soft), #fff);
    border-radius: var(--dv-radius-lg);
    z-index: 0;
    transform: rotate(-3deg);
}
.dv-rf-mock-window {
    position: relative;
    z-index: 1;
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    box-shadow: var(--dv-shadow-hover);
    overflow: hidden;
}
.dv-rf-mock-bar {
    display: flex;
    align-items: center;
    gap: .35rem;
    padding: .55rem .8rem;
    background: var(--dv-bg-soft);
    border-bottom: 1px solid var(--dv-border);
}
.dv-rf-mock-bar .dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
.dv-rf-mock-bar .dot--red    { background: #FF6F6F; }
.dv-rf-mock-bar .dot--yellow { background: #FFC857; }
.dv-rf-mock-bar .dot--green  { background: #4CC38A; }
.dv-rf-mock-body { padding: 1.1rem 1.2rem 1.3rem; }
.dv-rf-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 6px;
}
.dv-rf-cell {
    aspect-ratio: 1;
    background: var(--dv-bg-soft);
    border-radius: 6px;
    display: grid;
    place-items: center;
    font-size: .8rem;
    color: var(--dv-muted);
}
.dv-rf-cell.is-booked  { background: var(--dv-primary); color: #fff; font-weight: 700; }
.dv-rf-cell.is-blocked { background: var(--dv-dark); color: #fff; font-weight: 700; }
.dv-rf-legend {
    display: inline-block;
    width: 12px; height: 12px;
    border-radius: 3px;
    background: var(--dv-bg-soft);
    vertical-align: middle;
    margin-right: 4px;
}
.dv-rf-legend.is-booked  { background: var(--dv-primary); }
.dv-rf-legend.is-blocked { background: var(--dv-dark); }

/* Card toggle Reservafácil (en formulario de carga) */
.dv-rf-toggle {
    display: block;
    cursor: pointer;
    margin: 0;
    position: relative;
}
.dv-rf-toggle-input {
    position: absolute;
    opacity: 0;
    width: 0; height: 0;
    pointer-events: none;
}
.dv-rf-toggle-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    background: #fff;
    border: 2px solid var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 1rem 1.2rem;
    transition: border-color .25s ease, background .25s ease, box-shadow .25s ease, transform .15s ease;
}
.dv-rf-toggle:hover .dv-rf-toggle-card {
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(55, 71, 79, .08);
}
.dv-rf-toggle-icon {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    display: grid; place-items: center;
    font-size: 1.4rem;
    flex-shrink: 0;
    transition: background .25s ease, color .25s ease, transform .25s ease;
}
.dv-rf-toggle-body { flex: 1; min-width: 0; }
.dv-rf-toggle-title {
    font-weight: 700;
    color: var(--dv-dark);
    font-size: 1rem;
    line-height: 1.2;
    margin-bottom: 2px;
}
.dv-rf-toggle-sub {
    font-size: .85rem;
    color: var(--dv-muted);
    line-height: 1.35;
}
.dv-rf-toggle-sub strong { color: var(--dv-primary-dark); }

/* Switch a la derecha */
.dv-rf-toggle-switch { flex-shrink: 0; }
.dv-rf-toggle-track {
    width: 50px; height: 28px;
    background: #D4DCE2;
    border-radius: 999px;
    position: relative;
    transition: background .25s ease;
}
.dv-rf-toggle-thumb {
    position: absolute;
    top: 3px; left: 3px;
    width: 22px; height: 22px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 2px 6px rgba(0,0,0,.18);
    transition: transform .25s ease;
}

/* Estado: checked */
.dv-rf-toggle-input:checked + .dv-rf-toggle-card {
    border-color: var(--dv-primary);
    background: var(--dv-primary-soft);
    box-shadow: 0 6px 22px rgba(255, 160, 0, .18);
}
.dv-rf-toggle-input:checked + .dv-rf-toggle-card .dv-rf-toggle-icon {
    background: var(--dv-primary);
    color: #fff;
    transform: rotate(-10deg) scale(1.08);
}
.dv-rf-toggle-input:checked + .dv-rf-toggle-card .dv-rf-toggle-track {
    background: var(--dv-primary);
}
.dv-rf-toggle-input:checked + .dv-rf-toggle-card .dv-rf-toggle-thumb {
    transform: translateX(22px);
}
.dv-rf-toggle-input:focus-visible + .dv-rf-toggle-card {
    box-shadow: 0 0 0 4px rgba(var(--dv-primary-rgb), .22);
}

/* Compatibilidad: si en algún lado quedó la clase vieja */
.dv-rf-badge-form {
    background: var(--dv-primary-soft);
    border: 1px solid var(--dv-primary);
    border-radius: var(--dv-radius-sm);
    padding: .85rem 1rem;
}
.dv-rf-badge-form .form-check-label { color: var(--dv-dark); }

/* ===== Bloque de verificación Reservafácil ===== */
.dv-rf-verify {
    margin-top: -.4rem;
    background: var(--dv-primary-soft);
    border: 1px solid var(--dv-primary);
    border-top: 0;
    border-radius: 0 0 var(--dv-radius) var(--dv-radius);
    padding: 1rem 1.2rem 1.1rem;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height .25s ease, opacity .2s ease, padding .25s ease;
}
.dv-rf-verify.is-open {
    max-height: 360px;
    opacity: 1;
    padding: 1rem 1.2rem 1.1rem;
}
.dv-rf-verify[hidden] { display: none; }
.dv-rf-verify-head {
    display: flex;
    align-items: center;
    gap: .5rem;
    margin-bottom: .35rem;
    color: var(--dv-dark);
}
.dv-rf-verify-head strong { color: var(--dv-dark); }

/* ===== Mensaje contextual según plan elegido ===== */
.dv-plan-info {
    margin-top: 1.2rem;
}
.dv-plan-info-item {
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    padding: .85rem 1rem;
    font-size: .92rem;
    color: var(--dv-dark);
}
.dv-plan-info-item[hidden] { display: none; }

/* Step formulario */
.dv-step {
    display: flex;
    align-items: center;
    gap: .6rem;
    color: var(--dv-muted);
    font-weight: 600;
    font-size: .9rem;
}
.dv-step .num {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--dv-bg-soft);
    color: var(--dv-muted);
    display: grid;
    place-items: center;
    font-size: .85rem;
    flex-shrink: 0;
}
.dv-step.is-active { color: var(--dv-dark); }
.dv-step.is-active .num { background: var(--dv-primary); color: #fff; }

/* Forms generales */
.form-control, .form-select {
    border-radius: var(--dv-radius-sm);
    border-color: var(--dv-border);
    padding: .7rem .9rem;
}
.form-control:focus, .form-select:focus {
    border-color: var(--dv-primary);
    box-shadow: 0 0 0 .2rem rgba(var(--dv-primary-rgb), .18);
}

/* ========== Breadcrumb ========== */
.dv-breadcrumb {
    background: transparent;
    padding: 0;
    margin: 0 0 .8rem;
    font-size: .85rem;
}
.dv-breadcrumb a { color: var(--dv-muted); }
.dv-breadcrumb a:hover { color: var(--dv-primary-dark); }
.dv-breadcrumb .active { color: var(--dv-dark); }

/* ========== Contacto ========== */
.dv-contacto-ilustracion {
    background: var(--dv-primary-soft);
    border-radius: var(--dv-radius-lg);
    overflow: hidden;
    aspect-ratio: 4/3;
}
.dv-contacto-ilustracion svg { width: 100%; height: 100%; display: block; }

.dv-channel-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    padding: .9rem 1.1rem;
    transition: box-shadow .15s ease, transform .15s ease, border-color .15s ease;
    color: var(--dv-dark);
}
.dv-channel-card:hover {
    box-shadow: var(--dv-shadow);
    transform: translateY(-2px);
    border-color: var(--dv-primary);
    color: var(--dv-dark);
}
.dv-channel-icon {
    width: 46px; height: 46px;
    border-radius: 50%;
    display: grid; place-items: center;
    color: #fff;
    font-size: 1.3rem;
    flex-shrink: 0;
}
.dv-channel-title { font-weight: 700; line-height: 1.1; }
.dv-channel-sub { font-size: .85rem; color: var(--dv-muted); margin-top: 2px; }

.place-items-center { place-items: center !important; }

/* ========== Util ========== */
.dv-rounded { border-radius: var(--dv-radius); }
.dv-rounded-lg { border-radius: var(--dv-radius-lg); }
.dv-shadow { box-shadow: var(--dv-shadow); }
.dv-divider { height: 1px; background: var(--dv-border); margin: 1.4rem 0; }
.dv-sep-pipe::after { content: '|'; color: var(--dv-border); margin: 0 .5rem; }

/* ========== Flatpickr — overrides de marca ========== */
.flatpickr-calendar.airbnb { border-radius: var(--dv-radius); box-shadow: var(--dv-shadow-hover); border: 1px solid var(--dv-border); font-family: 'Inter', sans-serif; }
.flatpickr-calendar.airbnb .flatpickr-day.selected,
.flatpickr-calendar.airbnb .flatpickr-day.startRange,
.flatpickr-calendar.airbnb .flatpickr-day.endRange {
    background: var(--dv-primary) !important;
    border-color: var(--dv-primary) !important;
    color: #fff !important;
}
.flatpickr-calendar.airbnb .flatpickr-day.inRange {
    background: var(--dv-primary-soft) !important;
    border-color: var(--dv-primary-soft) !important;
    color: var(--dv-dark) !important;
    box-shadow: -5px 0 0 var(--dv-primary-soft), 5px 0 0 var(--dv-primary-soft) !important;
}
.flatpickr-calendar.airbnb .flatpickr-day.today {
    border-color: var(--dv-primary);
    color: var(--dv-primary-dark);
    font-weight: 600;
}
.flatpickr-calendar.airbnb .flatpickr-day:hover {
    background: var(--dv-bg-soft);
    color: var(--dv-dark);
}
.flatpickr-calendar.airbnb .flatpickr-months .flatpickr-month,
.flatpickr-calendar.airbnb .flatpickr-current-month,
.flatpickr-calendar.airbnb span.flatpickr-weekday {
    color: var(--dv-dark) !important;
    fill: var(--dv-dark) !important;
}
.flatpickr-calendar.airbnb .flatpickr-prev-month svg,
.flatpickr-calendar.airbnb .flatpickr-next-month svg { fill: var(--dv-dark); }
/* Cuando el input está dentro del searchbar, le sacamos el borde nativo del navegador */
.dv-searchbar input.flatpickr-input { color: var(--dv-text); cursor: pointer; }
.dv-searchbar input.flatpickr-input::placeholder { color: var(--dv-muted); }

/* ========== Autocomplete destino ========== */
.dv-autocomplete { position: relative; }
.dv-clear-btn {
    position: absolute;
    top: 50%;
    right: .55rem;
    transform: translateY(-50%);
    width: 26px;
    height: 26px;
    display: grid;
    place-items: center;
    background: transparent;
    border: 0;
    padding: 0;
    color: var(--dv-muted);
    font-size: 1.05rem;
    cursor: pointer;
    border-radius: 50%;
    transition: color .12s ease, background .12s ease;
    z-index: 2;
}
.dv-clear-btn:hover { color: var(--dv-primary-dark); background: var(--dv-bg-soft); }
.dv-clear-btn[hidden] { display: none; }
.dv-autocomplete input[data-autocomplete-input] { padding-right: 2.2rem; }
.dv-suggest {
    position: absolute;
    top: calc(100% + 8px);
    left: -.4rem;
    right: -.4rem;
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    box-shadow: var(--dv-shadow-hover);
    z-index: 1080; /* sobre cualquier sección/sticky */
    max-height: 360px;
    overflow-y: auto;
    padding: .35rem 0;
    display: none;
}
.dv-autocomplete.is-open { z-index: 1090; } /* el contenedor también */
.dv-searchbar { position: relative; } /* contexto de apilamiento */
.dv-suggest.is-open { display: block; }
.dv-suggest .group-header {
    padding: .55rem .9rem .25rem;
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--dv-muted);
    font-weight: 700;
}
.dv-suggest .sug-item {
    display: flex;
    align-items: center;
    gap: .8rem;
    padding: .55rem .9rem;
    cursor: pointer;
    transition: background .12s ease;
    border: 0;
    width: 100%;
    background: transparent;
    text-align: left;
}
.dv-suggest .sug-item:hover,
.dv-suggest .sug-item.is-active {
    background: var(--dv-bg-soft);
}
.dv-suggest .sug-icon {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    display: grid; place-items: center;
    flex-shrink: 0;
}
.dv-suggest .sug-name { font-weight: 600; color: var(--dv-dark); font-size: .92rem; line-height: 1.2; }
.dv-suggest .sug-region { font-size: .78rem; color: var(--dv-muted); }
.dv-suggest .sug-count { margin-left: auto; font-size: .78rem; color: var(--dv-muted); }
.dv-suggest .sug-empty {
    padding: 1rem .9rem;
    text-align: center;
    color: var(--dv-muted);
    font-size: .9rem;
}

/* ========== Selector de huéspedes (popover) ========== */
.dv-guests { position: relative; }
.dv-guests .dv-guests-display {
    cursor: pointer;
    user-select: none;
    color: var(--dv-text);
    font-weight: 500;
    font-size: .95rem;
    padding: 0;
    line-height: 1.4;
    min-height: 1.4em;
}
.dv-guests-pop {
    position: absolute;
    top: calc(100% + 12px);
    right: -.4rem;
    left: auto;
    min-width: 360px;
    max-width: 92vw;
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    box-shadow: var(--dv-shadow-hover);
    padding: 1rem 1.2rem 1.2rem;
    z-index: 1080;
    display: none;
}
.dv-guests-pop.is-open { display: block; }
.dv-guests-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .85rem 0;
    border-bottom: 1px solid var(--dv-border);
}
.dv-guests-row:last-of-type { border-bottom: 0; }
.dv-guests-row .lbl { font-weight: 700; color: var(--dv-dark); font-size: 1.05rem; line-height: 1.1; }
.dv-guests-row .sub { font-size: .82rem; color: var(--dv-muted); margin-top: 2px; }
.dv-guests-row .controls {
    display: flex;
    align-items: center;
    gap: .8rem;
    font-weight: 700;
    color: var(--dv-dark);
}
.dv-counter-btn {
    width: 32px; height: 32px;
    border-radius: 50%;
    border: 1.5px solid var(--dv-dark);
    background: #fff;
    color: var(--dv-dark);
    display: grid; place-items: center;
    font-size: 1.1rem;
    line-height: 0;
    cursor: pointer;
    transition: background .12s ease, color .12s ease, border-color .12s ease;
}
.dv-counter-btn:hover:not(:disabled) {
    background: var(--dv-dark);
    color: #fff;
}
.dv-counter-btn:disabled { border-color: #C9D1D6; color: #C9D1D6; cursor: not-allowed; }
.dv-counter-val { min-width: 24px; text-align: center; font-size: 1.05rem; }
.dv-guests-pet {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 0 .25rem;
}
.dv-guests-pet .lbl { font-weight: 700; color: var(--dv-dark); font-size: 1.05rem; line-height: 1.1; }
.dv-guests-pet .sub { font-size: .82rem; color: var(--dv-muted); margin-top: 2px; }

/* Toggle switch propio (paleta de marca) */
.dv-switch { position: relative; display: inline-block; cursor: pointer; flex-shrink: 0; }
.dv-switch input { position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none; }
.dv-switch-track {
    display: block;
    width: 48px; height: 28px;
    background: #D4DCE2;
    border-radius: 999px;
    position: relative;
    transition: background .2s ease;
}
.dv-switch-thumb {
    position: absolute;
    top: 3px; left: 3px;
    width: 22px; height: 22px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 2px 6px rgba(0,0,0,.18);
    transition: transform .2s ease;
}
.dv-switch input:checked + .dv-switch-track { background: var(--dv-primary); }
.dv-switch input:checked + .dv-switch-track .dv-switch-thumb { transform: translateX(20px); }
.dv-switch input:focus-visible + .dv-switch-track { box-shadow: 0 0 0 3px rgba(var(--dv-primary-rgb), .25); }
.dv-guests-actions { text-align: right; margin-top: .8rem; }
.dv-guests-actions .btn { padding: .55rem 1.2rem; }
@media (max-width: 640px) {
    .dv-guests-pop { right: 0; left: 0; min-width: 0; }
}

/* ========== Carousel reseñas ========== */
.dv-reviews-carousel { position: relative; }
.dv-reviews-track {
    display: flex;
    gap: 1.2rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    padding: .5rem .25rem 1rem;
    scrollbar-width: none;
}
.dv-reviews-track::-webkit-scrollbar { display: none; }
.dv-reviews-track .dv-review {
    flex: 0 0 calc(33.333% - .8rem);
    scroll-snap-align: start;
    min-width: 280px;
}
@media (max-width: 992px) { .dv-reviews-track .dv-review { flex-basis: calc(50% - .6rem); } }
@media (max-width: 640px) { .dv-reviews-track .dv-review { flex-basis: 88%; } }
.dv-carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: #fff;
    border: 1px solid var(--dv-border);
    width: 44px; height: 44px;
    border-radius: 50%;
    display: grid; place-items: center;
    font-size: 1.1rem;
    color: var(--dv-dark);
    cursor: pointer;
    box-shadow: var(--dv-shadow);
    z-index: 5;
    transition: background .15s ease, transform .15s ease;
}
.dv-carousel-btn:hover { background: var(--dv-primary-soft); color: var(--dv-primary-dark); transform: translateY(-50%) scale(1.06); }
.dv-carousel-btn--prev { left: -10px; }
.dv-carousel-btn--next { right: -10px; }
@media (max-width: 640px) { .dv-carousel-btn { display: none; } }

/* =============================================================
   Modal Auth (Iniciar sesión / Crear cuenta)
   Estilo inspirado en alquilerargentina.com — limpio, centrado,
   con float-label estilo Material Design.
   ============================================================= */
.dv-auth-modal .modal-dialog { max-width: 460px; }
.dv-auth-modal .modal-content.dv-auth-content {
    border: 0;
    border-radius: 18px;
    padding: 2.25rem 2rem 1.75rem;
    background: #fff;
    box-shadow: 0 20px 60px rgba(0,0,0,.18);
    position: relative;
    overflow: hidden;
}
.dv-auth-modal .modal-backdrop { background: rgba(20,30,40,.55); }

.dv-auth-close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 32px; height: 32px;
    border: 0; background: transparent;
    color: var(--dv-muted);
    font-size: 1rem;
    border-radius: 50%;
    display: grid; place-items: center;
    transition: background .15s ease, color .15s ease;
    z-index: 3;
}
.dv-auth-close:hover { background: var(--dv-bg-soft); color: var(--dv-dark); }

.dv-auth-logo {
    display: flex;
    justify-content: center;
    margin-bottom: 1rem;
}
.dv-auth-logo img { height: 44px; width: auto; }

.dv-auth-title {
    text-align: center;
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--dv-text);
    margin: 0 0 1.4rem;
    line-height: 1.25;
}
.dv-auth-subtitle {
    text-align: center;
    font-size: .92rem;
    color: var(--dv-muted);
    margin: -1rem 0 1.2rem;
}

/* Float field estilo Material */
.dv-float-field {
    position: relative;
    margin-bottom: 1rem;
}
.dv-float-field input {
    width: 100%;
    height: 56px;
    padding: 18px 14px 6px 14px;
    border: 1.5px solid var(--dv-border);
    border-radius: 6px;
    background: #fff;
    color: var(--dv-text);
    font-size: 1rem;
    font-weight: 500;
    outline: none;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.dv-float-field input:hover { border-color: #b9c2c7; }
.dv-float-field input:focus {
    border-color: var(--dv-primary);
    border-width: 2px;
    padding: 17px 13px 5px 13px; /* compensa el +1px del border */
}
.dv-float-field label {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1rem;
    color: var(--dv-muted);
    pointer-events: none;
    background: #fff;
    padding: 0 4px;
    transition: top .15s ease, transform .15s ease, font-size .15s ease, color .15s ease;
}
.dv-float-field input:focus + label,
.dv-float-field input:not(:placeholder-shown) + label {
    top: 0;
    transform: translateY(-50%) scale(1);
    font-size: .78rem;
    color: var(--dv-muted);
    font-weight: 500;
}
.dv-float-field input:focus + label { color: var(--dv-primary-dark); }
.dv-float-field label .req { color: var(--dv-primary-dark); }

.dv-toggle-pass {
    position: absolute;
    right: 8px; top: 50%; transform: translateY(-50%);
    border: 0; background: transparent;
    width: 38px; height: 38px;
    color: var(--dv-muted);
    border-radius: 50%;
    display: grid; place-items: center;
    cursor: pointer;
    transition: background .15s ease, color .15s ease;
}
.dv-toggle-pass:hover { background: var(--dv-bg-soft); color: var(--dv-dark); }

.dv-float-field.has-error input { border-color: #d93025 !important; }
.dv-float-field.has-error label { color: #d93025 !important; }
.dv-float-field .dv-field-error {
    color: #d93025;
    font-size: .8rem;
    margin-top: 4px;
    display: block;
}

/* Botón submit primario del modal */
.dv-auth-submit {
    width: 100%;
    height: 52px;
    border: 0;
    border-radius: 6px;
    background: var(--dv-primary);
    color: #fff;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: .01em;
    cursor: pointer;
    transition: background .15s ease, transform .15s ease, opacity .15s ease;
    margin-top: .25rem;
}
.dv-auth-submit:hover:not(:disabled) { background: var(--dv-primary-dark); }
.dv-auth-submit:active:not(:disabled) { transform: translateY(1px); }
.dv-auth-submit:disabled {
    background: #e4e7ea;
    color: #9aa4ab;
    cursor: not-allowed;
}
.dv-auth-submit--outline {
    background: #fff;
    color: var(--dv-dark);
    border: 1.5px solid var(--dv-border);
}
.dv-auth-submit--outline:hover:not(:disabled) { background: var(--dv-bg-soft); color: var(--dv-dark); }

/* Separador con círculo central */
.dv-auth-sep {
    position: relative;
    margin: 1.4rem 0 1.1rem;
    height: 1px;
    background: var(--dv-border);
    text-align: center;
}
.dv-auth-sep-dot {
    position: absolute;
    left: 50%; top: 50%;
    transform: translate(-50%, -50%);
    width: 24px; height: 24px;
    border: 1px solid var(--dv-border);
    border-radius: 50%;
    background: #fff;
}

/* Botón Google */
.dv-auth-google {
    width: 100%;
    height: 52px;
    border: 1.5px solid var(--dv-border);
    border-radius: 6px;
    background: #fff;
    color: var(--dv-text);
    font-size: 1rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    text-decoration: none;
    transition: background .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.dv-auth-google:hover {
    background: var(--dv-bg-soft);
    border-color: #b9c2c7;
    color: var(--dv-text);
    text-decoration: none;
    box-shadow: 0 2px 6px rgba(0,0,0,.06);
}
.dv-auth-google svg { flex-shrink: 0; }

/* Texto legal y links */
.dv-auth-terms {
    text-align: center;
    color: var(--dv-muted);
    font-size: .82rem;
    margin: 1.1rem 0 0;
    line-height: 1.4;
}
.dv-auth-terms a {
    color: var(--dv-primary-dark);
    text-decoration: underline;
}
.dv-auth-terms a:hover { color: var(--dv-primary); }
.dv-auth-link {
    color: var(--dv-primary-dark);
    font-size: .85rem;
    text-decoration: none;
    font-weight: 500;
}
.dv-auth-link:hover { color: var(--dv-primary); text-decoration: underline; }
.dv-auth-hint {
    color: var(--dv-muted);
    font-size: .8rem;
    display: block;
    margin: -.5rem 0 .8rem;
}

/* Pill con el email (paso 2) */
.dv-auth-email-pill {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--dv-bg-soft);
    border: 1px solid var(--dv-border);
    border-radius: 999px;
    padding: 8px 8px 8px 16px;
    margin-bottom: 1rem;
    font-size: .92rem;
    color: var(--dv-dark);
}
.dv-auth-email-pill i { color: var(--dv-primary-dark); }
.dv-auth-email-pill span {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 500;
}
.dv-auth-edit {
    border: 0; background: #fff;
    width: 30px; height: 30px;
    border-radius: 50%;
    color: var(--dv-muted);
    cursor: pointer;
    display: grid; place-items: center;
    transition: background .15s ease, color .15s ease;
}
.dv-auth-edit:hover { background: var(--dv-primary-soft); color: var(--dv-primary-dark); }

/* Feedback y loader */
.dv-auth-feedback {
    margin-top: 1rem;
    padding: .7rem .9rem;
    border-radius: 8px;
    font-size: .9rem;
    border: 1px solid;
}
.dv-auth-feedback.is-error { background: #fdecea; color: #b3261e; border-color: #f4c7c1; }
.dv-auth-feedback.is-ok    { background: #e6f4ea; color: #137333; border-color: #c5e3cd; }
.dv-auth-loader {
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,.85);
    display: grid; place-items: center;
    z-index: 10;
    backdrop-filter: blur(2px);
}
.dv-spinner {
    width: 40px; height: 40px;
    border: 3px solid var(--dv-border);
    border-top-color: var(--dv-primary);
    border-radius: 50%;
    animation: dvSpin 0.7s linear infinite;
}
@keyframes dvSpin { to { transform: rotate(360deg); } }

/* Estado "no encontrado" (email no registrado) */
.dv-auth-notfound { text-align: center; padding: .5rem 0 1.1rem; }
.dv-auth-notfound-icon {
    width: 72px; height: 72px;
    margin: 0 auto 1rem;
    border-radius: 50%;
    background: var(--dv-bg-soft);
    color: var(--dv-muted);
    display: grid; place-items: center;
    font-size: 2rem;
}
.dv-auth-notfound h3 {
    font-size: 1.15rem;
    margin: 0 0 .4rem;
    color: var(--dv-text);
    font-weight: 700;
}
.dv-auth-notfound p {
    color: var(--dv-muted);
    margin: 0 0 .25rem;
    font-size: .9rem;
    line-height: 1.4;
}

/* Responsive */
@media (max-width: 480px) {
    .dv-auth-modal .modal-content.dv-auth-content { padding: 2rem 1.25rem 1.5rem; border-radius: 14px; }
    .dv-auth-title { font-size: 1.2rem; }
    .dv-auth-logo img { height: 38px; }
}

/* =============================================================
   Páginas estáticas (sobre-nosotros, faq, reseñas, cómo buscar)
   ============================================================= */

/* Stats grandes (sobre nosotros, reseñas) */
.dv-stat { padding: .5rem 0; }
.dv-stat-num {
    font-size: 2.4rem;
    font-weight: 800;
    color: var(--dv-dark);
    line-height: 1;
    margin-bottom: .25rem;
}
.dv-stat-lbl {
    color: var(--dv-muted);
    font-size: .9rem;
    font-weight: 500;
}

/* Acordeón FAQ */
.dv-accordion .accordion-item {
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius-sm) !important;
    margin-bottom: .75rem;
    overflow: hidden;
    background: #fff;
}
.dv-accordion .accordion-button {
    font-weight: 600;
    color: var(--dv-dark);
    background: #fff;
    padding: 1rem 1.25rem;
    border: 0;
    box-shadow: none;
}
.dv-accordion .accordion-button:not(.collapsed) {
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    box-shadow: none;
}
.dv-accordion .accordion-button:focus { box-shadow: none; }
.dv-accordion .accordion-button::after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23FF6F00'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");
}
.dv-accordion .accordion-body {
    padding: 1rem 1.25rem 1.25rem;
    color: var(--dv-text);
    line-height: 1.55;
}
.dv-accordion .accordion-body a {
    color: var(--dv-primary-dark);
    text-decoration: underline;
}

/* Pasos numerados (cómo buscar) */
.dv-paso {
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 1.5rem 1.4rem;
    position: relative;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.dv-paso:hover {
    transform: translateY(-3px);
    box-shadow: var(--dv-shadow-hover);
    border-color: var(--dv-primary-soft);
}
.dv-paso-num {
    position: absolute;
    top: -14px; left: 1.4rem;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--dv-primary);
    color: #fff;
    font-weight: 800;
    display: grid; place-items: center;
    font-size: 1rem;
    box-shadow: 0 4px 10px rgba(255,160,0,.35);
}
.dv-paso-icon {
    width: 48px; height: 48px;
    border-radius: var(--dv-radius-sm);
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    display: grid; place-items: center;
    font-size: 1.5rem;
    margin: .8rem 0 .9rem;
}
.dv-paso h5 {
    color: var(--dv-dark);
    font-weight: 700;
    margin-bottom: .5rem;
}

/* Tips (cómo buscar) */
.dv-tip {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    background: var(--dv-bg-soft);
    border-radius: var(--dv-radius);
    padding: 1.1rem 1.25rem;
    height: 100%;
}
.dv-tip > i {
    font-size: 1.5rem;
    line-height: 1;
    flex-shrink: 0;
    margin-top: 2px;
}
.dv-tip h6 {
    font-weight: 700;
    color: var(--dv-dark);
}

/* =====================================================================
   Wizard cargar-alojamiento.php — estilos nuevos (2026-05-16)
   Solo clases que no existen en el resto del CSS.
   ===================================================================== */

/* Toggles políticas: mascotas, fiestas, fumar (paso 4) */
.dv-toggle {
    display: block;
    cursor: pointer;
    margin: 0;
    position: relative;
}
.dv-toggle input {
    position: absolute;
    opacity: 0;
    width: 0; height: 0;
    pointer-events: none;
}
.dv-toggle-body {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .75rem 1rem;
    background: #fff;
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    color: var(--dv-muted);
    font-weight: 600;
    font-size: .92rem;
    transition: all .15s;
}
.dv-toggle-body i {
    font-size: 1.15rem;
    color: var(--dv-muted);
    transition: color .15s;
}
.dv-toggle:hover .dv-toggle-body { border-color: var(--dv-primary); }
.dv-toggle input:checked + .dv-toggle-body {
    background: var(--dv-primary-soft);
    border-color: var(--dv-primary);
    color: var(--dv-primary-dark);
}
.dv-toggle input:checked + .dv-toggle-body i { color: var(--dv-primary-dark); }

/* Card de unidad (paso 3) */
.dv-unidad-card {
    position: relative;
    background: #fff;
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius);
    padding: 1.4rem 1.5rem 1.25rem;
    margin-bottom: 1rem;
    transition: border-color .15s, box-shadow .15s;
}
.dv-unidad-card:hover { border-color: var(--dv-primary-soft); }

.dv-unidad-head {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: 1.1rem;
}
.dv-unidad-chip {
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    font-weight: 700;
    font-size: .72rem;
    padding: .3rem .7rem;
    border-radius: 999px;
    letter-spacing: .04em;
    text-transform: uppercase;
    white-space: nowrap;
    flex-shrink: 0;
}
.dv-unidad-title-wrap { flex: 1; min-width: 0; }
.dv-unidad-title-label {
    display: block;
    font-size: .72rem;
    color: var(--dv-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 2px;
}
.dv-unidad-title {
    width: 100%;
    border: 0;
    background: transparent;
    font-weight: 600;
    font-size: .95rem;
    color: var(--dv-dark);
    padding: 0;
    outline: none;
}
.dv-unidad-title::placeholder { color: var(--dv-muted); font-weight: 400; }

.dv-unidad-remove {
    background: transparent;
    border: 0;
    color: var(--dv-muted);
    font-size: .82rem;
    font-weight: 600;
    cursor: pointer;
    padding: .25rem .5rem;
    border-radius: var(--dv-radius-sm);
    transition: all .15s;
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    flex-shrink: 0;
    margin-left: auto;
    white-space: nowrap;
}
.dv-unidad-remove:hover {
    background: #fef2f2;
    color: #dc2626;
}

/* Header del label de "Fotos de esta unidad" — título + badge */
.dv-uf-fotos-label {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: .65rem;
    flex-wrap: wrap;
}
.dv-uf-fotos-title { flex: 1 1 auto; min-width: 0; }

/* Detalle de camas (acordeón nativo <details>) */
.dv-camas-detail {
    background: var(--dv-bg-soft);
    border-radius: var(--dv-radius-sm);
    padding: .85rem 1rem;
}
.dv-camas-detail summary {
    list-style: none;
    user-select: none;
}
.dv-camas-detail summary::-webkit-details-marker { display: none; }
.dv-camas-detail summary i.bi-plus-circle {
    transition: transform .2s ease;
}
.dv-camas-detail[open] summary i.bi-plus-circle {
    transform: rotate(45deg);
}

.dv-cama-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    padding: .35rem .55rem;
    margin: 0;
    transition: border-color .15s, background .15s;
}
.dv-cama-name {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.dv-cama-spin {
    display: inline-flex;
    align-items: center;
    background: #fff;
    border: 1px solid var(--dv-border);
    border-radius: 999px;
    overflow: hidden;
    flex-shrink: 0;
}
.dv-cama-spin-btn {
    width: 24px; height: 24px;
    border: 0;
    background: transparent;
    color: var(--dv-primary);
    font-size: .8rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .12s;
    padding: 0;
}
.dv-cama-spin-btn:hover:not(:disabled) { background: var(--dv-primary-soft); }
.dv-cama-spin-btn:disabled {
    color: var(--dv-border);
    cursor: not-allowed;
}
.dv-cama-input {
    width: 32px;
    text-align: center;
    border: 0;
    background: transparent;
    padding: 0 .15rem;
    font-size: .9rem;
    font-weight: 600;
    color: var(--dv-dark);
    outline: none;
}
.dv-cama-input::-webkit-outer-spin-button,
.dv-cama-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.dv-cama-input { -moz-appearance: textfield; appearance: textfield; }
.dv-cama-spin.has-value {
    border-color: var(--dv-primary);
    background: var(--dv-primary-soft);
}
.dv-cama-spin.has-value .dv-cama-input { color: var(--dv-primary-dark); }

/* Modal de servicios y modal de tipos (catálogos largos) */
.dv-cat-list { display: grid; gap: 1.6rem; }
.dv-cat-title {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-weight: 700;
    color: var(--dv-primary-dark);
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    margin: 0 0 .85rem 0;
    padding-bottom: .5rem;
    border-bottom: 2px solid var(--dv-primary-soft);
}
.dv-cat-title i { font-size: 1rem; color: var(--dv-primary); }
.dv-cat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
    gap: .5rem .75rem;
}

/* Item del modal de servicios — chip con icono + check visual.
   NOTA: el input nativo está visualmente oculto pero SIGUE recibiendo clics
   (pointer-events normal y posicionado absolute sobre el label). */
.dv-servicio-mini {
    display: block;
    position: relative;
    margin: 0;
    cursor: pointer;
    user-select: none;
}
.dv-servicio-mini input[type="checkbox"] {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    opacity: 0;
    cursor: pointer;
    z-index: 2;
}
.dv-servicio-mini-body {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .55rem .75rem;
    background: #fff;
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    font-size: .88rem;
    color: var(--dv-dark);
    transition: all .15s ease;
    min-height: 42px;
}
.dv-servicio-mini-icon {
    color: var(--dv-muted);
    font-size: 1.05rem;
    flex-shrink: 0;
    width: 22px;
    text-align: center;
    transition: color .15s ease;
}
.dv-servicio-mini-name {
    flex: 1;
    line-height: 1.2;
    word-break: break-word;
}
.dv-servicio-mini-check {
    width: 20px; height: 20px;
    border-radius: 50%;
    background: #fff;
    border: 1.5px solid var(--dv-border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: transparent;
    flex-shrink: 0;
    transition: all .15s ease;
    font-size: .85rem;
}
.dv-servicio-mini:hover .dv-servicio-mini-body {
    border-color: var(--dv-primary);
    background: var(--dv-bg-soft);
}
.dv-servicio-mini:hover .dv-servicio-mini-check {
    border-color: var(--dv-primary);
}
.dv-servicio-mini input:checked + .dv-servicio-mini-body {
    border-color: var(--dv-primary);
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    font-weight: 600;
}
.dv-servicio-mini input:checked + .dv-servicio-mini-body .dv-servicio-mini-icon {
    color: var(--dv-primary);
}
.dv-servicio-mini input:checked + .dv-servicio-mini-body .dv-servicio-mini-check {
    background: var(--dv-primary);
    border-color: var(--dv-primary);
    color: #fff;
}
.dv-servicio-mini input:focus-visible + .dv-servicio-mini-body {
    outline: 2px solid var(--dv-primary);
    outline-offset: 2px;
}

/* Item del modal de tipos — radio card más compacto */
.dv-tipo-mini {
    display: block;
    cursor: pointer;
    margin: 0;
}
.dv-tipo-mini input { position: absolute; opacity: 0; pointer-events: none; }
.dv-tipo-mini-body {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .5rem .7rem;
    background: #fff;
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    font-size: .88rem;
    color: var(--dv-dark);
    transition: all .15s;
}
.dv-tipo-mini:hover .dv-tipo-mini-body { border-color: var(--dv-primary); }
.dv-tipo-mini input:checked + .dv-tipo-mini-body {
    background: var(--dv-primary-soft);
    border-color: var(--dv-primary);
    color: var(--dv-primary-dark);
    font-weight: 600;
}

/* Tag visible cuando se elige un tipo desde el modal "Otro" */
.dv-tipo-otro-tag {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    border-radius: 999px;
    padding: .35rem .85rem;
    font-weight: 600;
    font-size: .85rem;
    margin-top: .35rem;
}
.dv-tipo-otro-tag-clear {
    background: transparent;
    border: 0;
    color: var(--dv-primary-dark);
    padding: 0;
    line-height: 1;
    cursor: pointer;
}

/* Fila "Otro tipo de alojamiento" — botón + tag debajo de la grid */
.dv-tipo-otro-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .65rem;
    margin-top: .25rem;
    margin-bottom: .25rem;
}
.dv-tipo-otro-btn {
    background: transparent;
    border: 1.5px dashed var(--dv-border);
    color: var(--dv-muted);
    padding: .55rem 1rem;
    border-radius: var(--dv-radius-sm);
    font-size: .88rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    transition: all .15s;
}
.dv-tipo-otro-btn:hover {
    border-color: var(--dv-primary);
    color: var(--dv-primary-dark);
    background: var(--dv-bg-soft);
}
.dv-tipo-otro-btn .text-decoration-underline {
    color: var(--dv-primary);
    font-weight: 600;
}
.dv-tipo-otro-radio-hidden { display: none; }

/* Mapa del paso 1 — visible recién después de cargar la dirección */
.dv-map-wrap {
    margin-top: .25rem;
    overflow: hidden;
    max-height: 600px;
    opacity: 1;
    transition: max-height .45s ease, opacity .35s ease, margin .3s ease;
}
.dv-map-wrap.dv-map-hidden {
    max-height: 0;
    opacity: 0;
    margin-top: 0;
    margin-bottom: 0 !important;
    pointer-events: none;
}
.dv-map-wrap.dv-map-revealed {
    animation: dvMapPulse .6s ease;
}
@keyframes dvMapPulse {
    0%   { box-shadow: 0 0 0 0 var(--dv-primary-soft); }
    60%  { box-shadow: 0 0 0 8px transparent; }
    100% { box-shadow: 0 0 0 0 transparent; }
}
.dv-map {
    width: 100%;
    height: 280px;
    border-radius: var(--dv-radius);
    border: 1.5px solid var(--dv-border);
    background: var(--dv-bg-soft);
    overflow: hidden;
}
@media (max-width: 575.98px) {
    .dv-map { height: 230px; }
}

/* Dropzone más compacta para fotos por unidad (paso 3) */
.dv-dropzone-uf {
    padding: 1rem;
    min-height: 0;
}
.dv-dropzone-uf .dv-dropzone-empty { padding: 0; }
.dv-dropzone-uf .dv-dropzone-empty i { font-size: 1.5rem; }
.dv-dropzone-uf .dv-dropzone-empty p { font-size: .9rem; }
.dv-fotos-counter.is-uf {
    background: var(--dv-bg-soft);
    color: var(--dv-muted);
    border-radius: 999px;
    padding: .2rem .65rem;
    font-size: .78rem;
    font-weight: 600;
}
.dv-fotos-counter.is-uf.is-ok {
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
}

/* Modal de servicios — refinamientos visuales */
.dv-modal-servicios .modal-content {
    border-radius: var(--dv-radius);
    border: 0;
    box-shadow: 0 25px 50px rgba(0,0,0,0.12);
}
.dv-modal-servicios .modal-header {
    padding: 1.4rem 1.5rem .25rem;
}
.dv-modal-servicios .modal-title {
    font-weight: 700;
    color: var(--dv-dark);
}
.dv-modal-servicios .modal-body { padding: 1rem 1.5rem 1.5rem; }
.dv-modal-search .input-group { box-shadow: 0 2px 8px rgba(0,0,0,0.04); border-radius: var(--dv-radius-sm); overflow: hidden; }
.dv-modal-search .form-control, .dv-modal-search .input-group-text {
    border-color: var(--dv-border);
    background: #fff;
}
.dv-modal-search .form-control:focus {
    box-shadow: none;
    border-color: var(--dv-primary);
}
.dv-modal-search .input-group:focus-within {
    box-shadow: 0 0 0 3px var(--dv-primary-soft);
}
.dv-modal-footer {
    border-top: 1px solid var(--dv-border);
    padding: 1rem 1.5rem;
    background: var(--dv-bg-soft);
    border-radius: 0 0 var(--dv-radius) var(--dv-radius);
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.dv-modal-footer-count {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    color: var(--dv-dark);
    font-size: .92rem;
}
.dv-modal-footer-count i {
    color: var(--dv-primary);
    font-size: 1.1rem;
}
.dv-modal-footer-count strong {
    color: var(--dv-primary-dark);
    font-size: 1.05rem;
}

/* Input de contraseña con botón mostrar/ocultar */
.dv-password-wrap {
    position: relative;
    display: flex;
    align-items: stretch;
}
.dv-password-wrap input { padding-right: 40px; }
.dv-password-toggle {
    position: absolute;
    right: 6px;
    top: 50%;
    transform: translateY(-50%);
    width: 32px; height: 32px;
    background: transparent;
    border: 0;
    color: var(--dv-muted);
    cursor: pointer;
    border-radius: var(--dv-radius-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: color .15s, background .15s;
}
.dv-password-toggle:hover {
    color: var(--dv-primary);
    background: var(--dv-bg-soft);
}

/* Tom Select: selects de provincia y localidad con buscador integrado */
.ts-wrapper.single .ts-control {
    border-color: var(--dv-border);
    background: #fff;
    border-radius: var(--dv-radius-sm);
    padding: .375rem .75rem;
    min-height: calc(1.5em + .75rem + 2px);
    font-size: 1rem;
    color: var(--dv-dark);
    box-shadow: none;
}
.ts-wrapper.single.focus .ts-control,
.ts-wrapper.single .ts-control:focus-within {
    border-color: var(--dv-primary);
    box-shadow: 0 0 0 3px var(--dv-primary-soft);
}
.ts-wrapper.disabled .ts-control {
    background: var(--dv-bg-soft);
    cursor: not-allowed;
    opacity: .75;
}
.ts-dropdown {
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    margin-top: 4px;
}
.ts-dropdown .option {
    padding: .55rem .85rem;
    color: var(--dv-dark);
    cursor: pointer;
}
.ts-dropdown .option:hover,
.ts-dropdown .option.active {
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
}
.ts-dropdown .option.selected {
    background: var(--dv-primary);
    color: #fff;
}
.ts-dropdown .no-results {
    padding: .65rem .85rem;
    color: var(--dv-muted);
    font-style: italic;
}

/* intl-tel-input: integración con Bootstrap (campo de teléfono con bandera AR fija)
   NOTA: el CSS del plugin carga después del nuestro y usa display:inline-block.
   Por eso forzamos display:block y width:100% con !important. */
.iti {
    display: block !important;
    width: 100% !important;
    position: relative;
}
.iti__tel-input,
.iti input[type="tel"],
.iti input.form-control {
    width: 100% !important;
    padding-left: 92px !important;   /* hueco para la bandera + "+54" */
    height: calc(1.5em + .75rem + 2px); /* misma altura que .form-control de Bootstrap */
}
.iti--separate-dial-code .iti__selected-flag {
    background-color: var(--dv-bg-soft);
    border-right: 1px solid var(--dv-border);
    border-radius: var(--dv-radius-sm) 0 0 var(--dv-radius-sm);
    padding: 0 .65rem 0 .75rem !important;
    cursor: default !important;
}
.iti__selected-flag::after,
.iti__arrow {
    display: none !important;   /* oculta la flechita del dropdown (no se puede cambiar) */
}
.iti--separate-dial-code .iti__selected-dial-code {
    color: var(--dv-dark);
    font-weight: 500;
}

/* Dropdown del fallback OSM Nominatim (debajo del input de dirección) */
.dv-osm-suggest {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: #fff;
    border: 1.5px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    z-index: 1050;
    max-height: 320px;
    overflow-y: auto;
}
.dv-osm-item {
    width: 100%;
    text-align: left;
    background: transparent;
    border: 0;
    padding: .65rem .9rem;
    display: flex;
    align-items: center;
    gap: .65rem;
    cursor: pointer;
    border-bottom: 1px solid var(--dv-border);
    transition: background .12s;
    color: var(--dv-dark);
}
.dv-osm-item:last-child { border-bottom: 0; }
.dv-osm-item:hover, .dv-osm-item:focus {
    background: var(--dv-primary-soft);
    color: var(--dv-primary-dark);
    outline: none;
}
.dv-osm-item i {
    color: var(--dv-primary);
    flex-shrink: 0;
    font-size: 1.1rem;
}
.dv-osm-text {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
}
.dv-osm-text strong { font-weight: 600; font-size: .92rem; line-height: 1.2; }
.dv-osm-text small {
    color: var(--dv-muted);
    font-size: .78rem;
    line-height: 1.2;
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Mapa: estilo del cartel de error de Google Maps */
.dv-map-error {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    padding: 1rem 1.2rem;
    background: #fff7ed;
    border: 1px solid #fdba74;
    border-radius: var(--dv-radius-sm);
    color: #9a3412;
    height: 100%;
}
.dv-map-error i {
    color: #ea580c;
    font-size: 1.25rem;
    flex-shrink: 0;
    margin-top: 2px;
}

/* Overlay de carga mientras se procesa el submit del wizard */
.dv-submit-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(2px);
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
}
.dv-submit-overlay-inner {
    text-align: center;
    max-width: 480px;
}

/* ========== Dashboard del anfitrión ========== */
.dv-promo-destacar {
    background: linear-gradient(135deg, var(--dv-primary), var(--dv-primary-dark));
    color: #fff;
    border-radius: var(--dv-radius);
    overflow: hidden;
}
.dv-promo-destacar-inner {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding: 1.25rem 1.5rem;
}
.dv-promo-destacar-icon {
    width: 56px; height: 56px;
    border-radius: 50%;
    background: rgba(255,255,255,.18);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.dv-promo-destacar-icon i { font-size: 1.6rem; color: #fff; }
.dv-promo-destacar-body { flex: 1; }
.dv-promo-destacar-body h5 { color: #fff; margin-bottom: .25rem; }
.dv-promo-destacar-body p { color: rgba(255,255,255,.92); }
.dv-promo-destacar .btn-dv-primary {
    background: #fff;
    color: var(--dv-primary-dark);
    border: 0;
}
.dv-promo-destacar .btn-dv-primary:hover { background: #fff8f0; }

.dv-aloj-card {
    background: #fff;
    border-radius: var(--dv-radius);
    box-shadow: 0 2px 12px rgba(55,71,79,.06);
    overflow: hidden;
    display: grid;
    grid-template-columns: 280px 1fr;
    align-items: start;
}
.dv-aloj-card-cover {
    position: relative;
    background: var(--dv-bg-soft);
    height: 220px;
    align-self: start;
    overflow: hidden;
}
.dv-aloj-card-cover img {
    width: 100%; height: 100%; object-fit: cover;
    position: absolute; inset: 0;
}
.dv-aloj-card-noimg {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    color: var(--dv-muted); font-size: 2.5rem;
}
.dv-aloj-badge {
    position: absolute; top: .75rem; left: .75rem;
    padding: .25rem .65rem;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .04em;
}
.dv-aloj-badge-destacada {
    background: var(--dv-primary);
    color: #fff;
}
.dv-aloj-card-body { padding: 1.25rem 1.4rem; }
.dv-aloj-stats {
    display: flex; flex-wrap: wrap; gap: .9rem;
    color: var(--dv-muted); font-size: .88rem;
}
.dv-aloj-stats i { color: var(--dv-primary); margin-right: .25rem; }
.dv-aloj-ufs-toggle {
    background: transparent;
    border: 0;
    padding: .35rem 0;
    cursor: pointer;
    user-select: none;
    color: var(--dv-primary-dark);
}
.dv-aloj-ufs-toggle:hover { color: var(--dv-primary); }
.dv-aloj-ufs-toggle i { transition: transform .2s ease; display: inline-block; }
.dv-aloj-ufs-toggle.is-open i.bi-chevron-down { transform: rotate(180deg); }
.dv-aloj-ufs-grid[hidden] { display: none !important; }
.dv-aloj-ufs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: .85rem;
}
.dv-uf-mini {
    border: 1px solid var(--dv-border);
    border-radius: var(--dv-radius-sm);
    overflow: hidden;
    background: var(--dv-bg-soft);
    display: flex;
    flex-direction: column;
}
.dv-uf-mini img {
    width: 100%; height: 110px; object-fit: cover;
    display: block;
}
.dv-uf-mini-noimg {
    height: 110px;
    background: #f0f0f0;
    display: flex; align-items: center; justify-content: center;
    color: var(--dv-muted); font-size: 2rem;
}
.dv-uf-mini-body { padding: .65rem .8rem; flex: 1; }
.dv-uf-mini-body i { color: var(--dv-primary); margin-right: 2px; }
.dv-uf-mini-title { line-height: 1.2; }
.dv-uf-mini-edit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px; height: 26px;
    border-radius: 6px;
    background: #fff;
    border: 1px solid var(--dv-border);
    color: var(--dv-muted);
    text-decoration: none;
    font-size: .85rem;
    transition: all .15s ease;
    flex-shrink: 0;
}
.dv-uf-mini-edit i { color: inherit; margin: 0; }
.dv-uf-mini-edit:hover {
    background: var(--dv-primary);
    border-color: var(--dv-primary);
    color: #fff;
}
.dv-uf-mini-price {
    margin-top: .4rem;
    color: var(--dv-primary-dark);
    font-weight: 700;
    font-size: 1rem;
}

/* Destacar embebido en cada card (cuando NO es destacado) — naranja sólido, compacto */
.dv-card-destacar {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .55rem .85rem;
    background: var(--dv-primary);
    border-radius: var(--dv-radius-sm);
    color: #fff;
}
.dv-card-destacar-icon {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: rgba(255,255,255,.18);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .95rem;
    flex-shrink: 0;
}
.dv-card-destacar-body { flex: 1; min-width: 0; line-height: 1.25; }
.dv-card-destacar-body strong {
    color: #fff;
    display: block;
    font-size: .92rem;
    margin-bottom: .05rem;
}
.dv-card-destacar-body p {
    color: rgba(255,255,255,.92);
    font-size: .78rem;
    margin: 0;
}
.dv-card-destacar .btn {
    background: #fff;
    color: var(--dv-primary-dark);
    border: 0;
    padding: .3rem .75rem;
    font-size: .82rem;
    font-weight: 600;
    border-radius: 999px;
    flex-shrink: 0;
}
.dv-card-destacar .btn:hover {
    background: #fff;
    color: var(--dv-primary-dark);
    box-shadow: 0 0 0 3px rgba(255,255,255,.25);
}
@media (max-width: 575.98px) {
    .dv-card-destacar { flex-wrap: wrap; padding: .6rem .75rem; }
    .dv-card-destacar .btn { width: 100%; }
}

/* Estado destacado (verde / dorado) embebido en card */
.dv-card-destacado {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    padding: .5rem .85rem;
    background: #e9f7ef;
    border: 1px solid #c3e6d0;
    border-radius: var(--dv-radius-sm);
    color: #1e7e3b;
    font-size: .9rem;
}
.dv-card-destacado i { color: var(--dv-primary); }
@media (max-width: 767.98px) {
    .dv-aloj-card { grid-template-columns: 1fr; }
    .dv-aloj-card-cover { height: auto; min-height: 180px; aspect-ratio: 16/9; }
    .dv-promo-destacar-inner { flex-wrap: wrap; }
}

/* ===== Responsive móvil ===== */
@media (max-width: 575.98px) {
    .dv-unidad-card { padding: 1rem .85rem .85rem; }
    .dv-unidad-head {
        flex-wrap: wrap;
        align-items: center;
        gap: .5rem;
    }
    /* En móvil el chip "UNIDAD N" + botón "Quitar" van en una fila arriba, y el input abajo */
    .dv-unidad-chip { order: 1; }
    .dv-unidad-remove {
        order: 2;
        margin-left: auto;
        padding: .15rem .4rem;
        font-size: .78rem;
    }
    .dv-unidad-remove-text { display: none; } /* solo icono en móvil */
    .dv-unidad-title-wrap {
        order: 3;
        flex: 1 1 100%;
        min-width: 0;
        margin-top: .35rem;
        padding-top: .5rem;
        border-top: 1px solid var(--dv-border);
    }
    .dv-modal-servicios .modal-header,
    .dv-modal-servicios .modal-body { padding-left: 1rem; padding-right: 1rem; }
    .dv-modal-footer { padding: .85rem 1rem; flex-wrap: wrap; gap: .5rem; }
    .dv-cat-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }

    /* Tipo de alojamiento — grid más compacto en móvil */
    .dv-type-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: .45rem;
    }
    .dv-type-card-inner {
        padding: .6rem .25rem .55rem;
        gap: .25rem;
    }
    .dv-type-card-inner i { font-size: 1.25rem; }
    .dv-type-card-name { font-size: .72rem; line-height: 1.1; }

    /* Tipos de cama: 1 sola columna en móvil con nombre completo visible */
    .dv-camas-detail .row.g-2 > [class^="col-"] { flex: 0 0 100%; max-width: 100%; }
    .dv-cama-row {
        padding: .45rem .65rem;
    }
    .dv-cama-name {
        white-space: normal;        /* permite que el nombre wrappee */
        overflow: visible;
        font-size: .85rem;
        line-height: 1.2;
    }
    .dv-cama-spin {
        flex-shrink: 0;
    }

    /* Header de Fotos de esta unidad en columna en móvil */
    .dv-uf-fotos-label {
        flex-direction: column;
        align-items: flex-start;
        gap: .35rem;
    }
    .dv-fotos-counter.is-uf {
        align-self: flex-start;
    }
}

/* En pantallas chicas pero no tan chicas (tablet vertical), 4 columnas para tipos */
@media (min-width: 576px) and (max-width: 767.98px) {
    .dv-type-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* =========================================================
   Panel de consultas (consultas.php)
   ========================================================= */
.dv-consultas-filtros {
    background: #fff;
    border: 1px solid var(--dv-border, #e8e8e8);
    border-radius: 10px;
    padding: .85rem 1rem;
}

.dv-consultas-list {
    display: flex;
    flex-direction: column;
    gap: .85rem;
}

.dv-consulta {
    background: #fff;
    border: 1px solid var(--dv-border, #e8e8e8);
    border-radius: 12px;
    padding: 1rem;
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: .9rem;
    transition: box-shadow .15s ease, border-color .15s ease;
}
.dv-consulta:hover {
    box-shadow: 0 2px 14px rgba(0,0,0,.05);
    border-color: #d8d8d8;
}
.dv-consulta.is-unread {
    border-left: 3px solid var(--dv-primary, #FFA000);
    background: #fffdf7;
}

.dv-consulta-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--dv-primary-soft, #fff3df);
    color: var(--dv-primary, #FFA000);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.15rem;
}

.dv-consulta-body {
    min-width: 0; /* permite ellipsis dentro */
}

.dv-consulta-head {
    display: flex;
    justify-content: space-between;
    gap: .5rem;
    align-items: flex-start;
    flex-wrap: wrap;
}

.dv-consulta-meta {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    white-space: nowrap;
}

.dv-consulta-canal {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-size: .72rem;
    padding: .15rem .55rem;
    border-radius: 999px;
    font-weight: 600;
}
.dv-consulta-canal.is-mail { background: #eef3ff; color: #2c5cd3; }
.dv-consulta-canal.is-wa   { background: #e7f6ee; color: #1f8a45; }

.dv-consulta-dot {
    width: 9px; height: 9px;
    background: var(--dv-primary, #FFA000);
    border-radius: 50%;
    display: inline-block;
}

.dv-consulta-aloj {
    margin-top: .25rem;
    color: #555;
}
.dv-consulta-aloj a {
    color: #333;
    text-decoration: none;
    font-weight: 500;
}
.dv-consulta-aloj a:hover { text-decoration: underline; }

.dv-consulta-resumen {
    margin-top: .35rem;
    display: flex;
    flex-wrap: wrap;
    gap: .15rem 1rem;
    color: #555;
}
.dv-consulta-resumen i { color: #888; }

.dv-consulta-mensaje {
    margin: .65rem 0 .25rem;
    padding: .65rem .85rem;
    background: #fafafa;
    border-radius: 8px;
    color: #333;
    font-size: .92rem;
    line-height: 1.45;
    white-space: pre-line;
    word-break: break-word;
}
.dv-consulta-mensaje.is-empty {
    color: #999;
    font-style: italic;
    background: transparent;
    padding: .25rem 0;
}

.dv-consulta-actions {
    display: flex;
    gap: .4rem;
    flex-wrap: wrap;
    margin-top: .65rem;
}

@media (max-width: 575.98px) {
    .dv-consulta {
        grid-template-columns: 40px 1fr;
        padding: .85rem;
    }
    .dv-consulta-avatar { width: 40px; height: 40px; font-size: 1rem; }
    .dv-consulta-actions .btn { flex: 1 1 calc(50% - .25rem); }
}

/* Card chip "Consultas recibidas" en el dashboard */
.dv-dash-shortcuts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: .75rem;
    margin-bottom: 1.25rem;
}
.dv-dash-shortcut {
    display: flex;
    align-items: center;
    gap: .8rem;
    padding: .85rem 1rem;
    background: #fff;
    border: 1px solid var(--dv-border, #e8e8e8);
    border-radius: 10px;
    text-decoration: none;
    color: inherit;
    transition: box-shadow .15s ease, transform .15s ease, border-color .15s ease;
}
.dv-dash-shortcut:hover {
    text-decoration: none;
    color: inherit;
    box-shadow: 0 4px 16px rgba(0,0,0,.06);
    transform: translateY(-1px);
    border-color: #d8d8d8;
}
.dv-dash-shortcut-icon {
    width: 42px; height: 42px;
    border-radius: 10px;
    background: var(--dv-primary-soft, #fff3df);
    color: var(--dv-primary, #FFA000);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    flex-shrink: 0;
}
.dv-dash-shortcut-body {
    flex: 1;
    min-width: 0;
}
.dv-dash-shortcut-title {
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: .4rem;
}
.dv-dash-shortcut-sub {
    font-size: .8rem;
    color: #888;
}
.dv-dash-shortcut-badge {
    background: var(--dv-primary, #FFA000);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    padding: .1rem .5rem;
    border-radius: 999px;
}

/* =========================================================
   Reorder de fotos (SortableJS)
   ========================================================= */
.dv-fotos-actuales .dv-foto-actual {
    cursor: grab;
    user-select: none;
    transition: transform .15s ease, box-shadow .15s ease;
}
.dv-fotos-actuales .dv-foto-actual:active {
    cursor: grabbing;
}
.dv-fotos-actuales .dv-foto-actual img {
    pointer-events: auto;
}
/* Feedback durante el drag */
.dv-foto-ghost {
    opacity: .35;
    background: var(--dv-primary-soft, #fff3df);
}
.dv-foto-chosen {
    transform: scale(1.02);
    box-shadow: 0 6px 22px rgba(0,0,0,.18);
}
.dv-foto-drag {
    opacity: .95;
    box-shadow: 0 12px 30px rgba(0,0,0,.25);
}

/* Status bajo el editor cuando se guarda el orden */
.dv-fotos-reorder-status {
    display: inline-block;
    padding: .25rem .65rem;
    border-radius: 6px;
    line-height: 1.3;
}
.dv-fotos-reorder-status.is-info    { background: #eef3ff; color: #2c5cd3; }
.dv-fotos-reorder-status.is-success { background: #e7f6ee; color: #1f8a45; }
.dv-fotos-reorder-status.is-danger  { background: #fbe6e6; color: #b03030; }

/* =========================================================
   Barra de impersonación (admin operando como otro usuario)
   ========================================================= */
.dv-impersonation-bar {
    background: repeating-linear-gradient(135deg, #ffd966 0 14px, #ffd34d 14px 28px);
    color: #4a3500;
    padding: .6rem 1rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    font-size: .9rem;
    border-bottom: 2px solid #d49a00;
    position: sticky;
    top: 0;
    z-index: 1100;
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
}
.dv-impersonation-msg {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
}
.dv-impersonation-msg i { font-size: 1.1rem; }
.dv-impersonation-out {
    background: #1a1a1a;
    color: #fff;
    text-decoration: none;
    padding: .35rem .85rem;
    border-radius: 6px;
    font-weight: 600;
    font-size: .85rem;
    white-space: nowrap;
    transition: background .12s;
}
.dv-impersonation-out:hover {
    background: #000;
    color: #fff;
}

/* Cuando hay impersonación, la navbar sticky se mueve abajo de la barra */
.dv-impersonation-bar + .dv-navbar.sticky-top {
    top: 0; /* la barra ya empuja el flujo, no necesita offset extra */
}
