html, body {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
}


/* ----- ScrollBar --------------------------------------------------------- */
::-webkit-scrollbar {
    width: 5px;
    height: 5px;
}
::-webkit-scrollbar-track {
    background: transparent;
}
::-webkit-scrollbar-thumb {
    background: rgba(var(--bs-body-color-rgb), 0.5);
    border-radius: 5px;
}
/* ----- ScrollBar --------------------------------------------------------- */

/* ----- ContextMenu ------------------------------------------------------- */
.ctxmnubtn {
    border: 0px !important;
    border-radius: 0px !important;
}
.expandMenu {
    width: 100%;
    display: flex;
}
.expandMenuItem {
    display: none;
}
.expandMenu:hover .expandMenuItem {
    display: block;
}
/* ----- ContextMenu ------------------------------------------------------- */


/* ----- Badge HoverText --------------------------------------------------- */
.badgeht {
    display: inline-block;
}
.badgehtext {
    display: none;
}
.badgeht:hover .badgehtext {
    display: inline-block;
}
/* ----- Badge HoverText --------------------------------------------------- */

/* ----- Map --------------------------------------------------------------- */
.mapbox {
    padding: 0px;
    margin: 0px;
    min-width: 100%;
    min-height: 100%;
    max-width: 100%;
    max-height: 100%;
    overflow: hidden;
}
text {
    cursor: default;
    fill: var(--bs-body-color);
    font: 10px Consolas;
}
/* ----- Map --------------------------------------------------------------- */

/* ----- Map Links state --------------------------------------------------- */
.maplink {
    stroke-width: 2px;
    stroke: var(--bs-body-color);
    stroke-opacity: 0.2;
}
.maplink-stp {
    stroke-width: 2px;
    stroke: var(--map-stp-color);
    stroke-opacity: 0.4;
}
.maplink-sel {
    stroke-width: 2px;
    stroke: var(--map-selected-link-color);
    stroke-opacity: 0.4;
}
.maplink-route {
    stroke-width: 2px;
    stroke: var(--map-bestway-color);
    stroke-opacity: 0.1;
}
/* ----- Map Links state --------------------------------------------------- */

/* ----- PortView Styles --------------------------------------------------- */
.neon-panel {
    display: flex;
    flex-direction: column;
    gap: 5px; /* Минимальное пространство между рядами */
    background-color: #000; /* Чёрный фон панели */
    padding: 15px;
    border-radius: 8px;
    @* box-shadow: 0 0 8px #00FFFF;
    *@ max-width: 960px;
    margin: 0 auto;
    border: 3px double #202020;
}
.port-container {
    display: flex;
    justify-content: center;
    gap: 3px; /* Уменьшенное расстояние между портами */
    padding: 5px;
}
.port-card {
    width: 50px;
    height: 4.5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border: 1px solid #202020; /* Неоновая рамка */
    border-radius: 5px;
    box-shadow: 0 0 10px #202020, inset 0 0 10px #202020; /* Внешнее и внутреннее свечение */
    background: linear-gradient(145deg, #2a2a2a, #202020);
    text-align: center;
}
    .port-card:hover {
        transform: scale(1.1); /* Лёгкое увеличение при наведении */
        @* box-shadow: 0 0 5px #00FFFF; /* Внешнее и внутреннее свечение */
        *@
    }
.port-card-speed {
    font-family: monospace;
    text-wrap-mode: nowrap;
    font-size: 10px;
}
.port-label {
    font-size: 0.7rem;
    margin-top: 5px;
    color: #17D4FE;
    font-weight: bold;
    text-align: center;
    word-break: break-word;
}
/* ----- PortView Styles --------------------------------------------------- */

/* ----- Modal Colors ------------------------------------------------------ */
.modal-hdr {
    padding: 8px;
    color: var(--bs-body-color) !important;
    background: var(--bs-secondary-bg) !important;
}
.modal-ftr {
    background: var(--bs-tertiary-bg) !important;
    padding: 5px;
}
/* ----- Modal Colors ------------------------------------------------------ */

/* ----- Login panel ------------------------------------------------------- */
.loginwnd {
    position: absolute !important;
    width: 300px;
    left: calc(50% - 150px);
    top: calc(50% - 50px);
    border: 1px solid var(--bs-gray);
    padding: 10px;
    border-radius: 10px;
    height: 100px;
    opacity: 0.9;
    cursor: default;
    user-select: none;
    backdrop-filter: blur(5px);
    box-shadow: 0px 0px 10px var(--bs-primary);
}
.loginver {
    position: absolute;
    right: .5rem;
    bottom: .5rem;
    text-shadow: 0px 0px 2px var(--bs-primary);
    color: transparent;
    font: .75rem Monospace;
}
/* ----- Login panel ------------------------------------------------------- */

/* ----- Input Validator --------------------------------------------------- */
.txtval:valid {
    background-color: var(--bs-body-bg);
}
.txtval:invalid {
    background-color: var(--bs-danger-border-subtle);
}
/* ----- Input Validator --------------------------------------------------- */

/* ----- PasswordField ----------------------------------------------------- */
.pwd {
    cursor: default;
    filter: blur(4px);
}
    .pwd:hover {
        filter: unset;
    }
/* ----- PasswordField ----------------------------------------------------- */

/* ----- Opacity Field ----------------------------------------------------- */
.op {
    opacity: .5;
}
    .op:hover {
        opacity: 1;
    }
.op25 {
    opacity: .25;
}
    .op25:hover {
        opacity: 1;
    }
/* ----- Opacity Field ----------------------------------------------------- */

/* ----- Side bar ---------------------------------------------------------- */
.sidebar2 {
    height: 100vh;
    position: sticky;
    top: 0;
    transition: 0.5s cubic-bezier(.77,0,.18,1);
}
.nav-scrollable2 {
    background-color: #1b1b1b !important;
    color: var(--bs-body-color) !important;
    overflow-y: clip;
    height: calc(100% - 3.5rem);
    max-height: calc(100% - 3.5rem);
    display: flex;
    align-content: stretch;
    flex-wrap: nowrap;
    flex-direction: column;
    justify-content: space-between;
    overflow-y: auto;
}
.top-row2 {
    align-items: center;
    background-color: var(--bs-body-bg);
    border-bottom: 1px solid #3F474F;
    border-radius: unset;
    color: var(--bs-body-color);
    display: flex;
    height: 3.5rem;
    justify-content: flex-end;
    padding-left: 2rem;
    padding-right: 1.5rem;
    position: sticky;
    top: 0;
    z-index: 1;
}
.svglogo {
    height: 48px;
    /*filter: invert(100%);*/
    padding: 5px 0px;
    overflow-x: hidden;
    user-select: none;
    cursor: default;
}
.top-row {
    background-color: var(--bs-body-bg) !important;
    color: var(--bs-body-color) !important;
    border-bottom: 1px solid #3F474F !important;
}
/* ----- Side bar ---------------------------------------------------------- */

.content {
    padding-top: 1.1rem;
}
h1:focus {
    outline: none;
}
.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}
.invalid {
    outline: 1px solid #e50000;
}
.validation-message {
    color: #e50000;
}
.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}
    .blazor-error-boundary::after {
        content: "An error has occurred."
    }
.darker-border-checkbox.form-check-input {
    border-color: #929292;
}


/* ----- Dragable windows -------------------------------------------------- */
.draggable {
    position: absolute;
    z-index: 1500;
}
.draggableheader {
    padding: 10px;
    cursor: move;
    z-index: 1501;
}
.wnd {
    --bs-wnd-zindex: 1092;
    --bs-wnd-padding-x: 0.75rem;
    --bs-wnd-padding-y: 0.5rem;
    --bs-wnd-spacing: 1.5rem;
    --bs-wnd-max-width: 350px;
    --bs-wnd-font-size: 0.875rem;
    --bs-wnd-color:;
    --bs-wnd-bg: rgba(var(--bs-body-bg-rgb), 1);
    --bs-wnd-border-width: var(--bs-border-width);
    --bs-wnd-border-color: var(--bs-border-color-translucent);
    --bs-wnd-border-radius: var(--bs-border-radius);
    --bs-wnd-box-shadow: var(--bs-box-shadow);
    --bs-wnd-header-color: var(--bs-secondary-color);
    --bs-wnd-header-bg: rgba(var(--bs-secondary-bg), 1);
    --bs-wnd-header-border-color: var(--bs-border-color-translucent);
    width: max-content !important;
    max-width: 100%;
    font-size: var(--bs-wnd-font-size);
    color: var(--bs-wnd-color);
    pointer-events: auto;
    background-color: var(--bs-wnd-bg);
    background-clip: padding-box;
    border: var(--bs-wnd-border-width) solid var(--bs-wnd-border-color);
    box-shadow: var(--bs-wnd-box-shadow);
    border-radius: var(--bs-wnd-border-radius);
    user-select: none;
}
    .wnd.showing {
        opacity: 0
    }
    .wnd:not(.show) {
        display: none
    }
.wnd-container {
    --bs-wnd-zindex: 1000;
    position: absolute;
    z-index: var(--bs-wnd-zindex);
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    max-width: 100%;
    pointer-events: none;
    user-select: none;
}
    .wnd-container > :not(:last-child) {
        margin-bottom: var(--bs-wnd-spacing)
    }
.wnd-header {
    display: flex;
    align-items: center;
    padding: var(--bs-wnd-padding-y) var(--bs-wnd-padding-x);
    color: var(--bs-wnd-header-color);
    background-color: var(--bs-secondary-bg);
    background-clip: padding-box;
    border-bottom: var(--bs-wnd-border-width) solid var(--bs-wnd-header-border-color);
    border-top-left-radius: calc(var(--bs-wnd-border-radius) - var(--bs-wnd-border-width));
    border-top-right-radius: calc(var(--bs-wnd-border-radius) - var(--bs-wnd-border-width));
    user-select: none;
}
    .wnd-header .btn-close {
        margin-right: calc(-.5 * var(--bs-wnd-padding-x));
        margin-left: var(--bs-wnd-padding-x);
    }
    .wnd-header .btn-ex {
        padding: 0px 2px 0px 2px;
        border: none;
        height: 22px;
    }
.wnd-body {
    padding: 0.25rem;
    word-wrap: break-word;
    user-select: none;
}
/* ----- Dragable windows -------------------------------------------------- */

/* ----- Dragable windows -------------------------------------------------- */

.txblock {
    width: 475px;
    height: 275px;
    background-color: var(--bs-body-bg);
    border: none;
    border-bottom: solid var(--bs-tertiary-color) 1px;
    font-family: var(--bs-font-monospace);
    font-size: 12px;
    line-height: 13px;
    outline: 0 !important;
    resize: both;
}
.txcmd {
    width: 100%;
    background-color: var(--bs-body-bg);
    border: none;
    font-family: var(--bs-font-monospace);
    font-size: 12px;
    line-height: 13px;
    outline: 0 !important;
}

.themedbg {
    background-color: var(--bs-body-bg);
}
    .themedbg tr th {
        background-color: var(--bs-body-bg) !important;
    }
        .themedbg tr th div button {
            background-color: var(--bs-body-bg) !important;
            color: var(--bs-body-color) !important;
            border: none;
        }


    text .textG {
        color: #fff;
    }
    text .textR {
        color: #fff;
    }
    text .textS {
        color: #fff;
    }
    text .textH {
        color: #fff;
    }

/* ----- Table Odd/Even selected rows -------------------------------------- */
.g {
    background: var(--bs-secondary-bg);
}
.gs {
    background: var(--bs-red);
}
/* ----- Table Odd/Even selected rows -------------------------------------- */

/* ----- Group view TreeNodes ---------------------------------------------- */
.treenode0 {
    display: flex;
    background: unset;
    border-radius: 3px;
    padding: 1px 4px;
    cursor: default;
}
    .treenode0:hover {
        background-color: rgba(255,255,255,0.37);
    }
.treenode {
    margin-left: 26px;
}
/* ----- Group view TreeNodes ---------------------------------------------- */

/* ----- Event state sticker ----------------------------------------------- */
.tlb- {
    --qbs-gray: #6c757d;
    height: 25px;
    fill: var(--qbs-gray);
    background-color: var(--qbs-gray);
    opacity: .1;
}
    .tlb-:hover {
        --qbs-gray-tp: #6c757db0;
        fill: var(--qbs-gray-tp);
        background-color: var(--qbs-gray-tp);
    }
.tlb-0 {
    --qbs-gray: #6c757d;
    height: 25px;
    fill: var(--qbs-gray);
    background-color: var(--qbs-gray);
}
    .tlb-0:hover {
        --qbs-gray-tp: #6c757db0;
        fill: var(--qbs-gray-tp);
        background-color: var(--qbs-gray-tp);
    }
.tlb-1 {
    --qbs-purple: #6f42c1;
    height: 25px;
    fill: var(--qbs-purple);
    background-color: var(--qbs-purple);
}
    .tlb-1:hover {
        --qbs-purple-tp: #6f42c1b0;
        fill: var(--qbs-purple-tp);
        background-color: var(--qbs-purple-tp);
    }
.tlb-2 {
    --qbs-red: #dc3545;
    height: 25px;
    fill: var(--qbs-red);
    background-color: var(--qbs-red);
}
    .tlb-2:hover {
        --qbs-red-tp: #dc3545b0;
        fill: var(--qbs-red-tp);
        background-color: var(--qbs-red-tp);
    }
.tlb-3 {
    --qbs-orange: #fd7e14;
    height: 25px;
    fill: var(--qbs-orange);
    background-color: var(--qbs-orange);
}
    .tlb-3:hover {
        --qbs-orange-tp: #fd7e14b0;
        fill: var(--qbs-orange-tp);
        background-color: var(--qbs-orange-tp);
    }
.tlb-4 {
    --qbs-yellow: #ffc107;
    height: 25px;
    fill: var(--qbs-yellow);
    background-color: var(--qbs-yellow);
}
    .tlb-4:hover {
        --qbs-yellow-tp: #ffc107b0;
        fill: var(--qbs-yellow);
        background-color: var(--qbs-yellow);
    }
.tlb-5 {
    --qbs-teal: #20c997;
    height: 25px;
    fill: var(--qbs-teal);
    background-color: var(--qbs-teal);
}
    .tlb-5:hover {
        --qbs-teal-tp: #20c997b0;
        fill: var(--qbs-teal-tp);
        background-color: var(--qbs-teal-tp);
    }
.tlb-6 {
    --qbs-blue: #0d6efd;
    height: 25px;
    fill: var(--qbs-blue);
    background-color: var(--qbs-blue);
}
    .tlb-6:hover {
        --qbs-blue-tp: #0d6efdb0;
        fill: var(--qbs-blue-tp);
        background-color: var(--qbs-blue-tp);
    }
.tlb-7 {
    --qbs-cyan: #0dcaf0;
    height: 25px;
    fill: var(--qbs-cyan);
    background-color: var(--qbs-cyan);
}
    .tlb-7:hover {
        --qbs-cyan-tp: #0dcaf0b0;
        fill: var(--qbs-cyan-tp);
        background-color: var(--qbs-cyan-tp);
    }
/* ----- Event state sticker ----------------------------------------------- */




.syslogcheck {
    margin: 0px !important;
    padding: 8px 0px !important;
    height: 15px !important;
    width: 35px !important;
}

.mapnewradiusslider {
    width: 15rem;
    height: 40px;
    border: var(--bs-border-width) solid var(--bs-border-color);
    border-top-right-radius: var(--bs-border-radius);
    border-bottom-right-radius: var(--bs-border-radius);
}


/* OTHER STYLES BLOCK  */
/* for fast update */
/* https://www.random.org/strings/?num=10&len=10&digits=on&upperalpha=on&loweralpha=on&unique=on&format=html&rnd=new */


.v9NUwVMn1b {
    justify-content: center;
    display: flex;
    position: absolute;
    background-color: var(--bs-body-bg) !important;
}
.XKOpT3bCeX {
    width: fit-content;
    border: 1px solid var(--bs-secondary-bg);
    border-radius: 5px;
    padding: 5px 10px;
}
.XdnLfWDQcs {
    justify-content: center;
    display: flex;
    position: absolute;
    background-color: var(--bs-body-bg) !important;
    right: 10px;
    z-index:0;
}
.JxwfOetejv {
    width: fit-content;
    border: 1px solid var(--bs-secondary-bg);
    border-radius: 5px;
    padding: 5px;
}
.XGJ3C5hzWb {
    font-family: var(--bs-font-monospace);
    overflow-y: auto;
    max-height: 50vh;
    width: 300px;
    box-shadow: 0 0 10px var(--bs-secondary);
}
.J1ETXbNsRe {
    width: 200px;
    height: 2rem;    
}
ijL8i7VkZj {
    max-height: 2rem;
}
