
@font-face {
font-family: 'Essonnes-Display-Bold';
src: url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Essonnes-Display-Bold.woff2') format('woff2'),
	url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Essonnes-Display-Bold.woff') format('woff');
}
	
@font-face {
font-family: 'Essonnes-Display-Regular';
src: url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Essonnes-Display-Regular.woff2') format('woff2'),
		url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Essonnes-Display-Regular.woff') format('woff');
}

@font-face {
font-family: 'Nexa-Regular';
src: url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Nexa-Regular.woff2') format('woff2'),
		url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Nexa-Regular.woff') format('woff');
}

@font-face {
font-family: 'Nexa-Black';
src: url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Nexa-Black.woff2') format('woff2'),
		url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Nexa-Black.woff') format('woff');
}

@font-face {
	font-family: 'Nexa-Bold';
	src: url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Nexa-Bold.woff2') format('woff2'),
	     url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Nexa-Bold.woff') format('woff');
}

@font-face {
	font-family: 'Nexa-Heavy';
	src: url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Nexa-Heavy.woff2') format('woff2'),
	     url('https://static.pexi.nl/dpg-mediamagazines/Fonts/Nexa-Heavy.woff') format('woff');
}
/* Reset */

* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	outline: none;
	text-rendering: optimizeLegibility !important;
	-webkit-font-smoothing: antialiased !important;
}

body {
	background: #FFEBC7;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100svh;
	overscroll-behavior: none;
}

#stage {
	width: 300px;
	height: 600px;
	position: relative;
	cursor: url('cursor.svg'), auto;
	overflow: hidden;
	background-color: #ffffff;
	border-radius: 8px;
	box-shadow: 0px 0px 10px rgba(97, 76, 1, 0.8);
	transform: scale(min(calc(85vh / 600px), calc(90vw / 300px)));
	transform: scale(min(calc(85svh / 600px), calc(90vw / 300px)));
	touch-action: none;
}


.hiddenOnload {
	opacity: 0;
}

/* startscherm */
.startframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	z-index: 35;
}

.stripes {
	position: absolute;
	width: 110px;
	left: -84.43px;
	top: 0px;
	height: 600px;
	z-index:1;
	pointer-events: none;
}

.logo {
	position: absolute;
	width: 82.06px;
	left: 218px;
	top: 0px;
	z-index: 200;
}

.shabbieslogo {
	position: absolute;
	width: 53.44px;
	left: 139px;
	top: 578px;
	z-index: 2;
}

.tas {
	position: absolute;
	width: 359px;
	left: -17px;
	top: 422px;
}

.bg {
	position: absolute;
	width: 371px;
	height: 664px;
	top:-63px;
	left: 1px;
}

.gradient {
	position: absolute;
	width: 337.5px;
	height: 600px;
	background: rgba(255, 235, 199, 0.55);
	left: 0px;
	top:0px;
}

.waterfles {
	position: absolute;
	width: 37.65px;
	top: 417.54px;
	left: 50.62px;
	transform:rotate(23.72deg);
}

.telefoon {
	position: absolute;
	width: 33.68px;
	left: 148.78px;
	top: 384px;
	transform:rotate(-8.24deg);
	z-index: 50;
}

.notes {
	position: absolute;
	width: 58.32px;
	left: 216.25px;
	top: 341.41px;
	transform:rotate(20.88deg);
}

.portemonnee {
	position: absolute;
	width: 47px;
	left: 84px;
	top: 366px;
}

.parfum {
	position: absolute;
	width: 56.81px;
	top: 355.67px;
	left: 21.66px;
	transform:rotate(7.97deg);
}

.magazine {
	position: absolute;
	width: 86.7px;
	left: 26.94px;
	top: 234.97px;
	transform:rotate(8.78deg);
	z-index: 100;
}

.lippenstift {
	position: absolute;
	width: 10.04px;
	left: 148.46px;
	top: 267.65px;
	transform:rotate(-14deg);
}

.sleutels {
	position: absolute;
	width: 49.64px;
	top: 262px;
	left: 187px;
}

.headset {
	position: absolute;
	width: 46.74px;
	left: 242px;
	top: 242px;
}

.bril {
	position: absolute;
	width: 67.72px;
	left: 148.91px;
	top: 222.41px;
	transform:rotate(-13.2deg);
}

.pricebol {
	position: absolute;
	width: 66px;
	left: 214px;
	top: 474.5px;
	z-index:200;
}

.copy {
	position: absolute;
	top: 57px;
	left: 26px;
	width: 274px;
	text-align: center;
	font-size: 52.52px;
	font-family: "Essonnes-Display-Bold";
	text-align: center;
	-webkit-text-stroke-width: 0.44px;
	-webkit-text-stroke-color: #000;
	line-height: 56px;
}

.subcopy {
	position: absolute;
	width: 274px;
	font-family: "Nexa-Regular";
	font-size: 25.59px;
	top: 177px;
	left: 26px;
	color: #000;
	text-align: center;
}

.vang {
	position: absolute;
	width: 274px;
	left: 26px;
	text-align: center;
	top: 327px;
	font-family: 'Nexa-Regular';
	line-height: 1;
	font-size: 14px;
	color: #000;
}

.vang span {
	font-family: 'Nexa-Black';
}


/* Instructie scherm */
.instructions {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	opacity: 0;
	pointer-events: none;
}
.cta {
	width: 135px;
	position: absolute;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 36.08px;
	background-color: #E66582;
	gap: 10px;
	border-radius: 8.21px;
	top: 282px;
	left: 93px;
	transform-origin: center;
	transition: transform 0.2s ease;
}

.cta:hover {
	transform: scale(1.1);
}

.cta_copy {
	position: relative;
	font-family: 'Nexa-Bold';
	font-size: 16.29px;
	color: #FFF;
	line-height:2;
	margin-top: 4px;
}

.arrow {
	position: relative;
	width: 11.12px;
	top: 1px;
	transition: transform 0.2s ease;
}

.cta:hover .arrow {
	transform: translateX(4px);
}

.instr-demo-item {
	position: absolute;
	width: 87px;
	top: -150px;
	left: 95px;
}

.swipe-hand {
	position: absolute;
	width: 52.44px;
	top: 365px;
	left: 133.47px;
	z-index: 41;
	pointer-events: none;
	opacity: 0;
}

.swipe-dot {
	position: absolute;
	width: 19px;
	height: 19px;
	border-radius: 50%;
	background-color: #FFEBC7;
	top: 365px;
	z-index: 40;
	pointer-events: none;
	opacity: 0;
}

.swipe-dot--left  { left: 119.07px; }
.swipe-dot--right { left: 179.01px; }

/* game idle swipe indicator */
.game-idle {
	position: absolute;
	top: 365px;
	left: 0;
	z-index: 50;
	pointer-events: none;
	opacity: 0;
}

.game-idle-hand {
	position: absolute;
	width: 52.44px;
	top: 0;
	left: 133.47px;
}

.game-idle-dot {
	position: absolute;
	width: 19px;
	height: 19px;
	border-radius: 50%;
	background-color: #FFEBC7;
	top: 0;
	opacity: 0.31;
}

.game-idle-dot--left  { left: 119.07px; }
.game-idle-dot--right { left: 179.01px; }

/* de game */
.game {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	pointer-events: none;
}

.game .tas {
	position: absolute;
	width: 359px;
	left: -17px;
	top: 422px;
	z-index: 30;
}

.game-item {
	position: absolute;
	pointer-events: none;
	z-index: 30;
}

.gamecopy {
	position: absolute;
	width: 274px;
	left: 26px;
	top: 78px;
	text-align: center;
	font-size: 15.87px;
	line-height: 1;
	color: #000;
	font-family: "Nexa-Regular";
	opacity: 0;
}

.gamecopy span {
	font-family: "Nexa-Bold";
}

.score {
	position: absolute;
	left: 32px;
	top: 14px;
	display: flex;
	align-items: center;
	gap: 5px;
	opacity: 0;
	z-index: 100;
}

.medaille {
	width: 20.9px;
}

.score-count-badge {
	font-family: 'Nexa-Bold';
	font-size: 15.87px;
	color: #000;
	margin-top: 6px;
	line-height: 1;
}

/* ── Score display ────────────────────────────────────── */
.gameframe {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	opacity: 0;
	pointer-events: none;
}

/* ── Einde scherm ─────────────────────────────────────── */
.endframe {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	opacity: 0;
	pointer-events: none;
	display: flex;
	align-items: center;
	justify-content: center;
}

.bloemconfetti {
	position: absolute;
	width: 386.06px;
	left: -32.11px;
	top: -6.62px;
	pointer-events: none;
	opacity: 0;
	z-index: 100;
	transform: scale(0.5);
}

.end-inner {
	position: absolute;
	text-align: center;
	width: 203.87px;
	height: 203px;
	left: 60.43px;
	top: 148px;
	border-radius: 27.88px;
	background-color: #ECE0D7;
}

.end-label:first-child {
	position: absolute;
	font-family: 'Essonnes-Display-Bold';
	font-size: 32.275px;
	left: 0px;
	top: 20px;
	width: 100%;
	text-align: center;
	-webkit-text-stroke-width: 0.3px;
	-webkit-text-stroke-color: #000;
	color: #000;
	line-height: 1.1;
}

.medaille-end {
	position: absolute;
	width: 29.59px;
	top: 70px;
	left: 88px;
}

.end-label:last-child {
	position: absolute;
	font-family: 'Nexa-Regular';
	font-size: 15.87px;
	top: 166px;
	left:0px;
	width: 100%; 
	text-align: center;
	-webkit-text-stroke-width: 0.3px;
	-webkit-text-stroke-color: #000;
	color: #000;
	line-height: 1.1;
}

.end-score-big {
	top: 128px;
	left: 0px;
	width: 100%;
	position: absolute;
	font-family: 'Nexa-Regular';
	font-size: 23.85px;
	color: #101010;
	line-height: 1;
	margin-bottom: 6px;
}

.final-score {
	font-family: 'Essonnes-Display-Bold';
	color: #101010;
}

.maakkans {
	position: absolute;
	width: 184.25px;
	left: 70.81px;
	top:77.3px;
}

.endframetas {
	position: absolute;
	width: 232.15px;
	left: 48.09px;
	top: 348.6px;;
}

.pricebol-endframe {
	position: absolute;
	width:74.5px;
	left: 214px;
	top: 418px;
	z-index: 2;
}

/* ── Mail frame ───────────────────────────────────────── */
.mailframe {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 98px 30px 0;
	opacity: 0;
	pointer-events: none;
}

.lente-actie {
	position: absolute;
	width: 101.87px;
	height: 23.59px;
	left: 106.49px;
	top: 62.34px;
	transform: rotate(-2.65deg);
}

.mail-title {
	font-family: 'Nexa-Heavy';
	font-size: 24px;
	color: #000;
	text-align: center;
	line-height: 27px;
	
}

.mail-title span {
	font-style: italic;
}

.consent-label {
	position: absolute;
	width: 200px;
	left: 65px;
	display: flex;
	align-items: flex-start;
	gap: 8px;
	top: 275.52px;
	margin-bottom: 6px;
	cursor: pointer;
}

.consent-checkbox {
	flex-shrink: 0;
	width: 14px;
	height: 14px;
	margin-top: 2px;
	accent-color: #E66582;
	cursor: pointer;
}

.consent-label span {
	font-family: 'Nexa-Regular';
	font-size: 10px;
	color: #333;
	line-height: 1;
}

.mail-input::placeholder {
	color: #aaa;
}

.mail-cta {
	position: relative;
	top: auto;
	left: auto;
	width: 135px;
}

.mailError {
	position: relative;
    margin-top: -3px;
    display: none;
    font-size: 10px;
    color: red;
    font-family: 'Nexa-Regular';
    font-weight: 450;
    left: 11px;
    width: 274px;
    text-align: center;
    top: 158px;
    line-height: 1;
}

.maak-kans {
	position: absolute;
	width: 100%;
	left: 0px;
	top: 92px;
	font-size: 17px;
	line-height: 24.9px;
	font-family: 'Flama';
	font-weight: 450;
	text-align: center;
	color: #000000;
}

.tas

.maak-kans span {
	font-weight: 700;
	font-family:'Flama';
}

.feedback.error {
  color: red;
}

.feedback.success {
  color: green;
}

.feedback.active {
  display: block;
}

.errorOnResponse {
  color: red;
  display: none;
}

.input {
  height: 42px;
  padding: 0 25px;
  top: 201px;
  padding-top: 4px;
  left: 46px;
  width: 234px;
  border-radius: 50px;
  background: #ECE0D7;
  border: none;
  position: absolute;
  background-position: right center;
  background-repeat: no-repeat;
  background-size: auto 100%;
  font-size: 16px;
  line-height: 26px;
  font-family: 'Nexa-Regular';
  margin: 5px 0;
  color: #444444;
}

.input:focus {
  outline: none;
}

.inputError {
  background-image: url("val-error.svg");
}

.inputValidated {
  background-image: url("val-success.svg");
}

.disableInput:disabled {
  pointer-events: none;
  opacity: 0.6;
}

.button {
	width: 135px;
	height: 36.08px;
	position: absolute;
	color: #FFFF;
	background-color: #000000;
	border: none;
	cursor: pointer;
	font-size: 16.29px;
	font-family: "Nexa-Bold";
	line-height: 2;
	gap: 15px;
	top: 315px;
	align-items: center;
	justify-content: center;
	display: flex;
}

.consent-question {
	position: absolute;
	font-family: 'Nexa-Heavy';
	font-size: 24px;
	left: 39px;
	top: 105px;
	line-height: 27px;
	width: 250px;
	text-align: center;
}