/* Composant : ms-hover-popup
 * Popup riche déclenchée par hover (marker ou card) sur la carte.
 * Consomme tokens.css et la charte monswim.
 */

.__ms-hover-popup-wrap .leaflet-popup-content-wrapper {
    padding: 0;
    border-radius: 16px;
    overflow: hidden;
    background: var(--color-surface, #ffffff);
    box-shadow: 0 14px 38px rgba(14, 31, 36, 0.22);
}

.__ms-hover-popup-wrap .leaflet-popup-content {
    margin: 0;
    width: 280px !important;
}

.__ms-hover-popup-wrap .leaflet-popup-tip {
    display: none;
}

.ms-hover-popup {
    display: flex;
    flex-direction: column;
    background: var(--color-surface, #ffffff);
    cursor: pointer;
    font-family: inherit;
}

.ms-hover-popup__media {
    position: relative;
    width: 100%;
    padding-top: 56%;
    overflow: hidden;
    background: var(--color-surface-alt, #eef2f3);
}

.ms-hover-popup__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.ms-hover-popup__badge {
    position: absolute;
    top: 10px;
    left: 10px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 11px;
    border-radius: 999px;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.2px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    background: var(--color-primary, #004b58);
}

.ms-hover-popup__badge i {
    font-size: 11px;
}

.ms-hover-popup[data-type="piscine"] .ms-hover-popup__badge { background: var(--color-type-piscine); }
.ms-hover-popup[data-type="plage"]   .ms-hover-popup__badge { background: var(--color-type-plage); }
.ms-hover-popup[data-type="lac"]     .ms-hover-popup__badge { background: var(--color-type-lac); }
.ms-hover-popup[data-type="riviere"] .ms-hover-popup__badge { background: var(--color-type-riviere); }

.ms-hover-popup__body {
    padding: 12px 14px 14px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.ms-hover-popup__title {
    margin: 0;
    font-size: 16px;
    font-weight: 800;
    line-height: 1.2;
    color: var(--color-primary, #004b58);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ms-hover-popup__ville {
    margin: 0 0 4px;
    font-size: 12.5px;
    color: var(--color-text-secondary, #6b7a7e);
}

.ms-hover-popup__rating {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12.5px;
    font-weight: 700;
    color: var(--color-text-primary, #0e1f24);
}

.ms-hover-popup__rating i {
    color: #f4b942;
    font-size: 11px;
}

.ms-hover-popup__avis {
    font-weight: 500;
    color: var(--color-text-secondary, #6b7a7e);
}
