@charset "UTF-8";
/* ==========================================================================
   Normalize.scss settings
   ========================================================================== */
/**
 * Includes legacy browser support IE6/7
 *
 * Set to false if you want to drop support for IE6 and IE7
 */
/* Base
   ========================================================================== */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS and IE text size adjust after device orientation change,
 *    without disabling user zoom.
 * 3. Corrects text resizing oddly in IE 6/7 when body `font-size` is set using
 *  `em` units.
 */
/* TODO alles mit "no-overlay" soll nach der Einführung der Layer entfernt werden. Diese Klasse ist nur temporär da für Popup-Fenster */
html {
    font-family: sans-serif;
    /* 1 */
    -ms-text-size-adjust: 100%;
    /* 2 */
    -webkit-text-size-adjust: 100%;
    /* 2 */
}

/**
 * Remove default margin.
 */
body {
    margin: 0;
}

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

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

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

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

@font-face {
    font-family: "DBScreenHeadBlack";
    src: url("../fonts/DBScreenHead-Black.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: "DBScreenHeadLight";
    src: url("../fonts/DBScreenHead-Light.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: "DBScreenHeadRegular";
    src: url("../fonts/DBScreenHead-Regular.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: "DBScreenSansBold";
    src: url("../fonts/DBScreenSans-Bold.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: "DBScreenSansRegular";
    src: url("../fonts/DBScreenSans-Regular.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: "DBScreenSansCondBold";
    src: url("../fonts/DBScreenSansCond-Bold.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: "DBScreenSansCondRegular";
    src: url("../fonts/DBScreenSansCond-Regular.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
}

html {
    width: 100%;
    height: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-size: 16px;
    margin: 0;
    color: #282D37;
    background-color: #cecece;
}

body .wrapper {
    position: relative;
    width: 980px;
    margin: 0 auto;
    background: #fff;
}

.content {
    position: relative;
    background: #F0F3F5;
}

p {
    font-size: 0.875em;
    line-height: 1.5em;
    margin: 0;
}

a {
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 16px;
    font-weight: normal;
    font-style: normal;
    color: #282D37;
    text-decoration: none;
}

.no-touch a:hover {
    text-decoration: underline;
    color: #C50014;
}

a.close {
    position: absolute;
    right: 5px;
    top: 5px;
    width: 44px;
    height: 44px;
}

a.close .ico {
    position: absolute;
    top: 16px;
    right: 16px;
}

section {
    width: 100%;
}

.btn, a.btn {
    display: inline-block;
    text-align: center;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 1em;
    line-height: 14px;
    color: white;
    text-decoration: none;
    padding: 14px 16px;
    background: #ec0016;
    box-shadow: none;
    border: none;
    border-radius: 4px;
    min-width: 100px;
    height: 44px;
    justify-content: center;
}

.btn:hover, a.btn:hover {
    background: #9b000e;
    text-decoration: none;
    color: white;
}

.btn.grey, a.btn.grey {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", "Helvetica", sans-serif;
    color: #282D37;
    background: transparent no-repeat;
    border: 1px solid #70747f;
    text-align: center;
}

.btn.grey:hover, a.btn.grey:hover {
    color: #282D37;
    background-color: #afb4bb;
    text-decoration: none;
}

.btn.code, a.btn.code {
    color: #646973;
    background-color: #f5f5f5;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.btn.code.gutschein, a.btn.code.gutschein {
    color: #282D37;
    background: transparent no-repeat;
    border: 1px solid #70747f;
    min-width: 132px;
}

.btn.code:hover, a.btn.code:hover {
    color: #646973;
    background-color: #dedede;
}

.btn.code.gutschein:hover, a.btn.code.gutschein:hover {
    color: #282D37;
    background-color: #afb4bb;
}

.btn.big {
    padding: 8px 33px;
}

input.btn:hover,
button.btn:hover {
    background: #9b000e;
    text-decoration: none;
    color: white;
}

input.btn.right-btn,
button.btn.right-btn {
    margin-right: 12px;
}

input.btn.disabled, button.btn.disabled,
input.btn.disabled:hover, button.btn.disabled:hover,
.btn.code.gutschein.disabled,.btn.code.gutschein.disabled:hover {
    color: #afb4bb;
    background: transparent no-repeat;
    border: 1px solid #d7dce1;
}

.btn.darkgrey {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", "Helvetica", sans-serif;
    background-color: #646973;
    color: #FFFFFF;
    text-align: center;
    border: none;
}

.btn.darkgrey.disabled, .btn.darkgrey.disabled:hover {
    background-color: #AFB4BB;
    color: #FFFFFF;
}

.btn.darkgrey:hover {
    background-color: #282D37;
    color: #FFFFFF;
    opacity: 0.8;
    text-decoration: none;
}

.btn.darkgrey:active {
    background-color: #3C414B;
    color: #FFFFFF;
    text-decoration: none;
}

.btn.darksilver {
    background-color: #D7DCE1;
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", "Helvetica", sans-serif;
    color: #282D37;
    text-align: center;
    height: auto;
}

.btn.darksilver.disabled, .btn.darksilver.disabled:hover {
    background-color: #D7DCE1;
    border: none;
    color: #282D37;
    opacity: 0.5;
}

.btn.darksilver:hover {
    background-color: #C6CACF;
    color: #282D37;
    text-decoration: none;
}

.btn.darksilver:active {
    background-color: #B4B8BC;
    text-decoration: none;
}

/* TODO CL was soll diese Def? Rot wenn disabled?? */
/*
input.btn.disabled:hover,
button.btn.disabled:hover {
    background: #ff0000;
}
*/

input {
    border: 0;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    overflow: hidden;
}

input::-webkit-input-placeholder {
    color: #646973;
}

input:-moz-placeholder {
    color: #646973;
    opacity: 1;
}

input::-moz-placeholder {
    color: #646973;
    opacity: 1;
}

input:-ms-input-placeholder {
    color: #646973;
}

input {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

input[type=number] {
    appearance: textfield;
    -webkit-appearance: textfield;
    -moz-appearance: textfield;
    -ms-appearance: textfield;
    -o-appearance: textfield;
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    -ms-appearance: none;
    -o-appearance: none;
    margin: 0;
}

input.text {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 16px;
    line-height: 20px;
    color: #282d37;
    padding: 6px 0 5px;
}

input.text::-webkit-input-placeholder {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}

input.text:-moz-placeholder {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}

input.text::-moz-placeholder {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}

input.text:-ms-input-placeholder {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}

input.number {
    font-size: 1em;
    line-height: 20px;
    color: #282d37;
    padding: 6px 0 5px;
}

input.number::-webkit-input-placeholder {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}

input.number:-moz-placeholder {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}

input.number::-moz-placeholder {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}

input.number:-ms-input-placeholder {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
    display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
    display: inline-block;
    /* 1 */
    vertical-align: baseline;
    /* 2 */
}

/**
 * Prevents modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
    display: none;
    height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
 */
[hidden],
template {
    display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
    background-color: transparent;
}

/**
 * Improve readability of focused elements when they are also in an
 * active/hover state.
 */
a:active, a:hover {
    outline: 0;
}

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
    border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
    font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
    font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
    font-size: 2em;
    margin: 0.67em 0;
}

/**
 * Addresses styling not present in IE 8/9.
 */
mark {
    background: #ff0;
    color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
    font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sup {
    top: -0.5em;
}

sub {
    bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * 1. Remove border when inside `a` element in IE 8/9/10.
 * 2. Improves image quality when scaled in IE 7.
 */
img {
    border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
    overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
    margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
    box-sizing: content-box;
    height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
    overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 * Correct font family set oddly in IE 6, Safari 4/5, and Chrome.
 */
code,
kbd,
pre,
samp {
    font-family: monospace, monospace;
    font-size: 1em;
}

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *  Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 * 4. Improves appearance and consistency in all browsers.
 */
button,
input,
optgroup,
select,
textarea {
    color: inherit;
    /* 1 */
    font: inherit;
    /* 2 */
    margin: 0;
    /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
    overflow: visible;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
    text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *  and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *  `input` and others.
 * 4. Removes inner spacing in IE 7 without affecting normal text inputs.
 *  Known issue: inner spacing remains in IE 6.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
    -webkit-appearance: button;
    /* 2 */
    cursor: pointer;
    /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
    cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
    border: 0;
    padding: 0;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
    line-height: normal;
}

/**
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 *  Known issue: excess padding remains in IE 6.
 */
input[type="checkbox"],
input[type="radio"] {
    box-sizing: border-box;
    /* 1 */
    padding: 0;
    /* 2 */
}

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    height: auto;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome.
 */
input[type="search"] {
    -webkit-appearance: textfield;
    /* 1 */
    box-sizing: content-box;
    /* 2 */
}

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}

input[type=file] {
    padding-right: 8px;
}

input[type=file]::-webkit-file-upload-button {
    display: inline-block;
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 0.75em;
    background: transparent no-repeat;
    color: #282D37;
    border: 1px solid #70747f;
    border-radius: 4px;
    text-align: center;
    margin-top: -2px;
    line-height: 14px;
    min-width: 100px;
    justify-content: center;
}

input[type=file]:disabled::-webkit-file-upload-button,
input[type=file]:disabled:hover::-webkit-file-upload-button {
    color: #afb4bb;
    background: transparent no-repeat;
    border: 1px solid #d7dce1;
}

input[type=file]::-webkit-file-upload-button:hover {
color: #282D37;
background-color: #afb4bb;
text-decoration: none;
}

/**
* Define consistent border, margin, and padding.
*/
fieldset {
    border: 1px solid #c0c0c0;
    margin: 0 2px;
    padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 * 3. Corrects text not wrapping in Firefox 3.
 * 4. Corrects alignment displayed oddly in IE 6/7.
 */
legend {
    border: 0;
    /* 1 */
    padding: 0;
    /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
    overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
    font-weight: bold;
}

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
    border-collapse: collapse;
    border-spacing: 0;
}

td,
th {
    padding: 0;
}

img {
    display: block;
}

.clearfix {
    zoom: 1;
}

.clearfix:before, .clearfix:after {
    content: "";
    display: table;
}

.clearfix:after {
    clear: both;
}

.center-inline {
    width: 100%;
    text-align: center;
}

.center-block {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.pull-right {
    float: right;
}

.pull-left {
    float: left;
    text-align: left;
}

.hide {
    display: none !important;
}

.show {
    display: block;
}

.margin-left-8 {
    margin-left: 8px;
}

.margin-left-20 {
    margin-left: 20px;
}

.margin-right-20 {
    margin-right: 20px;
}

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

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

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

.margin-bottom-5 {
    margin-bottom: 5px;
}

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

.padding-20 {
    padding: 20px;
}

.no-margin-left {
    margin-left: 0 !important;
}

.no-margin-top {
    margin-top: 0 !important;
}

ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.errormsg,
.required {
    color: #C50014;
}

.errormsg + .errormsg {
    margin-top: 5px;
}

.hidden {
    display: none !important;
}

.grey {
    background: #F0F3F5;
}

small {
    display: block;
    color: #878c96;
}

small.text {
    color: #282D37;
    margin-top: 5px;
}

.center-select {
    line-height: 44px;
}

strong {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

.font-normal {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}
/*
    Colorbox Core Style:
    The following CSS is consistent between example themes and should not be altered.
*/
#colorbox, #cboxOverlay, #cboxWrapper {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 9999;
    overflow: hidden;
    -webkit-transform: translate3d(0, 0, 0);
}

#cboxWrapper {
    max-width: none;
}

#cboxOverlay {
    position: fixed;
    width: 100%;
    height: 100%;
}

#cboxMiddleLeft, #cboxBottomLeft {
    clear: left;
}

#cboxContent {
    position: relative;
}

#cboxLoadedContent {
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

#cboxTitle {
    margin: 0;
}

#cboxLoadingOverlay, #cboxLoadingGraphic {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

#cboxPrevious, #cboxNext, #cboxClose, #cboxSlideshow {
    cursor: pointer;
}

.cboxPhoto {
    float: left;
    margin: auto;
    border: 0;
    display: block;
    max-width: none;
    -ms-interpolation-mode: bicubic;
}

.cboxIframe {
    width: 100%;
    height: 100%;
    display: block;
    border: 0;
    padding: 0;
    margin: 0;
}

#colorbox, #cboxContent, #cboxLoadedContent {
    box-sizing: content-box;
    border-radius: 4px;
    -moz-box-sizing: content-box;
    -webkit-box-sizing: content-box;
}

/*
    User Style:
    Change the following styles to modify the appearance of Colorbox.  They are
    ordered & tabbed in a way that represents the nesting of the generated HTML.
*/
#cboxOverlay {
    background: #000;
    opacity: 0.3;
    filter: alpha(opacity=30);
}

#colorbox {
    outline: 0;
}

#cboxTopLeft,
#cboxTopRight,
#cboxBottomLeft,
#cboxBottomRight,
#cboxMiddleLeft,
#cboxMiddleRight,
#cboxTopCenter,
#cboxBottomCenter,
#cboxTitle,
#cboxCurrent,
#cboxSlideshow,
#cboxPrevious,
#cboxNext {
    display: none;
}

#cboxContent {
    background: #fff;
    overflow: hidden;
}

.cboxIframe {
    background: #fff;
}

#cboxError {
    padding: 50px;
    border: 1px solid #ccc;
}

#cboxLoadingOverlay {
    background: url(../img/colorbox/loading_background.png) no-repeat center center;
}

#cboxLoadingGraphic {
    background: url(../img/colorbox/loading.gif) no-repeat center center;
}

/*
  The following fixes a problem where IE7 and IE8 replace a PNG's alpha transparency with a black fill
  when an alpha filter (opacity change) is set on the element or ancestor element.  This style is not applied to or needed in IE9.
  See: http://jacklmoore.com/notes/ie-transparency-problems/
*/
.cboxIE #cboxTopLeft,
.cboxIE #cboxTopCenter,
.cboxIE #cboxTopRight,
.cboxIE #cboxBottomLeft,
.cboxIE #cboxBottomCenter,
.cboxIE #cboxBottomRight,
.cboxIE #cboxMiddleLeft,
.cboxIE #cboxMiddleRight {
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#00FFFFFF, endColorstr=#00FFFFFF);
}

.ico {
    display: inline-block;
    position: relative;
    background-image: url('../img/icon-se530d055c2.png');
    background-repeat: no-repeat;
    text-indent: 9999em;
    overflow: hidden;
}

.icon-arrow-down {
    background-position: 0 0;
    width: 24px;
    height: 24px;
}

.icon-arrow-down.centered {
    position: relative;
    left: 50%;
    margin-left: -12px;
}

.icon-arrow-right {
    background: url('../img/icon/icon-arrow_right_red.svg') no-repeat center;
    background-size: 18px;
    width: 20px;
    height: 20px;
}

.icon-arrow-right-grey {
    background: url('../img/icon/icon-arrow_right.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-arrow-up {
    background: url('../img/icon/icon-arrow-up.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-arrow-up.centered {
    position: relative;
    left: 50%;
    margin-left: -12px;
}

.icon-close {
    background-position: 0 -167px;
    width: 13px;
    height: 13px;
}

.icon-close.centered {
    position: relative;
    left: 50%;
    margin-left: -6.5px;
}

.icon-check-circle_20x20 {
    background: url("../img/icon/icon-check-circle_20x20.svg") no-repeat;
}

.icon-close-circle_20x20 {
    background: url("../img/icon/icon-close-circle_20x20.svg") no-repeat;
}

.icon-check-circle_20x20 span,
.icon-close-circle_20x20 span {
    padding-left: 24px;
}

.icon-connection {
    background-position: 0 -180px;
    width: 9px;
    height: 42px;
}

.icon-connection.centered {
    position: relative;
    left: 50%;
    margin-left: -4.5px;
}

.icon-direction-left {
    background-position: 0 -222px;
    width: 68px;
    height: 25px;
}

.icon-direction-left.centered {
    position: relative;
    left: 50%;
    margin-left: -34px;
}

.icon-direction-right {
    background-position: 0 -247px;
    width: 68px;
    height: 25px;
}

.icon-direction-right.centered {
    position: relative;
    left: 50%;
    margin-left: -34px;
}

.icon-euro-grey {
    background: url("../img/icon/icon-euro-grey.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-euro {
    background: url("../img/icon/icon-euro.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_1_klasse_medium {
    background-position: 0 -352px;
    width: 40px;
    height: 40px;
}

.icon-icon_1_klasse_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}

.icon-icon_2_klasse_medium {
    background-position: 0 -392px;
    width: 40px;
    height: 40px;
}

.icon-icon_2_klasse_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}

.icon-icon_ausrufezeichen_small {
    background: url("../img/icon/icon-icon_ausrufezeichen_small.svg") no-repeat center;
    background-position-x: -3px;
    width: 24px;
    height: 24px;
    top: -2px;
}

.icon-icon_remove {
    background: url("../img/icon/icon-icon_remove.svg") no-repeat center;
    background-position-x: -3px;
    width: 24px;
    height: 24px;
    top: -2px;
}

.icon-icon_bahn_bonus_punkte_large {
    background: url("../img/icon/icon-icon_bahn_bonus_punkte_large.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_brief_large {
    background: url("../img/icon/icon-icon_brief_large.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_drucker_large {
    background: url("../img/icon/icon-icon_drucker_large.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_check_small {
    background: url("../img/icon/icon-icon_check_small.svg") no-repeat center;
    background-position-x: -3px;
    width: 24px;
    height: 24px;   /* war: 24px. Aber dann ist es zu hoch innerhalb Text! */
    top: -2px;
}

.icon-icon_checkbox_small {
    background: url("../img/icon/icon_checkbox_enabled-unchecked.svg") no-repeat center;
}

.icon-icon_checkbox_mit_check_small {
    background: url("../img/icon/icon_checkbox_enabled-checked.svg") no-repeat center;
}

.icon-icon_city_ticket_large {
    background: url("../img/icon/icon-icon_city_ticket_large.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_city_ticket_medium {
    background: url("../img/icon/icon-icon_city_ticket_large.svg") no-repeat center;
    background-size: 40px;
    width: 56px;
    height: 56px;
}

.icon-icon_city_ticket_small {
    background: url("../img/icon/icon-icon_city_ticket_small.svg") no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_drucker_small {
    background-position: 0 -896px;
    width: 24px;
    height: 24px;
}

.icon-icon_drucker_small.centered {
    position: relative;
    left: 50%;
    margin-left: -12px;
}

.icon-icon_ecoupon_large {
    background: url("../img/icon/icon-icon_ecoupon_large.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_ecoupon_medium {
    background: url("../img/icon/icon-icon_ecoupon_medium.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_ecoupon_small {
    background: url("../img/icon/icon-icon_ecoupon_small.svg") no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_fahrradkarten_large {
    background: url("../img/icon/icon-icon_fahrradkarten_large.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_fahrradkarten_medium {
    background: url("../img/icon/icon-icon_fahrradkarten_medium.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_fahrradkarten_small {
    background: url("../img/icon/icon-icon_fahrradkarten_small.svg") no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_gepaeckregal_medium {
    background-position: 0 -1160px;
    width: 40px;
    height: 40px;
}

.icon-icon_gepaeckregal_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}

.icon-icon_gutschein_large {
    background: url("../img/icon/icon-icon_gutschein_large.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_gutschein_medium {
    background: url("../img/icon/icon-icon_gutschein_medium.svg") no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_gutschein_small {
    background: url("../img/icon/icon-icon_gutschein_small.svg") no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_reisender {
    background: url("../img/icon/icon-icon_reisender.svg") no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_drucker {
    background: url("../img/icon/icon-icon_drucker.svg") no-repeat center;
    width: 20px;
    height: 20px;
}

.icon-icon_handy_large {
    background-position: 0 -1320px;
    width: 56px;
    height: 56px;
}

.icon-icon_handy_large.centered {
    position: relative;
    left: 50%;
    margin-left: -28px;
}

.icon-icon_handybereich_medium {
    background-position: 0 -1376px;
    width: 40px;
    height: 40px;
}

.icon-icon_handybereich_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}

.icon-icon_handyverbot_medium {
    background-position: 0 -1416px;
    width: 40px;
    height: 40px;
}

.icon-icon_handyverbot_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}

.icon-icon_hotel_large {
    background-position: 0 -1456px;
    width: 56px;
    height: 56px;
}

.icon-icon_hotel_large.centered {
    position: relative;
    left: 50%;
    margin-left: -28px;
}

.icon-icon_hotel_small {
    background-position: 0 -1512px;
    width: 24px;
    height: 24px;
}

.icon-icon_hotel_small.centered {
    position: relative;
    left: 50%;
    margin-left: -12px;
}

.icon-icon_info_small {
    background: url('../img/icon/icon-icon_info_small.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_info_grey_small {
    background: url('../img/icon/icon-icon_info_grey_small.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_info_weiss_small {
    background: url('../img/icon/icon-icon_info_weiss_small.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_kalender_large {
    background: url('../img/icon/icon-icon_kalender_large.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_hotel_large {
    background: url('../img/icon/db_ic_seat_bed_24.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_kreditkarte_large {
    background: url('../img/icon/icon-icon_kreditkarte_large.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_kreditkarte_medium {
    background: url('../img/icon/icon-icon_kreditkarte_medium.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_kreditkarte_small {
    background: url('../img/icon/icon-icon_kreditkarte_small.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_meine_bahn_hinzufuegen_large {
    background-position: 0 -1816px;
    width: 56px;
    height: 56px;
}

.icon-icon_meine_bahn_hinzufuegen_large.centered {
    position: relative;
    left: 50%;
    margin-left: -28px;
}

.icon-icon_meine_bahn_large {
    background-position: 0 -1872px;
    width: 56px;
    height: 56px;
}

.icon-icon_meine_bahn_large.centered {
    position: relative;
    left: 50%;
    margin-left: -28px;
}

.icon-icon_newsletter_large {
    background-position: 0 -1928px;
    width: 56px;
    height: 56px;
}

.icon-icon_newsletter_large.centered {
    position: relative;
    left: 50%;
    margin-left: -28px;
}

.icon-icon_paypal {
    background: url('../img/icon/zahlungsmittel_paypal.svg') no-repeat center;
    width: 68px;
    height: 39px;
}

.icon-icon_paypal_small {
    background: url('../img/icon/icon-icon_paypal_small.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_pfeil_nach_links_medium {
    background-position: 0 -2064px;
    width: 40px;
    height: 40px;
}

.icon-icon_pfeil_nach_links_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}

.icon-icon_pfeil_nach_rechts_medium {
    background-position: 0 -2104px;
    width: 40px;
    height: 40px;
}

.icon-icon_pfeil_nach_rechts_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}


.icon-icon_verbindung_start {
    background: url('../img/icon/icon_start.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_verbindung_ziel {
    background: url('../img/icon/icon_ziel.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_pfeil_verbindung_small {
    background-position: 0 -2150px;
    width: 24px;
    height: 12px;
    top: 1px;
}

.icon-icon_pfeil_verbindung_small.centered {
    position: relative;
    left: 50%;
    margin-left: -12px;
}

.icon-icon_preis_grau_medium {
    background-position: 0 -2168px;
    width: 40px;
    height: 40px;
}

.icon-icon_preis_grau_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}

.icon-icon_preis_weiss_medium {
    background-position: 0 -2208px;
    width: 40px;
    height: 40px;
}

.icon-icon_preis_weiss_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}

.icon-icon_reiseplan_large {
    background: url('../img/icon/icon-icon_reiseplan_large.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_reiseversicherung_large {
    background: url('../img/icon/icon-icon_reiseversicherung_large.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_reiseversicherung_medium {
    background: url('../img/icon/icon-icon_reiseversicherung_medium.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_reiseversicherung_small {
    background: url('../img/icon/icon-icon_reiseversicherung_small.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_rollstuhlplatz_medium {
    background-position: 0 -2584px;
    width: 40px;
    height: 40px;
}

.icon-icon_rollstuhlplatz_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}

.icon-icon_ruhewagen_medium {
    background-position: 0 -2624px;
    width: 40px;
    height: 40px;
}

.icon-icon_ruhewagen_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}

.icon-icon_schliessen_small {
    background-position: 0 -2664px;
    width: 24px;
    height: 24px;
}

.icon-icon_schliessen_small.centered {
    position: relative;
    left: 50%;
    margin-left: -12px;
}

.icon-icon_sitzplatz_grau_large {
    background: url('../img/icon/icon-icon_sitzplatz_grau_large.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_sitzplatz_grau_medium {
    background: url('../img/icon/icon-icon_sitzplatz_grau_medium.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-reservierungsempfehlung {
    position: absolute;
    background-image: url('../img/icon/icon_res_auslastungsanzeige.svg');
    background-repeat: no-repeat;
    background-size: 30px;
    width: 30px;
    height: 30px;
    top: 20%;
    left: -70px;
}

.icon-icon_sitzplatz_small {
    background: url('../img/icon/icon-icon_sitzplatz_small.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_sofort_ueberweisung {
    background: url('../img/icon/zahlungsmittel_sofortueberweisung.svg') no-repeat center;
    width: 68px;
    height: 39px;
}

.icon-icon_andere_person {
    background: url('../img/icon/icon-icon_andere_person.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_trash_grey {
    background: url(../img/icon/icon-trash-grey.svg) no-repeat center;
    position: absolute;
    width: 20px;
    height: 20px;
    margin-left: -20px;
}

.icon_delete_grey {
    position: absolute;
    top: 12px;
    width: 18px;
    height: 20px;
    background-image: url('../img/delete_18x20.png');
}

.icon-icon_tickets_large {
    background: url('../img/icon/icon-icon_tickets_large.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_tickets_medium {
    background: url('../img/icon/icon-icon_tickets_medium.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

/* Für Onlineticket */
.icon-icon_tickets_small {
    background: url('../img/icon/icon-icon_tickets_small.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_tisch_medium {
    background-position: 0 -3048px;
    width: 40px;
    height: 40px;
}

.icon-icon_tisch_medium.centered {
    position: relative;
    left: 50%;
    margin-left: -20px;
}

.icon-icon_versandpauschale_medium {
    background: url('../img/icon/icon-icon_versandpauschale_medium.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_versandpauschale_small {
    background: url('../img/icon/icon-icon_versandpauschale_small.svg') no-repeat center;
    width: 24px;
    height: 24px;
}

.icon_glocke_grau {
    background: url('../img/icon/icon-glocke_grau.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_weitere_buchungen_large {
    background: url('../img/icon/icon-icon_weitere_buchungen_large.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_weitere_buchungen_large.centered {
    position: relative;
    left: 50%;
    margin-left: -28px;
}

.icon-plus {
    background-position: 0 -3400px;
    width: 23px;
    height: 23px;
}

.icon-plus.centered {
    position: relative;
    left: 50%;
    margin-left: -11.5px;
}

.icon-star {
    background-position: 0 -3423px;
    width: 20px;
    height: 20px;
}

.icon-star.centered {
    position: relative;
    left: 50%;
    margin-left: -10px;
}

.icon-trash {
    background-position: 0 -3443px;
    width: 24px;
    height: 24px;
}

.icon-trash.centered {
    position: relative;
    left: 50%;
    margin-left: -12px;
}

.ico.icon-edit{
    background: url("../img/icon/icon-edit.svg") no-repeat center;
    width: 24px;
    height: 24px;
}

/* Transportmittel */
.icon-icon_transportation_unknown {
    background: url('../img/icon/icon_transportation_rb.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_sch {
    background: url('../img/icon/icon_transportation_sch.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_air {
    background: url('../img/icon/icon_transportation_air.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_ec {
    background: url('../img/icon/icon_transportation_ec.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_ic {
    background: url('../img/icon/icon_transportation_ic.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_ice,
.icon-icon_transportation_tgd,
.icon-icon_transportation_tgv,
.icon-icon_transportation_rht,
.icon-icon_transportation_tha {
    background: url('../img/icon/icon_transportation_ice.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_rb {
    background: url('../img/icon/icon_transportation_rb.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_re {
    background: url('../img/icon/icon_transportation_re.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_s {
    background: url('../img/icon/icon_transportation_s.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_str {
    background: url('../img/icon/icon_transportation_str.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_u {
    background: url('../img/icon/icon_transportation_u.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_bus {
    background: url('../img/icon/icon_transportation_bus.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_transportation_exb,
.icon-icon_transportation_kxb,
.icon-icon_transportation_fbu,
.icon-icon_transportation_icb,
.icon-icon_transportation_ebu {
    background: url('../img/icon/icon_transportation_icbus.svg') no-repeat center;
    background-size: 20px;
    width: 20px;
    height: 20px;
}

.icon-icon_ticket_bahncard {
    background: url('../img/icon/icon-icon_ticket_bahncard.svg') no-repeat center;
    width: 56px;
    height: 56px;
}

.icon-icon_reservierung_inklusive {
    background: url("../img/icon/24dp_icon_seat-reservation_grey400.svg") no-repeat center;
    width: 24px;
    height: 24px;
}

.icon-icon_action_shedule {
    background-image: url("../img/icon/20dp_icon_action_schedule.svg");
    background-repeat: no-repeat;
    width: 20px;
    height: 20px;
}

.icon-icon_traveller {
    background: url(../img/icon/20dp_icon_action_account-solid.svg);
    background-repeat: no-repeat;
    width: 20px;
    height: 20px;
}

/***********************************************
 TODO afm-1042 Sollten wir nicht verwenden bzw. im Namen den Zweck
 statt konkreter Pixelangaben
 */

.container-90 {
    width: 90px;
}

.container-110 {
    width: 110px;
}

.container-120 {
    width: 120px;
}

.container-140 {
    width: 140px;
}

.container-220 {
    width: 220px;
}

.container-200 {
    width: 200px;
}

.container-260 {
    width: 260px;
}

.container-300 {
    width: 300px;
}

.container-320 {
    width: 320px;
}

.container-360 {
    width: 360px;
}

.container-380 {
    width: 380px;
}

.container-460 {
    width: 460px;
}

.container-520 {
    width: 520px;
}

.container-560 {
    width: 560px;
}

.container-580 {
    width: 580px;
}

.container-600 {
    width: 600px;
}

.container-700 {
    width: 700px;
    margin-left: 20px;
}

.container-800 {
    width: 800px;
}

.container-900 {
    width: 900px;
    margin-left: 40px;
}

.container-940 {
    width: 940px;
    margin-left: 20px;
}

.container-980 {
    width: 980px;
}

/*******************************/

h1, h2, h3, h4, h5 {
    color: #282D37;
}

h1.success, h2.success, h3.success, h4.success, h5.success {
    color: #63A615;
}

h2, .h2 {
    font-size: 1.625em;
    /*font-size: calculateRem($size) */
    line-height: 32px;
}

h3, .h3 {
    font-size: 1.125em;
    /*font-size: calculateRem($size) */
    line-height: 26px;
    margin: 25px 0 16px 0;
}

h3 ~ a.form-link {
    margin: 33px 0 20px 0;
}

h3 ~ div.input-link {
    margin: 33px 0 20px 0;
}

h3.w-full {
    width: 100%;
}

h4, .h4 {
    font-size: 1em;
    /*font-size: calculateRem($size) */
    line-height: 22px;
    margin: 0;
}

h5, .h5 {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 20px;
}

em {
    font-weight: normal;
    font-style: italic;
}

b {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

html input.placeholder-replacement, html textarea.placeholder-replacement {
    color: #aaa;
}

/* old icons */
.ico.icon-down {
    background: url("../img/icon/pfeil_unten_grau.svg") no-repeat center;
    height: 24px;
    width: 24px;
}

.ico.icon-up {
    background: url("../img/icon/pfeil_oben_grau.svg") no-repeat center;
    height: 24px;
    width: 24px;
}

.ico.icon-up-red {
    background: url("../img/icon/pfeil_oben_rot.svg") no-repeat center;
    height: 24px;
    width: 24px;
}

.ico.arrow-red-big {
    width: 15px;
    height: 13px;
    background: url("../img/placeholder/icon-sprite.png") -2px -635px no-repeat;
}

section {
    position: relative;
    width: 100%;
    margin: 0 0 10px 0;
    padding: 0;
    border: 0;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border-radius: 4px;
}

section header {
    padding: 25px 0 16px 0;
    border-radius: 4px 4px 0 0;
}

section header h2, section header h3 {
    font-size: 1.125em;
    /*font-size: calculateRem($size) */
    line-height: 26px;
    margin: 0;
    max-width: 620px;
}

section header a.form-link {
    margin: 7px 0 0;
}

section main {
    background: #ffffff;
    position: relative;
    overflow: hidden;
    border-radius: 4px;
}

section.w-340 {
    position: relative;
    width: 340px;
}

section.no-margin {
    margin: 0 !important;
}

section.options {
    overflow: visible;
    margin: 24px 0 30px 0;
    background: transparent !important;
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
}

section.disabled {
    pointer-events: none;
}

section.disabled .fs-header {
    opacity: 0.5;
    filter: alpha(opacity=50);
}

section.disabled .fs-header input[type="radio"] + label {
    background: url("../img/icon/icon_radio_unselected_default.svg") no-repeat 16px center !important;
}

section.disabled .fs-content {
    display: none;
}

section.disabled .hint {
    position: absolute;
    top: 0;
    right: 0;
    padding: 22px 25px 25px 50px;
    width: 300px;
    height: 100%;
    background: #ffffff;
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 16px;
    opacity: 1;
    filter: alpha(opacity=100);
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

/* Text-Position neben dem Icon */
section.disabled .hint span {
    position: relative;
    top: 30%;
}

section.disabled .hint span.post-disable {
    top: -2%;
}

section.disabled .hint .ico.icon-icon_info_small {
    position: absolute;
    top: 50%;
    left: 20px;
    margin-top: -12px;
}

section h3 {
    margin: 25px 0;
}

section .w-full {
    position: relative;
    width: 100%;
    background: white;
    border-radius: 4px;
}

section .w-320 {
    position: relative;
    width: 320px;
    float: left;
    background: white;
    border-radius: 4px;
}

section .w-380 {
    position: relative;
    width: 380px;
    float: left;
    background: white;
    border-radius: 4px;
}

section .w-480 {
    position: relative;
    width: 480px;
    float: left;
    background: white;
    border-radius: 4px;
}

section .w-660 {
    position: relative;
    width: 660px;
    float: left;
    background: white;
    border-radius: 4px;
}

section .w-720 {
    position: relative;
    width: 720px;
    float: left;
    background: white;
    border-radius: 4px;
}

section .item {
    position: relative;
    padding: 0 30px 10px 80px;
}

section .item:last-of-type {
    padding-bottom: 35px;
}

section .item.border-top {
    border-top: 1px solid #E7E7E7;
}

section .item.green {
    color: #63A615;
}

section .item.regular {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 20px;
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}

section .item.move-up-10 {
    margin-top: -10px;
}

section .item h4 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    padding: 15px 0;
}

section .item .ico {
    position: absolute;
    top: -2px;
    left: 0;
}

section .item .has-overlay,
section .item .no-overlay {
    position: absolute;
    top: 10px;
    right: 10px;
    padding: 10px;
}

section .item .has-overlay .ico,
section .item .no-overlay .ico {
    position: relative;
    top: 0;
}

section .item .item-header {
    position: relative;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 20px;
    padding: 0 0 0 27px;
}

section .item .item-header.regular {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}

section .item .item-list {
    margin: 0;
    padding: 0;
}

section .item .item-list.middle li {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 20px;
}


section .item .item-list li {
    position: relative;
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 16px;
    padding: 0 0 10px 26px;
}

section .item p {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 22px;
    margin: -5px 0 0 0;
    padding: 0;
}

section.additional-statements .flex-container {
    display: flex;
    padding: 20px;
    border-bottom: 1px solid #E7E7E7;
}

section.additional-statements.registrierung.readonly .flex-container {
    padding: 20px 20px 0 20px;
    border-bottom: none;
}

section.additional-statements.registrierung.readonly .flex-container:last-child {
    padding: 20px;
}

.content.bestaetigung section.additional-statements.registrierung.readonly .flex-container:first-child {
    padding-top: 20px;
}

.content.bestaetigung section.additional-statements.registrierung.readonly .flex-container,
.content.bestaetigung section.additional-statements.registrierung.readonly .flex-container:last-child {
    padding-top: 12px;
}

section.additional-statements .flex-container.no-border,
section.additional-statements .flex-container:last-child {
    border: none;
}

section.additional-statements .flex-container .flex-container-title {
    width: 250px;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    flex-shrink: 0;
}

section.additional-statements.bahncard .flex-container .flex-container-title {
    width: 305px;
    flex-shrink: 0;
}

section.additional-statements.registrierung.readonly .flex-container .flex-container-title {
    font-size: 0.875em;
}

section.additional-statements .flex-container .flex-container-data {
    position: relative;
    display: flex;
    flex-grow: 1;
    width:  75%;
    font-size: 0.875em;
}

section.additional-statements .flex-container .flex-container-data.zahlungsdaten {
    flex-wrap: wrap;
}

section.additional-statements .flex-container .flex-container-data .data-column {
    padding: 0 8px 0 0;
    width: 40%;
    flex-grow: 1;
    word-wrap: break-word;
}

section.additional-statements .flex-container .flex-container-data .data-column:nth-of-type(2) {
    width: 40%;
    padding-right: 36px;
}

section.additional-statements .flex-container.geburtsdatum .flex-container-data span {
    display: block;
}

section.additional-statements .flex-container.geburtsdatum .flex-container-data span:not(:first-child) {
    padding-top: 8px;
}

section.additional-statements .flex-container .flex-container-data .data-column.price {
    text-align: right;
    padding-right: 0;
}

section.additional-statements .flex-container .flex-container-data .data-column.zahlungsdaten-hinweis {
    width: 100%;
    padding-right: 36px;
}

section.additional-statements .flex-container .flex-container-data .data-column.zahlungsdaten-hinweis span {
    display: block;
}

section.additional-statements .flex-container .flex-container-data .data-column.zahlungsdaten-hinweis span:not(:first-child) {
    padding-top: 8px;
}

section.additional-statements .flex-container.teaser .flex-container-title a.toggle.clearfix {
    display: none;
}

section.additional-statements .flex-container .flex-container-data .edit-icon {
    position: absolute;
    top: 0;
    right: 0;
}

section.bahnbonus .bb-section .bb-input {
    margin: 15px 0 10px 0;
}

section.buy-it .total {
    padding-bottom: 19px;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 1.125em;
}

section.buy-it .total .text {
    position: relative;
    padding: 0 0 0 42px;
}

section.buy-it .total .price {
    padding-left: 52px;
}

section.buy-it .total .text .ico {
    position: absolute;
    top: -2px;
    left: 0;
}

section.buy-it.options .transportation-terms label {
    font-size: 0.75em;
    margin: 0 10px 0 0;
    padding: 7px 0 5px 49px;
}

section.buy-it.options .transportation-terms label a {
    font-size: 1em;
    text-decoration: underline;
}

section.buy-it.options .red {
    color: #C50014;
}

section.buy-it.options .btn:not(:last-child) {
    margin-right: 10px;
}

.captcha {
    margin: 25px 0 0 0;
}

.captcha h4 {
    margin-bottom: 20px;
}

.captcha img {
    margin-right: 20px;
}

section.code .ec-section {
    margin: 10px 56px 0 140px;
}

section.code .ec-section p,
section.ecoupon p.ecoupon,
section.bahnbonus p {
    max-width: 540px;
}

section.code .ec-section .ec-wrapper,
section.code .ec-section .ec-inputs {
    margin-top: 20px;
}

section.code .ec-section .ec-wrapper .ec-input,
section.code .ec-section .ec-inputs .ec-input {
    width: 220px;
    margin-right: 20px;
    position: relative;
}

section.code .ec-section .ec-wrapper .ec-input .input-overlay,
section.code .ec-section .ec-inputs .ec-input .input-overlay {
    background: #fff;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    display: none;
}

section.code .ec-section .ec-wrapper .ec-input .input-overlay .value,
section.code .ec-section .ec-inputs .ec-input .input-overlay .value {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 18px;
    color: #63A615;
    display: block;
    padding: 7px 9px 5px;
}

section.code .ec-section .ec-wrapper .ec-submit {
    margin-right: 30px;
    margin-top: 25px;
}

section.code .ec-section .ec-wrapper .ec-status {
    margin-top: 25px;
}

section.code .ec-section .ec-wrapper .ec-status .ico {
    top: 6px;
}

section.code .ec-section .ec-wrapper .ec-status h5 {
    margin: 0;
}

section.code .ec-section .ec-inputs {
    width: 220px;
}

section.code .ec-section .ec-inputs label {
    display: none;
}

section.code .ec-section .ec-inputs .ec-input:first-of-type label {
    display: block;
}

section.code .ec-section .ec-inputs .ec-input.valid input {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 18px;
    color: #63A615;
}

section.code .ec-section .ec-inputs .ec-input.valid .input-overlay {
    display: block;
}

section.code .ec-section .code-wrapper {
    position: relative;
}

section.code .ec-section .code-wrapper .ec-submit {
    position: absolute;
    bottom: 0;
    right: -145px;
    top: 24px;
}

section.code .ec-section .ec-more a {
    font-size: 0.875em;
}

section.code .ec-section .ec-more a i {
    margin: 0 5px -6px 0;
}

section.code .ec-section .ec-more a:hover {
    text-decoration: none;
}

section.code .ec-section .ec-more a:hover span {
    text-decoration: underline;
}

div.confirmation-header {
    display: flex;
    margin-top: 32px;
}

div.confirmation-header-box {
    border-radius: 4px;
    flex-grow: 1;
    width: 50%;
    background: #ffffff;
    -webkit-box-shadow: none;
    box-shadow: none;
}

div.confirmation-header-box section {
    margin: 16px 0;
}

div.confirmation-header-ticket div {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

div.confirmation-header-ticket div.text span {
    width: 100%;
    text-align: center;
}

div.confirmation-header-ticket .ticket div.visual .ticket_confirmation {
    background: url("../img/icon/ticket_digital.svg") no-repeat center;
    height: 64px;
    width: 64px;
}

div.confirmation-header-ticket .ticket div.visual .geschenkgutschein_confirmation {
    background: url("../img/icon/giftcard_64x64.svg") no-repeat center;
    height: 64px;
    width: 64px;
}

div.confirmation-header-ticket .ticket div.visual .reiseversicherung_confirmation {
    background: url("../img/icon/icon_insurance_64x64.svg") no-repeat center;
    height: 64px;
    width: 64px;
}

div.confirmation-header-ticket .reservierung div.visual .ticket_confirmation {
    background: url("../img/icon/icon_reservierung_xlarge.svg") no-repeat center;
    height: 64px;
    width: 64px;
}

div.confirmation-header-ticket div.text .line-1,
div.confirmation-header-ticket div.text .order {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

div.confirmation-header-ticket div.text .line-1 {
    margin-bottom: 16px;
}

div.confirmation-header-ticket div.text .line-1 .icon-icon_check_small {
    top: 6px;
}

div.confirmation-header-ticket div.text .order {
    margin-top: 4px;
}

div.confirmation-header-ticket span.versand-info {
    font-size: 0.875em;
    line-height: 1.5em;
    text-align: center;
    padding-top: 16px;
    color: #878C96;
}

div.confirmation-header-ticket span.versand-info.bc-versand {
    max-width: 700px;
}

div.confirmation-header-hrs-container {
    margin-left: 8px;
}

div.confirmation-header-hrs-container div {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

div.confirmation-header-hrs-container div.button-and-text {
    padding-top: 8px;
}

div.confirmation-header-hrs-container div.button-and-text span {
    width: 100%;
    text-align: center;
}

div.confirmation-header-hrs-container div.aufklappbereich .button-section {
    padding-top: 16px;
}

div.confirmation-header-hrs-container a.toggle.clearfix {
    display: none;
}

div.confirmation-header-hrs-container div.hrsbanner-visual .icon_hrsbanner {
    background: url("../img/placeholder/HRS_Color_sRGB.svg") no-repeat center;
    background-size: contain;
    width: 138px;
    height: 64px;
}

section.customer-data .c-data h4 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    margin: 0 0 15px 0;
}

section.customer-data .c-data .grid-wrapper-3 {
    margin: 16px;
}

section.customer-data .edit-icon {
    position: absolute;
    right: 16px;
}

section.customer-data .fs-header .edit-icon {
    right: 80px;
    top: 24px;
}

section.customer-data .c-data .grid-wrapper-3 .grid {
    width: 33.3%;
    padding-right: 20px;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    word-wrap: break-word;
}

section.customer-data p.data {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 22px;
}

section.header {
    padding: 28px 20px 12px 20px;
    margin: 0;
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
}

section.header h3 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
}

section.header h3.font-normal {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    font-weight: normal;
    font-style: normal;
}

section.header.grey {
    background: #F0F3F5;
}

section.header.img {
    padding: 0;
}

section.header h1, section.header h2, section.header h3, section.header h4, section.header p, section.header div {
    margin: 0;
    padding: 0 0 20px 0;
    max-width: 620px;
}

section.header h1:last-child, section.header h2:last-child, section.header h3:last-child, section.header h4:last-child, section.header p:last-child, section.header div:last-child {
    padding-bottom: 0;
}

section.header h1.no-padding, section.header h2.no-padding, section.header h3.no-padding, section.header h4.no-padding, section.header p.no-padding, section.header div.no-padding, section .fieldset-inner.no-padding {
    padding-bottom: 0;
}

section.header .error-container {
    margin-bottom: 3px;
}

section.header p {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 22px;
    padding-top: 0;
}

label.flex-icon-title {
    display: flex;
    align-items: center;
    padding: 15px 30px 15px 18px;
}

section.kreditkarte .creditcard-type {
    margin-bottom: 25px;
}

section.kreditkarte .creditcard-type ul.cc-chooser {
    margin: 0;
    padding: 0;
}

section.kreditkarte .creditcard-type ul.cc-chooser li {
    margin: 0 20px 0 0;
    padding: 0;
    float: left;
    max-height: 39px; /* wegen JCB-Icon, kann nach Ausbau weg */
}

section.kreditkarte a.form-link {
    display: block;
    margin: 8px 0 8px 20px;
}

section.kreditkarte a.form-link.no-margin-left {
    display: inline-block;
    margin-left: 0;
}

section.lastschrift fieldset .fs-content table {
    margin: -8px 0 20px 0;
    font-size: 1em;
    /*font-size: calculateRem($size) */
    line-height: 26px;
}

section.lastschrift fieldset .fs-content table tr td {
    min-width: 140px;
    padding: 5px 0;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

section.lastschrift fieldset .fs-content ul.block-list {
    margin-bottom: 20px;
}

section.lastschrift fieldset .fs-content p {
    margin: 0 0 10px 0;
}

section.lastschrift fieldset .fs-content p:first-child {
    margin: 0 0 20px;
}

section.lastschrift fieldset .fs-content img {
    margin-right: 20px;
}

section.lastschrift fieldset .fs-content .form-link {
    display: block;
    margin-top: 20px;
}

section.login {
    padding: 20px;
}

section.login .button-abschnitt {
    margin-top: 20px;
}

section.login h4 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    padding-bottom: 15px;
    padding-right: 30px;
}

section.login input[type='checkbox'] + label, section.login input[type='checkbox']:checked + label,
section.registrierung input[type='checkbox'] + label, section.registrierung input[type='checkbox']:checked + label {
    margin: 10px 0 10px 20px;
    width: auto;
    padding-right: 50px;
}

section.next-steps main {
    background: none;
    margin: -10px -10px -10px;
}

section.next-steps ul {
    display: flex;
    flex-wrap: wrap;
}

section.next-steps ul li {
    margin: 10px;
    width: calc(100%/3 - 20px);
    min-height: 64px;
    float: left;
    display: table;
    background: #fff;
    border-radius: 4px;
}

section.next-steps .link-wrapper {
    padding: 15px 12px 15px 56px;
    position: relative;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-size: 0.875em;
    line-height: 22px;
    display: table-cell;
    vertical-align: middle;
    height: 100%;
}

section.next-steps .link-wrapper .ico {
    position: absolute;
    top: 50%;
    left: 0;
    margin-top: -28px;
}

section.next-steps .link-wrapper .link {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 1em;
    white-space: normal;
    text-align: left;
}

section.online-ticket fieldset .fs-content fieldset {
    margin: 10px 0 25px 0;
}

/* tprb: postcontent für die Legende. Im Styleguide hat die Legende immer mit Schatten, d.h. mit dem Klickdummy abweichen.  */
section.postcontent {
    position: relative;
    background: white;
    padding: 15px 40px 25px;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

section.postcontent > h1, section.postcontent h2, section.postcontent h3, section.postcontent h4 {
    margin: 0 0 15px 0;
}

section.postcontent p, section.postcontent ul {
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 18px;
}

section.postcontent ul {
    margin-bottom: -16px;
}

section.postcontent li {
    position: relative;
    padding-left: 33px;
    padding-bottom: 10px;
    height: 24px;
}

section.postcontent li .ico {
    position: absolute;
    left: 0;
    top: -4px;
}

section.postcontent .form-link {
    margin-top: 11px;
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 18px;
}

section.procedure {
    margin-top: 12px;
}

section.procedure main {
    width: 100%;
    padding: 0 20px 20px 20px;
}

section.procedure .visual {
    width: 100%;
    padding-top: 20px;
}

section.procedure .visual > .ico {
    float: left;
    width: 104px;
    height: 64px;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: 140px 140px;
    -moz-background-size: 140px 140px;
    -o-background-size: 140px 140px;
    -webkit-background-size: 140px 140px;
}

section.procedure .visual > .ico.no-margin-left {
    margin-left: 0;
}

section.procedure .visual .ico.oeffnen {
    background: url("../img/icon/ticket_oeffnen.svg") no-repeat center;
}
section.procedure .visual .ico.mot_laden {
    background: url("../img/icon/handyticket_runterladen_xlarge.svg") no-repeat center;
}
section.procedure .visual .ico.versand {
    background: url("../img/icon/in_bearbeitung_xlarge.svg") no-repeat center;
}
section.procedure .visual .ico.reservierung {
    background: url("../img/icon/ticket_oeffnen.svg") no-repeat center;
}
section.procedure .visual .ico.drucken {
    background: url("../img/icon/ticket_ausdrucken.svg") no-repeat center;
}
section.procedure .visual .ico.laden {
    background: url("../img/icon/handyticket_runterladen_xlarge.svg") no-repeat center;
}
section.procedure .visual .ico.versand_erhalten {
    background: url("../img/icon/ticketsendung_erhalten_xlarge.svg") no-repeat center;
}
section.procedure .visual .ico.res_drucken {
    background: url("../img/icon/ticket_ausdrucken.svg") no-repeat center;
}
section.procedure .visual .ico.olt_ausweis {
    background: url("../img/icon/ticket_ausweiss.svg") no-repeat center;
}
section.procedure .visual .ico.olt_bc {
    background: url("../img/icon/online_ticket_bahncard_xlarge.svg") no-repeat center;
}
section.procedure .visual .ico.ticket {
    background: url("../img/icon/ticket_xlarge.svg") no-repeat center;
}
section.procedure .visual .ico.ticket_ausdrucken {
    background: url("../img/icon/ticket_ausdrucken.svg") no-repeat center;
}
section.procedure .visual .ico.ticket_ausweis {
    background: url("../img/icon/ticket_ausweiss.svg") no-repeat center;
}
section.procedure .visual .ico.ticket_handy_qrcode {
    background: url("../img/icon/handy_qr_code.svg") no-repeat center;
}
section.procedure .visual .ico.ticket_oeffnen {
    background: url("../img/icon/ticket_oeffnen.svg") no-repeat center;
}
section.procedure .visual .ico.digiabo {
    background: url("../img/icon/digiabo_in_bearbeitung_xlarge.svg") no-repeat center;
}
section.procedure .visual .ico.digiabo_navigator_einloggen {
    background: url("../img/icon/digiabo_navigator_einloggen_xlarge.svg") no-repeat center;
}
section.procedure .visual .ico.digiabo_ticket_aktualisieren {
    background: url("../img/icon/digiabo_ticket_aktualisieren_xlarge.svg") no-repeat center;
}

section.procedure .step {
    float: left;
    width: 33.3333%;    /* calc(33.3333% - 60px) nicht notwendig da wir in webclient-touch.css box-sizing: inherit; nutzen */
    text-align: center;
}

section.procedure .step.span-zweidrittel {
    width: 66.6666%;
    text-align: left;
    padding-left: 0;
}

section.procedure .step h3 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 1em;
    margin: 0 0 20px;
}

section.procedure .step p {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 18px;
    margin: 18px 0;
}

/** Bold bleibt bold! */
section.procedure .step b {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
}

section.procedure .step .format {
    white-space: nowrap;
}

section.procedure .step ul {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 18px;
}

section.procedure .step ul li {
    position: relative;
    padding: 8px 0 0 30px;
    text-align: left;
}

section.procedure .step.span-zweidrittel ul li {
    position: relative;
    padding: 4px 0 0 30px;
    text-align: left;
    line-height: 20px;
    margin-bottom: 8px;
}

section.procedure .step.span-zweidrittel ul li:last-child {
    margin-bottom: 0;
}

section.procedure .step ul li .ico {
    position: absolute;
    left: 0;
    top: 4px;
}

section.procedure .step .btn {
    margin: 15px 0 0;
}

section.procedure .step ul {
    font-size: 0.875em;
}

section.procedure .flex-container-steps {
    display: flex;
}

section.procedure .flex-container-steps .bst.step {
    flex-grow: 1;
    text-align: left;
    padding: 20px 0 0;
}

section.procedure .flex-container-steps .bst.step p {
    margin: 0;
}

section.procedure .flex-container-steps .step {
    width: 33.33%;
    text-align: center;
    padding: 0 16px;
}

section.procedure .flex-container-steps .step ul {
    text-align: left;
}

section.procedure .flex-container-steps .step-icon  {
    padding-top: 0;
}

section.procedure .flex-container-steps .step-icon .ico {
    width: 100%;
    height: 104px;
}

section.product main {
    padding: 20px 20px 30px;
}

section.product .left-column {
    width: 260px;
    float: left;
}

section.product .left-column img + h3 {
    margin-top: 20px;
}

section.product .right-column {
    width: 540px;
    margin: 0 0 0 40px;
    padding: 10px 0 0;
    float: left;
}

section.product .hotel-class {
    display: block;
    margin: 0 0 16px;
}

section.product h3 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 1em;
    /*font-size: calculateRem($size) */
    line-height: 18px;
    margin: 0 0 24px;
}

section.product p + h3 {
    margin-top: 30px;
}

section.product dl, section.product p {
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 18px;
    margin: 0 0 24px;
}

section.product dl:last-child, section.product p:last-child {
    margin: 0;
}

section.product dt, section.product dd {
    display: inline;
    margin: 0;
}

section.product dl.term-highlighted dt {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    display: inline-block;
    width: 140px;
}

section.product .btn {
    margin: 6px 0 0;
}

section.product .small-print {
    color: #878c96;
    margin: 30px 0 0 !important;
}

section.product footer {
    padding: 0 20px;
    background: #E7E7E7;
    height: 40px;
    line-height: 40px;
}

section.product footer .price {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    position: relative;
}

section.product footer .price .ico {
    position: absolute;
    top: 8px;
    left: -30px;
}

div.warenkorb-layer section,
div.pruefen-buchen section {
    -webkit-box-shadow: none;
    box-shadow: none;
}

div.pruefen-buchen section.bx-shadow {
    margin: 30px 0;
}

div.pruefen-buchen section.agb.bx-shadow {
    margin: 16px 0;
}

div.pruefen-buchen section.bx-shadow fieldset .fs-header h4 {
    margin: 0;
}

section.registrierung .fieldset-inner {
    padding: 30px 80px 22px 80px;
}

.kaufbeleg section.registrierung .fieldset-inner {
    padding-top: 10px;
}

section.registrierung .fieldset-inner.border-top {
    border-top: 1px solid #e7e7e7;
}

section.registrierung .fieldset-inner p {
    display: block;
    padding-bottom: 5px;
}

section.registrierung .item .item-header ~ ul.item-list li {
    padding-left: 35px;
}

section.reiseversicherung .fieldset-inner {
    padding: 30px 30px 22px 30px;
}

section.reiseversicherung fieldset .fs-content {
    padding-right: 20px;
}

section.reiseversicherung fieldset .fs-content label a.form-link, section.reiseversicherung fieldset .fs-content p a.form-link {
    font-size: 1em;
    /*font-size: calculateRem($size) */
    line-height: 1em;
    display: inline-block;
}

section.reiseversicherung fieldset .fs-content label span:nth-child(2),
section.reiseversicherung fieldset .fs-content p span:nth-child(2){
    display: block;
    padding-top: 7px;
    padding-bottom: 7px;
}

.reiseversicherung-layer-link {
    position: relative;
    top: 6px;
    left: 8px;
}

section.reservierungs-details.disabled,
section.reservierungs-details.disabled h4,
section.reservierungs-details.disabled fieldset .fs-sidebar {
    color: #878c96;
}

section.reservierungs-details.disabled .ico {
    opacity: 0.6;
}

section.reservierungs-details .grid-wrapper-4, section.reservierungs-details .grid-wrapper-3 {
    margin: 0 80px;
}

section.reservierungs-details .fs-header {
    border-bottom: 1px solid rgba(40,45,55,0.2);
    border-radius: 4px 4px 0 0;
}

section.reservierungs-details .fs-header .respflicht {
    padding: 16px 0 0 140px;
}

section.reservierungs-details .rd-connection {
    padding: 16px 0 16px 140px;
    font-size: 0.875em;
    line-height: 20px;
}

section.reservierungs-details .fs-header .form-link {
    line-height: 22px;
}

section.reservierungs-details .fs-header label {
    position: relative;
    display: inline-block;
    padding: 16px 0 16px 50px;
}

section.reservierungs-details .fs-header label .ico {
    position: absolute;
    top: 50%;
    margin-top: -28px;
    left: 8px;
}

section.reservierungs-details .verbindung-start,
section.reservierungs-details .verbindung-end {
    position: relative;
    padding-right: 20px;
}

section.reservierungs-details .verbindung-start {
    padding-bottom: 8px;
}

section.reservierungs-details .verbindung-start span.icon,
section.reservierungs-details .verbindung-end span.icon {
    display: block;
    position: relative;
}

section.reservierungs-details .verbindung-start span.icon i,
section.reservierungs-details .verbindung-end span.icon i {
    position: absolute;
    top: -2px;
}

section.reservierungs-details .verbindung-start span.label,
section.reservierungs-details .verbindung-end span.label {
    display: inline-block;
    padding-left: 32px;
}

section.reservierungs-details .rd-content table {
    margin: 0 56px 24px 140px;
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 20px;
}

section.reservierungs-details .rd-content table tr td {
    height: 29px;
    padding-left: 4px;
    vertical-align: top;
}

/*
section.reservierungs-details .rd-content table tr td .ico {
    top: 5px;
}
*/

section.reservierungs-details .rd-content table tr td.error {
    color: #C50014;
}

section.selection table {
    width: 100%;
}

section.selection table th, section.selection table td {
    vertical-align: top;
    padding: 17px 10px 27px;
    font-size: 0.875em;
    position: relative;
}

section.selection table th {
    text-align: left;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    padding-left: 57px;
    width: 24.468%;
}

section.selection table th .ico {
    position: absolute;
    top: 7px;
    left: 13px;
}

section.selection table .description {
    width: 59.574%;
}

section.selection table .description table th, section.selection table .description table td {
    line-height: 22px;
    padding: 0;
}

section.selection table .description table th {
    width: 140px;
    padding: 0 20px 0 0;
}

section.selection table .price {
    width: 15.974%;
    padding-right: 20px;
    text-align: right;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

section.selection table tfoot {
    background: #E7E7E7;
}

section.selection table tfoot th, section.selection table tfoot td {
    padding: 0 20px;
    height: 40px;
    line-height: 40px;
}

section.selection table tfoot th {
    font-size: 1em;
}

section.selection table tfoot .price {
    font-size: 1em;
}

section.selection table tfoot .price .ico {
    margin-bottom: -8px;
}

section.teasers main {
    background: none;
    width: 960px;
    margin: 0 -10px 20px;
}

section.teasers .teaser {
    width: 300px;
    float: left;
    background: #fff;
    margin: 0 10px;
}

section.teasers .teaser .text {
    padding: 0 20px 16px;
}

section.teasers .teaser .text h4 {
    margin: 16px 0;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

section.teasers .teaser .text a {
    font-size: 0.75em;
}

section.teasers-big {
    margin: 0 0 20px;
}

section.teasers-big .red {
    color: #C50014;
}

section.teasers-big .teaser {
    position: relative;
    background: #ffffff;
    margin-bottom: 16px;
    border-radius: 4px;
}

section.teasers-big .teaser:last-child {
    margin-bottom: 0;
}

section.teasers-big .teaser .preview .toggle, section.teasers-big .teaser .preview .no-toggle {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    font-size: 1em;
}

section.teasers-big.kundenbindung .teaser .preview .no-toggle {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    display: flex;
    width: 100%;
    height: 100%;
    font-size: 1em;
}

section.teasers-big .teaser .preview .text {
    float: left;
    margin: 20px;
    width: auto;
}

section.teasers-big .teaser .preview.kundenbindung .text,
section.teasers-big .teaser .preview.newsletter .text {
    width: 600px;
    margin-bottom: 0;
}

section.teasers-big.kundenbindung .teaser .preview .no-toggle .text {
    width: 66.6666%;
    margin: 16px;
}

section.teasers-big.kundenbindung .teaser .preview .no-toggle img {
    width: 35%;
    object-fit: cover;
    border-radius: 4px 0 0 4px;
}

section.teasers-big .teaser .preview .toggle:hover {
    color: #282D37;
}

section.teasers-big .teaser .toggle-icon {
    position: absolute;
    top: 14px;
    right: 10px;
    padding: 10px;
}

section.teasers-big .teaser .toggle-icon .icon-arrow-up,
section.teasers-big .teaser .toggle-icon .icon-up {
    display: none;
}

section.teasers-big .teaser.open .toggle-icon .icon-arrow-up,
section.teasers-big .teaser.open .toggle-icon .icon-up {
    display: block;
}

section.teasers-big .teaser.open .toggle-icon .icon-arrow-down,
section.teasers-big .teaser.open .toggle-icon .icon-down {
    display: none;
}

section.teasers-big .teaser.open .content {
    display: flex;
    flex-wrap: wrap;
}

section.teasers-big .teaser.open .content section {
    margin: 0;
}

section.teasers-big .teaser.open .content img {
    width: 100%;
    height: auto;
}

section.teasers-big .teaser .content {
    padding: 30px 20px;
    background: #fff;
    display: none;
    border-top: 1px solid rgba(40,45,55,0.2);
}

section.teasers-big .teaser h3, section.teasers-big .teaser h4 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 1em;
    /*font-size: calculateRem($size) */
    line-height: 22px;
    margin: 0 0 10px;
}

section.teasers-big .teaser p, section.teasers-big .teaser ul {
    font-size: 0.875em;
}

section.teasers-big .teaser .preview p {
    padding-right: 24px;
}

section.teasers-big .teaser p.margin-top-10 {
    margin-top: 8px;
}

section.teasers-big .teaser li {
    position: relative;
    padding: 4px 0 0 30px;
    text-align: left;
    min-height: 20px;
}

section.teasers-big .teaser li .ico {
    position: absolute;
    left: 0;
    top: 3px;
}

section.teasers-big .teaser .btn {
    margin: 16px 0 0;
}

section.tipp {
    margin: 20px 0;
}

section.tipp .tipp-reg .icon-arrow-right {
    top: 5px;
    left: 3px;
}

section.tipp .text h3 {
    margin: 0;
    font-size: 1em;
    line-height: 20px;
}

section.tipp .text h5 {
    margin-top: 4px;
}

section.tipp .text h3 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

section.tipp .text hgroup {
    margin: 0 0 20px;
}

section.tipp .text p, section.tipp .text a {
    line-height: 20px;
}

section.tipp .text p {
    margin: 8px 0;
}

section.confirmation-header-hrs .teaser .toggle-icon .icon-up-red {
    display: none;
}

section.confirmation-header-hrs .teaser.open .toggle-icon .icon-up-red {
    display: block;
}

section.confirmation-header-hrs .teaser.open .toggle-icon .icon-down {
    display: none;
}

/*
    Bekannt als 'Checkbox-Hack'
    Dabei wird die native Checkbox ausgeblendet und abseits positioniert.
    Anschließend kann ein <label> als Custom-Styled-Checkbox verwendet werden.
    Das <label> ist mit der nativen Checkbox verknüpft.
    Dadurch kann der Checked-State der nativen Checkbox weiterhin für Logik und Styling verwendet werden.

    ACHTUNG: durch position:absolute muss sichergestellt werden, dass ein direkter parent ebenfalls
    absolut oder relativ positioniert wird, sonst kann es beim Anklicken zum "Springen" des Browser kommen,
    siehe MOVE-4586
 */
input[type='checkbox'] {
    /* kein 'springen', wenn auf das <label> geklickt wird */
    position: absolute;
    top: 0;
    left: 0;
    /* native Checkbox nicht klickbar */
    width:0;
    height: 0;
    /* native Checkbox nicht sichtbar */
    opacity: 0;
    filter: alpha(opacity=0);
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    -ms-appearance: none;
    -o-appearance: none;
}

input[type='checkbox'].focus + label {
    background-image: url("../img/icon/icon_checkbox_unselected_focus.svg");
    background-size: 24px 24px;
}

input[type='checkbox']:checked.focus + label {
    background-image: url("../img/icon/icon_checkbox_selected_focus.svg");
    background-size: 24px 24px;
}

/* Anmerkung CL: Hiermit kann man das normale Verhalten, dass labels neben disabled Checkboxen ausgegraut werden,
 wieder überschreiben: einfach umgebendes DIV ebenfalls class.disabled setzen */
.disabled input[type='checkbox']:disabled + label {
    opacity: 1;
    filter: alpha(opacity=100);
}

input[type='checkbox']:disabled + label {
    opacity: 0.5;
    filter: alpha(opacity=50);
    cursor: default;
}

input[type='checkbox']:checked.disabled + label,
input[type='checkbox']:checked.readonly + label,
input[type='radio']:checked.readonly + label {
    pointer-events: none;
    cursor: default;
}

input[type='checkbox']:checked.disabled + label,
input[type='checkbox']:checked.readonly.disabled + label {
    background: url("../img/icon/icon_checkbox_disabled-checked.svg") no-repeat 18px center;
}

input[type="checkbox"] + label {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    display: inline-block;
    width: 100%;
    margin: 0;
    padding: 16px 30px 16px 80px;
    cursor: pointer;
    background: url("../img/icon/icon_checkbox_enabled-unchecked.svg") no-repeat 18px center;
}

input[type="checkbox"] + label.respref {
    background-position: 20px 26px;
}

/** Um einen Text bündig unter eine checkbox zu stellen.
 */
div.checkbox-aligned {
    font-size: 0.875em;
    margin: 15px 0 0 20px;
}

input[type="checkbox"] + label.min-height {
    min-height: 75px;
}

input[type="checkbox"] + label.small {
    padding: 11px 30px 11px 35px;
    background-position: 0 10px;
    max-width: 441px;
}

input[type="checkbox"] + label.fullwidth {
    padding: 11px 30px 11px 35px;
    background-position: 0 10px;
}

input[type="checkbox"] + label.smaller {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 20px;
    padding: 2px 0 2px 32px;
    background-position: 0 center;
}

input[type="checkbox"] + label.middle {
    padding: 25px 30px 25px 80px;
}

input[type="checkbox"] + label.meta {
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 18px;
    color: #666666;
    padding: 5px 0 5px 48px;
}

input[type="checkbox"] + label.icon {
    padding-left: 140px;
}

input[type="checkbox"] + label .ico {
    position: absolute;
    top: 50%;
    margin-top: -28px;
    left: 60px;
}

label.respref > i.icon-icon_sitzplatz_grau_large {
    top: 38px;
}

input[type="checkbox"] + label a.has-overlay,
input[type="checkbox"] + label a.no-overlay,
label.without-input a.no-overlay {
    position: absolute;
    top: 50%;
    margin-top: -22px;
    right: 10px;
    padding: 10px;
    pointer-events: all;
}

input[type="checkbox"] + label a.has-overlay .ico,
input[type="checkbox"] + label a.no-overlay .ico {
    position: relative;
    top: 0;
    left: 0;
    margin: 0;
}

input[type="checkbox"] + label span {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 20px;
}

input[type='checkbox']:checked + label {
    background: url("../img/icon/icon_checkbox_enabled-checked.svg") no-repeat 18px center;
}

input[type="checkbox"]:checked + label.respref {
    background-position: 20px 26px;
}

input[type='checkbox']:checked + label.small {
    padding: 11px 30px 11px 35px;
    background-position: 0 10px;
    max-width: 441px;
}

input[type='checkbox']:checked + label.fullwidth {
    padding: 11px 30px 11px 35px;
    background-position: 0 10px;
}

input[type='checkbox']:checked + label.smaller {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 20px;
    padding: 2px 0 2px 32px;
    background-position: 0 center;
}

fieldset {
    border: 0;
    padding: 0;
    margin: 0;
}

fieldset.border-top {
    border-top: 1px solid #E7E7E7;
}

fieldset.fix-margin {
    margin-top: -12px;
}

fieldset .fs-header {
    position: relative;
    background: white;
    border-radius: 4px;
}

fieldset .fs-header.margin {
    margin: 5px 20px 10px 20px;
}

fieldset .fs-header.margin input[type="checkbox"] + label.small, fieldset .fs-header.margin input[type='checkbox']:checked + label.small,
fieldset .fs-header.margin input[type='radio'] + label.small, fieldset .fs-header.margin input[type='radio']:checked + label.small {
    max-width: none;
}

fieldset .fs-header.grey {
    background: #F0F3F5;
}

fieldset .fs-header.border-top {
    border-top: 1px solid #E7E7E7;
}

fieldset .fs-header.border-bottom {
    border-bottom: 1px solid #E7E7E7;
}

.fs-header.pflicht-res + .fs-header#resprefs-sitzplaetze {
    border-top: 1px solid rgba(40,45,55,0.2);
    border-radius: 0;
}

fieldset .fs-header h4 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    margin: 25px 30px -5px 20px;
}

fieldset .fs-header .logo {
    position: absolute;
    top: 50%;
    right: 20px;
}

fieldset .fs-header .sub {
    margin: 0 0 15px 140px;
}

fieldset .fs-sidebar {
    width: 220px;
    float: right;
    text-align: right;
    padding: 16px;
    color: #666666;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

fieldset .fs-sidebar h4 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    margin: 0;
}

fieldset .fs-sidebar h4.info {
    position: relative;
    padding-right: 30px;
}

fieldset .fs-sidebar h4.info a.has-overlay {
    position: absolute;
    top: -12px;
    padding: 10px;
}

fieldset .fs-sidebar h5 {
    margin: 0;
    color: #282D37;
}

fieldset .fs-sidebar h5.price {
    color: #666666;
}

fieldset .fs-sidebar h5.inactive {
    color: #878c96;
}

fieldset .fs-sidebar p {
    padding-top: 10px;
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 16px;
}

fieldset .fs-sidebar p.bottom {
    position: absolute;
    bottom: 26px;
    right: 30px;
}

fieldset .fs-content,
fieldset .fs-notogglecontent  {
    position: relative;
    padding: 20px 56px 35px 80px;
    border-top: 1px solid rgba(40,45,55,0.2);
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

fieldset .fs-content fieldset fieldset:last-of-type input[type="radio"] + label:last-of-type, fieldset .fs-content fieldset fieldset:last-of-type input[type="checkbox"] + label:last-of-type {
    padding-bottom: 0 !important;
}

fieldset .fs-content.small-padding {
    padding: 26px 80px 24px 80px;
}

fieldset .fs-content.no-padding {
    padding: 15px 0 22px;
}

fieldset .fs-content.no-border {
    border-top: 0;
}

fieldset .fs-content .form-link {
    display: block;
}

fieldset#erstattungs-grund .fs-content .form-link {
    display: inline;
}

fieldset .fs-content p {
    margin: 0 0 22px 0;
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 22px;
}

fieldset .fs-content p:last-of-type {
    margin-bottom: 0;
}

fieldset .fs-content p a {
    font-size: 1em;
    /*font-size: calculateRem($size) */
    line-height: 20px;
}

fieldset .fs-content h4 + .item {
    margin-top: 13px;
}

fieldset .fs-content .item {
    padding: 0 56px 10px 0;
}

fieldset .fs-content .item:last-of-type {
    padding-bottom: 0;
}

fieldset .fs-content .grid h5 {
    margin: 11px 0;
}

fieldset .fs-content .grid-wrapper-4 {
    margin: 0 56px 25px 140px;
}

fieldset .fs-content .grid-wrapper-4 .grid {
    width: 25%;
}

fieldset .fs-content .grid-wrapper-3 {
    margin: 0 56px 25px 140px;
}

fieldset .fs-content .grid-wrapper-3.no-margin {
    margin: 0;
}

fieldset .fs-content .grid-wrapper-3 .grid {
    width: 30%;
    margin-right: 20px;
}

fieldset .fs-content h4 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

fieldset .fs-content fieldset {
    -webkit-box-shadow: none;
    box-shadow: none;
}

fieldset .fs-content table {
    margin-top: 5px;
    margin-bottom: 0;
    font-size: 0.85em;
    /*font-size: calculateRem($size) */
    line-height: 20px;
}

fieldset .fs-content table tr td.pl {
    padding-left: 20px;
}

fieldset .fs-content ul.radio-list li {
    margin: 0;
}

fieldset .fs-content ul.radio-list li input[type='radio'] + label,
fieldset .fs-content ul.radio-list li input[type='radio']:checked + label {
    padding: 3px 0 7px 38px;
    background-position: 3px 3px;
    margin: 0 0 5px 0;
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 23px;
}

fieldset .fs-content ul.radio-list li input[type='radio'] + label span,
fieldset .fs-content ul.radio-list li input[type='radio']:checked + label span {
    display: block;
}

#cboxLoadedContent .box ul,
#cboxLoadedContent .text-image ul,
fieldset .fs-content ul.block-list,
section.header ul.block-list {
    margin-top: 5px;
    margin-bottom: 0;
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 22px;
}

#cboxLoadedContent .box ul li,
#cboxLoadedContent .text-image ul li,
fieldset .fs-content ul.block-list li,
section.header ul.block-list li {
    background: url("../img/icon/icon_list-type.svg") no-repeat;
    padding: 2px 0 0 20px;
    background-position-y: 3px;
    background-position-x: -8px;
}

#cboxLoadedContent .box ul li:last-of-type,
#cboxLoadedContent .text-image ul li:last-of-type,
fieldset .fs-content ul.block-list li:last-of-type,
section.header ul.block-list li:last-of-type {
    margin-bottom: 0;
}

fieldset .fieldset-inner {
    position: relative;
    padding: 0 20px 25px 80px;
}

fieldset .fieldset-inner.withicon,
fieldset .fs-content.withicon,
fieldset .fs-notogglecontent.withicon,
section .item.withicon {
    padding-left: 140px;
}

fieldset .fieldset-inner .has-overlay,
fieldset .fieldset-inner .no-overlay {
    position: absolute;
    top: 10px;
    right: 10px;
    padding: 10px;
}

fieldset .fieldset-inner h5 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    margin-top: 0;
    margin-bottom: 30px;
}

#buchungfuerdritte-content fieldset .fieldset-inner,
.content-reisenderauswahl .fieldset-inner {
    padding-left: 140px;
}

a.form-link {
    position: relative;
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 1em;
}

a.form-link .ico.icon-arrow-right,
a.form-link .ico.icon-arrow-right-grey {
    position: absolute;
    left: -5px;
    top: 50%;
    margin-top: -10px;
}

a.form-link span {
    padding-left: 18px;
}

.no-touch a.form-link:hover {
    text-decoration: underline;
    color: #C50014;
}

a.form-link.disabled {
    color: #b7bac0;
    cursor: default;
}

a.form-link.disabled i.ico.arrow-red-big {
    background-position: -25px -635px;
}

a.form-link.disabled:hover {
    text-decoration: none;
    color: #b7bac0;
}

a.form-link.underline {
    font-size: 1em;
    text-decoration: underline;
}

.input-wrapper {
    position: relative;
    height: 44px;
    margin: 0 0 18px 0;
    background: #fff;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.readonly .input-wrapper {
    padding-top: 4px;
    border: none;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-size: 0.875em;
}

.input-wrapper.error {
    border: 1px solid #C50014;
}

.input-wrapper .ico.icon-icon_check_small {
    position: absolute;
    top: 7px;
    right: 2px;
}

.input-wrapper input {
    width: 100%;
    height: 100%;
    padding: 12px 16px;
    background-color: #f0f3f5;
    border: 0;
    border-bottom: 1px solid #afb4bb;
    border-radius: 4px;
}

.input-wrapper textarea.input-area {
    width: 100%;
    height: 100%;
    padding: 12px 16px;
    background-color: #f0f3f5;
    border: 0;
    border-bottom: 1px solid #afb4bb;
    border-radius: 4px;
}

.container-with-text-area .input-wrapper {
    height: auto;
    margin: 0;
}

.input-label {
    display: block;
    font-size: 0.875em;
    line-height: 18px;
    margin: 0 0 6px 0;
    color: #646973;
}

input.validation-successful {
    padding-right: 30px;
}

div.error-container, div.hinweis-container {
    font-size: 0.875em;
    line-height: 18px;
    color: #C50014;
    margin-bottom: 15px;
}

div.error-container-padding {
    padding-left: 200px;
    padding-right: 20px;
}

div.error-container span, div.hinweis-container span {
    display: block;
}

div.error-container span.hidden, div.hinweis-container span.hidden {
    display: none;
}

input span.headline, input[type="radio"] + label span.headline, input[type="checkbox"] + label span.headline, input.input-hidden + label span.headline, label.without-input span.headline {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 1em;
    /*font-size: calculateRem($size) */
    line-height: 22px;
    display: block;
    margin: 0;
}

input span.headline.center-select, input[type="radio"] + label span.headline.center-select, input[type="checkbox"] + label span.headline.center-select {
    line-height: 40px;
}

input span.headline.center-payment, input[type="radio"] + label span.headline.center-payment, input[type="checkbox"] + label span.headline.center-payment {
    line-height: 45px;
}

input span.headline + .custom-select, input[type="radio"] + label span.headline + .custom-select, input[type="checkbox"] + label span.headline + .custom-select {
    width: auto;
    min-width: 150px;
    margin: 0 0 0 10px;
}

input span.headline + .custom-select select.dropdown, input[type="radio"] + label span.headline + .custom-select select.dropdown, input[type="checkbox"] + label span.headline + .custom-select select.dropdown {
    width: 100%;
}

input span.subline, input[type="radio"] + label span.subline, input[type="checkbox"] + label span.subline {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 22px;
}

/*
    Siehe oben -> Checkbox-Hack
 */
input[type='radio'] {
    /* kein 'springen' */
    position: absolute;
    top: 0;
    left: 0;
    /* natives Element nicht klickbar */
    width:0;
    height: 0;
    opacity: 0;
    filter: alpha(opacity=0);
}

input[type='radio']:checked.focus + label {
    background: url("../img/icon/icon_radio_selected_focus.svg") no-repeat 16px center;
    background-size: 24px 24px;
}

input[type="radio"]:focus + label {
    background: url("../img/icon/icon_radio_unselected_focus.svg") no-repeat 16px center;
    background-size: 24px 24px;
}

.disabled input[type='radio']:disabled + label {
    opacity: 1;
    filter: alpha(opacity=100);
}

input[type='radio']:disabled + label {
    opacity: 0.5;
    filter: alpha(opacity=50);
    cursor: default;
}

input[type="radio"] + label {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: inline-block;
    position: relative;
    background: url("../img/icon/icon_radio_unselected_default.svg") no-repeat 16px center;
    margin: 0;
    width: 100%;
    padding: 16px 30px 16px 80px;
    cursor: pointer;
}

label.disabled, h3.disabled, h4.disabled, h5.disabled, p.disabled {
    opacity: 0.5;
    filter: alpha(opacity=50);
}

input[type="text"]:disabled.touch.text
{
    opacity: 0.75;
    filter: alpha(opacity=75);
}

input[type="radio"] + label.small {
    padding: 13px 30px 15px 35px;
    background-position: 0 11px;
    max-width: 430px;
}

input[type="radio"] + label.icon {
    padding-left: 140px;
}

input[type="radio"] + label .ico {
    position: absolute;
    top: 50%;
    margin-top: -28px;
    left: 60px;
}

input[type="radio"] + label a.has-overlay,
input[type="radio"] + label a.no-overlay {
    position: absolute;
    top: 50%;
    margin-top: -22px;
    right: 4px;
    padding: 10px;
}

input[type="radio"] + label a.has-overlay .ico,
input[type="radio"] + label a.no-overlay .ico {
    position: relative;
    top: 0;
    left: 0;
    margin: 0;
}

input[type="radio"] + label span {
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 20px;
}

input[type='radio']:checked + label,
input[type='radio']:checked + label.no-payment-method {
    background: url("../img/icon/icon_radio_selected_default.svg") no-repeat 16px center;
}

input[type='radio']:checked + label.small {
    padding: 13px 30px 15px 35px;
    background-position: 0 11px;
    max-width: 430px;
}

input[type='radio'] + label + .toggle-content {
    display: none;
}

input[type='radio']:checked + label + .toggle-content {
    display: block;
}

input[type='radio'].error + label {
    background: url("../img/icon/icon_radio_error_small.png") no-repeat 16px center;
}

label ~ fieldset {
    margin-left: 35px;
}

label + fieldset input[type="radio"] + label.small, label + fieldset input[type="radio"]:checked + label.small {
    padding: 10px 30px 10px 35px;
}

div.custom-select {
    position: relative;
    height: 44px;
    width: 100%;
    box-sizing: border-box;
    margin: 0 0 17px 0;
    border: 1px solid #878C96;
    border-radius: 4px;
}

div.custom-select .ico.icon-down {
    background-repeat: no-repeat;
    position: absolute;
    top: 10px;
    right: 9px;
    left: auto;
    margin: 0;
}

div.custom-select select.dropdown {
    box-sizing: border-box;
    display: inline;
    width: 100%;
    height: 100%;
    padding: 2px 42px 4px 16px;
    border: 0;
    border-radius: 4px;
    background: transparent;
    font-size: 1em;
    line-height: 20px;
    appearance: none;
    position: absolute;
    overflow: hidden;
    text-overflow: ellipsis;
    cursor: pointer;
}

.kamin {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 220px;
}

.kamin.warenkorb {
    position: relative;
    top: 0;
    right: 0;
    width: auto;
}

.kamin .kamin-inner, .kamin .kamin-additional.box {
    position: relative;
    background: white;
}

.kamin .kamin-additional {
    position: relative;
    margin-bottom: 10px;
}

.kamin .kamin-additional.box {
    padding: 15px 10px 26px 10px;
}

.kamin .kamin-additional.info-box {
    padding: 20px 10px 26px 10px;
}

.kamin .kamin-additional.info-box h4 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

.kamin .kamin-additional.info-box h4, .kamin .kamin-additional.info-box p {
    color: #666666;
}

.kamin .kamin-additional.info-box p {
    padding: 5px 0 10px 0;
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 16px;
}

.kamin .kamin-additional.info-box a.form-link .ico.icon-arrow-right {
    top: 2px;
    margin-top: 0;
}

.kamin h4 {
    color: #878c96;
    margin: 0;
}

.kamin .green {
    color: #63A615;
}

.kamin a.form-link {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 16px;
}

.kamin header, .kamin footer {
    position: relative;
    height: 40px;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 1em;
    /*font-size: calculateRem($size) */
    line-height: 40px;
    color: white;
    padding: 0 10px;
    background: #878c96;
}

.kamin.warenkorb .kamin-inner {
    padding-top: 24px;
}

.kamin.warenkorb .preiscontainer {
    float: right;
    color: #646973;
    max-width: 300px;
}

.kamin.warenkorb .preiscontainer.maxwidth {
    max-width: max-content;
}

.kamin.warenkorb .preiscontainer .pc-row {
    display: flow-root;
    line-height: 20px;
}

.kamin.warenkorb .preiscontainer .pc-row.hidden {
    display: none;
}

.kamin.warenkorb .preiscontainer .pc-row.gutscheine {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
}

.kamin.warenkorb .preiscontainer .pc-row.gutscheine,
.kamin.warenkorb .preiscontainer .pc-row.gutscheine-hinweis .item {
    margin-top: 14px;
}

.kamin.warenkorb .preiscontainer .price.col1 {
    float: left;
    display: block;
    color: #282D37;
    font-size: 1.125em;
    padding-right: 30px;
    position: relative;
}

.kamin.warenkorb .preiscontainer .price.col2 {
    display: block;
    text-align: right;
    color: #282D37;
    font-size: 1.125em;
    padding-left: 32px;
}

.kamin.warenkorb .preiscontainer .price.col1.paddingtop,
.kamin.warenkorb .preiscontainer .price.col2.paddingtop {
    padding-top: 16px;
}

.kamin.warenkorb .preiscontainer .price.col1.paddingtop.mwst,
.kamin.warenkorb .preiscontainer .price.col2.paddingtop.mwst {
    font-size: 0.875em;
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    color: #646973;
    padding-top: 4px;
}

.kamin.warenkorb .preiscontainer .teilpreis {
    float: left;
    padding-top: 4px;
}

.kamin.warenkorb .preiscontainer .teilpreis a {
    font-size: 0.875em;
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
    color: #646973;
    text-decoration: underline;
}

.kamin.warenkorb .preiscontainer .teilpreis a:hover {
    text-decoration: underline;
    color: #C50014;
}

.kamin.warenkorb .preiscontainer .teilpreis i {
    top: 4px;
}

.kamin.warenkorb .preiscontainer .bc-info {
    float: left;
    font-size: 0.875em;
    padding-top: 10px;
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", sans-serif;
}

.kamin .has-overlay {
    position: absolute;
    top: 0;
    right: 0;
    line-height: 0;
    padding: 8px 10px;
}

.kamin.warenkorb .has-overlay {
    top: -2px;
    padding: 0;
    right: 0;
}

.kamin .price,
.kamin .voucher,
.kamin .date {
    float: right;
}

.kamin .kamin-content {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

.kamin .kamin-content table {
    width: 100%;
}

.kamin .kamin-content table th {
    text-align: left;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

.kamin .kamin-content table tr td {
    padding: 5px 0 0 0;
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
}

.kamin .kamin-content table tr td.time {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 1.125em;
    /*font-size: calculateRem($size) */
    line-height: 16px;
    width: 50px;
    vertical-align: top;
}

.kamin .kamin-content table tr td.city {
    font-size: 1em;
    /*font-size: calculateRem($size) */
    line-height: 17px;
}

.kamin .kamin-content table tr td.dateChange {
    color: #878c96;
}

.kamin .kamin-content .travel-data {
    position: relative;
    padding: 20px 10px 30px 10px;
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 16px;
}

.kamin .kamin-content .travel-data .rueckfahrt {
    margin: 24px 0 0 0;
}

.kamin .kamin-content footer.price-small {
    font-size: 0.75em; 
    padding-left: 38px;
}

.kamin .item .item-header {
    position: relative;
    font-size: 0.875em;
    margin: 4px 0 0 0;
}

.kamin .item .item-header .ico {
    position: absolute;
    top: -5px;
    left: 0;
}

.kamin .item .item-list {
    margin: 6px 0 0 0;
    padding: 0;
}

.kamin .item .item-list li {
    font-family: "DBScreenSansRegular", "DBSansRegular", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    font-size: 0.75em;
    /*font-size: calculateRem($size) */
    line-height: 16px;
    padding: 0 0 3px 30px;
}

.kamin .item .item-list li:last-child {
    padding: 0 0 1px 30px;
}

.pg-bar-wrapper {
    height: 70px;
    opacity: 1;
    padding: 16px;
}

.pg-bar-wrapper .pg-list {
    display: table;
    width: 100%;
    list-style: none;
}

.pg-bar-wrapper .pg-list li {
    position: relative;
    text-align: center;
    display: table-cell;
    vertical-align: bottom;
    height: 100%;
    /* Nur ein grober Anhaltspunkt, Breiten werden bei table proportional zur Schriftlänge gesetzt */
    width: 84px;
}

.pg-bar-wrapper .pg-list li:first-of-type {
    left: -24px;
}

.pg-bar-wrapper .pg-list li:last-of-type {
    right: -16px
}

/* Der ausgemalte Kreis unterhalb des Schritts */
.pg-bar-wrapper .pg-list li a:before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -14px;
    width: 8px;
    height: 8px;
    background: #e7e7e7;
    margin-left: -4px;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    -ms-border-radius: 50%;
    border-radius: 50%;
    z-index: 10;
}

/* Die Linie links und rechts vom Kreis */
.pg-bar-wrapper .pg-list li:before, .pg-bar-wrapper .pg-list li:after {
    content: "";
    position: absolute;
    bottom: -11px;
    width: 50%;
    height: 2px;
    background: #e7e7e7;
}

.pg-bar-wrapper .pg-list li:before {
    left: 0;
}

.pg-bar-wrapper .pg-list li:after {
    right: 0;
}

/* Ausnahmen für den 1. und letzten Schritt: Linie nach rechts bzw. links schieben */
.pg-bar-wrapper .pg-list li:first-of-type:before, .pg-bar-wrapper .pg-list li:last-of-type:after {
    display: none;
}

.pg-bar-wrapper .pg-list li:first-of-type:after {
    width: 100%;
    left: 50%;
    right: auto;
}

.pg-bar-wrapper .pg-list li:last-of-type:before {
    width: 100%;
    left: auto;
    right: 50%;
}

.pg-bar-wrapper .pg-list li a {
    position: relative;
    font-size: 0.875em;
    color: #878c96;
    text-decoration: none;
    pointer-events: none;
    display: block;
    white-space: nowrap;
}

.pg-bar-wrapper .pg-list li a span {
    position: relative;
}

.pg-bar-wrapper .pg-list li.active a {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    color: #282D37;
}

.pg-bar-wrapper .pg-list li.completed a {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-weight: normal;
    font-style: normal;
    pointer-events: auto;
    color: #63A615;
}

.pg-bar-wrapper .pg-list li.completed .ico {
    display: inline-block;
    position: absolute;
    top: -4px;
}

.pg-bar-wrapper .pg-list li.completed a:before,
.pg-bar-wrapper .pg-list li.active a:before,
.pg-bar-wrapper .pg-list li.completed:before, .pg-bar-wrapper .pg-list li.completed:after,
.pg-bar-wrapper .pg-list li.completed + li.active a:before,
.pg-bar-wrapper .pg-list li.completed + li.active:before {
    background: #63A615;
}

/**
 CL Wir nehmen die body Definition raus und definieren diese Klasse
 als "unterhalb einer boxed-sections" oder "boxed-section"
 */

.boxed-sections section,
section.boxed,
div.bestaetigung section main.boxed /*
    body.zahlung section,
    body.zusatzangebote section,
    body.reservierungs-details section,
    body.ticket-reservierung section,
    body.registrierung section,
    body.login section,
    body.bahncard section,
    body.reisender section
     */
{
    background: white;
}

.boxed-sections section.grey {
    background: #F0F3F5;
}

section.additional-box {
    padding: 20px;
    font-size: 0.875em;
}

.boxed-sections section h4 span.subtitle {
    font-family: DBSansRegular, "Arial", "Helvetica", sans-serif;
    font-size: 0.875em;
    line-height: 22px;
    display: block;
}

/**
 Ausnahme(n) von der Regel, dass die sections immer weiss sind! Das sollte man aber wie auf den anderen Seiten lösen
 */
div.pruefen-buchen.boxed-sections section {
    background: inherit;
}

div.pruefen-buchen.boxed-sections section.verbindungsueberwachung {
    background: white;
}

section.verbindungsueberwachung input[type='checkbox'] + label.small {
    max-width: unset;
}

div.bestaetigung section main {
    -webkit-box-shadow: none;
    box-shadow: none;
}

div.bestaetigung .alert {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    padding-top: 10px;
}

div.bestaetigung .alert .ico.icon_glocke_grau {
    margin: 0 8px;
    width: 32px;
    height: 32px;
    top: 6px;
}

div.bestaetigung .alert .ico.large {
    top: 22px;
}

div.bestaetigung .alert .ico.small {
    top: 5px;
}

.error .content {
    background: #ffffff;
}

.error .content.hinweis {
    background: #F0F3F5;
}

.error .error-description {
    padding: 30px 78px;
    width: 560px;
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box;
}

.error .content.hinweis .error-description {
    padding: 34px;
}

.error .error-description h2 {
    font-size: 1.25em;
    /*font-size: calculateRem($size) */
    line-height: 35px;
    margin: 19px 0 45px;
}

.error .error-description p {
    margin: 23px 0;
    font-size: 0.875em;
    /*font-size: calculateRem($size) */
    line-height: 22px;
}

.error .new-request {
    border-top: 1px solid #E7E7E7;
    padding: 30px 80px;
}

.overlay-content {
    padding: 20px;
    position: relative;
    background: #fff;
    max-width: 640px;
    width: calc(100vw - 3rem);
}

.overlay-content h3, .overlay-content h4, .overlay-content p {
    max-width: 560px;
}

#cboxLoadedContent .box h3,
#cboxLoadedContent .text-image h2,
#cboxLoadedContent .text-image h3,
.overlay-content h3 {
    margin: 5px 0 13px;
}

#cboxLoadedContent .box h4,
#cboxLoadedContent .text-image h4,
.overlay-content h4 {
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-size: 0.875em;
    margin: -3px 0 9px;
}

.overlay-content p {
    font-size: 0.75em;
    margin: 0 0 1.5em;
}

#cboxLoadedContent .box table,
#cboxLoadedContent .text-image table,
.overlay-content table {
    border-spacing: 10px;
    border-collapse: separate;
    max-width: 640px;
    margin: -6px -10px;
}

#cboxLoadedContent .box table th,
#cboxLoadedContent .text-image table th,
.overlay-content table th {
    border-bottom: #E7E7E7 solid 4px;
    font-family: "DBScreenSansBold", "DBSansBold", "Arial", "Helvetica", sans-serif;
    font-size: 0.875em;
    text-align: left;
    padding: 0 10px 17px;
}

#cboxLoadedContent .box table td,
#cboxLoadedContent .text-image table td,
.overlay-content table td {
    border-bottom: #E7E7E7 solid 1px;
    font-size: 0.75em;
    padding: 2px 10px 12px;
}

#cboxClose {
    position: absolute;
    right: 16px;
    top: 16px;
    background: url("../img/icon/close.svg") no-repeat center;
    text-indent: -9999em;
    width: 20px;
    height: 20px;
    cursor: pointer;
    border: none;
}

#cboxClose:active {
    outline: none;
}

div.pruefen-buchen section.header.text {
    margin: 0 0 30px;
}

div.pruefen-buchen section main {
    -webkit-box-shadow: none;
    box-shadow: none;
}

.lt-ie10 .custom-select .ico.icon-down {
    display: none;
}

.lt-ie10 .custom-select select.dropdown {
    padding-right: 0;
}

.lt-ie9 .input-wrapper label.label {
    top: 6px;
}

/** TODO CL Diese Definition ermöglicht zusammen mit modernizr, dass Elemente ohne JS ausgeblendet weren können.
Dazu muss im <html> Tag (oder sonstwo ganz oben) IMMER erstmal .no-js geschrieben werden!
 */
.no-js .hide-no-js {
    display: none;
}

/* Block der nur ohne JS direkt angezeigt wird (z.B. kombinierbar mit hidden, wenn es dnymische JS-Logik dafür gibt) */
.no-js .show-no-js-block {
    position: unset !important;
}

.debugmsg {
    overflow-x: auto;
    color: #00f;
    font-size: 11px;
    font-family: courier,monospace;
    text-decoration: none;
    border: 1px solid #f00;
}

.debugmsg p, .debugmsg table {
    font-size: 1em;
}

.debugmsg h2 {
    color: #00f;
}

#versioninfo {
    background: #fff;
    font-size: 0.875em;
}

#versioninfo ul {
    display: inline-block;
    margin: 0;
    padding: 11px 0;
    zoom: 1;
}

#versioninfo ul li span {
    color: #00f;
}

.container-980.button-wrapper {
    padding: 40px 0;
    background: #F0F3F5;
    display: block;
}

.container-980.button-wrapper.nopaddingbottom {
    padding-bottom: 0;
}

.container-980.button-wrapper.nopaddingtop {
    padding-top: 0;
}

.container-980 .button-section {
    background: #ffffff;
    padding-left: 20px;
    padding-right: 20px;
    display: flex;
}

#resprefs-sitzplaetze input[type="checkbox"] + label span.headline + .custom-select {
    width: 280px;
    margin: 8px 16px 16px 0;
}

#resprefs-sitzplaetze .btn.grey {
    margin-top: 8px !important;
    height: 44px;
}

#resprefs-sitzplaetze h4.info {
    padding-right: 0;
}

#resprefs-sitzplaetze a.has-overlay {
    top: 26px;
    right: 6px;
}

/********************/
/*    Breadcrumb    */
/********************/

#breadcrumb {
    padding-top: 8px;
    margin: 0 20px 8px;
    position: relative;
    z-index: 999;
}
#breadcrumb li {
    background: url(../img/icon_pfeil_rechts_16.svg) no-repeat center;
    background-position-x: 2px;
    background-position-y: 4px;
    padding-left: 18px;
    float: left;
}
#breadcrumb li.first {
    background: none;
    padding: 0;
}
#breadcrumb a {
    font-size: 0.75em;
    color: #646973;
}
#breadcrumb a.active {
    cursor: auto;
    text-decoration: none;
}

/* Buchungsrueckschau Icons */
.icon-icon_reiseplan {
    background: url('../img/icon/ic-db_maps_map_32.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_erneut_buchen {
    background: url('../img/icon/icon-icon_navigation_refresh_32.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_fgr_einreichen {
    background: url('../img/icon/ic-db_action_legal_32.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_document {
    background: url('../img/icon/icon-icon_document_32.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_ticket {
    background: url('../img/icon/icon-icon_ticket_32.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_ticket_reiseplan {
    background: url('../img/icon/icon-icon_ticket_timetable_32.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_sitzplatz_not_available {
    background: url('../img/icon/icon-icon_sitzplatz_not_available_32.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_mobile_phone {
    background: url('../img/icon/icon-icon_mobile_phone_32.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_action_download {
    background: url('../img/icon/icon-icon_action_download_32.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_storno {
    background: url('../img/icon/ic-db_action_undo_32.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_storno_lighter {
    background: url('../img/icon/ic-db_action_undo_32_lighter.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_storno_ausgeschlossen {
    background: url('../img/icon/ic-db_action_block_32.svg') no-repeat center;
    width: 32px;
    height: 32px;
}

.icon-icon_bahnfahrt_hin {
    background: url('../img/icon/icon-icon_bahnfahrt_hin_20.svg') no-repeat center;
    width: 20px;
    height: 20px;
}

.icon-icon_bahnfahrt_rueck {
    background: url('../img/icon/icon-icon_bahnfahrt_rueck_20.svg') no-repeat center;
    width: 20px;
    height: 20px;
}

.icon-icon_bahnfahrt_hin_rueck {
    background: url('../img/icon/icon-icon_bahnfahrt_hin_rueck_20.svg') no-repeat center;
    width: 20px;
    height: 20px;
}

.icon-icon_reservierung {
    background: url('../img/icon/icon-icon_sitzplatz_20.svg') no-repeat center;
    width: 20px;
    height: 20px;
}

.icon-icon_bahncard {
    background: url('../img/icon/icon-icon_bahncard_20.svg') no-repeat center;
    width: 20px;
    height: 20px;
}

.icon-icon_geschenkgutschein {
    background: url('../img/icon/icon-icon_gutschein_20.svg') no-repeat center;
    width: 20px;
    height: 20px;
}

.icon-icon_reiseversicherung {
    background: url('../img/icon/icon-icon_reiseversicherung_small.svg') no-repeat center;
    width: 20px;
    height: 20px;
}

.icon-icon_ticket_default {
    background: url('../img/icon/icon-icon_ticket_default_20.svg') no-repeat center;
    width: 20px;
    height: 20px;
}

/***************************************************************************
 * Definitionen für Medium Drucker.
 * Überschreibungen allgemeiner Definitionen in webclient.css
 * für den Ausdruck.
 ***************************************************************************/
@media print {

    /** Element, das nicht gedruckt werden soll  */
    .notprintable {
        display: none;
    }

}

/**
 * Auch in einer Druckansicht (für media Screen etc.) Elemente unterdrücken, die nicht ausgedruckt werden sollen.
 */
div.druckansicht .notprintable {
    display: none;
}