/* 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');
}
.bookingForm{
    font-family: MainFont-R;
    letter-spacing: 0px;
    color: #6D6E71;
    margin: -640px 0 0 0;
}
.bookingForm.horizontal{
  margin: -136px 0 0 0;
}
.bookingForm .formtilte{
  background: url("../img/year.png") no-repeat center top;
  width: 100%;
  height: 44px;
  color: #ffffff;
  /* color: #545454; */
  font-size: 15px;
  padding: 40px 0 0 0;
  /* //text-shadow:1px 1px 3px rgba(0, 0, 0, 0.4); */
  margin: 0 0 90px 0;
  text-align: center;
  font-weight: bold;
}
.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;
}
.bookingForm .row{
  margin-right: 0;
  margin-left: 0;
}
.typewriter{
  margin: 18% 10% 0 15%;
  height: 181px;
  color: #1bb1e7;
  font-size: 24px;
}
/* General Styles */
.light-blue {
  color: #1bb1e7;
}
::-webkit-input-placeholder {
  color: #6D6E71;
}

:-moz-placeholder { /* Firefox 18- */
  color: #6D6E71; 
}

::-moz-placeholder {  /* Firefox 19+ */
  color: #6D6E71;
}

:-ms-input-placeholder {  
  color: #6D6E71; 
}
/*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!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: 430px !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!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-weight: bold!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: 18px;
  top: 18px;
  cursor: pointer;
  font-family: MainFont-B;
}
.ui-datepicker{
  font-family: MainFont-R!important;
  width: 21.5em!important;
  font-size: 19px!important;
  padding: .6em 2.2em 2.2em!important;
  box-shadow:0px 2px 7px 3px rgba(46, 43, 43, 0.2);
  border-radius: 8px!important;
  border: none!important;
}
.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: #1bb2e9!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: #1bb2e9!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;
  color: #b4b3b3 !important;
}
.ui-datepicker .ui-widget-header{
  border: none;
  border-bottom: 2px solid #d0d0d0;
  background: none;
  color:#6D6E71;
  border-radius: 0;
  padding: .4em 0 .6em!important;
  font-size: 19px;
  font-weight: normal;
}
.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: .2em .6em .2em .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 .nav-tabs{
  margin: 0 auto;
  background-color: transparent;
}
.modal-full {
  min-width: 110%;
  margin: 0;
}
.modal-full .modal-content {
  min-height: 100vh;
  background:rgba(0, 0, 0, 0.2);
}
.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: 3rem;
}
.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!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: #0089cf!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!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!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: 1.5rem;
  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 2.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 2.2rem;
  background: none !important;
  margin: 0;
  text-transform: uppercase;
}
.modal-full .portslist .port{
  height: 34px;
  line-height: 24px;
  cursor: pointer;
  font-size: 19px;
  color:#898f8f;
  width: 100%;
  transition: all .3s ease;
  list-style-type: none;
}
.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;
}
.left-box, .right-box  {
  background: #ffffff;
  min-height: 504px;
  border-radius: 8px;
  box-shadow:0px 2px 7px 3px rgba(46, 43, 43, 0.2);
}
.bookingForm.horizontal .right-box {
  min-height: auto;
  padding-bottom: 0;
}
.right-box { 
  z-index: 2;
  position: relative;
  padding-bottom: 26px;
}
.left-box{
  min-height: 414px;
  margin: 223px 0 0 0;
  position: relative;
}
.left-box .steps {
  width: 91%;
  text-align: left;
  margin-top: 10%;
  height: 206px;
}
.left-box .step {
  font-weight: bold!important;
  font-size: 18px;
  padding: 8px 8px 8px 30px;
  position: relative;
  margin: 0 0 22px 0;
  box-shadow: 0px 2px 5px 1px rgba(0,0,0,0.3);
  border-radius: 5px;
  background-image: linear-gradient(to right, #f4f9fd, #e0f2fc, #cfecfc, #bee7fb, #ade1f9);
  letter-spacing: -0.25px;
}

html:lang(nl) .left-box .step{
	font-size: 17px;
}

.step .step1 {
  background:url("../img/step1.png") no-repeat center 0;
  display: block;
  width: 35px;
  height: 58px;
  position: absolute;
  top: -10px;
  left:-22px;
}
.step .step2 {
  background:url("../img/step2.png") no-repeat center 0;
  display: block;
  width: 35px;
  height: 58px;
  position: absolute;
  top: -10px;
  left:-22px;
}
.step .step3 {
  background:url("../img/step3.png") no-repeat center 0;
  display: block;
  width: 35px;
  height: 58px;
  position: absolute;
  top: -10px;
  left:-22px;
}

.left-box p {
  font-size: 21px;
  line-height: 28px;
  color: #6D6E71;
  padding-right: 0;
}
.gfc-logo {
  background:url("../img/gfc-logo.png") no-repeat 0 20px;
  width:200px;
  height: 60px;
  display: block;
  margin: 0 auto;
  font-size: 14px;
  text-align: center;
  font-weight: bold;
}
.blue-bar {
  background: #1bb1e7;
  margin: 10px 0; 
  height: 395px;
  border-radius: 0 8px 8px 0;
}
.form-arrow {
  background:url("../img/form-arrow.png") no-repeat;
  width:40px;
  height:75px;
  display: block;
  position: absolute;
  top:-20px;
  right:-80px;
  -webkit-transition: all 1s ease;
	-moz-transition: all 1s ease;
	-o-transition: all 1s ease;
	transition: all 1s ease;
}
.form-search-btn {
  font-weight: bold;
  font-size: 18px;
  background: #0089cf;
  padding: 4px 30px 6px!important;
  color: #ffffff;
  width: 200px;
  border-radius: 10px;
  box-shadow: inset 0 0 0 1px #0089cf, inset 0 0 0 2px #fff;
}
.bookingForm.horizontal .form-search-btn {
  width: auto;
}
.form-search-btn:hover {
  background: #0293dd;
}
.form-group {
  position:relative; 
  margin-bottom:15px; 
  margin: 0;
}
.form-group input {
  font-size:18px;
  color: #6D6E71;
  padding:25px 6px 25px 8px;
  display:block;
  width:100%;
  border:none;
  align-self: auto;
}
.form-route-group input{
  font-size: 14px;
  padding: 0px 6px 16px;
}
.form-group input:focus {
    outline: none;
}
.split{
  width: 48%;
}
.split:first-child{
  margin-right: 4%;
}
.form-box{
  font-family: MainFont-R;
  color: #6D6E71;
  text-align: center;
}
.form-box input {
  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;
  /* background:url("../img/input-line.png") no-repeat ;
  background-repeat: no-repeat;
  background-position: bottom right; */
  border: none;
}
.form-box input.loader {
  background-image:url("../img/input-line.png"), url("../img/ui-anim_basic_16x16.gif");
  background-repeat: no-repeat, no-repeat;
  background-position: bottom right, center left;
}
.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!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 #6D6E71;
  border-radius: 4px;
  font-size: 36px;
  font-weight: bold;
  line-height: 30px;
  cursor: pointer;
  font-family: MainFont-B!important;
}
.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-seperator {
  color : #1bb1e7;
  font-weight: 900;
  font-size: 35px;
  position: absolute;
  top: 0;
  text-align: center;
  width: 10%;
  margin: 0 auto;
  left: 0;
  right: 0;
}
#ferriesform .tab-wrap {
  align-self: auto;
  width: 86%;
  position: relative;
}
.bookingForm.horizontal #ferriesform .tab-wrap {
  width: 96%;
}
#ferriesform input[type="radio"][name="tabs"] {
  position: absolute;
  z-index: -7;
  top: 0;
  left:0;
}
#ferriesform input[type="radio"][name="tabs"]:checked + .tab-label-content label {
  color: #1bb1e7;
  border-bottom: 2px solid #1bb1e7; 
}
#ferriesform input[type="radio"][name="tabs"]:checked + .tab-label-content .tab-content {
  display: block;
}
#ferriesform label {
  font-family: MainFont-R!important;
  font-size: 24px;
  cursor: pointer;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  transition: color 0.2s ease;
  width: 45%;
  position: absolute;
  top:20px;
}
#ferriesform label br{
  display: none;
}
#ferriesform label.left{
  left:0;
}
#ferriesform label.right{
  right:0;
}
#ferriesform:lang(fr) label {font-size: 23px;}
.tab-label-content {
  width: 100%;
}
#ferriesform .tab-label-content .tab-content {
  line-height: 130%;
  display: none;
  background: #fff;
  width: 100%;
  padding: 90px 0 0 0;
}
.bookingForm.horizontal #ferriesform .tab-label-content .tab-content {
  padding: 20px 0;
}
#ferriesform .form-route-group{
  width: auto;
  height: auto;
  border-bottom: 1px solid #D1D3D4;
  margin: 0 0 26px 0;
  padding: 0 0 8px 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: 0;
  margin: 0;
}
.bookingForm.horizontal #ferriesform .form-route-btns{
  width: 50px;
  padding: 16px 0 0 0;
}
#ferriesform .form-route-group p {
  color: #D1D3D4;
  text-align: left;
  border-bottom: 1px solid #D1D3D4;
  background: #fff;
}
.bookingForm.horizontal .tab-label-content .tab-content{
  display: flex!important;
}
/* Sidebar form */
.verticalform {
	width: 100%;
	height: auto;
	overflow: hidden;
	margin: 0 0 60px 0;
}
.verticalform .wrap{
  padding: 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 .split{
  width: 100%;
}
.verticalform .bookingForm .split:first-child{
  margin-right: 0;
}
.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 .form-box #tab2-content input{
	padding: 0 6px 10px 0;
}
.bookingForm.horizontal .form-box #tab2-content input{
  padding: 0 6px 17px 0;
  font-size: 16px;
  width: 100%;
  color: #6D6E71;
  outline: none;
}
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;
}

/* Internet Explorer/Edge ≥ 9 ---------------------------------------------------------------------- */
@supports (-ms-ime-align:auto) {
  
  .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: 768px) and (max-width: 964px) {

  .col-md-6.fixed-r{
    flex: 0 0 58.333333%;
    max-width: 58.333333%;
  }
  .left-box p{
    font-size: 18px;
    line-height: 24px;
  }
  .left-box .steps{
    width: 95%;
  }
  .left-box .step{
    font-size: 15px;
  }
  .form-box .calDate{
    display: none;
  }
  .form-group input{
    padding: 25px 6px 25px 0;
  }
  #ferriesform label{
    font-size: 23px;
  }
  .typewriter{
    font-size: 20px;
  }
  .form-arrow{
    right: -22%;
  }
  .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;
  }
}

/* Tablet Portrait--------------------------------------------------------------------------------- */
@media only screen and (min-width: 401px) and (max-width: 768px) {
  .bookingForm{
    margin:-624px 10px 0 10px;
  }
  .bookingForm .formtilte{
    display: none;
  }
  .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{
    margin: 8px 0;
    min-height: 410px;
  }
  .bookingForm .col-md-6{
    padding: 0;
  }
  .bookingForm label{
    line-height: 25px;
    font-size: 20px!important;
  }
  #ferriesform label br{
    display: block;
  }
  #ferriesform .tab-seperator{
    top: 7px;
    font-weight: normal;
    font-size: 41px;
  }
  .bookingForm .split{
    width: 100%;
  }
  .bookingForm .split:first-child{
    margin-right: 0;
  }
  .bookingForm .text-right.mt-6, .bookingForm .text-right.mt-5{
    text-align: center!important;
    margin-top: 3rem !important;
  }
  .bookingForm .form-box input {
    padding: 15px 6px 15px 0px;
    font-size: 15px;
  }
  .bookingForm .form-box #tab2-content input{
    padding: 10px 6px 10px 0px;
  }
  #ferriesform .tab-content .text-right{
    text-align: center !important;
  }
  .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: 28px !important;
    height: 36px !important;
  }
  .ui-autocomplete li.ui-menu-item:hover {
    line-height: 28px !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;
  }
  .clearDate{
    right: 19px;
    top: 8px;
  }
  .bookingForm.horizontal {
    margin: -326px 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;
  }
}

/* Mobile--------------------------------------------------------------------------------- */
@media screen and (max-width: 400px) {
  .bookingForm{
    margin:-624px 10px 0 10px;
  }
  .bookingForm .formtilte{
    display: none;
  }
  .bookingForm .row{
    margin:0;
  }
  .bookingForm .fixed-l{
    display: none;
  }
  .bookingForm .row{
    display: block;
  }
  .bookingForm .right-box{
    margin: 8px 0;
    min-height: 392px;
  }
  .bookingForm .col-md-6{
    padding: 0;
  }
  #ferriesform .tab-label-content .tab-content{
    padding: 80px 0 0 0;
  }
  .bookingForm label{
    line-height: 22px;
    font-size: 18px!important;
  }
  #ferriesform label br{
    display: block;
  }
  #ferriesform .tab-seperator{
    top: 7px;
    font-weight: normal;
    font-size: 41px;
  }
  .bookingForm .split{
    width: 100%;
  }
  .bookingForm .split:first-child{
    margin-right: 0;
  }
  .bookingForm .text-right.mt-6, .bookingForm .text-right.mt-5{
    text-align: center!important;
    margin-top: 2rem !important;
  }
  .bookingForm .form-box input {
    padding: 15px 6px 15px 0px;
    font-size: 15px;
  }
  #ferriesform .form-route-group{
    margin: 0 0 16px 0;
    padding: 0 0 16px 0;
  }
  #ferriesform .form-route-group p{
    margin-bottom: 10px !important;
  }
  #ferriesform .tab-content .text-right{
    text-align: center !important;
  }
  .bookingForm .form-box #tab2-content input{
    padding: 10px 6px 10px 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: 28px !important;
    height: 36px !important;
  }
  .ui-autocomplete li.ui-menu-item:hover {
    line-height: 28px !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;
    padding: .6em 1.2em 1.2em !important;
  }
  .ui-datepicker .ui-datepicker-title{
    font-size: 17px!important;
  }
  .ui-datepicker th{
    font-size: 16px !important;
  }
  .clearDate{
    right: 19px;
    top: 8px;
  }
  .bookingForm.horizontal {
    margin: -370px 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;
  }
}