/*****************************/
/**  /css/01-variables.css  **/
/*****************************/

:root {
	/*--color-primary: #60a960;*/
	--color-primary: #27668f;
	/*--color-secondary: #c14444;*/
	--color-secondary: #d13b3b;
	--color-tertiary: #c08315;
	--color-bg: #222;
	--color-bg-light: #666;
	--gradient: linear-gradient(90deg, var(--color-primary), #9c5cd0, var(--color-secondary));

	--font-text: 'Quicksand', sans-serif;
	--font-title: 'Fascinate Inline', sans-serif;
	--font-icon: 'Material Icons', sans-serif;

	--content-width: 1400px;

	--shadow: 0 0 20px 5px rgb(0, 0, 0, 0.4);
}


/*****************************/
/**  /css/02-animation.css  **/
/*****************************/

@keyframes opacity-0-1 { from {opacity: 0;} to {opacity: 1;} }
@keyframes opacity-1-0 { from {opacity: 0;} to {opacity: 1;} }
@keyframes scale-1-2 { from {transform: scale(1);} to {transform: scale(2);} }
@keyframes scale-2-1 { from {transform: scale(2);} to {transform: scale(1);} }
@keyframes left-0-100 { from {transform: translateX(0);} to {transform: translateX(100%);} }


/*************************/
/**  /css/03-style.css  **/
/*************************/

*, :before, :after {
	box-sizing: border-box;
}
body, h1, h2, h3, h4, h5, h6, ul{margin:0;}
header, footer, nav, article{display:block;}
a{color:inherit;text-decoration:none;}
input, select, textarea, button{font-family:inherit;border:0;outline:none;}
button{background:none;color:inherit;}
label[for], a[href], button{cursor:pointer;}

html, body {
	display: block;
	width: 100%;
	height: 100%;
}

body {
	background: var(--color-bg);
	color: white;
	font: 20px var(--font-text);
}



mi {
	display: inline-block;
	font-family: 'Material Icons';
	font-weight: normal;
	font-style: normal;
	letter-spacing: normal;
	text-transform: none;
	white-space: nowrap;
	word-wrap: normal;
	direction: ltr;
	-webkit-font-feature-settings: 'liga';
	-webkit-font-smoothing: antialiased;
}


.anchorTarget{position: absolute; margin-top: -85px;}






/* Input */
.form-item{display:block;}
.form-item + .form-item{margin-top:25px;}
.form-label{min-width:100%;font-weight:400;font-size:18px;line-height:20px;margin-bottom:10px;}
.form-label.required:after{margin-left:2px;color:#a54040;content:'*';}
.form-help{display:block;font-size:14px;line-height:20px;opacity:0.8;font-style:italic;margin:-5px 0 5px;}
.form-invisible{display:none;}
.form-input{display:block;width:100%;height:40px;padding:0 10px;font-size:16px;font-family:inherit;background-color:#444;color:white;border: 0;outline: none;}
textarea.form-input{min-height:150px;padding:10px;resize:vertical;}
.form-input[type=number]{direction:rtl;}
.form-input:disabled{background-color:#ddd;color:#777;}
.form-container{display:flex;}
.form-container .form-input{order:99;}
.form-prefix{flex:0;background-color:#333;color:white;font-weight:700;white-space:nowrap;line-height:40px;font-size:14px;padding:0 10px;}
.form-icon{min-width:40px;height:40px;line-height:40px;text-align:center;font-size:20px;background-color:#333;color:white;}
.form-icon svg{margin:10px;}
.form-icon svg > *{fill:white;}
.form-icon img{padding:2px;max-width:100%;max-height:100%;}
.form-row{display:flex;margin:0 -12.5px;}
.form-row-item{flex:1;margin:0 12.5px;}
.form-translation{background-color:#555;}
.form-translation .form-container + .form-container{margin-top:2px;}
.textarea-translation{display:flex;background-color:#555;flex:1;}
.textarea-translation-languages{width:50px;}
.textarea-translation-language{padding:5px;}
.textarea-translation-language img{display:block;}
.textarea-translation-language.selected{background-color:#444;}
.textarea-translation-areas{flex:1;min-height:150px;display:flex;}
.textarea-translation-area{display:flex;flex:1;}
.textarea-translation-area > textarea{min-height:100%;}
.textarea-translation-area .redactor-box{width:100%;}
.textarea-translation-area .redactor-in{cursor: auto;}
.form-checkbox-text{display:block;cursor:pointer;}
.form-checkbox-text:hover span{color:#555;}
.form-inline{display:inline;padding:0 2px;text-align:center;background:none;border-bottom:1px solid #333;}
.form-checkable:before{vertical-align:middle;font-size:1.2em;font-family:var(--font-icon);content:'check_box_outline_blank';}
input:checked + .input-checkable:before{content:'check_box';}


/***********************************/
/**  Component\AbstractComponent  **/
/***********************************/

body {margin: 0}


/*****************************/
/**  Component\App\Contact  **/
/*****************************/

.contact{position: relative; padding: 50px; margin: 100px 0 0; overflow: hidden;}
.contact-map{position: absolute; top: 0; left: 0; width: 100%; height: 100%;}
.contact-content{position: relative; background: rgba(34, 34, 34, 0.9); backdrop-filter: blur(5px); z-index: 90;}
.contact-content{display: inline-flex; flex-direction: column; gap: 25px; padding: 40px; border-radius: 15px; box-shadow: var(--shadow);}
.contact-infos{display: flex; flex-direction: column; gap: 15px;}
.contact-networks{display: flex; gap: 45px;}
.contact-data{display: flex; align-items: center; gap: 15px; font-size: 16px;}
.contact-data mi{font-size: 24px;}
a.contact-data:hover{color: var(--color-primary);}


/****************************/
/**  Component\App\Footer  **/
/****************************/

.footer{background: rgba(255, 255, 255, 0.025); position: relative; box-shadow: var(--shadow);}
.footer-copyright{padding: 20px 20px; display: flex; justify-content: center; font: 100 16px/normal var(--font-text); gap: 20px;}
.footer-copyright a:hover{text-decoration: underline;}


/****************************/
/**  Component\App\Header  **/
/****************************/

.header{position: fixed; top: 0; left: 0; right: 0; z-index: 100;}
.header-content{display: flex; height: 80px; align-items: center; gap: 25px; max-width: var(--content-width); margin: 0 auto; padding: 0 25px;}
.header-title{font: 900 48px/1.25 var(--font-title); text-transform: uppercase;}
.header-menu{display: flex; margin: auto; gap: 25px;}
.header-link{font: 700 20px/36px var(--font-text); text-transform: uppercase;}
.header-order{display: flex; align-items: center; gap: 10px; background: white; color: #222; padding: 10px 20px; border-radius: 10px; text-align: center;}
.header-order mi{font-size: 32px;}
.header-order div:first-child{font: 700 18px/18px var(--font-text);}
.header-order div:last-child{font: 700 24px/24px var(--font-text);}
.header-underline{position: absolute; height: 2px; background: var(--gradient); transition: 0.2s;}
@media (max-width: 1200px) {
	.header-title{font-size: 36px;}
	.header-link{font-size: 16px;}
	.header-order mi{font-size: 24px;}
	.header-order div:first-child{font-size: 14px;}
	.header-order div:last-child{font-size: 18px;}
}


/**************************/
/**  Component\App\More  **/
/**************************/

.more-sections{margin: 70px auto 0; padding: 0 25px; max-width: var(--content-width); display: grid; gap: 50px; grid-template-columns: repeat(3, 1fr);}
.more-section{position: relative; border: 1px solid white; align-self: flex-start; display: flex; flex-direction: column; align-items: center; padding: 0 25px 25px;}
.more-section{border-radius: 20px 60px 20px 60px / 60px 20px 60px 20px;}
.more-title{font: 700 32px/1 var(--font-title); padding: 0 25px; margin: -16px 0 25px; background: var(--color-bg);}
.more-items{width: 100%; display: grid; grid-template-columns: 1fr auto; gap: 10px;}
.more-item-price{font-weight: 700; text-align: right;}
.more-section-child .more-item-price{grid-row: 1/4; grid-column: 2/3; font-size: 30px; font-weight: 700; align-self: center;}
.more-background{position: absolute; top: 50%; left: 0; right: 0; font-size: 120px; line-height: 0; text-align: center; opacity: 0.05; z-index: -1;}


/**********************************/
/**  Component\App\OpeningHours  **/
/**********************************/

.openingHours{font-size: 14px; line-height: 26px; flex: 1;}
.openingHours > div{display: flex; justify-content: space-between; gap: 30px;}
.openingHours > .selected{font-weight: 700;}
.openingHours span{white-space: pre;}


/*******************************/
/**  Component\App\PizzaCard  **/
/*******************************/

.pizzaCard{display: flex; flex-direction: column; gap: 15px; height: 100%; padding: 15px;}
.pizzaCard{background: rgba(255, 255, 255, 0.025); border-radius: 15px; outline: 2px solid transparent; transition: 0.5s;}
.pizzaCard-picture{width: 100%; aspect-ratio: 1; object-fit: contain; border-radius: 7px;}
.pizzaCard-name{font: 700 24px/normal var(--font-text); letter-spacing: 1px; text-align: center;}
.pizzaCard-type{font: italic 700 16px/normal var(--font-text); text-align: center; margin-top: -12px;}
.pizzaCard-type.tomate{color: var(--color-secondary);}
.pizzaCard-type.crème{color: var(--color-primary);}
.pizzaCard-ingredients{font: 400 16px/normal var(--font-text);}
.pizzaCard-notes{font: italic 700 12px/normal var(--font-text); margin-top: -10px; color: orange;}
.pizzaCard-prices{display: flex; text-align: center; margin-top: auto;}
.pizzaCard-price{flex: 0 0 50%;}
.pizzaCard-price > div:first-child{font-size: 16px;}
.pizzaCard-price > div:last-child{font: 700 24px/normal var(--font-text);}
.pizzaCard:hover{background: rgba(255, 255, 255, 0.075); outline: 1px solid var(--color-bg-light);}


/*******************************/
/**  Component\App\PizzaList  **/
/*******************************/

.pizzaList{display: flex; flex-direction: column; gap: 50px; margin: 100px 0;}
.pizzaList-list{list-style: none; display: flex; gap: 25px; flex-wrap: wrap; justify-content: center; max-width: var(--content-width); padding: 0 25px; margin: 0 auto;}
.pizzaList-item{flex: 0 0 250px; max-width: 250px;}


/*************************************/
/**  Component\App\PizzaOfTheMonth  **/
/*************************************/

.pizzaOfTheMonth{margin: 100px 0; padding: 0 25px;}
.pizzaOfTheMonth-card{max-width: 700px; margin: 50px auto; padding: 25px; display: flex; gap: 50px;}
.pizzaOfTheMonth-card{background: rgba(255, 255, 255, 0.025); border-radius: 15px; outline: 2px solid transparent; transition: 0.5s;}
.pizzaOfTheMonth-content{display: flex; flex-direction: column; gap: 20px;}
.pizzaOfTheMonth-picture{grid-row: 1/7; border-radius: 7px; align-self: center;}
.pizzaOfTheMonth-description{}
.pizzaOfTheMonth-card:hover{background: rgba(255, 255, 255, 0.075); outline: 1px solid var(--color-bg-light);}
.pizzaOfTheMonth .pizzaCard-name{font-size: 28px;}
.pizzaOfTheMonth .pizzaCard-type{font-size: 18px;}
.pizzaOfTheMonth .pizzaCard-ingredients{font-size: 18px;}
.pizzaOfTheMonth .pizzaCard-notes{font-size: 14px;}
.pizzaOfTheMonth .pizzaCard-price > div:first-child{font-size: 18px;}
.pizzaOfTheMonth .pizzaCard-price > div:last-child{font-size: 28px;}


/*****************************/
/**  Component\App\Reviews  **/
/*****************************/

.reviews{padding: 100px 50px 50px;}
.reviews a[href^="https://elfsight.com"]{filter: opacity(0) !important; pointer-events: none !important;}
.reviews .eapps-widget-toolbar{display: none !important;}
.reviews .es-rating-value{color: white !important;}
.reviews .es-header-rating-reviews-count{color: white !important;}


/***************************/
/**  Component\App\Title  **/
/***************************/

.title{font: 700 48px/normal var(--font-title); text-transform: uppercase; text-align: center;}
.title span{position: relative;}
/*.title span::before{position: absolute; top: -2px; left: 0; right: 0; height: 2px; background: var(--gradient); content: '';}*/
.title span::after{position: absolute; bottom: -2px; left: 0; right: 0; height: 2px; background: var(--gradient); content: '';}
/*.title span{border-style: solid; border-width: 2px 0; border-color: var(--color-secondary) transparent var(--color-primary);}*/
h1.title{font-size: 64px;}


/*****************************/
/**  Component\App\Welcome  **/
/*****************************/

.welcome{position: relative; min-height: 100vh; display: flex; overflow: hidden; padding: 130px 50px 50px;}
.welcome-background{position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 40%; opacity: 0.7;}
.welcome-content{position: relative; margin: 0 auto; display: flex; flex-direction: column; justify-content: space-evenly; z-index: 1;}
.welcome-content{text-align: center; align-items: center; gap: 30px;}
.welcome-titles{text-shadow: 0.1em 0.1em 0.1em rgb(0 0 0 / 50%);}
.welcome-slogan{font: italic 700 32px/1 var(--font-text); margin-top: 20px;}
.welcome-infos{background: rgba(34, 34, 34, 0.9); backdrop-filter: blur(5px); padding: 40px; border-radius: 15px; box-shadow: var(--shadow);}
.welcome-infos{position: relative; display: grid; grid-template-columns: 1fr auto; gap: 40px 60px; max-width: 700px;}
.welcome-description{font: 400 20px/1 var(--font-text); grid-column: 1/3;}
.welcome-hours{display: flex; flex-direction: column; gap: 15px; }
.welcome-contact{display: flex; flex-direction: column; gap: 15px; white-space: nowrap;}
.welcome-networks{display: flex; gap: 20px;}
.welcome-data{display: flex; align-items: center; gap: 15px; font-size: 16px;}
.welcome-data mi{font-size: 24px;}
a.welcome-data:hover{color: var(--color-primary);}
.welcome-warning{font: 700 16px/normal var(--font-text); color: var(--color-tertiary); grid-column: 1/3; margin: -10px 0;}
.welcome-fidelity{position: absolute; left: 100%; top: 100%; white-space: nowrap;}
.welcome-fidelity{padding: 12px; transform: translate(-50%, -60%) rotateZ(-10deg);}
.welcome-fidelity{
--grid: #2A2A2A;
border: 1.5px solid var(--grid);
background: var(--color-bg);
background-size: 6.25% 12.5%;
background-image:
	linear-gradient(var(--grid) 0.5px, transparent 0.5px, transparent calc(100% - 0.5px), var(--grid) calc(100% - 0.5px)),
	linear-gradient(90deg, var(--grid) 0.5px, transparent 0.5px, transparent calc(100% - 0.5px), var(--grid) calc(100% - 0.5px));
}
.welcome-fidelity-title{font-size: 18px; font-weight: 700; text-transform: uppercase;  backface-visibility: hidden;}
.welcome-fidelity-explanation{font-size: 14px; font-style: italic; margin: 4px 0; backface-visibility: hidden;}
.welcome-fidelity-offer{font-size: 16px; backface-visibility: hidden;}


/********************************/
/**  Component\Composite\Form  **/
/********************************/

form[loading]::before{
position: absolute;
top:0;
left: 0;
right: 0;
bottom: 0;
background: rgba(0, 0, 0, 0.2);
content: '';
z-index: 1000;
}


/*********************************/
/**  Component\Composite\Popup  **/
/*********************************/

.popup {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	overflow: auto;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.2);
	backdrop-filter: blur(30px);
	animation: opacity-0-1 0.3s;
	z-index: 100;
}
.popup[closed] {
	transition: 0.5s;
	opacity: 0;
}
.popup > * {
	animation: opacity-0-1 0.3s, scale-2-1 0.3s;
}
.popup[closed] > * {
	animation: opacity-1-0 0.5s, scale-1-2 0.5s;
}


/********************************/
/**  Component\Composite\Tabs  **/
/********************************/

.tabs{display:flex;flex-wrap:wrap;background-color:#eee;}
.tabs-handle{position: relative;flex:1 auto;display:flex; align-items: center; justify-content: center; gap: 5px; height:50px;background-color:#ddd;padding:0 25px;order:1;}
.tabs-handle{font:700 20px/50px var(--font-title);cursor: pointer;}
.tabs-handle:hover{background-color:#e5e5e5;}
.tabs-handle ~ .tabs-handle::before{position:absolute;top:10px;bottom:10px;left:-1px;border-right:2px solid #ccc;content:'';}
.tabs-content{min-width:100%;min-height:50px;display:none;order:2;}
.tabs-handle[selected]{background-color:#eee;}
.tabs-content[selected]{display: block;}


/*****************************/
/**  Component\Form\Button  **/
/*****************************/

.button{position:relative;display: inline-flex; vertical-align:middle;height:40px;background-color:#333;padding: 0 15px 0 0; gap: 15px; overflow: hidden;}
.button{color: white; text-align:center;font:600 20px/40px var(--font-title);text-transform:uppercase;}
.button > mi{height: 40px; width: 40px; background-color: rgba(0, 0, 0, 0.1);}
.button:hover{opacity:0.9;}
.button:hover > mi{}
.button:hover::after{position: absolute; top:0; bottom: 0; left: -20%; width: 20px; transform: skewX(-20deg); background: rgba(255, 255, 255, 0.5); animation: button-bright 0.5s;content: '';}
@keyframes button-bright {
	from {left: -20%;}
	to {left: 120%;}
}

.button.main{background-color:hsl(var(--hue), 24%, 41%);}
.button.red{background-color:#a54040;}
.button.green{background-color:#70b949;}
.button.blue{background-color:#2186de;}
.button.purple{background-color:#7a6dbb;}
.button.brown{background-color:#c37f4a;}
.button.grey{background-color:#777777;}
.button.black{background-color:#444444;}


/***************************************/
/**  Component\Module\AbstractModule  **/
/***************************************/

.module{position: relative;display:inline-block;vertical-align:top;margin:50px;background-color:white;box-shadow:0 0 25px 0 rgba(0, 0, 0, 0.2);font-size:16px;}
.module-head{display:flex;height:50px;line-height:50px;background-color:white;font-size:0;}
.module-head-icon{flex:0;min-width:50px;text-align:center;font-size:24px;}
.module-head-icon[href]:hover, .module-head-icon[type=button]:hover{background-color:#eeeeee;cursor:pointer;}
.module-head-icon.close{order:99;}
.module-head-title{flex:1;font-size:20px;font-weight:700;padding:0 24px 0 0;text-transform:uppercase;font-family:'Open Sans Condensed', sans-serif;}
.module-head-title{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;}
.module-head-title strong{font-weight:200;}
.module-body{background-color:#eeeeee;padding:25px;}
.module-body .module-foot{margin:25px -25px -25px -25px;}
.module-foot{background-color:white;padding:5px 25px;text-align:right;}
.module.red .module-head{color:#de4f4f;}
.module.red .module-text{color:#de4f4f;background-color:rgba(222, 79, 79, 0.1);}
.module.green .module-head{color:#4CAF50;}
.module.green .module-text{color:#4CAF50;background-color:rgba(76, 175, 80, 0.1);}


