/*==============================================================================
============================== ALLGEMEIN =======================================
==============================================================================*/

html {
  height: 100%;
}

body {
  width: 100%;
  min-height: 100%;
  height: 100%;
  margin: 0px;
}

.flex-center-center {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.display-none {
  display: none !important;
}

.align-center-left {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

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

.align-center-right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.align-right {
  display: flex;
  justify-content: flex-end;
}

.color-red {
  color: red;
}

input {
  width : 100px;
}

/*---------------------------- MARGIN ----------------------------------------*/

.ml-3 {
  margin-left: 1rem!important;
}

.mr-5 {
  margin-right: 5px;
}

.mt-20 {
  margin-top: 20px;
}

.mt-30 {
  margin-top: 30px;
}

.mt-40 {
  margin-top: 40px;
}

.mb-10 {
  margin-bottom: 10px;
}

.mb-20 {
  margin-bottom: 20px;
}

.mb-40 {
  margin-bottom: 40px;
}

@media (min-width: 576px){
  .mt-sm-40 {
    margin-top: 40px;
  }
  .mt-sm-20 {
    margin-top: 20px;
  }
}

@media (min-width: 768px){
  .mt-md-0 {
    margin-top: 0px;
  }
}

@media (min-width: 992px){
  .mt-lg-0 {
    margin-top: 0px;
  }
}

/*==============================================================================
============================== HEADER ==========================================
==============================================================================*/

#header {
  position: relative;
  height: 60px;
  width: 100%;
  /*position: fixed;*/
  top: 0px;
  box-shadow: 0px 4px 14px #dbeaff;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
  background: #dbeaff;
  z-index: 100;
}

#header > .row {
  height: 100%;
  /*padding: 0px 20px;*/
}

.header-title-container {
  padding-top: 5px;
  text-align: right;
}

.header-title {
  margin-bottom: 3px;
}

.header-subtitle {
  margin-bottom: 0px;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

/*==============================================================================
============================== MENU ============================================
==============================================================================*/

#menu {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0px;
  background-color: #edf5ff;
  z-index: 10;
  left: -100%;
  padding-top: 90px;
}

.menu-inner {
  padding-left: 20px;
  padding-right: 20px;
}

.menu-inner > a {
  display: block;
  padding: 20px;
  text-decoration: none;
  color: #000000;
}

.menu-inner > a:hover {
  background-color: #a8adb3;
}

/*==============================================================================
============================== LOGIN ===========================================
==============================================================================*/

.login-header {
  margin-bottom: 30px;
}

.login-container {
  padding: 30px;
  background-color: #ffffff;
  box-shadow: 0px 1px 6px #0000001F;
  border-radius: 4px;
  width: 100%;
  max-width: 400px;
}

/*==============================================================================
============================== BTN =============================================
==============================================================================*/

.btn-fluid {
  width: 100%;
}

.btn-circle {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  width: 50px;
  padding: 0px;
  border-radius: 50%;
  font-size: 22px;
}

.btn-fs {
  display: block;
  width: 100%;
}

.btn-blue {
  background-color: #7e9cd0;
  color: #ffffff;
}

.btn-blue:hover {
  background-color: #57585a;
  color: #ffffff;
}

.btn-grey {
  background-color: #ffffff;
  color: #57585a;
  border-color: #57585a;
}

.btn-grey:hover {
  background-color: #57585a;
  color: #ffffff;
}

/*==============================================================================
============================== CONTENT =========================================
==============================================================================*/

.content-distance-top {
  height: 20px;
}

/*==============================================================================
============================== AUFTRAG =========================================
==============================================================================*/

.auftrag {
  display: block;
  color: #7e9cd0;
  border: 1px solid #7e9cd0;
  margin-bottom: 10px;
  border-radius: 3px;
  padding: 10px 20px;
  text-decoration: none;
}

.auftrag:hover {
  color: #ffffff;
  background-color: #7e9cd0;
}

.artikel-item {
  display: flex;
  border: 1px solid #7e9cd0;
  margin-bottom: 10px;
  border-radius: 3px;
  padding: 3px 3px;
}

.artikel-title {
  width: calc( 100% - 105px );
}

.artikel-title-inner {
  display: flex;
}

.artikel-title-inner .artikel-title-artnr {
  width: 150px;
}

.artikel-title-inner .artikel-title-menge {
  width: calc( 100% - 150px );
}

.artikel-title > h6 {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  margin-bottom: 0px;
  line-height: 1.4em;
  font-size: 1em;
}

.artikel-control {
  width: 50px;
  display: flex;
  flex-direction: column;
}

.artikel-inc,
.artikel-dec,
.artikel-del,
.artikel-edit,
.artikel-a_edit {
  width: 100%;
  height: 35px;
  border: 1px solid #7e9cd0;
  color: #7e9cd0;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 3px;
}

.artikel-edit,
.artikel-a_edit {
  height: 100%;
}

.artikel-indicator {
  width: 100%;
  height: 29px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.artikel-select-item {
  display: flex;
  border: 1px solid #7e9cd0;
  margin-bottom: 10px;
  border-radius: 3px;
  padding: 3px 3px;
}

.artikel-select-title {
  width: calc( 100% - 50px );
}

.artikel-select-control {
  width: 50px;
  display: flex;
  flex-direction: column;
}

.artikel-select-add {
  width: 100%;
  height: 50px;
  border: 1px solid #7e9cd0;
  color: #7e9cd0;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 3px;
}

.artikel-select-title > h5 {
  font-size: 1.15rem;
  margin-bottom: 0.3rem;
}

.artikel-select-title > h6 {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  margin-bottom: 0px;
}

/*==============================================================================
============================== ERROR POPUP =====================================
==============================================================================*/

.error-popup {
  border: 1px solid #7e9cd0;
  border-radius: 3px;
  background: #dbeaff;
  padding: 5px 10px;
}

.error-popup-error {
  border-color: #ed1b1b;
  background-color: #f1a5a5;
}

/*==============================================================================
============================== HAMBURGER =======================================
==============================================================================*/

.hamburger {
	padding: 15px 0px;
	display: inline-block;
	cursor: pointer;
	transition-property: opacity, filter;
	transition-duration: 0.15s;
	transition-timing-function: linear;
	font: inherit;
	color: inherit;
	text-transform: none;
	background-color: transparent;
	border: 0;
	margin: 0;
	overflow: visible;
}
.hamburger:hover {
	opacity: 0.7;
}
.hamburger.is-active:hover {
  opacity: 0.7;
}
.hamburger.is-active .hamburger-inner, .hamburger.is-active .hamburger-inner::before, .hamburger.is-active .hamburger-inner::after {
  background-color: #000;
}
.hamburger-box {
  width: 40px;
  height: 24px;
  display: inline-block;
  position: relative;
}
.hamburger-inner {
   display: block;
   top: 50%;
   margin-top: -2px;
}
.hamburger-inner, .hamburger-inner::before, .hamburger-inner::after {
  width: 40px;
  height: 4px;
  background-color: #000;
  border-radius: 4px;
  position: absolute;
  transition-property: transform;
  transition-duration: 0.15s;
  transition-timing-function: ease;
}
.hamburger-inner::before, .hamburger-inner::after {
  content: "";
  display: block;
}
.hamburger-inner::before {
  top: -10px;
}
.hamburger-inner::after {
  bottom: -10px;
}

.hamburger--squeeze .hamburger-inner {
  transition-duration: 0.075s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--squeeze .hamburger-inner::before {
  transition: top 0.075s 0.12s ease, opacity 0.075s ease;
}
.hamburger--squeeze .hamburger-inner::after {
  transition: bottom 0.075s 0.12s ease, transform 0.075s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--squeeze.is-active .hamburger-inner {
  transform: rotate(45deg);
  transition-delay: 0.12s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger--squeeze.is-active .hamburger-inner::before {
  top: 0;
  opacity: 0;
  transition: top 0.075s ease, opacity 0.075s 0.12s ease;
}
.hamburger--squeeze.is-active .hamburger-inner::after {
  bottom: 0;
  transform: rotate(-90deg);
  transition: bottom 0.075s ease, transform 0.075s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1);
}
