/**
 * HTML
 */
html, body {
	width: 100%;
	min-height: 100%;
	margin: 0;
	padding: 0;
	font-family: "Exo", sans-serif;
	font-size: 1em;
	color: #30373b;
	}


/**
 * HTML elements
 */
a {
	color: #1c73b6;
	text-decoration: underline;
	transition: all 0.2s ease;
	-moz-transition: all 0.2s ease;
	-webkit-transition: all 0.2s ease;
	-ms-transition: all 0.2s ease;
	-o-transition: all 0.2s ease;
	}

a:hover {
	color: #8ec549;
	}

img {
	border: none;
	}

p {
	margin: 0;
	padding: 10px 0;
	font-size: 1em;
	line-height: 1.5em;
	}

ul, ol {
	margin: 0;
	padding: 10px 0 10px 25px;
	}

li {
	font-size: 0.9em;
	line-height: 1.5em;
	}

li li {
	font-size: 1em;
	}

hr {
	margin: 21px 0 20px 0;
	padding: 0;
	border: #8ec549 dotted;
	border-width: 1px 0 0 0;
	}

h2 {
	margin: 0 0 15px 0;
	padding: 0;
	font-size: 1.4em;
	font-weight: normal;
	}


/**
 * forms
 */
input[type="radio"], input[type="checkbox"] {
	margin: 0;
	padding: 0;
	}


/**
 * common classes
 */
.pointer {
	cursor: pointer;
	}

.textcenter {
	text-align: center;
	}

.textright {
	text-align: right;
	}


/**
 * wraps
 */
#order_wrap_outer {
	position: absolute;
	left: 0;
	top: 0;
	display: table;
	width: 100%;
	height: 100%;
	}

#order_wrap_middle {
	width: 100%;
	height: 100%;
	display: table-cell;
	vertical-align: middle;
	background: #ebeef0;
	}

#order_wrap_inner {
	position: relative;
	width: 870px;
	height: 80%;
	margin: 0 auto;
	background: #fff;
	box-shadow: 0 0 5px #cae0ef;
	}


/**
 * top order stepper - with heading
 */
.order_stepper_top {
	position: absolute;
	left: 30px;
	top: 0;
	width: 810px;
	height: 120px;
	overflow: hidden;
	}

.order_stepper_top h1 {
	position: absolute;
	left: 0;
	top: 0;
	display: block;
	width: 100%;
	height: 70px;
	line-height: 70px;
	overflow: hidden;
	margin: 0;
	padding: 0;
	text-align: center;
	font-size: 1.7em;
	}

.order_stepper_top ul {
	position: absolute;
	left: 0;
	top: 70px;
	display: block;
	width: 100%;
	height: 50px;
	line-height: 50px;
	overflow: hidden;
	margin: 0;
	padding: 0;
	text-align: center;
	}

.order_stepper_top ul li {
	list-style: none;
	position: relative;
	display: inline-block;
	margin: 0 5px;
	padding: 0;
	font-size: 1.5em;
	}

.order_stepper_top ul li a {
	color: #ebeef0;
	text-decoration: none;
	}

.order_stepper_top ul li a:hover {
	color: #8ec549;
	}

.order_stepper_top ul li.selected a {
	color: #30373b;
	}


/**
 * bottom order stepper - with buttons
 */
.order_stepper_bottom {
	position: absolute;
	left: 0px;
	bottom: 0px;
	width: 870px;
	height: 110px;
	overflow: hidden;
	border-top: 1px #ebeef0 solid;
	}

.order_stepper_bottom ul {
	position: absolute;
	left: 30px;
	bottom: 30px;
	display: block;
	width: 810px;
	height: 50px;
	line-height: 49px;
	overflow: hidden;
	margin: 0;
	padding: 0;
	text-align: center;
	}

.order_stepper_bottom ul li {
	list-style: none;
	position: relative;
	display: inline-block;
	height: 50px;
	line-height: 50px;
	margin: 0;
	padding: 0;
	}

.order_stepper_bottom ul li a {
	text-decoration: none;
	}

.order_stepper_bottom .link_prev {
	float: left;
	color: #000;
	}

.order_stepper_bottom .link_prev a {
	color: #000;
	font-size: 0.9em;
	}

.order_stepper_bottom .link_prev a span {
	color: #7a7a7a;
	font-size: 1.5em;
	vertical-align: -2px;
	}

.order_stepper_bottom .link_prev a:hover span {
	color: #8ec549;
	}

.order_stepper_bottom .link_next {
	float: right;
	display: block;
	}

.order_stepper_bottom .link_next a {
	display: block;
	padding: 0 30px;
	color: #fff;
	background: #8ec549;
	border: 0px transparent solid;
	border-radius: 5px;
	font-size: 1.2em;
	}

.order_stepper_bottom .link_next a:hover {
	background: #1c73b6;
	}

.order_stepper_bottom .link_next a span {
	display: none;
	}

.order_stepper_bottom .link_finish {
	float: right;
	display: none;
	}

.order_stepper_bottom .link_finish a {
	display: block;
	padding: 0 30px;
	color: #fff;
	background: #8ec549;
	border: 0px transparent solid;
	border-radius: 5px;
	font-size: 1.2em;
	}

.order_stepper_bottom .link_finish a:hover {
	background: #1c73b6;
	}

.order_stepper_bottom .link_finish a span {
	display: none;
	}


/**
 * order block
 */
.order_block_outer {
	display: block;
	position: absolute;
	left: 30px;
	top: 120px;
	width: -moz-calc(100% - 60px);
	width: -webkit-calc(100% - 60px);
	width: -o-calc(100% - 60px);
	width: calc(100% - 60px);
	height: -moz-calc(100% - 230px);
	height: -webkit-calc(100% - 230px);
	height: -o-calc(100% - 230px);
	height: calc(100% - 230px);
	overflow: hidden;
	}

.order_block {
	display: block;
	position: absolute;
	left: 100%;
	top: 0;
	width: 100%;
	height: 100%;
	overflow-x: hidden;
	overflow-y: auto;
	opacity: 0;
	}


/**
 * order block - version selection
 */
.order_block ul.selector_version {
	margin: 0;
	padding: 0;
	width: 99%;
	}

.order_block ul.selector_version li.version {
	list-style: none;
	position: relative;
	width: 100%;
	overflow: hidden;
	margin: 0 0 20px 0;
	padding: 0;
	border: 1px #fff solid;
	border-radius: 5px;
	background: #f9fafa;
	transition: all 0.2s ease;
	-moz-transition: all 0.2s ease;
	-webkit-transition: all 0.2s ease;
	-ms-transition: all 0.2s ease;
	-o-transition: all 0.2s ease;
	}

.order_block ul.selector_version li.version a.version {
	position: relative;
	display: block;
	width: 100%;
	height: 100px;
	text-decoration: none;
	color: #30373b;
	}

.order_block ul.selector_version li.version a.version img {
	position: absolute;
	left: 0;
	top: 0;
	padding: 18px;
	background: #ebeef0;
	border-right: 1px #fff solid;
	border-bottom: 1px #fff solid;
	transition: all 0.2s ease;
	-moz-transition: all 0.2s ease;
	-webkit-transition: all 0.2s ease;
	-ms-transition: all 0.2s ease;
	-o-transition: all 0.2s ease;
	}

.order_block ul.selector_version li.version a.version span.version_name {
	margin-left: 120px;
	line-height: 100px;
	font-size: 1.6em;
	}

.order_block ul.selector_version li.version:hover, .order_block ul.selector_version li.version_selected {
	border: 1px #8ec549 solid;
	}

.order_block ul.selector_version li.version:hover a.version img, .order_block ul.selector_version li.version_selected a.version img {
	border-right: 1px #8ec549 solid;
	border-bottom: 1px #8ec549 solid;
	}

.order_block ul.selector_variant {
	width: 100%;
	height: 0;
	overflow: hidden;
	margin: 0;
	padding: 0;
	}

.order_block ul.selector_variant li.variant {
	position: relative;
	list-style: none;
	width: 100%;
	height: 80px;
	overflow: hidden;
	margin: 0;
	padding: 0;
	transition: all 0.2s ease;
	-moz-transition: all 0.2s ease;
	-webkit-transition: all 0.2s ease;
	-ms-transition: all 0.2s ease;
	-o-transition: all 0.2s ease;
	}

.order_block ul.selector_variant li.variant div.variant_name_block {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 40px;
	line-height: 40px;
	}

.order_block ul.selector_variant li.variant div.variant_name_block input[type="radio"] {
	width: 18px;
	height: 18px;
	margin: 0 0 0 7px;
	padding: 0;
	}

.order_block ul.selector_variant li.variant div.variant_name_block label {
	position: absolute;
	left: 30px;
	top: 0;
	}

.order_block ul.selector_variant li.variant div.variant_description_block {
	position: absolute;
	left: 30px;
	bottom: 0;
	width: -moz-calc(100% - 40px);
	width: -webkit-calc(100% - 40px);
	width: -o-calc(100% - 40px);
	width: calc(100% - 40px);
	height: 30px;
	padding: 0 0 10px 0;
	line-height: 15px;
	overflow: hidden;
	font-size: 0.8em;
	}

.order_block ul.selector_variant li.variant:hover, .order_block ul.selector_variant li.variant_selected {
	background: #8ec549;
	}


/**
 * order block - selectable items
 */
.order_block .block_selectable_group {
	}

.order_block .selection_skip, .order_block .selection_help {
	margin: 0 0 10px 0;
	padding: 0;
	}

.order_block .selection_skip input, .order_block .selection_help input {
	width: 18px;
	height: 18px;
	margin: 0 5px 0 0;
	padding: 0;
	vertical-align: -1px;
	}

.order_block .block_selectable_group ul {
	width: 100%;
	margin: 20px 0 0 0;
	padding: 0 0 0 1px;
	}

.order_block .block_selectable_group ul li.item {
	list-style: none;
	float: left;
	position: relative;
	display: block;
	width: -moz-calc(33% - 10px);
	width: -webkit-calc(33% - 10px);
	width: -o-calc(33% - 10px);
	width: calc(33% - 10px);
	height: 200px;
	overflow: hidden;
	margin: 0 10px 10px 0;
	padding: 0;
	border: 1px #ebeef0 solid;
	transition: all 0.2s ease;
	-moz-transition: all 0.2s ease;
	-webkit-transition: all 0.2s ease;
	-ms-transition: all 0.2s ease;
	-o-transition: all 0.2s ease;
	}

.order_block .block_selectable_group ul li.item:hover, .order_block .block_selectable_group ul li.item_selected {
	border: 1px #8ec549 solid;
	}

.order_block .block_selectable_group ul li.item .item_image_outer {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: #fff;
	}

.order_block .block_selectable_group ul li.item .item_image_inner {
	position: absolute;
	left: 10%;
	top: 10%;
	width: 80%;
	height: 80%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	}

.order_block .block_selectable_group ul li.item .item_image_inner img {
	display: none;
	}

.order_block .block_selectable_group ul li .item_data_outer {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, 0.95);
	opacity: 0;
	transition: all 0.2s ease;
	-moz-transition: all 0.2s ease;
	-webkit-transition: all 0.2s ease;
	-ms-transition: all 0.2s ease;
	-o-transition: all 0.2s ease;
	}

.order_block .block_selectable_group ul li:hover .item_data_outer {
	opacity: 1;
	}

.order_block .block_selectable_group ul li.item_selected .item_data_outer {
	opacity: 1;
	background-color: rgba(142, 197, 73, 0.95);
	}

.order_block .block_selectable_group ul li.item .item_data_inner {
	position: absolute;
	left: 5%;
	top: 5%;
	width: 90%;
	height: 90%;
	}

.order_block .block_selectable_group ul li.item .item_data_inner p.item_name {
	position: absolute;
	left: 0;
	top: 0;
	display: block;
	width: 90%;
	height: 40px;
	overflow: hidden;
	line-height: 20px;
	margin: 0;
	padding: 0 0 0 25px;
	font-weight: bold;
	text-align: left;
	}

.order_block .block_selectable_group ul li.item .item_data_inner p.item_name input[type="checkbox"] {
	position: absolute;
	left: 0;
	top: 0;
	margin: 0;
	padding: 0;
	width: 18px;
	height: 18px;
	}

.order_block .block_selectable_group ul li.item .item_data_inner p.item_description {
	position: absolute;
	left: 0;
	top: 45px;
	display: block;
	width: 100%;
	height: 60%;
	overflow: hidden;
	line-height: 1.4em;
	margin: 0;
	padding: 0;
	text-align: left;
	font-size: 0.8em;
	}

.order_block .block_selectable_group ul li.item .item_data_inner p.item_price {
	position: absolute;
	right: 0;
	bottom: 0;
	margin: 0;
	padding: 0;
	text-align: left;
	font-size: 0.8em;
	line-height: 2.4em;
	}

.order_block .block_selectable_group ul li.item .item_data_inner div.item_amount {
	position: absolute;
	left: 0;
	bottom: 0;
	margin: 0;
	padding: 0;
	display: none;
	}

.order_block .block_selectable_group ul li.item_selected .item_amount {
	display: block !important;
	}

.order_block .block_selectable_group ul li.item .item_data_inner div.item_amount input {
	float: left;
	width: 36px;
	margin: 0 5px 0 0;
	padding: 4px;
	font-size: 1em;
	border: 1px #a9a9a9 solid;
	border-radius: 2px;
	vertical-align: middle;
	}

.order_block .block_selectable_group ul li.item .item_data_inner div.item_amount span {
	float: left;
	line-height: 2em;
	}

.order_block .block_selectable_group_ruler {
	clear: left;
	margin-top: -1px;
	padding-top: 1px;
	background: #fff;
	}


/**
 * order block - input rows
 */
.order_block .heading_row {
	display: block;
	width: 100%;
	}	

.order_block .heading_row h3 {
	margin: 0;
	padding: 30px 0 0 0;
	font-weight: normal;
	font-size: 1em;
	}

.order_block .spacer_row {
	padding-top: 30px;
	}

.order_block .input_row {
	display: block;
	width: 100%;
	height: 90px;
	}

.order_block .input_row_single {
	float: left;
	position: relative;
	width: 100%;
	height: 100%;
	}

.order_block .input_row_double {
	float: left;
	position: relative;
	width: 45%;
	height: 100%;
	}

.order_block .input_row_double:first-child {
	margin-right: 10%;
	}

.order_block .input_row label {
	position: absolute;
	left: 1px;
	top: 0;
	display: block;
	width: 100%;
	margin-top: 15px;
	line-height: 2em;
	font-size: 0.75em;
	font-weight: bold;
	text-transform: uppercase;
	}

.order_block .input_row input[type="text"] {
	position: absolute;
	left: 0;
	bottom: 0;
	display: block;
	width: -moz-calc(100% - 22px);
	width: -webkit-calc(100% - 22px);
	width: -o-calc(100% - 22px);
	width: calc(100% - 22px);
	height: 50px;
	margin: 0;
	padding: 0 10px;
	font-family: "Exo", sans-serif;
	font-size: 1em;
	color: #000;
	border: 1px #a9a9a9 solid;
	border-radius: 3px;
	}

.order_block .input_row input[type="text"]:focus {
	background: #f9f9f9;
	border: 1px #8ec549 solid;
	}

.order_block .input_row select {
	position: absolute;
	left: 0;
	bottom: 0;
	display: block;
	width: 100%;
	height: 50px;
	margin: 0;
	padding: 0 10px;
	font-family: "Exo", sans-serif;
	font-size: 1em;
	color: #000;
	border: 1px #a9a9a9 solid;
	border-radius: 3px;
	}

.order_block .input_row select:focus {
	background: #f9f9f9;
	border: 1px #8ec549 solid;
	}

.order_block .radio_row {
	display: block;
	width: 100%;
	}

.order_block .radio_row_single {
	position: relative;
	width: 100%;
	padding-top: 40px;
	}

.order_block .radio_row span.label {
	position: absolute;
	left: 1px;
	top: 0;
	display: block;
	width: 100%;
	margin-top: 15px;
	line-height: 2em;
	font-size: 0.75em;
	font-weight: bold;
	text-transform: uppercase;
	}

.order_block .radio_row_single {
	position: relative;
	width: 100%;
	padding-top: 38px;
	}

.order_block .radio_row_content {
	margin-bottom: 5px;
	}

.order_block .radio_row_content input[type="radio"] {
	margin: 0 5px 0 3px;
	}


/**
 * order loader
 */
#order_loader {
	display: none;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-image: url('/data/images/layout/loading.png');
	background-position: center;
	background-repeat: no-repeat;
	background-color: rgba(255, 255, 255, 0.9);
	opacity: 0;
	}


/**
 * message holder
 */
#message_holder {
	display: none;
	}


/**
 * messages
 */
#message_wrap {
	display: none;
	opacity: 0;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	}	

#message_content {
	display: table-cell;
	vertical-align: middle;
	text-align: center;
	width: 100%;
	height: 100%;
	}	


/**
 * info message
 */
.message_info {
	color: #8ec549;
	background-color: #fff;
	}

.message_info p {
	padding: 0 20%;
	text-align: center;
	font-size: 1.6em;
	}

.message_info p big {
	font-size: 10em;
	line-height: 1.05em;
	}


/**
 * error message
 */
.message_error {
	color: #c00;
	background-color: rgba(255, 255, 255, 0.9);
	}

.message_error p {
	padding: 0 20%;
	text-align: center;
	font-size: 1.6em;
	}

.message_error p big {
	font-size: 10em;
	line-height: 1.05em;
	}

.message_error p a {
	display: inline-block;
	margin-top: 15px;
	padding: 10px 30px;
	color: #fff;
	background: #c00;
	border: 0px transparent solid;
	border-radius: 5px;
	text-decoration: none;
	font-size: 0.7em;
	}

.message_error p a:hover {
	background: #1c73b6;
	}
