/* ############################################################################################# 
## GERICKE-CMS-TEMPLATE ##################################################################################
############################################################################################# */

@font-face {
    font-family: 'roboto';
    src: url('../fonts/Roboto-Regular-webfont.eot');
    src: url('../fonts/Roboto-Regular-webfont.eot?#iefix') format('embedded-opentype'), url('../fonts/Roboto-Regular-webfont.woff') format('woff'), url('../fonts/Roboto-Regular-webfont.ttf') format('truetype'), url('../fonts/Roboto-Regular-webfont.svg#robotoregular') format('svg');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'robotolight';
    src: url('../fonts/Roboto-Light-webfont.eot');
    src: url('../fonts/Roboto-Light-webfont.eot?#iefix') format('embedded-opentype'), url('../fonts/Roboto-Light-webfont.woff') format('woff'), url('../fonts/Roboto-Light-webfont.ttf') format('truetype'), url('../fonts/Roboto-Light-webfont.svg#robotolight') format('svg');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'robotomedium';
    src: url('../fonts/Roboto-Medium-webfont.eot');
    src: url('../fonts/Roboto-Medium-webfont.eot?#iefix') format('embedded-opentype'), url('../fonts/Roboto-Medium-webfont.woff') format('woff'), url('../fonts/Roboto-Medium-webfont.ttf') format('truetype'), url('../fonts/Roboto-Medium-webfont.svg#robotomedium') format('svg');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Cairo';
    font-style: normal;
    font-weight: 400;
    src: url('../fonts/cairo-v1-latin-regular.eot');
    /* IE9 Compat Modes */
    src: local('Cairo'), local('Cairo-Regular'), url('../fonts/cairo-v1-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('../fonts//cairo-v1-latin-regular.woff') format('woff'), /* Modern Browsers */
    url('../fonts/cairo-v1-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
    url('../fonts/cairo-v1-latin-regular.svg#Cairo') format('svg');
    /* Legacy iOS */
}

@font-face {
    font-family: 'Cairo';
    font-style: normal;
    font-weight: 600;
    src: url('../fonts/cairo-v1-latin-600.eot');
    /* IE9 Compat Modes */
    src: local('Cairo SemiBold'), local('Cairo-SemiBold'), url('../fonts/cairo-v1-latin-600.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('../fonts/cairo-v1-latin-600.woff') format('woff'), /* Modern Browsers */
    url('../fonts/cairo-v1-latin-600.ttf') format('truetype'), /* Safari, Android, iOS */
    url('../fonts/cairo-v1-latin-600.svg#Cairo') format('svg');
    /* Legacy iOS */
}

@font-face {
    font-family: 'Cairo';
    font-style: normal;
    font-weight: 700;
    src: url('../fonts/cairo-v1-latin-700.eot');
    /* IE9 Compat Modes */
    src: local('Cairo Bold'), local('Cairo-Bold'), url('../fonts/cairo-v1-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('../fonts/cairo-v1-latin-700.woff') format('woff'), /* Modern Browsers */
    url('../fonts/cairo-v1-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */
    url('../fonts/cairo-v1-latin-700.svg#Cairo') format('svg');
    /* Legacy iOS */
}

html {
    background: #2d3038;
    height: 100%;
}

body {
    font-family: 'roboto', arial, verdana, sans-serif;
    margin: 0;
    padding: 0;
}

body * {
    margin: 0;
    padding: 0;
    font-size: 16px;
    line-height: 150%;
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    -ms-hyphens: auto;
    -o-hyphens: auto;
    hyphens: auto;
    color: #e4e4e4;
    box-sizing: border-box;
    scroll-behavior: smooth;
}


/* #### HEADLINES ############################### */

h1 {
    font-size: 45px;
    margin: 50px auto 10px;
    font-family: 'Cairo', arial, verdana, sans-serif;
    line-height: 110%;
    font-weight: 700;
    max-width: 1300px;
    width: 94%;
    margin: 0 0 20px;
    text-align: center;
    text-transform: uppercase;
    color: #fff;
    text-align: left;
}

h2 a,
h2 {
    font-size: 25px;
    line-height: 100%;
    margin: 0 0 20px;
    font-family: 'Cairo', arial, verdana, sans-serif;
    color: #fff;
    font-weight: 600;
    text-align: center;
    text-transform: none;
    text-align: left;
    padding: 0;
}

h3 {
    font-size: 25px;
    line-height: 120%;
    font-family: 'Cairo', arial, verdana, sans-serif;
    margin: 25px 0px 15px 0px;
    font-weight: 400;
}

h4 {
    font-size: 18px;
    line-height: 120%;
    margin: 20px 0px 4px 0px;
    font-weight: 600;
}


/* text- and list-margins */

a h2,
a .fa {
    -webkit-transition: .3s;
    transition: .3s;
}

a,
.link {
    color: #ff3c48 ;
    text-decoration: none;
    -webkit-transition: .3s;
    transition: .3s;
}

a:focus,
a:hover,
a:not(.button):hover .fa,
a:not(.button):focus .fa,
a:not(.button):hover h2,
.link:focus,
.link:hover {
    color: #b02d2d;
    text-decoration: none;
}

a.button {
    -webkit-appearance: none;
}

a.add-address {
    cursor: pointer;
}

.asc, .desc {
    position: relative;
}

.asc:after {
    content: '\f103';
    font-family: 'FontAwesome';
    position: absolute;
    right: -15px;
    top: 0;
    bottom: 0;
}
.desc:after {
    content: '\f102';
    font-family: 'FontAwesome';
    position: absolute;
    right: -15px;
    top: 0;
    bottom: 0;
}

ul,
ol {
    margin: 20px 0;
}

li {
    margin: 0 0 0 15px;
    border-bottom: 1px solid rgba(34, 37, 47, 0.1);
    padding: 5px 0;
}

li:last-child {
    border: none!important;
}

p,
table,
form {
    margin: 0 0 10px 0;
    width: 100%;
}

small,
small * {
    font-size: 11px;
    display: inline-block;
}

figure img {
    width: 100%;
}

hr {
    margin: 20px 0 0;
    width: 100%;
    height: 1px;
    border-width: 3px 0 0 0;
    border-style: solid;
    border-color: rgba(0, 0, 0, 0.1);
}

figure img {
    width: 100%;
}

#footer img {
    width: 100%;
}

.required:after {
    content: " *";
    color: #ff3c48 ;
}

.panel {
    background: rgba(68, 70, 79, 0.5);
    padding: 20px;
}

.section {
    margin-bottom: 70px;
}

.wrapper {}

#holiday {
    display: none;
}

#holiday .buttons {
    display: flex;
    justify-content: space-between;
}

#holiday .buttons .save {
    display: flex;
}

#holiday .buttons .save span {
    display: flex;
    opacity: 0;
    margin-right: 10px;
    align-self: center;
    color: #080;
    transition: opacity .3s;
}

#holiday .holidays {
    display: flex;
}

#holiday .holidays .holidays_form {
    width: 20%;
    padding-right: 10px;
}

#holiday .holidays .holidays_form .form_row label {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#holiday .holidays .holidays_form .form_row label .delete {
    display: flex;
    width: 18px;
    height: 18px;
    background: #b02d2d;
    justify-content: center;
    margin-bottom: 1px;
    align-items: center;
    cursor: pointer;
}

#holiday #add_new {
    display: none;
}


/* #### GRID ############################### */

.row {
    display: flex;
    width: 100%;
    max-width: 1300px;
}

.row::after {
    content: "";
    clear: both;
    display: block;
}

[class*="col-"] {
    float: left;
}

.col-2 {
    width: 14.66%;
    margin: 0 1%;
}

.col-2_5 {
    width: 20%;
    margin: 0;
}

.col-3 {
    width: 23%;
    margin: 0 1%;
}

.col-4 {
    width: 31.33%;
    margin: 0 1%;
}

.col-5 {
    width: 39.66%;
    margin: 0 1%;
}

.col-6 {
    width: 48%;
    margin: 0 1%;
}

.col-7 {
    width: 56.33%;
    margin: 0 1%;
}

.col-8 {
    width: 64.66%;
    margin: 0 1%;
}

.col-9 {
    width: 73%;
    margin: 0 1%;
}

.col-10 {
    width: 81.33%;
    margin: 0 1%;
}

.col-12 {
    width: 98%;
}

.col-first {
    margin-left: 0;
}

.col-last {
    margin-right: 0;
}


/* ############################################################################################# 
## NAVIGATION ##################################################################################
############################################################################################# */

#header {
    background: none;
    margin: 20px auto;
    width: 100%;
    padding: 0 2%;
}

#header .row {
    padding: 10px 0;
    margin: 0 auto;
}

#logo {
    margin: 5px 0 0 0;
}

#logo img {
    width: 100%;
}

.sticky {
    position: fixed;
    background: #282b33!important;
    max-width: none!important;
    margin: 0!important;
    padding: 10px 2%!important;
    left: 0;
    top: 0;
    z-index: 101;
}

.sticky .row {
    padding: 0!important;
    border: none!important;
}

.sticky #logo {
    margin: 0;
}

.sticky #logo img {
    height: 50px;
    width: auto;
    margin-top: 5px;
}

.sticky #navigation ul {
    margin: 15px 0 0 0!important;
}

.sticky #navigation ul ul {
    margin: 25px 0 0 0!important;
}


/* #### FOOTER ############################### */

#footer {
    margin: 0 auto;
    width: 94%;
    padding: 20px 3%;
    background: rgb(25, 26, 33);
    font-size: 14px;
}

#footer div,
#footer p,
#footer span {
    font-size: 12px!important;
}

#footer a {
    font-size: 12px;
}

#footer span {
    display: block;
    margin-right: 10px;
    width: 100px;
    float: left;
}

#footer h4 {
    font-family: "robotomedium", arial, verdana, sans-serif;
    font-size: 16px;
    margin-bottom: 10px;
    text-transform: uppercase;
    font-weight: normal;
}

#footer li {
    list-style-type: none;
    margin-left: 0;
    border: none;
    padding: 0;
    margin-bottom: 1px;
}

#footer li ul {
    display: none;
}

#footer li a {
    font-size: 12px;
    display: block;
    padding: 5px;
    background: #0c0d10;
}

#footer li a:before {
    content: '\f054';
    font-family: 'FontAwesome';
    display: block;
    float: left;
    margin-right: 5px;
    font-size: 10px;
}

#footer li a:hover {
    background: rgba(0, 0, 0, 0.2);
}

#footer hr {
    height: 1px;
    border-width: 1px 0 0 0;
    border-style: solid;
    border-color: rgba(255, 255, 255, 0.5);
    margin: 5px 0;
}

#footer img {
    margin-top: 10px;
}

#copyright {
    position: fixed;
    background: #0c0d10;
    text-align: center;
    width: 100%;
    padding: 13px 0;
    box-sizing: border-box;
    bottom: 0;
}

#copyright .row {
    padding: 0;
    width: 100%;
}

#copyright p {
    font-size: 12px!important;
    line-height: 30px;
    margin: 0;
}


/* ## INPUTS ##*/

input,
textarea,
select {
    padding: 10px;
    width: auto;
    font-family: 'robotolight'!important;
    border: none;
    background: #494b54;
    width: 100%;
}

select optgroup {
    background: #494b54;
}

.form_row input[disabled],
.form_row textarea[disabled],
.form_row select[disabled] {
    background-color: #2c2e34;
    opacity: 1;
    cursor: not-allowed;
}

input.checkbox {
    float: left;
    height: auto;
    margin: 5px 2% 0 0;
    padding: 0px;
}

textarea {
    min-height: 150px;
}

.button {
    color: #fff!important;
    background: #ff3c48 ;
    /* font-size:20px; */
    width: auto;
    border: none;
    padding: 12px 15px 12px 15px;
    -webkit-appearance: none;
    display: inline-block;
    text-transform: uppercase;
    font-family: 'Cairo', arial, verdana, sans-serif;
    font-weight: 700;
    -webkit-transition: .3s;
    transition: .3s;
    line-height: 130%;
    /* margin:20px 0 0; */
}

.button:before {
    content: '\f054';
    font-family: 'FontAwesome';
    float: left;
    font-size: 12px;
    margin: 0 10px 0 0;
}

.button:hover {
    color: #fff;
    cursor: pointer;
    background: #b02d2d;
    background: #b02d2d;
}

.button.button-new {
    background: #00803c!important;
}

.button.button-red {
    background: #ff3c48 !important;
}

.button.button-new:before {
    content: '\f055';
}

.icon-button {
    width: 44px;
    height: 44px;
    vertical-align: middle;
    text-align: center;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}


/* table-styles */

table {
    border-collapse: collapse;
}

table tr {}

table tr th {
    color: #fff;
    text-align: left;
    max-width: 50%;
}

table tr th,
table tr th * {
    background: rgba(34, 37, 47, 0.8);
	hyphens: none;
}

table tr th,
table tr td {
    border-top: 1px solid #3d404c;
    padding: 6px 20px 6px 10px;
    vertical-align: top;
}

table tr td.dimensions input {
    width: 25%;
}

table tr:nth-child(even) {
    background-color: rgba(68, 70, 79, 0.5);
}

table tr td.tool-box {
    white-space: nowrap;
    text-align: right;
}

table tr td.tool-box div {
    margin-bottom: 2px;
}

table tr td.tool-box .button {
    background: #494b54;
}

table tr td.tool-box .button:before {
    display: none;
}

table tr td.tool-box .icon-button {
    width: 30px;
    height: 30px;
}

#items_table {
    width: 100%;
    overflow: auto;
    overflow-y: hidden;
}


/* form-styles */

.form_row {
    margin-bottom: 40px;
    width: 100%;
}

.form_row .form_row {
    margin-bottom: 15px;
}

.form_row.inline {
    display: flex;
    margin-bottom: 5px;
}

.form_row.inline label {
    width: 30%;
}

.form_row input,
.form_row textarea,
.form_row select {
    padding: 10px;
    font-family: 'robotolight'!important;
    border: none;
    background: #494b54;
}

.form_row input.checkbox {
    float: left;
    height: auto;
    margin: 5px 2% 0 0;
    width: auto;
    padding: 0px;
}

.form_row input.checkbox+label {
    display: inline-block;
}

.form_row label {
    display: block;
}

.form_row .button {
    margin-right: 10px;
}

.form_row_header {
    height: 25px;
    color: #fff;
    margin-top: 30px;
}

.form_row_header:first-child {
    margin-top: 0!important;
}

.form_row_header h2 {
    font-size: 20px;
    margin-top: 0!important;
}

.radio-button,
.radio-switch-group {
    margin-bottom: 10px;
}

.radio-button input,
.radio-switch-group input {
    display: none;
}

.radio-switch-group label:after,
.radio-button label:after {
    content: ""
}

.radio-switch-group.multi-rows label {
    display: block;
    margin-bottom: 3px;
    width: 200px;
}

.radio-switch-group input[type="radio"]:checked+label,
.radio-button input[type="radio"]:checked+label {
    font-weight: bold;
    background: #ff3c48 ;
    color: white;
}

.radio-switch-group label,
.radio-button label {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background: #494b54;
    cursor: pointer;
    text-align: center;
    display: inline-block;
    margin-right: 3px;
}

.radio-button label {
    padding: 10px 20px;
    margin-right: 10px;
    min-width: 140px;
}

.radio-switch-group label {
    padding: 5px 10px;
    min-width: 60px;
}


/* common classes */

.clear {
    clear: both;
}

.message {
    margin-bottom: 20px;
    padding: 5px 10px 5px 40px;
    display: flex;
    color: #fff;
    list-style: none;
    display: block;
    position: relative;
}

.message:before {
    font-family: 'FontAwesome';
    position: absolute;
    left: 15px;
    top: 5px;
}

.message li {
    margin: 0;
    padding-top: 0;
}

.message ul,
.error ul,
.warning ul,
.info ul,
.success ul {
    margin-bottom: 0px;
    margin-left: 15px;
}

.message a {
    color: #fff;
    text-decoration: underline;
}

.message.error {
    border: 2px solid #ff3c48 ;
}

.message.error:before {
    content: '\f06a';
}

.message.warning {
    border: 2px solid #b70;
}

.message.warning:before {
    content: '\f071';
}

.message.success {
    border: 2px solid #080;
}

.message.success:before {
    content: '\f058';
}

.message.info {
    border: 2px solid #005288;
}

.message.info:before {
    content: '\f05a';
}


/* ############################################################################################# 
## BUCHUNGSTOOL ##################################################################################
############################################################################################# */

.main {
    width: 94%;
    max-width: 1300px;
    margin: 0 auto 0 auto;
    padding-top: 120px;
    padding-bottom: 50px;
}

.main.frame {
    margin: 30px auto 30px;
}


/* ## ACCOUNT ## */

.account {
    height: 80px;
    background: #ff3c48 ;
    display: inline-block;
    position: absolute;
    right: 0;
    top: 0;
    margin: 0;
    width: 350px;
    color: #fff;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.account .avatar {}

.account .avatar img {
    width: 60px;
    height: 60px;
    margin-right: 10px;
    margin-left: 10px;
}

.account .customer {
    margin-right: 10px;
}

.account .customer a {
    color: #fff!important;
}

.account .customer .email a {
    font-size: smaller;
}

.account .buchungmenu,
.account .logout {
    width: 60px;
    height: 100%;
}

.account .buchungmenu span,
.account .logout a {
    display: flex;
    height: 100%;
    width: 100%;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.account .buchungmenu .account-menu {
    display: none;
    position: absolute;
    top: 80px;
    left: 0;
    width: 100%;
}

.account .buchungmenu .account-menu {
    display: none;
}

.account .account-menu,
.account:hover .account-menu {
    display: block;
    top: 60px;
    right: 0;
    position: absolute;
    width: 350px;
    background: #191A21;
    padding: 20px;
    box-sizing: border-box;
}

.account .buchungmenu .account-menu li {
    list-style-type: none;
}

.account .buchungmenu .account-menu li a {
    color: #fff;
}

.account .buchungmenu .account-menu li a:hover {
    color: #b02d2d;
}


/* ## APPS ## */

.apps .row {
    display: -webkit-flex!important;
    display: -ms-flex!important;
    display: flex!important;
    -webkit-flex-wrap: wrap!important;
    -ms-flex-wrap: wrap!important;
    flex-wrap: wrap!important;
    padding: 10px 0;
    width: 100%;
    margin: 0;
}

.apps .row>a,
.apps .row>div {
    background-color: rgba(68, 70, 79, 0.5);
    padding: 20px;
    box-sizing: border-box;
    color: #fff;
    position: relative;
}

.apps .row>.red-box {
    background: #ff3c48 ;
    padding: 30px 20px 30px 20px;
}

.apps .row>.col-3 {
    padding: 20px 20px 80px 20px;
}

.apps .row>div.red-box h2,
.apps .row>div.red-box h2 a,
.apps .row>div.red-box h2 a .fa {
    color: #fff;
}
/* 
.apps .row>div:hover a h2
{
    color: #b02d2d;
} */

.apps .button {
    position: absolute;
    bottom: 20px;
}

.bubble {
    white-space: nowrap;
    border-radius: 5%;
    color: #fff;
    text-align: center;
    padding: 2px;
}

.bubble-green {
    background: #008E4B;
}

.bubble-yellow {
    background: #f79700;
}

.bubble-red {
    background: #ff3c48 ;
}

#copyright {
    margin-top: 50px;
}

#copyright a {
    display: inline-block;
    font-size: 12px!important;
}

.modal {
    display: none;
    margin: 0 auto;
    top: 0;
    left: 0;
    position: fixed;
    height: 100%;
    width: 100%;
    background: rgba(255, 255, 255, .2);
    flex-direction: column;
    z-index: 1000;
}

.modal .modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 70%;
    height: 50px;
    background: #222;
    margin: 90px auto 0 auto;
    padding: 10px 20px;
}

.modal .modal-header-small {
    width: 40% !important;
}

.modal .modal-header span {
    font-family: "roboto";
    color: #fff;
    font-size: 20px;
    padding: 10px 10px;
}

.modal .modal-header .close {
    cursor: pointer;
}

.modal .modal-body,
.modal iframe {
    width: 70%;
    height: 600px;
    background: #2d3038;
    margin: 0 auto;
}

.modal .modal-body {
    padding: 20px;
    overflow-y: scroll
}

.modal .modal-body-small {
    width: 40% !important;
    height: 400px !important;
}

.modal-open {
    overflow: hidden;
}


/* ## DATEPICKER ## */

.datepicker {
    position: relative;
    padding: 10px 0;
    margin-bottom: 10px;
}

.datepicker .day {
    width: 52px;
    height: 52px;
    display: inline-block;
    background: #4f4f4f;
    color: white;
    position: relative;
    margin-bottom: 2px;
    margin-right: 4px;
    cursor: pointer;
    padding: 3px;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.datepicker .day.active {
    background: #ff3c48 ;
    cursor: inherit;
}

.datepicker .day.disabled {
    background: #2c2e34;
    cursor: not-allowed;
}

.datepicker .day.disabled.active {
    background: #C73B4F;
    color: white;
}

.datepicker .day .month,
.datepicker .day .number,
.datepicker .day .name {
    position: absolute;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    font-size: 9px;
}

.datepicker .day .number {
    top: 13px;
    font-size: 15px;
    font-weight: bold;
}

.datepicker .day .name {
    bottom: 0;
}

.time-wrap {
    display: flex;
    align-items: center;
}

.time-wrap .time {
    margin-left: 10px;
    margin-right: 20px;
}
.time-wrap .time select {
    width: 65px;
}
.time-wrap .time .seperator {
    display: inline-block;
    font-weight: bold;
    margin-left: 4px;
    margin-right: 4px;
}

.time input[type="text"] {
    width: 40px;
}


.datetime input[type="text"] {
    width: 180px;
}


/* ## FILTER ## */

.filter {
    display: flex;
    justify-content: space-between;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    height: 44px;
    margin-bottom: 20px;
}

.filter input {
    margin-bottom: 0;
    height: 100%;
}

.filter .left-area,
.filter .right-area {
    display: flex;
    justify-content: space-around;
}

.filter .filter-group {
    display: inline-flex;
    margin-left: 10px;
}

.filter .filter-group div {
    display: inline-block;
    cursor: pointer;
}

.filter .filter-group div label {
    display: inline-block;
    border-right: none;
    padding: 0 10px;
    cursor: pointer;
    height: 44px;
    width: inherit!important;
    line-height: 44px;
    margin-right: 1px;
    background: #494b54;
}

.filter .filter-group input:checked+label {
    background: #ff3c48 ;
    color: white;
}

.filter .filter-group input[type="radio"],
.filter .filter-group input[type="checkbox"] {
    display: none;
}

.filter-group .button:before {
    display: none;
}

.pagination {
    display: flex;
    justify-content: space-between;
}

.pagination .button {
    padding: 5px;
    width: 30px;
    height: 30px;
    text-align: center;
}

.pagination .button:before {
    content: ""
}

.pagination .button i {
    display: block;
    margin: 0;
    width: 100%;
    height: 100%;
    font-size: 18px;
    line-height: 120%;
}

.pagination .button a {
    display: block;
    width: 100%;
    height: 100%;
    text-align: center;
    color: #fff;
}

.pagination .button a:focus,
.pagination .button a:focus .fa,
.pagination .button a:hover,
.pagination .button a:hover .fa {
    color: #fff
}

.pagination .button.disabled {
    background: #494b54;
    cursor: auto;
}


/* ## BOOKING ## */

#booking {
    position: relative;
}

#booking #content {
    position: relative;
    opacity: 0;
    transition: opacity 300ms ease;
    margin-bottom: 140px;
}

#booking #loading {
    margin-top: 50px;
    text-align: center;
}

#booking #part-one,
#booking #part-two,
#booking #part-three,
#booking #part-four {
    width: 100%;
}

.booking-nav .back {
    float: left;
}

.booking-nav .next {
    float: right;
}

.change table tr:nth-child(even) .form_row {
    border-bottom: 1px solid #2d3038;
}
.change table tr:nth-child(odd) .form_row {
    border-bottom: 1px solid rgba(68, 70, 79, 0.5);
}

.change .form_row.inline label {
    width: 40%;
    min-width: 40%;
}


/* ## ANIMATIONS ## */

.fade-enter,
.fade-leave-to {
    opacity: 0
}

.fade-leave,
.fade-enter-to {
    opacity: 1
}

.fade-enter-active {
    transition: opacity 300ms ease-out
}

.fade-leave-active {
    transition: opacity 300ms ease-in
}

.slide-open-enter,
.slide-open-leave-to {
    max-height: 0;
}

.slide-open-leave,
.slide-open-enter-to {
    max-height: 400px;
    margin: inherit;
}

.slide-open-enter-active,
.slide-open-leave-active {
    transition: max-height 500ms ease-in;
    overflow: hidden;
}


/* ############################################################################################# 
## RWD ##################################################################################
############################################################################################# */

@media only screen and (max-width: 1050px) {
    h2 {
        font-size: 38px;
    }
    #logo {
        width: 23%;
        min-width: 170px;
    }
    .hide-mobile {
        display: none !important;
    }
}

@media only screen and (max-width: 925px) {}

@media only screen and (max-width: 767px) {
    body * {
        font-size: 14px;
    }
    h1 {
        font-size: 28px;
    }
    h2,
    .leistungen h2 {
        font-size: 22px;
    }
    h3 {
        font-size: 20px;
    }
    .row {
        flex-wrap: wrap;
    }
    [class*="col-"] {
        float: none;
        padding: 10px;
        width: 100%;
        box-sizing: border-box;
    }
    #header {
        background: #5b5b5b;
        height: 80px !important;
        left: auto!important;
        margin: 0 !important;
        max-width: 767px !important;
        padding: 5px 2% !important;
        -webkit-box-shadow: 0px 3px 17px -7px rgba(0, 0, 0, 0.75);
        -moz-box-shadow: 0px 3px 17px -7px rgba(0, 0, 0, 0.75);
        z-index: 100;
        position: fixed;
        width: inherit!important;
        box-sizing: border-box;
    }
    #header .row {
        border: medium none !important;
        padding: 0 !important;
    }
    #logo {
        margin: 0;
        padding: 5px 0 0 0;
    }
    .sticky #logo img {
        width: 100%;
        height: auto;
    }
    #header .col-10 {
        width: auto;
        padding: 0;
    }
    #copyright .col-12 {
        box-sizing: border-box;
    }
    .form_row.inline label {
        width: 100%;
    }
    #header {
        width: 100%!important;
    }
    .row>div {
        margin: 0 0 20px 0;
    }
    .account,
    .account .account-menu,
    .account:hover .account-menu {
        width: 100%;
    }
    .modal .modal-header {
        width: 90%;
    }
    .modal .modal-body,
    .modal iframe {
        width: 90%;
    }
    .holidays {
        flex-wrap: wrap;
    }
    .holidays_form {
        margin: 0;
    }
}

@media only screen and (max-width: 480px) {}

@media only screen and (max-width: 320px) {
    body {
        font-size: 16px;
    }
    .row {
        padding: 30px 0;
        width: 100%;
    }
    h1 {
        font-size: 28px;
    }
    h2,
    .leistungen h2 {
        font-size: 22px;
    }
    h3 {
        font-size: 20px;
    }
    #header {
        max-width: 320px!important;
    }
    #logo {
        width: 50%;
        min-width: 0;
    }
    #footer {
        font-size: 12px;
    }
    #footer h4 {
        font-size: 14px;
    }
    #footer ul {
        margin: 20px 0!important;
    }
    #footer div,
    #footer p,
    #footer a,
    #footer span {
        font-size: 12px!important;
    }
    #footer span {
        margin-right: 6px;
        width: 80px;
    }
}