/* utilisation : 
<span tooltip-bot="Tooltip help here!" data-flow="bottom">CSS Tooltips</span>  
*/

[tooltip-bot] {
    z-index: 1d;
    position: relative;
    cursor: pointer;
}

[tooltip-bot]:before,
[tooltip-bot]:after {
    line-height: 1;
    font-size: .9em;
    pointer-events: none;
    position: absolute;
    box-sizing: border-box;
    display: none;
    opacity: 0;
    filter: drop-shadow(0px 0px 10px #800000);
}

[tooltip-bot]:before {
    content: "";
    border: 5px solid transparent;
    z-index: 100;
}

[tooltip-bot]:after {
    content: attr(tooltip-bot);
    text-align: center;
    min-width: 3em;
    max-width: 21em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 10px 8px;
    border-radius: 3px;
    background: #C22525;
    color: #FFFFFF;
    z-index: 99;
}

[tooltip-bot]:hover:before,
[tooltip-bot]:hover:after {
    display: block;
    opacity: 1;
}

[tooltip-bot]:not([data-flow])::before,
[tooltip-bot][data-flow="top"]::before {
    bottom: 100%;
    border-bottom-width: 0;
    border-top-color: #C22525;
}

[tooltip-bot]:not([data-flow])::after,
[tooltip-bot][data-flow="top"]::after {
    bottom: calc(100% + 5px);
}

[tooltip-bot]:not([data-flow])::before,
[tooltip]:not([data-flow])::after,
[tooltip-bot][data-flow="top"]::before,
[tooltip-bot][data-flow="top"]::after {
    left: 50%;
    -webkit-transform: translate(-50%, -4px);
    transform: translate(-50%, -4px);
}

[tooltip-bot][data-flow="bottom"]::before {
    top: 100%;
    border-top-width: 0;
    border-bottom-color: #C22525;
}

[tooltip-bot][data-flow="bottom"]::after {
    top: calc(100% + 5px);
}

[tooltip-bot][data-flow="bottom"]::before,
[tooltip-bot][data-flow="bottom"]::after {
    left: 50%;
    -webkit-transform: translate(-50%, 8px);
    transform: translate(-50%, 8px);
}

[tooltip-bot][data-flow="left"]::before {
    top: 50%;
    border-right-width: 0;
    border-left-color: #C22525;
    left: calc(0em - 5px);
    -webkit-transform: translate(-8px, -50%);
    transform: translate(-8px, -50%);
}

[tooltip-bot][data-flow="left"]::after {
    top: 50%;
    right: calc(100% + 5px);
    -webkit-transform: translate(-8px, -50%);
    transform: translate(-8px, -50%);
}

[tooltip-bot][data-flow="right"]::before {
    top: 50%;
    border-left-width: 0;
    border-right-color: #C22525;
    right: calc(0em - 5px);
    -webkit-transform: translate(8px, -50%);
    transform: translate(8px, -50%);
}

[tooltip-bot][data-flow="right"]::after {
    top: 50%;
    left: calc(100% + 5px);
    -webkit-transform: translate(8px, -50%);
    transform: translate(8px, -50%);
}

[tooltip-bot=""]::after,
[tooltip-bot=""]::before {
    display: none !important;
}