﻿/*----------------------Step 0 - Global ----------------*/
#form-step-0 h2 {
    text-align: center;
}
#form-step-0 .selection-container {
    display: flex;
    justify-content: space-between;
    margin: 45px 0 35px 0;
}
#form-step-0 .selection-container > a {
    height: auto;
    width: 45%;
    margin: 0;
    background-position-x: 15px;
    background-position-y: center;
    background-size: 32px 32px;
    transition: background-size .25s ease, background-position-y .25s ease, background-position-x .25s ease;
    padding-left: 75px;
    color: #000;
    text-decoration: none;
    background-size: 32px 32px;
}
#form-step-0 .selection-container > a:hover {
    color: #000;
    text-decoration: none;
    background-position-y: calc(50% - 2px);
    background-position-x: 13px;
    transition: background-size .25s ease, background-position-y .25s ease, background-position-x .25s ease;
    background-size: 36px 36px;
}
#form-step-0 .selection-container span.title {
    display: block;
    font-weight: bold;
    border-bottom: 1px solid #000;
    padding: 0 0 3px 0;
    margin: 0 0 5px 0;
}
#form-step-0 .selection-container span.description {
    font-size: .9em;
}


/*----------------------Step 1 - Global ----------------*/
#Heading1a, #Heading1b {
    text-transform: uppercase;
    font-size: 20px;
    text-align: center;
    border-bottom: 1px solid #E0E0E0;
    font-weight: normal;
    margin-bottom: 15px;
}
.reservation-step-1 h2 {
    font-weight: bold;
}
.reservation-step-1 .option-description {
    margin: 0;
    padding: 0;
}
.reservation-step-1 .option-description p {
    padding: 0;
    margin: 15px 0 25px 0;
    color: #000;
}
.reservation-step-1 .Deactive_Div h2,
.reservation-step-1 .Deactive_Div p {
    color: #AAA;
}

.field-validation-error {
    position: relative;
    font-size: 1em;
    padding: 0 5px;
    border-radius: 3px;
    display: block;
    margin: 3px 0 15px 0;
    max-width: none;
}

#Div_ButtonBox {
    display: flex;
    justify-content: space-between;
}

#Div_ButtonBox #Div_Back {
    text-align: left;
    float: none;
    width: auto;
    white-space: nowrap;
}

#Div_ButtonBox #Div_Next {
    text-align: right;
    float: none;
    width: auto;
}

#Div_ButtonBox #Div_Back input[type="submit"],
#Div_ButtonBox #Div_Back input[type="button"],
#Div_ButtonBox #Div_Back a.linkbutton,
#Div_ButtonBox #Div_Next input[type="submit"],
#Div_ButtonBox #Div_Next input[type="button"],
#Div_ButtonBox #Div_Next a.linkbutton {
    margin-top: 0;
    margin-bottom: 0;
}

#Div_ButtonBox #Div_Back a.linkbutton:hover,
#Div_ButtonBox #Div_Next a.linkbutton:hover {
    text-decoration: none;
    color: #fff;
}


/*----------------------Step 1 - Event Selection ----------------*/
#Div_Date {
    height: calc(100% - 38px);
}
.EventGroupSelector {
    margin-top: 15px;
    width: 100%;
    border-bottom: 1px solid #ddd;
}

.EventGroupSelector tr {
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
    cursor: pointer;
}

.EventGroupSelector td {
    background-color: #F9F9F9;
    border-top: 1px solid #ddd;
    width: auto;
}

.EventGroupSelector tr td:first-child {
    padding: 0 10px;
    border-right: 1px solid #ddd;
}

#.EventGroupSelector tr:first-child td:first-child {
    border-top-color: #ddd;
}

.EventGroupSelector tr td:nth-child(2) {
    padding-left: 10px;
    width: 100%;
}

.EventGroupSelector tr.Div_EventSelect_Radio.selected {
    -webkit-box-shadow: 0px 0px 10px -2px #000000;
    box-shadow: 0px 0px 10px -2px #000000;
    position: relative;
}

.EventGroupSelector tr.Div_EventSelect_Radio.selected td {
    background-color: #ddd;
    border-top-color: #ddd;
    font-weight: bold;
}

.EventGroupSelector tr.Div_EventSelect_Radio.selected td:first-child {
    border-right-color: #F9F9F9;
}

.reservation-step-1 .EventGroupSelector .hint-mobile {
    display: none;
}


/*----------------------Step 1 - Table Selection ----------------*/
#Div_Table, #Div_TableSelection {
    height: calc(100% - 38px);
}
#Div_Table_Select {
    display: flex;
    justify-content: stretch;
}

#Div_MiniaturePlan {
    width: auto;
    float: none;
}

#Div_Table_Dropdowns {
    width: auto;
    flex-grow: 2;
}

#Div_Table_Dropdowns .Div_Dropdown {
    position: relative;
}

#Div_Table_Dropdowns .Div_Dropdown > select {
    position: absolute;
    top: 0;
}

#Div_Table_Dropdowns .form-group > label {
    font-weight: bold;
}


/*----------------Step 1 - Premium Seating --------------*/
.reservation-step-1 .Deactive_Div #TableSelectBtn,
.reservation-step-1 .Deactive_Div #TableSelectError {
    display: none;
}


/*-------------Step 1 - Premium Seating Modal -----------*/
#Plan h1 {
    text-align: left;
    padding-bottom: 7px;
    margin-bottom: 15px;
}
#Div_Legend_Container td {
    padding-bottom: 15px;
}
#TablePlanHintText {
    display: none;
}
#Balloon, #Balloon_Vertical, #balloon_left_top, #balloon_left_bottom {
    box-sizing: content-box;
}


/*----------------------Step 1 - Timer ----------------*/
body.timer {
    padding-top: 100px;
}
#timer {
    display: none;
    position: fixed;
    border-radius: 0;
    width: 100%;
    border: none;
    padding: 10px 20px;
    top: 0;
    right: 0;
    left: 0;
    text-align: center;
    color: White;
    background-color: Red;
    height: auto;
    -webkit-box-shadow: 0px 5px 10px -5px #000000;
    box-shadow: 0px 5px 10px -5px #000000;
}

#timer > span {
    font-weight: bold;
}


/*-------------- Step 1 - Premium Seating Wahl -----------*/
#Div_TableSelectedHeader {
    padding: 0 0 5px 0;
    margin: 25px 0 15px 0;
    border-bottom: 1px solid #000;
}



/*----------------------Step 1 - Options ----------------*/
#Div_ProductSelection {
    width: auto;
}

#Div_ProductSelection table td {
    padding-bottom: 25px;
}

#Div_ProductSelection table td:nth-child(2) {
    padding-left: 15px;
    padding-right: 25px;
}


/*-------------------- Step 1 - Continue ----------------*/
.reservation-step-1 #Div_ButtonBox.Active_Div,
.reservation-step-1 #Div_ButtonBox.Deactive_Div {
    background-color: transparent;
    border: none;
}

.reservation-step-1 #Div_ButtonBox.Deactive_Div {
    display: none;
}


/*----------------------Step 2 - Global ----------------*/
#Heading2 {
    text-transform: uppercase;
    font-size: 20px;
    text-align: center;
    border-bottom: 1px solid #E0E0E0;
    font-weight: normal;
    margin-bottom: 15px;
}

#form-step-2 #Div_FormContainer {
    margin-top: 30px;
    padding-top: 20px !important;
    padding-bottom: 20px !important;
}
#form-step-2 .returning-customer {
    padding-top: 20px;
}
#form-step-2 .returning-customer input[type=button] {
    display: block;
    margin: 0 auto;
}
#form-step-2 .returning-customer .new-customer {
    text-align: center;
    display: block;
    width: auto;
    max-width: 300px;
    margin: 35px auto;
    font-weight: bold;
    border-top: 1px solid #000;
    padding-top: 20px;
}


/*----------------------Step 3 - Global ----------------*/
#Heading3, #Heading3b, #Heading3c, #Heading3d {
    text-transform: uppercase;
    font-size: 20px;
    text-align: center;
    border-bottom: 1px solid #E0E0E0;
    font-weight: normal;
    margin-bottom: 15px;
    padding-top: 0 !important;
}

#form-step-3 #Div_FormContainer {
    margin-top: 15px;
    margin-bottom: 30px;
    padding-top: 20px !important;
    padding-bottom: 0px !important;
}

#form-step-3 .form-control.select {
    font-size: 13px;
    color: #444;
    border-radius: 4px;
    padding: 7px;
    border: 1px solid #ccc;
}
#form-step-3 .form-control.checkbox {
    float: left;
    margin-right: 10px;
    position: relative;
    top: 2px;
}


/*----------------- Step 3 - Zahlungsmethoden -------------*/
#form-step-3 .payment-method-hints {
    font-style: italic;
    padding: 0 0 15px 0;
    font-size: .9em;
}


/*----------------- Step 3 - AGB und Alter -------------*/
#form-step-3 .agb-accept-hints {
    padding: 0 0 15px 0;
    font-weight: bold;
}
#form-step-3 #TermsConditionLink {
    display: inline-block;
    text-decoration: underline;
}
#form-step-3 .checkbox-field label {
    display: inline;
}


/*----------------------Step 4 - Global ----------------*/
#Heading4 {
    text-transform: uppercase;
    font-size: 20px;
    text-align: center;
    border-bottom: 1px solid #E0E0E0;
    font-weight: normal;
    margin-bottom: 15px;
}

#form-step-4 #Div_FormContainer {
    margin-top: 30px;
    padding-top: 20px !important;
    padding-bottom: 20px !important;
}

#form-step-4 h3 {
    background-color: #ededed;
    padding: 5px 10px;
    font-weight: bold;
    font-size: 14px;
}

#step-4-order-overview.row {
    margin-left: 0;
    margin-right: 0;
}

#step-4-order-overview .tabular {
    padding: 0 10px;
    display: table;
    width: 100%;
}

#step-4-order-overview .tabular > div {
    display: table-row;
}

#step-4-order-overview .tabular > div > div {
    padding-top: 5px;
    display: table-cell;
}

#step-4-order-overview .tabular > div > div:first-child {
    white-space: nowrap;
    padding-right: 25px;
}

#step-4-order-overview .tabular > div > div:last-child {
    width: 100%;
}

#step-4-order-overview .tabular .a-right {
    text-align: right;
}

#step-4-order-overview .tabular .bold {
    font-weight: bold;
}

#step-4-order-overview .uline-single {
    border-bottom: 1px solid #000;
}


/*----------------------Step 5 - Global ----------------*/
#Heading5 {
    text-transform: uppercase;
    font-size: 20px;
    text-align: center;
    border-bottom: 1px solid #E0E0E0;
    font-weight: normal;
    margin-bottom: 15px;
}

#form-step-5 #Div_FormContainer {
    margin-top: 30px;
    padding-top: 20px !important;
    padding-bottom: 20px !important;
}


/*------------- Registration Closed: Login  -------------*/
body.reg-closed.login #content,
body.reg-closed.login #footer {
    max-width: 600px;
}
body.reg-closed.login #footer {
    padding: 25px 0;
    width: 100%;
}
body.reg-closed.login #content .logo {
    margin: 0 auto;
    display: block;
    position: relative;
    top: -20px;
    max-height: 145px;
}
body.reg-closed.login #content h1 {
    text-transform: uppercase;
    font-size: 20px;
    text-align: center;
    border-bottom: 1px solid #E0E0E0;
    font-weight: normal;
    margin-bottom: 15px;
}
body.reg-closed.login #content .introduction {
    text-align: justify;
}
body.reg-closed.login #content fieldset {
    padding: 25px;
}
body.reg-closed.login #content fieldset.login-form > legend {
    background: #c0e7ff;
    width: auto;
    padding: 3px 25px 3px 10px;
    border-radius: 5px;
    color: rgba(0,0,0,.75);
    position: relative;
    left: -10px;
}
body.reg-closed.login #content fieldset.login-form .form-fields {
    display: table;
    width: 100%;
}
body.reg-closed.login #content fieldset.login-form .form-fields > div {
    display: table-row;
}
body.reg-closed.login #content fieldset.login-form .form-fields > div > div {
    display: table-cell;
    padding-bottom: 15px;
}
body.reg-closed.login #content fieldset.login-form .form-fields > div > div:first-child {
    padding-right: 25px;
}
body.reg-closed.login #content fieldset.login-form .form-fields > div > div:last-child {
    width: 100%;
}
body.reg-closed.login #content fieldset.login-form .form-fields > div > div:last-child > input {
    width: 100%;
}
body.reg-closed.login #content fieldset.login-form .form-button {
    text-align: right;
}
body.reg-closed.login #content .validation-summary-errors {
    border: 1px solid #ff9600;
    background-color: #fde7c8;
    border-radius: 5px;
}
body.reg-closed.login #content .validation-summary-errors > ul {
    margin: 15px;
    padding: 0 0 0 15px;
}
body.reg-closed.login #content .validation-summary-errors > ul >li  {
    color: #000;
    font-weight: normal;
}


/*------- Registration Follow-Up: Meal selection  --------*/
#form-step-0.meal-selection .box {
    padding: 15px;
    border-radius: 6px;
}
#form-step-0.meal-selection .description {
    padding-top: 30px;
    padding-bottom: 15px;
    font-weight: normal;
    background-color: transparent;
    border-color: transparent;
    text-align: center;
}
#form-step-0.meal-selection .saved {
    background-color: #9ee79e;
    border-color: #7abd7a;
    font-weight: bold;
    color: #000;
    text-align: center;
    margin: 25px 0;
}
#form-step-0.meal-selection .input-title,
#form-step-0.meal-selection .input-title-hidden {
    text-align: right;
    font-weight: bold;
    padding-bottom: 7px;
    width: 100%;
}
#form-step-0.meal-selection .input-title-hidden {
    display: none;
}
#form-step-0.meal-selection .product-selector {
    display: table;
    width: 100%;
}
#form-step-0.meal-selection .product-selector > div {
    display: table-row;
}

#form-step-0.meal-selection .product-selector > div > div {
    display: table-cell;
    vertical-align: top;
    padding-bottom: 25px;
}
#form-step-0.meal-selection .product-selector > div > div:nth-child(2) {
    padding-left: 25px;
    padding-right: 50px;
}
#form-step-0.meal-selection .product-selector > div > div:last-child {
    text-align: right;
}
#form-step-0.meal-selection .product-selector p {
    padding: 0;
    margin: 0;
}
#form-step-0.meal-selection .product-selector .title {
    padding-bottom: 5px;
    font-weight: bold;
}
#form-step-0.meal-selection .product-selector .title > .price {
    font-weight: normal;
    font-style: italic;
    padding-left: 25px;
}
#form-step-0.meal-selection .product-selector .description {
    text-align: left;
}
#form-step-0.meal-selection .product-selector input.anzahl {
    width: 35px;
    border: 1px solid #ccc;
    padding: 7px;
    font-size: 1.2em;
    color: #444;
    font-size: 13px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
    text-align: right;
    -moz-appearance: textfield;

}
#form-step-0.meal-selection .product-selector input.anzahl::-webkit-outer-spin-button,
#form-step-0.meal-selection .product-selector input.anzahl::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
#form-step-0.meal-selection .max-product-info {
    text-align: center;
    font-weight: bold;
    position: relative;
    width: calc(100% + 32px);
    padding: 10px 0;
}
#form-step-0.meal-selection .max-product-info.top {
    top: -16px;
    left: -16px;
    border-top-right-radius: 6px;
    border-top-left-radius: 6px;
    margin-bottom: 15px;
}
#form-step-0.meal-selection .max-product-info.bottom {
    top: 16px;
    left: -16px;
    border-bottom-right-radius: 6px;
    border-bottom-left-radius: 6px;
}


/*----- Registration Follow-Up: Add extra products ------*/
#form-step-0.extra-product-selection .box {
    padding: 15px;
    border-radius: 6px;
    margin-bottom: 30px;
}

#form-step-0.extra-product-selection .description {
    padding-top: 15px;
    padding-bottom: 25px;
    font-weight: normal;
    background-color: transparent;
    border-color: transparent;
    text-align: center;
}

#form-step-0.extra-product-selection .title {
    text-align: left;
    font-weight: bold;
    position: relative;
    width: calc(100% + 32px);
    padding: 10px 16px;
    top: -16px;
    left: -16px;
    background-color: rgba(0,0,0,.25);
    border-bottom: 1px solid rgba(0,0,0,.25);
    border-top-right-radius: 6px;
    border-top-left-radius: 6px;
    color: #000;
    font-size: 1.2em;
}

#form-step-0.extra-product-selection .sub-title {
    font-size: 1.1em;
    font-weight: bold;
    background-color: rgba(0,0,0,.1);
    position: relative;
    left: -16px;
    width: calc(100% + 32px);
    padding: 12px 16px 12px 16px;
    margin: 25px 0 25px 0;
}

#form-step-0.extra-product-selection hr {
    margin: 10px 0 15px 0;
    padding: 0;
    border: none;
    border-top: 1px solid rgba(0,0,0,.15);
}

#form-step-0.extra-product-selection .reservation-details {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    align-content: flex-start;
}

#form-step-0.extra-product-selection .reservation-details p {
    margin: 0 0 6px 0;
}

#form-step-0.extra-product-selection .reservation-details .event-name {
    font-weight: bold;
}

#form-step-0.extra-product-selection .reservation-details .AddProductsBtn {
    margin-top: 0;
    margin-bottom: 0;
}

#form-step-0.extra-product-selection .existing-products .no-products {
    font-weight: bold;
}

#form-step-0.extra-product-selection .product-selector {
    display: table;
    width: 100%;
}

#form-step-0.extra-product-selection .new-products {
    display: none;
}

#form-step-0.extra-product-selection .product-selector > div {
    display: table-row;
}

#form-step-0.extra-product-selection .product-selector > div > div {
    display: table-cell;
    vertical-align: top;
    padding-bottom: 25px;
}

#form-step-0.extra-product-selection .product-selector > div > div:nth-child(2) {
    padding-left: 25px;
    padding-right: 50px;
}

#form-step-0.extra-product-selection .product-selector > div > div:last-child {
    text-align: right;
}

#form-step-0.extra-product-selection .product-selector p {
    padding: 0;
    margin: 0;
}

#form-step-0.extra-product-selection .product-selector .product-title {
    padding-bottom: 5px;
    font-weight: bold;
}

#form-step-0.extra-product-selection .product-selector .product-title > .price {
    font-weight: normal;
    font-style: italic;
    padding-left: 25px;
    float: right;
}

#form-step-0.extra-product-selection .product-selector .description {
    text-align: left;
}

#form-step-0.extra-product-selection .product-selector select.anzahl {
    width: 60px;
    border: 1px solid #ccc;
    padding: 7px;
    font-size: 1.2em;
    color: #444;
    font-size: 13px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
    text-align: left;
}
#form-step-0.extra-product-selection .submitbutton {
    text-align: right;
}
#form-step-0.extra-product-selection .submitbutton > input:disabled {
    cursor: default;
}


/*---------------------- Responsive ---------------------*/
@media screen and (max-width: 767px) {
        #content {
        padding-top: 20px !important;
    }

    #Div_Table, #Div_TableSelection, #Div_Date {
        height: auto;
        min-height: unset;
    }

    .reservation-step-1 .EventGroupSelector .EventDisplayName > span {
        display: block;
        font-weight: bold;
        line-height: 15px;
        padding: 8px 0 0 0;
    }

    .reservation-step-1 .EventGroupSelector .hint-mobile {
        display: block;
        line-height: 15px;
        font-weight: normal;
        padding: 5px 0 5px 0;
    }

    .reservation-step-1 .EventGroupSelector .Div_EventSelect_Description {
        display: none !important;
    }

    #PremiumSeatingModal {
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden;
    }

    #TablePlanHintText {
        display: block;
    }

    #Plan {
        flex-direction: column;
    }

    #Plan #Div_TablePlanContainer {
        width: 100% !important;
        float: none !important;
        max-width: 100% !important;
    }

    #Plan #Div_TablePlanContainer #TablePlan {
        width: 100% !important;
        float: none !important;
        max-width: 100% !important;
        overflow: scroll;
    }

    #Plan #Div_Legend_Container {
        float: none !important;
        height: auto !important;
        width: 100% !important;
        margin: 35px 0 25px 0 !important;
    }

    #Plan #Div_Legend_Container h1 {
        float: none !important;
        width: 100% !important;
        text-align: left !important;
        margin: 0 0 25px 0 !important;
        padding: 0 0 10px 0 !important;
    }

    #Plan #Div_Legend_Container td {
        padding-bottom: 15px !important;
    }

    #form-step-2 {
        margin: 10px 25px;
    }

    #form-step-3 {
        margin: 10px 25px;
    }

    #form-step-4 {
        margin: 10px 25px;
    }

    #form-step-5 {
        margin: 10px 25px;
    }

    #step-4-order-overview.row > div {
        padding-left: 0 !important;
        padding-right: 0 !important;
        padding-top: 35px;
    }

    #step-4-order-overview.row > div:first-child {
        padding-top: 0;
    }

    #step-4-order-overview .tabular > div > div {
        padding-top: 5px;
    }
    
    #step-4-order-overview .tabular > div > div:last-child {
        text-align: right;
    }

    #form-login {
        margin: 10px 25px;
        padding-top: 25px;
        padding-bottom: 25px;
    }
}

@media screen and (max-width: 550px) {
    /*----- Registration Follow-Up: Add extra products ------*/
    #form-step-0.extra-product-selection .reservation-details {
        display: block;
        padding-bottom: 5px;
    }
}

@media screen and (max-width: 500px) {
    .reservation-step-1 #Div_Table_Select {
        flex-direction: column-reverse;
    }

    .reservation-step-1 #Div_Table_Dropdowns {
        float: none;
        padding-left: 0;
        padding-right: 0;
    }

    .reservation-step-1 #Div_Table #Div_MiniaturePlan {
        margin-top: 20px;
        text-align: center;
    }

    #step-4-order-overview .tabular {
        display: block;
    }

    #step-4-order-overview .tabular > div {
        display: flex;
    }

    #step-4-order-overview .tabular > div > div {
        display: initial;
    }

    #step-4-order-overview .tabular > div > div:first-child {
        white-space: nowrap;
        padding-right: 25px;
    }

    #step-4-order-overview .tabular > div > div:last-child {
        flex-grow: 2;
    }

    /*----- Registration Follow-Up: Add extra products ------*/
    #form-step-0.extra-product-selection .input-title {
        display: none;
    }

    #form-step-0.extra-product-selection .input-title-hidden {
        display: block;
    }

    #form-step-0.extra-product-selection .product-selector,
    #form-step-0.extra-product-selection .product-selector > div,
    #form-step-0.extra-product-selection .product-selector > div > div,
    #form-step-0.extra-product-selection .product-selector > div > div:nth-child(2) {
        display: block;
        padding: 0;
    }

    #form-step-0.extra-product-selection .product-selector > div {
        padding-bottom: 35px;
    }

    #form-step-0.extra-product-selection .product-selector > div > div:nth-child(1) {
        text-align: left;
        padding-bottom: 15px;
    }

    #form-step-0.extra-product-selection .product-selector > div > div:nth-child(1) img {
        width: auto;
        max-width: 100%;
        min-width: 150px;
    }

    #form-step-0.extra-product-selection .product-selector > div > div:nth-child(3) {
        padding-bottom: 25px;
        border-bottom: 1px solid rgba(0,0,0,.25);
    }

    #form-step-0.extra-product-selection .product-selector > div:last-child,
    #form-step-0.extra-product-selection .product-selector > div:last-child > div:nth-child(3) {
        padding-bottom: 7px;
        border-bottom: none;
    }

    #form-step-0.extra-product-selection .product-selector > div > div:nth-child(3) .input-title-hidden {
        text-align: left;
        padding: 15px 0 0 0;
    }

    #form-step-0.extra-product-selection .product-selector > div > div:nth-child(3) select.anzahl {
        width: 100%;
        margin-top: 15px;
    }

    #form-step-0.extra-product-selection .submit-area {
        padding-bottom: 25px;
    }

    #form-step-0.extra-product-selection .submit-area input[type=submit] {
        width: 100%;
    }
}

@media screen and (max-width: 450px) {
    .form-step-1, #form-step-2, #form-step-3, #form-step-4, #form-login {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .reservation-step-1 > div {
        padding-left: 0;
        padding-right: 0;
    }

    .reservation-step-1 #product_container #Div_ProductSelection > table tr {
        display: flex;
        flex-direction: column;
    }

    .reservation-step-1 #product_container #Div_ProductSelection > table td {
        padding: 0;
    }

    .reservation-step-1 #product_container #Div_ProductSelection > table td:nth-child(1) img {
        width: 100%;
        max-width: 150px;
    }

    .reservation-step-1 #product_container #Div_ProductSelection > table td:nth-child(2) {
        padding-top: 15px;
        padding-bottom: 15px;
    }

    .reservation-step-1 #product_container #Div_ProductSelection > table td:last-child {
        padding-bottom: 30px;
        border-bottom: 1px solid #000;
        margin-bottom: 40px;
    }

    .reservation-step-1 #product_container #Div_ProductSelection > table tr:last-child td:last-child {
        padding-bottom: 0px;
        border-bottom: none;
        margin-bottom: 0px;
    }

    body.reg-closed.login #content #form-login {
        padding-top: 0;
        padding-bottom: 1px;
    }

    body.reg-closed.login #content .logo {
        max-height: 100px;
        top: -10px;
    }

    body.reg-closed.login #content fieldset.login-form .form-fields {
        display: block;
    }

    body.reg-closed.login #content fieldset.login-form .form-fields > div {
        display: flex;
        flex-direction: column;
    }

    body.reg-closed.login #content fieldset.login-form .form-fields > div > div {
        display: block;
    }

    body.reg-closed.login #content fieldset.login-form .form-fields > div > div:first-child {
        padding-bottom: 5px;
    }

    body.reg-closed.login #content fieldset.login-form .form-fields > div > div:last-child {
        padding-bottom: 20px;
    }

    /*------- Registration Follow-Up: Meal selection  --------*/
    #form-step-0.meal-selection .input-title {
        display: none;
    }

    #form-step-0.meal-selection .input-title-hidden {
        display: block;
    }

    #form-step-0.meal-selection .product-selector,
    #form-step-0.meal-selection .product-selector > div,
    #form-step-0.meal-selection .product-selector > div > div,
    #form-step-0.meal-selection .product-selector > div > div:nth-child(2) {
        display: block;
        padding: 0;
    }

    #form-step-0.meal-selection .product-selector > div {
        padding-bottom: 35px;
    }

    #form-step-0.meal-selection .product-selector > div > div:nth-child(1) {
        text-align: left;
        padding-bottom: 15px;
    }

    #form-step-0.meal-selection .product-selector > div > div:nth-child(1) img {
        width: auto;
        max-width: 100%;
        min-width: 150px;
    }

    #form-step-0.meal-selection .product-selector > div > div:nth-child(3) {
        padding-bottom: 25px;
        border-bottom: 1px solid rgba(0,0,0,.25);
    }

    #form-step-0.meal-selection .product-selector > div:last-child, 
    #form-step-0.meal-selection .product-selector > div:last-child > div:nth-child(3) {
        padding-bottom: 7px;
        border-bottom: none;
    }

    #form-step-0.meal-selection .product-selector > div > div:nth-child(3) .input-title-hidden {
        text-align: left;
        padding: 15px 0 0 0;
    }

    #form-step-0.meal-selection .product-selector > div > div:nth-child(3) input.anzahl {
        width: 100%;
    }

    #form-step-0.meal-selection .submit-area {
        padding-bottom: 25px;
    }

    #form-step-0.meal-selection .submit-area input[type=submit] {
        width: 100%;
    }

    /*----- Registration Follow-Up: Add extra products ------*/
    #form-step-0.extra-product-selection .submitbutton {
        text-align: center;
        margin-bottom: 25px;
    }
    #form-step-0.extra-product-selection .submitbutton > input[type=submit] {
        width: 100%;
    }
}