/* === START OF general instructions === */
html,
body {
    /* background-color: #d0ae8d; */
    background-color: #7B2020;
    color: #fff;
    font-family: "PT Sans";
}
.container-content .row div {
    /* max-width: 75rem; */
    /* margin: 0 auto; */
}
.noselect {
    -webkit-touch-callout: none;
    /* iOS Safari */
    -webkit-user-select: none;
    /* Safari */
    -khtml-user-select: none;
    /* Konqueror HTML */
    -moz-user-select: none;
    /* Old versions of Firefox */
    -ms-user-select: none;
    /* Internet Explorer/Edge */
    user-select: none;
    /* Non-prefixed version, currently supported by Chrome, Edge, Opera and Firefox */
}
.nowrap {
    white-space: nowrap;
}
h4 font b,
h4 font span {
    color: #7B2020;
}
/* === END OF general instructions === */


/* === START OF text styles with classes === */
.text-left {
    text-align: left;
}
.text-center {
    text-align: center;
}
.text-right {
    text-align: right;
}
.text-middle {
    vertical-align: middle;
}
.text-bold {
    font-weight: bold;
}
.text-very-small,
.text-xs {
    font-size: 0.25em !important;
}
.text-xs {
    font-size: 0.5em !important;
}
.text-small {
    font-size: 0.85em;
}
.text-big {
    font-size: 1.6em;
}
.text-normal {
    font-weight: normal !important;
}
/* === END OF text styles with classes === */


/* === START of margin and padding classes === */
.mtb-100 {
    margin-top: 100px;
    margin-bottom: 100px;
}
.ptb-100 {
    padding-top: 100px;
    padding-bottom: 100px;
}
.me-6 {
    margin-right: 30px;
}
/* === END of margin and padding classes === */

/* === START of error message === */
.error-message {
    font-size: 1.25em;
}
#message-container {
    display: none;
}
/* === END of error message === */

/* === START of buttons extra style === */
.btn {
    font-weight: bold;
}
.btn-128px {
    width: 128px;
}
.btn-m128px {
    min-width: 128px;
}
.btn-m50px {
    min-width: 50px;
}

.btn-success {
    background: #d0ae8d;
    border-color: #d0ae8d;
}
.btn-success:hover {
    background: #b08e6d;
    border-color: #b08e6d;
}

.text-bg-success {
    background-color: #d0ae8d;
    color: white;
}

button#save-button {
    padding: 0.6rem 1.6rem;
}
button#save-button i {
    margin-right: 0.3rem;
}

/* Specify the effect when the button is hovered over */
.shaky-btn {
    animation: shake 0.250s ease-out;
}
/* Use the keyframes for defining the animation */
@keyframes shake {
    0% {
        position: relative;
        left: 0px;
    }

    25% {
        position: relative;
        left: -5px;
    }

    50% {
        position: relative;
        left: 0px;
    }

    75% {
        position: relative;
        left: 5px;
    }

    100% {
        position: relative;
        left: 0px;
    }
}

.btn-template-save {
    width: 100%;
    border-top-left-radius: 0px;
    border-top-right-radius: 0px;
}
.btn-template-collapse {
    width: 100%;
    margin-top: 10px;
}
.btn-template-collapse[aria-expanded="true"] {
    border-bottom-left-radius: 0px;
    border-bottom-right-radius: 0px;
}
/* === END of buttons extra style === */


/* === START of other styles === */
.copy {
    font-size: 0.8em;
}

.div-links {
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.0em;
}

.text-bg-teamhr {
    background-color: #7B2020;
    /* background-color: #d0ae8d; */
    color: #fff;
}

.text-bg-other {
    background-color: rgba(51, 51, 51, 0.941);
    color: #fff;
}
.text-bg-pause {
    background-color: rgba(51, 51, 51, 0.941);
    color: #fff;
}


.table-hover tbody tr.text-bg-teamhr:hover td,
.table-hover tbody tr.text-bg-teamhr:hover th {
    /* background-color: #d0ae8d; */
    background-color: #9B4040;
    color: white;
}

.table-hover tbody tr.text-bg-other:hover td,
.table-hover tbody tr.text-bg-other:hover th {
    background-color: #333333;
    color: white;
}

.text-bg-white {
    background-color: white;
    color: #333333;
}

.text-teamhr-dark {
    color: #333333;
}

.text-teamhr {
    color: #7b2020;
}

.border-b-w-5 {
    border-bottom: 3px solid white;
}

.border-t-w-5 {
    border-top: 3px solid white;
}

.company-name {
    font-size: 1.5em;
}

.btn-teamhr {
    background-color: #7b2020;
    color: #fff;
    font-weight: bold;
}

.btn-teamhr:hover {
    background-color: #9b4040;
    color: #fff;
}

.btn-teamhr:active {
    background-color: #ab5050;
    color: #ffffff;
}

.link-teamhr {
    text-decoration: none;
    color: #7b2020;
    font-weight: bold;
}

.link-teamhr:hover,
.link-teamhr:focus,
.link-teamhr:active {
    color: #9b3030;
}

.nav-tabs {
    border-bottom: 0px;
}

.nav-link {
    font-weight: bold;
    color: #fff;
    text-align: center;
}

.nav-link:hover,
.nav-link:focus {
    background-color: #f0f0f0;
    color: black;
}

.dropdown-item {
    font-weight: bold;
}

.dropdown-item:hover {
    background-color: rgba(123, 32, 32, 0.376) !important;
}

.dropdown-item:active,
.dropdown-item:focus {
    background-color: #9b3030 !important;
    color: #ffffff;
}

.card-title {
    font-weight: bold;
    color: #7b2020;
    margin-bottom: 1rem;
    font-size: 1.4rem;
}

.shaky-btn {
    cursor: pointer
}

.cols-8>.col {
    width: 12.5%;
}

.col-year {
    font-size: 24px;
}

.container-header {
    background-color: #fff;
}

.row-header {
    padding: 10px;
}

.container-menu {
    background-color: #7B2020;
    color: #fff;
    padding-top: 10px;
    padding-bottom: 10px;
}

.container-menu-navtabs {
    padding-bottom: 0px;
}

.container-content {
    background-color: white;
    color: #333333;
    /* padding-top: 3rem !important; */
}

.container-calendar {
    min-width: 360px;
    background-color: #fff;
    color: #333333;
    border-radius: 3px;
}

.container-calendar-day {
    overflow-y: auto;
}

.row-calendar-slot {
    border: 1px outset #808080;
}

.row-calendar-slot-free {
    background-color: rgba(var(--bs-light-rgb), 0.50);
    font-weight: bold;
}

.row-calendar-slot-occupied {
    background-color: rgba(var(--bs-dark-rgb), 0.60);
}

.row-calendar-slot-occupied-self {
    background-color: rgba(var(--bs-danger-rgb), 0.50);
    font-weight: bold;
}


.row-months {
    font-weight: bold;
    border-bottom: 1px solid #7b2020;
    font-size: 0.85em;
    color: #7b2020;
    padding-left: 5px;
    padding-right: 5px;
}

.btn-month {
    font-size: 0.85em;
    cursor: pointer;
    padding-left: 0px;
    padding-right: 0px;
    padding-top: 8px;
    padding-bottom: 8px;
    text-align: center;
    background-color: rgb(var(--bs-light-rgb)) !important;
    color: #333333;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
}

.btn-month:hover {
    background-color: rgba(123, 32, 32, 0.2) !important;
    color: #333333;
}

.btn-month.active {
    background-color: #7b2020 !important;
    color: #fff;
}

.row-day-title {
    font-weight: bold;
    color: rgba(51, 51, 51, 0.8);
}

.row-calendar {
    display: flex;
    align-items: center;
    justify-content: center;
}

.col-calendar {
    padding: 10px;
    padding-top: 20px;
    padding-bottom: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 1px;
}

.col-calendar-kw {
    text-align: center;
    color: #33333380;
    font-size: 0.85em;
    line-height: 24px;
}

.col-calendar-day {
    text-align: center;
    border: 1px solid #f0f0f0;
    border-radius: 8px;
    font-weight: bold;
    cursor: pointer;
    aspect-ratio: 1 / 1;
}

.col-calendar-day:hover {
    border: 2px solid #7b2020d8;
    padding: 9px;
    padding-top: 19px;
    padding-bottom: 19px;
}


.col-calendar-active {
    border: 2px solid #7b2020d8;
    padding: 9px;
    padding-top: 19px;
    padding-bottom: 19px;

    font-weight: bold;
    cursor: pointer;
}

.col-calendar-active:hover {
    border: 2px solid #7b2020d8;
    padding: 9px;
    padding-top: 19px;
    padding-bottom: 19px;
}

.col-calendar-day-none {
    border: 1px solid #00000000;
    border-radius: 10px;
    background-color: #00000000 !important;
}

.col-calendar-day-none:hover {
    border: 1px solid #00000000;
    border-radius: 10px;
    background-color: #00000000;
}

.col-calendar-disabled {
    border: 0px solid #00000000;
    margin: 2px;


    background-color: rgba(var(--bs-dark-rgb), 0.25);
    color: #eee;
    color: #444444;
}

.col-calendar-disabled:hover {
    font-weight: bold;
    cursor: not-allowed;
    border: 0px solid #00000000;
    padding: 10px;
    padding-top: 20px;
    padding-bottom: 20px;

}

.col-calendar-today {
    text-decoration: underline;
    border: 6px solid #7b2020d8;
    padding: 5px;
    padding-top: 14px;
    padding-bottom: 14px;

}

.col-calendar-today:hover {
    border: 2px solid #7b2020d8;
    padding: 9px;
    padding-top: 18px;
    padding-bottom: 18px;
}


.col-calendar-active.col-calendar-disabled {
    border: 2px solid #7b2020d8;
    padding: 9px;
    padding-top: 19px;
    padding-bottom: 19px;
    color: #fff;
}

.col-calendar-active.col-calendar-disabled.col-calendar-today {
    text-decoration: underline;
    border: 6px solid #7b2020d8;
    padding: 5px;
    padding-top: 14px;
    padding-bottom: 14px;
}

.tr-slot {
    cursor: pointer;
}

.tr-slot-occupied {
    cursor: not-allowed;
}

.tr-slot-occupied-self {
    cursor: pointer;
}

.tr-slot-in-history {
    background-color: rgba(var(--bs-dark-rgb), 0.20) !important;
    font-weight: normal !important;
}

.sw-calendar-navigation-button,
.sw-calendar-navigation-button:active,
.sw-calendar-navigation-button:disabled {
    border: 0px;
}

.editor,
.__editor {
    height: 512px;
}

#current-date {
    border-bottom-left-radius: 0px;
    border-bottom-right-radius: 0px;
    border-top-left-radius: 4px;
    border-top-right-radius: 4px;
    font-size: 1.5em;
    background-color: #7b2020;
    color: #fff;
}

#current-date:focus {
    -webkit-box-shadow: none;
    box-shadow: none;
}

#slot-loading-spinner {
    display: none;
}


.span-heatmap {
    font-weight: bold;
    text-align: center;
    font-size: 0.8em;
    height: 50px;
    width: 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: auto;
    border-radius: 6px;
    margin: 0.3rem;
    position: relative;
}

.container.text-center.mb-3.noselect::before {
    content: "Durchschnittliche Anzahl an Terminen pro Monat";
    display: block;
    margin-bottom: 1rem;
    font-weight: bold;
    font-size: 1.2rem;
}

.modal-header {
    padding: 12px 20px;
    /* background-color: #d0ae8d !important; */
}

.modal-footer {
    padding: 4px;
}

.uuid {
    font-size: 14px;
    color: #7b2020;
}

.card-qrcode {
    color: #7b2020;
}

.media-menu-icon {
    display: none;
}
.customer-slot-icon-td {
    text-align: center;
    font-size: 1.8em;
}

.modal-body>p {
    margin-bottom: 6px;
    margin-top: 6px;
}
/* === END of other styles === */


/* === START of media queries === */
/* small smartphones - silvanos css */
@media (max-width: 219px) {
    .nav-link {
        border-radius: 6px !important;
    }
    .container-menu-navtabs {
        padding-bottom: 10px;
    }
    #b-username {
        display: none;
    }
    .media-menu-text {
        display: none;
    }
    .media-menu-icon {
        display: inline-block;
    }
}

@media (min-width: 220px) and (max-width: 299px) {
    .nav-link {
        border-radius: 6px !important;
    }
    .container-menu-navtabs {
        padding-bottom: 10px;
    }
    #b-username {
        display: none;
    }
    .media-menu-text {
        display: none;
    }
    .media-menu-icon {
        display: inline-block;
    }
}

/* for all smartphones */
@media only screen and (max-width: 40.062rem) {
    .container.text-center.mb-3.noselect::before {
        font-size: 1rem;
    }
    .nav-link {
        border-radius: 6px !important;
    }
    .container-menu-navtabs {
        padding-bottom: 10px;
    }
    #b-username {
        display: none;
    }
    .media-menu-text {
        display: inline-block;
    }
    .media-menu-icon {
        display: none;
    }
}

/* Tablet portrait format */
@media only screen and (min-width: 40.063rem) and (max-width: 50.062rem) {
    .span-heatmap {
        height: 45px;
        width: 45px;
    }
}

/* Smartphones in landscape format */
@media only screen and (min-width: 40.1rem) and (max-width: 51.483rem) and (orientation: landscape) {}

/* Tablets landscape format */
@media only screen and (min-width: 50.063rem) and (max-width: 64.062rem) and (orientation: landscape) {}

/* Everything up to max. normal PC monitor */
@media only screen and (max-width: 64.062rem) {}

/* From standard screen */
@media only screen and (min-width: 64.063rem) {}

/* From larger screen */
@media only screen and (min-width: 90.063rem) {}

/* === END of media queries === */


.faq-question {
    font-size: 1.25em;
    font-weight: bold;
    color: #7B2020;
    text-decoration: none;
}
.faq-question:hover {
    color: #d0ae8d;
}

.legend-element {
    display: inline-block;
    font-weight: bold;
}

.link {
  text-decoration: none;
  font-weight: bold;
  color: #7B2020;
  font-size: 1.25em;
}
.only-print {
  display: none;
}

@media print
{
    .no-print, .no-print *
    {
        display: none !important;
    }
    .only-print {
      display: block !important;
    }
}



table.dataTable {
  cursor: pointer;
}

table.dataTable tbody tr.coupon-tr-redeemed > * {
    box-shadow: inset 0 0 0 9999px #00000040 !important;
    background-color: black;
    color: #c0c0c0;
}
table.dataTable tbody tr.coupon-tr-expired > * {
    box-shadow: inset 0 0 0 9999px #00000040 !important;
    background-color: #ff0000;
    color: yellow;
}
table.dataTable tbody tr.coupon-tr-valid > * {
    box-shadow: inset 0 0 0 9999px #00000040 !important;
    background-color: #00ff0080;
}


.text-bg-light-warning {
  background-color: #ff800060;
  color: black;
}


.circle-border {
  /*margin-top: 10px;*/
  text-align: center!important;
  display: inline-block;
  line-height: 54px;
  font-size:1.5em;
  height: 64px;
  width: 64px;
  border-radius: 50%;
  border: 6px solid #7B2020;
}

.container-content img {
  max-width: 128px;
}

.container-content table {
  width: 100%!important;
}

.row-company-text > .col > table {
  margin-top: 10px;
  margin-bottom: 10px;
}

.row-company-text > .col > table > tbody > tr > td {
  border-bottom: 1px solid #f0f0f0!important;
}
