/* ----------- ORDER NOW - OVERALL ----------- */
.page-order-now .main {
	text-align: left;
}

/* ----------- ORDER NOW - MAIN PAGE ----------- */
.order-now-container {
	background-color: #8AC032;
	padding-bottom: 20px;
	text-align: center;
}

.order-now-container > section {
	position: relative;
	padding: 50px;
}

.order-now-container > section:before {
	position: absolute;
	top: 0;
	border-top: 36px solid #FFFFFF;
	border-left: 36px solid transparent;
	border-right: 36px solid transparent;
	content: ' ';
	left: 50%;
	margin-left: -36px;
}

/* Industry Selection */
.order-now-types {
	display: table;
	width: 100%;
}

.order-now-types > div  {
	position: relative;
	display: table-cell;
	width: 33%;
	vertical-align: middle;
	color: #32394D;
	font-size: 140%;
}

.order-now-types a {
	display: block;
	background-color: #FFFFFF;
	border-radius:  5px;
	text-transform:  uppercase;
	text-align: left;
	padding: 45px 25px 45px 100px;
}

.order-now-types a small {
	display: block;
	text-transform: none;
	font-size: 60%;
}

.order-now-types [data-type="real-estate"] {
	background: #FFFFFF url('/images/icons/order-real-estate.png') no-repeat 20px center;
}

.order-now-types [data-type="real-estate"]:hover,
.order-now-types .sel [data-type="real-estate"] {
	background-image: url('/images/icons/order-real-estate-active.png');
}

.order-now-types [data-type="business"] {
	background: #FFFFFF url('/images/icons/order-business.png') no-repeat 20px center;
}

.order-now-types [data-type="business"]:hover,
.order-now-types .sel [data-type="business"] {
	background-image: url('/images/icons/order-business-active.png');
}

.order-now-types .sel:before {
	position: absolute;
	top: 5px;
	right: 5px;
	width: 30px;
	height: 30px;
	background-color: #FFFFFF;
	border-radius: 5px;
	content: ' ';
}

.order-now-types .sel:after {
    content: '\2713';
	position: absolute;
    top: -11px;
    right: -1px;
    font-size: 200%;
}

.order-now-types .sel a,
.order-now-types a:hover {
	background-color: #148ACD;
	color: #FFFFFF;
}

/* Service List */
.order-now-list {
	margin-bottom: 10px;
}

.order-now-list li {
	background-color:  #FFFFFF;
	border-radius: 5px;
	margin-bottom: 8px;
	text-align: left;
}

.order-now-list li a {
	padding: 10px 50px;
	display: block;
	color: #32394D;
	text-transform: uppercase;
	font-size: 130%;
	position: relative;
}

.order-now-list li a:before {
	content: '+';
	font-size: 150%;
	padding: 0 15px;
	font-weight: bold;
	position: absolute;
	left: 3px;
	top: 0;
	bottom: 0;
	margin: auto;
	height: 30px;
}

.order-now-list li a small {
	text-transform: none;
	font-size: 80%;
}

/* ----------- ORDER NOW - FORMS (GLOBAL) ----------- */
.form-order-steps input[type="radio"] {
	-webkit-appearance: radio;
}

.form-order-steps input[type="checkbox"] {
	/* -webkit-appearance: checkbox; */
}

.form-order-steps abbr[title="Required"] {
	font-size: 130%;
    color: red;
    font-weight: bold;
    position: absolute;
    margin-left: 2px;
}

.form-order-steps p {
	margin-bottom: 10px;
}
.form-order-steps .vacant-prop {
	margin: 25px 0 0;
}
.form-order-steps section {
	padding-bottom: 2px;
}
.table-option-list ul li label {
	display: block;
	margin-bottom: 8px;
}
.table-option-list ul li label input {
	margin-right: 5px;
}

/* Step Headers */
.form-order-steps header {
	position: relative;
	opacity: .6;
}

.form-order-steps section.active header,
.form-order-steps section.step-done header,
.form-order-steps section.current header {
	opacity: 1;
}

.form-order-steps section.active header a,
.form-order-steps section.step-done header a,
.form-order-steps section.current header a {
	cursor: pointer;
}

.form-order-steps section.skip-step {
	display: none;
}

.form-order-steps section.step-done header:before {
    position: absolute;
    top: 10px;
    right: 5px;
    width: 30px;
    height: 30px;
    background-color: #FFFFFF;
    border-radius: 5px;
    content: ' ';
}

.form-order-steps section.step-done header:after {
    content: '\2714';
    position: absolute;
    top: 1px;
    right: -2px;
    font-size: 230%;
    font-weight: bold;
}

.form-order-steps header a {
	width: 100%;
	display: table;
	font-size: 18px;
	cursor: default;
}

.form-order-steps header a > span {
	display: table-cell;
	vertical-align: middle;
	text-transform: uppercase;
}

.form-order-steps header .step-num {
	background-color: #348bcd;
	width: 67px;
	text-align: center;
	color: white;
	border-right: 2px solid #FFFFFF;
}

.form-order-steps header .step-title {
	background: #8ac032 none no-repeat scroll 10px center;
	color: #FFF;
	text-align: left;
	padding: 15px 40px 15px 60px;
}

.form-order-steps header .step-cost {
	background-color: #8ac032;
	display: table-cell;
	width: 100px;
	color: #FFFFFF;
	text-align: right;
	padding-right: 60px;
}

.form-order-steps header .step-cost:empty {
	display: none;
}

/* Step Icons */
.form-order-steps header .icon-account {
	background-image: url("/images/icons/step-account.png");
}

.form-order-steps header .icon-property-info {
	background-image: url("/images/icons/step-propertyInfo.png");
}

.form-order-steps header .icon-tour-services {
	background-image: url("/images/icons/step-tours.png");
}

.form-order-steps header .icon-marketing {
	background-image: url("/images/icons/step-marketing.png");
}

.form-order-steps header .icon-add-ons {
	background-image: url("/images/icons/step-addons.png");
}

.form-order-steps header .icon-hosting-support {
	background-image: url("/images/icons/step-hosting.png");
}

/*.fa-with-bg{
    position: relative;
}

.fa-with-bg::after{
    position: absolute;
    content: '';
    background: #f00;
    z-index: -1;
    top: 10px;
    left: 3px;
    width: 35px;
    height: 33px;
}*/

.link-icon-terms-of-service,
.form-order-steps header .icon-terms-of-service {
    position:relative;
}    

.link-icon-terms-of-service:before,
.form-order-steps header .icon-terms-of-service:before {
    content: "\f15b";  /* this is your text. You can also use UTF-8 character codes as I do here */
    font-family: "Font Awesome 5 Pro";
    font-size: xx-large;
    color: #000;
    left:17px;
    position:absolute;
    top: 9px;
}
.link-icon-terms-of-service:before {
	position: relative;
	top: 8px;
	left: -9px;
}
.terms-service-link {
	display: block;
	line-height: 20px;
	padding: 10px 0 10px 10px;
}
.terms-of-service-section .tos-label {
	display: block;
	margin-top: 10px;
	padding-left: 20px;
}
.terms-of-service-section .tos-label:before {
	border: none;
}

.form-order-steps .buttons {
	margin-top: 10px;
	text-align: left;
}

.page-order-now .required {
	text-align: right;
	margin-bottom: 0px;
}

.page-order-now .required abbr[title="Required"] {
	font-size: 130%;
    color: red;
    font-weight: bold;
}

/* Step Content */
.form-order-steps article {
	display: table;
	padding: 20px 0 2px;
	display: none;
	text-align: left;
}

.form-order-steps section:first-child article {
	display: block;
}

.form-order-steps {
	margin-bottom: 100px;
}

.row-block {
	display: block;
	vertical-align: top;
}

.block {
	display: inline-block;
	vertical-align: top;
}

.block > h3 {
	margin-bottom: -20px;
	
}

.table {
	display: table;
	width: 100%;
}

.table-cell {
	display: table-cell;
	vertical-align: top;
}

.table-option-list > .table-cell:first-child {
	width: 40%;
	padding-right: 10px;
}

.table-option-list > .table-cell:first-child + .table-cell {
    padding: 10px 0 10px 80px;
}

.option-check-list {
	background-color: #f9fafb;
}

.option-check-list li {
	position: relative;
	border-bottom: 1px solid #F0F3F7;
}

.option-check-list li label:before {
	position: absolute;
	top: 12px;
	right: 8px;
	width: 20px;
	height: 20px;
	background: linear-gradient(to bottom, #FFFFFF, #EDEDED);
	border: 1px solid #BFBFBF;
	border-radius: 5px;
	content: ' ';
}

.option-check-list li.sel,
.option-check-list li:hover {
	background-color: #d7d7d7;
}

.option-check-list li input[type="checkbox"] {
	float: right;
}

#tos-checkbox {
	float: right;	
}

.terms-checkbox {
	position: relative;
	padding: 10px 0;
}
.terms-checkbox .tos-label:before {
	border: solid 1px #bebebe;
	position: absolute;
	top: 15px;
	right: auto;
	left: 0;
}
.terms-checkbox li.sel .tos-label:after {
	top: 10px;
	right: auto;
	left: 3px;
}
.tos-label:before {
	position: relative;
	top: 12px;
	right: 8px;
	width: 20px;
	height: 20px;
	background: linear-gradient(to bottom, #FFFFFF, #EDEDED);
	border: 1px solid #BFBFBF;
	border-radius: 5px;
	content: ' ';
}

.terms-checkbox li.sel label:after,
.option-check-list li.sel label:after {
	content: '\2714';
	position: absolute;
	top: 7px;
	right: 4px;
	font-size: 170%;
	font-weight: bold;
	color: #248CCE;
}

.option-check-list label {
	padding: 13px 10px;
	display: block;
	cursor: pointer;
}

.option-check-list select {
    width: 80%;
    margin: 0 0 10px 30px;
    display: none;
}

/* Floating Info Bar */
.order-info-bar {
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	z-index: 50;
	background-color: #FFF;
}

.order-info-bar header {
	color: #ffffff;
	background-color: #158acd;
	padding: 30px 10px;
	text-transform: uppercase;
	font-size: 16.5pt;
}

.order-info-bar header a {
	color: #FFFFFF;
	font-size: 13.5pt;
	float: right;
}

.order-info-bar article {
	background-color: #F9FAFB;
	margin: 20px auto;
	max-height: 300px;
    overflow-y: auto;
	display: none;
}

.order-info-bar article li {
	text-align: left;
	padding: 20px 65px;
	border-top: 1px solid #ECF1F5;
}

.order-info-bar article ul li:first-child {
	border-top: 0;
}

.order-info-bar article span {
	float: right;
}

.form-order-steps input[type="text"],
.form-order-steps input[type="email"],
.form-order-steps input[type="tel"], 
.form-order-steps input[type="number"], 
.form-order-steps textarea {
	resize: none;
	padding: 5px;
	margin: 5px;
	background: #fefefe;
	border: 1px solid #ccc;
	border-radius: 0.3em;
	box-shadow: inset 0.1em 0.1em 0.1em rgba(0, 0, 0, 0.1);
	transition: none;
}

.form-order-steps label {
	margin-left: 5px;
}
.form-order-steps select {
	border: 1px solid rgba(121, 128, 123, 0.37);
	padding: 5px;
	margin: 5px;
	background: #fefefe;
	border: 1px solid #ccc;
	border-radius: 0.3em;
	box-shadow: inset 0.1em 0.1em 0.1em rgba(0, 0, 0, 0.1);
 }

.align-center {
	text-align: center;
}

/* Buttons */
.form-order-steps .button {
	text-transform: uppercase;
}

.form-order-steps .arrow-back {
	border-color: #D7D7D7;
}

.form-order-steps .arrow-back:hover {
	background-color: #D7D7D7;
	color: #000000;	
}

.form-order-steps .next-step-final {
	background-color: #000000;
	color: #FFFFFF;
	border: 2px solid #000000;
}

.form-order-steps .next-step-final:hover {
	background-color: #000000;
	color: #FFFFFF;
}

.form-order-steps input[type="text"].fld-error, 
.form-order-steps input[type="email"].fld-error, 
.form-order-steps input[type="tel"].fld-error, 
.form-order-steps input[type="number"].fld-error, 
.form-order-steps textarea.fld-error {
	border: 1px solid red;
	background-color: #FFB1B1;
}

.form-order-steps input[type="text"].fld-error::placeholder, 
.form-order-steps input[type="email"].fld-error::placeholder, 
.form-order-steps input[type="tel"].fld-error::placeholder, 
.form-order-steps input[type="number"].fld-error::placeholder, 
.form-order-steps textarea.fld-error::placeholder {
	color: #000;
	opacity: .75;
	font-style: italic;
}

/* Select2 Styling */
.form-order-steps .select2-container {
	margin: 5px;
	min-width: 150px;
}

.select2-results {
	color: #000;
}

.form-order-steps select.fld-error + .select2 .select2-selection {
	border: 1px solid red;
}

input[type="number"] {
    -moz-appearance: textfield;
}

input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
}

/* Updated Order Now Page */
.order-now {
	display: flex;
	flex-wrap: wrap;
	position: relative;
}
.order-now:before {
	content: '';
	border-left: solid 40px transparent;
	border-right: solid 40px transparent;
	border-top: solid 30px #fff;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	margin: auto;
	height: 50px;
	width: 0;
}
.order-now > div {
	cursor: pointer;
  display: flex;
  justify-content: center;
  flex-direction: column;
	height: 450px;
	width: 50%;
}
.order-now > div > a {
	background-color: rgba(138, 192, 50, 0.6);
  display: flex;
  justify-content: center;
  flex-direction: column;
	height: 110px;
	transition: all 0.3s ease 0s;
}
.order-now > div:hover > a {
	height: 100%;
}
.order-now h3 {
	font-size: 30px;
	margin: 0;
	text-align: center;
}
.order-now h3 span {
	display: block;
	font-size: 24px;
}
.order-now .real-estate {
	background: transparent url(/images/layout/real-estate-image-lg.jpg) no-repeat center center scroll;
	background-size: cover;
}
.order-now .business {
	background: transparent url(/images/layout/business-image-lg.jpg) no-repeat center center scroll;
	background-size: cover;
}