/* Tooltip Wrapper */
.custom-tooltip {
    position: relative;
    display: inline-block;
    cursor: pointer;
}

/* Tooltip Text */
.custom-tooltip .tooltip-text {
    visibility: hidden;
    width: 300px; 
    background-color: rgba(0, 0, 0, 0.8);
    font-size: 13px;
    line-height: 17px;
    text-transform: none;
    font-style: italic;
    font-weight: 400;
    color: #fff;
    text-align: left;
    border-radius: 5px;
    padding: 15px;
    position: absolute;
    z-index: 9999;
    bottom: 125%;
    left: 50%;
    transform: translateX(-50%);
    opacity: 0;
    transition: opacity 0.3s;
    pointer-events: none;
    box-sizing: border-box;
}

/* Tooltip Arrow */
.custom-tooltip .tooltip-text::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-width: 5px;
    border-style: solid;
    border-color: rgba(0, 0, 0, 0.75) transparent transparent transparent;
}

/* Show on hover and focus */
.tooltip-content-wrapper:hover + .tooltip-text,
.tooltip-content-wrapper:focus + .tooltip-text {
    visibility: visible;
    opacity: 1;
}

/* Responsive Adjustments */
@media (max-width: 993px) {
    .custom-tooltip .tooltip-text {
        left: 0;
        transform: translateX(0);
    }

    .custom-tooltip .tooltip-text::after {
        left: 10px;
        transform: none;
    }
}

@media (max-width: 400px) {
    .custom-tooltip .tooltip-text {
        width: 250px;
    }

    .custom-tooltip .tooltip-text::after {
        left: 10px;
    }
}

/* Accessibility Enhancements */
.tooltip-content-wrapper:focus + .tooltip-text {
    visibility: visible;
    opacity: 1;
}
