body {
	font-family: 'Lato', 'Roboto', sans-serif;
}

body.modal-open {
	overflow: hidden;
	position: relative;
}
@media (min-width: 767px) {
	body.modal-open {
		overflow: visible;
		position: relative;
	}
}

.modal-dialog {
	margin-top: 60px;
}


a {
	color: inherit;
}

a:hover {
	color: inherit;
	opacity:0.8;
	text-decoration: none;
}

a:any-link {
	color: inherit;
	text-decoration: none;
}

#navbar-background {
	transition: opacity 0.3s, visibility 0.3s;
	-webkit-transition: opacity 0.3s, visibility 0.3s;
}

.content {
  margin-top: 50px;
}

.forStickyFooter {
	min-height: calc(100vh - 375px - 75px); /* 100% viewport minus footer height minus top margin */
}
.forStickyFooterHome {
	min-height: calc(100vh - 375px); /* 100% viewport minus footer height minus top margin */
}

.no-user-select {
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.undecorated-link:hover {
  text-decoration: none;
}
[ng\:cloak],
[ng-cloak],
[x-ng-cloak],
.ng-cloak,
.x-ng-cloak {
  display: none !important;
}
.header-profile-image {
  border-radius: 50%;
  height: 28px;
  margin-right: 5px;
  opacity: 0.8;
  width: 28px;
}
.open .header-profile-image,
a:hover .header-profile-image {
  opacity: 1;
}
.user-header-dropdown-toggle {
  padding-bottom: 11px !important;
  padding-top: 11px !important;
}
.user-primary-account {
  font-size: 30px;
  position: absolute;
  right: 10px;
  top: 10px;
}
.error-text {
	/*display: none;*/
}
.has-error .help-block.error-text {
  display: block;
}
.has-error .help-inline.error-text {
  display: inline;
}

.authbox .has-error .form-control {
	border-color: #FFB6C1;
}
.authbox .error-text {
	color: #FFB6C1;
}

.authbox .menuitems .row:not(:first-child){
	border-top: 0!important;
}
.authbox .menuitems .row:hover {
	background:rgba(68,68,68,0.5);
	cursor:pointer;
}

.has-error .btn {
	border-color: #a94442;
}
.has-success .btn {
	border-color: #3c763d;
}

.hoverable:hover {
	background:#f6f6f6;
	cursor:pointer;
}

.zipItem {
	min-height: 50px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 18px
}


/* Admin area */
.form-signin {
  max-width: 330px;
  padding: 15px;
  margin: 0 auto;
}

.form-signin .form-group {
  margin-bottom:0;
}

.form-signin input[type="email"] {
  margin-bottom: -1px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}

.form-signin input[type="password"] {
  margin-bottom: 10px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

@media (min-width: 768px) {
	.form-horizontal .control-label {
		text-align: inherit
	}
}

.deliveryRegion {
	display:flex;
	align-items: center;
}

.progress-animation {
	width: 0;
	transition: width 5s linear;
}
.progress-animation.complete {
	width: 100%;
}

.authbox_wrapper {
	position:fixed;
	top:0;
	left:0;
	right:0;
	bottom:0;
	color:#f8f8f8;
	padding:15px 20px;
	overflow:scroll;
	overflow: -moz-scrollbars-none;
	-ms-overflow-style: none;
	background: #222222;
	opacity:0;
	visibility: hidden;
	-webkit-transition: opacity 300ms;
	transition: opacity 300ms;
	z-index:999;
}
.authbox_wrapper::-webkit-scrollbar { width: 0 !important }

@media (min-width: 768px) {
	.authbox_wrapper {
		position:absolute;
		right:0;
		top:65px;
		left: auto;
		bottom: auto;
		overflow: visible;
		width:400px;
		color:#f8f8f8;
		padding:15px 20px;
		background: #222222;
		border: 1px solid #080808;
		border-radius: 4px;
		opacity:0;
		visibility: hidden;
		box-shadow: 0 5px 20px rgba(0, 0, 0, 0.25);
		-webkit-transition: opacity 300ms, visibility 300ms;
		transition: opacity 300ms, visibility 300ms;
	}
	.authbox_wrapper:after, .authbox_wrapper:before {
		bottom: 100%;
		right: 15px;
		border: solid transparent;
		content: " ";
		height: 0;
		width: 0;
		position: absolute;
		pointer-events: none;
	}

	.authbox_wrapper:after {
		border-color: rgba(34, 34, 34, 0);
		border-bottom-color: #222222;
		border-width: 10px;
		margin-left: -10px;
	}
	.authbox_wrapper:before {
		border-color: rgba(8, 8, 8, 0);
		border-bottom-color: #080808;
		border-width: 11px;
		margin-left: -11px;
	}
}

.social-btn:hover, .social-btn:active, .social-btn:visited, .social-btn:focus {
	opacity: 0.9;
	color: inherit;
	outline: 0;
}

a.anchor {
	display: block;
	position: relative;
	top: -250px;
	visibility: hidden;
}
@media (min-width: 768px) {
	a.anchor {
		top: -150px;
	}
}

.membernavRow {
	position: fixed;
	right: 0;
	left: 0!important;
	width: 100%!important;
	background-color: white;
	-webkit-box-shadow: 0px 0px 25px 0px rgba(0,0,0,0.3);
	-moz-box-shadow: 0px 0px 25px 0px rgba(0,0,0,0.3);
	box-shadow: 0px 0px 25px 0px rgba(0,0,0,0.3);
	z-index: 5;
}
.membernav {
	padding: 10px;
}

.membernav a {
	display: block;
	padding: 5px;
	font-size: 18px;
}
@media (min-width: 768px) {
	.membernav a {
		display: inline;
		margin: 0 10px;
		font-size: 18px;
	}
}
.memberContent {
	padding-top: 200px;
}
@media (min-width: 768px) {
	.memberContent {
		padding-top: 100px;
	}
}

.membernav a.active span {
	border-bottom: 2px solid gray;
}
@media (min-width: 768px) {
	.membernav a.active {
		border-bottom: 2px solid gray;
	}
	.membernav a.active span {
		border-bottom: none;
	}
}

/* Load Indicator */
.loadIndicatorWrapper {
	position: absolute;
	width: 100%;
	height: 100%;
	background: rgba(255, 255, 255, 0.8);
	padding-top: 200px;
	text-align: center;
	z-index: 99;
}
.lds-ellipsis {
	display: inline-block;
	position: relative;
	width: 64px;
	height: 64px;
}
.lds-ellipsis div {
	position: absolute;
	top: 27px;
	width: 11px;
	height: 11px;
	border-radius: 50%;
	background: #000;
	animation-timing-function: cubic-bezier(0, 1, 1, 0);
}
.lds-ellipsis div:nth-child(1) {
	left: 6px;
	animation: lds-ellipsis1 0.6s infinite;
}
.lds-ellipsis div:nth-child(2) {
	left: 6px;
	animation: lds-ellipsis2 0.6s infinite;
}
.lds-ellipsis div:nth-child(3) {
	left: 26px;
	animation: lds-ellipsis2 0.6s infinite;
}
.lds-ellipsis div:nth-child(4) {
	left: 45px;
	animation: lds-ellipsis3 0.6s infinite;
}
@keyframes lds-ellipsis1 {
	0% {
		transform: scale(0);
	}
	100% {
		transform: scale(1);
	}
}
@keyframes lds-ellipsis3 {
	0% {
		transform: scale(1);
	}
	100% {
		transform: scale(0);
	}
}
@keyframes lds-ellipsis2 {
	0% {
		transform: translate(0, 0);
	}
	100% {
		transform: translate(19px, 0);
	}
}

/* END LoadIndicator */

@media (max-width: 767px) {
	.btn-xs-block {
		display: block;
		width: 100%!important;
	}
	input[type="submit"].btn-xs-block,
	input[type="reset"].btn-xs-block,
	input[type="button"].btn-xs-block {
		width: 100%!important;
	}
	.btn-block + .btn-xs-block,
	.btn-xs-block + .btn-block,
	.btn-xs-block + .btn-xs-block {
		margin-top: 0.5rem;
	}
}
@media (min-width: 768px) and (max-width: 991px) {
	.btn-sm-block {
		display: block;
		width: 100%!important;
	}
	input[type="submit"].btn-sm-block,
	input[type="reset"].btn-sm-block,
	input[type="button"].btn-sm-block {
		width: 100%!important;
	}
	.btn-block + .btn-sm-block,
	.btn-sm-block + .btn-block,
	.btn-sm-block + .btn-sm-block {
		margin-top: 0.5rem;
	}
}
@media (min-width: 992px) and (max-width: 1199px) {
	.btn-md-block {
		display: block;
		width: 100%!important;
	}
	input[type="submit"].btn-md-block,
	input[type="reset"].btn-md-block,
	input[type="button"].btn-md-block {
		width: 100%!important;
	}
	.btn-block + .btn-md-block,
	.btn-md-block + .btn-block,
	.btn-md-block + .btn-md-block {
		margin-top: 0.5rem;
	}
}
@media (min-width: 1200px) {
	.btn-lg-block {
		display: block;
		width: 100%!important;
	}
	input[type="submit"].btn-lg-block,
	input[type="reset"].btn-lg-block,
	input[type="button"].btn-lg-block {
		width: 100%!important;
	}
	.btn-block + .btn-lg-block,
	.btn-lg-block + .btn-block,
	.btn-lg-block + .btn-lg-block {
		margin-top: 0.5rem;
	}
}

.ng-leave {
	display:none !important;
}

tr:hover td .table-magnifier {
	display: block;
}
.table-magnifier {
	display: none;
	position: absolute;
	top: 0;
	right:0;
	height: 100%;
	font-size:18px;
}

.table-magnifier::before {
	content: "";
	display: inline-block;
	height: 100%;
	vertical-align: middle;
}

.table-clickable:hover {
	cursor: pointer;
}

.articleSelection {
	border-bottom: 1px solid #e5e5e5;
	padding: 5px 15px;
}
.articleSelection:hover {
	background: #f5f5f5;
	cursor: pointer;
}

/* floating labels start */
.form-control-placeholder {
	position: absolute;
	top: 0;
	padding: 7px 0 0 13px;
	transition: all 200ms;
	opacity: 0.5;
}
.form-group.has-success .form-control-placeholder {
	color: #3c763d;
}
 .form-group.has-error .form-control-placeholder {
	 color: #a94442;
 }

input.input-lg ~ .form-control-placeholder {
	font-size: 18px;
	font-weight: normal;
	padding: 10px 16px;
}

.form-control:focus + .form-control-placeholder,
.form-control:not(:placeholder-shown) + .form-control-placeholder {
	font-size: 75%;
	transform: translate3d(0, -100%, 0);
	opacity: 1;
	padding: 7px 0 0 13px;
}
/* end */
.card .trash-hover {
	display: none;
}
.card:hover .trash-hover {
	display: inline-block;
}

.extras {
	padding: 0 15px;
	line-height: 30px;
	min-height: 30px;
}

.extrasBox {
	overflow:hidden;
}

.extrasBox.ng-hide-add,
.extrasBox.ng-hide-remove {
	display: block;
	max-height: 300px;
	transition: max-height 0.15s linear;
}

.extrasBox.ng-hide {
	display: block!important;
	max-height: 80px;
	overflow: hidden;
}

.extrasBox .showMore {
	 display: flex;
	 align-items: flex-end;
	 justify-content: center;
	 position: absolute;
	 bottom:0;
	 left:0;
	 right:0;
	 z-index:1;
	 user-select: none;
}
.extrasBox.ng-hide .showMore {
	height:60px;

	background: rgb(255,255,255);
	background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 70%, rgba(255,255,255,1) 100%);
}


.showMore:hover span {
	color: rgba(0,0,0,0.8);
}

.showMore span {
	color: rgba(0,0,0,0.5);
}


@media (max-width: 767px) {
	.extras:nth-of-type(odd) {
		background: #f7f7f7;
		background-clip: content-box;
	}
}
@media (min-width: 768px) {
	.extras.left:nth-of-type(4n+1) {
		background: #f7f7f7;
		background-clip: content-box;
	}
	.extras.right:nth-of-type(4n+2) {
		background: #f7f7f7;
		background-clip: content-box;
	}
}

@media (min-width: 767px) {
	.text-md-right {
		text-align: right;
	}
	.text-md-left {
		text-align: left;
	}
	.text-md-center {
		text-align: center;
	}
}

/* Categories START */
.categoriesContainer {
	overflow-x: scroll;
	overflow-y: hidden;
	white-space: nowrap;
	box-shadow: 0 2px 9px 0 rgba(120,130,140,0.13);
	transition: padding-left 0.5s cubic-bezier(.02, .01, .47, 1);
}
.categoriesContainer::-webkit-scrollbar {
	display: none;
}

.categoriesContainer span {
	display: inline-block;
	padding: 0 10px;
	cursor: pointer;
	color: gray;
}
@media (hover: hover) {
	.categoriesContainer span:not(.active):hover {
		border-bottom: 2px solid gray;
	}
}

.categoriesContainer span.active {
	color: black;
	border-bottom: 2px solid black;
}

/* Categories END */


.paypal-buttons {
	z-index: 0;
}

.pointer {
	cursor: pointer;
}

.slide-right {
	-webkit-animation: slide-right 1s linear infinite both;
	animation: slide-right 1s linear infinite both;
}

/* placehoder div */
.mapsPlaceholder {
	position:absolute !important;
	width: 100%;
	height: 100%;
	background-color: #dddddd;
	overflow: hidden;
}
.-loading {
	position: relative;
	background-color: #E2E2E2;
	overflow: hidden;
}
.mapsWrapper {
	overflow: hidden;
}
.mapsCol {
	padding: 0;
}
@media (min-width: 768px) {
	.-loading {
		border-radius: 15px;
	}
	.mapsPlaceholder {
		width: calc(100% - 30px);
	}
	.mapsWrapper {
		border-radius: 15px;
	}
	.mapsCol {
		padding: 0 15px;
	}
}

.-loading::after {
	 display: block;
	 content: '';
	 position: absolute;
	 width: 100%;
	 height: 100%;
	 transform: translateX(-100%);
	 background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .2), transparent);
	 animation: loading 1.5s infinite;
}

@keyframes loading {
	100% {
		transform: translateX(100%);
	}
}

/* Load animation */
.pace {
	-webkit-pointer-events: none;
	pointer-events: none;

	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
	overflow: hidden;
	width: 100%;
}

.pace-inactive {
	display: none;
}

.pace .pace-progress:first-child {
	background: #000;
	position: fixed;
	z-index: 2000;
	top: 0;
	left:0;
	right: 100%;
	width: 100%;
	height: 2px;
	opacity: 0.3;
}
.pace .pace-progress:nth-child(2) {
	background: #fff;
	position: fixed;
	z-index: 2000;
	top: 0;
	left:-100%;
	right: 100%;
	width: 100%;
	height: 2px;
	opacity: 0.5;
}
.pace .pace-progress:nth-child(3) {
	background: #000;
	position: fixed;
	z-index: 2000;
	top: 0;
	left:-200%;
	right: 100%;
	width: 100%;
	height: 2px;
	opacity: 0.3;
}

@-webkit-keyframes slide-right {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
	}
	100% {
		-webkit-transform: translateX(200%);
		transform: translateX(200%);
	}
}
@keyframes slide-right {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
	}
	100% {
		-webkit-transform: translateX(200%);
		transform: translateX(200%);
	}
}
