body {
  font-family: "Montserrat", sans-serif;
  background: white;
  position: relative;
}

html,
body {
  overscroll-behavior: none;
}

.tabs {
  display: flex;
}

.tabs-wrapper {
  margin-top: 30px;
}

.tab {
  background: #00000069;
  color: white;
  padding: 20px 40px;
  font-size: 16px;
  box-shadow: 0 10px 15px #ffffffb5;
  cursor: pointer;
  transition: all 0.2s;
  font-weight: 600;
  display: flex;
  align-items: flex-start;
}

.tab:nth-child(1) {
  border-top-left-radius: 5px;
}

.tab:last-child {
  border-top-right-radius: 5px;
}

.tab.active {
  background: white;
  color: black;
}

.top-inputs {
  display: flex;
}

.top-input-wrapper {
  background: white;
  padding: 20px;
  box-shadow: 0 0 10px #0000000d;
}

.top-input-wrapper img {
  width: 20px;
  margin-right: 5px;
  vertical-align: bottom;
}

.top-input-wrapper:nth-child(1) {
  border-top-left-radius: 5px;
  border-bottom-left-radius: 5px;
}

.tab-contents {
  margin-top: -7px;
}

.tab-content {
  display: none;
}

.tab-content.active {
  display: block;
}

.top-input-label {
  font-size: 12px;
  color: #8f8f8f;
  margin-bottom: 5px;
}

.top-input-wrapper input,
.top-input-wrapper select,
.top-input-wrapper button {
  border: none;
  background: none;
  color: black;
  font-size: 14px;
  font-weight: 600;
}

button.top-inputs-btn {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.top-input-wrapper:last-child {
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
  padding: 0;
  overflow: hidden;
  width: 100%;
}

button.top-inputs-submitter {
  width: 100%;
  height: 100%;
  padding: 20px;
  background: #20c997;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
  color: white;
}

.tab:hover {
  padding: 20px 45px;
}

.top-input-wrapper input,
.top-input-wrapper select {
  width: 180px;
}

.query-results-box img {
  max-width: 100%;
}

.query-results-box {
  background: white;
  border-radius: 5px;
}

.map-bottom-icons img {
  max-width: 24px;
  margin-right: 10px;
}

.map-bottom-icons {
  display: flex;
  padding: 10px 20px;
  margin-top: 10px;
}

.map-bottom-icons .d-flex {
  width: 50%;
  padding: 0px 30px;
}

.d-flex {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}

.map-bottom-icons .d-flex:nth-child(2) {
  border-left: 1px solid lightgray;
  padding-right: 0;
}

.border-right-column {
  border-bottom: 1px solid lightgray;
  padding-bottom: 5px;
  margin-bottom: 20px;
  border-radius: 30px;
}

.query-results-box {
  padding: 20px;
  padding-top: 40px;
  padding-bottom: 40px;
}

.transfer-info-section img {
  width: 24px;
}

.transfer-info-section {
  display: flex;
  align-items: end;
  justify-content: flex-start;
}

.transfer-info {
  padding: 5px 20px;
  font-size: 16px;
  font-weight: 500;
}

.transfer-info img {
  vertical-align: sub;
  margin-right: 10px;
  max-width: 30px;
}

.transfer-card {
  margin-top: 15px;
  padding-bottom: 20px;
  border-bottom: 1px solid gainsboro;
}

.transfer-product-description {
  padding: 5px 20px;
}

.product-price-section h3,
.product-price-section small {
  font-weight: 500;
}

span.bigger {
  font-size: 1.3em;
}

.product-price-section small {
  margin-left: 20px;
}

.btn-primary {
  width: 100%;
  background: #2d8cd9;
  border: none;
  border-radius: 4px !important;
  font-size: 1.5em;
  box-shadow: 0px 0px 20px #00000026;
}

.product-price-section {
  /* padding-top: 30px; */
}

.form-titles {
  font-size: 2.3rem;
  width: fit-content;
  padding: 10px 30px;
  font-weight: 600;
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
  background: white;
  border-radius: 10px;
  box-shadow: 0px 4px 15px #0000002e;
}

.query-results-box {
  position: relative;
}

button.circle-btn {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: #2d8cd9;
  box-shadow: 4px 4px 10px #0000003d;
}

button.circle-btn img {
  max-width: 32px;
}

.transfer-form-title {
  text-align: center;
  margin-bottom: 20px;
  font-size: 1.2em;
  font-weight: 500;
}

.transfer-form-rows {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}

.t-form-flexes img {
  max-width: 24px;
}

.t-form-flexes input,
.t-form-flexes select {
  border: none;
  background: none;
  height: 100%;
  min-width: 180;
  width: 100%;
}

.t-form-flexes {
  border: 2px solid #2d8cd954;
  position: relative;
  padding: 0px 20px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 300px;
}

button.transparent-btn {
  background: none;
  border: none;
}

span.t-form-input-labels {
  position: absolute;
  left: 20px;
  top: 5px;
  font-size: 0.8em;
  color: #787878;
}

.t-form-flexes.dividers {
  border: none;
  font-size: 1.5em;
  font-weight: 500;
  width: 100px;
}

.horizontal-line {
  height: 1px;
  width: 50px;
  background: gainsboro;
}

.transfer-form-rows {
  margin-bottom: 20px;
}

.transfer-forms {
  max-width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

.child-seat-box {
  display: none;
}

img.t-form-icons {
  position: absolute;
  right: 25px;
  width: 16px;
  transition: all 0.2s;
}

.no-border {
  border: none;
}

.checkbox-flex {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}

input[type="checkbox"] {
  width: fit-content;
  min-width: auto;
}

.checkbox-flex input {
  margin-right: 10px;
}

.left-aligned {
  justify-content: flex-start;
}

.quantity-wrapper {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.quantity-wrapper * {
  border: none;
  background: none;
  font-weight: 500;
  font-size: 1.3em;
}

.quantity-wrapper button {
  width: 32px;
  height: 32px;
}

.transfer-form-title:nth-child(1) {
  margin-top: 0 !important;
}

.transfer-form-title {
  margin-top: 70px;
}

.cards-section {
  max-width: fit-content;
  margin-left: auto;
  margin-right: auto;
  position: relative;
}

.tall-cards {
  height: 100%;
  width: 280px;
  cursor: pointer;
  transition: all 0.2s;
}

.tall-cards:hover {
  transform: scale(1.05);
}

.cards-section .dividers {
  width: 50px;
}

.tall-cards.active {
  background: #2d8cd9;
  color: white;
}

.tall-cards.active:after {
  content: "";
  width: 32px;
  height: 32px;
  position: absolute;
  bottom: 5px;
  right: 5px;
  transform: translate(-50%);
  background: url(images/check.png);
  z-index: 2;
  background-position: center;
  background-size: contain;
}

.tall-cards-content {
  height: 100%;
  padding: 10px;
  padding-bottom: 30px;
}

.tall-cards-content p {
  margin-top: 40px;
}

.tallcards-price {
  font-size: 1.5em;
  font-weight: 500;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  transition: all 0.3s;
}

.query-results-box:nth-child(1) {
  margin-top: 60px;
}

.query-results-box {
  margin-bottom: 10px;
}

input:focus {
  outline: none;
}

.drag-drop-d-flex {
  display: flex;
  margin-bottom: 20px;
  align-items: center;
  padding: 10px;
  background: white;
  box-shadow: 4px 4px 20px #00000026;
  z-index: 2;
  width: 450px;
}

.drag-drop-d-flex input {
  display: block;
  border: none;
}

.drag-drop-d-flex div:nth-child(2) {
  padding-left: 20px;
}

.drag-drop-d-flex small {
  opacity: 0.6;
}

.drag-drop-btn {
  width: 32px;
  height: 32px;
  background: url(images/drag.png);
  background-size: contain;
  background-position: center;
  min-width: 32px;
  min-height: 32px;
}

div#addressesWrapper {
  position: relative;
}

.additional-addresses {
  z-index: 2;
  background: white;
  width: 450px;
}

.additional-addresses-floor {
  width: 450px;
  height: 59px;
  background: #2d8cd929;
  margin-bottom: 20px;
}

.saydam {
  opacity: 0.5;
}

.additional-addresses {
  -webkit-user-select: none;
  /* Safari */
  -moz-user-select: none;
  /* Firefox */
  -ms-user-select: none;
  /* IE10+/Edge */
  user-select: none;
  /* Standard */
}

.additional-addresses button {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 16px;
  font-weight: 300;
  opacity: 0.5;
  z-index: 2;
}

.additional-addresses {
  position: relative;
}

.child-seat-box {
  position: absolute;
  width: 100%;
  top: 60px;
  background: white;
  z-index: 2;
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0px 0px 20px #00000026;
}

.child-seat-box.active {
  display: block;
}

.down-chevron.active {
  transform: rotate(180deg);
}

.flex-box {
  display: flex;
}

.space-between {
  justify-content: space-between;
}

.child-seat-box .flex-box {
  margin: 10px 0px;
}

.child-seats-btn {
  width: 100%;
  display: flex;
  margin-right: 10px;
}

.child-seats-display {
  background: #2d8cd9;
  margin: 0px 5px;
  color: white;
  padding: 4px;
  border-radius: 4px;
}

.t-form-flexes.child-seats {
  padding: 0px 10px;
}

.justify-content-center {
  justify-content: center;
}

.insurance-checkbox input {
  margin-right: 10px;
}

.container {
  padding-bottom: 300px;
}

.total-price {
  font-size: 1.5em;
  font-weight: 800;
}

.total-price small {
  font-size: 80%;
  font-weight: 300;
}

.button-wrapper {
  width: 100%;
  text-align: right;
}

.query-totals {
  position: fixed;
  left: 50%;
  bottom: auto;
  transform: translateX(-50%);
  box-shadow: 0px 0px 20px #00000014;
  transition: all 0.5s;
  z-index: 2;
}

.drag-drop-btn {
  cursor: grab;
}

.t-form-flexes-addresses {
  width: 100%;
  margin-top: 20px;
  margin-bottom: 20px;
  touch-action: none;
  -ms-touch-action: none;
}

.top-inputs.has-error .top-input-wrapper {
  border: 2px solid indianred;
}

.top-inputs.has-error .top-input-wrapper:last-child {
  border: none;
}

.lightbox-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  z-index: 3;
}

.lightbox-background {
  background: #00000042;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 0;
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(1px);
}

.lightbox {
  position: relative;
  z-index: 1;
  padding: 20px;
  background: white;
  box-shadow: 0px 0px 20px #0000005c;
  min-width: 550px;
  max-height: calc(100vh - 20px);
  overflow: auto;
  margin: 20px;
  box-sizing: border-box;
  border-radius: 5px;
  max-width: 1360px;
}

.lightbox-content {
  padding: 20px 0px;
}

input.has-error {
  border-bottom: 3px solid red;
}

.has-error {
  border-bottom: 4px solid indianred !important;
}

.pac-container {
  min-width: 250px;
  padding: 10px;
  box-shadow: 0px 0px 10px #00000014;
  border-radius: 5px;
}

@media only screen and (min-width: 1440px) {
  .container {
    width: 1380px;
  }

  .top-input-wrapper input,
  .top-input-wrapper select {
    width: 200px;
  }

  select[name="company"] {
    max-width: fit-content;
    width: fit-content !important;
  }
}

.top-input-wrapper input,
.top-input-wrapper select {
  font-size: 1.2rem;
}

.input-placeholder {
  width: fit-content;
  position: absolute;
  right: 45px;
  bottom: 25px;
}

.top-input-wrapper {
  position: relative;
}

.quantity-price {
  padding-left: 10px;
  border-left: 1px solid gainsboro;
  font-size: 1.2em;
  font-weight: 400;
}

.tall-cards.active h2 {
  color: white;
}

.loading {
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9;
}

.loading .lightbox {
  background: none;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: none;
  top: 0 !important;
}

button:focus,
input:focus {
  outline: none !important;
}

.user-localisation {
  background: white;
  height: fit-content;
  width: fit-content;
  position: fixed;
  right: 100px;
  z-index: 9;
  border-bottom-left-radius: 5px;
  border-bottom-right-radius: 5px;
}

.user-localisation .pull-left {
  float: none !important;
  margin-left: auto;
  margin-right: 0;
}

.additional-addresses input {
  min-width: 300px;
}

.additional-addresses .has-error {
  border: 3px solid indianred;
}

.additional-addresses .has-error:before {
  content: "!";
  color: white;
  width: 32px;
  height: 32px;
  background: indianred;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: -32px;
  font-size: 16px;
  font-weight: 600;
  border-top-left-radius: 3000px;
  border-bottom-left-radius: 3000px;
  padding-left: 6px;
}

.additional-addresses .no-error {
  border: none;
}

.additional-addresses .no-error:before {
  content: "OK";
  color: white;
  width: 32px;
  height: 32px;
  background: lightseagreen;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: -32px;
  font-size: 16px;
  font-weight: 600;
  border-top-left-radius: 3000px;
  border-bottom-left-radius: 3000px;
  padding-left: 6px;
}

.additional-addresses .has-error input.has-error {
  border: none !important;
}

form.lightbox-forms {
  min-width: 500px;
}

form.lightbox-forms .row {
  margin: 10px 0px;
}

div#common-success {
  color: white;
}

div#common-success a {
  color: white;
  font-weight: 600;
}

ul.breadcrumb li a {
  color: #2d8cd9 !important;
}

option {
  padding: 10px;
  font-size: 17px;
}

.time-wings {
  display: flex;
  max-width: 150px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 5px;
  align-items: flex-start;
  justify-content: center;
}

.left-wing,
.right-wing {
  max-height: 200px;
  overflow-y: auto;
  max-width: 50px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin: 5px;
  height: fit-content;
  overflow-x: hidden;
  scrollbar-width: thin;
  /* For Firefox */
  scrollbar-color: #2d8cd9 #f1f1f1;
  /* Thumb and track colors for Firefox */
}

.left-wing::-webkit-scrollbar,
.right-wing::-webkit-scrollbar {
  width: 6px;
  /* Scrollbar width for WebKit browsers */
}

.left-wing::-webkit-scrollbar-track,
.right-wing::-webkit-scrollbar-track {
  background: #f1f1f1;
  /* Track color */
  border-radius: 10px;
}

.left-wing::-webkit-scrollbar-thumb,
.right-wing::-webkit-scrollbar-thumb {
  background: #2d8cd9;
  /* Thumb color */
  border-radius: 10px;
  box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
}

.left-wing button,
.right-wing button {
  width: 40px;
  height: 40px;
  background: #ffffff;
  border: none;
  color: #0c71c3;
  font-weight: 600;
  margin: 5px;
  margin-bottom: 5px;
  border: 1px solid #ededed;
}

/* width */
::-webkit-scrollbar {
  width: 12px;
}

/* Track */
::-webkit-scrollbar-track {
  width: 16px;
  box-shadow: inset 0 0 5px #80808082;
  border-radius: 10px;
  background: #ababab;
}

/* Handle */
::-webkit-scrollbar-thumb {
  background: #264e6e;
  border-radius: 10px;
  box-shadow: inset 0 0 5px #80808082;
}

.left-wing::-webkit-scrollbar-track,
.right-wing::-webkit-scrollbar-track {
  box-shadow: inset 0 0 5px #80808082;
  border-radius: 10px;
  background: #ffffff;
}

.left-wing::-webkit-scrollbar-thumb,
.right-wing::-webkit-scrollbar-thumb {
  background: #2d8cd9;
  border-radius: 10px;
  box-shadow: inset 0 0 5px #80808082;
}

button.fur:disabled {
  opacity: 0.3;
}

button.fur.active {
  background: #0c71c3;
  color: white;
}

button.btn.btn-secondary {
  margin-bottom: 10px;
  border: 1px solid #2d8cd9;
  background: white;
  color: #2d8cd9;
  text-shadow: 0 0 BLACK;
  width: 100%;
  font-size: 1.6rem;
}

.extras-box {
  position: relative;
}

.extras-box .overlay {
  position: absolute;
  top: -5px;
  left: -5px;
  width: calc(100% + 10px);
  height: calc(100% + 10px);
  background: #00000000;
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(1px);
  z-index: 2;
}

span.error-description {
  color: indianred;
  font-weight: 600;
}

.transfer-form-title small {
  font-weight: 400;
  font-size: 1.2rem;
}

.transfer-form-title {
  font-weight: 600;
  font-size: 1.7rem;
}

input[type="datetime-local"]::-webkit-calendar-picker-indicator {
  font-size: 20px;
}

body.main-window .query-totals {
  bottom: 20px;
}

.p-image-cell {
  width: 280px;
}

table.table.table-bordered a {
  color: white;
}

input#tempDateInput {
  padding: 10px;
  border: 1px solid gainsboro;
  font-size: 20px;
  margin-bottom: 20px;
}

.temp-date-submit-date {
  margin-bottom: 10px;
}

.temp-date-submit-date {
  margin-bottom: 10px;
}

button.inputlike-button {
  border: none;
  background: none;
  color: black;
  font-size: 14px;
  font-weight: 600;
}

.t-form-flexes .inputlike-button {
  width: 100%;
  text-align: left;
  display: block;
  margin-top: 15px;
}

.inquiry-btn.zone-warning {
  max-width: fit-content;
  padding: 10px 40px;
  margin-left: 50px;
}

.price-loading {
  width: 100%;
}

.button-edit a {
  max-width: fit-content;
  box-shadow: none;
  font-size: 16px !important;
  border-radius: 5px !important;
}

.button-edit a i {
  margin-right: 10px;
}

small.sameday_warning {
  display: block;
  margin-left: 0;
  font-size: 1.2rem;
  margin-top: 5px;
  line-height: 1.4;
  color: indianred;
}

#account-order h1,
#account-order h2,
#account-order h3,
#account-order h3,
#account-order h4,
#account-order h5,
#account-order p,
#account-order div,
#account-order span {
  color: white !important;
}

div#account-account {
  color: white;
}

div#account-account a {
  color: white;
}

div#account-account #column-right a {
  color: #333 !important;
  font-weight: 500;
}

div#account-edit {
  color: white;
}

div#account-edit legend {
  color: white;
}

div#account-password,
#account-password legend {
  color: white;
}

div#account-return,
div#account-return legend {
  color: white;
}

div#account-transaction {
  color: white;
}

div#account-newsletter {
  color: white;
}

div#addressSelectboxElement {
  position: absolute;
  background: white;
  /* max-height: 350px; */
  padding: 10px;
  overflow: auto;
  border-radius: 4px;
  box-shadow: 0px 10px 30px #00000014;
  z-index: 3;
  min-width: 300px;
  top: 0;
}

.germany-address-unit {
  padding: 5px !important;
  cursor: pointer;
  border-radius: 3px;
  max-width: fit-content;
  float: left;
  border: 1px solid gainsboro;
  margin: 5px;
}

.germany-address-unit:hover {
  background: #dcdcdca6;
}

.wing-desc {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 10px;
}

.time-wings {
  flex-wrap: wrap;
}

.wing-desc div {
  min-width: 50px;
  padding: 5px;
  text-align: center;
  margin: 5px;
  border-bottom: 1px solid gainsboro;
}

.t-form-flexes-text {
  max-width: 260px;
}

div#addressSelectboxElement small {
  display: block;
  width: 100%;
}

input[name="pickup-location"],
input[name="destination-location"],
.additional-addresses input[type="text"] {
  cursor: pointer;
}

button.box-closer {
  position: absolute;
  top: 10px;
  right: 10px;
  background: none;
  border: none;
}

.address-list-overflow {
  max-height: 190px;
  overflow: auto;
}

.address-step-input button {
  position: relative;
  top: auto;
  right: auto;
  transform: none;
  opacity: 1;
}

input#citySearchInput {
  background: #20b2aa4d;
}

input#addressStepInput,
input#OtherAddressStepInput {
  background: #20b2aa4d;
}

input#addressStepInput {
  margin-bottom: 20px;
}

.button-wrapper button {
  width: 300px;
}

#OtherAddressStepInput {
  display: none;
}

.other-city #OtherAddressStepInput {
  display: block;
  margin-bottom: 10px;
}

div#checkout-cart table {
  font-weight: 500;
  color: #333;
}

span.cart-transfer-type {
  font-weight: 500;
  color: lightseagreen;
}

span.cart-transfer-type.red {
  color: indianred;
}

.tall-cards {
  margin-bottom: 5px;
}

span.wprice {
  font-size: 14px;
  text-decoration: line-through;
  color: indianred;
  margin-left: 5px;
}

[name="telephone"],
[name="phone"] {
  padding-left: 100px;
}

.dial-codes-select img {
  max-height: 24px;
}

.telephone-flags {
  max-height: 34px;
  overflow: hidden;
  position: absolute;
  bottom: 0;
  left: 0;
  border-radius: 5px 0px 0px 5px;
  box-shadow: inset 0 1px 5px rgba(0, 0, 0, 0.075);
  background: #f3f3f3;
  cursor: pointer;
  display: none;
}

.form-group {
  position: relative;
}

.dial-codes-select div {
  height: 34px;
  padding-left: 10px;
  background: #f3f3f3;
  width: 140px;
  padding-top: 5px;
  font-weight: 600;
  color: dimgrey;
  box-shadow: inset 0 1px 5px rgba(0, 0, 0, 0.075);
}

.dial-codes-select div img {
  margin-right: 7px;
}

.dial-codes-select div.active {
  display: block;
}

.telephone-flags.expanded {
  height: 250px;
  overflow: auto;
  max-height: fit-content;
  top: 25px;
  z-index: 2;
}

.expanded .dial-codes-select div {
  display: block;
}

.active-dial-code {
  height: 34px;
  padding: 5px;
  background: #efefef;
  position: absolute;
  top: 25px;
  left: 0;
  border-radius: 5px 0px 0px 5px;
  width: 90px;
  box-sizing: border-box;
  font-size: 14px;
  font-weight: 500;
  color: #3f3f3f;
  box-shadow: inset 0 1px 5px rgba(0, 0, 0, 0.075);
  cursor: pointer;
}

.active-dial-code img {
  height: 24px;
  margin-right: 7px;
}

.telephone-flags.active {
  display: block;
  height: 200px;
  max-height: max-content;
  top: 60px;
  z-index: 1;
  overflow: auto;
}

.row .active-dial-code {
  margin-left: 15px;
}

fieldset#account .active-dial-code {
  margin-left: 0;
}

button.company-private-btn {
  width: 100%;
  height: 34px;
  margin-bottom: 10px;
  background: #ffffff;
  border: none;
  border-radius: 4px !important;
  font-size: 1.5em;
  box-shadow: 0px 0px 20px #00000026;
  color: #2d8cd9;
}

button.company-private-btn.active-btn {
  height: fit-content;
  padding: 10px;
  transition: 0.2s all;
  background: #2d8cd9;
  color: white;
}

button.company-private-btn {
  transition: all 0.2s;
}

button.company-private-btn.active-btn:before {
  content: "\f00c";
  font: normal normal normal 18px/1 FontAwesome;
  margin-right: 10px;
}

div#checkout-checkout h1 {
  color: white;
}

.flight-input-warning {
  position: absolute;
  top: calc(100% + 5px);
  padding: 0px 2px;
  font-size: 11px;
  left: 0;
  color: indianred;
}

form#inquiryForm .active-dial-code {
  top: 0;
}

form#inquiryForm .telephone-flags {
  top: 40px;
}

.address-list-steps input,
.address-step-input input {
  padding: 0px 10px !important;
}

.passenger_info_query .active-dial-code {
  top: 0;
}

.phone_input_for_passenger {
  padding-left: 100px;
}

.passenger_info_query .telephone-flags.active {
  top: 35px;
  left: 15px;
}

input[name="agree"] {
  width: 16px;
  height: 16px;
}

input#button-payment-method {
  margin-top: 10px;
}

.flex-wrap-wrap {
  flex-wrap: wrap;
}

.return-trip-prices-fancy-btn {
  border-radius: 3px;
  border: 2px solid #2d8cd9;
  margin-top: 10px;
  transition: all 0.3s;
  animation: borderChange 3s linear infinite;
  width: 100%;
}

.t-form-flexes.no-border {
  height: fit-content;
}

@keyframes borderChange {
  0% {
    border: 2px solid #2d8cd9;
  }

  50% {
    border: 2px solid #8df96c;
  }

  100% {
    border: 2px solid #2d8cd9;
  }
}

table.calendar {
  width: 100%;
}

td.day {
  width: 100px;
  height: 80px;
  border: 1px solid #0000000d;
  padding: 10px;
  cursor: pointer;
  transition: all 0.2s;
  text-align: center;
}

td.day:hover {
  background: #dcdcdc38;
}

tr.calendar-title {
  font-size: 20px;
}

tr.calendar-title th {
  padding-bottom: 15px;
  padding-top: 15px;
}

.calendar_display {
  background: white;
  /* margin-top: -88px; */
  border-radius: 5px;
  padding: 20px 40px;
  z-index: 2;
  position: relative;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.top-input-wrapper {
  white-space: nowrap;
}

tr.calendar-title th {
  text-align: center;
  background: #ededed;
  border-radius: 5px;
}

.calendar_explanation_text_block {
  background: white;
  padding: 20px 40px;
  /* margin-top: -88px; */
  position: relative;
  border-top-right-radius: 5px;
}

.tab:nth-child(2) {
  border-top-right-radius: 5px;
}

td.day div {
  font-size: 16px;
  margin-bottom: 10px;
  font-weight: 300;
}

td.day.today,
td.day.active {
  box-shadow: inset 0px 0px 30px #2d8cd94f;
}

.insta-book-card {
  padding: 20px;
  border: 2px solid #2d8cd9;
  border-radius: 5px;
  width: 350px;
  margin: 10px;
  cursor: pointer;
  transition: all 0.2s;
}

.insta-book-card:hover {
  color: white;
  background: #2d8cd9;
}

.insta-book-cards-wrapper {
  display: flex;
  flex-wrap: wrap;
  max-width: 960px;
  margin: 0px -10px;
  justify-content: center;
}

.insta-book-card i {
  width: 24px;
  height: 24px;
}

.insta-book-card.selected-booking {
  background: #18619d;
  color: white;
  border: 2px solid #ffffff00;
  box-shadow: 0px 0px 30px #2d8cd940;
}

.card-selected-identifier {
  display: none;
}

.selected-booking .card-selected-identifier {
  display: block;
}

.lightbox-content h3 {
  margin-top: 0;
}

input#citySearchInput {
  min-height: 35px;
}

.lightbox-content div#addressSelectboxElement {
  position: relative;
  max-width: 300px;
  margin-top: -60px;
}

.lightbox-content .top-input-wrapper {
  padding: 10px;
}

span.insta-book-card-price {
  font-size: 2em;
  font-weight: 600;
  text-align: right;
  display: block;
  padding: 15px;
  border-radius: 5px;
  /* background: #2d8cd9; */
  /* color: white; */
  /* margin-top: 20px; */
  transition: all 0.2s;
}

.calendar_explanation_text_block {
  height: 170px;
  /* cursor: pointer; */
  overflow: hidden;
  transition: all 0.2s;
  max-height: 100%;
}

.calendar_explanation_text_block:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100px;
  background: rgb(28 28 28);
  background: linear-gradient(180deg,
      rgba(196, 11, 11, 0) 0%,
      rgb(0 0 0 / 45%) 100%);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

.calendar_explanation_text_block h2 {
  margin-top: 0;
  cursor: pointer;
}

.calendar_explanation_text_block.expanded {
  height: 600px;
  overflow: auto;
}

.calendar_explanation_text_block.expanded:after {
  display: none;
}

.calendar_display {
  box-shadow: 0px 0px 30px #0000001f;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
}

.insta-booking-form h3 i {
  font-size: 30px;
  vertical-align: middle;
}

.calendar_explanation_text_block h2:after {
  content: "\f078";
  font: normal normal normal 14px/1 FontAwesome;
  margin-left: 15px;
  font-size: 30px;
}

.calendar_explanation_text_block.expanded h2:after {
  content: "\f077";
}

.calendar_explanation_text_block h2 {
  position: relative;
  z-index: 2;
}

.card-info-layer img {
  max-width: 36px;
  margin-right: 15px;
}

.card-info-layer {
  display: flex;
  align-items: center;
}

.card-info-layer {
  border-bottom: 1px solid #00000008;
  padding: 15px 0px;
}

.card-info-layer span {
  font-weight: 600;
  font-size: 1.3em;
}

.card-info-layer small {
  opacity: 0.8;
  font-weight: 500;
  font-size: 0.8em;
}

.insta-book-card:hover img {
  filter: invert(1);
}

.insta-book-card:hover .card-info-layer,
.selected-booking .card-info-layer {
  border-bottom: 1px solid #ffffff26;
}

.card-info-price-layer {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

span.insta-book-card-price small {
  font-weight: 400;
  font-size: 0.7em;
  vertical-align: bottom;
}

span.insta-book-card-price small {
  font-weight: 400;
  font-size: 0.7em;
  vertical-align: bottom;
}

.card-info-price-layer {
  margin-top: 20px;
}

.card-selected-identifier {
  position: absolute;
  top: -15px;
  right: 20px;
  background: white;
  color: #18619d;
  padding: 5px 10px;
  border-radius: 5px;
  box-shadow: 0px 0px 20px #1b75bf26;
  font-weight: 600;
}

.insta-book-card.selected-booking {
  position: relative;
}

.card-selected-identifier i {
  vertical-align: text-top;
  width: auto;
  height: auto;
}

.insta-book-card.selected-booking img {
  filter: invert(1);
}

.insta-booking-form .top-input-wrapper {
  margin-bottom: 10px;
  border: 1px solid #00000014;
  border-radius: 5px;
}

.germany-address-unit small {
  display: initial !important;
}

.day button.transparent-btn {
  font-size: 20px;
  font-weight: 800;
  color: lightseagreen;
}

p.error-holder {
  font-style: italic;
  color: indianred;
  font-weight: 600;
}

.month12,
.month10,
.month8,
.month6,
.month4,
.month2 {
  background: #ffffff;
}

.month11,
.month9,
.month7,
.month5,
.month3,
.month1 {
  background: #f1f1f1;
}

.show-only-mobile {
  text-align: left;
  margin-bottom: 25px;
}

span.show-only-mobile {
  font-size: 20px;
  font-weight: 600;
}

.mobile-cart-confirm {
  max-width: fit-content;
  margin-left: auto;
  text-align: right;
  min-width: 300px;
}

.mobile-cart-product-info {
  margin-bottom: 25px;
}

span.smallest-text {
  font-size: 14px;
  vertical-align: bottom;
  margin-right: 4px;
}

img.tab-icon {
  filter: invert(1);
  max-width: 32px;
  margin-right: 10px;
}

.active img.tab-icon {
  filter: none;
}

.tab-text small {
  font-weight: 400;
  font-size: 80%;
  display: block;
  line-height: 1.4;
  opacity: 0.7;
}

.background-image-holder {
  position: fixed;
  top: 0;
  left: 0;
  width: 100dvw;
  height: 100dvh;
  background: url(images/airport-bg.jpeg);
  background-size: cover;
  background-position: center;
  opacity: 1;
  filter: blur(3px);
  transition: all 0.2s;
  z-index: -2;
}

.logo-holder {
  max-width: 300px;
  background: #ffffff;
  padding: 15px;
  border-bottom-left-radius: 5px;
  border-bottom-right-radius: 5px;
  box-shadow: 10px 15px 30px 10px #4141411f;
}

.logo-holder img {
  max-width: 100%;
}

.landing-section {
  color: white;
}

.landing-section h1 {
  font-size: 36px;
  font-weight: 700;
}

.calendar_explanation_text_block {
  box-shadow: 0px -5px 30px #00000026;
}

.landing-section h1 {
  margin: 0;
}

.landing-section p {
  font-size: 16px;
}

.landing-col-boxes img {
  max-width: 96px;
  margin-bottom: 15px;
}

.landing-col-boxes {
  max-width: 280px;
  margin: auto;
  background: #00000038;
  padding: 30px 10px;
  min-height: 220px;
  max-height: 220px;
  border-radius: 5px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: all 0.3s;
  box-shadow: 0px 0px 30px #0000000f;
}

.landing-section h1 {
  padding-bottom: 15px;
  margin-bottom: 15px;
  position: relative;
  display: block;
}

.landing-section h1:after {
  content: "";
  width: 80px;
  height: 2px;
  background: #ffffff69;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}

.landing-section {
  margin-bottom: 50px;
}

button.mouse-scroll-animated-button img {
  max-width: 100%;
}

button.mouse-scroll-animated-button {
  background: none;
  border: none;
  margin: auto;
  animation: scrollInteracter 5s infinite linear;
  display: block;
  position: relative;
}

@keyframes scrollInteracter {
  0% {
    bottom: 0;
  }

  50% {
    bottom: -50px;
  }

  100% {
    bottom: 0px;
  }
}

.landing-col-boxes:hover {
  transform: scale(1.02);
  box-shadow: 0px 0px 20px #00000021;
}

.background-blur-overlay {
  background: #2d8cd9;
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: -1;
  opacity: 0.7;
}

div#content {
  color: white;
}

.payment-form-wrapper #card-element {
  max-width: 100%;
  overflow: auto;
  min-width: auto !important;
}

.i-flightnumber-warning {
  font-size: 90%;
  color: indianred;
  white-space: normal !important;
  max-width: 300px;
}

.insta-booking-form .top-input-label {
  color: #333333;
  font-weight: 600;
}

.horizontal-time-picker .time-wings {
  width: 100%;
  max-width: 500px;
  overflow: auto;
}

.horizontal-time-picker .left-wing,
.horizontal-time-picker .right-wing {
  width: 400px;
  max-width: 100% !important;
}

.horizontal-time-picker .right-wing {
  width: 0;
  transition: all 0.2s;
}

.wing-desc:last-child {
  display: none;
}

.left-wing button[disabled=disabled] {
  display: none;
}

.insta-booking-form input,
.insta-booking-form select {
  width: 100%;
  padding: 5px 0px;
}

.insta-booking-form div#addressSelectboxElement {
  max-width: 500px;
}

div#checkout-cart a.btn-primary {
  padding: 10px 30px;
  letter-spacing: 2px;
  font-weight: 600;
  animation: infinite checkoutBtnAnimation 1.2s;
}

@keyframes checkoutBtnAnimation {
  0% {
    background: #2d8cd9;
    color: white;
  }

  50% {
    background: #5a9fd7;
    box-shadow: 0px 0px 20px #ffffffc0
  }

  100% {
    background: #2d8cd9;
    color: white;
  }
}

.calendar_explanation_text_block {
  margin-top: 20px;
  border-top-left-radius: 5px;
}

.booking-table {
  background: white;
  border-radius: 5px;
  padding: 20px;
  position: relative;
}

.oneway-round-switch {
  display: flex;
  position: relative;
  background: #dfdfdf;
  border: 1px solid #bfbfbf;
  padding: 5px;
  border-radius: 5px;
  max-width: 300px;
  margin-top: 30px;
}

.switch-holder {
  position: absolute;
  top: 5px;
  left: 5px;
  width: calc(50% - 10px);
  height: calc(100% - 10px);
  background: white;
  border-radius: 5px;
  transition: 0.2s all;
  box-shadow: 5px 5px 5px #00000024;
}

.switch-btn {
  width: 50%;
  text-align: center;
  cursor: pointer;
  z-index: 1;
  font-weight: 600;
  color: gray;
  font-size: 12px;
}

.switch-btn.active {
  color: #2d2d2d;
}

.default-switch-system {
  position: relative;
  width: 40px;
  height: 20px;
  background: #bfbfbf;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 300px;
}

.default-switch-system .switch-btn {
  height: 100%;
}

.booking-table-inputs {
  display: flex;
  padding: 20px 0px;
}

.booking-table-input-holder {
  margin-right: 40px;
  height: 50px;
  position: relative;
  min-width: 71px;
}

.booking-table-input-label {
  font-size: 12px;
  font-weight: 700;
  line-height: 12px;
  margin-bottom: 10px;
}

.booking-table-input-holder input {
  border: none;
  height: 100%;
  border-left: 3px solid #cbcbcb;
  padding-left: 20px;
  min-width: 200px;
  font-size: 12px;
}

.address-step-input input {
  padding: 10px !important;
  border: none;
}

.switch-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  cursor: pointer;
}

div#addressSelectboxElement .address-left,
div#addressSelectboxElement .address-right {
  min-width: 300px;
}

.airports-list-wrapper {
  padding: 10px;
}

button.airport-select-button {
  width: 100%;
  text-align: left;
  padding: 10px;
  border: none;
  background: none;
  transition: all 0.2s;
}

button.airport-select-button:hover {
  background: #f9f9f9;
}

.input-tooltip {
  position: absolute;
  bottom: -60px;
  left: 50%;
  width: fit-content;
  white-space: nowrap;
  background: #4d4d4d;
  color: white;
  padding: 10px;
  border-radius: 5px;
  display: none;
  transform: translateX(-50%);
}

.booking-table-input-holder:hover .input-tooltip {
  display: block !important;
}

.input-tooltip:after {
  content: "";
  width: 16px;
  height: 16px;
  background: #4d4d4d;
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  z-index: 2;
}

div#addressSelectboxElement h3 {
  font-size: 22px;
  margin: 0;
}

button.revert-locations-btn {
  width: 24px;
  height: 100%;
  padding: 0;
  border: none;
  background: none;
  margin: 10px;
  margin-top: 32px;
  opacity: .5;
  margin-bottom: 0;
}

button.revert-locations-btn img {
  width: 100%;
}

.booking-table button.inputlike-button {
  border: none;
  height: 100%;
  border-left: 3px solid #cbcbcb;
  padding-left: 20px;
  min-width: 180px;
  font-size: 12px;
  text-align: left;
}

tr.calendar-title button {
  margin: 5px 15px;
  border: none;
  background: none;
}

.months-buttons-layout button {
  padding: 15px;
  background: none;
  border: none;
  background: #eaeaea;
  border: 1px solid #d1d1d1;
  border-radius: 5px;
  box-shadow: 0px 5px 30px #0000001f;
}

.months-buttons-layout {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid #ededed;
  margin-bottom: -50px;
}

.datetime-picker-definer {
  width: 24px;
  height: 24px;
  background: white;
  box-shadow: 0px 0px 30px black;
  position: absolute;
  z-index: 0;
  left: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  display: none;
  transition: all 0.5s;
}

.booking-table button.inputlike-button {
  position: relative;
  z-index: 1;
  background: white;
}

button[disabled] {
  opacity: .5;
}

.row.bookings-calendar-system-row {
  overflow: hidden;
  transition: all 0.5s;
  max-height: fit-content;
}

.selection-element img {
  max-width: 24px;
  margin-top: 12px;
  margin-left: 5px;
}

.selection-element select {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: none;
  border: none;
  border-radius: 5px;
  text-align: right;
}

.selection-element {
  position: relative;
  width: 65px;
  margin-top: 0px;
  height: 50px;
  margin-right: 5px;
}

.basePrice {
  font-size: 12px !important;
  font-weight: 600 !important;
}

.last-minute-booking-weiter {
  margin-bottom: 10px;
}

.overall-screen {
  background: white;
  border-radius: 5px;
  height: 0px;
  overflow: auto;
  max-height: fit-content;
  transition: all 0.5s;
  overflow-x: hidden;
}

.go-to-normal-booking-btn {
  overflow: hidden;
  transition: all 0.2s;
  max-height: fit-content;
  margin-top: 50px;
}

.t-form-flexes button.inputlike-button {
  background: none;
  border: none;
}

.focus-this {
  position: relative;
  padding: 5px;
  box-shadow: 0px 0px 30px #0000001c;
  border: 1px solid gainsboro !important;
  border-radius: 5px;
}

.total-price {
  min-width: fit-content;
}

img.transfer-product-image {
  width: 200px;
}

img.transfer-product-image {
  width: 200px;
}

.step-flexbox {
  margin: 20px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 20px;
  border: 1px solid gainsboro;
  border-radius: 30px;
  background: white;
}

.step-number {
  font-size: 22px;
  font-weight: 800;
  width: 36px;
  height: 36px;
  background: #2d8cd9;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 3000px;
  margin-right: 20px;
}

.selected-overlay {
  background: #ffffffcf;
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  z-index: 2;
  font-size: 30px;
  line-height: normal;
  text-align: center;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}

.selected-overlay button {
  font-size: 20px;
  margin-top: 20px;
  font-weight: 800;
}

.lmb-selected-overlay {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #ffffffba;
  z-index: 2;
  font-size: 30px;
  line-height: normal;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}

.star-icon {
  color: orange;
  text-shadow: 0px 0px 10px #ffa500;
  font-size: 18px !important;
  position: absolute;
  top: 10px;
  right: 10px;
}

td.day {
  position: relative;
}

.mark-info {
  display: flex;
  max-width: fit-content;
  margin: 10px;
  align-items: center;
}

.mark-info .star-icon {
  position: relative;
  top: auto;
  right: auto;
  padding: 5px;
  border: 1px solid #0000003d;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 10px;
  border-radius: 5px;
}

.mark-info-text {
  font-weight: 600;
}

.selected-box-sample {
  position: relative;
  top: auto;
  right: auto;
  padding: 5px;
  border: 1px solid #0000003d;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 10px;
  border-radius: 5px;
  box-shadow: inset 0px 0px 30px #2d8cd94f;
}

tr.calendar-header th {
  padding-top: 20px;
  padding-left: 15px;
}

.calendar tbody tr:first-child td:first-child {
  border-top-left-radius: 10px;
  border: none;
}

.calendar tbody tr:first-child td:last-child {
  border-top-right-radius: 10px;
  border: none;
}

.calendar tbody tr:first-child {
  border: none !important;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.selected-box-sample.single {
  box-shadow: none;
  background: #f1f1f1;
}

.selected-box-sample.double {
  box-shadow: none;
  background: #ffffff;
}

.mark-info-wrapper {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
}

.mark-info-tooltip {
  position: absolute;
  width: 350px;
  height: 0;
  max-height: fit-content;
  bottom: 50px;
  background: white;
  left: 0;
  border-radius: 5px;
  box-shadow: 4px 4px 10px #00000021;
  overflow: hidden;
  transition: all 0.7s;
  color: transparent;
}

.mark-info-text {
  position: relative;
  cursor: pointer;
}

.mark-info-text:hover .mark-info-tooltip {
  padding: 2em;
  height: 1000px;
  color: black;
}

button.transparent-btn.popup-closer {
  position: absolute;
  top: 0;
  right: 0;
  background: white;
}

button.small-circle-btn {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 3000px;
  border: none;
  background: #1778c6;
  color: white;
}