/* Start CSS Shortcuts */
	.font-main-font { font-family: 'MainFont'; }
	.font-main-headline { font-family: mainheadline,Helvetica Neue,Helvetica,Arial; }
	.font-alt-headline { font-family: 'AltHeadline'; }
	.font-secondary-content { font-family: secondarycontent,Helvetica Neue,Helvetica,Arial; }
	.font-size-1 { font-size: 1px; }.font-size-2 { font-size: 2px; }.font-size-3 { font-size: 3px; }.font-size-4 { font-size: 4px; }.font-size-5 { font-size: 5px; }.font-size-6 { font-size: 6px; }.font-size-7 { font-size: 7px; }.font-size-8 { font-size: 8px; }.font-size-9 { font-size: 9px; }.font-size-10 { font-size: 10px; }.font-size-11 { font-size: 11px; }.font-size-12 { font-size: 12px; }.font-size-13 { font-size: 13px; }.font-size-14 { font-size: 14px; }.font-size-15 { font-size: 15px; }.font-size-16 { font-size: 16px; }.font-size-17 { font-size: 17px; }.font-size-18 { font-size: 18px; }.font-size-19 { font-size: 19px; }.font-size-20 { font-size: 20px; }.font-size-21 { font-size: 21px; }.font-size-22 { font-size: 22px; }.font-size-23 { font-size: 23px; }.font-size-24 { font-size: 24px; }.font-size-25 { font-size: 25px; }.font-size-26 { font-size: 26px; }.font-size-27 { font-size: 27px; }.font-size-28 { font-size: 28px; }.font-size-29 { font-size: 29px; }.font-size-30 { font-size: 30px; }.font-size-31 { font-size: 31px; }.font-size-32 { font-size: 32px; }.font-size-33 { font-size: 33px; }.font-size-34 { font-size: 34px; }.font-size-35 { font-size: 35px; }.font-size-36 { font-size: 36px; }.font-size-37 { font-size: 37px; }.font-size-38 { font-size: 38px; }.font-size-39 { font-size: 39px; }.font-size-40 { font-size: 40px; }.font-size-41 { font-size: 41px; }.font-size-42 { font-size: 42px; }.font-size-43 { font-size: 43px; }.font-size-44 { font-size: 44px; }.font-size-45 { font-size: 45px; }.font-size-46 { font-size: 46px; }.font-size-47 { font-size: 47px; }.font-size-48 { font-size: 48px; }.font-size-49 { font-size: 49px; }.font-size-50 { font-size: 50px; }.font-size-60 { font-size: 60px; }.font-size-70 { font-size: 70px; }.font-size-80 { font-size: 80px; }.font-size-90 { font-size: 90px; }.font-size-100 { font-size: 100px; }.font-size-110 { font-size: 110px; }.font-size-120 { font-size: 120px; }.font-size-130 { font-size: 130px; }.font-size-140 { font-size: 140px; }.font-size-150 { font-size: 150px; }
	.line-height-1 { line-height: 1px; }.line-height-2 { line-height: 2px; }.line-height-3 { line-height: 3px; }.line-height-4 { line-height: 4px; }.line-height-5 { line-height: 5px; }.line-height-6 { line-height: 6px; }.line-height-7 { line-height: 7px; }.line-height-8 { line-height: 8px; }.line-height-9 { line-height: 9px; }.line-height-10 { line-height: 10px; }.line-height-11 { line-height: 11px; }.line-height-12 { line-height: 12px; }.line-height-13 { line-height: 13px; }.line-height-14 { line-height: 14px; }.line-height-15 { line-height: 15px; }.line-height-16 { line-height: 16px; }.line-height-17 { line-height: 17px; }.line-height-18 { line-height: 18px; }.line-height-19 { line-height: 19px; }.line-height-20 { line-height: 20px; }.line-height-21 { line-height: 21px; }.line-height-22 { line-height: 22px; }.line-height-23 { line-height: 23px; }.line-height-24 { line-height: 24px; }.line-height-25 { line-height: 25px; }.line-height-26 { line-height: 26px; }.line-height-27 { line-height: 27px; }.line-height-28 { line-height: 28px; }.line-height-29 { line-height: 29px; }.line-height-30 { line-height: 30px; }.line-height-31 { line-height: 31px; }.line-height-32 { line-height: 32px; }.line-height-33 { line-height: 33px; }.line-height-34 { line-height: 34px; }.line-height-35 { line-height: 35px; }.line-height-36 { line-height: 36px; }.line-height-37 { line-height: 37px; }.line-height-38 { line-height: 38px; }.line-height-39 { line-height: 39px; }.line-height-40 { line-height: 40px; }.line-height-41 { line-height: 41px; }.line-height-42 { line-height: 42px; }.line-height-43 { line-height: 43px; }.line-height-44 { line-height: 44px; }.line-height-45 { line-height: 45px; }.line-height-46 { line-height: 46px; }.line-height-47 { line-height: 47px; }.line-height-48 { line-height: 48px; }.line-height-49 { line-height: 49px; }.line-height-50 { line-height: 50px; }.line-height-100 { line-height: 100px; }.line-height-110 { line-height: 110px; }.line-height-120 { line-height: 120px; }.line-height-130 { line-height: 130px; }.line-height-140 { line-height: 140px; }.line-height-150 { line-height: 150px; }
	.text-uppercase { text-transform: uppercase; } .text-shadow { text-shadow: 2px 2px 10px rgba(0,0,0,.5), 0 -2px 10px rgba(0,0,0,.5); }
	.color-red { color: var(--main-color); } .color-green { color: green; }
	.clear { clear: both; } .bg-red { background: #ed1e25; } .bg-dark-red { background: #b30006; } .no-border { border: 0px; }
	.min-height-100 { min-height: 100%; }
/* End CSS Shortcuts */

@media (min-width: 768px) {  
	.font-size-md-1 { font-size: 1px; }.font-size-md-2 { font-size: 2px; }.font-size-md-3 { font-size: 3px; }.font-size-md-4 { font-size: 4px; }.font-size-md-5 { font-size: 5px; }.font-size-md-6 { font-size: 6px; }.font-size-md-7 { font-size: 7px; }.font-size-md-8 { font-size: 8px; }.font-size-md-9 { font-size: 9px; }.font-size-md-10 { font-size: 10px; }.font-size-md-11 { font-size: 11px; }.font-size-md-12 { font-size: 12px; }.font-size-md-13 { font-size: 13px; }.font-size-md-14 { font-size: 14px; }.font-size-md-15 { font-size: 15px; }.font-size-md-16 { font-size: 16px; }.font-size-md-17 { font-size: 17px; }.font-size-md-18 { font-size: 18px; }.font-size-md-19 { font-size: 19px; }.font-size-md-20 { font-size: 20px; }.font-size-md-21 { font-size: 21px; }.font-size-md-22 { font-size: 22px; }.font-size-md-23 { font-size: 23px; }.font-size-md-24 { font-size: 24px; }.font-size-md-25 { font-size: 25px; }.font-size-md-26 { font-size: 26px; }.font-size-md-27 { font-size: 27px; }.font-size-md-28 { font-size: 28px; }.font-size-md-29 { font-size: 29px; }.font-size-md-30 { font-size: 30px; }.font-size-md-31 { font-size: 31px; }.font-size-md-32 { font-size: 32px; }.font-size-md-33 { font-size: 33px; }.font-size-md-34 { font-size: 34px; }.font-size-md-35 { font-size: 35px; }.font-size-md-36 { font-size: 36px; }.font-size-md-37 { font-size: 37px; }.font-size-md-38 { font-size: 38px; }.font-size-md-39 { font-size: 39px; }.font-size-md-40 { font-size: 40px; }.font-size-md-41 { font-size: 41px; }.font-size-md-42 { font-size: 42px; }.font-size-md-43 { font-size: 43px; }.font-size-md-44 { font-size: 44px; }.font-size-md-45 { font-size: 45px; }.font-size-md-46 { font-size: 46px; }.font-size-md-47 { font-size: 47px; }.font-size-md-48 { font-size: 48px; }.font-size-md-49 { font-size: 49px; }.font-size-md-50 { font-size: 50px; }.font-size-md-100 { font-size: 100px; }.font-size-md-110 { font-size: 110px; }.font-size-md-120 { font-size: 120px; }.font-size-md-130 { font-size: 130px; }.font-size-md-140 { font-size: 140px; }.font-size-md-150 { font-size: 150px; }
	.line-height-md-1 { line-height: 1px; }.line-height-md-2 { line-height: 2px; }.line-height-md-3 { line-height: 3px; }.line-height-md-4 { line-height: 4px; }.line-height-md-5 { line-height: 5px; }.line-height-md-6 { line-height: 6px; }.line-height-md-7 { line-height: 7px; }.line-height-md-8 { line-height: 8px; }.line-height-md-9 { line-height: 9px; }.line-height-md-10 { line-height: 10px; }.line-height-md-11 { line-height: 11px; }.line-height-md-12 { line-height: 12px; }.line-height-md-13 { line-height: 13px; }.line-height-md-14 { line-height: 14px; }.line-height-md-15 { line-height: 15px; }.line-height-md-16 { line-height: 16px; }.line-height-md-17 { line-height: 17px; }.line-height-md-18 { line-height: 18px; }.line-height-md-19 { line-height: 19px; }.line-height-md-20 { line-height: 20px; }.line-height-md-21 { line-height: 21px; }.line-height-md-22 { line-height: 22px; }.line-height-md-23 { line-height: 23px; }.line-height-md-24 { line-height: 24px; }.line-height-md-25 { line-height: 25px; }.line-height-md-26 { line-height: 26px; }.line-height-md-27 { line-height: 27px; }.line-height-md-28 { line-height: 28px; }.line-height-md-29 { line-height: 29px; }.line-height-md-30 { line-height: 30px; }.line-height-md-31 { line-height: 31px; }.line-height-md-32 { line-height: 32px; }.line-height-md-33 { line-height: 33px; }.line-height-md-34 { line-height: 34px; }.line-height-md-35 { line-height: 35px; }.line-height-md-36 { line-height: 36px; }.line-height-md-37 { line-height: 37px; }.line-height-md-38 { line-height: 38px; }.line-height-md-39 { line-height: 39px; }.line-height-md-40 { line-height: 40px; }.line-height-md-41 { line-height: 41px; }.line-height-md-42 { line-height: 42px; }.line-height-md-43 { line-height: 43px; }.line-height-md-44 { line-height: 44px; }.line-height-md-45 { line-height: 45px; }.line-height-md-46 { line-height: 46px; }.line-height-md-47 { line-height: 47px; }.line-height-md-48 { line-height: 48px; }.line-height-md-49 { line-height: 49px; }.line-height-md-50 { line-height: 50px; }.line-height-md-100 { line-height: 100px; }.line-height-md-110 { line-height: 110px; }.line-height-md-120 { line-height: 120px; }.line-height-md-130 { line-height: 130px; }.line-height-md-140 { line-height: 140px; }.line-height-md-150 { line-height: 150px; }
}


html, body {
	width: 100%;
	height: 100%;
    font-family: "MainFont",Helvetica,Arial,sans-serif;
    min-width: 350px;
}
body {
    background: #fff;
	padding-top: 86px;
}
	@media (min-width: 580px) {
		body {
			padding-top: 97px;
		}
		.navbar-expand-lg .navbar-mobile {
			top: 92px!important;
			box-shadow: none;
		}
	}
	@media (min-width: 768px) {
		body {
			padding-top: 104px;
		}
		.header-cart {
			top: 104px!important;
		}
		.navbar-expand-lg .navbar-mobile {
			top: 98px!important;
			box-shadow: none;
		}
	}

a,
a:hover,
a:active {
	color: #ed1e25;
}

.navbar-left {
	max-width: 100%;
}
.navbar-light .nav-navbar>.nav-item>.nav-link, .navbar-light .nav-navbar>.nav-link, .navbar-stick-light.stick .nav-navbar>.nav-item>.nav-link, .navbar-stick-light.stick .nav-navbar>.nav-link {
	text-shadow: 2px 2px 10px rgba(0,0,0,.5), 0 -2px 10px rgba(0,0,0,.5);
}
.navbar-open .navbar .nav-navbar>.nav-item>.nav-link, .navbar-open .navbar .nav-navbar>.nav-link,
.navbar-dark .nav-navbar>.nav-item>.nav-link, .navbar-dark .nav-navbar>.nav-link, .navbar-stick-dark.stick .nav-navbar>.nav-item>.nav-link, .navbar-stick-dark.stick .nav-navbar>.nav-link {
	text-shadow: none!important;
}

.header {
	padding-top: 0px;
	padding-bottom: 0px;
}

	.header.menu {
		background: url("/assets/img/photo/0283.jpg") no-repeat center;
		background-size: cover; 
	}

	.header.auth-signin {
		background: url("/assets/img/photo/0245.jpg") no-repeat center;
		background-size: cover; 
	}
	.header.auth-retrieve {
		background: url("/assets/img/photo/0277.jpg") no-repeat center;
		background-size: cover; 
	}
	.header.auth-signup {
		background: url("/assets/img/photo/0284.jpg") no-repeat center;
		background-size: cover; 
	}
	.header.client-area {
		background: url("/assets/img/photo/203.jpg") no-repeat center;
		background-size: cover; 
	}
	.header.order-start {
		background: url("/assets/img/photo/0248.jpg") no-repeat center;
		background-size: cover; 
	}
	.header.order-pick {
		background: url("/assets/img/photo/0250.jpg") no-repeat center;
		background-size: cover; 
	}
	.header.order-checkout {
		background: url("/assets/img/photo/0252.jpg") no-repeat center;
		background-size: cover; 
	}
	.header.review {
		background: url("/assets/img/photo/203.jpg") no-repeat center;
		background-size: cover; 
	}

.color-white {
	color: white;
}

.navbar {
	top: 0px;
}

	.nav-navbar .icon-item {
		line-height: 70px;
	}

	.nav-navbar .icon-item .iconbox {
		padding: 5px;
	}

	.nav-navbar .icon-item .badge {
		float: right;
		margin-top: 30px;
		margin-left: -20px;
		z-index: 99;
		position: relative;
	}

	.navbar .account-button {
		margin-right: 5px;
	}

	.navbar .btn-on-header {
		margin-top: 25px;
	}

.promotion-area {
    border: 5px dashed #fff!important;
}
	.promotion-area h5 {
		font-weight: bold;
		text-transform: uppercase;
	}

.store-area {
    border: 5px dashed red!important;
    transition: all 0.5s;
    cursor: pointer;
    min-height: 100%;
}
	.store-area.unavailable,
	.order-types .pickup.unavailable,
	.order-types .delivery.unavailable {
	    border: 5px solid black!important;
	    opacity: 0.25;
	    cursor: auto;
	}
	.store-area.selected {
	    border: 5px dashed white!important;
	    background: #ed1e25;
	    color: white;
	}
		.store-area.selected a,
		.store-area.selected .name {
		    color: white;
		}
	.store-area .name {
		font-weight: bold;
		text-transform: uppercase;
	}

.order-types .pickup {
	border: 5px solid red!important;
	background-image: url(/assets/img/photo/203.jpg);
    background-size: cover;
}

.order-types .delivery {
	border: 5px solid red!important;
	background-image: url(/assets/img/photo/201.jpg);
    background-size: cover;
}

.fake-select {
	background: white;
	border: 1px solid black;
}
	.fake-select .option {
		padding: 20px;
		background: #fff;
		border-bottom: 1px solid lightgrey;
	}
		.fake-select .option:last-child {
			border-bottom: 0px;
		}
		.fake-select .option.disabled {
			background: #f0f0f0;
		}

section {
	padding-top: 2rem!important;
	padding-bottom: 2rem!important;
}

section.lojas {
	border-top: 1px solid black;
	padding-top: 10px;
	text-align: center;
}
	section.lojas .main-header h3 {
		color: var(--main-color);
		text-align: center;
	}

img.top-right-border-image {
    position: absolute;
    width: min(25vw, 323px);
    top: 10px;
    right: 10px;
    z-index: -1;
}
img.bottom-left-border-image {
    position: absolute;
    width: min(25vw, 472px);
    bottom: 10px;
    left: 10px;
    z-index: -1;
}

.login-order h3,
.top-heading h3 {
	font-family: 'MainHeadline';
	color: var(--main-color);
	font-size: 30px;
	line-height: 20px;
	padding-bottom: 0px;
	text-align: center;
}
	.top-heading small,
	.top-heading .small {
		font-size: 16px;
		line-height: 20px;
	}

.btn-login-system {
	height: 40px;
	padding-left: 5px;
	text-transform: initial;
	font-size: 15px;
}
	.btn-login-system img {
		max-height: 30px;
		margin-top: -3px;
	}

.bg-dark {
    background-color: var(--secondary-color)!important;
}

.btn-bordered {
	border: 1px solid white;
	color: white;
	font-size: 16px;
	text-transform: initial;
	font-weight: bold;
}

.order-type-picker input {
	background: none;
	width: 20px; height: 20px;
	border-radius: 20px;
	border: 1px solid white;
	appearance: none;
	margin-top: 10px;
}
	.order-type-picker.light input {
		border-color: black;
	}
	.order-type-picker input:checked {
		background: var(--main-color);
	}
.order-type-picker label {
	font-size: 20px;
	color: white;
	margin-left: 5px;
}
	.order-type-picker.light label {
		color: black;
	}

.btn-danger {
	background: var(--main-color)!important;
	border-color: var(--main-color)!important;
}
.bg-danger {
	background: var(--main-color)!important;
}

.carousel-indicators li {
	background: var(--main-color)!important;
	border: 0px;
	height: 5px;
}
.carousel-indicators li.active {
	background: var(--highlight-color)!important;
}

pre {
	border-left-color: var(--main-color)!important;
}
.color-danger {
	color: var(--main-color)!important;
}

.nav.nav-pills {

}
	.nav.nav-pills .nav-link {
		background: var(--main-color);
		color: white;
		margin-right: 5px;
		font-family: mainheadline,Helvetica Neue,Helvetica,Arial;
		font-size: 18px;
		padding: 10px!important;
	}
		.nav.nav-pills .nav-link:last-child {
			margin-right: 0px;
		}
		.nav.nav-pills .nav-link.active {
			background: var(--highlight-color)!important;
		}

	@media (max-width: 768px) { 
		.nav.nav-pills .nav-link {
			font-size: 11px;
		}
	}

input.form-control {
	border: 1px solid black;
}

/* Search Component Styles */
.search-section {
	padding: 20px 0;
	background: #f8f9fa;
}

.search-container {
	max-width: 600px;
	margin: 0 auto;
}

.search-input-wrapper {
	position: relative;
}

.search-input {
	padding: 12px 45px 12px 15px;
	border: 2px solid #ddd;
	border-radius: 25px;
	font-size: 16px;
	background: white;
	box-shadow: 0 2px 4px rgba(0,0,0,0.1);
	transition: all 0.3s ease;
}

.search-input:focus {
	outline: none;
	border-color: var(--main-color);
	box-shadow: 0 2px 8px rgba(237, 30, 37, 0.2);
}

.search-icon {
	position: absolute;
	right: 15px;
	top: 50%;
	transform: translateY(-50%);
	color: #666;
	font-size: 16px;
	pointer-events: none;
}

.search-clear-btn {
	position: absolute;
	right: 40px;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	color: #999;
	font-size: 14px;
	cursor: pointer;
	padding: 5px;
	border-radius: 50%;
	transition: all 0.2s ease;
}

.search-clear-btn:hover {
	color: var(--main-color);
	background: #f0f0f0;
}

.search-results {
	padding: 20px 0;
}

.search-category-label {
	margin-top: 5px;
	font-style: italic;
}

.search-section {
	padding-top: 80px!important;
}

@media (max-width: 991px) {
	.search-section {
		padding-top: 20px!important;
	}
}
@media (max-width: 768px) {
	.search-input {
		font-size: 16px; /* Prevents zoom on iOS */
		padding: 10px 40px 10px 12px;
	}
	
	.search-icon {
		right: 12px;
		font-size: 14px;
	}
	
	.search-clear-btn {
		right: 35px;
		font-size: 12px;
	}
}


.custom-radio-holder {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-content: center;
	align-items: center;
}
input.custom-radio-box {
	background: none;
	width: 20px; height: 20px;
	border-radius: 20px;
	border: 1px solid white;
	appearance: none;
}
	input.custom-radio-box {
		border-color: black;
	}
	input.custom-radio-box:checked {
		background: var(--main-color);
	}

.main-title-checkout {
	font-size: 20px;
	font-weight: normal;
}

.target-address-checkout {
    padding: 20px;
    box-shadow: 0 1px 9px rgb(200 200 200);
}
.btn-edit-address-checkout {
	border: 1px solid lightgrey;
}

.login-button-holder {
	min-width: 329px;
	max-width: 400px;
	margin: auto;
	overflow: hidden;
}
#google-signin-button > div {
	margin: auto;
	width: 100%!important;
}

#google-signin-button .abcRioButtonIcon {
	margin-left: 5px;
}

span[id^=not_signed_]:before {
  content: 'Iniciar sessão com uma conta Google';
  font-size: 15px;
  color: black;
}
span[id^=not_signed_] {
	font-size: 0px;
	color: transparent;
}

.external-signup-bar {
	clear: both;
	padding: 20px;
	background: white;
	border-bottom: 1px solid black;
}

.btn-new-customer {
	border: 2px solid #ed1e25;
}
	.btn-new-customer b {
		color: #ed1e25;
	}

.order-pick-page {
	min-height: 100vh;
}
.menu-list {
}
	.menu-list .label-main-text {
		font-size: 16px;
		font-weight: bold;
	}
	.menu-list .category-btn {
		font-size: 30px;
		border: 1px solid black;
		padding: 20px;
		position: relative;
		padding-left: calc(min(30%, 150px) + 10px);
	}
		.menu-list .category-btn .left-img {
			width: min(30%, 150px); 
			position: absolute;
			left: 1px; top: 1px; bottom: 1px;
			background-size: contain;
			background-position: center center;
			background-repeat: no-repeat;
		}
		.menu-list .category-btn .left-img img {
			max-height: 100%;
			max-width: 100%;
		}
	
	.menu-list .ingredient-table-rows {
	}
		.menu-list .ingredient-table-rows .container-fluid {
			margin-bottom: 50px;
		}
		.menu-list .ingredient-table-rows .col-12 {
			border: 5px dotted var(--main-color);
		}
		.menu-list .ingredient-table-rows .col {
			border: 5px dotted var(--main-color);
			border-left: 0px;
		}
			.menu-list .ingredient-table-rows .col:first-child {
				border-left: 5px dotted var(--main-color);
			}
		.menu-list .ingredient-table-rows .headings .col {
			border-right: 5px dotted white;
			background: var(--main-color);
			color: white;
		}
			.menu-list .ingredient-table-rows .headings .col:last-child {
				border-right: 0px;
			}

	.menu-list .menu-red-table {
		border: 5px dotted var(--main-color);
		padding: 0px; margin: 0px;
		border-bottom: 5px dotted var(--main-color);
	}
		.menu-list .menu-red-table.table-striped tbody tr:nth-of-type(odd) {
		    background: lightgrey;
		}
		.menu-list .menu-red-table thead {
			background: var(--main-color);
			color: white;
		}
		.menu-list .menu-red-table tbody td {
			border: 5px dotted black;
		}
		.menu-list .menu-red-table tbody td:first-child {
			border-left: 5px dotted var(--main-color);
		}
		.menu-list .menu-red-table tbody td:last-child {
			border-right: 5px dotted var(--main-color);
		}
		.menu-list .menu-red-table tbody tr:first-child td {
			border-top: 5px dotted var(--main-color);
		}
		.menu-list .menu-red-table tbody tr:last-child td {
			border-bottom: 5px dotted var(--main-color);
		}

	.menu-list .pizza-price-table {
		border: 0px;
		padding: 0px; margin: 0px;
		font-weight: bold;
	}
		.menu-list .pizza-price-table tr:first-child td {
			border-top: 1px solid black;
		}
		.menu-list .pizza-price-table tr td {
			border-bottom: 1px solid black;
		}


	.menu-list .btn-order-now {
		margin: 20px;
	}

	.menu-list .menu-red-table .btn-order-now {
		margin: 0px;
	}

	.menu-list .product-photo {
		float: right;
		max-width: 33%;
		max-height: 20vh;
	}
	.menu-list .product-title {
		position: relative;
	}
	.menu-list .product-price {
		position: relative;
	}

	.menu-list .menu-item {
		border-bottom: 1px solid lightgrey;
	}/*
		.menu-list .menu-item:last-child {
			border-bottom: 0px;
		}*/
		@media (min-width: 992px) {
			.menu-list .menu-item {
				border-bottom: 0px;
			}
			.menu-list .menu-item .card {
				height: 100%;
				border: 1px solid lightgrey;
				padding: 10px!important;
				border-radius: 0px;
			}
		}


		.menu-list .menu-item .card-body {
			display: flex;
    		flex-direction: row;
    		flex-wrap: nowrap;
    		justify-content: flex-start;
    		align-content: center;
    		align-items: center;
		}
			.menu-list .menu-item .card-body .product-main {
			}

		.menu-list.for-show .menu-item {
			position: relative;
		}
			.menu-list.for-show .menu-item .card-body {
				flex-direction: column;
			}
			.menu-list.for-show .menu-item .card-body .price.pizzas,
			.menu-list.for-show .menu-item .card-body .product-overview {
				width: 100%;
			}

			.menu-list.for-show .menu-item .card-body .product-overview {
				padding: 20px;
				padding-bottom: 0px;
			}

		.menu-list.for-show .product-photo{
			padding-top: 10px;
			max-width: 100%;
			padding: 10px;
			margin: auto;
			float: none;
			max-height: 40vh;
		}


.menu-list.fixed-top {
	position: fixed;
	background: white;
	top: 104px;
	left: 0px;
	right: 0px;
	z-index: 998!important;
}
	.menu-list.fixed-top .category-btn {
		cursor: pointer;
		font-size: 12px;
		padding: 10px;
		padding-left: 5px; padding-right: 5px;
		padding-left: 30px;
		border: 0px;
		color: white;
		background: var(--main-color);
	}
		.menu-list.fixed-top .category-btn.active {
			background: #b60000!important;
		}
		.menu-list.fixed-top .category-btn .left-img {
			margin-left: 10px;
			max-width: 20px;
			max-height: 90%;
		}
		.menu-list.fixed-top .category-btn.back {
			padding-left: 10px;
		}

.menu-list.fixed-bottom {
	position: fixed;
	background: white;
	bottom: 0px;
	left: 0px;
	right: 0px;
}
	.menu-list.fixed-bottom .category-btn {
		font-size: 12px;
		padding: 10px;
		border: 0px;
		color: black;
		background: white;
		border-top: 1px solid black;
	}
		.menu-list.fixed-bottom .category-btn.active {
			font-weight: bold;
		}
		.menu-list.fixed-bottom .category-btn .left-img {
			margin-left: 10px;
			max-width: 20px;
			max-height: 90%;
		}
		.menu-list.fixed-bottom .category-btn.back {
			padding-left: 10px;
		}

.menu-list-fixed-spacer {
	height: 51px;
}


.menu-list.personalizing {

}
	.menu-list.personalizing .product-name {
		position: relative;
	}
	.menu-list.personalizing .product-photo {
		max-width: 600px;
	}

	.personalize-description {
		margin-left: 20%;
	}

.table-menu-personalize {

}
	.table-menu-personalize tr.base-ingredient td {
	    background: #e8e8e8;
	}
		.table-menu-personalize tr.thin-crust td {
		    background: #feffd8;
		}
		.table-menu-personalize tr.config-ingredient td {
		    background: #e8e8e8;
		}
		.table-menu-personalize tr.without-ingredient td {
		    background: #ffb5b5;
		}

	/* Cart item styling for ingredients and halfed pizzas */
	.order-render-placeholder {

	}
		.order-render-placeholder .btn-sm {
			padding: 2px 15px!important;
		}
	.cart-halfed-pizza-label {
		font-weight: bold;
	}
	.cart-halfed-pizza-item {
		background-color: white !important;
		font-weight: bold;
		padding: 8px !important;
		margin-left: 20px !important;
	}
	.cart-halfed-pizza-item td:first-child:before {
		font: normal normal normal 14px / 1 FontAwesome;
		content: "";
		color: #1976d2;
		padding-right: 10px;
		padding-left: 10px;
		font-weight: bold;
	}

	.cart-main-item {
		font-weight: bold;
	}

	.cart-item-ingredient {
		font-weight: bold;
	}
	.cart-item-ingredient {
		background-color: white !important;
		font-weight: bold;
		padding: 8px !important;
		margin-left: 20px !important;
	}
	.cart-item-ingredient td:first-child:before {
		font: normal normal normal 14px / 1 FontAwesome;
		content: "";
		color: lightgrey;
		padding-right: 10px;
		padding-left: 20px;
		font-weight: bold;
	}

	.table-menu-personalize .product-name {
		background: black;
		color: white;
		font-family: 'MainFont';
		font-size: 20px;
	}
		.table-menu-personalize tbody tr td {
			padding: 1px;
		}
		.table-menu-personalize tbody tr td:first-child {
			padding-left: 15px;
		}

			.table-menu-personalize tbody tr td .btn {
				padding: 0px;
				padding-left: 15px;
				padding-right: 15px;
			}
			.table-menu-personalize tbody tr td {
				border: 0px;
				border-bottom: 1px solid lightgrey;
			}
			.table-menu-personalize tfoot {
				font-weight: bold;
			}

.modal-personalizing-product {
}
	.modal-personalizing-product .number-bullet {
	    display: inline-block;
	    background: var(--main-color);
	    color: white;
	    width: 25px;
	    height: 25px;
	    border-radius: 25px;
	}
	.modal-personalizing-product .title-area {
	    font-size: 18px;
    	font-weight: bold;
	}

.btn-order-now.btn-xs {
	font-size: 9px;
	margin: 5px;
}

.ajax-preloader {
	position: fixed;
	top: 0px; bottom: 0px;
	left: 0px; right: 0px;
	width: 100%;
	height: 100%;
	z-index: 999999999;
	background: #fff;
	display: none;
}
	.ajax-preloader.active {
		display: block;
	}
	.ajax-preloader .center-vertical {
	    margin: 0;
	    position: absolute;
	    top: 50%;
	    left: 50%;
	    transform: translate(-50%, -50%);
	}
	.ajax-preloader .spinner {
		font-size: 100px;
		color: white;
	}

	.ajax-preloader.active .spinner {
	    -webkit-animation: spin 2s infinite linear;
	}

.full-height {
	min-height: calc(100vh - 85px);
}


@-webkit-keyframes spinner-border {
	to {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg)
	}
}

@keyframes spinner-border {
	to {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg)
	}
}

.spinner-border {
	display: inline-block;
	width: 2rem;
	height: 2rem;
	vertical-align: text-bottom;
	border: 0.25em solid black;
	border-right-color: transparent;
	border-radius: 50%;
	-webkit-animation: spinner-border .75s linear infinite;
	animation: spinner-border .75s linear infinite
}

.spinner-border-sm {
	width: 1rem;
	height: 1rem;
	border-width: 0.2em
}

@-webkit-keyframes spinner-grow {
	0% {
		-webkit-transform: scale(0);
		transform: scale(0)
	}
	50% {
		opacity: 1
	}
}

@keyframes spinner-grow {
	0% {
		-webkit-transform: scale(0);
		transform: scale(0)
	}
	50% {
		opacity: 1
	}
}

.spinner-grow {
	display: inline-block;
	width: 2rem;
	height: 2rem;
	vertical-align: text-bottom;
	background-color: white;
	border-radius: 50%;
	opacity: 0;
	-webkit-animation: spinner-grow .75s linear infinite;
	animation: spinner-grow .75s linear infinite
}

.spinner-grow-sm {
	width: 1rem;
	height: 1rem
}

.min-height-100vh {
	min-height: 100vh;
	height: 100vh;
}

.react-main-component-area {
	/*min-height: 100px;*/
}

.header-cart,
.footer-cart {
	position: fixed;
	width: 500px;
	text-align: center;
	z-index: 1001;
	right: 0px;
	margin: auto;
}
	.header-cart {
		border-left: 1px solid black;
	}
	.footer-cart {
		left: 0px; 
	}

	.header-cart .button,
	.footer-cart .button {
		width: 100%;
		margin: auto;
	}
	.header-cart .body,
	.footer-cart .body {
		transition: all 0.5s;
		width: 100%;
		max-width: 500px;
		margin: auto;
		text-align: left;
		border: 0px solid black;
		padding: 20px;
		max-height: 50vh;
		overflow: hidden;
	}
		.header-cart .hidden,
		.footer-cart .hidden {
			max-height: 0px!important;
			padding: 0px!important;
		}
		.header-cart .shown,
		.footer-cart .shown {
			overflow-y: scroll;
		}
		.header-cart .shown {
			border-bottom: 1px solid black;
		}
		.footer-cart .shown {
			border-top: 1px solid black;
		}

	.footer-cart {
		bottom: -1px;
	}
	.header-cart {
		top: 86px;
	}

		.cart-table table {

		}
			.cart-table table td,
			.cart-table table th {
				border-right: 1px solid #eaeff4;
			}
			.cart-table table thead {
				font-weight: bold;
				background: var(--main-color);
				color: white;
				border: 0px;
			}
				.cart-table table thead td,
				.cart-table table thead th {
					font-family: 'MainHeadline';
					font-size: 16px;
					border: 0px;
				}
			.cart-table table tfoot {
				font-family: 'AltHeadline';
				font-size: 16px;
				background: #f3f3f3;
				border: 0px;
			}
			.cart-table table tfoot tr:last-child {
				font-family: 'MainHeadline';
			}
			.cart-table table tfoot td,
			.cart-table table tfoot th {
				border-top: 1px solid #eaeff4;
			}

.terms-of-service-holder .terms-acceptance-wrapper {
	height: calc(100vh - 350px);
	min-height: 200px;
	overflow-y: scroll;
	overflow-x: hidden;
	border: 1px solid black;
	padding: 20px;
}
.terms-of-service-holder.external-login .terms-acceptance-wrapper {
	height: calc(100vh - 440px);
}

.alert-terms-required .message {
    font-size: 12px;
    line-height: 12px;
}

.mh-50vh {
	max-height: 50vh;
}

footer {
	background-color: var(--secondary-color)!important;
	color: white;
	font-size: 20px;
}

	footer .follow-us {
		font-weight: bold;
		line-height: 25px;
	}

	footer .legal {
		font-size: 11px;
	}
		footer .legal .brand {
			text-align: justify;
		}

	footer .social-bg-white a {
		border-radius: 100px;
	    border: 4px solid white;
	    font-size: 30px;
	    width: 55px;
	    height: 55px;
	    margin-left: 10px;
	    padding: 6px;
	}
		footer .social-bg-white a:first-child {
			margin-left: 0px;
		}

	footer .nav {
		
	}
		footer .nav .nav-link {
			display: block;
			width: 100%;
			border: 1px solid white;
			border-top: 0px;
			color: white;
			text-align: left;
		}
		footer .nav .nav-link:first-child {
			border-top: 1px solid white;
		}
		footer .nav .nav-link::after {
			content: "";
			font: normal normal normal 14px/1 FontAwesome;
			float: right;
			line-height: 30px;
   			font-size: 20px;
		}

.navbar[data-navbar="fixed"] {
    background-color: rgba(255,255,255,0.99)!important;
    box-shadow: 0 1px 9px rgb(0 0 0 / 5%)!important;
}
	.navbar .navbar-toggler {
		color: black!important;
	    font-size: 38px;
   		line-height: 35px;
   		font-weight: 300;
	}
	.navbar .logo {
		max-width: 60vw;
		max-height: 20px;
		transition: max-height 0.5s;
	}

	@media (min-width: 1040px) {
		.navbar .logo {
			max-height: 30px;
		}
	}
	@media (min-width: 1100px) {
		.navbar .logo {
			max-height: 30px;
		}
	}

	@media (min-width: 1150px) {
		.navbar .logo {
			max-height: 40px;
		}
	}
	@media (min-width: 1200px) {
		.navbar .logo {
			max-height: 50px;
		}
	}

	@media (max-width: 991px) {
		.navbar .logo {
			max-height: 50px;
		}
	}

	.navbar .button-header {
		border: 0px;
		background: transparent;
	    font-size: 25px;
   		line-height: 35px;
   		padding-left: 10px; padding-right: 10px;
   		color: black;
	}

	.fake-header-cart-button {
	    position: fixed;
	    top: 0px;
	    right: 0px;
	    width: 70px;
	    height: 90px;
	    padding-top: 50px;
	    text-align: right;
	    padding-right: 20px;
	    z-index: 999;
	}

.mask-select {
	position: relative;
}
	.mask-select .mask {
		position: absolute;
		top: 0px; left: 0px;
		bottom: 0px; right: 0px;
		z-index: 99;
	}

.backdrop-navbar {
	top: 85px;
	background: none;
	display: none;
}

	.navbar-open .backdrop-navbar {
		display: block;
	}

.spacer-topbar,
.spacer-topbar-email {
	position: relative;
	min-height: 40px;
}

.topbar {
	z-index: 1000;
}
	.navbar-open .topbar {
		z-index: 999;
	}
.navbar {
	z-index: 999;
}

.invite-image-cta img {
	width: 49%;
}

.voucher-holder {
	position: relative;
}
	.voucher-holder .voucher-stamp {
		position: absolute;
		top: 35px;
		left: 35px;
		padding: 10px;
		border: 2px dashed var(--main-color);
		transform: rotate(-30deg);
		font-family: "MainHeadline";
	}
		.voucher-holder .voucher-stamp.color-green {
			border-color: green;
		}

body:not(.navbar-scrolled) .spacer-topbar + nav.navbar.navbar-expand-lg {
	top: 40px;
}

.modal-open .navbar {
	right: 0px;
}


.modal .modal-dialog {
	min-width: 100vw;
	padding: 0px;
	margin: 0px;
}
.modal .modal-dialog .modal-content {
	max-width: min(500px, 90%);
	margin: auto;
}

.modal-personalizing-product .modal-body {
    max-height: calc(85vh - 140px);
    overflow-y: auto;
}

.video-intro-show {
	position: fixed;
	top: 0px; left: 0px; right: 0px;
	bottom: 0px;
	z-index: 10000;
	background: white;
}
	.video-intro-show video {
		height: 100%;
		min-width: max(calc(100vh * 1.8), 100vw);
		min-height: max(100vh, calc(100vw * 1.5));
		margin: auto;
		margin-top: calc(50vh - max(100vh, calc(100vw * 1.5)) * 0.5);
		margin-left: calc(50vw - max(calc(100vh * 1.8), 100vw) * 0.5);
	}

@media (max-width: 991px) {
	.navbar-expand-lg .navbar-mobile {
		top: 87px;
	    bottom: auto;
	    height: auto;
	    border-bottom: 1px solid black;
		box-shadow: none;
		width: 100%;
		left: -100vw;
	}
}
@media (max-width: 500px) {
	.header-cart {
		border-left: 0px;
	}
	.header-cart,
	.footer-cart {
		left: 0px; right: 0px;
		width: 100%;
	}
}

@media (max-width: 767px) {
	.topbar {
		display: block;
	}
	.header-cart .body,
	.footer-cart .body {
		max-height: calc(100vh - 165px);
	}
}

@media (max-width: 1000px) {
	.spacer-topbar.email {
		min-height: 140px;
	}
	body:not(.navbar-scrolled) .spacer-topbar.email + nav.navbar.navbar-expand-lg {
		top: 140px;
	}
	.topbar.warning-email {
		display: block;
		height: 140px;
		text-align: center;
		padding: 10px;
	}
		.topbar.warning-email .ml-2,
		.topbar.warning-email .mr-2 {
			display: block;
			width: 100%;
			padding-bottom: 20px;
			margin: 0px;
		}

	.invite-image-cta img {
		width: 100%;
	}
}
@media (max-width: 994px) {
	.topbar,
	.topbar.warning-email {
		display: block;
	}
}

.vbump-1 {

}

.border-black,
.border-black:focus {
	border: 1px solid black;
}

.background-section {
	background: var(--main-color);
	padding: 5px!important;
}
.background-section h1 {
	color: white;
	text-align: center;
	padding: 0px!important;
	margin: 0px!important;
	font-size: 20px;
}

.membership-card {
	margin: auto;
	width: 500px;
	border: 1px solid grey;
	text-align: left;
	border-radius: 25px;
	padding: 25px;
	background: rgb(255,255,255);
	background: radial-gradient(circle, rgba(255,255,255,1) 0%, rgba(221,221,221,1) 100%);
}
	.membership-card .logo {
		width: 50%;
		float: left;
		text-shadow: -1px -1px 0px rgba(255, 255, 255, 0.3), 1px 1px 0px rgba(0, 0, 0, 0.8);
		text-shadow: #474747 0px 0px 2px;
	}
	.membership-card .card-title {
		font-size: 30px;
		line-height: 35px;
		text-align: right;
		font-weight: bold;
		color: red;
		text-shadow: -1px -1px 0px rgba(255, 255, 255, 0.3), 1px 1px 0px rgba(0, 0, 0, 0.8);
		text-shadow: #474747 0px 0px 2px;

	}

	.membership-card .number-title {
		text-align: center;
		font-size: 12px;
		font-weight: bold;
		text-shadow: -1px -1px 0px rgba(255, 255, 255, 0.3), 1px 1px 0px rgba(0, 0, 0, 0.8);
		text-shadow: #474747 0px 0px 2px;
		padding-top: 30px;
	}

	.membership-card .number {
		font-size: 40px; line-height: 40px;
		padding-bottom: 20px;
		text-align: center;
		color: lightgrey;
		text-shadow: -1px -1px 0px rgba(255, 255, 255, 0.3), 1px 1px 0px rgba(0, 0, 0, 0.8);
		text-shadow: #474747 0px 0px 2px;
	}
	.membership-card .validity {
		text-align: right;
		font-size: 16px;
		font-weight: bold;
		color: #3f51b5;
		text-shadow: -1px -1px 0px rgba(255, 255, 255, 0.3), 1px 1px 0px rgba(0, 0, 0, 0.8);
		text-shadow: #474747 0px 0px 2px;
	}

	.membership-card .holder {
		text-align: right;
		font-size: 20px;
		font-weight: bold;
		text-shadow: -1px -1px 0px rgba(255, 255, 255, 0.3), 1px 1px 0px rgba(0, 0, 0, 0.8);
		text-shadow: #474747 0px 0px 2px;
	}
	.membership-card .authorized {
		text-align: right;
		font-size: 12px;
		font-weight: bold;
		text-shadow: -1px -1px 0px rgba(255, 255, 255, 0.3), 1px 1px 0px rgba(0, 0, 0, 0.8);
		text-shadow: #474747 0px 0px 2px;
	}


	.membership-card {
		position: relative;
	}
	.membership-card .expired-card {
		font-size: 40px;
		position: absolute;
		top: 0px;
		right: 0px; left: 0px;
		bottom: -10px;
		border-radius: 25px;
		opacity: 0.5;
		display: flex;
		align-content: center;
		justify-content: center;
    	flex-direction: column;
	}

/* Top Seller Styles */
.top-seller-item {
	position: relative;
	border: 2px solid #ed1e25 !important;
	box-shadow: 0 4px 8px rgba(237, 30, 37, 0.3) !important;
}

.top-seller-badge {
	position: absolute;
	top: -10px;
	right: -10px;
	background: #ed1e25;
	color: white;
	padding: 5px 10px;
	border-radius: 15px;
	font-size: 12px;
	font-weight: bold;
	z-index: 10;
	box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

.top-seller-item .card-body {
	padding-top: 20px !important;
}

.top-seller-item .product-title {
	color: #ed1e25;
	font-weight: bold;
}

.top-seller-item:hover {
	transform: translateY(-2px);
	transition: transform 0.3s ease;
	box-shadow: 0 6px 12px rgba(237, 30, 37, 0.4) !important;
}
