  /* Den klickbara/hovrbara texten */
  .bm-niva{
    position:relative;
    display:inline-flex;
    align-items:center;
    gap:6px;
    cursor:help;
    border-bottom:1px dashed rgba(251,69,112,.55);
    color:inherit;
    font:inherit;
  }
  .bm-niva:focus-visible{outline:2px solid #fb4570; outline-offset:3px; border-radius:3px;}
 
  /* Själva rutan (tooltip) */
  .bm-niva__ruta{
    position:absolute;
    bottom:calc(100% + 14px);
    left:50%;
    transform:translateX(-50%) translateY(6px);
    width:300px;
    max-width:80vw;
    box-sizing:border-box;       /* padding ingår i bredden */
    white-space:normal;          /* åsidosätt ev. nowrap från sidans CSS */
    word-break:break-word;
    background:#1c2230;
    color:#e7e9ef;
    border:1px solid rgba(251,69,112,.35);
    border-radius:12px;
    padding:18px 18px 14px;
    box-shadow:0 20px 50px rgba(10,12,20,.45);
    z-index:50;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:opacity .18s ease, transform .18s ease, visibility .18s;
    text-align:left;
    font-size:14px;
    line-height:1.55;
  }
  /* Visa vid hover, fokus eller .is-open (touch) */
  .bm-niva:hover .bm-niva__ruta,
  .bm-niva:focus-within .bm-niva__ruta,
  .bm-niva.is-open .bm-niva__ruta{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateX(-50%) translateY(0);
  }
  /* Osynlig "bro" som täcker glappet mellan text och ruta,
     så att hover inte tappas när man rör sig uppåt */
  .bm-niva__ruta::before{
    content:"";
    position:absolute;
    top:100%;
    left:0;
    right:0;
    height:18px;            /* lite mer än glappet (14px) för marginal */
  }
  /* Liten pil neråt */
  .bm-niva__ruta::after{
    content:"";
    position:absolute;
    top:100%;
    left:50%;
    transform:translateX(-50%);
    border:8px solid transparent;
    border-top-color:#1c2230;
  }
 
  .bm-niva__titel{
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin:0 0 8px;
    font-size:15px;
    font-weight:700;
    color:#fff;
    letter-spacing:.3px;
  }
  /* Prickarna som visar nivån */
  .bm-niva__prickar{display:flex; gap:5px;}
  .bm-niva__prickar i{
    width:9px; height:9px; border-radius:50%;
    background:rgba(255,255,255,.18);
    display:inline-block;
  }
  .bm-niva__prickar i.fylld{background:#fb4570; box-shadow:0 0 8px rgba(251,69,112,.6);}
 
  .bm-niva__text{margin:0 0 12px; color:#c5c9d4;}
 
  .bm-niva__lank{
    display:inline-flex;
    align-items:center;
    gap:5px;
    color:#fb4570;
    text-decoration:none;
    font-weight:600;
    font-size:13px;
    border-top:1px solid rgba(255,255,255,.1);
    padding-top:11px;
    width:100%;
  }
  .bm-niva__lank:hover{color:#ff6f93;}
  .bm-niva__lank svg{transition:transform .15s ease;}
  .bm-niva__lank:hover svg{transform:translateX(3px);}
  .bm-niva__titel span{
    color:#fff;
  }


  .rating-visual i {
    font-size: 30px;
    color: #ccc;
}

.rating-visual i.filled {
    color: gold;
}

.key-wrapper {
    position: relative;
    display: inline-block;
}

.key-wrapper i {
    display: block;
}

.key-wrapper i.filled {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    white-space: nowrap;
}