html {
    overflow-y: scroll;
}

.navbar-inverse {
    background-color: #2d373c;
}

.well {
    background-color: #C0E3E0;
}

@media (min-width: 992px) and (max-width: 1199px) {
    .well {
        padding: 19px 5px;
    }
}

a {
    color: #d20537;
}

.list-group-item {
    padding: 0px 15px;
}

h1 {
    font-size: 2em;
    margin-top: 0;
}

h2 {
    font-size: 1.5em;
}

h3 {
    font-size: 1.3em;
}

.breadcrumb {
    margin-bottom: 0;
    padding: 10px 0 !important;
}

.breadcrumb li a {
    color: #333;
}

.breadcrumb li a:hover {
    color: #d20537;
}

.breadcrumb>li+li::before {
    content: "\003e ";
}

.navbar-inverse .navbar-nav>.active>a,
.navbar-inverse .navbar-nav>.active>a:focus,
.navbar-inverse .navbar-nav>.active>a:hover {
    background-color: #d20537;
}

.navbar-nav>li>a:hover {
    background-color: white !important;
    color: #333 !important;
}

.jumbotron {
    background-color: #a5d7d2;
    padding: 10px 0;
    margin-bottom: 0;
}

@media (min-width: 768px) and (max-width: 991px) {
    .jumbotron {
        padding-top: 60px;
    }
}

.navbar-inverse .navbar-brand {
    color: white;
}

.navbar-inverse .navbar-nav>li>a {
    color: white;
}

.btn-primary,
.btn-primary:focus {
    background-color: #a5d7d2;
    border-color: #a5d7d2;
}

.btn-primary:hover,
.btn-primary:active {
    background-color: gray;
    border-color: gray;
}

.redbutton,
.redbutton:focus {
    background-color: #d20537;
    border-color: #d20537;
}

.redbutton:hover,
.redbutton:active {
    background-color: gray;
    border-color: gray;
}

.btn-primary .badge {
    color: #d20537;
}

.pagination>li>a,
.pagination>li>span {
    color: #d20537;
}

.pagination>.active>a,
.pagination>.active>span,
.pagination>.active>a:hover,
.pagination>.active>span:hover,
.pagination>.active>a:focus,
.pagination>.active>span:focus {
    background-color: #d20537;
    border-color: #d20537;
}

.breadcrumbbar {
    background-color: #f5f5f5;
    margin-bottom: 20px;
}

.logo {
    display: block;
    text-indent: -9999px;
    width: 141px;
    height: 45px;
    background: url('/images/uni-basel-logo.svg');
    background-size: 141px 45px;
    border: none;
}

/* page extensions - 09/2024 */
/* Matthias Müller, nextron.ch */

.page-footer {
    position: relative;
    display: block;
    background: #f5f5f5;
    padding: 10px 0;
}

.page-footer .footer-inner {
    position: relative;
    display: block;
}

@media (min-width: 992px) {
    .page-footer .footer-inner {
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: flex-start;
    }
}

.page-footer .footer-inner>p {
    margin-bottom: 10px;
}

@media (min-width: 992px) {
    .page-footer .footer-inner>p {
        margin-bottom: 0;
    }
}

.page-footer .footer-inner>ul {
    position: relative;
    display: block;
    margin: 0;
    padding: 0;
}

.page-footer .footer-inner>ul::after {
    content: '';
    display: block;
    clear: both;
}

@media (min-width: 992px) {
    .page-footer .footer-inner>ul {
        padding-left: 30px;
    }
}

@media (min-width: 992px) {
    .page-footer .footer-inner>ul::before {
        content: '-';
        display: block;
        position: absolute;
        top: 0;
        left: 12px;
        z-index: 1;
        color: #bbb;
    }
}

.page-footer .footer-inner>ul>li {
    position: relative;
    display: block;
    margin: 0;
    padding: 0 20px 0 0;
    list-style: none;
    float: left;
}

.page-footer .footer-inner>ul>li::after {
    content: '|';
    display: block;
    position: absolute;
    top: 0;
    right: 8px;
    z-index: 1;
    color: #bbb;
}

.page-footer .footer-inner>ul>li:last-child {
    padding-right: 0;
}

.page-footer .footer-inner>ul>li:last-child::after {
    display: none;
}

.page-footer .footer-inner>ul>li>a,
.page-footer .footer-inner>ul>li>a:is(:hover, :focus, :active) {
    color: inherit;
    text-decoration: none;
}

.page-footer .footer-inner>ul>li>a:is(:hover) {
    color: #d20537;
    text-decoration: underline;
}

.page-footer .footer-inner > small {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
}

@media (max-width: 991.98px) {
    .page-footer .footer-inner > small {
        padding-top: 10px;
        position: relative;
        top: auto;
        right: auto;
    }
}

.select2-container {
    display: block;
    width: 100% !important;
    padding: 0;
    margin: 0 !important;
    color: #555;
}

.select2-container-multi .select2-choices {
    border: 1px solid #ccc;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
    background: #c0e3e0;
    border: 1px solid #a5d7d2;
    border-radius: 0 !important;
    padding: 0 20px 0 5px !important;
    box-shadow: none !important;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove,
.select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
    left: auto;
    right: 5px;
    top: 1px;
    bottom: 0;
    display: block;
    border: none !important;
    background: transparent !important;
    border-radius: 0 !important;
    font-size: 18px;
    line-height: 18px;
    padding: 0 !important;
}

.select2-container--default .select2-results__option--selected {
    background: #c0e3e0;
}

.searchfields button {
    background-color: #e6e6e6 !important;
}

@media (max-width: 991.98px) {
    .table-max-width {
        position: relative;
        display: block;
        width: 100%;
        max-width: 100%;
        overflow-x: auto;
    }
}

table.table-events td,
table.table-events th {
    hyphens: auto !important;
}

table.table-events {
    border-left: none !important;
    border-right: none !important;
}

@media screen and (max-width: 767px) {

    div.dt-container div.dt-length,
    div.dt-container div.dt-search,
    div.dt-container div.dt-info,
    div.dt-container div.dt-paging {
        text-align: left !important;
    }
}

@media (min-width: 992px) {
    .page-frame {
        min-height: calc(100vh - 91px);
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .jumbotron {
        padding-top: 10px;
    }
}

.navbar-fixed-top {
    border: none !important;
}

.navbar-inverse .navbar-nav>li>a,
.navbar-inverse .navbar-nav>li>a:focus,
.navbar-inverse .navbar-nav>li>a:hover {
    padding-left: 20px;
    padding-right: 20px;
}

.navbar-inverse .navbar-nav>li.active>a,
.navbar-inverse .navbar-nav>li.active>a:focus,
.navbar-inverse .navbar-nav>li.active>a:hover {
    background-color: #a5d7d2 !important;
    color: inherit !important;
}

.navbar-header .navbar-clipboard {
    display: block;
    position: absolute;
    color: #fff !important;
    text-decoration: none !important;
    height: 50px;
    padding: 0 10px;
    top: 0;
    right: 60px;
    z-index: 1;
}

@media (min-width: 768px) {
    .navbar-header .navbar-clipboard {
        display: none;
    }
}

.navbar-header .navbar-clipboard i {
    font-size: 20px;
    color: #fff !important;
    text-decoration: none;
    line-height: 50px;
}

.navbar-header .navbar-clipboard span.clipboard-counter {
    display: block;
    height: 16px;
    background: rgb(210, 5, 55);
    padding: 0 5px;
    color: #fff;
    border-radius: 5px;
    position: absolute;
    font-size: 11px;
    line-height: 16px;
    top: 5px;
    right: 0;
    z-index: 1;
}

nav li.nav-clipboard {
    position: relative;
}

nav li.nav-clipboard span.clipboard-counter {
    display: block;
    height: 16px;
    background: rgb(210, 5, 55);
    padding: 0 5px;
    color: #fff;
    border-radius: 5px;
    position: absolute;
    font-size: 11px;
    line-height: 16px;
    top: 3px;
    right: 10px;
    z-index: 1;
}

@media (max-width: 767.98px) {
    .navbar-collapse span.clipboard-counter {
        display: none !important;
    }
}

input {
    outline: none !important;
}

table.dataTable input.dt-select-checkbox {
    width: 16px !important;
    height: 16px !important;
}

table.dataTable input.dt-select-checkbox:indeterminate::after {
    top: 5px !important;
    left: 5px !important;
}

table.dataTable input.dt-select-checkbox:checked::after {
    font-family: "Font Awesome 6 Pro";
    font-weight: 500;
    content: "\f00c" !important;
    position: absolute;
    font-size: 22px;
    top: 3px;
    left: 0;
}

@keyframes bounce {
    0%, 100% {
        transform: scale(1);
    }

    30% {
        transform: scale(1.3);
    }

    50% {
        transform: scale(0.9);
    }

    70% {
        transform: scale(1.1);
    }
}

.clipboard-counter.bounce {
    animation: bounce 0.6s ease;
}

.input-clear-button {
    width: 35px;
    position: absolute;
    right: 5px;
    top: 50%;
    transform: translateY(40%);
    height: 14px;
    font-size: 16px;
    cursor: pointer;
    color: #cccccc;
}

@media (max-width:991.98px) {
    .input-clear-button {
        transform: translateY(115%);
    }
}

table.table.dataTable>tbody>tr.selected a,
table.table.dataTable>tbody>tr.selected a:is(:focus, :active) {
    color: #d20537 !important;
    text-decoration: none;
}

table.table.dataTable>tbody>tr.selected a:is(:hover) {
    color: #d20537 !important;
    text-decoration: underline;
}

table.table.dataTable.table-hover>tbody>tr:hover>* {
    box-shadow: none !important;
}

table.table.dataTable.table-striped>tbody>tr:nth-of-type(2n+1)>*,
table.table.dataTable.table-striped>tbody>tr:hover:nth-of-type(2n+1)>* {
    box-shadow: inset 0 0 0 9999px rgba(var(--dt-row-stripe), 0.05) !important;
}

.form-control,
.form-control:focus {
    background-color: #fff !important;
}

.form-control:focus {
    border-color: #a5d7d2;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 8px rgba(165, 215, 210, .6);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 8px rgba(165, 215, 210, .6);
}

.label-default {
    background: #c0e3e0;
    border: 1px solid #a5d7d2;
    color: rgb(85, 85, 85);
    font-weight: 100px;
}