body,
button,
html,
input,
select,
textarea {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    font-size: 16px;
    overflow-x: hidden;
}

html {
    background-color: #ebebeb;
    max-width: 100%;
}

html.home {
    background-color: #fff;
}

@media (max-width: 719px) {
    body,
    button,
    html,
    input,
    select,
    textarea {
        font-size: 16px;
    }
    html,
    html.home {
        background-color: #ebebeb;
    }
}

@media (min-width:1440px) {
    #content-wrapper,
    app-ticket-shop-main #content-wrapper {
        max-width: auto;
    }
}

app-travel-action-push>.content-wrapper {
    display: flex;
    padding: 65px 65px 40px 65px;
    flex-direction: column;
    background-color: #fff;
    box-shadow: 0 25px 55px -30px rgb(0 0 0 / 25%);
    border-top: 5px solid #cc3433;
}

@media (max-width:719px) {
    app-travel-action-push>.content-wrapper {
        padding: 25px 10px 10px 25px;
    }
}

app-home .customer-information,
body[state="root.ticket.offer.journey"] relation-input,
body[state="root.ticket.offer"] relation-input app-home .customer-tab,
.global-content-wrapper-single-col,
timetable-container,
offer-state-wrapper app-home .tab0Content,
app-home app-general-information,
app-home app-travel-action-push,
app-home general-info-bubble,
.mat-tab-group,
payment-footer .footer-wrapper {
    max-width: 980px;
}

.global-content-wrapper-single-col,
timetable-container,
relation-input #relationInput.wrapper,
offer-state-wrapper {
    width: 100%;
    ;
}

#main-wrapper {
    overflow: hidden;
    height: 100%;
    width: 100%;
    display: flex;
}

.root-content,
root-content router-outlet-wrapper {
    max-width: 100%;
}

app-ticket-shop-main #content-wrapper,
#content-wrapper {
    width: 100%;
    max-width: 100%;
    flex: 1;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: center;
}

page-header-wrapper {
    width: 100%;
    overflow: visible;
    z-index: 20;
    position: relative;
    box-shadow: 0 20px 15px -20px rgb(0 0 0 / 15%);
    z-index: 9999;
    max-width: 2560px;
}

page-header {
    display: flex;
    flex-direction: column;
    width: 100%;
    position: relative;
    align-items: center;
    background-color: #fff
}

page-header .page-header {
    width: 100%;
    max-width: 2560px;
    display: flex;
}

page-header .page-header {
    position: relative;
}

@media (max-width:719px) {
    page-header .page-header.no-buttons.has-relation-input:not(.is-start) {
        height: 0
    }
    html[feature-toggles=relationInputHide] page-header .page-header.no-buttons.has-relation-input:not(.is-start) {
        height: 62px
    }
    app-home .tab0Content,
    app-home app-travel-action-push {
        margin-top: unset;
    }
}

@media (max-width:1180px) {
    app-ticket-shop-main .root-content-wrapper app-quick-navigation-bar {
        display: none;
    }
}

@media (min-width:720px) {
    avc-payment>section .shoppingcart-item-wrapper:first-of-type,
    ts-payment>section .shoppingcart-item-wrapper:first-of-type {
        margin-top: 40px;
    }
}

@media (min-width: 720px) {
    app-home .tab0Content,
    app-home app-travel-action-push {
        margin-top: -5vw;
        width: 100%;
        margin-bottom: 65px
    }
}

.background,
[appChangingBackground] {
    height: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-color: none;
    background-position: bottom center;
    overflow: hidden
}

app-footer {
    display: flex;
    flex: 0 0 auto;
    background-color: #fff;
    width: 100%;
}

app-footer>footer {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 1fr 2fr;
    grid-template-columns: 1fr 1fr 2fr;
    -ms-grid-rows: auto 1fr auto;
    grid-template-rows: auto 1fr auto;
    max-width: 980px;
    width: 100%;
    margin: 40px auto 25px auto
}

.home app-footer>footer {
    border-top: 1px solid #d7d7d7;
    padding-top: 40px;
    padding-bottom: 25px;
}

app-ticket-shop-main .root-content-wrapper {
    display: flex;
    flex: 1 0;
    height: 100%;
    width: 100%;
    max-width: 2560px;
    flex-direction: column;
    overflow: hidden;
    position: relative
}

app-ticket-shop-main {
    display: flex;
    width: 100%;
    max-width: 100%;
    flex: 1;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    justify-items: center;
}

.background.background-landscape-1440,
[appChangingBackground].background-landscape-1440 {
    background-image: url("Web_L_1440_sommer.jpg");
    background-position: bottom center;
}

.background.background-landscape-1440.darken,
[appChangingBackground].background-landscape-1440.darken {
    position: absolute;
    width: 100%;
    height: 250px;
    z-index: 0;
    background-position: center;
    background-image: url(Web_L_1440_small_auszug.jpg);
    background-size: cover;
    background-repeat: no-repeat;
}

.background.background-landscape-1440.darken.blur,
[appChangingBackground].background-landscape-1440.darken.blur {
    background-position: center 35%;
    background-image: url(Web_L_1440_blur.jpg);
    z-index: 0;
}

.background.background-landscape-1440.darken.blur:after,
[appChangingBackground].background-landscape-1440.darken.blur:after {
    content: "";
    z-index: 5;
    background-color: rgba(0, 0, 0, 0.05);
    position: absolute;
    width: 100%;
    height: 100%;
}

app-ticket-shop-main .root-content-wrapper .ticket-content {
    z-index: 1;
}

.f12 {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    font-size: 0.75rem;
    line-height: 1
}

.f10 {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    font-size: 0.625rem;
    line-height: 1
}

.f11 {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    font-size: 0.75rem;
    line-height: 1
}

.f13 {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    font-size: 0.875rem;
    line-height: 1.33
}

.f14 {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    font-size: 0.875rem;
    line-height: 1.33
}

.f15 {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    font-size: 0.875rem;
    line-height: 1.33;
}

.f16 {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    font-size: 1rem;
    line-height: 1.33;
}

.f18 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1rem;
    line-height: 1;
}

.f19 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1.125rem;
    line-height: 1;
}

.f20 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1.125rem;
    line-height: 1;
}

.f21 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1.125rem;
    line-height: 1;
}

.f22 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1.125rem;
    line-height: 1;
}

.f24 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1.25rem;
    line-height: 1;
}

.f26 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1.25rem;
    line-height: 1;
}

.f27 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1.25rem;
    line-height: 1;
}

.f28 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1.25rem;
    line-height: 1;
}

.f30 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1.25rem;
    line-height: 1;
}

.f32 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1.625rem;
    line-height: 1;
}

.f34 {
    font-family: "-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif";
    font-size: 1.625rem;
    line-height: 1
}

mat-form-field.mat-form-field-appearance-outline.mat-form-field-should-float.mat-focused .mat-form-field-label,
mat-form-field.mat-form-field-appearance-outline.mat-form-field-should-float.mat-focused .mat-form-field-outline,
mat-form-field.mat-form-field-appearance-outline.mat-form-field-should-float.ng-valid:not(.mat-form-field-invalid) .mat-form-field-label,
mat-form-field.mat-form-field-appearance-outline.mat-form-field-should-float.ng-valid:not(.mat-form-field-invalid) .mat-form-field-outline {
    background-color: #fff;
}

page-header .title-wrapper {
    flex-grow: 1;
    display: flex;
    align-content: center;
    align-items: center;
}

page-header .header-title {
    font-size: 20px;
    line-height: 1;
    color: #222;
    padding-right: 8px;
    font-weight: 400;
    padding-top: 0;
    line-height: 1;
    margin: 0;
}

page-header h1.header-title {
    margin-top: 0.25em;
    display: none;
}

app-footer>footer {
    margin: 40px auto;
}

app-ticket-shop-main .root-content-wrapper .ticket-content .scrolled-container.global-content-wrapper-single-col {
    display: flex;
    justify-content: center;
    margin: 0;
    z-index: 1;
}

.global-content-wrapper-single-col {
    margin: auto !important;
}

timetable-container .him-1-max {
    padding-top: 0;
}

@media (max-width: 719px) {
    timetable-header header.navigationHeader {
        padding-bottom: 0;
    }
}

.timetable-container header,
timetable-header header.navigationHeader {
    margin-bottom: unset;
    padding: 40px 15px
}

.timetable-container header {
    padding: 15px;
}

@media (max-width: 719px) {
    timetable-header header.navigationHeader .combiticket-info,
    timetable-header header.navigationHeader h1,
    timetable-header header.navigationHeader {
        color: #222;
        margin: 25px 0 0 0;
    }
    .timetable-container header,
    timetable-header header.navigationHeader {
        padding: 15px;
        margin: 0;
    }
}

@media (max-width: 719px) {
    timetable-container .him-1-max {
        padding-top: 0;
    }
    app-footer>footer .help-link-list,
    app-footer>footer .legal-link-list {
        display: none;
    }
    best-price-finder>.sortSelection .rtfSaveButton,
    best-price-finder>.sortSelection>connection-filter,
    connection-filter button {
        overflow: hidden;
    }
}

relation-input #relationInput>.content .change {
    line-height: unset;
}

relation-input #relationInput.wrapper {
    border-top: 0;
}

@media (min-width: 720px) {
    best-price-finder {
        background-color: #fff;
        box-shadow: 0 20px 15px -20px rgb(0 0 0 / 15%);
    }
}

timetable-connection .connectionWrapper .connection.widget .time {
    background-color: #fff;
}

@media (min-width: 720px) {
    timetable-connection .connectionWrapper .connection.widget .time {
        font-size: 1.25rem;
    }
}

timetable-connection .connectionWrapper .connection.widget .travel {
    background-color: #fff;
}

timetable-connection .connectionWrapper .connection.widget .price {
    border-left: 1px solid #d7d7d7;
}

.grey-card {
    background-color: rgba(255, 255, 255, 0.75);
}

timetable-connection .connectionWrapper .connection.widget:focus .time,
timetable-connection .connectionWrapper .connection.widget:focus .travel,
timetable-connection .connectionWrapper .connection.widget:hover .time,
timetable-connection .connectionWrapper .connection.widget:hover .travel,
timetable-connection .connectionWrapper .connection.widget:hover .price {
    background-color: rgba(255, 255, 255, 0.5);
}

timetable-connection .connectionWrapper .actions svg {
    fill: #666;
}

.timetable-container header {
    color: #000;
}

.timetable-container .button {
    text-shadow: none;
    background-color: #666;
}

.connection .sections .section .journey {
    background-color: #f4f4f4 !important;
}

@media (min-width: 720px) {
    .global-content-wrapper-single-col,
    timetable-container,
    relation-input #relationInput.wrapper,
    offer-state-wrapper {
        max-width: 980px;
    }
    timetable-connection .connectionWrapper {
        margin-bottom: 25px;
        box-shadow: 0 20px 15px -20px rgb(0 0 0 / 15%);
    }
    timetable-connection .connectionWrapper .connection.widget .time,
    timetable-connection .connectionWrapper .connection.widget .price,
    timetable-connection .connectionWrapper .connection.widget .travel {
        padding: 25px 15px 15px 5px;
    }
    timetable-connection .connectionWrapper .connection.widget .price {
        font-size: 1.25rem;
        font-weight: 500;
    }
    timetable-connection .connectionWrapper .connection.widget .travel {
        padding-left: 15px;
    }
    date-chooser {
        padding: 25px 0;
        display: flex;
        justify-content: space-between;
    }
    date-chooser button.calendarButton {
        max-width: 33%;
    }
    best-price-finder>.sortSelection best-price-finder-sort-selection-form {
        flex: 1 25%;
    }
    best-price-finder>.sortSelection .rtfSaveButton .favoriteHeart,
    best-price-finder>.sortSelection>connection-filter .favoriteHeart {
        margin: 0 5px 0 0;
    }
    best-price-finder>.sortSelection>.rtfSaveButton,
    connection-filter button {
        font-weight: 600;
        font-size: 0.875rem;
    }
    best-price-finder>.sortSelection {
        padding: 15px;
    }
    relation-input #relationInput>.content>.mainSection>.passengers.visible {
        visibility: visible;
        flex: 0 0 160px;
        width: 160px;
        max-width: 160px;
        padding: 5px 11px;
        cursor: pointer;
    }
    relation-time {
        flex: 0 0 130px;
        width: 130px;
        max-width: 130px;
        padding: 0;
    }
    .connection .connection-sections-details .oneRowEllipsis,
    .connection .connection-sections-details span {
        font-weight: 500;
    }
    timetable-connection .connectionWrapper .connection.widget .travel {
        border-left: 0;
        border-right: 0;
    }
    offer-state-wrapper .headline,
    offers-headline .offers-headline .headline {
        color: #000;
        font-weight: 400;
        font-size: 1.25rem;
    }
    offers-headline .offers-headline .headline {
        color: #fff;
    }
    offer-state-wrapper .offer-controls {
        padding-top: 40px;
    }
    offer-block .offer-block .content-section .title,
    .extra-item-container-light .content-section .info-section .title {
        font-size: 1.15rem;
        line-height: 1;
        margin: 0 0 10px 0;
        font-weight: 400;
    }
    offer-state-wrapper .more-or-less-section {
        color: #000;
        font-weight: 400;
        font-size: 1rem;
    }
    offer-state-wrapper .more-or-less-section svg polyline {
        stroke: #000;
    }
    footer-navigation-button {
        width: 980px !important;
        margin: 0 auto;
        position: relative;
        left: 0 !important;
    }
    footer-navigation-button>button {
        border-radius: 5px 5px 0 0;
        position: fixed;
        bottom: 0;
    }
    tourist-specials .extra-items-container .item-block .item-image .details {
        bottom: 25px;
        right: 25px;
    }
    offer-block .offer-block .content-section .title .price {
        font-size: 1rem;
    }
    offer-price .show-price .title {
        margin: 0 0 5px 0;
        padding: 0 0 15px 0;
        font-weight: 400;
        font-size: 1rem;
        line-height: 1;
        text-align: right;
        font-size: 1.15rem;
    }
    offer-price .extra-info p {
        font-weight: 500;
    }
    offer-create-info-card svg {
        margin-right: 10px;
    }
    offers-headline .offers-headline .headline {
        color: #fff;
        font-size: 1.625rem;
        margin-bottom: 40px;
        font-weight: 400;
        margin-top: 0;
    }
    offer-block,
    .extra-item-container-light {
        border-bottom: 1px solid #d7d7d7;
        box-shadow: 0 20px 15px -20px rgb(0 0 0 / 15%);
    }
    offer-block .offer-block {
        border-bottom: 0;
    }
    .extra-item-container-light .content-section .price-section,
    offer-block .offer-block .price-section {
        border-left: 1px solid #d7d7d7;
    }
    tourist-specials .extra-items-container .item-block .item-image,
    .extra-item-container-light .content-section .check-box-section,
    .extra-item-container-light .content-section .info-section,
    offer-block .offer-block .content-section,
    offer-block .offer-block .check-section {
        background-color: #fff;
    }
}

body[state="root.ticket.offer.journey"] relation-input,
body[state="root.ticket.offer"] relation-input {
    max-width: 100vw;
    width: 100%;
    display: flex;
    justify-content: center;
    margin-left: 0 !important;
}

offers-headline .offers-headline .offer-headline-buttons-section .offers-headline-action {
    color: #fff;
    fill: #fff;
    display: flex;
    align-items: center;
}

offers-headline .offers-headline .offer-headline-buttons-section .offers-headline-action ts-icon {
    width: 25px;
    height: 25px;
    margin-right: 10px;
}

@media (max-width: 719px) {
    offers-headline .offers-headline .offer-headline-buttons-section .offers-headline-action {
        color: #000;
        fill: #000;
    }
    offers-headline .offers-headline .offer-headline-buttons-section .offers-headline-action svg {
        margin-right: 5px;
        ;
    }
}

@media (max-width: 1279px) {
    app-home .customer-information,
    app-home .customer-tab,
    app-home .tab0Content,
    app-home app-general-information,
    app-home app-travel-action-push {
        margin-left: auto;
        margin-right: auto;
        width: 100%;
    }
}

ts-payment section {
    padding-right: 0;
    margin-bottom: 105px;
}

shoppingcart-summary-buttons button,
shoppingcart-summary-buttons>span {
    overflow: hidden;
}

payment-footer {
    margin-left: 0;
    width: 100%;
    position: fixed;
    bottom: 0;
    left: 0;
}

payment-footer .footer-wrapper {
    margin: 10px auto;
}

shopping-cart-item .item-wrapper,
payment-box {
    background-color: #fff;
}

shopping-cart-item shopping-cart-item-entry,
shopping-cart-item shopping-cart-item-route,
shopping-cart-item shopping-cart-item-single-ride,
shopping-cart-item .item-wrapper .passengers,
shopping-cart-item .item-wrapper>.conversion,
shopping-cart-item .item-wrapper .contractual-button,
shopping-cart-item .item-wrapper .remove-button {
    border-bottom: 0;
}

shopping-cart-item-single-ride .connection-wrapper .station {
    height: 100%;
}

.mat-form-field-invalid .mat-input-element,
.mat-warn .mat-input-element {
    color: #000;
}

payment-method-list .payment-methods>div,
payment-method-list one-click-methods>div {
    border-bottom: 1px solid #d7d7d7;
}

payment-box payment-email {
    margin-bottom: 65px;
}

payment-box {
    margin: 25px 0;
    padding: 40px 0 25px 40px;
}

@media (max-width: 719px) {
    payment-box {
        padding: 40px 0 15px 25px
    }
}

shoppingcart-summary-buttons {
    padding: 15px 5px 15px 25px;
}

payment-method-list .payment-methods {
    border-top: 1px solid #d7d7d7;
    margin-top: 25px;
}

payment-box-footer .security-info>.col2 {
    padding: 40px 40px 40px 0;
}

payment-box-footer .security-info>.col1 {
    padding: 40px 0 0 0;
    margin-right: 15px;
    width: 65px;
    text-align: center;
}

avc-payment .go-to-home-button,
ts-payment .go-to-home-button {
    background-color: transparent;
    padding: 25px;
}

one-click-method .payment-method>.col1,
payment-method-template .payment-method>.col1,
payment-newsletter-box .data-privacy-section .icon-section,
avc-payment .go-to-home-button>.col1,
ts-payment .go-to-home-button>.col1 {
    width: 65px;
    padding: 25px 0 0 0;
    margin: 0;
}

payment-newsletter-box .data-privacy-section .icon-section,
avc-payment .go-to-home-button>.col1,
ts-payment .go-to-home-button>.col1 {
    padding: 0;
    margin-right: 15px;
    max-width: 25px;
}

avc-payment>section .shoppingcart-item-wrapper:first-of-type,
ts-payment>section .shoppingcart-item-wrapper:first-of-type,
shoppingcart-summary .total,
payment-box {
    box-shadow: 0 20px 15px -20px rgb(0 0 0 / 15%);
}

payment-newsletter-box .data-privacy-section,
payment-newsletter-box {
    border-top: 0;
    background-color: transparent;
}

payment-newsletter-box .data-privacy-section {
    padding: 25px;
}

payment-footer {
    box-shadow: 0 -25px 55px -30px rgb(0 0 0 / 35%);
}

payment-box h2 {
    font-size: 1.25rem;
}

@media (max-width: 719px) {
    shopping-cart-summary-price-row>.value>.left {
        flex: 2 1 75%;
    }
}

shopping-cart-summary-price-row>.value>.left * {
    margin-bottom: 5px;
    font-size: 1.15rem;
    font-weight: 400;
}

shopping-cart-summary-price-row>.value>.left a {
    margin-bottom: 0;
    font-size: 1rem;
}

@media (max-width: 719px) {
    shopping-cart-summary-price-row>.value>.left a {
        font-size: 0.85rem;
    }
}

mat-checkbox .mat-checkbox-frame {
    border-color: #000;
}

.mat-form-field.mat-form-field-invalid .mat-form-field-label,
.mat-form-field.mat-form-field-invalid .mat-form-field-label .mat-form-field-required-marker,
.mat-form-field.mat-form-field-invalid .mat-form-field-label.mat-accent {
    color: #666;
}

relation-input #relationInput>.content>.mainSection {
    display: flex;
    justify-content: space-between;
}

body[state="root.ticket.baggageOffer"] relation-time,
body[state="root.ticket.offer.journey"] relation-time,
body[state="root.ticket.offer"] relation-time {
    cursor: pointer!important;
    flex: 1 1;
    width: auto;
    max-width: unset;
}

@media (min-width: 720px) {
    body[state="root.ticket.baggageOffer"] relation-time,
    body[state="root.ticket.offer.journey"] relation-time,
    body[state="root.ticket.offer"] relation-time {
        min-width: 80px;
    }
}

@media (max-width: 719px) {
    body[state="root.ticket.baggageOffer"] relation-time,
    body[state="root.ticket.offer.journey"] relation-time,
    body[state="root.ticket.offer"] relation-time {
        min-width: 60px;
    }
}

body[state="root.ticket.baggageOffer"] relation-input #relationInput>.content>.mainSection>.connection,
body[state="root.ticket.offer.journey"] relation-input #relationInput>.content>.mainSection>.connection,
body[state="root.ticket.offer"] relation-input #relationInput>.content>.mainSection>.connection {
    cursor: pointer!important;
    visibility: visible;
    flex: 1 1 30px;
    width: auto;
    max-width: 30px;
}

relation-station {
    flex: 5 2 50%;
}

relation-input #relationInput>.content>.mainSection>.passengers.visible {
    flex: 1 1 10%;
    min-width: 100px;
    width: auto;
    max-width: unset;
}

conversion-button {
    padding: 0;
    margin: 0;
    display: flex;
    flex: 0 0 150px;
    padding: 10px 10px;
    width: auto;
    max-width: unset;
}

@media (max-width: 719px) {
    conversion-button {
        flex: 0 0 135px;
    }
}

@media (min-width: 720px) {
    conversion-button {
        flex: 0 0 150px;
    }
}

@media (max-width: 719px) {
    relation-input #relationInput>.content>.mainSection>.passengers.visible {
        width: auto;
        max-width: unset;
    }
}

@media (min-width: 720px) {
    relation-input #relationInput>.content>.mainSection>.passengers.visible {
        width: auto;
        max-width: unset;
    }
}

conversion-button .conversion-button-wrapper {
    border-radius: 2px;
    flex: 0 0 100%;
}

conversion-button .conversion-button-wrapper .conversion-button-content .price {
    margin: 0 0 5px 0;
}

relation-input #relationInput>.content .change {
    left: 10px;
}

offer-block .offer-block .price-section {
    width: 150px;
    min-width: 150px;
}

relation-station .input input {
    padding-left: 15px;
}

payment-footer-pay-button button {
    flex: 0 0 110px;
}

@media (min-width: 720px) {
    payment-footer-pay-button button {
        flex: 0 0 150px;
    }
}

@media (min-width: 720px) {
    shopping-cart-item .item-wrapper>.conversion {
        min-width: 150px;
    }
}

shopping-cart-summary-price-row>.value>.right {
    flex: 0 1 25%;
    box-sizing: border-box;
    padding-right: 5px;
    border-left: 1px solid #d7d7d7;
}

@media (min-width: 720px) {
    shopping-cart-summary-price-row>.value>.right {
        padding-right: 15px;
        flex: 0 1 150px;
    }
}

payment-footer-pay-button {
    flex: 0 0 150px;
}

offers-headline .offers-headline {
    margin: 40px 15px;
}

@media (max-width: 719px) {
    offers-headline .offers-headline {
        margin-top: 0;
        margin-bottom: 0;
        padding: 40px 0 25px 0;
        margin: 0 10px;
    }
    offer-state-wrapper .headline {
        margin: unset;
    }
}

offer-state-wrapper .offer-controls {
    padding-top: 0;
}

@media (max-width: 719px) {
    offers-headline .offers-headline .offer-headline-buttons-section {
        margin-right: 0;
    }
}

extras-wrapper .headline,
offers-headline .offers-headline .headline,
city-tickets .headline,
offer-state-wrapper .headline {
    font-weight: 400;
}

extras-wrapper .headline,
city-tickets .headline,
offer-state-wrapper .headline {
    margin: 40px 10px 15px 10px;
}

offers-headline .offers-headline .headline {
    margin: 0;
}

.extra-item-container-light .content-section .info-section .title,
offer-block .offer-block .content-section .title,
offer-state-wrapper .more-or-less-section {
    font-weight: 400;
}

@media (max-width: 719px) {
    offers-headline .offers-headline .offer-headline-buttons-section .offers-headline-action svg {
        margin-right: 5px;
        width: 25px;
        height: 25px;
    }
}

@media (max-width: 719px) {
    timetable-connection .connectionWrapper {
        margin-bottom: 10px;
    }
}

shoppingcart-summary-buttons button,
shoppingcart-summary-buttons>span {
    margin-right: 25px;
}

one-click-method .payment-method>.col2 .title,
payment-method-template .payment-method>.col2 .title {
    font-weight: 400;
}

shopping-cart-item .item-wrapper .passengers,
shopping-cart-item-single-ride .connection-wrapper .time {
    padding: 10px 5px 10px 10px;
}

shopping-cart-item .item-wrapper .passengers passengers-summary .subheading {
    left: unset;
}

timetable-header header.navigationHeader h1 {
    font-weight: 400;
}

@media (max-width: 719px) {
    .extra-item-container-light .content-section .check-box-section {
        width: 46px;
        min-width: 46px;
    }
}

shoppingcart-item-count .shoppingcart-wrapper {
    align-items: center;
}

shoppingcart-item-count .shoppingcart-wrapper .shoppingcart {
    width: unset;
    margin: 0;
}

page-header .header-logo-img {
    margin: 25px;
    height: 25px;
}

@media (max-width: 719px) {
    page-header .header-logo-img {
        height: 20px;
        margin: 15px;
    }
}

page-header .header-logo {
    display: flex !important;
    align-items: center;
}

payment-footer-pay-button button {
    flex: 1 1;
    border-radius: 3px;
}

payment-footer-pay-button {
    padding: 10px;
}

.header-nav {
    position: absolute;
    right: 0;
    height: 100%;
    display: flex;
    align-items: center;
}

.header-nav ul {
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: row;
    height: 100%;
}

.header-nav ul li {
    list-style: none;
    margin: 0 25px 0 0;
    padding: 5px;
    font-size: 12px;
    font-weight: 600;
    color: #666;
    display: flex;
    align-items: center;
    height: 100%;
    cursor: pointer;
}

.header-nav ul li:hover {
    opacity: 0.75;
    text-decoration: underline;
}

.header-nav ul li span {
    margin-left: 5px;
}

.header-nav ul li img {
    width: 17px;
    height: 16px;
}

@media (max-width: 719px) {
    .header-nav ul li {
        margin: 0 15px 0 0;
    }
    .header-nav ul li span {
        display: none;
    }
    .show-md-up {
        display: none!important;
    }
    page-header .is-home .title-wrapper {
        margin-left: 0;
    }
    page-header {
        padding-right: 10px;
    }
}

h1,
h2,
h3,
h4,
h5 {
    font-family: "Frutiger Next", "Frutiger Next Pro", "Frutiger";
    margin-top: 0.25em;
    font-weight: bold;
}

app-home-login-box h3 {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    font-size: 14px;
}

* {
    overflow: unset;
}

avc-payment>section .shoppingcart-item-wrapper:first-of-type,
ts-payment>section .shoppingcart-item-wrapper:first-of-type,
relation-input-wrapper {
    position: sticky;
    top: 0;
    display: block;
    z-index: 1111;
}

.root-content,
app-ticket-shop-main .root-content-wrapper,
.ticket-content,
html,
body,
#main-wrapper {
    overflow: unset !important;
}

html {
    overflow-x: hidden !important;
}

app-ticket-shop-main .root-content-wrapper app-quick-navigation-bar {
    display: none;
}