/* @group Appointment*/
	
.appointment {
	width: 100%;
	max-width: 350px;
	margin: 30px auto;
	min-height: 150px;
	position: relative;
	overflow: hidden;
/* 	border: 1px solid #ddd; */
/* 	background: #f2f2f2; */
	background: #fff;
	box-shadow: 0 12px 15px 0 rgba(0, 0, 0, 0.24);
}
.form-center .appointment {
    border: 1px solid #dfdfdf;
    box-shadow: none;
    margin-top: 13px;
}
.appointment * {
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
.appointment *:hover {
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
}
.appointment * {
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
}
.appointment .step {
	float: left;
	padding: 0px;
	margin: 0;
	width: 100%;
	position: absolute;
	left: 350px;
	/* 	padding-bottom: 10px; */
}
.appointment .step.active {
	left: 0;
	display: block !important;
}
.appointment .step.one {
	z-index: 1;
}
.appointment .step.two {
	z-index: 2;
}
.appointment .step.three {
	z-index: 3;
}
.appointment .step.four {
	z-index: 4;
}
.appointment .step h2 {
	color: #333;
	text-transform: none;
	font-size: 17px;
	font-weight: 400;
	width: 100%;
/* 	background: #fff; */
/* 	color: #fff; */
	padding: 17px;
	padding-left: 30px;
	padding-bottom: 0;
/* 	border-bottom: 1px solid #e5e5e5; */
}
.appointment .step h2:before {
	width: 22px;
	height: 22px;
	text-align: center;
	border-radius: 50%;
	background: #9B1633;
	color: #fff;
	font-size: 11px;
	line-height: 22px;
	display: inline-block;
	position: relative;
	top: -2px;
	left: -8px;
	margin: 0;
}
.appointment .step.one h2:before {
	content: '1';
}
.appointment .step.two h2:before {
	content: '2';
}
.appointment .step.three h2:before {
	content: '3';
}
.appointment .step.four h2:before {
	content: '4';
}
.padding {
	padding: 20px;
	padding-top: 0;
/* 	padding-bottom: 30px; */
}
.app-x {
	position: absolute;
    top: 17px;
    right: 20px;
    z-index: 99999;
    width: 22px;
    cursor: pointer;
}
.appointment p.topper {
	margin-top:0;
}

/* @end */

/* @group Step 1*/

.zipfinder {
	width: 100%;
	overflow: hidden;
}
.zipfinder input {
	width: 65%;
	height: 38px;
	float: left;
	font-size: 16px;
	border: 1px solid #ddd;
	padding: 0 10px;
	font-family: inherit;
	font-weight: 400;
}
.zipfinder button {
	background: #9B1633;
	padding: 0 10px;
	color: #fff;
	font-size:15px;
	font-weight: 400;
	float: right;
	width: 33%;
	height: 38px;
	line-height: 36px;
	border: 0;
	outline: none;
	border-radius: 2px;
}
.zipfinder button:hover {
	background: #bb2b4b;
	cursor: pointer;
}
.campus {
	width: 100%;
	background: #fff;
	border-radius: 2px;
	padding: 10px;
	margin: 0px 0 -1px 0;    
	border: 1px solid #ddd;
	background: #fff;
	overflow: hidden;
	position: relative;
	z-index: 9;
/* 	box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2), 0 6px 10px 0 rgba(0, 0, 0, 0.3); */
}
.campus:hover {
	cursor: pointer;
/* 	box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2), 0 6px 10px 0 rgba(0, 0, 0, 0.3); */
    border: 1px solid #9B1633;
    z-index: 10;
}
.campus.selected {
	border: 1px solid #9B1633;
	background: white;
/* 	background: #9b1633; */
}
/*
.campus.selected p, .campus.select p strong {
	color: #fff;
}
*/
.campus img {
	width: 95px;
	display: inline-block;
	vertical-align: middle;
	margin-right: 15px;
}
.campus p {
	font-size: 14px;
	line-height: 18px !important;
	margin: 0px 0 0 0;
	display: inline-block;
	vertical-align: middle;
	font-weight: 400;
}
.campus p strong {
	font-size: 16px;
	font-weight: 600;
}
@media only screen and (max-width:550px) {
	.campus img {
		width: 70px;
		float: left;
		margin-right: 10px;
	}
	.campus p {
		margin-top: 8px;
		font-size: 13px;
		display: block;
		font-weight: 400;
	}
	.campus p strong {
		font-size: 14px;
		font-weight: 600;
	}
	.form-center.trigger .request_layer {
		padding: 15px !important;
	}
	.padding {
		padding: 0 15px 20px 15px;
	}
}
.appointment p.disclaimer {
	font-size: 11px;
    line-height: 14px;
    text-align: justify;
}

/* @end */

/* @group button*/

.button {
	box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.22);
    height: 45px;
    line-height: 43px;
    padding: 0 14px;
    border-radius: 2px;
    margin:15px 0px;
    font-size: 16px;
    background: #9B1633;
    color: #fff;
    text-align: center;
    width: 100%;
    outline: none;
    cursor: pointer;
}
.button:hover {
	background: #90102c !important;
	color: #fff !important;
}
.button.back {
	width: 48%;
	float: left;
}
.button.next {
	width: 48%;
	float: right;
}
.button.full {
	width: 100%;
	float: none;
}

/* @end */

/* @group Date Picker*/

.material-datepicker {
	display: block !important;
	position: relative !important;
	border: 1px solid #ddd !important;
	top: 0 !important;
	left: 0 !important;
}

/* @end */

/* @group Time Slots */

.appointment .step.three {
	height: 440px;
}
.appointment .step.three.active {
	height: auto;
}
.times {
	width: 100%;
	margin-bottom: 10px;
	position: relative;
}
.slot {
	width: 100%;
	background: white;
	text-align: center;
	padding: 12px;
	margin: -1px 0;
	border: 1px solid #ddd;
	font-size: 14px;
	font-weight: 600;
	color: #333;
	z-index: 1;
	position: relative;
	cursor: pointer;
}
.slot.date_slot {
	font-size: 16px;
	font-weight: 600;
}
.slot span {
	font-style: italic;
	font-size: 12px;
	font-weight: 400;
}
.appointment.test .slot {
	font-size: 16px;
}
.slot:hover {
	border: 1px solid #9b1633;
	cursor: pointer;
	z-index: 10;
	color: #9b1633;
}
@media only screen and  (max-width:550px) {
	.slot:hover {
		border: 1px solid #ddd;
		color: #333;
	}
}
.slot.selected {
	background: #9B1633;
	color: #fff;
}
.show-more {
    width: 100%;
    background: white;
    text-align: center;
    padding: 12px;
    margin: -1px 0;
    border: 1px solid #ddd;
    font-size: 13px;
    color: #3D31D6;
    z-index: 1;
    position: relative;
}
.show-more:hover {
	background: #eee;
	cursor: pointer;
}

/* @end */

/* @group New Title Bar */

.appointment .title-bar, .trigger .title-bar {
/* 	background: #000; */
	background: #fff;
    padding: 10px 0 0 20px;
    padding-top: 15px;
    width: 100%;
    overflow: hidden;
    margin: 0 0px 0px 0px;
    position: relative;
    /* box-shadow: 0px 2px 3px rgba(0,0,0,0.25); */
    height: 52px;
    margin-bottom: 10px;
    text-align: left;
}
.appointment .title-bar h1, .trigger .title-bar h1 {
	margin: 0;
    padding: 0;
    font-size: 18px;
    font-weight: 600;
    /* color: #fff; */
    color: #9B1633;
    /* float: left; */
    text-transform: none;
    vertical-align: middle;
    display: inline-block
}
.appointment .title-bar h1 strong {
	font-weight: 600;
}
.appointment .title-bar a {
	color: #fff;
}
.appointment .title-bar a.link {
	font-size: 16px;
}
.appointment .title-bar a.back, .appointment .title-bar a.back {
	width: 30px;
    position: relative;
    left: 0;
    top: 0;
    bottom: 0;
    background-color: #9B1633;
    border-radius: 50%;
    margin: 0 5px 0 0;
    height: 30px;
    display: inline-block;
    vertical-align: middle;
}
a.back:hover, a.back:hover {
	opacity: .8;
}
a.back img, a.back img {
	margin-top: 1px;
    width: 90%;
    margin-left: 1px;
}
.backspace {
	float: left;
	width: 50px;
	height: 20px;
}
.appointment h3 {
	font-size: 16px;
	font-weight: 600;
	color: #9B1633;
	margin-top: 30px;
	margin-bottom: 5px;
}

/* @end */

/* @group Form*/
.confirm, .message {
	width: 100%;
	padding: 0 10px;
	text-align: center;
	background: white;
	border: 1px solid #ddd;
	margin-bottom: 20px;
	background: #f2f2f2;
}
.form-center .confirm {
	text-align: left;
	padding: 15px;
}
.confirm.warn {
	background: #9B1633;
	color: #fff;
}
.confirm p, .message p {
	font-size: 15px;
    line-height: 23px;
}
.confirm p span {
    width: 72px;
    display: inline-block;
    text-align: right;
    margin-right: 10px;
}
.appointment .step input {
	-webkit-appearance: none;
	border-radius: 0;
}
.appointment .step form input {
	height: 40px;
	border: 1px solid #ddd;
	padding: 0 15px;
	margin-bottom: 5px;
	text-indent: 0;
	width: 100%;
	font-size: 14px;
	font-family: inherit;
	font-weight: 300;
	background: white;
	-webkit-appearance: none;
	outline-offset: 0 !important;
}
.appointment .step form input.needsfilled {
	    background: #ffebe8 !important;
}
.appointment .step form input.submitButton {
	width: 100%;
	background: #9B1633;
	color: #fff;
	font-size: 18px;
	margin-top: 10px;
	height: 50px;
	line-height: 18px;
	font-weight: 400;
	border: 0;
}

/* @end */

/* @group Confirm Table*/

.confirm table {
	width: 100%;
	margin: -5px 0 15px 0;
}
.confirm.conflict p:first-child {
	margin-top: 0;
}
.confirm table tr td {
	vertical-align: top;
	font-size: 14px;
	font-weight: 600;
}
.confirm table tr td.label {
	text-align: right;
	padding-right: 10px;
	font-weight: 400;
	font-size: 12px;
	line-height: 18px;
	width: 55px;
}

/* @end */

/* @group Calendar*/
/*
.appointment {
	height: 600px !important;
}
*/
.holder {
	height: 280px;
}
.form-center .holder {
	height: 300px;
}
.spinner-group {
	position: relative;
	width: 100%;
}
.spinner {
	position: absolute;
	background: #fff;
	width: 100%;
	z-index: 99;
	top:0;
	left: 0;
	height: 280px;
	text-align: center;
}
.form-center .spinner {
    border: 1px solid #ddd;
    height: 300px;
    margin-bottom: 15px;
}
.spinner img {
	max-width: 350px;
	width: 100%;
	display: inline-block;
}
.spinner p {
	position: absolute;
	top:0;
	width: 100%;
	margin-top: 200px;
	text-align: center;
	z-index: 999;
}
#datepicker,  #datepicker-apply {
	width: 100%;
	padding: 15px;
	background: #fff;
	position: relative;
	border: 1px solid #ddd;
}
table.ui-datepicker-calendar {
	width: 100%;
}
table.ui-datepicker-calendar tr td {
	text-align: center;
} 
#datepicker td,  #datepicker-apply td {
	border-radius: 50%;
	height: 37px;
	width: 14.2%;
}
.ui-datepicker table {
	border-collapse: collapse;
}
.appointment .ui-widget-content .ui-state-default, .appointment .ui-state-default {
	width: 100%;
	border-radius: 50%;
	text-align: center;
	text-decoration: none;
	color: #333;
	max-width: 35px;
	line-height: 34px;
	height: 35px;
	display: inline-block;
	border: 1px solid #fff;
	font-size: 14px;
}
.appointment .ui-widget-content .ui-state-default:hover {
	border: 1px solid #9b1633;
	color: #9b1633;
}
.ui-widget-content .ui-datepicker-current-day .ui-state-default {
	background: #9B1633;
	border: 1px solid #9b1633;
	color: #fff !important;
 }
 .ui-datepicker-unselectable.ui-state-disabled span {
	 color: #dedede !important;	
	 border: 1px solid #fff !important;
 }
 #datepicker thead tr th,  #datepicker-apply  thead tr th {
	 font-size: 11px;
	 padding: 18px 0;
 }
  #datepicker thead,  #datepicker-apply thead {
	 margin: 10px 0;	  
  }
  
  /* Title */
input.ui-button::-moz-focus-inner,
button.ui-button::-moz-focus-inner {
	border: 0;
	padding: 0;
}
.ui-datepicker .ui-datepicker-header {
	position: relative;
	padding: .2em 0;
}
.ui-datepicker .ui-datepicker-prev {
	left: 2px;
}
.ui-datepicker .ui-datepicker-next {
	right: 2px;
}
.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next {
	position: absolute;
	top: 9px;
	width: 8px;
	height: 16px;
}
.ui-widget-header .ui-icon.ui-icon-circle-triangle-e {
    background-image: url("images/arrow_right.png");
}
.ui-widget-header .ui-icon.ui-icon-circle-triangle-w {
    background-image: url("images/arrow_left.png");
}
.ui-icon {
    width: 16px;
    height: 16px;
}
.ui-icon {
    display: block;
    text-indent: -99999px;
    overflow: hidden;
    background-repeat: no-repeat;
}
.ui-datepicker .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-next span {
	display: block;
	position: absolute;
	left: 50%;
	margin-left: -6px;
	top: 50%;
	margin-top: -8px;
}
.ui-datepicker .ui-datepicker-title {
	margin: 0 2.3em;
	line-height: 1.8em;
	text-align: center;
}
.ui-datepicker .ui-datepicker-title select {
	font-size: 1em;
	margin: 1px 0;
}
.ui-datepicker select.ui-datepicker-month,
.ui-datepicker select.ui-datepicker-year {
	width: 45%;
}
p.appt-more {
	font-size: 14px;
	line-height: 20px;
	width: 100%;
	text-align: center;
	margin: 15px 0 0;
}

/* @end */

/* @group Modal*/

.layer-back {
	display: none;
	position: fixed;
	background: black;
	top:0;
	bottom: 0;
	left: 0;
	right: 0;
	opacity: .65;
	z-index: 9999999;
}
.layer-group {
	position: absolute;
	top: -999px;
	left: 50%;
	margin-top: 120px;
	margin-left: -175px;
	z-index: 999999999999999999999;
	width: 350px;
}

/* @end */

/* @group Completion Bar*/

.completion {
	width: 100%;
/* 	max-width: 300px; */
	overflow: hidden;
	padding-bottom: 20px;
	margin: 0 auto 15px;
	text-align: center;
	position: relative;
	z-index: 1;
}
.check {
	display: inline-block;
    margin-left: -2px;
    margin-right: -2px;
	width: 19%;
	text-align: center;
	position: relative;
}
.check.one {
/* 	margin-left: -12%; */
}
.check.one.apply_text {
	margin-left: 0;
}
.check.one.apply_text:after {
	display: none;
}
.check.last {
/* 	margin-right: -12%; */
}
.check .circle:after {
    position: absolute;
    top: 29px;
    left: -15px;
    right: -15px;
    text-align: center;
    color: #bbb;
    font-size: 11px;
}
.check * {
	 transition: all 0.4s ease-in;
    -ms-transition: all 0.4s ease-in;
    -moz-transition: all 0.4s ease-in;
    -webkit-transition: all 0.4s ease-in;
}
.check.one .circle:after {
	content: "Info";
}
.check.one.apply_text .circle:after {
	content: "Apply Now";
	white-space: nowrap;
}
.check.two .circle:after {
	content: "Campus";
}
.check.three .circle:after {
	content: "Date";
}
.check.four .circle:after {
	content: "Time";
}
.check.five .circle:after {
	content: "Finish";
}
.check:after, .check:before {
	content:'';
	position: absolute;
	top: 50%;
	margin-top: -2px;
	background: #eee;
	height: 2px;
}
.check:after {
	left: 50%;
	right: 0;
}
.check:before {
	right: 50%;
	left: 0;
}
.check.one:before, .check.last:after {
	display: none;
}
.check .circle {
	border-radius: 50%;
	width: 35px;
	height: 35px;
	font-size: 14px;
	line-height: 34px;
	text-align: center;
	display: inline-block;
	background: #eee;
	color: #bbb;
	vertical-align: middle;
	position: relative;
	z-index: 99;
}
.check .circle img {
	opacity: 0;
    transition: opacity 0.4s ease-in;
    -ms-transition: opacity 0.4s ease-in;
    -moz-transition: opacity 0.4s ease-in;
    -webkit-transition: opacity 0.4s ease-in;
	position: absolute;
    top: 50%;
    left: 50%;
    width: 18px;
    margin-left: -9px;
    margin-top: -10px;
}
.check.active .circle {
	background: #9B1633;
	color: #fff;
	font-weight: 600
}
.check.active .circle:after {
	color: #9B1633;
	font-weight: 600;
}
.check.complete .circle:after {
	color: #4CAF50;
}
.check.complete .circle {
	background: #4CAF50;
}
.check.complete span {
	display: none;
}
.check.complete img {
	opacity: 1;
    transition: opacity 0.4s ease-in;
    -ms-transition: opacity 0.4s ease-in;
    -moz-transition: opacity 0.4s ease-in;
    -webkit-transition: opacity 0.4s ease-in;
}
.check.active:before, .check.complete:before, .check.complete:after {
	background: #4CAF50;
}
#applyNow {
	display: none;
}
.step .request_layer form input.button.apply {
	box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.22);
    height: 45px;
    line-height: 43px;
    padding: 0 14px;
    border-radius: 2px;
    margin: 15px 0px;
    font-size: 16px;
    font-weight: 400;
    background: #9B1633;
    color: #fff;
    text-align: center;
    width: 100%;
    outline: none;
    cursor: pointer;
    margin-bottom: 7px;
    margin-top: 0;
}
.error {
	background: #ffebe8 !important;
	border: 1px solid #e49f9f !important;
    padding: 5px 5px 5px 10px;
    margin-bottom: 10px;
    width: 100%;
    display: none;
}
.error p {
	margin: 0;
    width: 100%;
    display: block;
}
#shedule_tour, #custom_appt {
	display: none;
}
#datepicker2 {
	position: relative;
}

/* @end */

/* @group Checkbox*/

.checkbox {
	margin-bottom: 20px;
	overflow: hidden;
}
.top-label {
  display: block;
  margin: 10px 0;
}

.step input[type="checkbox"], .step input[type="radio"] {
  position: absolute !important;
  left: -9999px;
  background: none !important;
  width: 25px !important;
  height: 25px !important;
  display: inline-block !important;
  -webkit-appearance: radio !important;
  appearance: radio-button !important;
  padding: 0 !important;
  outline: none !important;
  float: left;
}
@media \0screen\,screen\9 {
	.step input[type="checkbox"], input[type="radio"] {
		position: relative !important;
		left: 0;
	}
}

.side-label {
  display: block;
  position: relative;
  margin: 2px 0 11px;
  padding-left: 30px;
  cursor: pointer;
  font-size: 15px;
}

.side-label::before, .side-label::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
}

input[type="radio"] + .side-label::before,
input[type="radio"] + .side-label::after {
  width: 25px;
  height: 27px;
  border: 0px solid #fff;  
  background: url(/images/radios.png) no-repeat;
  background-size: 30px;
  background-position-y: 0px;
  top:-5px;
}

.side-label::before {
  border: 0;
}

.side-label::after {
  display: none;
}

input:checked + .side-label::after {
  display: block;
  background-position-y: -120px !important;
  top: -3px !important;
}

/* @end */

/* @group Long Form*/

form h3 {
	font-size: 14px;
	font-weight: 600;
	font-style: italic;
	margin: 25px 0 6px 0;
	color: #9B1633;
}
form h3.one:before {
	content: '1';
}
form h3.two:before {
	content: '2';
}
form h3.three:before {
	content: '3';
}
form h3.four:before {
	content: '4';
}
form h3:before {
	width: 21px;
	height: 21px;
	line-height: 21px;
	display: inline-block;
	font-size: 12px;
	color:#fff;
	background: #9B1633;
	border-radius: 125px;
	margin: 0 5px 0 0px;
	font-weight: 700;
	text-align: center;
	position: relative;
	top:-1px;
}
.appointment .step form.sst_form input {
    border: 0;
    height: 45px;
    margin-bottom: 0;
    outline: 1px solid #e4decb;
}
form.sst_form .half {
	width: 50% !important;
	float: left;
	border: 0;
	outline: 1px solid #e4decb;
	margin: 0;
}
form.sst_form .full {
	width: 100% !important;
	float: left;
	border: 0;
	outline: 1px solid #e4decb;
	margin: 0;
}
form.sst_form .half.left {
	border-right: 0 !important;
}
form.sst_form .half.right {
	margin-right: 0;
}
/*Drop Down*/
form.sst_form .drop_line {
	background: #fff url(/images/drop_arrow2.png) no-repeat right;
	height: 45px !important;
	padding: 0px;
	display: inline-block;
	border-radius: 0px;
	width: 100%;
	margin-bottom: 0px;
	margin-top: 0px;
	border: 0px solid #ddd;
	max-width: none;
}
form.sst_form span.drop {
	width: 100%;
	display: inline-block;
}
form.sst_form span.drop select {
	background:none;
	height: 45px;
	position: relative;
	top: 0px;
	border: 0px solid #ddd;
	border-radius: 0px;
	padding: 10px 7px 10px 10px;
	text-indent: 0px;
	vertical-align: middle;
	font-size: 14px;
	font-weight: 300;
	width: 100%;
    margin: 0;
    outline:none;
    display: inline-block;
    -webkit-appearance:none;
    -moz-appearance:none;
    appearance:none;
    cursor:pointer;
    color: #999;
}
form.sst_form span.drop select.CareerPref {
	color: #000;
}
form.sst_form .drop_arrow {
	position: absolute;
	top: 6px;
	left: 369px;
	z-index: 1;
	width: 18px;
}
.appointment .step form.sst_form input.submitButton {
	margin-top: 15px;
}
form.sst_form .needsfilled {
	background: #fcebeb url(/images/drop_arrow2.png) no-repeat right !important;
	outline: 1px solid #e49f9f !important;
	color: #000 !important;
	border: 0 !important;
}

/* @end */

@media only screen and  (max-width:550px) {
	.appointment .title-bar, .trigger .title-bar {
		padding: 10px 0 0 15px;
		margin-bottom: 5px;
	}
	.form-center #spinner1 {
		margin-top: -10px;
	}
	.check {
		width: 21%;
	}
	.check.last {
		margin-right: -12px;
	}
	.check.one {
		margin-left: -12px;
	}
	.layer-trigger .appointment {
		width: 100%;
		top: -2200px;
	    bottom: 1600px;
	    left: 0;
	    right: 0;
	    background: #fff;
	    overflow-y: scroll;
	    margin: 0;
	    position: fixed;
	    height: auto !important;
	    max-width: none;
	}
	.appointment .step {
		left: 450px;
	}
	.layer-back {
		background: #fff;
		opacity: 1;
		position: fixed;
		width: 100%;
		top: -2200px;
	    bottom: 1600px;
	    left: 0;
	    right: 0;
	    display: block;
	}
}

/* @group Slit Button*/

form .button.split {
	width: 46%;
	float:left;
	height: auto;
    line-height: 20px;
    padding: 13px 0 16px;
    font-size: 16px;
}
form .or {
	width: 8%;
	float: left;
	text-align: center;
	padding: 38px 0;
}
.trigger .request_layer span.drop select.program.CareerPref {
	color: #000;
}
.loader {
	display: none;
	text-align: center;
    height: 50px;
    padding-top: 15px;
}
.layer-trigger .loader {
	text-align: center;
    height: 62px;
    padding-top: 22px;
    float: left;
    width: 100%;
}

/* @end */