/*
>>> TABLE OF CONTENTS:

1. Custom Properties
2. Fonts
3. General
4. Header
5. Initial Screen
6. Wine Bottle
7. Product Info
8. Dishes
9. Final Selection
10. Elements
11. Footer
12. Section Positioning
13. Dishes Areas
14. Animations

*/

/* 1. Custom Properties */
:root {
	--app-color-white: #ffffff;
	--app-color-black: #000000;
	--app-color-transparent: rgba(0, 0, 0, 0.7);

	--app-font-color: var(--app-color-white);
	--app-background-color: var(--app-color-black);
	--app-svg-position-y: -24px;

	--app-bubble-radius: 110px 110px 40px;
}

/* 2. Fonts */
@font-face {
	font-family: Outfit;
	font-display: swap;
	src: url('../fonts/outfit-variable.ttf');
}
@font-face {
	font-family: Cinzel;
	font-display: swap;
	src: url('../fonts/cinzel-600.ttf');
}

/* 3. General */
body {
	background-color: var(--app-background-color);
	color: var(--app-font-color);
	font-family: Outfit, sans-serif;
	width: 100vw;
	height: 100vh;
	position: relative;
	overflow: hidden;
	padding: 0;
	margin: 0;
	transition-duration: 0.5s;
}
body[data-style="red"] {
	/* --app-svg-position-y: -24px; */
}
body[data-style="white"] {
	/* --app-svg-position-y: 0; */
}
.app-effets {
	display: none;
}

main {
	width: 100vw;
	height: 100vh;
	position: relative;
	overflow: hidden;
	padding: 0;
	margin: 0;
	opacity: 0;
	transition: opacity 0.5s;
}
main.ready {
	opacity: 1;
}
h1, h2, h3, h4, h5, h6 {
	font-family: Cinzel, serif;
	margin: 0;
	line-height: 1.1;
	letter-spacing: 1px;
}
h1 {
	font-size: 80px;
	text-align: center;
}
h2 {
	font-size: 50px;
}
h3 {
	font-size: 31px;
}
p {
	margin: 0 0 8px;
}
ul, li {
	list-style-type: none;
	margin: 0;
	padding: 0;
}
label {
	pointer-events: auto;
}
button {
	border: none;
	background-color: var(--app-color-transparent);
	color: var(--app-font-color);
	font-size: 16px;
	border-radius: 10px;
	height: 50px;
	min-width: 50px;
	padding: 13px;
	position: relative;
	pointer-events: auto;
	outline: none;
}
button * {
	pointer-events: none;
}
button.open-dialog-button {
	position: absolute;
	top: 50%;
	width: 100px;
	height: 200px;
	translate: 0 -50%;
	background-color: transparent;
	text-indent: -9999px;
}
button.open-dialog-button.product-scan {
	right: 0;
}
button.open-dialog-button.image-reference {
	left: 0;
}
section:not(.initial-screen) {
	display: grid;
	grid-template-columns: 32px repeat(20, 1fr) 32px;
	grid-template-rows: 32px repeat(20, 1fr) 41px;
	width: 100vw;
	height: 100vh;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	position: absolute;
	pointer-events: none;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 2;
	-webkit-transform: translateZ(0);
	-moz-transform: translateZ(0);
	-ms-transform: translateZ(0);
	-o-transform: translateZ(0);
	transform: translateZ(0);
	will-change: transform, opacity;
}
.interaction-element {
	will-change: transform;
}
dialog {
	width: 80%;
	max-width: 1024px;
	min-height: 848px;
	border: 0;
	position: relative;
	padding: 2rem;
	border-radius: 40px;
	background-color: var(--app-color-transparent);
	color: var(--app-font-color);
	backdrop-filter: url(#blur);
	transition: opacity 0.5s ease-out, scale 0.5s ease-out, display 0.6s, overlay 0.6s;
	opacity: 0;
	scale: 0.8;
	outline: 0;
	-webkit-transform: translateZ(0);
	-moz-transform: translateZ(0);
	-ms-transform: translateZ(0);
	-o-transform: translateZ(0);
	transform: translateZ(0);
}
dialog.manual-image-reference {
	max-width: 1120px;
}
dialog .dialog-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	padding-block: 3rem;
}
dialog button.close-dialog {
	text-indent: -9999px;
	position: absolute;
	top: 16px;
	right: 16px;
	border-radius: 50%;
}
dialog.auto-scan-dialog .close-dialog {
	opacity: 0;
	transition: opacity 0.3s;
}
dialog.auto-scan-dialog[data-state="rescan"] .close-dialog,
dialog.auto-scan-dialog[data-state="failed"] .close-dialog {
	opacity: 1;
}
dialog.manual-image-reference .dialog-content {
	display: grid;
	grid-template-columns: auto 70px;
	grid-template-rows: auto;
	grid-gap: 1rem 2rem;
}
dialog.manual-image-reference .dialog-content .manual-reference-video {
	grid-column: 1 / 2;
	grid-row: 1 / 2;
}
dialog.manual-image-reference .dialog-content .reference-buttons {
	grid-column: 1 / 2;
	grid-row: 2 / 3;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	gap: 1rem;
}
dialog.manual-image-reference .dialog-content .reference-buttons button {
	width: 100%;
}
dialog.manual-image-reference .dialog-content .reference-data {
	grid-column: 1 / 2;
	grid-row: 3 / 4;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-gap: 0.5rem;
	color: var(--app-font-color);
	font-size: 1.25rem;
}
dialog.manual-image-reference .dialog-content .reference-preview {
	grid-column: 2 / 3;
	grid-row: 1 / 4;
	position: relative;
	height: 100%;
	zoom: 0.65;
}
dialog.manual-image-reference .dialog-content .reference-preview canvas {
	position: absolute;
	top: 0;
}
dialog.manual-image-reference .dialog-content .reference-preview .reference-frame {
	border: 4px dotted red;
	position: absolute;
	left: -10px;
	width: calc(100% + 12px);
}
dialog video {
	width: 100%;
	aspect-ratio: 4/3;
	border-radius: 14px;
}

/* 4. Header */
header {
	font-size: 0.75rem;
	font-weight: 400;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10;
	display: grid;
	grid-template-columns: 125px 1fr;
	grid-gap: 20px 50px;
	padding: 38px 76px 0;
	width: 100%;
	background-color: transparent;
	box-sizing: border-box;
}
header .testing-message {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	width: auto;
	padding: 0.75rem;
	background-color: var(--app-background-color);
	color: var(--app-font-color);
	text-align: center;
	opacity: 0.7;
}
header .powered-by {
	opacity: 0.5;
	pointer-events: none;
}
header .app-downloads {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	transition-duration: 0.5s;
	opacity: 0;
	translate: 0 -50px;
}
header .app-downloads .app-downloads-description {
	opacity: 0.5;
	max-width: 850px;
}
header .app-downloads .app-downloads-buttons {
	display: flex;
	gap: 24px;
}
header hr {
	background-color: var(--app-color-white);
	width: 100%;
	height: 1px;
	border: none;
	grid-column: 1 / 3;
	transition-duration: 0.5s;
	opacity: 0;
	translate: 0 -20px;
}

/* 5. Initial Screen */
.initial-screen .initial-screen-content {
	grid-column: 1 / -1;
	grid-row: 1 / -1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 85px;
	width: 100vw;
	height: 100vh;
}
.initial-screen .initial-screen-tab-icon {
	display: block;
	width: 170px;
	height: 266px;
	position: relative;
}
.initial-screen .initial-screen-tab-icon::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	width: 24px;
	height: 24px;
	background-image: url("../svg/weinscanner-icons.svg");
	background-size: 168px 48px;
	background-position: -120px var(--app-svg-position-y);
	scale: 12;
	translate: -50% -50%;
}
.auto-scan-dialog .dialog-content {
	height: 750px
}
.auto-scan-dialog .scan-state-icon {
	position: relative;
	width: 285px;
	height: 100%;
	margin: 0 auto;
}
.auto-scan-dialog .scan-state-icon::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 285px;
	height: 285px;
	background-image: url("../svg/scan-dialog-icons.svg");
	background-size: 285px 855px;
	background-position-x: center;
	background-position-y: top;
	translate: 0 -50%;
	transition: 0.3s background-position-y ease-in-out;
}
.auto-scan-dialog[data-state="scanning"] .scan-state-icon::before {
	background-position-y: center;
}
.auto-scan-dialog[data-state="failed"] .scan-state-icon::before {
	background-position-y: bottom;
}
.auto-scan-dialog[data-state="rescan"] .scan-state-icon::before {
	background-position-y: top;
	animation: icon-shake 4s ease-in-out infinite;
}
.auto-scan-dialog .scan-state-text {
	font-size: 65px;
	text-align: center;
	font-weight: 300;
	max-width: 845px;
	height: 240px;
	width: 100%;
	margin: 0 0 2rem;
	position: relative;
}
.auto-scan-dialog .scan-state-text span {
	opacity: 0;
	position: absolute;
	height: 100%;
	width: 100%;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	transition: 0.2s opacity ease-in-out;
}
.auto-scan-dialog[data-state="active"] .scan-state-text span.state-active,
.auto-scan-dialog[data-state="scanning"] .scan-state-text span.state-scanning,
.auto-scan-dialog[data-state="rescan"] .scan-state-text span.state-rescan,
.auto-scan-dialog[data-state="failed"] .scan-state-text span.state-failed {
	opacity: 0.99;
}
.auto-scan-dialog .rescan-button {
	font-size: 46px;
	height: 76px;
	position: relative;
	padding-inline: 100px 40px;
	opacity: 0.99;
	transition: opacity 0.3s ease-in-out;
}
.auto-scan-dialog .rescan-button:disabled {
	opacity: 0;
	pointer-events: none;
}
.auto-scan-dialog .rescan-button::before {
	content: '';
	position: absolute;
	left: 40px;
	top: 50%;
	translate: 0 -50%;
	display: block;
	width: 24px;
	height: 24px;
	background-image: url('../svg/weinscanner-icons.svg');
	background-size: 168px 48px;
	background-position: -24px 0;
	scale: 2;
}
.auto-scan-dialog[data-state="rescan"] .rescan-button {
	background-color: #30E06B;
	color: var(--app-color-black);
}

/* 6. Wine Bottle */
.wine-bottle .wine-bottle-container {
	text-align: center;
	align-content: center;
	width: 100%;
	height: 100%;
	background-image: url('../svg/wine-bottle-shadow.svg');
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: 100% auto;
}
.wine-bottle .wine-bottle-container img {
	width: 100%;
	height: 100%;
	max-height: 900px;
	object-fit: contain;
}
.wine-bottle .interaction-position {
	grid-row: 2 / -2;
}
.wine-bottle .interaction-position.wine-bottle-dish-suggestions,
.wine-bottle .interaction-position.wine-bottle-dish-preview {
	grid-column: 6 / 10;
}
.wine-bottle .interaction-position.wine-bottle-combination {
	grid-column: 7 / 11;
}
.wine-bottle .interaction-position.wine-bottle-full {
	grid-column: 10 / 14;
}

/* 7. Product Info */
.product-info {
	z-index: 2;
}
.product-info .interaction-position.product-info-full {
	grid-column: 4 / 9;
	grid-row: 5 / 20;
}
.product-info .interaction-position.product-info-dish-suggestions,
.product-info .interaction-position.product-info-dish-preview {
	grid-column: 3 / 7;
	grid-row: 6 / 20;
}
.product-info .interaction-position.product-info-combination {
	grid-column: 4 / 8;
	grid-row: 6 / 20;
}
.product-info .product-content {
	display: flex;
	flex-direction: column;
	gap: 16px;
	position: relative;
}
.product-info .product-content .product-country-flag {
	display: block;
	width: 60px;
	height: 60px;
	background-color: var(--app-color-white);
	border: 2px solid var(--app-color-white);
	border-radius: 50%;
	overflow: hidden;
	position: absolute;
	top: -80px;
	left: 0;
	transition-duration: 0.5s;
	transition-timing-function: cubic-bezier(0.42, 0, 0.58, 1);
}
.product-info .product-content .product-winery {
	font-size: 24px;
	font-weight: 400;
	line-height: 43px;
}
.product-info .product-content .product-name {
	max-width: 375px;
}
.product-info .product-content .product-details {
	display: flex;
	justify-content: flex-start;
	gap: 16px;
	font-size: 18px;
	font-weight: 400;
}
.product-info .product-content .product-description,
.product-info .product-content .product-taste-graphs {
	opacity: 0;
	transition-duration: 0.5s;
}
.product-info .product-content .product-description {
	font-size: 18px;
	font-weight: 400;
	line-height: 24px;
	width: 437px;
	margin-top: 24px;
}
.product-info .product-content .product-taste-graphs {
	display: flex;
	flex-direction: column;
	gap: 16px;
	width: 310px;
	margin-top: 68px;
}
.product-info .product-content .product-taste-graphs .product-taste-graph-element {
	display: none;
}
.product-info .product-content .product-taste-graphs .product-taste-graph-element.active-graph {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 5px;
}
.product-info .product-content .product-taste-graphs .product-taste-graph-element .taste-graph {
	display: flex;
	gap: 1px;
	width: 100%;
	justify-content: stretch;
}
.product-info .product-content .product-taste-graphs .product-taste-graph-element .taste-graph .graph-indicator {
	background-color: var(--app-color-white);
	opacity: 0.12;
	height: 8px;
	width: 100%;
}
.product-info .product-content .product-taste-graphs .product-taste-graph-element .taste-graph .graph-indicator.active-indicator {
	opacity: 0.99;
}
.product-info .product-content .product-taste-graphs .product-taste-graph-element .taste-graph .indicator-1 {
	border-radius: 8px 0 0 8px;
}
.product-info .product-content .product-taste-graphs .product-taste-graph-element .taste-graph .indicator-5 {
	border-radius: 0 8px 8px 0;
}

/* 8. Dishes */
.dishes {
	z-index: 1;
}
.dishes .dishes-container {
	grid-column: 7 / -2;
	grid-row: 2 / -2;
	display: grid;
	grid-template-columns: repeat(15, 1fr);
	grid-template-rows: repeat(20, 1fr);
	position: relative;
}
.dishes .dishes-container .open-dish-suggestions {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 30px;
	width: 100%;
	height: 100%;
	border-radius: var(--app-bubble-radius);
}
.dishes .dishes-container .open-dish-suggestions.no-suggestions {
	visibility: hidden;
	pointer-events: none;
}
.dishes .dishes-container .open-dish-suggestions .serving-images {
	width: 330px;
	height: 295px;
	display: block;
	overflow: hidden;
	position: relative;
}
.dishes .dishes-container .open-dish-suggestions .serving-images img {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	transition: opacity 0.3s ease-out;
}
.dishes .dishes-container .open-dish-suggestions .serving-images img.standard-image,
.dishes .dishes-container .open-dish-suggestions:hover .serving-images img.hover-image {
	opacity: 0.99;
}
.dishes .dishes-container .open-dish-suggestions .serving-images img.hover-image,
.dishes .dishes-container .open-dish-suggestions:hover .serving-images img.standard-image {
	opacity: 0;
}
.dishes .dishes-container .open-dish-suggestions .serving-name {
	font-size: 24px;
	font-weight: 300;
}
.dishes .dishes-container .dish-suggestions-container {
	align-content: end;
}
.dishes .dishes-container .dish-suggestions {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 32px;
	padding: 68px 96px;
	background-color: var(--app-color-transparent);
	border-radius: var(--app-bubble-radius);
	box-sizing: border-box;
	position: relative;
	height: auto;
}
.dishes .dishes-container .dish-suggestions .dish-suggestions-title {
	font-size: 44px;
	font-weight: 300;
}
.dishes .dishes-container .dish-suggestions .dish-suggestions-list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-template-rows: auto;
	grid-gap: 24px;
}
.dishes .dishes-container .dish-suggestions .dish-suggestions-list button {
	display: inline-block;
	padding: 0;
	background-color: transparent;
	width: 100%;
	height: auto;
	align-self: start;
}
.dishes .dishes-container .dish-suggestions .dish-suggestions-list img {
	max-width: 280px;
}
.dishes .dishes-container .dish-suggestions .dish-suggestions-list .dish-name {
	display: block;
	font-size: 24px;
	font-weight: 300;
	margin-top: 16px;
}
.dishes .dishes-container .dish-preview {
	position: relative;
	align-content: end;
	height: 100%;
}
.dishes .dishes-container .dish-preview .dish-preview-element {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-template-rows: 150px auto 50px 5px 50px;
	grid-gap: 40px;
	padding: 38px;
	background-color: var(--app-color-transparent);
	border-radius: var(--app-bubble-radius);
	box-sizing: border-box;
	bottom: 0;
	left: 0;
	min-height: 724px;
	position: absolute;
	transition: translate 0.3s ease-in-out, opacity 0.3s ease-in-out, z-index 0.15s ease-in-out;
	will-change: translate, opacity, z-index;
}
.dishes .dishes-container .dish-preview .dish-preview-element.active {
	backdrop-filter: url(#blur);
	opacity: 0.99;
	z-index: 1;
}
.dishes .dishes-container .dish-preview .dish-preview-element.inactive {
	translate: 20% -20%;
	opacity: 0.5;
	z-index: 0;
}
.dishes .dishes-container .dish-preview .dish-preview-element.inactive button,
.dishes .dishes-container .dish-preview .dish-preview-element.inactive label {
	pointer-events: none;
}
.dishes .dishes-container .dish-preview img {
	grid-column: 1 / 2;
	grid-row: 1 / 4;
	width: 100%;
}
.dishes .dishes-container .dish-preview .dish-preview-name {
	grid-column: 2 / 3;
	grid-row: 1 / 2;
	font-size: 28px;
	font-weight: 300;
	align-self: end;
}
.dishes .dishes-container .dish-preview .dish-preview-description {
	grid-column: 2 / 3;
	grid-row: 2 / 3;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.4;
}
.dishes .dishes-container .dish-preview .dish-preview-portion-selection {
	grid-column: 2 / 3;
	grid-row: 3 / 4;
	display: flex;
	gap: 40px;
	justify-content: flex-start;
	font-size: 18px;
	align-self: center;
}
.dishes .dishes-container .dish-preview .dish-preview-portion-selection label {
	padding: 10px 0;
}
.dishes .dishes-container .dish-preview .dish-preview-portion-selection input {
	display: none;
}
.dishes .dishes-container .dish-preview .dish-preview-portion-selection .checkmark {
	display: inline-block;
	margin: 0 6px -2px 0;
	width: 16px;
	height: 16px;
	border: 1px solid var(--app-color-white);
	border-radius: 4px;
}
.dishes .dishes-container .dish-preview .dish-preview-portion-selection input:checked ~ .checkmark {
	background-color: var(--app-color-white);
}
.dishes .dishes-container .dish-preview .dish-combination-selection-container {
	grid-column: 1 / 3;
	grid-row: 5 / 6;
	display: flex;
	justify-content: center;
	gap: 40px;
}
.dishes .dishes-container .dish-preview .dish-combination-selection-container button.dish-combination-selection,
.dishes .dishes-container .dish-preview .dish-combination-selection-container button.dish-alternative-selection {
	font-weight: 700;
	padding-left: 47px;
	position: relative;
}
.dishes .dishes-container .dish-preview .dish-combination-selection-container button.dish-combination-selection {
	background-color: var(--app-color-white);
	color: var(--app-color-black);
}
.dishes .dishes-container .dish-preview .dish-combination-selection-container button.dish-alternative-selection {
	border: 2px solid var(--app-color-white);
}
.dishes .dishes-container .dish-preview .dish-combination-selection-container button.dish-combination-selection::before,
.dishes .dishes-container .dish-preview .dish-combination-selection-container button.dish-alternative-selection::before {
	content: '';
	position: absolute;
	left: 13px;
	top: 50%;
	translate: 0 -50%;
	display: block;
	width: 24px;
	height: 24px;
	background-image: url('../svg/weinscanner-icons.svg');
	background-size: 168px 48px;
}
.dishes .dishes-container .dish-preview .dish-combination-selection-container button.dish-combination-selection::before {
	background-position: -144px top;
}
.dishes .dishes-container .dish-preview .dish-combination-selection-container button.dish-alternative-selection::before {
	background-position: -96px bottom;
	rotate: -90deg;
}
.dishes .dishes-container .close-dish-view-button {
	background-color: transparent;
	border: 2px solid var(--app-color-white);
	border-radius: 50%;
	width: 40px;
	height: 40px;
	min-width: unset;
	text-indent: -9999px;
	padding: 0;
	position: absolute;
	bottom: 24px;
	right: 24px;
}
.dishes .dishes-container .close-dish-view-button::before {
	content: '';
	position: absolute;
	left: 50%;
	top: 50%;
	translate: -50% -50%;
	display: block;
	width: 24px;
	height: 24px;
	background-image: url('../svg/weinscanner-icons.svg');
	background-size: 168px 48px;
	background-position: -72px var(--app-svg-position-y);
}
.dishes .dishes-container .dish-combination {
	display: grid;
	grid-template-columns: repeat(15, 1fr);
	grid-template-rows: repeat(20, 1fr);
}
.dishes .dishes-container .dish-combination img {
	grid-column: 1 / 10;
	grid-row: 4 / 20;
	width: 100%;
	object-fit: contain;
}
.dishes .dishes-container .dish-combination h3 {
	grid-column: 10 / 15;
	grid-row: 7 / -2;
	font-size: 50px;
	text-align: left;
}

/* 9. Final Selection */
.final-selection .final-selection-content {
	grid-column: 5 / -5;
	grid-row: 6 / -3;
	display: grid;
	grid-template-columns: 1fr 365px;
	grid-template-rows: auto 1fr;
	grid-gap: 40px 80px;
}
.final-selection .final-selection-content h2 {
	grid-column: 1 / 2;
	grid-row: 1 / 2;
	font-size: 100px;
}
.final-selection .final-selection-content .final-content {
	grid-column: 1 / 2;
	grid-row: 2 / 3;
	display: grid;
	grid-template-columns: 375px 510px;
	grid-gap: 16px;
}
.final-selection .final-selection-content .final-content .final-product-content {
	grid-column: 1 / 2;
	grid-row: 1 / 2;
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.final-selection .final-selection-content .final-content .final-product-country-flag {
	display: block;
	width: 60px;
	height: 60px;
	background-color: var(--app-color-white);
	border: 2px solid var(--app-color-white);
	border-radius: 50%;
	overflow: hidden;
}
.final-selection .final-selection-content .final-content .final-product-winery {
	font-size: 24px;
	font-weight: 400;
	line-height: 43px;
}
.final-selection .final-selection-content .final-content .final-product-name {
	font-size: 50px;
	font-weight: 700;
	line-height: 55px;
}
.final-selection .final-selection-content .final-content .final-product-details {
	display: flex;
	justify-content: flex-start;
	gap: 16px;
	font-size: 18px;
	font-weight: 400;
}
.final-selection .final-selection-content .final-content .final-combination {
	grid-column: 2 / 3;
	grid-row: 1 / 2;
	display: grid;
	grid-template-columns: repeat(8, 1fr);
	grid-template-rows: 440px 85px;
	max-height: 510px;
}
.final-selection .final-selection-content .final-content .final-combination img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.final-selection .final-selection-content .final-content .final-combination .final-wine-bottle-image-container {
	grid-column: 1 / 4;
	grid-row: 1 / 3;
}
.final-selection .final-selection-content .final-content .final-combination .final-dish-image-container {
	grid-column: 2 / 9;
	grid-row: 1 / 2;
}
.final-selection .final-selection-content .final-content .final-combination .final-dish-name {
	grid-column: 4 / 9;
	grid-row: 2 / 3;
}
.final-selection .final-selection-content .final-qr-container {
	grid-column: 2 / 3;
	grid-row: 2 / 3;
	display: flex;
	flex-direction: column;
	gap: 24px;
	width: 365px;
}
.final-selection .final-selection-content .final-qr-container .final-qr-code,
.final-selection .final-selection-content .final-qr-container .final-qr-code svg {
	width: 309px;
	height: 309px;
	aspect-ratio: 1 / 1;
}

/* 10. Elements */
.background {
	width: calc(100% + 40px);
	height: calc(100% + 40px);
	display: block;
	position: fixed;
	top: -20px;
	left: -20px;
	right: -20px;
	bottom: -20px;
	z-index: -1;
	opacity: 0.4;
	filter: url(#blur);
	pointer-events: none;
}
.background video {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	width: 100%;
	height: 100%;
	transition: opacity 1s;
}
.background video.show-video {
	opacity: 0.99;
}

/* 11. Footer */
.app-footer {
	position: fixed;
	bottom: 0;
	left: 0;
	z-index: 4;
	width: 100%;
	background-color: transparent;
	display: flex;
	gap: 10px;
	padding: 0 32px 41px;
	box-sizing: border-box;
	pointer-events: none;
}
.app-footer button.home-button {
	text-indent: -9999px;
}
.app-footer button.back-button {
	transition-duration: 0.5s;
	opacity: 0;
	translate: 0 50px;
}
.app-footer button.final-button {
	background-color: var(--app-color-white);
	color: var(--app-color-black);
	margin-inline: auto;
}
.app-footer button.restart-button,
.app-footer button.final-button {
	transition-duration: 0.5s;
	opacity: 0;
	translate: 0 50px;
	padding-left: 47px;
}
dialog button.close-dialog::before,
.app-footer button.home-button::before,
.app-footer button.final-button::before,
.app-footer button.restart-button::before {
	content: "";
	position: absolute;
	top: 50%;
	display: block;
	width: 24px;
	height: 24px;
	background-image: url('../svg/weinscanner-icons.svg');
	background-size: 168px 48px;
}
dialog button.close-dialog::before {
	background-position: -72px var(--app-svg-position-y);
	translate: -50% -50%;
	left: 50%;
}
.app-footer button.home-button::before {
	background-position: 0 var(--app-svg-position-y);
	translate: -50% -50%;
	left: 50%;
}
.app-footer button.final-button::before {
	background-position: -24px 0;
	left: 13px;
	translate: 0 -50%;
}
.app-footer button.restart-button::before {
	background-position: -48px var(--app-svg-position-y);
	left: 13px;
	translate: 0 -50%;
}

/* 12. Section Positioning */
.section-position {
	display: block;
	width: 100vw;
	height: 100vh;
	position: fixed;
}
.section-position.section-central-view {
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
}
.section-position.section-top,
.section-position.section-bottom,
.section-position.section-left,
.section-position.section-right {
	opacity: 0;
}
.section-position.section-top {
	top: -100vh;
}
.section-position.section-bottom {
	bottom: -100vh;
}
.section-position.section-left {
	left: -100vw;
}
.section-position.section-right {
	right: -100vw;
}

/* 13. Dishes Areas */
.dishes-area.dish-button-area {
	grid-column: 12 / -1;
	grid-row: 12 / -1;
}
.dishes-area.dish-suggestion-area {
	grid-column: 5 / -1;
	grid-row: 4 / -1;
}
.dishes-area.dish-combination-area {
	grid-column: 1 / -1;
	grid-row: 1 / -1;
}
.dishes-area.dish-out-area {
	position: absolute;
}
.dishes-area.dish-out-area.dish-out-bottom {
	height: 100%;
	width: 100%;
	bottom: calc(-100% - 72px);
}
.dishes-area.dish-out-area.dish-out-right {
	height: 100%;
	width: 100%;
	right: calc(-100% - 32px);
}
.dishes-area.dish-out-area.dish-out-right-bottom {
	width: 500px;
	height: 500px;
	right: -532px;
	bottom: -541px;
}

/* 14. Animations */
main[data-section-view="final"] header .app-downloads {
	opacity: 0.99;
	translate: 0 0;

	@starting-style {
		opacity: 0;
		translate: 0 -50px;
	}
}
main[data-section-view="final"] header hr {
	opacity: 0.3;
	translate: 0 0;

	@starting-style {
		opacity: 0;
		translate: 0 -20px;
	}
}
dialog[open] {
	opacity: 0.99;
	scale: 1;

	@starting-style {
		opacity: 0;
		scale: 0.8;
	}
}
main[data-section-view="combination"] .app-footer button.final-button,
main[data-section-view="product"][data-interaction-view="full"] .app-footer button.home-button,
main[data-section-view="combination"][data-interaction-view="combination"] .app-footer button.back-button,
main[data-section-view="final"] .app-footer button.restart-button {
	opacity: 0.99;
	translate: 0 0;

	@starting-style {
		opacity: 0;
		translate: 0 50px;
	}
}
main[data-section-view="product"][data-interaction-view="full"] .product-content .product-description,
main[data-section-view="product"][data-interaction-view="full"] .product-content .product-taste-graphs {
	opacity: 0.99;

	@starting-style {
		opacity: 0;
	}
}
main[data-section-view="product"][data-interaction-view="full"] .product-content .product-country-flag {
	top: 0;
	left: -100px;

	@starting-style {
		top: -80px;
		left: 0;
	}
}

@keyframes icon-shake {
	0% { rotate: 0 }
	10% { rotate: 0 }
	30% {
		rotate: 55deg;
	}
	40% {
		rotate: 35deg;
	}
	50% {
		rotate: 55deg;
	}
	60% {
		rotate: 35deg;
	}
	70% {
		rotate: 55deg;
	}
	90% { rotate: 0 }
	100% { rotate: 0 }
}