/* IMPORT */
@import url("https://use.fontawesome.com/releases/v5.1.0/css/all.css");


/* MAIN STYLE */
html, body {
  height: 100%;
}
body {
  margin: 0;
  font-size: 16px;
  color: #333;
  background: #fff;
  padding: 0;
}
body.kalender-setting {
  padding: 70px 0 45px 0;
}


/* TYPOGRAPHY */
h1, h2, h3, h4, h5, h6 {
  font-weight: lighter;
  line-height: 1.2;
}

p {
  line-height: 1.8;
  margin: 10px 0;
}

a {
  cursor: pointer;
  color: #666;
  outline: none;
}
a:hover,
a:focus {
  text-decoration: none;
  color: #0069b4;
}

small {
  display: block;
  font-size: 65%;
}

strong, b,.fw-bold {
  font-weight: bold;
}

.hr {
  border: none;
  width: 100%;
  height: 1px;
  background-color: #0069b4;
  margin: 30px 0;
}


/* BUTTON */
.btn {
  border-radius: 0;
  box-shadow: none;
  outline: none !important;
  box-shadow: none !important;
  font-weight: bold;
  text-transform: uppercase;
}
.btn-full {
  width: 100%;
}

.btn-primary {
  background-color: #0069b4;
  border-color: #0069b4;
  color: #fff;
}
.btn-primary:hover,
.btn-primary:focus {
  background-color: #005896;
  border-color: #0069b4;
  color: #fff;
}

.btn-secondary {
  background-color: #666666;
  border-color: #666666;
  color: #fff;
}
.btn-secondary:hover,
.btn-secondary:focus {
  background-color: #444444;
  border-color: #444444;
  color: #fff;
}


/* BACKGROUND */
.bg-grey {
  background: #eee !important;
}


/* MODAL */
.modal-content {
  border-radius: 0;
  box-shadow: none;
  border: none;
}

.modal-footer {
  display: block;
}

.close {
  font-size: 40px;
  transform: rotate(-45deg);
  font-weight: lighter;
  line-height: 1;
  outline: none !important;
}


/* INFOLINE */
.infoline {
  background: #eee;
  padding: 15px 62.5px;
}

.infoline.f-top {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  border-bottom: 1px solid #333;
  padding-left: 90px;
  padding-right: 90px;
  z-index: 1000;
  min-height: 71px;
  max-height: 71px;
}
.infoline.f-bottom {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  border-top: 1px solid #333;
  z-index: 1000;
}

.infoline .zurueck_kalender {
  font-size: 25px;
  padding: 15px 25px;
  position: absolute;
  left: 0;
  margin: 0;
  top: 0;
  background: #333;
  color: #fff !important;
  min-height: 70px;
  transition: all 0.1s;
}
.infoline .zurueck_kalender:hover {
  padding: 15px 30px 15px 20px;
  background: #111;
  color: #fff !important;
}

.infoline .weiter_kalender {
  font-size: 25px;
  padding: 15px 25px;
  position: absolute;
  right: 0;
  margin: 0;
  top: 0;
  background: #333;
  color: #fff !important;
  min-height: 70px;
  transition: all 0.1s;
}
.infoline .weiter_kalender:hover {
  padding: 15px 20px 15px 30px;
  background: #111;
  color: #fff !important;
}

.infoline.f-bottom .zurueck_kalender,
.infoline.f-bottom .weiter_kalender {
  min-height: 45px;
  max-height: 45px;
  padding: 2.5px 25px;
}
.infoline.f-bottom .zurueck_kalender:hover {
  padding: 2.5px 30px 2.5px 20px;
}
.infoline.f-bottom .weiter_kalender:hover {
  padding: 2.5px 20px 2.5px 30px;
}


/* NAVIGATION */
.nav-fill .nav-item {
  line-height: 1;
  background: #f5f5f5;
  border-radius: 0;
  font-weight: 700;
  color: #333;
}
.nav-fill .nav-item:nth-child(odd){
  background: #fff;
}

.nav-fill .nav-item.active {
  background: #000;
  color: #fff;
}

.nav-fill .nav-item small {
  font-size: 75%;
  font-weight: 500;
}


/* FORM */
.form-control {
  border-radius: 0px;
  box-shadow: none;
  border: none;
  border-bottom: 1px solid #ccc;
  padding-left: 0;
  transition: all 0.1s;
}
.form-control:focus {
  box-shadow: none;
  outline: none;
  border-color: #333;
  padding-left: 12px;
}

.form-control-plaintext {
  display: block;
  width: 100%;
  padding-top: 0;
  padding-bottom: 5px;
  margin-bottom: 0;
  line-height: 1.2;
  color: #212529;
  background-color: transparent;
  border: solid transparent;
  border-top-width: medium;
  border-right-width: medium;
  border-bottom-width: medium;
  border-left-width: medium;
  border-width: 1px 0;
}

.has-error label {
  color: #ff0000 !important;
}
.has-error .form-control,
.has-error .form-control:focus {
  border-bottom-color: #ff0000 !important;
  background: #ffdada;
}

/* breadcrumb */
.breadcrumb {
  background-color: #0069b4;
  color: #ffffff;
  border-radius: 0;
}
.breadcrumb-item,
.breadcrumb-item a,
.breadcrumb-item + .breadcrumb-item::before {
  color: #fff;
  opacity: 0.75;
}
.breadcrumb-item.active {
  color: #fff;
  opacity: 1;
}

/* card */
.card {
  border-radius: 0;
  background-color: #ffffff;
  transition: all .25s;
  border-color: #666;
  box-shadow: 0 7.5px 10px -5px rgba(0,0,0,0.25);
}
.anim {
  padding: 5px 0;
}
.card:hover .anim {
  animation: ani 1.5s infinite;
}


/* DROPDOWN */
.dropdown-menu {
  border-radius: 0;
  padding: 0;
  min-width: 200px;
}
.dropdown-item {
  padding: 10px 15px;
  color: #666;
}


@keyframes ani {
  0% {
    padding: 5px 0;
  }
  50% {
    padding: 10px 0 0 0;
  }
  100% {
    padding: 5px 0;
  }
}

@media (min-width: 1200px) {
  .modal-lg {
    max-width: 1100px;
  }
}



/*
    ##### THEMES #####
*/
/* +++++ BLUE THEME +++++ */
.blue-theme .infoline .zurueck_kalender,
.blue-theme .infoline .weiter_kalender,
.blue-theme .nav-fill .nav-item:hover,
.blue-theme .spezial-nav a:hover .spezial-nav-item,
.blue-theme .spezial-nav a.active .spezial-nav-item {
  background: #0069b4;
  color: #fff;
}

.blue-theme .infoline.f-top,
.blue-theme .infoline.f-bottom,
.blue-theme .form-control:focus,
.blue-theme .login {
  border-color: #0069b4;
}

.blue-theme table th,
.blue-theme .infoline i.colored-icon,
.blue-theme .full_hour_scroll .full_hour_scroll_btn,
.blue-theme .btn-termin-anlegen a {
  color: #0069b4;
}

.blue-theme .kalender .spalte tr td:hover {
  background: #c8deed;
}

.blue-theme .nav-fill .nav-item.active {
  background: #00497e;
}


/* +++++ RED THEME +++++ */
.red-theme .infoline .zurueck_kalender,
.red-theme .infoline .weiter_kalender,
.red-theme .nav-fill .nav-item:hover,
.red-theme .spezial-nav a:hover .spezial-nav-item,
.red-theme .spezial-nav a.active .spezial-nav-item  {
  background: #b40000;
  color: #fff;
}

.red-theme .infoline.f-top,
.red-theme .infoline.f-bottom,
.red-theme .form-control:focus,
.red-theme .login {
  border-color: #b40000;
}

.red-theme table th,
.red-theme .infoline i.colored-icon,
.red-theme .full_hour_scroll .full_hour_scroll_btn,
.red-theme .btn-termin-anlegen a {
  color: #b40000;
}

.red-theme .kalender .spalte tr td:hover {
  background: #edc8c8;
}

.red-theme .nav-fill .nav-item.active {
  background: #7e0000;
}


/* +++++ RED THEME +++++ */
.green-theme .infoline .zurueck_kalender,
.green-theme .infoline .weiter_kalender,
.green-theme .nav-fill .nav-item:hover,
.green-theme .spezial-nav a:hover .spezial-nav-item,
.green-theme .spezial-nav a.active .spezial-nav-item {
  background: #37b400;
  color: #fff;
}

.green-theme .infoline.f-top,
.green-theme .infoline.f-bottom,
.green-theme .form-control:focus,
.green-theme .login {
  border-color: #37b400;
}

.green-theme table th,
.green-theme .infoline i.colored-icon,
.green-theme .full_hour_scroll .full_hour_scroll_btn,
.green-theme .btn-termin-anlegen a {
  color: #37b400;
}

.green-theme .kalender .spalte tr td:hover {
  background: #cbedc8;
}

.green-theme .nav-fill .nav-item.active {
  background: #497e00;
}
