.hidden {
  opacity: 0;
  position: absolute;
}
.visible {
  opacity: 1;
}
input.calendar {
  background: #fff url("//www.bestwestern.de/bw/v5/img/bg/input_calendar.gif") no-repeat right !important;
  color: #727272;
  border: 1px #c3c3c3 solid;
  padding: 1px 0;
}
button.calendar {
  border: 0;
  height: 1px;
  line-height: 1px;
  font-size: 1px;
  visibility: hidden;
  position: absolute;
  top: 0;
}
button.calendar.active,
button.calendar:hover {
  background-position: 0 20px;
}
div.calendar {
  background: url("//www.bestwestern.de/bw/v5/img/bg/calendar.png") no-repeat 0 0;
  height: 204px;
  padding: 0 6px;
  text-align: center;
  width: 182px;
  box-sizing: content-box;
}
div.calendar * {
  margin: 0;
  padding: 0;
  box-sizing: content-box;
}
div.calendar div {
  background: none !important;
  cursor: move;
  height: 185px;
  overflow: hidden;
  padding-top: 10px;
  position: relative;
  width: 176px;
}
div.calendar caption {
  color: #000;
  font: bold 13px/16px Arial, Helvetica, sans-serif;
  padding: 2px 0 0 6px;
  text-align: left;
  width: 100%;
}
div.calendar caption a {
  cursor: pointer;
  display: block;
  height: 13px;
  overflow: hidden;
  position: absolute;
  text-indent: -100px;
  top: 13px;
  width: 13px;
}
div.calendar caption a#captPrev,
div.calendar caption a.prev {
  background-image: url("//www.bestwestern.de/bw/v5/img/ico/scrollback.gif");
  right: 15px;
}
div.calendar caption a#captNext,
div.calendar caption a.next {
  background-image: url("//www.bestwestern.de/bw/v5/img/ico/scrollfwd.gif");
  right: 0;
}
div.calendar caption a:hover {
  background-position: 0 -37px;
}
div.calendar caption span {
  height: 25px;
  position: relative;
  text-align: center;
}
div.calendar caption span.month {
  padding-right: 8px;
}
div.calendar table {
  background: #FFF;
  border: 0;
  border-collapse: collapse;
  border-spacing: 0;
  cursor: default;
  margin: 0 0 0 -1px;
  overflow: hidden;
  width: 177px;
}
div.calendar table td,
div.calendar table th {
  border: 0 !important;
  color: #000;
  font: normal 12px Arial, Helvetica, sans-serif;
  height: 23px;
  text-align: center;
  width: 27px;
  padding: 0 !important;
  vertical-align: middle;
}
div.calendar table th {
  font-weight: bold;
  border-bottom: 1px solid #999;
  background: url("//www.bestwestern.de/bw/v5/img/bg/calendar-td.gif") 0 -1px;
}
div.calendar table td {
  background: url("//www.bestwestern.de/bw/v5/img/bg/calendar-td.gif");
  color: #aaa;
}
div.calendar table td.invalid {
  color: #999;
}
div.calendar table td.valid {
  background: url("//www.bestwestern.de/bw/v5/img/bg/calendar-td.gif");
  color: #000;
  cursor: pointer;
}
div.calendar table td.today {
  color: #78ad21;
  font-weight: bold;
}
div.calendar table td.hilite {
  background: #1b70b3;
  color: #fff;
}
div.calendar table td.inactive {
  background: #1b70b3;
  color: #fff;
}
div.calendar table td.active,
div.calendar table td.hover {
  background: #78ad21;
  color: #fff;
  cursor: pointer;
}
div.calendar table td.blocked {
  background: #ff6666;
  text-decoration: line-through;
  color: #ffffff;
}
#bwbbx {
  padding: 0 20px 0 0;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 12px;
  line-height: 1.3em;
  font-weight: normal;
  clear: both;
}
#bwbbx * {
  box-sizing: content-box;
}
#bwbbx form {
  background: #f9f9f9;
  border: 1px solid #f0f0f0 !important;
  padding: 15px 20px 6px 20px !important;
  margin: 0 0 0 0 !important;
  min-height: 60px;
  width: auto !important;
  overflow: visible !important;
  float: left;
}
#bwbbx form > div {
  float: left;
  margin: 0 5px 3px 0 !important;
  width: auto;
  clear: none !important;
  position: relative;
}
#bwbbx form div.optional {
  display: none;
}
#bwbbx form div.optional input {
  text-align: center;
}
#bwbbx form div.btn {
  width: 130px;
  padding-top: 12px;
}
#bwbbx form div.tipp {
  display: none;
}
#bwbbx form label {
  display: block;
  width: auto !important;
  margin-bottom: 2px;
  font: normal 12px/16px Arial, Helvetica, sans-serif !important;
  text-transform: none !important;
}
#bwbbx form label small {
  font-size: 9px !important;
  line-height: 12px;
  white-space: nowrap;
}
#bwbbx form input.text {
  color: #727272;
  border: 1px #ABABAB solid;
  padding: 4px 2px 5px;
  box-sizing: content-box;
  margin-top: 0;
  font: normal 12px/16px Arial, Helvetica, sans-serif;
  height: 15px;
  background-color: white;
}
#bwbbx form #ss_doppelzimmer,
#bwbbx form #ss_einzelzimmer,
#bwbbx form #ss_erwachsene,
#bwbbx form #ss_kinder {
  width: 30px;
}
#bwbbx form input.calendar {
  font: normal 12px/16px Arial, Helvetica, sans-serif;
  height: 15px;
  width: 94px;
  color: #727272;
  border: 1px #ABABAB solid;
  padding: 4px 2px 5px 6px;
  box-sizing: content-box;
  margin-top: 0;
}
#bwbbx form select.text {
  padding: 3px 0 4px 2px;
}
#bwbbx form input.imgbtn {
  height: auto;
  margin: 5px 0 0 -7px;
  width: auto;
}
#bwbbx form select.sdSelect {
  opacity: .0;
  filter: alpha(opacity=0);
  position: absolute;
  top: 0;
  left: 0;
  width: 50px;
}
#bwbbx form div.selectreplace div {
  position: relative;
  height: 26px;
  width: 50px;
  overflow: hidden;
  background: transparent url("//www.bestwestern.de/bw/v5/img/btn/bg_btn_l.gif") no-repeat left top;
}
#bwbbx form div.selectreplace span.selecttext {
  display: block;
  height: 26px;
  width: 40px;
  background: transparent url("//www.bestwestern.de/bw/v5/img/btn/select_btn.gif") no-repeat right top;
  font: normal 12px/23px Arial, Helvetica, Verdana, sans-serif;
  color: #727272;
  padding: 2px 0 0 10px;
  position: absolute;
  top: 0;
}
#bwbbx form div.nowrap {
  width: auto !important;
}
#bwbbx form div.nowrap > div {
  float: left;
  margin-right: 5px;
  margin-bottom: 3px;
  clear: none !important;
  max-width: 88px;
}
#bwbbx form input.btn {
  display: block;
  margin: 0;
  color: #fff;
  text-align: center;
  text-transform: uppercase;
  cursor: pointer;
  vertical-align: middle;
  touch-action: manipulation;
  background-image: none;
  border: 1px solid transparent;
  white-space: nowrap;
  padding: 6px 12px 6px 6px;
  font: bold 12px/1.5em Arial, Helvetica, Verdana, sans-serif;
  height: 20px;
  border-radius: 0;
  -webkit-user-select: none;
  float: right;
  background-color: #759114;
  border: 1px solid #759114;
}
#bwbbx form input.btn:hover {
  background-color: #99BE18;
  border: 1px solid #99BE18;
}
#bwbbx .popover {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1010;
  display: none;
  max-width: 276px;
  padding: 1px;
  text-align: left;
  white-space: normal;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid #ccc;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 6px;
  -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
  width: 260px;
}
#bwbbx .popover.top {
  margin-top: -10px;
}
#bwbbx .popover.top > .arrow {
  bottom: -11px;
  left: 50%;
  margin-left: -11px;
  border-top-color: #999;
  border-top-color: rgba(0, 0, 0, 0.25);
  border-bottom-width: 0;
}
#bwbbx .popover.top > .arrow:after {
  bottom: 1px;
  margin-left: -10px;
  content: " ";
  border-top-color: #fff;
  border-bottom-width: 0;
}
#bwbbx .popover.right {
  margin-left: 10px;
}
#bwbbx .popover.right > .arrow {
  top: 50%;
  left: -11px;
  margin-top: -11px;
  border-right-color: #999;
  border-right-color: rgba(0, 0, 0, 0.25);
  border-left-width: 0;
}
#bwbbx .popover.right > .arrow:after {
  bottom: -10px;
  left: 1px;
  content: " ";
  border-right-color: #fff;
  border-left-width: 0;
}
#bwbbx .popover.bottom {
  margin-top: 10px;
}
#bwbbx .popover.bottom > .arrow {
  top: -11px;
  left: 50%;
  margin-left: -11px;
  border-top-width: 0;
  border-bottom-color: #999;
  border-bottom-color: rgba(0, 0, 0, 0.25);
}
#bwbbx .popover.bottom > .arrow:after {
  top: 1px;
  margin-left: -10px;
  content: " ";
  border-top-width: 0;
  border-bottom-color: #f7f7f7;
}
#bwbbx .popover.left {
  margin-left: -10px;
}
#bwbbx .popover.left > .arrow {
  top: 50%;
  right: -11px;
  margin-top: -11px;
  border-right-width: 0;
  border-left-color: #999;
  border-left-color: rgba(0, 0, 0, 0.25);
}
#bwbbx .popover.left > .arrow:after {
  right: 1px;
  bottom: -10px;
  content: " ";
  border-right-width: 0;
  border-left-color: #fff;
}
#bwbbx .popover h3 {
  padding: 5px 10px;
  margin: 0;
  font-size: 12px;
  font-weight: normal;
  line-height: 1.4em;
  background-color: #f7f7f7 !important;
  border-bottom: 1px solid #ebebeb;
  border-radius: 5px 5px 0 0;
  text-transform: uppercase;
}
#bwbbx .popover p {
  padding: 9px 10px;
  font-size: 11px;
  line-height: 1.2em;
  color: #4a4a4a;
}
#bwbbx .popover > .arrow:after,
#bwbbx .popover > .arrow {
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  border-color: transparent;
  border-style: solid;
}
#bwbbx .popover > .arrow {
  border-width: 11px;
}
#bwbbx .popover > .arrow:after {
  content: "";
  border-width: 10px;
}
#bwbbx .popover > .close {
  position: absolute;
  top: 5px;
  right: 7px;
  display: block;
  width: auto;
  height: auto;
  color: #999;
  cursor: pointer;
}
#bwbbx .popover > .close:before {
  font-style: normal;
  font-weight: normal;
  speak: none;
  display: inline-block;
  margin: 0;
  content: 'x';
}
#bwbbx.EN form > div {
  margin-right: 8px;
}
#bwbbx.EN form div.nowrap > div {
  max-width: 98px;
}
