/* fonts */
@font-face {
	font-family: 'MainFont-B';
	src: url('fonts/OpenSans-Bold.eot');
  src: url('fonts/OpenSans-Bold.eot?#iefix') format('embedded-opentype'),
	url('fonts/OpenSans-Bold.ttf') format('truetype');
}
@font-face {
  font-family: 'MainFont-R';
	src: url('fonts/OpenSans-Regular.eot');
  src: url('fonts/OpenSans-Regular.eot?#iefix') format('embedded-opentype'),
	url('fonts/OpenSans-Regular.ttf') format('truetype');
}
@font-face {
	font-family: 'MainFont-S';
	src: url('fonts/OpenSans-Semibold.eot');
  src: url('fonts/OpenSans-Semibold.eot?#iefix') format('embedded-opentype'),
	url('fonts/OpenSans-Semibold.ttf') format('truetype');
}
@font-face {
	font-family: 'MainFont-L';
	src: url('fonts/OpenSans-Light.eot');
  src: url('fonts/OpenSans-Light.eot?#iefix') format('embedded-opentype'),
	url('fonts/OpenSans-Light.ttf') format('truetype');
}
/* Map styles */
#map {
	margin: 0 0 20px 0;
	width: auto;
	height: 950px;
}
.marker-label {
  color: #5b5a5a;
  text-align: center;
  line-height: 14px;
  font-size: 13px;
  min-width: 120px;
  height: 28px;
  padding: 6px 12px 0;
  border-radius: 4px;
  background:#fdb715;
  border: 1px solid #fff;
  text-transform: uppercase;
}
.marker-label .arr-from{
	background: url(../img/arrow-sm-r.png) no-repeat 0 1px;
	width: 9px;
	height: 12px;
	display: inline-block;
	margin: 0 0 0 4px;
}
.marker-label .arr-to{
	background: url(../img/arrow-sm-r.png) no-repeat 0 1px;
	width: 9px;
	height: 12px;
	display: inline-block;
	margin: 0 4px 0 0;
}
.map-wrapper {
	width: auto;
	height: 950px;
}
.map-arrow {
	content: "";
	position: absolute;
	width: 0;
	height: 0;
	top: 47%;
	left: 0;
	box-sizing: border-box;
	border: 40px solid black;
	border-color: transparent transparent #44a4e5 #44a4e5;
	background: #44a4e5;
	transform-origin: 0 0;
	transform: rotate(45deg);
	box-shadow: -4px 4px 4px 0 rgba(0, 0, 0, 0.5);
	margin: 0 0 0 3px;
  }

.map-form-box {
	width: auto;
	height: 950px;
	box-shadow: -4px 0 4px 0px rgba(0, 0, 0, 0.4);
}

.map-form {
	width: 354px;
	height: auto;
	position: relative;
	margin: 60px 0 0 90px;
}

.map-form .form-slogan{
	font-size: 19px;
	color: #fff;
	margin: 20px auto 0;
	background: url("../img/greekferries-club-sa-white.png") no-repeat center bottom;
	padding: 0 0 24px;
}
.map-form .form-slogan p{
	margin: 0;
	padding: 0;
	line-height: 22px;
}
.map-form .form-slogan p:first-child{
	font-size: 28px;
	padding-bottom: 16px;
}

#iw-container .iw-title {
    font-size: 15px;
	color:#3c3c3c;
}

.map-form .form-award{
	background: url("../img/golden-wreath-icon.png") no-repeat center top;
	width: 158px;
	height: 134px;
	font-size: 10px;
	margin: 80px auto 0;
}
.map-form .form-award a{
	color: #fff;
	text-decoration:none;
}
.map-form .form-award p{
	margin: 0;
	padding: 95px 0 0 0;
	line-height: 13px;
	color: #3f4045;
	text-align: center;
	font-size: 11px;
	font-weight: bold;
}
.bookingForm{
    /* font-family: MainFont-R, Ubuntu, Arial!important; */
    font-family: 'Century', Ubuntu, Arial!important;
    letter-spacing: 0px;
    color: #6D6E71;
}
.bookingForm.horizontal{
  margin: 495px 0 0 0;
  height: auto;
}
.bookingForm .formtilte{
  background: url("../img/year.png") no-repeat center top;
  width: 100%;
  height: 44px;
  font-family: MainFont-S, Ubuntu, Arial!important;
  color: #5c5d60;
  font-size: 15px;
  padding: 40px 0 0 0;
  margin: 0 0 120px 0;
  text-align: center;
}
.bookingForm .formtilte font{
  display: inline-block;
  margin: 0 0 10px 0;
}
.bookingForm .formsubtilte{
  color: #fff;
  font-size: 24px;
  text-shadow:1px 1px 3px rgba(0, 0, 0, 0.4);
  margin: 0 0 60px 0;
  text-align: center;
  font-weight: bold;
}
.col-lg-4-half{
  flex: 0 0 37%;
  max-width: 37%;
}
.col-lg-3-half{
  flex: 0 0 26%;
  max-width: 26%;
}
/* General Styles */
.light-blue {
  color: #1bb1e7;
}
::-webkit-input-placeholder {
  color: #3c3c3c;
  opacity: 1;
}
:-moz-placeholder { /* Firefox 18- */
  color: #3c3c3c;
  opacity: 1;
}
::-moz-placeholder {  /* Firefox 19+ */
  color: #3c3c3c;
  opacity: 1;
}
:-ms-input-placeholder {
  color: #3c3c3c;
  opacity: 1;
}
/*navigation*/
.navbar {
  background-image: url("../img/headerbar.png");
  height: 160px;
}
.navbar p, .navbar a, .navbar span  {
  margin-bottom: 0rem;
  font-size: 14px;
  line-height: 1rem
}
.navbar .container, .main-banner .container{
  width: 1070px ;
}
.message-bar {
  background: #e3eef9 !important;
  width: 100%;
  height: 50px;
  z-index: 1005;
  margin-top: -17px;
  border: none;

}
.main-banner {
  background: url("../img/greece-ferries-cover.jpg") no-repeat;
  height: 100vh;
  /* Flexbox */
  display: flex;
  align-items: center;
  margin-top: -210px;
}
.flag-item {
  margin: 0  !important;
}
/* Autocomplete Styles */
.autocomplete-wrapper{
  position: relative;
}
.ui-autocomplete {
  font-family: MainFont-R, Ubuntu, Arial!important;
  max-height: 286px;
  min-height: auto;
  overflow-y: auto;
  box-shadow:0px 2px 7px 3px rgba(46, 43, 43, 0.4);
  border: none!important;
  min-width: 300px !important;
  overflow-x: hidden;
  background:#f7f8fa;
}
.ui-autocomplete .ui-menu-item{
  background: #f7f8fa;
  line-height: 40px!important;
  position: relative!important;
  box-sizing: border-box;
  height: 46px!important;
  font-family: MainFont-R, Ubuntu, Arial!important;
  font-size: 18px!important;
  color: #6D6E71!important;
  padding: 0 0 0 36px !important;
  clear: left;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.ui-autocomplete .ui-autocomplete-category.ui-menu-item {
  background: #f7f8fa;
  border-top: 1px solid #aeaeae !important;
  border-bottom: 1px solid #aeaeae !important;
  font-size: 22px!important;
  font-family: MainFont-S, Ubuntu, Arial!important;
  font-weight: normal;
  padding:4px 0 0 18px !important;
  clear: left;
}
.ui-autocomplete .ui-autocomplete-category:first-child {
  border-top: none !important;
}
.ui-autocomplete .ui-autocomplete-category.ui-menu-item::before {
  content: "";
  border:none;
}
.ui-autocomplete .ui-menu-item::before {
  content:"\A";
  border-style: solid;
  border-width: 5px 0 5px 5px;
  border-color: transparent transparent transparent #756c71;
  position: absolute;
  left: 20px;
  top: 16px;
}
.ui-autocomplete .ui-menu-item:hover:before {
  border-width: 7px 0 7px 7px;
}
.ui-autocomplete .ui-menu-item font{
  font-weight: bold;
  color:#404444;
}
.ui-autocomplete .ui-menu-item .portcode{
  font-size: 14px;
  position: absolute;
  top: 10px;
  right: 16px;
  min-width: 60px;
  max-width: 100px;
  padding: 0;
  line-height: 20px;
  text-align: right;
  height: 40px;
}
.ui-autocomplete li.ui-menu-item:hover{
  background: #aae0fa;
  border:none!important;
  margin: 0!important;
  line-height: 40px!important;
}
.ui-autocomplete li div:hover, .ui-autocomplete .ui-state-active{
  background: none!important;
  border: 0!important;
  margin: 0!important;
  color: #6D6E71!important;
  font-weight: bold!important;
}
.ui-autocomplete-footer {
  height: 60px;
  background: #1bb2e9;
  box-shadow:0px 2px 7px 3px rgba(46, 43, 43, 0.4);
  border-top: none;
  text-align: center;
  position: absolute;
  color:#fff;
  cursor: pointer;
  z-index:999;
  padding: 2px;
}
.ui-autocomplete-footer a{
  display: block;
  font-size: 20px;
  font-weight: bold;
  padding:0;
  border:1px solid #fff;
  height: 56px;
  line-height: 50px;
}
/* Datepicker */
.clearDate{
  position: absolute;
  right: 31px;
  top: 2px;
  cursor: pointer;
  font-family: MainFont-B, Ubuntu, Arial!important;
  color: #005bac;
  font-size: 14px;
}
.calendar.complete .clearDate{
	color: #fff;
}
.ui-datepicker{
  font-family: MainFont-R, Ubuntu, Arial!important;
  width: 18.7em!important;
  font-size: 19px!important;
  padding: .2em .6em .2em!important;
  box-shadow:0px 2px 7px 3px rgba(46, 43, 43, 0.2);
  border-radius: 8px!important;
  border: none!important;
  margin: 107px 0 0 -23px;
}
.ui-datepicker tbody{
  border-bottom:none;
}
.ui-datepicker .ui-state-default, .ui-datepicker .ui-widget-content .ui-state-default{
  border: 1px solid #dcdcdc!important;
  border-radius: 4px!important;
  color:#6c6d6f!important;
  background: #ffffff!important;
}
.ui-datepicker tbody .ui-state-active, .ui-datepicker tbody .ui-widget-content .ui-state-active, .ui-datepicker tbody a.ui-button:active, .ui-datepicker tbody .ui-button:active, .ui-datepicker tbody .ui-button.ui-state-active:hover{
  color:#ffffff!important;
  background: #ed1b24!important;
  border: 1px solid #dcdcdc!important;
}
.ui-datepicker tbody .ui-state-hover,
.ui-datepicker tbody .ui-widget-content .ui-state-hover,
.ui-datepicker tbody .ui-widget-header .ui-state-hover,
.ui-datepicker tbody .ui-state-focus,
.ui-datepicker tbody .ui-widget-content .ui-state-focus,
.ui-datepicker tbody .ui-widget-header .ui-state-focus,
.ui-datepicker tbody .ui-button:hover,
.ui-datepicker tbody .ui-button:focus {
  color:#ffffff!important;
  background: #ed1b24!important;
  border: 1px solid #dcdcdc!important;
}
.ui-datepicker .ui-state-disabled, .ui-datepicker .ui-widget-content .ui-state-disabled{
  opacity: 1!important;
}
.ui-datepicker .ui-state-disabled .ui-state-default{
  background: #f3f3f5!important;
}
.ui-datepicker .ui-widget-header{
  border: none;
  border-bottom: 2px solid #d0d0d0;
  background: none;
  color:#373737;
  border-radius: 0;
  padding: .2em 0!important;
  font-size: 19px;
  font-weight: bold;
}
.ui-datepicker .ui-widget-header .ui-icon{
  background:url("../img/cal-arrows.png")!important;
  background-repeat: no-repeat!important;
  background-position: 0 0!important;
  width: 11px;
  height: 21px;
  cursor: pointer!important;
}
.ui-datepicker .ui-widget-header .ui-state-disabled .ui-icon{
  background:url("../img/cal-arrows-dis.png")!important;
  cursor: default!important;
}
.ui-datepicker .ui-widget-header .ui-datepicker-next .ui-icon{
  background-position: -12px 0px !important;
}
.ui-datepicker .ui-datepicker-prev{
  left: 0!important;
  width: 11px!important;
  height: 2.2em!important;
}
.ui-datepicker .ui-datepicker-next{
  right: 0!important;
  width: 11px!important;
  height: 2.2em!important;
}
.ui-datepicker .ui-state-hover,
.ui-datepicker .ui-widget-content .ui-state-hover,
.ui-datepicker .ui-widget-header .ui-state-hover {
	border: none !important;
  background: none !important;
  top:2px !important;
}
.ui-datepicker th{
  text-transform: none;
  color:#6D6E71;
  font-size: 18px !important;
  font-weight: normal!important;
}
.ui-datepicker td span, .ui-datepicker td a{
  padding: .5em .6em .5em .2em!important;
}
/* Modal for Autocomplete */
.modal{
  padding-right: 0!important;
  z-index: 99999;
}
#modalPortsList{
  width: 100%;
}
.innerPortsList{
  width: 100%;
  background: #fff;
  padding: 40px 0 60px 0;
  border: 2px solid #b6b7bb;
  box-shadow:0px 2px 7px 3px rgba(46, 43, 43, 0.2);
  border-radius: 1.5rem;
}
.portsloading{
  background:#fff url("../img/ripple.gif") no-repeat center center;
  height: 400px;
}
.modal-full {
  min-width: 110%;
  margin: 0;
}
.modal-full .modal-content {
  min-height: 100vh;
  background:rgba(0, 0, 0, 0.5);

}
.modal-full .container{
  max-width: 1070px;
  padding: 0;
}
.modal-full .modal-header{
  padding: 0 1rem;
  border-bottom: none;
}
.modal-full .modal-header .close, .modal-full .modal-header .close span{
  color: #fff;
  opacity: 1;
  text-shadow: none;
  font-size: 2.5rem;
  font-weight: normal;
}
.modal-full .modal-header .close span{
  font-size: 5rem;
}
.modal-full .modal-footer{
  border-top: none;
}
.fade-scale {
  transform: scale(0);
  opacity: 0.5;
  -webkit-transition: all .45s linear;
  -o-transition: all .45s linear;
  transition: all .45s linear;
}
.fade-scale.show {
  opacity: 1;
  transform: scale(1);
}
/* Modal Alerts */
.modal {
  font-family: MainFont-R, Ubuntu, Arial!important;
}
#errorModal .modal-title{
  font-size: 18px;
  margin-left: 10px;
}
#errorModal ul{
  list-style-type: none;
  line-height: 22px;
  color: #6D6E71;
  font-size: 15px;
  margin: 0 0 0 10px;
  padding: 0;
}

.modal .btn-dialog{
  font-size: 15px !important;
  padding: 5px 18px !important;
  background: #005bac!important;
  border-radius: 6px;
  color: #fff;
}
/* Modal Tabs */
#modalPortsList{
  width: 100%;
}
.modal{
  z-index: 99999;
}
.modal-full .nav-tabs{
  width: 100%;
  font-size: 1.6rem;
  font-family: MainFont-R, Ubuntu, Arial!important;
  position: relative;
}
.modal-full .nav-tabs::after{
  content: "";
  display: block;
  width: 100%;
  height: 10px;
  background: #fff;
  border-left: 2px solid #b6b7bb;
  border-right: 2px solid #b6b7bb;
  position: absolute;
  bottom: -9px;
  border-top-right-radius: 2rem;
}

.nav-tabs .nav-link{
  border-width:2px;
}
.nav-tabs .nav-item.show .nav-link, .nav-tabs .nav-link.active{
  border-color: #b6b7bb #b6b7bb #fff;
  border-top-left-radius: 1.5rem;
  border-top-right-radius: 1.5rem;
  color: #13b5f3;
  font-size: 24px;
  line-height: 20px;
}
.nav-tabs .nav-link span{
  font-size: 14px;
}
.nav-tabs .nav-item.show .nav-link span, .nav-tabs .nav-link.active span{
  border-bottom: 1px solid #ccc;
  color: #13b5f3;
}
.modal-full .row{
  display: flex;
  flex-wrap: wrap;
  margin-right: 0;
  margin-left: 0;
}
.modal-full .ports-columns{
  column-count: 4;
  column-gap: 1.25rem;
  font-family: MainFont-R, Ubuntu, Arial!important;
}
.modal-full .ports-wrap{
  display: inline-block;
  width: 100%;
}
.modal-full .tab-content{
  width: 100%;
  font-size: 16px;
  min-height: 500px;
  background: white;
  color: black;
  border: 2px solid #b6b7bb;
  border-top: none;
  box-shadow:0px 2px 7px 3px rgba(46, 43, 43, 0.2);
  border-radius: 0 1rem 1.5rem 1.5rem;
  padding-bottom: 30px;
}
.modal-full .nav-link{
  background: #dae3e8;
  border-top-left-radius: 1.5rem;
  border-top-right-radius: 1.5rem;
  color: #8f9297;
  font-size: 24px;
  line-height: 20px;
  border-color: #b6b7bb #b6b7bb transparent;
  padding: 2rem 3rem 2rem 3rem;
  min-width: 240px;
  box-shadow: 0px -2px 7px 3px rgba(46, 43, 43, 0.2);
}
.modal-full .nav-link a{
  color:#fff;
}
.modal-full .innerPortsList .portslist{
  padding: 0 0 0 8.2rem;
}
.modal-full .portslist{
  width: 100%;
  height: auto;
  overflow: hidden;
  padding: 0 0 0 3.2rem;
  margin:0 !important;
}
.modal-full .innerPortsList h2{
  padding: 30px 0 10px 8.2rem;
}
.modal-full h2{
  font-size: 20px;
  color: #13b5f3;
  padding: 30px 0 10px 3.2rem;
  background: none !important;
  margin: 0;
  text-transform: uppercase;
}
.modal-full .portslist .port{
  height: 24px;
  line-height: 24px;
  cursor: pointer;
  font-size: 19px;
  color:#898f8f;
  width: 100%;
  transition: all .3s ease;
}
.modal-full .portslist .port:hover{
  color: #13b5f3;
  transform: scale(1.1);
}
.modal-full .portslist .port .pcode{
  color: #5a5f5f;
}
.modal-full .portslist .port .psep{
  color: #c7c8c8;
  padding: 0 4px;
}
/* Form Styles */
.fixed-l{
  max-width: 418px!important;
}
.fixed-r{
  max-width: 535px!important;
}
.bookingForm.horizontal .fixed-r{
  max-width: 930px!important;
}
.box-wrapper {
  margin-top: 16px;
}
.bookingForm.horizontal .right-box {
  min-height: auto;
  padding-bottom: 0;
}
.right-box {
  z-index: 2;
  position: relative;
  padding-bottom: 26px;
}
.form-search-btn {
  width: auto;
  background: transparent;
}
.form-search-btn .txt {
  font-family: MainFont-S, Ubuntu, Arial!important;
  font-size: 18px;
  display: inline-block;
  min-width: 160px;
  padding: 4px 30px 6px!important;
  border-radius: 10px;
  border: 2px solid #ffffff;
  background: #005bac;
  color: #ffffff;
}
.form-search-btn .arrow {
  display: inline-block;
  content: "";
  background: #005bac url("../img/arrow-white.png") no-repeat center center;
  border-radius: 10px;
  border: 2px solid #ffffff;
  width: 40px!important;
  height: 40px;
  /* float: right; */
  margin: 0 0 0 4px;
}
.bookingForm.horizontal .form-search-btn {
  width: auto;
}
.form-group {
  position:relative;
  margin: 0 0 15px;
  background: #fff;
  border-radius: 6px;
  padding: 4px 22px;
  border: 1px solid #fff;
}
.form-group.complete {
  background: #005bac;
}
.form-route-group .form-group.complete{
	background: #fff;
	padding: 0 22px;
}
.verticalform .form-route-group .form-group.complete{
	padding: 4px 12px;
}
.form-route-group .form-group{
  margin: 0;
  padding: 0 22px;
  border:none;
}
.form-group input {
  font-size:16px;
  color: #3c3c3c;
  padding:2px 26px 9px 22px;
  display:block;
  width:100%;
  border:none;
  align-self: auto;
  background-image: url("../img/input-line-2.png"), url("../img/input-arrow.png");
  background-position: bottom left, bottom right;
  background-repeat: no-repeat;
  background-size: calc(100% - 27px) 13px, 27px 13px;
}
.form-group.form-row.calendar input{
  padding: 2px 26px 9px 50px;
}
.form-route-group .form-group.form-row.calendar input{
  padding: 12px 26px 9px 50px;
}
.form-group.form-row.calendar:before{
  content: "";
  display: block;
  background: url("../img/calendar-grey.png") no-repeat 0 0;
  width: 21px;
  height: 19px;
  position: absolute;
  left: 43px;
  top: 4px;
}
.form-route-group .form-group.form-row.calendar:before{
	top:8px;
}
.form-group.form-row.calendar.complete:before{
	background: url("../img/calendar-white.png") no-repeat 0 0;
}
.form-group.complete input {
  color: #fff;
  background-image: url("../img/input-line-2-sel.png"), url("../img/input-arrow-sel.png");
  background-color: #005bac;
}
.form-route-group input{
  font-size: 14px;
  padding: 12px 26px 9px 22px;
}
.form-route-group input#dep_1, .form-route-group input#dep_2, .form-route-group input#dep_3, .form-route-group input#dep_4{
	padding: 20px 26px 9px 22px;
}
.form-group input:focus {
    outline: none;
}
.form-box{
  font-family: MainFont-R, Ubuntu, Arial!important;
  color: #3c3c3c;
  text-align: center;
}
.form-box .date-wrap{
  position: relative;
}
.form-box .calDate {
  position: absolute;
  left: 0;
  top: 24px;
  width: 30px;
  height: 26px;
  background: #fff;
  font-family: MainFont-B, Ubuntu, Arial!important;
  font-size: 24px;
}
.mt-6, .my-6 {
  margin-top: 6rem !important;
}
.form-box .route-btn{
  display: inline-block;
  width: 36px;
  height: 36px;
  border: 1px solid #939498;
  color:#939498;
  border-radius: 4px;
  font-size: 36px;
  font-weight: bold;
  line-height: 30px;
  cursor: pointer;
  font-family: MainFont-B, Ubuntu, Arial!important;
}
.form-box .route-btn-txt {
  color: #939498;
}
.form-box .route-btn.remove{
  line-height: 27px;
}
.bookingForm.horizontal .form-box .route-btn{
  width: 20px;
  height: 20px;
  font-size: 18px;
  line-height: 16px;
}
.form-box .route-btn.disabled{
  border: 1px solid #ebebeb;
  color:#ebebeb;
  cursor: default;
}
.form-box .route-btn-txt{
  display: inline-block;
  font-size: 13px;
  height: 36px;
  line-height: 17px;
  margin: 0 6px;
  position: relative;
  top: 6px;
}
/*.form-box input.hasDatepicker {
  background-image: url("../img/calendar.png"), url("../img/input-line.png");
  background-position: center left, bottom right;
  background-repeat: no-repeat;
}*/

.form-box input img {
  max-width:20px;
}

.immybox_results {
  width: 400px !important;
}
/* Tabs */
#ferriesform .tab-content {
  align-items: center !important;
}
#ferriesform .tab-wrap {
  align-self: auto;
  width: 100%;
  position: relative;
}
.bookingForm.horizontal #ferriesform .tab-wrap {
  width: 96%;
}
#ferriesform input[type="radio"][name="tabs"] {
  display: none;
}
#ferriesform input[type="radio"][name="tabs"]:checked + .tab-label-content label {
  color: #fff;
  background: #005bac;
  box-shadow: 0 0 0 2px rgba(255,255,255,1), 0 0 0 6px rgba(0,91,172,1), 0 0 0 8px rgba(255,255,255,1);
}
#ferriesform input[type="radio"][name="tabs"]:checked + .tab-label-content .tab-content {
  display: block;
}
#ferriesform label {
  font-family: MainFont-R, Ubuntu, Arial!important;
  background: #fff;
  color: #005bac;
  font-size: 19px;
  cursor: pointer;
  text-align: center;
  border-radius: 50%;
  width: 90px;
  height: 90px;
  position: absolute;
  top:0;
  box-shadow: 0 0 0 2px rgba(0,91,172,1), 0 0 0 6px rgba(255,255,255,1), 0 0 0 8px rgba(0,91,172,1);
  padding: 26px 0 0 0;
  line-height: 21px;
}

body.nl #ferriesform label {
	font-size: 15px;
}

#ferriesform label span{
  display: block;
  font-size: 15px;
}
#ferriesform label.left{
  left:15%;
}
#ferriesform label.right{
  right:15%;
}
.tab-label-content {
  width: 100%;
}
#ferriesform .tab-label-content .tab-content {
  line-height: 130%;
  display: none;
  width: 100%;
  padding: 112px 0 0 0;
}
.bookingForm.horizontal #ferriesform .tab-label-content .tab-content {
  padding: 20px 0;
  display: block;
}
.bookingForm.horizontal .row{
  margin-right: 0;
  margin-left: 0;
}
#ferriesform .form-route-group{
  width: auto;
  height: auto;
  /* border-bottom: 1px solid #D1D3D4; */
  margin: 0;
  padding: 0;
  background: #fff;
}
#ferriesform .form-route-group:first-child{
  border-radius: 8px 8px 0 0;
}
.bookingForm.horizontal #ferriesform .form-route-group{
  border-bottom: none;
  margin: 0;
  padding: 0;
}
#ferriesform .form-route-group.complete{
  background: #EFF9FE;
}
#ferriesform .form-route-btns{
  width: auto;
  height: auto;
  border-bottom: none;
  padding: 10px 0 16px;
  margin: 0;
  background: #fff;
  border-radius: 0 0 8px 8px;
}
.bookingForm.horizontal #ferriesform .form-route-btns{
  width: 50px;
  padding: 16px 0 0 0;
}
#ferriesform .form-route-group p {
  color: #939498;
  text-align: right;
  margin: 0 22px 5px;
  padding: 15px 0 0;
  font-size: 14px;
}
.bookingForm.horizontal .tab-label-content .tab-content{
  display: flex!important;
}
/* Sidebar form */
.verticalform {
	width: 100%;
	height: auto;
	overflow: hidden;
	background: #fff;
	padding: 27px 10px 0;
	border: 1px solid #2B94BA;
	border-radius: 5px;
	margin: 16px 0 40px;
}
.verticalform .formtilte{
	display:none;
}
.verticalform .wrap{
  padding: 0;
}
.verticalform .form-group.complete{
	background: #fff;
}
.verticalform .form-group.complete input{
	background-image: url("../img/input-line-2.png"), url("../img/input-arrow.png");
	background-color: #fff;
	color: #3c3c3c;
}
.verticalform .form-group.form-row.calendar.complete:before{
	background: url("../img/calendar-grey.png") no-repeat 0 0;
}
.verticalform #ferriesform label{
	width: 80px;
	height: 80px;
	font-size: 17px;
	padding: 21px 0 0 0;
	line-height: 21px;
}
.verticalform #ferriesform label span{
	font-size: 14px;
}
.verticalform #ferriesform label.left{
	left: 10px;
}
.verticalform #ferriesform label.right{
	right: 10px;
}
.verticalform .form-group{
	padding: 4px 12px 0;
}
.verticalform .clearDate{
	right: 21px;
	top: -3px;
}
.verticalform .form-group input{
	font-size: 14px;
	padding: 2px 26px 9px 0!important;
}
.verticalform .form-group.form-row.calendar input{
	padding: 2px 26px 9px 26px!important;
}
.verticalform .form-group.form-row.calendar::before{
	left: 10px;
	top: 2px;
}
.verticalform .form-route-group .form-group.form-row.calendar::before{
	top: 2px;
}
.verticalform #ferriesform .form-route-group p{
	margin: 0 12px 0;
}
.verticalform #ferriesform .mt-5{
	margin-top: 2rem !important;
}
.verticalform .form-search-btn .txt{
	font-size: 16px;
	min-width: 140px;
	padding: 4px 20px 6px !important;
}
.verticalform .form-search-btn .arrow{
	width: 38px !important;
	height: 38px;
	margin: 0;
}
.verticalform #ferriesform .form-route-btns{
	padding: 10px 0 0;
}
.verticalform .bookingForm .fixed-l{
  display: none;
}
.verticalform .bookingForm .row{
  display: block;
}
.verticalform .bookingForm .right-box{
  margin: 8px;
  min-height: 410px;
}
.verticalform .bookingForm label{
  line-height: 28px;
  font-size: 21px!important;
}
.verticalform .bookingForm .text-right.mt-6, .verticalform .bookingForm .text-right.mt-5{
  text-align: center!important;
  margin-top: 3rem !important;
}
.verticalform .bookingForm .form-box input {
  padding: 15px 6px 15px 0px;
  font-size: 15px;
}
.verticalform .bookingForm .clearDate{
  top:5px;
}
.verticalform .bookingForm .form-box .calDate{
  display:none;
}
.verticalform .bookingForm .form-box .route-btn{
  display: block;
  float: left;
}
.verticalform .bookingForm .form-box .route-btn.remove{
  float: right;
}
.bookingForm.horizontal .form-box #tab2-content input{
  border: none;
  padding: 0 6px 17px 0;
  font-size: 16px;
  width: 100%;
  color: #6D6E71;
}
body.sidebar-content .ui-autocomplete {
  min-width: auto !important;
}
body.sidebar-content .ui-autocomplete .ui-menu-item {
    font-size: 15px !important;
    padding: 0 0 0 30px !important;
    line-height: 28px !important;
    height: 36px !important;
}
body.sidebar-content .ui-autocomplete-footer a{
	font-size: 18px;
}
body.sidebar-content .ui-autocomplete .ui-menu-item::before {
  top: 10px;
}
body.sidebar-content .ui-autocomplete .ui-menu-item:hover:before {
  border-width: 5px 0 5px 5px;
}
body.sidebar-content .ui-datepicker {
    width: auto !important;
    font-size: 15px !important;
    margin-top: 5%;
    z-index: 1000 !important;
}

@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
     /* IE10+ CSS styles go here */

	 .form-route-group input#dep_1, .form-route-group input#dep_2, .form-route-group input#dep_3, .form-route-group input#dep_4{
		padding: 10px 26px 9px 22px;
	}
	.map-form .form-slogan{
		margin:0 auto;
	}
}

/* Internet Explorer/Edge ≥ 9 ---------------------------------------------------------------------- */
@supports (-ms-ime-align:auto) {

  .ui-autocomplete .ui-menu-item, .ui-autocomplete li.ui-menu-item:hover { line-height: 12px!important;}
  .ui-autocomplete .ui-autocomplete-category.ui-menu-item{ line-height: 36px!important;}
  body.sidebar-content .ui-autocomplete .ui-menu-item{ line-height: 12px!important;}
  body.sidebar-content .ui-autocomplete-category.ui-menu-item{ line-height: 36px!important;}
}

/* Tablet Landscape--------------------------------------------------------------------------------- */
@media only screen and (min-width: 769px) and (max-width: 992px) {
  .map-form{
	background: #ffffff;
	padding: 34px 0 0;
	margin: 0;
	border-radius: 2px;
	box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 4px -1px;
  }
  .map-form-box {
	position: absolute;
	right: 10px;
	top: 60px;
	box-shadow: none;
  }
  .map-form .form-slogan, .map-form .form-award{
	display: none!important;
  }
  .map-arrow{
	display: none;
  }
  .form-box .calDate{
    display: none;
  }
  .clearDate{
	background: #ddd;
	border-radius: 50%;
	width: 20px;
	height: 20px;
	right: 26px;
	top: -9px;
  }
  .verticalform .clearDate{
	right: 14px;
	top: -9px;
  }
  .calendar.complete .clearDate {
    color: #005bac;
  }
  .form-group.complete{
	background: transparent;
  }
  .form-group.complete input{
	background-image: url("../img/input-line-2.png"), url("../img/input-arrow.png");
	background-color: #fff;
	color: #3c3c3c;
  }
  .form-group.form-row.calendar::before, .form-group.form-row.calendar.complete::before {
	background: url("../img/calendar-grey.png") no-repeat 0 0;
	top: 3px;
  }
  .form-route-group .form-group.form-row.calendar.complete::before {
	  top: 8px;
  }
  #ferriesform label{
    font-size: 23px;
  }
  .form-route-group input{
	font-size: 16px;
  }
  .form-route-group input#dep_1, .form-route-group input#dep_2, .form-route-group input#dep_3, .form-route-group input#dep_4{
	  padding: 6px 26px 9px 22px;
  }
  #ferriesform .form-route-group p{
	padding: 15px 0 0;
  }
  #ferriesform .form-route-btns{
	padding: 16px 0 0;
  }
  .bookingForm.horizontal .form-search-btn{
    margin: 30px 0 12px 0;
  }
  .bookingForm.horizontal #ferriesform .form-route-btns{
    width: 73px;
    padding: 28px 0 0 0;
  }
  .bookingForm.horizontal .form-box .route-btn{
    width: 30px;
    height: 30px;
    font-size: 22px;
    line-height: 25px;
  }
  .col-lg-4-half{
    flex: 0 0 100%;
    max-width: 100%;
  }
  .col-lg-3-half{
    flex: 0 0 100%;
    max-width: 100%;
  }
  .verticalform #ferriesform label.left {
	left: 33%;
  }
  .verticalform #ferriesform label.right{
	right: 33%;
  }
}

/* Tablet Portrait--------------------------------------------------------------------------------- */
@media only screen and (min-width: 401px) and (max-width: 768px) {
  .map-form{
	width: 90%;
	margin: 5% auto;
	background: #ffffff;
	padding: 22px 0 0;
	border-radius: 2px;
	box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 4px -1px;
  }
  .map-wrapper, .map-arrow, .map-form .form-slogan, .map-form .form-award{
	  display: none!important;
  }
  .map-form-box{
	  width: 100%;
	  height: auto;
	  box-shadow: none;
  }
  #ferriesform .form-route-btns{
	max-width:244px;
	margin:0 auto;
  }
  .bookingForm .formtilte{
    margin: 0 0 50px 0;
  }
  .bookingForm .row{
    margin:0;
  }
  .bookingForm .fixed-l{
    display: none;
  }
  .bookingForm .fixed-r{
    margin: 0 auto;
    max-width: 505px !important;
  }
  .bookingForm .row{
    display: block;
  }
  .bookingForm .right-box{
	width: auto !important;
	height: auto !important;
	padding: 16px 5% 30px !important;
  }
  .bookingForm .col-md-6{
    padding: 0;
  }
  .clearDate{
	background: #ddd;
	border-radius: 50%;
	width: 20px;
	height: 20px;
	right: 26px;
	top: -9px;
  }
  .calendar.complete .clearDate {
    color: #005bac;
  }
  .verticalform .clearDate{
	  right:14px;
	  top:-11px;
  }
  .form-group.complete{
	background: transparent;
  }
  .form-group.complete input{
	background-image: url("../img/input-line-2.png"), url("../img/input-arrow.png");
	background-color: #fff;
	color: #3c3c3c;
  }
  .form-group.form-row.calendar::before, .form-group.form-row.calendar.complete::before {
	background: url("../img/calendar-grey.png") no-repeat 0 0;
	top: 3px;
  }
  .form-route-group .form-group.form-row.calendar.complete::before {
	  top: 8px;
  }
  .bookingForm label{
    line-height: 25px;
    font-size: 20px!important;
  }
  #ferriesform label.left{
	left: 18%!important;
  }
  #ferriesform label.right{
	right: 18%!important;
  }
  .bookingForm .text-right.mt-6, .bookingForm .text-right.mt-5{
    text-align: center!important;
    margin-top: 3rem !important;
  }
  .form-route-group input{
	font-size: 16px;
  }
  .form-route-group input#dep_1, .form-route-group input#dep_2, .form-route-group input#dep_3, .form-route-group input#dep_4{
	  padding: 6px 26px 9px 22px;
  }
  #ferriesform .form-route-group p{
	padding: 15px 0 0;
  }
  .bookingForm .form-box .calDate{
    display: none;
  }
  .bookingForm .form-route-group{
    border-bottom: none;
  }
  .bookingForm .form-box .route-btn{
    display: block;
    float: left;
  }
  .bookingForm .form-box .route-btn.remove{
    float: right;
  }
  .ui-autocomplete {
    min-width: auto!important;
  }
  .ui-menu .ui-menu-item-wrapper{
	padding: 2px 0 0 5px!important;
  }
  .ui-autocomplete li.ui-autocomplete-category:hover{
	line-height:26px!important;
  }
  .ui-autocomplete .ui-menu-item .portcode{
	height: 20px;
	top: 4px;
  }
  .ui-autocomplete .ui-state-active{
	line-height:26px!important;
  }
  .ui-autocomplete .portcode.ui-state-active{
	padding: 0!important;
	line-height: 20px!important;
  }
  .ui-autocomplete .ui-autocomplete-category.ui-menu-item{
    font-size: 17px !important;
  }
  .ui-autocomplete .ui-menu-item {
    font-size: 15px !important;
    padding: 0 0 0 30px !important;
    line-height: 26px !important;
    height: 36px !important;
  }
  .ui-autocomplete .ui-menu-item::before {
    top: 10px;
  }
  .ui-autocomplete .ui-menu-item:hover:before {
    border-width: 5px 0 5px 5px;
  }
  .ui-autocomplete-footer{
    display: none!important;
  }
  .ui-datepicker{
    width: auto !important;
    font-size: 15px !important;
  }
  .ui-datepicker .ui-datepicker-title{
    font-size: 17px!important;
  }
  .ui-datepicker th{
    font-size: 16px !important;
  }
  .bookingForm.horizontal {
    margin: 260px 0 0 0;
  }
  .bookingForm .formsubtilte{
    margin: 0 0 20px 0;
  }
  .bookingForm.horizontal #ferriesform .tab-label-content .tab-content {
    padding: 20px 10px;
  }
  .bookingForm.horizontal .form-search-btn {
    margin: 20px 0 10px 0;
  }
  .bookingForm.horizontal #ferriesform .form-route-btns{
    width: 73px;
    padding: 28px 0 0 0;
  }
  .bookingForm.horizontal .form-box .route-btn{
    width: 30px;
    height: 30px;
    font-size: 22px;
    line-height: 25px;
  }
  .bookingForm.horizontal .form-box input{
    background-image: url("../img/input-line-2.png"), url("../img/input-arrow.png");
    background-position: bottom left, bottom right;
    background-size: calc(100% - 27px) 13px, 27px 13px;
  }
  .col-lg-4-half{
    flex: 0 0 100%;
    max-width: 100%;
  }
  .col-lg-3-half{
    flex: 0 0 100%;
    max-width: 100%;
  }
}

/* Mobile--------------------------------------------------------------------------------- */
@media screen and (max-width: 400px) {
  .map-form{
	width: 96%;
	margin: 2% auto;
	background: #ffffff;
	padding: 4px 0 0;
	border-radius: 2px;
	box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 4px -1px;
  }
  .map-form .col-md-12, .verticalform .col-md-12 {
	padding-right: 0px;
	padding-left: 0px;
  }
  .map-wrapper, .map-arrow, .map-form .form-slogan, .map-form .form-award{
	  display: none!important;
  }
  .map-form-box{
	  width: 100%;
	  height: auto;
	  box-shadow: none;
  }
  #ferriesform .form-route-btns{
	margin: 0 22px;
  }
  .bookingForm .row{
    margin:0;
  }
  .bookingForm .fixed-l{
    display: none;
  }
  .bookingForm .row{
    display: block;
  }
  .bookingForm .right-box{
	width: auto !important;
	height: auto !important;
	padding: 16px 0 30px !important;
  }
  .bookingForm .col-md-6{
    padding: 0;
  }
  .bookingForm label{
    line-height: 25px;
    font-size: 20px!important;
  }
  #ferriesform label.left{
	left: 10%;
  }
  #ferriesform label.right{
	right: 10%;
  }
  .clearDate{
	background: #ddd;
	border-radius: 50%;
	width: 20px;
	height: 20px;
	right: 26px;
	top: -9px;
  }
  .calendar.complete .clearDate {
    color: #005bac;
  }
  .verticalform .clearDate{
	  right: 14px;
	  top: -9px;
  }
  .form-group.complete{
	background: transparent;
  }
  .form-group.complete input{
	background-image: url("../img/input-line-2.png"), url("../img/input-arrow.png");
	background-color: #fff;
	color: #3c3c3c;
  }
  .form-group.form-row.calendar::before, .form-group.form-row.calendar.complete::before {
	background: url("../img/calendar-grey.png") no-repeat 0 0;
	top: 3px;
	left: 20px;
  }

  .form-route-group .form-group.form-row.calendar.complete::before {
	top: 8px;
  }
  .bookingForm .text-right.mt-6, .bookingForm .text-right.mt-5{
    text-align: center!important;
    margin-top: 3rem !important;
  }
  .bookingForm .form-box input{
    padding: 10px 6px 10px 0px;
	font-size: 16px;
  }
  .form-group.form-row.calendar input {
	padding: 2px 26px 9px 23px;
  }
  .form-route-group .form-group.form-row.calendar input{
	padding: 10px 6px 10px 23px;
  }
  .form-route-group input#dep_1, .form-route-group input#dep_2, .form-route-group input#dep_3, .form-route-group input#dep_4{
	  padding: 10px 26px 9px 0px;
  }
  .bookingForm .form-box .calDate{
    display: none;
  }
  .bookingForm .form-route-group{
    border-bottom: none;
  }
  .bookingForm .form-box .route-btn{
    display: block;
    float: left;
  }
  .bookingForm .form-box .route-btn.remove{
    float: right;
  }
  .ui-autocomplete {
    min-width: auto!important;
  }
  .ui-autocomplete .ui-autocomplete-category.ui-menu-item{
    font-size: 17px !important;
  }
  .ui-autocomplete .ui-menu-item {
    font-size: 15px !important;
    padding: 0 0 0 30px !important;
    line-height: 26px !important;
    height: 36px !important;
  }
  .ui-autocomplete li.ui-autocomplete-category:hover{
	line-height:26px!important;
  }
  .ui-autocomplete .ui-menu-item .portcode{
	height: 20px;
	top: 4px;
  }
  .ui-autocomplete .ui-state-active{
	line-height:26px!important;
  }
  .ui-autocomplete .portcode.ui-state-active{
	padding: 0!important;
	line-height: 20px!important;
  }
  .ui-autocomplete .ui-menu-item::before {
    top: 10px;
  }
  .ui-autocomplete .ui-menu-item:hover:before {
    border-width: 5px 0 5px 5px;
  }
  .ui-autocomplete-footer{
    display: none!important;
  }
  .ui-datepicker{
    width: auto !important;
    font-size: 15px !important;
  }
  .ui-datepicker .ui-datepicker-title{
    font-size: 17px!important;
  }
  .ui-datepicker th{
    font-size: 16px !important;
  }
  .bookingForm.horizontal {
    margin: 260px 0 0 0;
  }
  .bookingForm .formsubtilte{
    margin: 0 0 20px 0;
    font-size: 19px;
  }
  .bookingForm.horizontal #ferriesform .tab-label-content .tab-content {
    padding: 20px 10px;
  }
  .bookingForm.horizontal .form-search-btn {
    margin: 20px 0 10px 0;
  }
  .bookingForm.horizontal #ferriesform .form-route-btns{
    width: 73px;
    padding: 28px 0 0 0;
  }
  .bookingForm.horizontal .form-box .route-btn{
    width: 30px;
    height: 30px;
    font-size: 22px;
    line-height: 25px;
  }
  .col-lg-4-half{
    flex: 0 0 100%;
    max-width: 100%;
  }
  .col-lg-3-half{
    flex: 0 0 100%;
    max-width: 100%;
  }
}

@media (max-width:1000px){
  .ui-datepicker{
    margin-top:10% !important;
  }
}

@media (max-width:993px){
  body.sidebar-content .ui-datepicker {
    margin-top: 0 !important;
  }
}
