/**
 * Reservations
 * ------------
 */
.reservations	#lightbox-content {
	background-color: #f5f5f5;
	}

.reservations #content p {
	max-width: 700px;
	margin: 0 auto;
	padding: 0 10%;
	color: #3e3e3e;
	}


#reservations-header {
	width: 100%;
	height: 400px;
	min-height: 400px;
	display: table;
	text-align: center;
	text-transform: uppercase;
	background: url(../img/reservations-header-bg-pattern.jpg) repeat;
	}
#reservations-header-content {
	width: 100%;
	height: 100%;
	max-width: 1024px;
	display: table-cell;
	vertical-align: middle;
	background: #969c9f url(../img/reservations-header-bg.jpg) no-repeat center center;
	background-size: cover !important;
	}
#reservations-header h2 {
	margin: -20px 0 0 0;
	color: #fff;
	font-size: 5.5em;
	font-family: 'TriviaSerifLight';
	text-transform: uppercase;
	}
#reservations-header p {
	margin: 0 auto;
	color: #3e3e3e;
	text-transform: none;
	}

#reservations-content {
	padding: 75px 0;
	text-align: center;
	position: relative;
	}
#reservations-content a {
	color: #e40280;
	}

#reservation-steps { 
	background: #f2f2f2;
	}
#reservation-steps-container { 
	margin: 0 auto;
	max-width: 1024px;
	}
#reservation-steps .reservation-step {
	width: 33%;
	margin: 0 0.5% 0 0;
	padding: 75px 0;
	display: block;
	float: left;
	position: relative;
	}
#reservation-steps .reservation-step:last-child {
	margin: 0;
	}
#reservation-steps .reservation-step .number {
	width: 112px;
	height: 112px;
	margin: 0 auto;
	display: block;
	color: #3e3e3e;
	font-size: 4em;
	font-family: 'TriviaSerifLight';
	text-align: center;
	line-height: 112px;
	background-color: #000;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	border-radius: 50%;
	}
#reservation-steps .reservation-step-content {
	padding: 5%;
	text-align: center;
	}
#reservation-steps .reservation-step-content h4 {
	color: #3e3e3e;
	font-size: 1.75em;
	font-family: 'BebasNeueRegular';
	}
#reservation-steps .reservation-step-content p {
	max-width: 170px;
	}

#reservation-event {
	width: 100%;
	height: 250px;
	clear: both;
	background-color: #fff;
	}
#reservation-event .btn {
	margin: 0;
	}

.reservations .skip-btn {
	display: none;
	font-size: 4em;
	}


#reservations-content-header {
	width: 100%;
	background-color: #fff;
	}
ul#reservation-steps {
	width: auto;
	max-width: 680px;
	margin: 0 auto;
	padding: 50px 0;
	display: block;
	position: relative;
	background-color: #fff;
	}
ul#reservation-steps li {
	width: 120px;
	display: inline-block;
	position: relative;
	vertical-align: top;
	}
ul#reservation-steps li span {
	width: 108px;
	height: 108px;
	margin: 0 auto;
	display: block;
	color: #fff;
	font-size: 5em;
	font-family: 'TriviaSerifLight';
	text-align: center;
	line-height: 108px;
	background-color: #f5f5f5;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	border-radius: 50%;
	}
ul#reservation-steps li.active span {
	color: #3e3e3e;
	background-color: #000;
	}
ul#reservation-steps li.small {
	width: 35px;
	margin: 48px 0 0 0;
	}
ul#reservation-steps li.small span {
	width: 22px;
	height: 22px;
	margin: 0 auto;
	display: block;
	text-align: center;
	background-color: #f5f5f5;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	border-radius: 50%;
	}
ul#reservation-steps li p {
	margin: 10px 0 0 0;
	display: block;
	font-size: 0.75em;
	text-align: center;
	}

ul#reservation-steps #bg-line {
	width: 100%;
	height: 0;
	position: absolute;
	left: 0;
	top: 60px;
	z-index: 0;
	/*border-bottom: 1px solid #3e3e3e;*/
	}


#content form#reservation-form,
#lightbox form#reservation-form {
	width: auto;
	margin: 0 auto;
	max-width: 1024px;
	}
#reservation-content {
	width: 100%;
	margin: 0 auto;
	padding: 0 0 5% 0;
	display: table;
	background-color: #f5f5f5;
	}
#reservation-content-left,
#reservation-content-right {
	width: 40%;
	padding: 0 5%;
	display: table-cell;
	text-align: left;
	vertical-align: top;
	}
#reservation-content-left {
	padding: 50px 5% 0 5%;
	}
#reservation-content-right {
	width: 60%;
	margin: 0;
	padding: 0;
	}
#reservation-content-wide {
	width: auto;
	padding: 50px 0 0 0;
	text-align: center;
	}
#reservation-content-left h3,
#reservation-content-left h4,
#reservation-content-right h3,
#reservation-content-right h4,
#reservation-content-wide h3,
#reservation-content-wide h4  {
	font-size: 1.5em;
	font-family: 'BebasNeueRegular';
	}

#reservation-content-left .user-response {
	padding: 30px 0;
	font-size: 1.25em;
	}
#reservation-content .text-purple {
	color: #bd1a8d;
	}

#reservation-content-left a,
#reservation-content-right a {
	color: #bd1a8d;
	}

#reservation-footer {
	width: auto;
	margin: 0 auto;
	padding: 50px 0;
	display: block;
	clear: both;
	text-align: right;
	}

#reservation-login,
#reservation-guest-checkout {
	width: auto;
	padding: 0;
	display: none;
	clear: both;
	text-align: left;
	}
#reservation-login {
	margin: 100px 0 20px 0;
	display: block;
	}
#reservation-guest-checkout {
	}

#reservation-form a#login-btn,
#reservation-form a#guest-checkout,
#reservation-form a#guest-checkout-submit {
	width: auto;
	min-width: 0;
	background-color: #ffc20e; 
	}
#reservation-form input {
	margin: 0 !important;
	}
#reservation-form #reservation-content-right a#lost_password-btn,
#reservation-form #reservation-content-right a#register-btn {
	margin: 0 6px;
	color: #3e3e3e;
	font-size: 0.8em;
	}

#floors {
	display: block;
	position: relative;
	overflow: hidden;
	}
#floors .floor {
	width: 320px;
	max-width: 50%;
	height: 480px;
	padding: 0;
	float: left;
	cursor: pointer;
	position: relative;
	}
#floors .floor.active {
	background-color: lightgreen;
	}
#floors .floor-bg {
	top: 0;
	position: absolute;
	z-index: 1;
	}
#floors .floor-image {
	position: relative;
	z-index: 2;
	}
#floors svg {
	top: 0 !important;
	left: 0 !important;
	position: absolute !important;
	z-index: 3;
	}

#floorsection {
	background-color: #f5f5f5;
	}


/*
#floors rect,
#floors path,
#floors shape {
	fill: #fff;
	stroke: #3e3e3e;
	stroke-width: 1.5px;
	transition: all 250ms ease;
	}
#floors rect:hover,
#floors path:hover,
#floors shape:hover {
	fill: lightgreen;
	}
#floors rect.active,
#floors path.active,
#floors shape.active {
	fill: lightgreen;
	}
#floors text,
#floors .text {
	font-size: 2em;
	fill: #3e3e3e;
	}
*/

#floor-tables {
	height: 280px;
	padding: 20px;
	display: block;
	position: relative;
	outline: 1px solid #e3e3e3;
	}
#floor-tables .floor-table {
	width: 60px;
	height: 60px;
	cursor: pointer;
	position: absolute;
	}
#floor-tables .floor-table:hover,
#floor-tables .floor-table.active {
	background-color: lightgreen !important;
	}
#floor-tables .floor-table.seats-2 {
	background: transparent url(../img/seats-2.png) no-repeat center center;
	}
#floor-tables .floor-table.seats-4 {
	background: transparent url(../img/seats-4.png) no-repeat center center;
	}
#floor-tables .floor-table.seats-6 {
	background: transparent url(../img/seats-6.png) no-repeat center center;
	}
#floor-tables .floor-table.seats-8 {
	background: transparent url(../img/seats-8.png) no-repeat center center;
	}



.reservations #phone {
	font-size: 1em; 
	font-family: 'BebasNeueRegular';
	}

/* tablet to smartphone */
@media all and (max-width: 767px) {

	ul#reservation-steps {
		padding: 10px 0;
		}
	ul#reservation-steps li {
		width: 68px;
		}
	ul#reservation-steps li.small {
		width: 35px;
		margin: 24px 0 0 0;
		}
	ul#reservation-steps li p {
		display: none;
		}
	ul#reservation-steps li span {
		width: 64px;
		height: 64px;
		font-size: 2.5em;
		line-height: 64px;
		}

	#reservation-content {
		padding: 0 5%;
		}
	#reservation-content-left {
		text-align: center;
		}

}
@media all and (max-width: 624px) {

	#reservation-content-left,
	#reservation-content-right {
		width: 100%;
		float: none;
		margin: 0;
		}

	.reservations #phone {
		color: #000;
		font-size: 0.5em; 
		font-family: 'BebasNeueRegular';
		}
	#lightbox .reservations #phone {
		font-size: 2.5em;
		}

}

@media all and (max-width: 320px) {

	.reservations #reservation-steps h3 {
		font-size: 0.4em;
		margin: 0 !important;
		padding: 0 !important;
		}

}
