@import url('https://fonts.googleapis.com/css2?family=El+Messiri&family=Parisienne&display=swap');
* {
	list-style: none;
}

* ul {
	padding: 0px;
	margin: 0px;
}

html {
	scroll-behavior: smooth;
	min-width: 250px;
}

body {
	margin: 0;
	list-style: none;
}

h1 {
	color: white;
}

.front {
	height: 100vh;
	width: 100%;
	background: url("../img/background.png") center no-repeat;
	background-size: cover;
	background-color: rgba(0, 0, 0, 0.4);
	background-blend-mode: multiply;
	background-attachment: fixed;
}

.frontMap {
	background: url('../img/background2.png') center no-repeat;
	background-size: cover;
	background-attachment: fixed;
	background-color: rgba(0, 0, 0, 0.4);
	background-blend-mode: multiply;
	height: calc(50vh + 4rem);
	width: 100%;
	text-align: center;
	margin-top: -4rem;
}

.frontMessageMap {
	display: inline-flex;
	font-size: 80px;
	color: #FFB125;
	max-height: 100px;
	font-family: 'El Messiri';
	width: fit-content;
	font-family: 'Parisienne';
	text-shadow: -1px -1px 0 #fff, 1px -1px 0 #fff, -1px 1px 0 #fff, 1px 1px 0 #fff;
}

@media screen and (max-width: 950px) {
	.frontMessageMap {
		font-size: 50px;
	}
}

@media screen and (max-width: 650px){
	.frontMessageMap {
		font-size: 40px;
	}
	.mapSectionCon {
		width: 100% !important;
	}
	.mapSection {
		width: 100% !important;
	}
}

@media screen and (max-width: 490px) {
	.frontMessageMap {
		font-size: 35px;
	}
	.navBar {
		margin-right: 12px !important;
	}
}
@media screen and (max-width: 415px) {
	.frontMessageMap {
		font-size: 30px;
	}
	nav {
		font-size: 18px !important;
	}
}
@media screen and (max-width: 360px) {
	.frontMessageMap {
		font-size: 27px;
	}
}

.frontMessageMapContainer{
	display: inline-block;
	width: 100%;
	margin-top: calc(50vh / 3);
}

nav {
	background-color: rgb(26, 26, 26, 0.65);
	width: 100%;
	height: 4rem;
	position: relative;
	color: #FFB125;
	font-size: 24px;
}

.mapNav {
	background-color: rgba(26, 26, 26, 0.65) !important;
}

.logo {
	position: relative;
	top: 50%;
	text-align: left;
	float: left;
	transform: translateY(-50%);
	margin-left: 2rem;
	font-size: 32px;
	font-family: 'Parisienne';
}

.logo a {
	text-decoration: none;
	color: #FFB125;
}

.navBar {
	position: relative;
	top: 50%;
	text-align: right;
	transform: translateY(-50%);
	float: right;
	margin-right: 2rem;
	font-family: 'El Messiri', arial;
}

.navBar a {
	text-decoration: none;
	color: #FFB125;
}

.frontMessage {
	margin-top: calc(45vh - 4rem);
	margin-bottom: calc(50vh - 4rem - 100px);
	text-align: center;
	font-size: 128px;
	color: #FFB125;
	max-height: 100px;
	font-family: 'Parisienne';
	text-shadow: -1px -1px 0 #fff, 1px -1px 0 #fff, -1px 1px 0 #fff, 1px 1px 0 #fff;
}

.navArrow {
	width: 100%;
}

.navArrow a {
	text-decoration: none;
	margin: 0 calc(50% - 22.28px);
	text-align: center;
	font-size: 50px;
	color: #FFB125;
}

.arrows {
	width: 120px;
	height: 144px;
	position: absolute;
	left: 50%;
	margin-left: -60px;
	bottom: 20px;
}

.arrows path {
	stroke: #FFB125;
	fill: transparent;
	stroke-width: 4px;
	animation: arrow 2s infinite;
	-webkit-animation: arrow 2s infinite;
}

@keyframes arrow {
	0% {
		opacity: 0
	}
	40% {
		opacity: 1
	}
	80% {
		opacity: 0
	}
	100% {
		opacity: 0
	}
}

.arrows path.a1 {
	animation-delay: -1s;
}

.arrows path.a2 {
	animation-delay: -0.5s;
}

.arrows path.a3 {
	animation-delay: 0s;
}

.divider {
	width: 100%;
	height: 4rem;
	background-color: #2E2E2E;
}

.openHours {
	padding: 20vh calc(50% - 210px);
	width: 420px;
	background-color: #1A1A1A;
	font-size: 45px;
	color: white;
	font-family: 'El Messiri', arial;
}

.titleHours {
	text-align: center;
}

.weekDays {
	font-size: 38px;
}

.day {
	float: left;
}

.spacer {
	width: 4rem;
	padding: 0 2rem;
}

.time {
	float: right;
}

.menu {
	min-height: 1000px;
	background-color: #1A1A1A;
	padding: 1rem 25%;
	width: 50%;
	color: white;
	font-family: 'El Messiri', arial;
}

.titleMenu {
	text-align: center;
	font-size: 45px;
	margin: 1rem 0px;
}

.subTitleMenu{

	text-align: center;
	font-size: 30px;
	margin: 1rem 0px;
}

.legend {
	

	text-decoration: none;
  }

.buttons {
	background-color: #2E2E2E;
	overflow: hidden;
	padding: 1rem;
	
}


.buttons button {
	float: left;
	border: none;
	outline: none;
	margin: 5px;
	padding: 12px 16px;
	color: #FFB125;
	cursor: pointer;
	font-size: 16px;
	display: flex;
	justify-content: center;
	align-items: center;

}

.buttons button:hover{

	opacity: 75%;

}

.filterWith {
	background-color: gray;
	color: #FFB125;
}

.filterWith:hover{

	background-color: rgb(143, 19, 19) ;
}

.filterWithout {

	text-decoration: line-through;
	background-color: #444444;
	text-decoration-color:  rgb(143, 19, 19);
	text-decoration-thickness: 3px;
}

.filterNeutral {
	background-color: #444444;
	color: #ffB125;
}

.box {
	background-color: #2E2E2E;
	width: calc(100% - 2rem);
	padding: 1rem;
	margin: 0.5rem 0px;
	line-height: 2rem;
}

.box :nth-child(2) {
	text-align: right;
}

.product {
	width: 100px;
	font-size: 20px;
}

.price {
	position: relative;
	float: right;
	top: 0px;
	font-size: 20px;
}

.ingredients {
	color: darkgray;
	font-size: 16px;
}

.show {
	display: block;
}

.footer {
	height: 18rem;
	background-color: #1A1A1A;
	color: white;
	font-size: 20px;
	font-family: 'El Messiri', arial;
	padding: 0px 20%;
}

.contactInfo {
	float: left;
	margin-top: calc(9rem - 64px);
}

.contactInfo li {
	margin-bottom: .75rem;
}

.contactInfo li:first-child {
	width: fit-content;
}

.contactInfo li a {
	color: white;
}

.mapSectionInfo .contactInfo {
	font-size: x-large;
	margin-left: 20%;
}

#specInfo {
	font-family: 'El Messiri', arial;
}

.footerOpenHours {
	float: right;
	width: 190px;
	margin-top: calc(9rem - 129px);
}

.footerOpenHours .weekDays {
	font-size: 20px;
	margin: 5px;
}

.dividerLine {
	display: table;
	font-size: 24px;
	text-align: center;
	width: 90%;
	/*Divider width*/
	margin: 0 auto;
	/*spacing above/below*/
}

.dividerLine span {
	display: table-cell;
	position: relative;
}

.dividerLine span:first-child,
.dividerLine span:last-child {
	width: 50%;
	top: 2rem;
	/*Adjust vertical alignment*/
	background-size: 100% 4px;
	/*Line width*/
	background-position: 0 0, 0 100%;
	background-repeat: no-repeat;
}


/*Color changes in here*/

.dividerLine span:first-child {
	background-image: -webkit-gradient(linear, 0 0, 0 100%, from(transparent), to(#FFB125));
	background-image: -webkit-linear-gradient(180deg, transparent, #FFB125);
	background-image: linear-gradient(90deg, transparent, #FFB125);
}

.dividerLine span:nth-child(2) {
	color: #FFB125;
	padding: 0px 5px;
	width: auto;
	white-space: nowrap;
}


/*Color changes in here*/

.dividerLine span:last-child {
	background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#FFB125), to(transparent));
	background-image: -webkit-linear-gradient(180deg, #FFB125, transparent);
	background-image: linear-gradient(90deg, #FFB125, transparent);
}


/*Circle in divider*/

.dividerCircle {
	top: 2.3rem;
	box-sizing: border-box;
	position: relative;
	display: block;
	transform: rotate(45deg) scale(var(--ggs, 1)) translateY(-50%) translateX(-50%);
	width: 16px;
	height: 16px;
	border-radius: 100% 100% 100% 100%;
	box-shadow: inset 0 0 0 2px;
	color: #FFB125;
}


@media screen and (max-width: 1000px) {
	.footer {
		padding: 0px 10%;
	}
}

@media screen and (max-width: 565px) {
	.frontMessage {
		font-size: 64px;
	}
	.openHours {
		width: 210px;
		font-size: 22px;
		padding: 20vh calc(50% - 105px);
	}
	.weekDays {
		font-size: 19px;
	}
	.spacer {
		width: 2rem;
		padding: 0 1rem;
	}
	.menu{
		min-height: 1000px;
		padding-left: 0px;
		padding-right: 0px;
		width: 100%;
		margin-bottom: -10px;
	}
	.titleMenu {
		font-size: 22.5px;
		margin: 0.5rem 0px;
	}
	.buttons{
		width: calc(100% - 51px);
		margin: 0.5rem 0px 10px 10px;
	}
	.buttons button {
		max-width: 100%;
		font-size: 16px;
	}
	.box {
		width: calc(100% - 35px);
		padding: 0.5rem;
		margin: 0.5rem 0px 10px 10px;
		line-height: 1rem;
	}
	.product {
		font-size: 14px;
	}
	.price {
		font-size: 14px;
	}
	.ingredients {
		font-size: 11px;
	}
	.footer {
		height: 15rem;
		font-size: 12px;
		padding-left: 16px;
		padding-right: 16px;
	}
	.contactInfo {
		margin-top: calc(5rem - 41px);
	}
	.footerOpenHours {
		width: 110px;
		margin-top: calc(5rem - 62px);
	}
	.footerOpenHours .weekDays {
		font-size: 12px;
		margin: 2px;
	}
}

@media screen and (max-width: 360px) {
	.logo {
		margin-left: 1rem;
		font-size: 24px;
	}
}

@media screen and (max-width: 290px) {
	.spacer {
		width: 1rem;
		padding: 0 0.5rem;
	}
	.footer {
		height: 8rem;
		font-size: 7px;
	}
	.contactInfo {
		margin-top: calc(4rem - 35px);
	}
	.footerOpenHours {
		width: 70px;
		margin-top: calc(4rem - 46px);
	}
	.footerOpenHours .weekDays {
		font-size: 7px;
		margin: 2px;
	}
}

.mapSecCon {
	width: calc(100% - 40px);
	height: 80vh;
	background-color: #1A1A1A;
	display: grid;
	padding: 20px;
}

.mapSection {
	height: 80vh;
	grid-column-start: 1;
	grid-column-end: 2;
	background: url('../img/staticMap.PNG') center no-repeat;
	background-size: cover;
}

.mapSectionInfo {
	height: 80vh;
	grid-column-start: 2;
	grid-column-end: 3;
}

@media screen and (max-width: 1350px) {
	.mapSectionInfo {
		grid-row-start: 2;
		grid-row-end: 3;
		grid-column-start: 1;
		grid-column-end: 2;
		max-height: fit-content;
	}
	.mapSecCon {
		height: calc(80vh + 300px);
	}

	#specInfo {
		margin-left: 10px;
		margin-top: 0px;
	}
	.mapSectionInfo {
		height: fit-content;
	}
}

#map {
	width: 100%;
	height: 100%;
}

.whiteSpace {
	white-space: normal;
}