@font-face {
  font-family: 'Avenir-Black';
  src: URL(Avenir-Black.woff2) format('woff2');
}
@font-face {
  font-family: 'Avenir-Book';
  src: URL(Avenir-Book.woff2) format('woff2');
}
@font-face {
  font-family: 'Avenir-Light';
  src: URL(Avenir-Light.woff2) format('woff2');
}
@font-face {
  font-family: 'Avenir-Medium';
  src: URL(Avenir-Medium.woff2) format('woff2');
}
@font-face {
  font-family: 'ChikenQuiche';
  src: URL(ChikenQuiche.woff2) format('woff2');
}
@font-face {
  font-family: 'BebasNeue';
  src: URL(BebasNeue-Regular.woff2) format('woff2');
}
@font-face {
  font-family: 'Britannic';
  src: URL(Britannic.woff2) format('woff2');
}

html, body {
  margin: 0px;
  padding: 0px;
  height: 100%;
  width: 100%;
  font-family: 'Avenir-Book';
  font-size: 18px;
  color: #707070;
}

.small_promo { 
  font-size: 11px;
  color: #c80000;
  display: inline-block;
  transform: rotate(-35deg);  
 }

#spinner {
	position: fixed;
	top: 0px;
	left: 0px;
	width: 100%;
	height:100%;
	display: none;
	align-items: center;
	justify-content: center;
	z-index: 2;
	background-color: rgba(255,255,255,.25);
}
#spinner:before {
	content: ' ';
	display: block;
	position: absolute;
	width: 110px;
	height: 110px;
	border-radius: 100%;
	background: URL(payplug-logo.png) no-repeat center;  
	background-color: white;
}
#spinner:after {
	content: ' ';
	display: block;
	position: absolute;
	width: 100px;
	height: 100px;
	border: 5px solid #cbcbca;
	border-top-color: #2380be;
	border-radius: 100%;
	animation: rotation .7s linear infinite;
}
@keyframes rotation {
	0% { transform: rotate(0deg) }
	to  { transform: rotate(359deg) }
}

a { 
  text-decoration: none;
  color: #707070;
}

select {
  outline: none;
}

.error { background-color: orange }

.scroll {
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  min-height: 50%;
}

.scroll img { 
  width: 100%;
  /*max-height: 50%;*/
  object-fit: cover;
  object-position: bottom left;
 }
.pizzas .pico img {
  flex: 0 0 446px;
}
@media screen and (min-width: 446px) {
	.scroll img {
		object-fit: cover;
	}
}
.fl,
.fv {
  display: flex;
}
.fv {
  flex-direction: column;
}
.fill { flex: 1 }
.wrap { flex-wrap: wrap }
.ac { align-items: center }
.jc { justify-content: center }
.sa { justify-content: space-around }
.m20 { margin: 20px }
.m5 { margin: 5px }
.ma { margin: auto }
.max50 { max-width: 50% }
.w100 { width: 100% }
.click { cursor: pointer }
.tc { text-align: center }
.tr { text-align: right }
.tu { text-transform: uppercase }
.pre { white-space: pre }

/* TOP */

.round {
  border-radius: 50%; 
}
.clWhite {
   color: white; 
}
.clRed {
  color: #c80000;
}
.bkRed {
  background-color: #c80000;
}
.clGreen {
  color: #85a011;
}
.bkGreen {
  background-color: #85a011;
}
.bkGreen2 {
  background-color: #f0f7e7;
}
.bdGreen {
  border-color: #85a011;
}
.clBlue {
  color: #7db3cb;
}
.bkBlue {
  background-color: #7db3cb;
}
.bkBlue2 {
  background-color: #f2f7fa;
}
.bdBlue {
  border-color: #7db3cb;
}
.clCoupe {
  color: #6d6ddf;
}
.bkCoupe {
  background-color: #6d6ddf;
}

.clViande {
  color: #af8e6d;
}
.bkViande {
  background-color: #af8e6d;
}
.bkViande2 {
  background-color: #f8f4f1;
}
.bdViande {
  border-color: #af8e6d;
}
.clWater {
  color:#254a9a;
}
.bkWater {
  background-color: #254a9a;
}

.top {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  border-bottom: 4px solid #c70000;
  font-family: 'Avenir-Light';
  flex: 0 0 40px;
}
.top a {   
  margin: 5px;
  line-height: 24px;
}
.Instagram {
  background: URL(Instagram.png);
  font-size: 0;
  display: inline-block;
  width: 24px;
  height: 24px;
  margin-left: 40px;
}
.Facebook {
  background: URL(Facebook.png);
  font-size: 0;
  display: inline-block;
  width: 24px;
  height: 24px;
  margin-right: 40px;
}

.page {
   display: flex;
   flex-direction: column;
   height: 100%;
}

/* MENU */
.menuItems {
  display: flex;
  flex: 1;
  flex-wrap: wrap;
  justify-content: space-around;
  align-content: center;
}
.menuItems div {
	margin: 5px;
}
.menuItems a {
	display: block;
}
.menu {
  font-family: Avenir-Light;
  display: flex;
  justify-content: space-between;
  margin: 10px;
}
.menu>span {
  align-self: center;
}
.menu>* {
  padding: 20px;
  text-transform: uppercase;
}
.subMenu {
  display: flex;
  flex-direction: column;
  text-align: center;
}
.subMenu>a:first-child,
.subMenu .active {
  color: #cf0000;
}
.options select {
  font-family: Avenir-Light;
  color: #707070;
  text-transform: uppercase;
  padding: 10px;
  border: 1px solid gray;
  border-radius: 20px;
}
.logo {
  position: relative;
  display: flex;
}
.logo span {
  background: URL(Logo.png) no-repeat center;
  background-size: contain;
  font-size: 0;
  display: inline-block;
  width: 100%;
  height: 100%;
}

.menu2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 0px;
  padding-top: 0px;
  flex: 0 0 155px;
}
.Panier {
  display: inline-block;
  position: relative;
}
.Panier span {
  background: URL(Panier.png) no-repeat center;
  background-size: contain;
  font-size: 0;
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0px;
  left: 0px;
}
.BonsPlans {
  font-family: ChikenQuiche;
  color: white;
  background-color: #1095A0;
  padding: 8px 15px;
  border-radius: 25px;
  font-size: 25px;
  margin-top: 20px;
}
.menuItems a.BonsPlans2 {
  font-family: ChikenQuiche;
  color: white;
  background-color: #1095A0;
  padding: 8px 15px;
  border-radius: 25px;
  font-size: 25px;
  margin-top: 20px;
  display: inline-block;
  transform: rotate(-10deg);
}

/* FRONT PAGE */

.p1 { 
  text-align: center;
  text-transform: uppercase;
  display: flex;
  flex-direction: column;
  justify-content: center; 
  margin: 50px;
}

.p2 { 
  text-align: center;
  text-transform: uppercase;
  font-family: BebasNeue;
  font-size: 30px;
  letter-spacing: 5px;
  margin: 50px 0px;
}
.p2 a {
  margin-left: 20px;
}

.btCommander {
	font-family: 'Avenir-Light';
	background-color: #c80000;
	color: white;
	text-align: center;
	text-transform: uppercase;
	padding: 20px;
	cursor: pointer;
	display: none;
}

.front_wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.front_wrap>a {
  text-align: center;
  width: 380px;
  max-width: 50%;
  display: flex;
  flex-direction: column;
  align-self: flex-end;
  margin: 30px 0px;
}
.front_wrap>a>span {
  display: inline-block;
  font-family: ChikenQuiche;
  font-size: 6vw;  
  transform: rotate(-20deg);
  margin-bottom: 5px;
  margin-left: -15%;
}

.hp_image {
  background: URL(Homepage-ronde.jpg) no-repeat center;
  background-size: contain;
  height: 0%;
  padding-top: 60%;
}

.hp_pizzas_rondes {
  background-image: URL(Homepage-ronde.jpg);
}
.hp_pizzas_rectangulaires {
  background-image: URL(Homepage-rectangle.jpg);
}
.hp_sous_marins {
  background-image: URL(Homepage-sousmarins.jpg);
}
.hp_frangos {
  background-image: URL(Homepage-frangos.jpg);
}
.hp_salades {
  background-image: URL(Homepage-salades.jpg);
}
.hp_pates {
  background-image: URL(Homepage-pates.jpg);
}
.hp_desserts {
  background-image: URL(Homepage-desserts.jpg);
}
.hp_boissons {
  background-image: URL(Homepage-boissons.jpg);
}

.gray { 
  background-color: #e8e8e8;
  text-align: center;
}

.gray table {
  margin: auto;
  margin-top: 30px;
  font-size: 3vw;
}
.gray table th {
  text-transform: uppercase;
}
.gray table td {
  padding: 0px 25px;
}

.t1 {
  font-family:Britannic;
  font-size: 28px;  
  font-weight: bold;
  margin-bottom: 10px;
}

.bold {
  font-weight: bold;
}

.p3 {
  font-size: 20px;
}

.gray tr.tel td {
  font-weight: bold;
  padding: 10px;
}

.hp_logo {
  background-color: white; 
  height: 100px;
  border-radius: 0% 0% 50% 50%;
}
.hp_logo>div {
  background: URL(Logo.png) no-repeat center;
  height: 85px;
}
.hp_bow {
  background-color: white; 
  height: 100px;
  border-radius: 50% 50% 0% 0%;  
}

.lines {
  text-align: center;
}
.lined {
  border-bottom: 1px solid #707070;
  position: relative;
  top: -50%;
}
.Horaires {
  display: inline-block;
  width: 36px;
  height: 36px;
  background: URL(Clock.png);
}

.Facebook2 {
  background: URL(Facebook2.png);
  font-size: 0;
  width: 36px;
  height: 36px;
  display: inline-block;
}

.copy {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0px 50px 20px 50px;
}

.round_menu { 
  display: flex;
  place-self: center;
}
.round_menu span {
  display: inline-block;
  width: 60px;
  height: 60px;
  border: 1px solid gray;
  border-radius: 50%;
  font-size: 0;
  margin: 5px;
  background-size: contain;
}
.round_vegetarien {
  background-image: URL(round_vegetarien.png);
  border-color: #85a010;
}
.round_poisson {
  background-image: URL(round_poisson.png);
  border-color: #7db3cb;
}
.round_crevettes {
  background-image: URL(round_crevettes.png);
  border-color: #7db3cb;
}
.round_poulet {
  background-image: URL(round_poulet.png);
  border-color: #a35c07;
}
.round_viande {
  background-image: URL(round_viande.png);
  border-color: #af8e6d;
}
.round_coupe {
  background-image: URL(round_coupe.png);
  border-color: blue
}
.rond {
  font-family: ChikenQuiche;
  font-size: 4vw;
  text-align: center;
  margin-bottom: 0px;
  padding-bottom: 0px;
}
.rond0 {
  color: #85a010;
}
.rond1 {
  color: #7db3cb;
}
.lines.picto {
  display: flex;
  justify-content: center;
  margin: 0px;
}
.lines.picto span { 
  display: block; 
  width: 15vw; 
  height: 15vw;
  max-width: 120px;
  max-height: 120px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;  
}
.lines.picto2 span { 
  display: block; 
  width: 80px; 
  height: 80px;
  background-size: cover;
}

.lines.picto *::before {
  top: 60px;
}
.lines.picto *::after {
  top: 60px;
  left: 150px;
}
.lines.picto.line0 *::before,
.lines.picto.line0 *::after { border-color: #85a010 }

.spinner { user-select: none; }

.moveCart {
  position: absolute;
  padding: 25px;
  background-color: #71a400;
  color: white;
  border-radius: 50%;
}
#counter {
  display: none;
  color: #c80000;
  border: 1px solid #c80000;
  background-color: white;
  width: 25px;
  height: 25px;  
  border-radius: 50%;
  text-align: center;
  position: absolute;
  padding: 2px;
  bottom: -5px;
  right: -5px;
}

.enpromo .horspromo,
.horspromo .enpromo,
.enpromo2 .horspromo2,
.horspromo2 .enpromo2 { display: none }

.pizzas {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.pizza {
  width: 350px;
  text-align: center;
  max-width: 50%;
  margin-bottom: 50px;
}
.detail {
  display: flex;
  text-align: center;
}
.detail {
  justify-content: center;
}
.desc {
	font-size: 14px;
}
.title {
  font-weight: bold;
  font-size: 5vw;
}
.scroll .detail img {
  object-fit: contain;
}
.fitHeight {
  height: fit-content;
}
.band1, .band2 {
  padding: 20px;
  display: flex;
  justify-content: center;
  text-transform: uppercase;
  align-items: center;
  flex-wrap: wrap;
}
.spinner,
.band1 select,
.band1 option {
  text-transform: uppercase;
  padding: 5px;
  border: none;
  border-radius: 10px;
  line-height: 24px;
  margin: 10px;
  font-family: 'Avenir-Book';
  font-size: 18px;  
}
.spinner {
  color: black;
  background-color: white;
}
.spinner *:nth-child(n+2) {
  width: 24px;
  text-align: center;
}
.tailles {
  display: flex;
  align-items: flex-end;  
  text-align: center;
  width: 300px;
  justify-content: center;
}
.taille1,
.taille2 {
  margin: 0px 10px;
  cursor: pointer;
  border: 1px solid transparent;
}
.vert {
  text-align: center;
  height: 81px;
  width: 24px;
  text-orientation: mixed;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
}
.tailleRect {
  background-color: white;
  border-radius: 10px;
  color: black;
  width: 114px;
  height: 81px;
  font-size: 30px;
  line-height: 81px;
}
.tailles .active {
  border: 1px solid white;
  border-radius: 10px;
}
.tailles .cm { font-size: 10px }
.tailles .dim {
  color: black;
  background-color: white;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  font-weight: bold;
  padding-bottom: 15px;
  margin: 5px;
}
.taille1 .dim { width:  75px; height: 60px}
.taille2 .dim { width: 100px; height: 85px; font-size: 28px }
.tailles .nom {
  display: block;
  font-size: 12px;
}
.suppl {
  max-width: 80%;
}
.suppl div,
.suppr div {
  font-size: 24px;
}
.suppl select {
  margin: 10px;
  padding: 5px;
}
.suppr label {
  margin-left: 20px;
  position: relative;
}
.suppr input:checked::after {
  content: '';
  width: 100%;
  border-bottom: 1px solid red;
  height: 1px;
  display: block;
  position: absolute;
  top: 50%;  
}
.descr {
  padding: 10px;
  height: 100px;
  font-size: 16px;
}
.tarif {
  position: relative;
  display: flex;
  align-items: center; /* vertical */
  justify-content: space-around;
  height: 20vw;
  max-height: 50px;
}
.prix {
  font-family: ChikenQuiche;
  border-bottom: 2px solid;
  display: inline-block;
}
.prix .euro {
  font-size: 24px;
  position: relative;
  top: -8px;
}
.tarif .cart {
  position: absolute;
  right: 0px;
  width: 12vw;
  height: 12vw;
  max-width: 90px;
  max-height: 90px;
  padding: 0px;
}
.pizza_not_found {
  width: 290px;
  margin: 0px 30px 30px 30px;
  height: 200px;
  border-radius: 50%;
  background-color: #ffc107;
  box-shadow: 10px 10px 20px 0px silver;
  line-height: 200px;
  text-align: center;
  font-size: 40px;
}

.addCart {
  display: flex;
  align-items: center;
  border-radius: 60px;
  padding: 10px 20px;
  color: white;
}
.addCart div {
  padding: 5px;
  text-transform: uppercase;
  text-align: center;
}
.addCart round {
  border: 1px solid white;
  border-radius: 50%;
}
.total {
  margin: 10px 50px;
}
@supports (-webkit-mask-image: url(#mask)) or (mask-image: url(#mask)) {
  .addCart .round { background-color: white; max-width: 80px }
  .Panier span.miGreen { background: none; background-color: #85a011 }
  .Panier span.miBlue { background: none; background-color: #7db3cb }
  .Panier span.miViande { background: none; background-color: #af8e6d }
  .Panier span.miCoupe { background: none; background-color: #4747ff }
  .addCart .round span {
    -webkit-mask: URL(Panier.png) no-repeat center;
	-webkit-mask-size: contain;
    mask: URL(Panier.png) no-repeat center;
	mask-size: contain;
  }
}
.articles {
  background-color: gray;
  color: white;
  margin: 5px;
  padding: 5px;
  border-radius: 10px;
}
.continue {  
  color: white;
  padding: 10px 20px;
  border-radius: 10px;
}
.frangos {
  text-align: center;
  padding: 20px;
}
.frangos .tarif  {
  width: 60%;
  height: 90px;
  margin-top: 40px;
}
.frangos img {
  border-radius: 50px;
}

.salades img {
  width: 350px;
  max-width: 50%;
}
.salades .tarif,
.pates .tarif {
  height: 90px;
  margin-top: -40px;
}
.salade,
.pate {
  width: 350px;
  text-align: center;
  margin: 20px;
}
.pates img {
  width: 350px;
  max-width: 50%;
  border-radius: 50px;
  margin: 20px;
}
.boisson {
  width: 300px;
  max-width: 50%;
  text-align: center;
}
.boisson img {
  width: 190px;
}
/* Mobile First */
.top {
	display: none;
}
#toggle {
	align-self: center;
}
#toggle .bars {
	display: inline-block;
    position: relative;
    width: 40px;
    height: 20px;
    border-top: 4px solid darkgray;
    border-bottom: 4px solid darkgray;
    cursor: pointer;
	padding: 0px;
    margin-left: 5px;	
	align-self: center;
}
#toggle .bars:before {
    content: ' ';
    position: absolute;
    top: 8px;
    left: 0px;
    height: 4px;
    width: 40px;
    background-color: darkgray;	
}
.collapse {
	 display: none;
}
.logo {
	flex: 3;
	text-align: center;
}
.menu {
	flex: 0 0 126px;
}
.menu2 {
	flex: 1;
	max-width: 90px;
	padding: 0px;
	align-self: center;
}
.optionsRoot {
  position: relative;
}
.options {
  margin-bottom: 10px;
  text-align: center;
}
.Panier {
  width: 100%;
  height: auto;
  aspect-ratio: 1/1;
}
.BonsPlans {
	display: none;
}
.p1, .f3 { font-size: 3vw }
.p2 { font-size: 2.5vw }
.copy { font-size: 3vw }

.bkRedGray {
  background-color: darkgray;
}

.hideMenu .btCommander { display: block }
.hideMenu .scroll { flex: 1 }
.hideMenu .menuExtend { flex: 1 }
.hideMenu .menuHidden,
.hideMenu .menuHiddenFlex {
	display: none;
}

.collect {
	background: URL(collect.png) no-repeat center;
	width: 128px;
	height: 128px;
}

/*.scroll .detail img { max-width: 50% }*/

@media screen and (max-width: 1070px) {
	.quickMenu .menuItems {
		display: block;
		position: absolute;
		background-color: white;
		top: 145px;
		left: 0px;
		width: 100%;
		text-align: center;
		padding: 0px 0px 50px 0px;
		box-shadow: 5px 5px 5px silver;
		z-index: 1;
	}
	.quickMenu .menuItems div {
		padding: 5px;
	}
  .band2 {
	  flex-direction: column;
  }
}
.prix {
	  font-size: 5vw;
	  padding: 0px 2vw;
}
.fx {
	flex-direction: column;
}
@media screen and (min-width: 1070px) {
	.top { display: flex }
	.top2 { display: none }
	.copy { font-size: 18px }
	.prix {
		font-size: 30px;
		padding: 0px 20px;
	}
	.fx { flex-direction: row }
	.fx.rev {
		flex-direction: row-reverse;
	}
	#toggle {
		display: none;
	}
	.collapse {
		display: flex;
	}
	.menu {
       flex: 0 0 174px;
	}
	.logo {
		flex: 0 0 256px;
	}	
	.logo span {
		max-width: 256px;
	}
	.menu2 {
		flex: 0 0 155px;
		max-width: none;
		padding: 20px;
		padding-top: 0px;
		align-self: auto;
	}
	.menuItems a.BonsPlans2 { display: none }
	.Panier {
		width: 90px;
		height: 90px;
		padding: 0px;
	}
	.scroll img {
		max-height: none;
	}
	.optionsRoot {
	  position: relative;
	}
	.options {
	  position: absolute;
	  bottom: 10px;
	  left: auto;
	  right: 200px;
	}
	.BonsPlans {
		display: block;
	}
	.f3 { font-size: 15px }
	.p1 { font-size: 24px }
	.p2 { font-size: 30px }
	.bkRedGray {
		background-color: #c80000;
	}
	.front_wrap>a {
		margin: 30px;
	}
	.front_wrap>a>span {
		font-size: 60px;
	}
	.hp_image {
		padding-top: 100%;
	}
	.hideMenu .btCommander {
		display: none;
	}
	.hideMenu .menuExtend {
		flex: auto;
	}
	.hideMenu .menuHidden {
		display: block;
	}
	.hideMenu .menuHiddenFlex {
		display: flex;
	}
	.scroll .detail img { max-width: 300px }
	.title {
		font-size: 24px;
	}
	.descr {
		font-size: 18px;
	}
	.gray table { font-size: 18px }
}