.ith-hotspot {
    cursor: help;
    text-decoration: underline dotted;
    text-underline-offset: 0.25em;
    padding-bottom: 2px;
}

.ith-popup {
    position: absolute;
    z-index: 999999;
    width: auto;           /* Shrink-wrap to content */
    min-width: 150px;      /* Prevent it from being too tiny */
    max-width: 320px;      /* Keep it readable */
    background: #ffffff;
    padding: 12px;
    border: 1px solid #ddd;
    border-radius: 8px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.12);
    pointer-events: auto;
}

.ith-popup[hidden] { 
    display: none !important; 
}

.ith-popup-title { 
    font-weight: bold; 
    margin-bottom: 0;      /* Default to no margin */
}

/* Add margin only if title is followed by an image or content */
.ith-popup-title + .ith-popup-image,
.ith-popup-title + .ith-popup-content,
.ith-popup-image + .ith-popup-content {
    margin-top: 10px;
}

.ith-popup a { 
    color: #0073aa; 
    text-decoration: underline; 
}

.ith-popup-image img { 
    display: block; 
    max-width: 100%; 
    height: auto; 
    border-radius: 4px;
}

.ith-popup-content {
    font-size: 0.95rem;
    line-height: 1.4;
}