.fonts {
    font-family: 'GenYoGothic', Arial, Helvetica, sans-serif;
}

.flag-hint {
    position: absolute;
    z-index: 998;
    background: #fffbe6;
    border: 2px solid #d5d1bd;
    border-radius: 2px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .12);
    padding: .6em .9em;
    max-width: 260px;
    line-height: 1.45;
    display: none;
}

.flag-hint .flag-hint-arrow {
    position: absolute;
    width: 10px;
    height: 10px;
    transform: rotate(45deg);
    background: #fffbe6;
    border-left: 2px solid #d5d1bd;
    border-top: 2px solid #d5d1bd;
    left: -7.5px;
    top: 20%;
    margin-top: -5px;
}

.flag-hint .flag-hint-body {
    font-size: 1em;
    padding-right: 1.2em;
}

.flag-hint .flag-hint-close {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 0;
    border-radius: 4px;
    cursor: pointer;
}

.flag-hint .flag-hint-close:hover {
    background: rgba(0, 0, 0, .06);
}

.flag-hint .flag-hint-close:active {
    background: rgba(0, 0, 0, .12);
}

.flag-hint .flag-hint-close img {
    width: 16px;
    height: 16px;
    display: block;
}

#flag-hint-dismiss-week {
    -webkit-appearance: checkbox;
    appearance: checkbox;
    width: auto;
    height: auto;
    border-radius: initial;
    vertical-align: middle;
}

.flag-hint label {
    display: inline-flex;
    align-items: center;
    gap: .45em;
    user-select: none;
}

.flag-hint label span {
    font-size: 0.8em;
    margin-left: 0;
}

.flag {
    cursor: pointer;
}