.form-select {
    padding: .5rem;

}

.form-control {
    padding: .5rem;

}

.form-check-input {
    width: 1.125rem;
    height: 1.125rem;
    margin-top: 0;
}

.btn {
    padding: 4px 8px !important;
}

.valid-until {
    color: green;
}

.expires-soon {
    color: orange;
}

.expired-at {
    color: red;
}

.link-connectionstate {
}

.link-connectionstate- {
    background-color: red;
}

.link-connectionstate-Disconnected {
    background-color: salmon !important;
}

.link-connectionstate-Connecting {
    background-color: orange !important;
}

.link-connectionstate-Connected {
    background-color: lightgreen !important;
}

.link-clients {
    text-align: center;
    border-radius: 0px;
    padding: 0px 4px;
}

.link-clients-connected {
    background-color: lightgreen;
}

.link-clients-notconnected {
    background-color: lightcoral;
}


.link-host {
    text-align: center;
    padding: 0px 4px;
    border-radius: 0px;
    background-color: rgb(222, 222, 222);
}


.link-port {
    text-align: center;
    padding: 0px 4px;
    border-radius: 0px;
    background-color: silver;
}

li.connected-client {
    list-style-type: none;
}

.link-layer {
    text-align: center;
    color: silver;
}


.code {
    white-space: pre;
    font-family: "Lucida Console", "Courier New", monospace;
}



div.code {
    color:white;
    display:block;
    width:24px;
    background-color:black;
    border-right: 1px solid #333333;
    text-align:center;
    vertical-align:middle;
}

.character {
    font-size:10px;
    font-weight:normal;
    color:black;
    text-align:center;
}

.code-special {
    font-size:10px;   
    font-weight:normal;
    line-height:10px !important;
    background-color:silver;
    color:black;
}

.code-regular {   
    font-weight:normal;   
    
}

.output .code {
    font-size: 20px;
}

h1.box-title, .box h1, .box2 h1 {
    margin-top: 8px;
    margin-bottom: 16px;
    font-weight: 400 !important;
    font-size: 1.15rem !important;
    text-transform: uppercase;
    font-weight: 500 !important;
    color: gray
}

h2.box-title, .box h2, .box2 h2 {
    margin-top: 16px;
    margin-bottom: 16px;
    font-weight: 400 !important;
    font-size: 1.05rem !important;
    text-transform: uppercase;
    font-weight: 500 !important;
    color: gray
}

.box {
    flex: 1 1 auto;
    padding: 0.5rem 0.5rem !important;
    border-radius: 0px !important;
    box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px !important;
    border: none !important;
    position: relative;
    margin-bottom: 1rem;
    display: flex;
    flex-direction: column;
    min-width: 0;
    word-wrap: break-word;
    background-color: #ffffff;
    background-clip: border-box;
}

.box-selected {
    border: 3px solid var(--primary-accent-color) !important;
    background: linear-gradient(135deg, var(--primary-accent-color) 10px, white 0);
    overflow: hidden;
}


.box2 {
    flex: 1 1 auto;
    padding: 0.5rem 0.5rem !important;
    border-radius: 0px !important;
    box-shadow: none !important;
    border: none !important;
    position: relative;
    margin-bottom: 1rem;
    display: flex;
    flex-direction: column;
    min-width: 0;
    word-wrap: break-word;
    background-color: #efefef8c;
    background-clip: border-box;
}


.fa-connections:before {
    content: '\f1e6';
}

.fa-live:before {
    content: '\f611';
}

.fa-log:before {
    content: '\e17c';
}

.fa-reconnect:before {
    content: '\f2f1';
}

.fa-link:before {
    content: '\f0ec';
}

.fa-scene:before {
    content: '\e132';
}

.fa-script:before {
    content: '\f70e';
}

.fa-play:before {
    content: '\f04b';
}

.fa-stop:before {
    content: '\f04d';
}

.fa-refresh:before {
    content: '\f021';
}

.btn-spinner {
    position: relative;
}

.btn-spinner::before {
    content: "";
}

    .btn-spinner::after {
        content: "";
        position: absolute;
        width: 16px;
        height: 16px;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        margin: auto;
        border: 4px solid transparent;
        border-top-color: #ffffff;
        border-radius: 50%;
        animation: button-loading-spinner 1s ease infinite;
    }
    
    .teaser {
        display: block ;
        height:140px;
        
        text-align:center;
        margin:auto;
        padding: 15px;
    }

