.signature-pad { position: relative; width: 100%; background-color: #fff; margin-bottom: 50px; }
.signature-pad--body { position: relative; width: 100%; }
.signature-pad--body:before { content: ""; display: block; width: 100%; padding-top: 25%; }
.signature-pad--body::after { content: ""; display: block; width: 80%; height: 1px; position: absolute; bottom: 25%; left: 0; right: 0; margin: 0 auto; background-color: #dddddd; }
.signature-pad--body canvas {position: absolute; left: 0; top: 0; width: 100%; height: 100%; border: 1px solid #e61c58; }
.signature-pad--actions { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; position: absolute; top: 2px; right: 2px; -webkit-touch-callout: none; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }
.signature-pad--actions button { background-color: #dddddd; border: none; width: 40px; height: 40px; text-align: center; padding: 11px; margin: 1px; font-family: 'FontAwesome'; font-size: 18px; cursor: pointer; outline: none; }

.signature-pad--lock { display: none; width: 100%; height: 100%; position: absolute; top: 0; right: 0; left: 0; bottom: 0; background-color: transparent; }
.signature-pad--lock.active { display: block; cursor: not-allowed; }

.signature-pad--actions button[data-action="lock"].active { background-color: #ababab; }


@media (max-width: 500px) {
  .signature-pad--actions { position: static; }
  .signature-pad--actions button { margin: 5px 5px 0 0; }
}

.form--flexbox { display: -webkit-box;display: -ms-flexbox;display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 0 -15px 15px -15px; }
.form--flexbox > * { padding: 0 15px; width: 50%; }

.form--flexbox .placeholder,
.signature-pad .placeholder { line-height: 1; margin-top: 5px; font-size: 16px; -webkit-touch-callout: none; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none}
.form--flexbox input { padding: 5px 0; }

@media (max-width: 500px) {
  .signature-pad--actions { position: static; }
  .form--flexbox > * { width: 100%; }
}

/* Statusübersicht */
.status-list li { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-wrap: wrap; flex-wrap: wrap; line-height: 1.4; font-size: 20px; color: #000; }
.status-list li > * { display: block; padding: 15px; }
.status-list span.info { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
.status-list span.status { text-align: center; min-width: 170px; color: #e61c58; }
.status-list span.status b { text-transform: uppercase; font-size: .8em;}
.status-list strong { display: block; }
.status-list svg { width: 30px; height: 30px; display: block; margin: 0 auto 5px auto; }
.status-list .status i { display: block; font-size: 30px; margin: 0 auto 5px auto; }


/* Checkbox Einverständniserklärung */
.checkbox.verlauf_box { padding: 15px; }

.cbx { margin: auto; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; cursor: pointer; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; color: #000; }
.cbx span { display: inline-block; vertical-align: middle; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); }
.cbx span:first-child { position: relative; width: 18px; height: 18px; -webkit-transform: scale(1); -ms-transform: scale(1); transform: scale(1); border: 1px solid #e61c58; -webkit-transition: all 0.2s ease; -o-transition: all 0.2s ease; transition: all 0.2s ease; }
.cbx span:first-child svg { position: absolute; top: 3px; left: 2px; fill: none;stroke: #FFFFFF; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; stroke-dasharray: 16px; stroke-dashoffset: 16px; -webkit-transition: all 0.3s ease; -o-transition: all 0.3s ease; transition: all 0.3s ease; -webkit-transition-delay: 0.1s; -o-transition-delay: 0.1s; transition-delay: 0.1s; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); }
.cbx span:first-child:before { content: ""; width: 100%; height: 100%; background: #e61c58; display: block; -webkit-transform: scale(0); -ms-transform: scale(0); transform: scale(0); opacity: 1; border-radius: 50%; }
.cbx span:last-child { padding-left: 15px; padding-top: .1em; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
.cbx:hover span:first-child { border-color: #e61c58; }

.inp-cbx:checked + .cbx span:first-child { background: #e61c58; border-color: #e61c58; -webkit-animation: wave 0.4s ease; animation: wave 0.4s ease; }
.inp-cbx:checked + .cbx span:first-child svg { stroke-dashoffset: 0; }
.inp-cbx:checked + .cbx span:first-child:before { -webkit-transform: scale(3.5); -ms-transform: scale(3.5); transform: scale(3.5); opacity: 0; -webkit-transition: all 0.6s ease; -o-transition: all 0.6s ease; transition: all 0.6s ease; }

@-webkit-keyframes wave {
  50% {
    -webkit-transform: scale(0.9);
        -ms-transform: scale(0.9);
            transform: scale(0.9);
  }
}

@keyframes wave {
  50% {
    -webkit-transform: scale(0.9);
        -ms-transform: scale(0.9);
            transform: scale(0.9);
  }
}

/* Meine Buchung EV */
.verlauf_box.option--box { padding: 30px;}
.verlauf_box.option--box h2 { color: #e61c58; font-weight: bold; text-transform: none; margin-bottom: 15px; }
.verlauf_box.option--box h2 span { font-weight: 300; }
.verlauf_box.option--box p { padding: 0;}
.verlauf_box.option--box label { font-size: 20px; font-weight: bold; color: #000; margin: 30px 0 5px 0; line-height: 1.2; }

.email--wrapper { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.email--wrapper input { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; border: 1px solid #e61c58; height: 70px; line-height: 68px; margin: 0; padding: 0 15px; }
.email--wrapper button.btn_pink { display: block; width: 70px; height: 70px; font-family: Font Awesome\ 5 Free; margin: 0; }
.email--wrapper .placeholder { display: none; }

.ev_wrapper { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: end; -ms-flex-align: end; align-items: flex-end }
.ev_wrapper > span { display: block; padding: 0 30px; line-height: 70px; font-size: 20px; text-transform: uppercase; color: #000; }
.ev_wrapper .copylink { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
.ev_wrapper .copylink strong { width: 100%; }
.ev_wrapper .copylink div { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; cursor: pointer; -webkit-touch-callout: none; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }
.ev_wrapper .copylink div div { border: 1px solid #e61c58; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; line-height: 68px; height: 70px; font-size: 16px; padding: 0 15px; white-space: normal; color: #e61c58; overflow: hidden; }
.ev_wrapper .email--wrapper { display: -webkit-box; display: -ms-flexbox; display: flex; }
.ev_wrapper .whatsapp--wrapper { min-width: 270px; padding-left: 30px; }
.ev_wrapper a.whatsapp { width: 100%; }
.ev_wrapper .placeholder { display: none; }
.ev_wrapper button.btn_pink.text_center { width: 70px; font-family: 'FontAwesome'; }
.ev_wrapper a.whatsapp,
.ev_wrapper button.btn_pink.text_center { display: block; height: 70px; margin: 0; padding: 0; line-height: 70px; color: #FFF; font-size: 30px; font-weight: normal; }
.ev_wrapper strong {display: block; font-size: 20px; font-weight: bold; color: #000;  margin: 30px 0 5px 0; line-height: 1.2;}
@media (max-width: 680px) {
  .ev_wrapper { -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; }
  .ev_wrapper > * { width: 100%; }
  .ev_wrapper > span { padding: 0; }
  .ev_wrapper .whatsapp--wrapper { padding-left: 0; }
}

/* Drag & Drop EV */
.file-drop-area { position: relative; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; width: 100%; padding: 25px; border: 1px dashed rgba(0, 0, 0, 0.6); -webkit-transition: 0.2s; -o-transition: 0.2s; transition: 0.2s; font-size: 16px; line-height: 18px; margin-top: 20px; }
.file-drop-area.is-active { background-color: rgba(0, 0, 0, 0.05); }
.file-drop-area.done { border: 1px dashed #2ccc55; background-color: rgba(44, 204, 85, 0.05); }
.file-drop-area.done:after {content: ""; display: block; width: 100%; height: 100%; position: absolute; top: 0; right: 0; left: 0; bottom: 0; z-index: 10; }
button.btn_pink.fake-btn { -ms-flex-negative: 0; flex-shrink: 0; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgba(0, 0, 0, 0.1); margin: 0 10px 0 0; color: #747474; }
.file-msg { font-weight: 300; line-height: 1.4; white-space: nowrap; overflow: hidden; -o-text-overflow: ellipsis; text-overflow: ellipsis; }
.file-input { position: absolute; left: 0; top: 0; height: 100%; width: 100%; cursor: pointer; opacity: 0; }
.file-input:focus { outline: none; }
button.btn_pink#file-upload { margin: 20px auto 0 0; }
button.btn_pink#file-upload.disabled { color: #666; background-color: #dddddd; cursor: not-allowed; }


/* Data Table Fix */
.overview td { overflow-wrap: break-word; }

@media (max-width: 435px) {
  span.info,
  .verlauf_box.option--box label,
  .ev_wrapper strong { font-size: 16px; }
}


/* Input Field Clear Fix */
.form--vorname,
.form--nachname,
.form--ort,
.form--datum { position: relative; }
.form--vorname span,
.form--nachname span,
.form--ort span,
.form--datum span { position: absolute; top: 27px; left: 15px; line-height: 1; z-index: 10; background-color: red; font-family: "DIN Next LT W01 Heavy"; font-size: 16px; color: #000; background-color: #FFF; }
