*, ::before, ::after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}/*
! tailwindcss v3.4.14 | MIT License | https://tailwindcss.com
*//*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: currentColor; /* 2 */
}

::before,
::after {
  --tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/

html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/*
Remove the default font size and weight for headings.
*/

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

a {
  color: inherit;
  text-decoration: inherit;
}

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
  font-weight: bolder;
}

/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}

/*
Add the correct font size in all browsers.
*/

small {
  font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
  text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
  outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

:-moz-ui-invalid {
  box-shadow: none;
}

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
  vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

::-webkit-search-decoration {
  -webkit-appearance: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
  display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
}

legend {
  padding: 0;
}

ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

/*
Reset default styling for dialogs.
*/
dialog {
  padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
  resize: vertical;
}

/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
  cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/
:disabled {
  cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

img,
video {
  max-width: 100%;
  height: auto;
}

/* Make elements with the HTML hidden attribute stay hidden by default */
[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}
.\!container {
  width: 100% !important;
}
.container {
  width: 100%;
}
@media (min-width: 640px) {

  .\!container {
    max-width: 640px !important;
  }

  .container {
    max-width: 640px;
  }
}
@media (min-width: 768px) {

  .\!container {
    max-width: 768px !important;
  }

  .container {
    max-width: 768px;
  }
}
@media (min-width: 1024px) {

  .\!container {
    max-width: 1024px !important;
  }

  .container {
    max-width: 1024px;
  }
}
@media (min-width: 1280px) {

  .\!container {
    max-width: 1280px !important;
  }

  .container {
    max-width: 1280px;
  }
}
@media (min-width: 1536px) {

  .\!container {
    max-width: 1536px !important;
  }

  .container {
    max-width: 1536px;
  }
}
@media (min-width: 1660px) {

  .\!container {
    max-width: 1660px !important;
  }

  .container {
    max-width: 1660px;
  }
}
.pointer-events-none {
  pointer-events: none;
}
.visible {
  visibility: visible;
}
.static {
  position: static;
}
.fixed {
  position: fixed;
}
.absolute {
  position: absolute;
}
.relative {
  position: relative;
}
.inset-0 {
  inset: 0px;
}
.inset-y-0 {
  top: 0px;
  bottom: 0px;
}
.-top-5 {
  top: -1.25rem;
}
.bottom-0 {
  bottom: 0px;
}
.left-0 {
  left: 0px;
}
.left-1\/2 {
  left: 50%;
}
.left-\[15px\] {
  left: 15px;
}
.left-\[17\.5\%\] {
  left: 17.5%;
}
.left-\[27\.7\%\] {
  left: 27.7%;
}
.left-\[28\%\] {
  left: 28%;
}
.left-\[37\.7\%\] {
  left: 37.7%;
}
.left-\[38\%\] {
  left: 38%;
}
.left-\[43\.4\%\] {
  left: 43.4%;
}
.left-\[43\.7\%\] {
  left: 43.7%;
}
.left-\[45\.7\%\] {
  left: 45.7%;
}
.left-\[46\.2\%\] {
  left: 46.2%;
}
.left-\[57\.9\%\] {
  left: 57.9%;
}
.left-\[58\.2\%\] {
  left: 58.2%;
}
.left-\[71\.7\%\] {
  left: 71.7%;
}
.left-\[73\.9\%\] {
  left: 73.9%;
}
.left-\[74\.2\%\] {
  left: 74.2%;
}
.left-\[79\.2\%\] {
  left: 79.2%;
}
.left-\[79\.5\%\] {
  left: 79.5%;
}
.left-\[82\.2\%\] {
  left: 82.2%;
}
.right-\[29\%\] {
  right: 29%;
}
.top-0 {
  top: 0px;
}
.top-1\/2 {
  top: 50%;
}
.top-\[0\] {
  top: 0;
}
.top-\[21\%\] {
  top: 21%;
}
.top-\[28\.5\%\] {
  top: 28.5%;
}
.top-\[41\%\] {
  top: 41%;
}
.top-\[53\.5\%\] {
  top: 53.5%;
}
.top-\[60\%\] {
  top: 60%;
}
.top-\[70\%\] {
  top: 70%;
}
.top-\[78\.2\%\] {
  top: 78.2%;
}
.top-\[84\%\] {
  top: 84%;
}
.isolate {
  isolation: isolate;
}
.z-0 {
  z-index: 0;
}
.z-10 {
  z-index: 10;
}
.z-\[10\] {
  z-index: 10;
}
.z-\[1\] {
  z-index: 1;
}
.z-\[2\] {
  z-index: 2;
}
.z-\[5\] {
  z-index: 5;
}
.z-\[99\] {
  z-index: 99;
}
.m-8 {
  margin: 2rem;
}
.-mx-\[20px\] {
  margin-left: -20px;
  margin-right: -20px;
}
.-mx-\[50px\] {
  margin-left: -50px;
  margin-right: -50px;
}
.mx-\[-5px\] {
  margin-left: -5px;
  margin-right: -5px;
}
.mx-auto {
  margin-left: auto;
  margin-right: auto;
}
.my-\[30px\] {
  margin-top: 30px;
  margin-bottom: 30px;
}
.\!mt-\[60px\] {
  margin-top: 60px !important;
}
.-mt-\[10px\] {
  margin-top: -10px;
}
.mb-16 {
  margin-bottom: 4rem;
}
.mb-4 {
  margin-bottom: 1rem;
}
.mb-\[20px\] {
  margin-bottom: 20px;
}
.mb-\[30px\] {
  margin-bottom: 30px;
}
.mb-\[5px\] {
  margin-bottom: 5px;
}
.mb-\[60px\] {
  margin-bottom: 60px;
}
.mr-\[40px\] {
  margin-right: 40px;
}
.mt-4 {
  margin-top: 1rem;
}
.mt-\[20px\] {
  margin-top: 20px;
}
.mt-\[30px\] {
  margin-top: 30px;
}
.mt-\[50px\] {
  margin-top: 50px;
}
.mt-\[60px\] {
  margin-top: 60px;
}
.block {
  display: block;
}
.flex {
  display: flex;
}
.inline-flex {
  display: inline-flex;
}
.\!grid {
  display: grid !important;
}
.grid {
  display: grid;
}
.hidden {
  display: none;
}
.size-\[120px\] {
  width: 120px;
  height: 120px;
}
.size-\[30px\] {
  width: 30px;
  height: 30px;
}
.size-\[50px\] {
  width: 50px;
  height: 50px;
}
.h-2 {
  height: 0.5rem;
}
.h-\[100\%\] {
  height: 100%;
}
.h-\[100dvh\] {
  height: 100dvh;
}
.h-\[130px\] {
  height: 130px;
}
.h-\[14\%\] {
  height: 14%;
}
.h-\[150px\] {
  height: 150px;
}
.h-\[19\%\] {
  height: 19%;
}
.h-\[220px\] {
  height: 220px;
}
.h-\[25\%\] {
  height: 25%;
}
.h-\[30px\] {
  height: 30px;
}
.h-\[31\%\] {
  height: 31%;
}
.h-\[40px\] {
  height: 40px;
}
.h-\[450px\] {
  height: 450px;
}
.h-\[600px\] {
  height: 600px;
}
.h-\[62px\] {
  height: 62px;
}
.h-\[70px\] {
  height: 70px;
}
.h-\[80\%\] {
  height: 80%;
}
.h-auto {
  height: auto;
}
.h-full {
  height: 100%;
}
.min-h-\[400px\] {
  min-height: 400px;
}
.min-h-\[57px\] {
  min-height: 57px;
}
.w-0 {
  width: 0px;
}
.w-64 {
  width: 16rem;
}
.w-\[25px\] {
  width: 25px;
}
.w-\[30px\] {
  width: 30px;
}
.w-\[40px\] {
  width: 40px;
}
.w-\[50px\] {
  width: 50px;
}
.w-\[640px\] {
  width: 640px;
}
.w-\[90px\] {
  width: 90px;
}
.w-full {
  width: 100%;
}
.w-max {
  width: -moz-max-content;
  width: max-content;
}
.min-w-\[120px\] {
  min-width: 120px;
}
.max-w-\[320px\] {
  max-width: 320px;
}
.flex-1 {
  flex: 1 1 0%;
}
.flex-shrink {
  flex-shrink: 1;
}
.-translate-x-1\/2 {
  --tw-translate-x: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.-translate-y-1\/2 {
  --tw-translate-y: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.translate-y-\[-150px\] {
  --tw-translate-y: -150px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.transform {
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.cursor-grab {
  cursor: grab;
}
.cursor-pointer {
  cursor: pointer;
}
.select-none {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.resize {
  resize: both;
}
.flex-col {
  flex-direction: column;
}
.items-start {
  align-items: flex-start;
}
.items-end {
  align-items: flex-end;
}
.items-center {
  align-items: center;
}
.justify-end {
  justify-content: flex-end;
}
.justify-center {
  justify-content: center;
}
.justify-between {
  justify-content: space-between;
}
.gap-2 {
  gap: 0.5rem;
}
.gap-\[15px\] {
  gap: 15px;
}
.gap-\[18px\] {
  gap: 18px;
}
.gap-\[20px\] {
  gap: 20px;
}
.gap-\[30px\] {
  gap: 30px;
}
.gap-\[40px\] {
  gap: 40px;
}
.space-y-0 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0px * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0px * var(--tw-space-y-reverse));
}
.space-y-10 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(2.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(2.5rem * var(--tw-space-y-reverse));
}
.space-y-5 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.25rem * var(--tw-space-y-reverse));
}
.space-y-6 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}
.space-y-\[10px\] > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(10px * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(10px * var(--tw-space-y-reverse));
}
.space-y-\[30px\] > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(30px * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(30px * var(--tw-space-y-reverse));
}
.space-y-\[40px\] > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(40px * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(40px * var(--tw-space-y-reverse));
}
.overflow-hidden {
  overflow: hidden;
}
.rounded {
  border-radius: 0.25rem;
}
.rounded-\[10px\] {
  border-radius: 10px;
}
.rounded-\[12px\] {
  border-radius: 12px;
}
.rounded-\[15px\] {
  border-radius: 15px;
}
.rounded-\[16px\] {
  border-radius: 16px;
}
.rounded-\[20px\] {
  border-radius: 20px;
}
.rounded-\[50px\] {
  border-radius: 50px;
}
.rounded-full {
  border-radius: 9999px;
}
.rounded-lg {
  border-radius: 0.5rem;
}
.border {
  border-width: 1px;
}
.border-0 {
  border-width: 0px;
}
.border-b {
  border-bottom-width: 1px;
}
.border-l {
  border-left-width: 1px;
}
.border-r-\[2px\] {
  border-right-width: 2px;
}
.border-t {
  border-top-width: 1px;
}
.border-purple {
  --tw-border-opacity: 1;
  border-color: rgb(110 70 207 / var(--tw-border-opacity));
}
.border-white {
  --tw-border-opacity: 1;
  border-color: rgb(255 255 255 / var(--tw-border-opacity));
}
.border-r-purple {
  --tw-border-opacity: 1;
  border-right-color: rgb(110 70 207 / var(--tw-border-opacity));
}
.border-opacity-20 {
  --tw-border-opacity: 0.2;
}
.border-opacity-70 {
  --tw-border-opacity: 0.7;
}
.bg-\[\#6E46CF\] {
  --tw-bg-opacity: 1;
  background-color: rgb(110 70 207 / var(--tw-bg-opacity));
}
.bg-\[\#BCA9E9\] {
  --tw-bg-opacity: 1;
  background-color: rgb(188 169 233 / var(--tw-bg-opacity));
}
.bg-\[\#C7B8F2\] {
  --tw-bg-opacity: 1;
  background-color: rgb(199 184 242 / var(--tw-bg-opacity));
}
.bg-\[\#F4D03F\] {
  --tw-bg-opacity: 1;
  background-color: rgb(244 208 63 / var(--tw-bg-opacity));
}
.bg-\[\#F4D03F\]\/50 {
  background-color: rgb(244 208 63 / 0.5);
}
.bg-hover {
  --tw-bg-opacity: 1;
  background-color: rgb(188 169 233 / var(--tw-bg-opacity));
}
.bg-purple {
  --tw-bg-opacity: 1;
  background-color: rgb(110 70 207 / var(--tw-bg-opacity));
}
.bg-purple2 {
  --tw-bg-opacity: 1;
  background-color: rgb(231 230 246 / var(--tw-bg-opacity));
}
.bg-transparent {
  background-color: transparent;
}
.bg-white {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}
.bg-white\/30 {
  background-color: rgb(255 255 255 / 0.3);
}
.bg-yellow {
  --tw-bg-opacity: 1;
  background-color: rgb(255 224 65 / var(--tw-bg-opacity));
}
.object-cover {
  -o-object-fit: cover;
     object-fit: cover;
}
.p-\[20px\] {
  padding: 20px;
}
.p-\[25px\] {
  padding: 25px;
}
.p-\[28px\] {
  padding: 28px;
}
.px-10 {
  padding-left: 2.5rem;
  padding-right: 2.5rem;
}
.px-2 {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}
.px-5 {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}
.px-\[10px\] {
  padding-left: 10px;
  padding-right: 10px;
}
.px-\[20px\] {
  padding-left: 20px;
  padding-right: 20px;
}
.px-\[30px\] {
  padding-left: 30px;
  padding-right: 30px;
}
.px-\[40px\] {
  padding-left: 40px;
  padding-right: 40px;
}
.px-\[65px\] {
  padding-left: 65px;
  padding-right: 65px;
}
.px-\[8\%\] {
  padding-left: 8%;
  padding-right: 8%;
}
.py-5 {
  padding-top: 1.25rem;
  padding-bottom: 1.25rem;
}
.py-\[100px\] {
  padding-top: 100px;
  padding-bottom: 100px;
}
.py-\[10px\] {
  padding-top: 10px;
  padding-bottom: 10px;
}
.py-\[15px\] {
  padding-top: 15px;
  padding-bottom: 15px;
}
.py-\[40px\] {
  padding-top: 40px;
  padding-bottom: 40px;
}
.py-\[50px\] {
  padding-top: 50px;
  padding-bottom: 50px;
}
.py-\[80px\] {
  padding-top: 80px;
  padding-bottom: 80px;
}
.\!pb-0 {
  padding-bottom: 0px !important;
}
.\!pb-\[80px\] {
  padding-bottom: 80px !important;
}
.pb-8 {
  padding-bottom: 2rem;
}
.pb-\[100px\] {
  padding-bottom: 100px;
}
.pb-\[20px\] {
  padding-bottom: 20px;
}
.pb-\[30px\] {
  padding-bottom: 30px;
}
.pb-\[50px\] {
  padding-bottom: 50px;
}
.pb-\[5px\] {
  padding-bottom: 5px;
}
.pb-\[80px\] {
  padding-bottom: 80px;
}
.pl-\[20px\] {
  padding-left: 20px;
}
.pr-\[25px\] {
  padding-right: 25px;
}
.pr-\[30px\] {
  padding-right: 30px;
}
.pr-\[40px\] {
  padding-right: 40px;
}
.pt-1 {
  padding-top: 0.25rem;
}
.pt-10 {
  padding-top: 2.5rem;
}
.pt-\[20px\] {
  padding-top: 20px;
}
.pt-\[30px\] {
  padding-top: 30px;
}
.pt-\[80px\] {
  padding-top: 80px;
}
.text-left {
  text-align: left;
}
.text-center {
  text-align: center;
}
.text-4xl {
  font-size: 2.25rem;
  line-height: 2.5rem;
}
.text-\[14px\] {
  font-size: 14px;
}
.text-\[18px\] {
  font-size: 18px;
}
.text-\[2\.3rem\] {
  font-size: 2.3rem;
}
.text-\[20px\] {
  font-size: 20px;
}
.text-\[22px\] {
  font-size: 22px;
}
.text-\[23px\] {
  font-size: 23px;
}
.text-\[24px\] {
  font-size: 24px;
}
.text-\[25px\] {
  font-size: 25px;
}
.text-\[26px\] {
  font-size: 26px;
}
.text-\[28px\] {
  font-size: 28px;
}
.text-\[2rem\] {
  font-size: 2rem;
}
.text-\[30px\] {
  font-size: 30px;
}
.text-\[35px\] {
  font-size: 35px;
}
.text-\[40px\] {
  font-size: 40px;
}
.text-\[45px\] {
  font-size: 45px;
}
.text-\[50px\] {
  font-size: 50px;
}
.text-\[55px\] {
  font-size: 55px;
}
.text-\[5rem\] {
  font-size: 5rem;
}
.text-\[6rem\] {
  font-size: 6rem;
}
.text-\[70px\] {
  font-size: 70px;
}
.text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.text-xl {
  font-size: 1.25rem;
  line-height: 1.75rem;
}
.font-bold {
  font-weight: 700;
}
.font-medium {
  font-weight: 500;
}
.font-normal {
  font-weight: 400;
}
.font-semibold {
  font-weight: 600;
}
.uppercase {
  text-transform: uppercase;
}
.leading-10 {
  line-height: 2.5rem;
}
.leading-\[1\.1\] {
  line-height: 1.1;
}
.leading-\[1\.2\] {
  line-height: 1.2;
}
.leading-\[1\.3\] {
  line-height: 1.3;
}
.leading-\[1\.5\] {
  line-height: 1.5;
}
.leading-\[1\.7\] {
  line-height: 1.7;
}
.leading-\[1\] {
  line-height: 1;
}
.leading-none {
  line-height: 1;
}
.leading-tight {
  line-height: 1.25;
}
.\!text-white {
  --tw-text-opacity: 1 !important;
  color: rgb(255 255 255 / var(--tw-text-opacity)) !important;
}
.\!text-yellow {
  --tw-text-opacity: 1 !important;
  color: rgb(255 224 65 / var(--tw-text-opacity)) !important;
}
.text-\[\#6E46CF\] {
  --tw-text-opacity: 1;
  color: rgb(110 70 207 / var(--tw-text-opacity));
}
.text-black {
  --tw-text-opacity: 1;
  color: rgb(0 0 0 / var(--tw-text-opacity));
}
.text-purple {
  --tw-text-opacity: 1;
  color: rgb(110 70 207 / var(--tw-text-opacity));
}
.text-purple2 {
  --tw-text-opacity: 1;
  color: rgb(231 230 246 / var(--tw-text-opacity));
}
.text-white {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
}
.text-yellow {
  --tw-text-opacity: 1;
  color: rgb(255 224 65 / var(--tw-text-opacity));
}
.opacity-0 {
  opacity: 0;
}
.opacity-100 {
  opacity: 1;
}
.opacity-20 {
  opacity: 0.2;
}
.opacity-60 {
  opacity: 0.6;
}
.opacity-70 {
  opacity: 0.7;
}
.opacity-80 {
  opacity: 0.8;
}
.opacity-90 {
  opacity: 0.9;
}
.opacity-\[\.55\] {
  opacity: .55;
}
.opacity-\[\.75\] {
  opacity: .75;
}
.opacity-\[\.7\] {
  opacity: .7;
}
.shadow-\[0px_2px_10px_\#0003\] {
  --tw-shadow: 0px 2px 10px #0003;
  --tw-shadow-colored: 0px 2px 10px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.drop-shadow {
  --tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / 0.1)) drop-shadow(0 1px 1px rgb(0 0 0 / 0.06));
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.filter {
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.backdrop-blur-sm {
  --tw-backdrop-blur: blur(4px);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}
.transition {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}
.transition-all {
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}
.transition-opacity {
  transition-property: opacity;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}
.duration-300 {
  transition-duration: 300ms;
}
.duration-500 {
  transition-duration: 500ms;
}
.ease-in-out {
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

/* Custom SCSS styles - auto-injected from style.scss */
@font-face {
  font-family: 'ProximaNova';
  src: url('/static/fonts/proximanova-regular-webfont.woff2') format('woff2'),
       url('/static/fonts/proximanova-regular-webfont.woff') format('woff');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'RobotoSlab';
  src: url('/static/fonts/RobotoSlab-Bold.woff2') format('woff2'),
       url('/static/fonts/RobotoSlab-Bold.woff') format('woff');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
body {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
  font-size: 18px;
  --tw-text-opacity: 1;
  color: rgb(0 0 0 / var(--tw-text-opacity));
  font-family: 'ProximaNova',sans-serif;
}
header {
  z-index: 99;
  display: flex;
  height: 70px;
  align-items: center;
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}
.container {
  margin-left: auto;
  margin-right: auto;
  width: 640px;
}
h1,h2,h3,h4,h5,h6 {
  font-family: 'RobotoSlab',sans-serif;
  font-weight: 700;
  line-height: 1.2;
}
h2 {
  font-size: 55px;
}
h3 {
  font-size: 45px;
}
h4 {
  font-size: 30px;
}
h5 {
  font-size: 26px;
}
h6 {
  font-size: 22px;
}
p {
  line-height: 1.7;
}
.site_copy > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}
.site_copy {
  padding-top: 80px;
  padding-bottom: 80px;
}
.btn_download {
  display: flex;
  width: -moz-max-content;
  width: max-content;
  align-items: center;
  border-radius: 10px;
  --tw-bg-opacity: 1;
  background-color: rgb(255 224 65 / var(--tw-bg-opacity));
  padding-left: 20px;
  padding-right: 40px;
  font-weight: 700;
  --tw-text-opacity: 1;
  color: rgb(110 70 207 / var(--tw-text-opacity));
  span {
    margin-right: 40px;
  }
  span {
    height: 100%;
  }
  span {
    border-right-width: 2px;
  }
  span {
    --tw-border-opacity: 1;
    border-right-color: rgb(110 70 207 / var(--tw-border-opacity));
  }
  span {
    padding-top: 10px;
    padding-bottom: 10px;
  }
  span {
    padding-right: 30px;
  }
  span {
    font-size: 2rem;
  }
  span {
    font-family: 'RobotoSlab',sans-serif;
  }
  &:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(188 169 233 / var(--tw-bg-opacity));
  }
}
.btn_yellow {
  display: flex;
  width: -moz-max-content;
  width: max-content;
  align-items: center;
  border-radius: 16px;
  --tw-bg-opacity: 1;
  background-color: rgb(255 224 65 / var(--tw-bg-opacity));
  padding-left: 40px;
  padding-right: 40px;
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: 18px;
  font-weight: 700;
  --tw-text-opacity: 1;
  color: rgb(110 70 207 / var(--tw-text-opacity));
    font-family: 'RobotoSlab',sans-serif;
  &:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(188 169 233 / var(--tw-bg-opacity));
  }
}
.btn_purple {
  display: flex;
  width: -moz-max-content;
  width: max-content;
  align-items: center;
  border-radius: 16px;
  --tw-bg-opacity: 1;
  background-color: rgb(110 70 207 / var(--tw-bg-opacity));
  padding-left: 40px;
  padding-right: 40px;
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: 18px;
  font-weight: 700;
  --tw-text-opacity: 1;
  color: rgb(255 224 65 / var(--tw-text-opacity));
    font-family: 'RobotoSlab',sans-serif;
  &:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(188 169 233 / var(--tw-bg-opacity));
  }
  &:hover {
    --tw-text-opacity: 1;
    color: rgb(110 70 207 / var(--tw-text-opacity));
  }
}
.welcome {
  .video {
    height: 100dvh;
  }
  .video {
    width: 100%;
  }
  .video {
    --tw-bg-opacity: 1;
    background-color: rgb(255 224 65 / var(--tw-bg-opacity));
  }
}
.welcome_copy > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(2.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(2.5rem * var(--tw-space-y-reverse));
}
.welcome_copy {
  padding-top: 80px;
  padding-bottom: 80px;
  p {
    --tw-text-opacity: 1;
    color: rgb(125 125 125 / var(--tw-text-opacity));
  }
  ul {
    display: flex;
  }
  ul {
    gap: 20px;
  }
  ul {
    li {
      flex: 1 1 0%;
    }
    li {
      border-radius: 20px;
    }
    li {
      padding-left: 20px;
      padding-right: 20px;
    }
    li {
      padding-top: 20px;
    }
    li {
      padding-bottom: 20px;
    }
    li {
      p {
        margin-bottom: 20px;
      }
      p {
        display: flex;
      }
      p {
        height: 130px;
      }
      p {
        align-items: center;
      }
      p {
        justify-content: center;
      }
      p {
        padding-left: 10px;
        padding-right: 10px;
      }
      p {
        img {
          width: 100%;
        }
      }
      h6 {
        font-weight: 700;
      }
      h6 {
        line-height: 1.2;
      }
      h6 {
        --tw-text-opacity: 1;
        color: rgb(110 70 207 / var(--tw-text-opacity));
      }
    }
  }
}
.introduction {
  --tw-bg-opacity: 1;
  background-color: rgb(110 70 207 / var(--tw-bg-opacity));
  .copy > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(2.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(2.5rem * var(--tw-space-y-reverse));
  }
  .copy {
    padding-top: 100px;
    padding-bottom: 100px;
  }
  h3 {
    --tw-text-opacity: 1;
    color: rgb(255 224 65 / var(--tw-text-opacity));
  }
  p {
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity));
  }
  p {
    opacity: .7;
  }
}
.key_statistic {
  --tw-bg-opacity: 1;
  background-color: rgb(231 230 246 / var(--tw-bg-opacity));
  padding-bottom: 100px;
  .copy > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(2.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(2.5rem * var(--tw-space-y-reverse));
  }
  .copy {
    padding-top: 100px;
    padding-bottom: 100px;
  }
  h3 {
    --tw-text-opacity: 1;
    color: rgb(0 0 0 / var(--tw-text-opacity));
  }
  p {
    --tw-text-opacity: 1;
    color: rgb(125 125 125 / var(--tw-text-opacity));
  }
}
.statistic_wrap {
  height: 600px;
  border-radius: 15px;
  --tw-bg-opacity: 1;
  background-color: rgb(110 70 207 / var(--tw-bg-opacity));
  --tw-shadow: 0px 2px 10px #0003;
  --tw-shadow-colored: 0px 2px 10px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  .statistic_view {
    height: 80%;
  }
  .statistic_copy {
    display: flex;
  }
  .statistic_copy {
    align-items: center;
  }
  .statistic_copy {
    justify-content: space-between;
  }
  .statistic_copy {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
  .statistic_copy {
    h4 {
      --tw-text-opacity: 1;
      color: rgb(255 255 255 / var(--tw-text-opacity));
    }
    button {
      border-radius: 0.5rem;
    }
    button {
      --tw-bg-opacity: 1;
      background-color: rgb(255 224 65 / var(--tw-bg-opacity));
    }
    button {
      padding-left: 2.5rem;
      padding-right: 2.5rem;
    }
    button {
      font-weight: 700;
    }
    button {
      line-height: 2.5rem;
    }
    button {
      --tw-text-opacity: 1;
      color: rgb(110 70 207 / var(--tw-text-opacity));
    }
    button {
      font-family: 'RobotoSlab',sans-serif;
      &:hover {
        --tw-bg-opacity: 1;
        background-color: rgb(188 169 233 / var(--tw-bg-opacity));
      }
    }
  }
}
.section_switcher {
  --tw-bg-opacity: 1;
  background-color: rgb(255 224 65 / var(--tw-bg-opacity));
  padding-top: 80px;
  .copy > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(30px * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(30px * var(--tw-space-y-reverse));
  }
  .copy {
    & > p {
      --tw-text-opacity: 1;
      color: rgb(0 0 0 / var(--tw-text-opacity));
    }
    & > p {
      opacity: .55;
    }
  }
  .copy_with_img {
    display: flex;
  }
  .copy_with_img {
    gap: 40px;
  }
  .copy_with_img {
    padding-left: 8%;
    padding-right: 8%;
  }
  .copy_with_img {
    padding-bottom: 80px;
  }
  .copy_with_img {
    p {
      font-weight: 400;
    }
    p {
      line-height: 1.5;
    }
    p {
      --tw-text-opacity: 1;
      color: rgb(110 70 207 / var(--tw-text-opacity));
    }
    p {
      font-family: 'RobotoSlab';
    }
    article {
      flex: 1 1 0%;
    }
    article > :not([hidden]) ~ :not([hidden]) {
      --tw-space-y-reverse: 0;
      margin-top: calc(30px * calc(1 - var(--tw-space-y-reverse)));
      margin-bottom: calc(30px * var(--tw-space-y-reverse));
    }
  }
  .interactive {
    --tw-bg-opacity: 1;
    background-color: rgb(231 230 246 / var(--tw-bg-opacity));
  }
  .interactive {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .interactive_wrap {
    min-height: 400px;
  }
}
.card_switcher {
  margin-left: -50px;
  margin-right: -50px;
  display: flex;
  gap: 15px;
  li {
    margin-top: 30px;
    margin-bottom: 30px;
  }
  li {
    flex: 1 1 0%;
  }
  li {
    border-radius: 12px;
  }
  li {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
  li {
    padding-top: 30px;
  }
  li {
    padding-bottom: 2rem;
  }
  li {
    --tw-shadow: 0px 2px 10px #0003;
    --tw-shadow-colored: 0px 2px 10px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  }
  li {
    .percentages {
      margin-bottom: 2.5rem;
    }
    .percentages {
      display: flex;
    }
    .percentages {
      justify-content: space-between;
    }
    .percentages {
      span {
        width: 50%;
      }
      span {
        flex: 1 1 0%;
      }
      span {
        text-align: left;
      }
      span {
        font-size: 40px;
      }
      span {
        font-weight: 700;
      }
      span {
        line-height: 1;
      }
      span {
        --tw-text-opacity: 1;
        color: rgb(255 255 255 / var(--tw-text-opacity));
      }
      span {
        opacity: 0.8;
      }
      span {
        font-family: 'RobotoSlab', sans-serif;
        &.highlight {
          --tw-text-opacity: 1;
          color: rgb(255 224 65 / var(--tw-text-opacity));
        }
        &.highlight {
          opacity: 1;
        }
      }
    }
    .bar-chart-wrapper {
      position: relative;
    }
    .bar-chart-wrapper {
      height: 220px;
    }
    .bar-chart {
      position: relative;
    }
    .bar-chart {
      z-index: 10;
    }
    .bar-chart {
      display: flex;
    }
    .bar-chart {
      height: 100%;
    }
    .bar-chart {
      align-items: flex-end;
    }
    .bar-chart {
      .bar {
        width: 50%;
      }
      .bar {
        &.bar-nederland {
          --tw-bg-opacity: 1;
          background-color: rgb(255 224 65 / var(--tw-bg-opacity));
        }
        &.bar-jongeren {
          --tw-bg-opacity: 1;
          background-color: rgb(231 230 246 / var(--tw-bg-opacity));
        }
      }
    }
    .grid-lines {
      pointer-events: none;
    }
    .grid-lines {
      position: absolute;
    }
    .grid-lines {
      inset: 0px;
    }
    .grid-lines {
      margin-left: -20px;
      margin-right: -20px;
    }
    .grid-lines {
      display: flex;
    }
    .grid-lines {
      flex-direction: column;
    }
    .grid-lines {
      justify-content: space-between;
    }
    .grid-lines {
      span {
        width: 100%;
      }
      span {
        border-top-width: 1px;
      }
      span {
        border-style: dotted;
      }
      span {
        --tw-border-opacity: 1;
        border-color: rgb(255 255 255 / var(--tw-border-opacity));
      }
      span {
        --tw-border-opacity: 0.7;
      }
    }
    .labels {
      display: flex;
    }
    .labels {
      justify-content: space-between;
    }
    .labels {
      padding-left: 0.25rem;
      padding-right: 0.25rem;
    }
    .labels {
      div {
        display: flex;
      }
      div {
        flex: 1 1 0%;
      }
      div {
        align-items: center;
      }
      div {
        gap: 0.5rem;
      }
      div {
        p {
          font-size: 14px;
        }
        p {
          --tw-text-opacity: 1;
          color: rgb(231 230 246 / var(--tw-text-opacity));
        }
        p {
          font-family: 'RobotoSlab',sans-serif;
        }
      }
    }
    h5 {
      padding-top: 2.5rem;
    }
    h5 {
      font-size: 23px;
    }
    h5 {
      line-height: 1.3;
    }
  }
  li.bg-light-purple {
    .percentages span.highlight {
      --tw-text-opacity: 1;
      color: rgb(110 70 207 / var(--tw-text-opacity));
    }
    .bar-chart {
      .bar {
        &.bar-nederland {
          --tw-bg-opacity: 1;
          background-color: rgb(255 255 255 / var(--tw-bg-opacity));
        }
        &.bar-jongeren {
          --tw-bg-opacity: 1;
          background-color: rgb(110 70 207 / var(--tw-bg-opacity));
        }
      }
    }
    .grid-lines {
      span {
        --tw-border-opacity: 1;
        border-color: rgb(110 70 207 / var(--tw-border-opacity));
      }
      span {
        --tw-border-opacity: 0.5;
      }
    }
    .labels {
      div {
        .indicator {
          &.indicator-nederland {
            --tw-bg-opacity: 1;
            background-color: rgb(255 255 255 / var(--tw-bg-opacity));
          }
          &.indicator-jongeren {
            --tw-bg-opacity: 1;
            background-color: rgb(110 70 207 / var(--tw-bg-opacity));
          }
        }
        p {
          --tw-text-opacity: 1;
          color: rgb(110 70 207 / var(--tw-text-opacity));
        }
      }
    }
  }
}
.section_quiz {
  --tw-bg-opacity: 1;
  background-color: rgb(110 70 207 / var(--tw-bg-opacity));
  padding-top: 100px;
  padding-bottom: 100px;
  .copy > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(2.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(2.5rem * var(--tw-space-y-reverse));
  }
  .copy {
    h4 {
      --tw-text-opacity: 1;
      color: rgb(255 255 255 / var(--tw-text-opacity));
    }
    h4 {
      opacity: .75;
    }
    & > p {
      --tw-text-opacity: 1;
      color: rgb(255 255 255 / var(--tw-text-opacity));
    }
    & > p {
      opacity: .75;
    }
  }
  .interactive {
    margin-top: 50px;
  }
}
.quiz-container {
  position: relative;
}
.quiz-explanation {
  margin-top: 60px;
  display: flex;
  align-items: flex-start;
  gap: 40px;
  &.hidden {
    display: none;
  }
}
.quiz-explanation-icon {
  flex-shrink: 0;
  svg {
    width: 48px;
    height: 48px;
  }
}
.quiz-explanation-content {
  flex: 1 1 0%;
}
.quiz-explanation-content > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(30px * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(30px * var(--tw-space-y-reverse));
}
.quiz-explanation-content {
  font-family: 'RobotoSlab', sans-serif;
  p {
    line-height: 1.5;
  }
  p {
    --tw-text-opacity: 1;
    color: rgb(231 230 246 / var(--tw-text-opacity));
  }
}
.quiz-percentage-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  padding-right: 25px;
  .quiz-percentage {
    padding: 0;
  }
}
.quiz-tooltip {
  position: absolute;
  top: 160%;
  right: 10px;
  background: #6e46cf;
  color: white;
  padding: 10px 20px;
  border-radius: 12px;
  white-space: nowrap;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
  z-index: 10;
  width: -moz-max-content;
  width: max-content;
}
.quiz-tooltip::after {
  content: '';
  position: absolute;
  top: -35px;
  left: 63%;
  transform: translateX(-50%) rotate(200deg);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0px 0px 50px 30px;
  border-color: transparent transparent transparent #6e46cf;
}
.quiz-tooltip.hidden {
  display: none;
}
.quiz-tooltip-content {
  display: flex;
  align-items: center;
  gap: 8px;
}
.quiz-tooltip-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #FFE041;
  svg {
    width: 20px;
    height: 20px;
  }
}
.quiz-tooltip-text {
  font-size: 14px;
  font-weight: 600;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
  font-family: 'RobotoSlab', sans-serif;
}
.interactive-quiz > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0px * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0px * var(--tw-space-y-reverse));
}
.interactive-quiz {
  overflow: hidden;
  border-radius: 20px;
  --tw-bg-opacity: 1;
  background-color: rgb(255 224 65 / var(--tw-bg-opacity));
  --tw-shadow: 0px 2px 10px #0003;
  --tw-shadow-colored: 0px 2px 10px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  li {
    display: flex;
  }
  li {
    align-items: center;
  }
  li {
    border-bottom-width: 1px;
  }
  li {
    --tw-border-opacity: 1;
    border-color: rgb(110 70 207 / var(--tw-border-opacity));
  }
  li {
    --tw-border-opacity: 0.2;
  }
  li {
    transition: all 0.3s ease;
    position: relative;
    &:last-child {
      border-bottom-width: 0px;
    }
    .letter {
      padding-top: 0.25rem;
    }
    .letter {
      text-align: center;
    }
    .letter {
      font-size: 20px;
    }
    .letter {
      font-weight: 700;
    }
    .letter {
      line-height: 1;
    }
    .letter {
      --tw-text-opacity: 1;
      color: rgb(110 70 207 / var(--tw-text-opacity));
    }
    .letter {
      font-family: 'RobotoSlab', sans-serif;
      min-width: 60px;
    }
    .answer-text {
      flex: 1 1 0%;
    }
    .answer-text {
      border-left-width: 1px;
    }
    .answer-text {
      --tw-border-opacity: 1;
      border-color: rgb(110 70 207 / var(--tw-border-opacity));
    }
    .answer-text {
      --tw-border-opacity: 0.2;
    }
    .answer-text {
      padding: 25px;
    }
    .answer-text {
      p {
        line-height: 1.5;
      }
      p {
        --tw-text-opacity: 1;
        color: rgb(110 70 207 / var(--tw-text-opacity));
      }
      p {
        font-family: 'RobotoSlab', sans-serif;
      }
    }
    .quiz-percentage {
      padding-right: 25px;
    }
    .quiz-percentage {
      font-size: 25px;
    }
    .quiz-percentage {
      font-weight: 700;
    }
    .quiz-percentage {
      --tw-text-opacity: 1;
      color: rgb(110 70 207 / var(--tw-text-opacity));
    }
    .quiz-percentage {
      font-family: 'RobotoSlab', sans-serif;
      min-width: 80px;
      text-align: right;
      &.hidden {
        display: none;
      }
    }
    .quiz-percentage-wrapper .quiz-percentage {
      padding: 0;
    }
    &:hover {
      cursor: pointer;
    }
    &::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: #C4B5FD;
      transform: scaleX(0);
      transform-origin: left;
      transition: transform 0.4s ease;
      z-index: 0;
    }
    &:hover::before {
      transform: scaleX(1);
    }
    .letter,
    .answer-text,
    .quiz-percentage,
    .quiz-percentage-wrapper {
      position: relative;
      z-index: 1;
    }
    &.selected {
      background: rgba(124, 58, 237, 0.1);
    }
    &.quiz-correct {
      background: #C4B5FD;
    }
    &.quiz-incorrect {
      background: #C4B5FD;
    }
  }
}
.section_savings {
  --tw-bg-opacity: 1;
  background-color: rgb(255 224 65 / var(--tw-bg-opacity));
  .copy > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(2.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(2.5rem * var(--tw-space-y-reverse));
  }
  .copy {
    padding-top: 100px;
    padding-bottom: 100px;
  }
  h3 {
    --tw-text-opacity: 1;
    color: rgb(110 70 207 / var(--tw-text-opacity));
  }
  .interactive {
    --tw-bg-opacity: 1;
    background-color: rgb(231 230 246 / var(--tw-bg-opacity));
  }
  .interactive {
    .copy {
      p {
        opacity: .7;
      }
    }
  }
  .interactive_wrap {
    min-height: 400px;
  }
}
.section_beliefcheck {
  --tw-bg-opacity: 1;
  background-color: rgb(255 224 65 / var(--tw-bg-opacity));
  .copy > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(2.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(2.5rem * var(--tw-space-y-reverse));
  }
  .copy {
    padding-top: 100px;
    padding-bottom: 100px;
  }
  h3 {
    --tw-text-opacity: 1;
    color: rgb(110 70 207 / var(--tw-text-opacity));
  }
  .interactive {}
  .interactive_wrap {}
}
.section_cta {}
.cta_download {
  font-family: 'RobotoSlab', sans-serif;
  display: flex;
  width: -moz-max-content;
  width: max-content;
  border-radius: 12px;
  --tw-bg-opacity: 1;
  background-color: rgb(110 70 207 / var(--tw-bg-opacity));
  padding-top: 1.25rem;
  padding-bottom: 1.25rem;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
  font-size: 20px;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
  &:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(188 169 233 / var(--tw-bg-opacity));
  }
  &:hover {
    --tw-text-opacity: 1;
    color: rgb(110 70 207 / var(--tw-text-opacity));
  }
}
.section_complexity {
  margin-top: -80px;
}
.circle-section-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: -50px;
    .circle-container {
        display: flex;
        justify-content: center;
        align-items: center;
    }
}
#progressCircle {
    stroke: #6E46CF !important;
}
.circular-progress {
    position: relative;
    width: 100%;
    aspect-ratio: 1;
    cursor: pointer;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
    display: flex;
    align-items: center;
    justify-content: center;
    @media (max-width: 768px) {
        max-width: 400px;
    }
    @media (max-width: 480px) {
        max-width: 100%;
    }
}
.progress-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    pointer-events: none;
    width: 280px;
    z-index: 10;
    font-family: 'RobotoSlab',sans-serif;
}
.progress-value {
    font-size: 72px;
    font-weight: 800;
    color: #6E46CF;
    margin-bottom: 12px;
    display: block;
    line-height: 1;
    @media (max-width: 480px) {
        font-size: 52px;
        margin-bottom: 8px;
    }
}
.progress-text {
    font-size: 16px;
    line-height: 1.6;
    color: #6E46CF;
    font-weight: 700;
    margin-bottom: 20px;
    @media (max-width: 480px) {
        font-size: 13px;
        margin-bottom: 16px;
    }
    br {
        @media (max-width: 480px) {
            display: none;
        }
    }
}
.answer-button {
    margin: 10px auto 0;
    cursor: pointer;
    pointer-events: auto;
    white-space: nowrap;
}
.circle-answer-button {
    @extend .answer-button;
}
.handle-icon {
    width: 24px;
    height: 24px;
    fill: white;
    pointer-events: none;
}
svg {
    filter: drop-shadow(0 8px 24px rgba(0, 0, 0, 0.08));
    @media (max-width: 480px) {
        filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.06));
    }
}
/* Ẩn circle màu vàng ban đầu, hiển thị khi submit */
.hidden-circle {
    display: none;
}
.vertical-section-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 60px;
}
.vertical-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    background: rgba(255, 255, 255, 0.4);
    border-radius: 20px;
    padding: 20px;
    --tw-shadow: 0px 2px 10px #0003;
    --tw-shadow-colored: 0px 2px 10px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.vertical-bars-wrapper {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-bottom: 30px;
    width: 100%;
    position: relative;
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 29px,
            rgba(124, 58, 237, 0.5) 29px,
            rgba(124, 58, 237, 0.5) 30px
        );
    @media (max-width: 768px) {
        background:
            repeating-linear-gradient(
                0deg,
                transparent,
                transparent 24px,
                rgba(124, 58, 237, 0.5) 24px,
                rgba(124, 58, 237, 0.5) 25px
            );
    }
    @media (max-width: 480px) {
        background:
            repeating-linear-gradient(
                0deg,
                transparent,
                transparent 19px,
                rgba(124, 58, 237, 0.5) 19px,
                rgba(124, 58, 237, 0.5) 20px
            );
    }
}
.vertical-bar-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    transform: translateY(-4px);
    position: relative;
    @media (max-width: 768px) {
        gap: 12px;
    }
}
.bar-percentage {
    position: absolute;
    font-size: 24px;
    font-weight: 700;
    color: #6e46cf;
    min-width: 60px;
    text-align: center;
    transition: top 0.2s ease;
    z-index: 5;
    left: 50%;
    transform: translateX(-50%);
    font-family: 'RobotoSlab',sans-serif;
    @media (max-width: 768px) {
        font-size: 20px;
    }
}
.bar-percentage1, .bar-label1 {
    color: #FFE041
}
.bar-percentage2, .bar-label2 {
    color: #E7E6F6
}
.bar-percentage3, .bar-label3 {
    color: #6E46CF
}
.vertical-bar-container {
    position: relative;
    width: 100%;
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    margin-top: 50px; /* Space for percentage label*/
}
.handle-icon {
    position: absolute;
    left: 50%;
    transform: translate(-50%, -80%);
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transition: top 0.2s ease;
    pointer-events: auto;
    cursor: grab;
    img {
        width: 24px;
        height: 24px;
        -o-object-fit: contain;
           object-fit: contain;
    }
    &:active {
        cursor: grabbing;
    }
}
.vertical-svg {
    width: 100%;
    height: 100%;
    filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.1));
}
.bar-label {
    font-size: 14px;
    font-weight: 600;
    text-align: center;
    max-width: 120px;
    margin-top: -25px;
    font-family: 'RobotoSlab',sans-serif;
    @media (max-width: 768px) {
        font-size: 12px;
        max-width: 100px;
    }
}
.bar-progress {
    stroke-linecap: round;
    transition: stroke-dashoffset 0.2s ease;
}
.hidden-bar {
    display: none;
}
.vertical-question {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    align-items: center;
    width: 100%;
    h2 {
        grid-column: span 2;
        font-size: 25px;
        font-weight: 700;
        line-height: 1.4;
        margin: 0;
        text-align: left;
    }
    h2 {
    --tw-text-opacity: 1;
    color: rgb(110 70 207 / var(--tw-text-opacity));
  }
}
.vertical-answer-button {
    grid-column: span 1;
    cursor: pointer;
    white-space: nowrap;
}
/* Hand pointer icon in center */
.vertical-hand-pointer {
    position: absolute;
    top: 35%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 30;
    pointer-events: auto;
    animation: vertical-hand-slide 1.8s ease-in-out infinite;
    cursor: pointer;
    transition: opacity 0.3s ease;
    img {
        width: 40px;
        height: 40px;
        @media (max-width: 768px) {
            width: 50px;
            height: 50px;
        }
        @media (max-width: 480px) {
            width: 40px;
            height: 40px;
        }
    }
    &:hover {
        opacity: 0;
    }
    &.hidden {
        display: none;
    }
}
@keyframes vertical-hand-slide {
    0% {
        transform: translate(-50%, -58%);
        opacity: 0;
    }
    15% {
        opacity: 1;
    }
    50% {
        transform: translate(-50%, -42%);
        opacity: 1;
    }
    85% {
        opacity: 0;
    }
    100% {
        transform: translate(-50%, -58%);
        opacity: 0;
    }
}
.vertical-tip {
    display: flex;
    align-items: flex-start;
    gap: 40px;
    width: 100%;
    margin-top: 60px;
    color: white;
    .tip-icon {
        width: 40px;
        flex-shrink: 0;
    }
    .tip-text {
        font-family: 'RobotoSlab',sans-serif;
        line-height: 1.5;
        margin: 0;
    }
}
.healthcare-card {
  position: relative;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
  border-radius: 20px;
  --tw-bg-opacity: 1;
  background-color: rgb(110 70 207 / var(--tw-bg-opacity));
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
  --tw-shadow: 0px 2px 10px #0003;
  --tw-shadow-colored: 0px 2px 10px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.healthcare-grid {
  pointer-events: none;
  position: absolute;
  top: 0px;
  bottom: 0px;
  opacity: 0.2;
  left: var(--healthcare-grid-left, 0);
  right: var(--healthcare-grid-right, 0);
}
.healthcare-grid-lines {
  display: flex;
  height: 100%;
  justify-content: space-between;
}
.healthcare-grid-lines span {
  border-left-width: 1px;
  border-style: dashed;
  height: calc(100% - 165px);
  border-color: #e7e6f6;
}
.healthcare-content {
  position: relative;
  z-index: 1;
}
.healthcare-content > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(40px * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(40px * var(--tw-space-y-reverse));
}
.healthcare-content {
  padding-left: 30px;
  padding-right: 30px;
}
.healthcare-header {
  margin-bottom: 20px;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
}
.healthcare-percentage {
  font-size: 6rem;
  font-weight: 800;
  line-height: 1;
}
.healthcare-bars {
  margin-bottom: 20px;
}
.healthcare-row {
  display: flex;
  align-items: center;
  gap: 20px;
}
.healthcare-track-nederland {
  position: relative;
  height: 150px;
  flex: 1 1 0%;
}
.healthcare-bar-nederland {
  position: absolute;
  top: 0px;
  bottom: 0px;
  left: 0px;
  width: 24.6%;
  background-color: #E7E6F6;
}
.healthcare-value-nederland {
  position: absolute;
  top: 50%;
  font-size: 35px;
  font-weight: 700;
  line-height: 1;
  --tw-text-opacity: 1;
  color: rgb(231 230 246 / var(--tw-text-opacity));
  left: calc(24.6% + 12px);
  transform: translateY(-50%);
  font-family: 'RobotoSlab',sans-serif;
}
.healthcare-op3 {
  margin-top: 60px;
  .healthcare-grid-lines span {
    border-color: #4F2DA8;
  }
  .healthcare-card {
    --tw-bg-opacity: 1;
    background-color: rgb(255 224 65 / var(--tw-bg-opacity));
  }
  .healthcare-bar-nederland {
    width: 36.4%;
    background: white;
  }
  .healthcare-label {
    --tw-text-opacity: 1;
    color: rgb(110 70 207 / var(--tw-text-opacity));
  }
  .healthcare-footer h2 {
    --tw-text-opacity: 1;
    color: rgb(110 70 207 / var(--tw-text-opacity));
  }
  .healthcare-bar {
    --tw-bg-opacity: 1;
    background-color: rgb(110 70 207 / var(--tw-bg-opacity));
  }
  .healthcare-label-nederland,
  .healthcare-label-nederland h4 {
    color: #fff;
  }
  .healthcare-value-nederland {
    left: calc(36.4% + 12px);
    color: #fff;
  }
}
.healthcare-op2 {
  margin-top: 60px;
  .healthcare-bar-nederland {
    width: 20%;
  }
  .healthcare-value-nederland {
    left: calc(20% + 12px);
  }
}
.healthcare-label-nederland {
  min-width: 120px;
  font-weight: 700;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
}
.healthcare-label-nederland h4 {
  font-size: 18px;
  line-height: 1.1;
  --tw-text-opacity: 1;
  color: rgb(231 230 246 / var(--tw-text-opacity));
}
.healthcare-track {
  position: relative;
  height: 150px;
  flex: 1 1 0%;
  &::after {
    content: "";
    position: absolute;
    inset: 0;
    width: var(--healthcare-guess-width, 0);
    background: rgba(255, 255, 255, 0.35);
    pointer-events: none;
    opacity: 0;
    transition: width 0.3s ease, opacity 0.3s ease;
  }
}
.healthcare-track-bg {
  position: absolute;
  inset: 0px;
}
.healthcare-bar {
  position: absolute;
  top: 0px;
  bottom: 0px;
  left: 0px;
  z-index: 1;
  --tw-bg-opacity: 1;
  background-color: rgb(255 224 65 / var(--tw-bg-opacity));
  width: var(--healthcare-bar-width, 25%);
  transition: none;
}
.healthcare-label {
  min-width: 120px;
  font-weight: 700;
  --tw-text-opacity: 1;
  color: rgb(255 224 65 / var(--tw-text-opacity));
}
.healthcare-label h4 {
  font-size: 18px;
  line-height: 1.3;
}
.healthcare-range {
  position: absolute;
  inset: 0px;
  z-index: 10;
  height: 100%;
  width: 100%;
  cursor: pointer;
  background-color: transparent;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  transition: opacity 0.3s ease;
}
.healthcare-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 30px;
  height: 30px;
  background: transparent;
  cursor: grab;
  opacity: 0;
}
.healthcare-range:active::-webkit-slider-thumb {
  cursor: grabbing;
}
.healthcare-range::-moz-range-thumb {
  width: 30px;
  height: 30px;
  background: transparent;
  cursor: grab;
  border: 0;
  opacity: 0;
}
.healthcare-range:active::-moz-range-thumb {
  cursor: grabbing;
}
.healthcare-play-icon {
  pointer-events: none;
  position: absolute;
  top: 50%;
  z-index: 2;
  display: flex;
  height: 30px;
  width: 30px;
  align-items: center;
  justify-content: center;
  right: 0;
  transform: translate(50%, -50%);
}
.healthcare-play-icon img {
  height: 100%;
  width: 100%;
}
.healthcare-question {
  pointer-events: none;
  position: absolute;
  top: 50%;
  font-size: 35px;
  font-weight: 800;
  z-index: 20;
  transform: translateY(-50%);
  font-family: 'RobotoSlab',sans-serif;
}
.healthcare-question-higher {
  z-index: 1;
}
.healthcare-bar-higher {
  z-index: 3 !important;
}
.healthcare-guess-lower::after {
  z-index: 0 !important;
}
.healthcare-result-visible .healthcare-track::after {
  z-index: 2;
}
.healthcare-question span {
  display: block;
}
.healthcare-question.is-centered {
  left: 50%;
  transform: translate(-50%, -50%);
}
.healthcare-pointer {
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  --tw-translate-x: -50%;
  --tw-translate-y: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.healthcare-pointer img {
  height: 40px;
  width: 40px;
}
.healthcare-hand-active {
  animation: healthcare-hand-slide 1.8s ease-in-out infinite;
}
.healthcare-pointer.hidden {
  display: none;
}
@keyframes healthcare-hand-slide {
  0% {
    transform: translate(-70%, -50%);
    opacity: 0;
  }
  15% {
    opacity: 1;
  }
  50% {
    transform: translate(10%, -50%);
    opacity: 1;
  }
  85% {
    opacity: 0;
  }
  100% {
    transform: translate(-70%, -50%);
    opacity: 0;
  }
}
.healthcare-result-visible .healthcare-track::after {
  opacity: 1;
}
.healthcare-result-visible .healthcare-range {
  pointer-events: none;
  opacity: 0;
}
.healthcare-result-visible .healthcare-pointer,
.healthcare-result-visible .healthcare-question [data-healthcare-focus] {
  display: none;
}
.healthcare-result-visible .healthcare-play-icon {
  display: none;
}
.healthcare-result-visible .healthcare-bar {
  transition: width 0.4s ease;
}
.healthcare-footer {
  margin-top: 20px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 30px;
  padding-bottom: 30px;
}
.healthcare-footer h2 {
  font-size: 2.3rem;
  font-weight: 700;
  line-height: 1.25;
  --tw-text-opacity: 1;
  color: rgb(231 230 246 / var(--tw-text-opacity));
}
@media (min-width: 768px) {

  .healthcare-footer h2 {
    font-size: 25px;
  }
}
.healthcare-footer button {
  margin-top: 20px;
}
.healthcare-result-visible .healthcare-footer button {
  display: none;
}
.map-question {
  position: relative;
  margin: 60px -200px 0 -200px;
  &::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
  }
}
.map-question__inner {
  position: relative;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  gap: 15px;
  z-index: 1;
}
.map-question__card {
  position: relative;
  display: flex;
  flex: 1 1 0%;
  flex-direction: column;
  justify-content: space-between;
  border-radius: 20px;
  padding: 20px;
  --tw-shadow: 0px 2px 10px #0003;
  --tw-shadow-colored: 0px 2px 10px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  min-height: 540px;
}
.map-question__card--most {
  background: #d9c6ff;
}
.map-question__card--least {
  --tw-bg-opacity: 1;
  background-color: rgb(255 224 65 / var(--tw-bg-opacity));
}
.map-question__map {
  width: 100%;
  aspect-ratio: 5 / 5;
  isolation: isolate;
  position: relative;
  margin: -30px -75px 0;
  width: calc(100% + 150px);
}
[data-map-container] {
  position: relative;
  width: 100%;
  height: 100%;
}
.map-question__map svg {
  height: 100%;
  width: 100%;
  filter: drop-shadow(0 8px 12px rgba(34, 0, 85, 0.06));
}
.map-question__stat {
  position: absolute;
  left: calc(var(--map-tooltip-left, 50%) + var(--map-tooltip-offset-x, 0px));
  top: calc(var(--map-tooltip-top, 50%) + var(--map-tooltip-offset-y, 0px));
  transform: translate(-50%, -100%);
  z-index: 3;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s ease, transform 0.4s ease;
  width: clamp(200px, 35vw, 320px);
  filter: drop-shadow(0 0 5px rgba(38, 0, 85, 0.15));
  font-family: 'RobotoSlab', sans-serif;
}
.map-question__stat.is-visible {
  opacity: 1;
  visibility: visible;
}
.map-question__stat-content {
  position: relative;
  width: 100%;
  padding: clamp(24px, 4.5vw, 36px) clamp(32px, 6vw, 52px) clamp(32px, 6vw, 48px);
  padding-top: clamp(60px, 8vw, 80px);
  color: #5533cc;
  text-align: center;
  background-image: url('/static/images/icons/comment.svg');
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center center;
}
.map-question__card--least .map-question__stat {
  width: auto;
  min-width: clamp(200px, 35vw, 320px);
  height: auto;
}
.map-question__card--least .map-question__stat-content {
  background-image: url('/static/images/icons/map.svg');
  padding: 0;
  background-size: contain;
  width: 100%;
  height: 0;
  padding-bottom: 60%; /* Tỷ lệ khung hình của map.png, có thể điều chỉnh */
  background-position: center center;
}
.map-question__card--least .map-question__stat-value,
.map-question__card--least .map-question__stat-caption {
  display: none;
}
.map-question__stat-value {
  font-size: 45px;
  font-weight: 900;
  line-height: 0.95;
  letter-spacing: -0.01em;
}
.map-question__stat-caption {
  margin-top: clamp(4px, 1.2vw, 8px);
  font-size: clamp(15px, 3.2vw, 22px);
  font-weight: 800;
  letter-spacing: 0.02em;
  line-height: 1.25;
}
.map-question__labels {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.map-question__label {
  position: absolute;
  transform: translate(-50%, -50%);
  color: #4c23b3;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: normal;
  text-align: center;
  display: inline-block;
  line-height: 1.15;
  transition: color 0.2s ease;
  font-family: 'RobotoSlab',sans-serif;
}
.map-question__label.is-selected {
  color: #ffffff;
}
.map-question__label.is-guess {
  color: #3e1a83;
}
.map-question__label.is-correct {
  color: #ffffff;
}
.map-question__card--least .map-question__label {
  color: #3e1a83;
}
.map-question__card--least .map-question__label.is-selected {
  color: #4c23b3;
}
.map-question__card--least .map-question__label.is-guess {
  color: #4c23b3;
}
.map-question__card--least .map-question__label.is-correct {
  color: #4c23b3;
}
[data-map-features] path {
  fill: transparent;
  stroke: #4f2da8;
  stroke-width: 1.8;
  stroke-dasharray: 8 6;
  transition: fill 0.25s ease, stroke 0.25s ease, transform 0.25s ease,
    filter 0.25s ease;
  cursor: pointer;
}
.map-question__card.is-answered [data-map-features] path {
  cursor: default;
  pointer-events: none;
}
[data-map-features] path.is-selected {
  fill: rgba(118, 85, 217, 0.2);
  stroke: #4e23b8;
  stroke-dasharray: none;
}
[data-map-features] path.is-guess {
  fill: rgba(118, 85, 217, 0.35);
  stroke: #4e23b8;
  stroke-dasharray: none;
}
[data-map-features] path.is-incorrect {
  fill: rgba(118, 85, 217, 0.2);
  stroke: #4e23b8;
  stroke-dasharray: none;
}
[data-map-features] path.is-correct {
  fill: #4e23b8;
  stroke: #220b71;
  stroke-dasharray: none;
  filter: none;
}
.map-question__card--least [data-map-features] path {
  stroke: #5130a4;
  fill: transparent;
}
[data-map-features] path:hover {
  filter: drop-shadow(0 6px 10px rgba(55, 19, 136, 0.12));
  stroke: #321782;
}
.map-question__summary {
  display: none;
  line-height: 1.3;
  opacity: 0;
  font-family: 'RobotoSlab', sans-serif;
  font-size: 22px;
  --tw-text-opacity: 1;
  color: rgb(110 70 207 / var(--tw-text-opacity));
}
.map-question__card.is-answered .map-question__summary {
  opacity: 1;
  transform: translateY(0);
}
.map-question__card--least [data-map-features] path:hover {
  stroke: #2f0d6f;
}
[data-map-features] path.is-selected {
  fill: #4e23b8;
  stroke: #220b71;
  stroke-dasharray: none;
  filter: none;
}
.map-question__card--least [data-map-features] path.is-selected {
  fill: #ffffff;
  stroke: rgba(255, 255, 255, 0.4);
}
.map-question__card--least [data-map-features] path.is-guess {
  fill: rgba(255, 255, 255, 0.3);
  stroke: rgba(255, 255, 255, 0.4);
  stroke-dasharray: none;
}
.map-question__card--least [data-map-features] path.is-correct {
  fill: #ffffff;
  stroke: rgba(255, 255, 255, 0.4);
  stroke-dasharray: none;
}
.map-question__body {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.map-question__prompt {
  font-family: 'RobotoSlab', sans-serif;
  font-size: 25px;
  line-height: 1.2;
  --tw-text-opacity: 1;
  color: rgb(110 70 207 / var(--tw-text-opacity));
  transition: opacity 0.25s ease, transform 0.25s ease;
}
.map-question__prompt.is-hidden {
  opacity: 0;
  transform: translateY(12px);
  visibility: hidden;
}
.map-question__button {
  display: inline-flex;
  width: 100%;
  align-items: center;
  justify-content: center;
}
.map-question__button.is-hidden {
  display: none;
}
@media (max-width: 768px) {
  .map-question {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .map-question__card {
    min-height: 460px;
    padding: 28px;
  }
  .map-question__card::after {
    inset: 18px;
    border-radius: 26px;
  }
  .map-question__map {
    margin: -28px -28px 0;
    width: calc(100% + 56px);
  }
  .map-question__label {
    font-size: 8px;
    letter-spacing: 0.06em;
  }
  .map-question__stat {
    right: clamp(120px, 20vw, 200px);
    bottom: clamp(18px, 10vw, 40px);
  }
}
@media (min-width: 1024px) {
  .map-question__inner {
    flex-direction: row;
  }
}
.zone-section-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
}
.zone-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 60px;
}
.zone-header {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
    gap: 16px;
    @media (max-width: 768px) {
        gap: 12px;
    }
    @media (max-width: 480px) {
        gap: 10px;
    }
}
.zone-title {
    font-size: 32px;
    font-weight: 700;
    color: #1a202c;
    margin: 0;
    line-height: 1.3;
    @media (max-width: 768px) {
        font-size: 28px;
    }
    @media (max-width: 480px) {
        font-size: 24px;
    }
}
.zone-subtitle {
    font-size: 16px;
    font-weight: 400;
    color: #718096;
    margin: 0;
    line-height: 1.6;
    @media (max-width: 768px) {
        font-size: 14px;
    }
    @media (max-width: 480px) {
        font-size: 13px;
    }
}
.zones-wrapper {
    display: flex;
    width: 100%;
    height: 350px;
    background: rgba(255, 255, 255, 0.4);
    border-radius: 10px;
    overflow: hidden;
    position: relative;
}
.zones-separators {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 900px;
    height: 300px;
    pointer-events: none;
    display: flex;
    align-items: center;
    @media (max-width: 768px) {
        height: 250px;
    }
    @media (max-width: 480px) {
        height: 200px;
    }
}
.zone {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
    z-index: 1;
    border-right: 1px dotted #6e46cf;
    &:last-child {
        border-right: none;
    }
    &:nth-child(1) {
        background: #FFE041;
    }
    &:nth-child(3) {
        background: #c5b5ec;
    }
    &:nth-child(5) {
        background: #ffffff;
    }
    &:nth-child(7) {
        background: #FFE041;
    }
    &:nth-child(9) {
        background: #c5b5ec;
    }
}
.zone-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    width: 100%;
    padding: 20px 10px;
    text-align: center;
    position: relative;
    @media (max-width: 768px) {
        padding: 15px 8px;
    }
    @media (max-width: 480px) {
        padding: 12px 6px;
    }
}
.zone-bottom {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    font-family: 'RobotoSlab',sans-serif;
    @media (max-width: 768px) {
        gap: 6px;
        bottom: 15px;
    }
    @media (max-width: 480px) {
        gap: 4px;
        bottom: 12px;
    }
}
.zone-emoji {
    font-size: 64px;
    font-weight: 700;
    color: #6e46cf;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'RobotoSlab',sans-serif;
    img {
        width: 40px;
        -o-object-fit: contain;
           object-fit: contain;
    }
    @media (max-width: 768px) {
        font-size: 32px;
        img {
            width: 32px;
        }
    }
    @media (max-width: 480px) {
        font-size: 24px;
        img {
            width: 24px;
        }
    }
}
.zone-emoji-multi {
    flex-direction: column;
    gap: 6px;
}
.zone-emoji-grid-2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
}
.zone-label {
    font-size: 12px;
    font-weight: 600;
    color: #6e46cf;
    line-height: 1.2;
    @media (max-width: 768px) {
        font-size: 10px;
    }
    @media (max-width: 480px) {
        font-size: 8px;
    }
}
.zone-percentage {
    font-size: 24px;
    font-weight: 700;
    color: #6e46cf;
    @media (max-width: 768px) {
        font-size: 18px;
    }
    @media (max-width: 480px) {
        font-size: 14px;
    }
}
.zone-separator {
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    width: 40px;
    height: 100%;
    top: 0;
    pointer-events: none;
    margin-left: -20px;
    z-index: 5;
    &:nth-of-type(2) {
        left: 20%;
    }
    &:nth-of-type(4) {
        left: 40%;
    }
    &:nth-of-type(6) {
        left: 60%;
    }
    &:nth-of-type(8) {
        left: 80%;
    }
}
.separator-handle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    cursor: col-resize;
    pointer-events: auto;
    img {
        width: 24px;
        height: 24px;
        -o-object-fit: contain;
           object-fit: contain;
        z-index: 60;
    }
    @media (max-width: 768px) {
        width: 24px;
        height: 24px;
        img {
            width: 16px;
            height: 16px;
        }
    }
}
.zone-hand-pointer {
  pointer-events: none;
  position: absolute;
  top: 70%;
  left: 50%;
  width: 50px;
  height: 50px;
  --tw-translate-x: -50%;
  --tw-translate-y: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    z-index: 70;
    img {
        width: 62px;
        height: 62px;
        @media (max-width: 768px) {
            width: 48px;
            height: 48px;
        }
        @media (max-width: 480px) {
            width: 40px;
            height: 40px;
        }
    }
}
.zone-hand-active {
    animation: zone-hand-slide 1.8s ease-in-out infinite;
}
.zone-hand-pointer.hidden {
    display: none;
}
@keyframes zone-hand-slide {
    0% {
        transform: translate(-70%, -50%);
        opacity: 0;
    }
    15% {
        opacity: 1;
    }
    50% {
        transform: translate(10%, -50%);
        opacity: 1;
    }
    85% {
        opacity: 0;
    }
    100% {
        transform: translate(-70%, -50%);
        opacity: 0;
    }
}
.zone-content-wrapper {
    display: flex;
    flex-direction: column;
    width: 100%;
    background: #6e46cf;
    border-radius: 20px;
    color: white;
    --tw-shadow: 0px 2px 10px #0003;
    --tw-shadow-colored: 0px 2px 10px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
    @media (max-width: 768px) {
        gap: 20px;
    }
    @media (max-width: 480px) {
        gap: 15px;
    }
}
.zone-question {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 20px;
    align-items: center;
    width: 100%;
    background: transparent;
    padding: 20px;
    position: relative;
    .zone-arrow {
    position: absolute;
  }
    .zone-arrow {
    top: -1.25rem;
  }
    .zone-arrow {
    right: 29%;
  }
    .zone-arrow {
    z-index: 50;
  }
    .zone-arrow {
        width: 0;
        height: 0;
        border-left: 15px solid transparent;
        border-right: 15px solid transparent;
        border-bottom: 36px solid #6e46cf;
    }
    h2 {
        grid-column: span 4;
        font-size: 20px;
        color: #ffe041;
        line-height: 1.4;
        margin: 0;
        text-align: left;
        transition: grid-column 0.3s ease;
        @media (max-width: 768px) {
            font-size: 24px;
        }
        @media (max-width: 480px) {
            font-size: 20px;
            grid-column: span 5;
        }
    }
}
.zone-tip {
    display: flex;
    align-items: flex-start;
    gap: 40px;
    width: 100%;
    .tip-icon {
        width: 40px;
        flex-shrink: 0;
    }
    .tip-text {
    --tw-text-opacity: 1;
    color: rgb(110 70 207 / var(--tw-text-opacity));
  }
    .tip-text {
        font-family: 'RobotoSlab',sans-serif;
        margin: 0;
    }
}
.zone-user-answer-line {
    position: absolute;
    top: 0;
    height: 100%;
    width: 1px;
    background: transparent;
    border-left: 1px dashed rgba(111, 40, 234, 0.5);
    pointer-events: none;
    z-index: 10;
    margin-left: -1.5px;
    transition: left 0.3s ease;
    @media (max-width: 768px) {
        width: 2px;
        border-left-width: 2px;
        margin-left: -1px;
    }
    @media (max-width: 480px) {
        width: 2px;
        border-left-width: 2px;
        margin-left: -1px;
    }
}
.swipe-card-section {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
.swipe-card-container {
  position: relative;
  height: 450px;
  width: 100%;
  max-width: 320px;
  font-family: 'RobotoSlab', sans-serif;
}
.swipe-card-stack {
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 15px;
  z-index: 5;
  border-radius: 12px;
  --tw-shadow: 0px 2px 10px #0003;
  --tw-shadow-colored: 0px 2px 10px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  width: 100%;
  height: 450px;
  opacity: 1;
  transition: opacity 0.2s ease;
}
.swipe-card-behind {
  position: absolute;
  left: 50%;
  --tw-translate-x: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  width: 100%;
  height: 100%;
  background: #C5B5EC;
  border-radius: 12px;
  transition: all 0.2s ease;
}
.swipe-card-behind-second {
  top: 0 !important;
  opacity: 0.8;
}
.swipe-card-behind-third {
  top: 0 !important;
  opacity: 0;
  width: 100%;
}
.swipe-card {
  position: absolute;
  height: 450px;
  width: 100%;
  cursor: grab;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  border-radius: 12px;
  padding: 20px;
  --tw-shadow: 0px 2px 10px #0003;
  --tw-shadow-colored: 0px 2px 10px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  background: #6e46cf;
  transition: transform 0.3s ease, opacity 0.3s ease;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  z-index: 10;
}
.swipe-card.grabbing {
  cursor: grabbing;
}
.swipe-card.hide {
  pointer-events: none;
  opacity: 0;
}
.swipe-card-content {
  display: flex;
  flex: 1 1 0%;
  flex-direction: column;
  justify-content: flex-start;
}
.swipe-card-text {
  margin-bottom: 30px;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.3;
  --tw-text-opacity: 1;
  color: rgb(255 224 65 / var(--tw-text-opacity));
}
.swipe-card-question {
  font-size: 24px;
  font-weight: 600;
  --tw-text-opacity: 1;
  color: rgb(255 224 65 / var(--tw-text-opacity));
}
.swipe-card-buttons {
  position: relative;
  width: 100%;
  min-height: 60px;
  padding-top: 20px;
}
.swipe-btn {
  position: absolute;
  bottom: 0px;
  cursor: pointer;
  border-width: 0px;
  background-color: transparent;
  font-size: 30px;
  font-weight: 700;
  --tw-text-opacity: 1;
  color: rgb(231 230 246 / var(--tw-text-opacity));
  transition: transform 0.2s;
  padding: 0;
}
.swipe-btn-left {
  left: 0px;
}
.swipe-btn-right {
  right: 0px;
}
.swipe-btn:hover {
  --tw-scale-x: 1.1;
  --tw-scale-y: 1.1;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.swipe-btn:active {
  --tw-scale-x: .95;
  --tw-scale-y: .95;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.swipe-hand-icon {
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  transform: translate(-50%, -50%);
  animation: swipe-hand-slide 2.4s ease-in-out infinite;
}
.swipe-hand-icon img {
  height: 62px;
  width: 50px;
}
.swipe-hand-icon.hidden {
  display: none;
}
.swipe-card.grabbing .swipe-hand-icon,
.swipe-card.hide .swipe-hand-icon {
  display: none;
}
@keyframes swipe-hand-slide {
  0% {
    transform: translate(-50%, -50%);
  }
  25% {
    transform: translate(-70%, -50%);
  }
  50% {
    transform: translate(-50%, -50%);
  }
  75% {
    transform: translate(-30%, -50%);
  }
  100% {
    transform: translate(-50%, -50%);
  }
}
.swipe-result-card {
  position: absolute;
  top: 0;
  left: 15px;
  display: flex;
  height: 450px;
  width: 100%;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  padding-top: 40px;
  padding-bottom: 40px;
  padding-left: 20px;
  padding-right: 20px;
  text-align: center;
  z-index: 3;
  opacity: 0;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.swipe-result-correct {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}
.swipe-result-incorrect {
  background: #c5b5ec; /* Màu tím cho Ja (phải) */
}
.swipe-result-final {
  display: none;
  z-index: 15;
  opacity: 1;
  transform: scale(1);
}
.swipe-result-final.show {
  display: flex;
}
.swipe-result-icon {
  margin-bottom: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.swipe-result-icon svg {
  width: 120px;
  height: 120px;
  color: #6e46cf;
}
.swipe-result-title {
  margin-bottom: 20px;
  font-size: 50px;
  font-weight: 700;
  color: #6e46cf;
}
.swipe-result-text {
  text-align: left;
  font-size: 20px;
  line-height: 1.5;
  color: #6e46cf;
}
.swipe-btn-restart {
  margin-top: 30px;
  min-height: 57px;
  cursor: pointer;
  border-radius: 50px;
  border-width: 0px;
  --tw-bg-opacity: 1;
  background-color: rgb(110 70 207 / var(--tw-bg-opacity));
  padding-left: 40px;
  padding-right: 40px;
  padding-top: 15px;
  padding-bottom: 15px;
  font-size: 18px;
  font-weight: 600;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
  background: #6e46cf;
  transition: background 0.3s;
}
.swipe-btn-restart:hover {
  background: #6D28D9;
}
.swipe-card-style1 {
  margin-top: 60px;
  .swipe-result-card {
    align-items: flex-start;
  }
  .swipe-result-card {
    text-align: left;
  }
  .swipe-result-card {
    font-size: 2rem;
  }
  .swipe-result-card {
    --tw-text-opacity: 1;
    color: rgb(110 70 207 / var(--tw-text-opacity));
  }
  .swipe-result-card {
    .number {
      padding-bottom: 5px;
    }
    .number {
      font-size: 5rem;
    }
    .number {
      line-height: 1;
    }
    .swipe-result-text {
      font-size: 1.6rem;
    }
    &.swipe-result-correct {
      --tw-bg-opacity: 1;
      background-color: rgb(255 224 65 / var(--tw-bg-opacity));
    }
    &.swipe-result-correct { /* Màu vàng cho Nee (trái) */
    }
    &.swipe-result-incorrect {
      background: #A78BFA; /* Màu tím cho Ja (phải) */
    }
  }
}
.section_satisfaction {
    overflow: visible;
}
.satisfied-section-wrapper {
    background: #FFE041;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: visible;
    margin-top: 150px;
}
.satisfied-container {
    position: relative;
    width: 100% !important;
    max-width: 100% !important;
    height: 400px;
    overflow: visible;
    @media (max-width: 768px) {
        height: 350px;
    }
    @media (max-width: 480px) {
        height: 250px;
    }
}
/* M�t */
.eye {
    position: absolute;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    z-index: 10;
    @media (max-width: 768px) {
        width: 32px;
        height: 32px;
    }
    @media (max-width: 480px) {
        width: 24px;
        height: 24px;
    }
}
.eye.top-left {
    left: 22%;
    top: 40%;
    background: white;
    @media (max-width: 768px) {
        left: 23%;
        top: 38.5%;
    }
    @media (max-width: 480px) {
        left: 23%;
        top: 34%;
    }
}
.eye.top-right {
    left: 37%;
    top: 40%;
    background: white;
    @media (max-width: 768px) {
        left: 38%;
        top: 38.5%;
    }
    @media (max-width: 480px) {
        left: 38%;
        top: 34%;
    }
}
.eye.bottom-left {
    left: 60%;
    top: -8%;
    background: #6e46cf;
    @media (max-width: 768px) {
        left: 56%;
        top: 2.8%;
    }
    @media (max-width: 480px) {
        left: 56.5%;
        top: 3.2%;
    }
}
.eye.bottom-right {
    left: 75%;
    top: -8%;
    background: #6e46cf;
    @media (max-width: 768px) {
        left: 71%;
        top: 2.8%;
    }
    @media (max-width: 480px) {
        left: 71.5%;
        top: 3.2%;
    }
}
/* SVG Container */
.progress-container {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    overflow: visible;
}
svg {
    width: 100%;
    height: 100%;
    filter: drop-shadow(0 8px 24px rgba(0, 0, 0, 0.08));
    @media (max-width: 480px) {
        filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.06));
    }
}
/* Progress paths */
.progress-bg {
    fill: none;
    stroke: #6e46cf;
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-dasharray: 3 3;
}
.progress-fill {
    fill: none;
    stroke-width: 60;
    stroke-linecap: round;
    transition: stroke-dashoffset 0.5s ease;
    @media (max-width: 768px) {
        stroke-width: 50;
    }
    @media (max-width: 480px) {
        stroke-width: 40;
    }
}
.progress-happy {
    stroke: white;
}
.progress-sad {
    stroke: #6e46cf;
}
.progress-user-answer {
    stroke: #d1d5db;
    opacity: 0.8;
}
.hidden-path {
    display: none;
}
/* Control icons */
.control-icon {
    position: absolute;
    width: 35px;
    height: 35px;
    background: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: grab;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    z-index: 20;
    transition: transform 0.2s;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
    @media (max-width: 768px) {
        width: 28px;
        height: 28px;
    }
    @media (max-width: 480px) {
        width: 18px;
        height: 18px;
    }
}
.control-icon:active {
    cursor: grabbing;
}
.control-icon:hover {
    transform: scale(1.1);
}
.control-icon svg {
    width: 20px;
    height: 20px;
    @media (max-width: 768px) {
        width: 16px;
        height: 16px;
    }
    @media (max-width: 480px) {
        width: 14px;
        height: 14px;
    }
}
.icon-happy {
    top: 42.5%;
    right: 10.8%;
    @media (max-width: 768px) {
        top: 41.4%;
        right: 11%;
    }
    @media (max-width: 480px) {
        top: 38%;
        right: 11.6%;
    }
}
.icon-sad {
    top: 42.5%;
    left: 10.8%;
    @media (max-width: 768px) {
        top: 41.4%;
        left: 11%;
    }
    @media (max-width: 480px) {
        top: 38%;
        left: 11.6%;
    }
}
/* Percentage labels */
.percentage {
    position: absolute;
    font-size: 32px;
    font-weight: bold;
    color: #6e46cf;
    z-index: 15;
    font-family: 'RobotoSlab',sans-serif;
    @media (max-width: 768px) {
        font-size: 28px;
    }
    @media (max-width: 480px) {
        font-size: 20px;
    }
}
.percentage-happy {
    top: 92%;
    left: 25%;
    @media (max-width: 768px) {
        top: 70%;
    }
    @media (max-width: 480px) {
        top: 64%;
    }
}
.percentage-sad {
    top: 16%;
    right: 20%;
    @media (max-width: 768px) {
        top: 22.8%;
    }
    @media (max-width: 480px) {
        top: 22%;
    }
}
/* Answer button and tip */
.satisfied-answer-wrapper {
    margin-top: 40px;
    text-align: center;
    z-index: 25;
}
.satisfied-answer-button {
    cursor: pointer;
    margin: 0 auto;
}
.satisfied-tip {
    display: flex;
    align-items: flex-start;
    gap: 40px;
    width: 100%;
    margin-top: 60px;
    .tip-icon {
        width: 40px;
        flex-shrink: 0;
    }
    .tip-text {
        font-family: 'RobotoSlab',sans-serif;
        color: #6e46cf;
        line-height: 1.6;
    }
}
.hidden-tip {
    display: none;
}
/* Floating Button Styles */
.floating-button {
  position: fixed !important;
  right: 20px !important;
  bottom: 50px !important;
  border-radius: 12px;
  background: #6e46cf;
  color: #FFE041;
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease !important;
  z-index: 9999 !important;
  opacity: 1 !important;
  visibility: visible !important;
  font-family: 'RobotoSlab',sans-serif;
  padding: 10px 20px;
  &:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2) !important;
  }
  &:active {
    transform: translateY(0) !important;
  }
  &.hidden {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
}
@media (max-width: 767px) {
  .floating-button {
    display: none;
  }
}
.hero-banner {
  /* Use actual image aspect ratio: 1298x818 */
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  /* Maintain aspect ratio based on actual image dimensions */
  &::before {
    content: '';
    display: block;
    padding-top: 63.02%; /* 818/1298 * 100 = 63.02% */
  }
  @media (max-width: 1000px) {
    max-width: 100%;
  }
}
.hero-animation-container {
  will-change: opacity;
  transform: translate(7px,-2px);
  @media (max-width: 1000px) {
    transform: translate(2px,-1px);
  }
  &.loaded {
    opacity: 1 !important;
    .hero-animation-loader {
      display: none;
    }
  }
}
.hero-animation-canvas {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
}
.hero-animation-loader {
  transition: opacity 0.3s ease;
  z-index: 10;
}
.hero-animation-progress {
  transition: width 0.3s ease;
}
/* Grid overlay styles */
.hero-grid-wrapper {
  opacity: 0;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  transition: opacity 0.5s ease;
}
/* Vertical lines - Xanh lá */
.hero-grid-vertical {
  width: 100%;
  height: 100%;
}
.hero-grid-lines-vertical {
  position: relative;
  width: 100%;
  height: 100%;
  span {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 1px;
    height: 100%;
    border-left: 1px dashed #6e46cf;
    opacity: .5
  }
}
/* Horizontal lines - Đỏ */
.hero-grid-horizontal {
  width: 100%;
  height: 100%;
}
.hero-grid-lines-horizontal {
  position: relative;
  width: 100%;
  height: 100%;
  span {
    position: absolute;
    left: 50%;
    width: 100vw;
    margin-left: -50vw;
    height: 1px;
    border-top: 1px dashed #6e46cf;
  }
  .text {
    position: absolute;
    top: -35px
  }
  .text {
    font-size: 28px;
  }
  .text {
    --tw-text-opacity: 1;
    color: rgb(110 70 207 / var(--tw-text-opacity));
  }
  .text {
    font-family: 'RobotoSlab',sans-serif;
    width: 1000px;
    left: 50%;
    transform: translateX(-50%);
    opacity: 0;
    transition: opacity 0.5s ease;
    @media screen and (max-width: 1000px) {
      width: 100%;
      font-size: 23px;
      top: -28px;
    }
    @media screen and (max-width: 768px) {
      font-size: 20px;
      top: -25px;
    }
    @media screen and (max-width: 700px) {
      font-size: 14px;
      top: -17px;
    }
    @media screen and (max-width: 500px) {
      font-size: 12px;
      top: -15px;
    }
    p {
      left: 17.5%;
      position: absolute;
      top: 0;
    }
  }
  .line {
    border: none;
    margin-top: -0.005dvh;
    @media screen and (max-width: 1000px) {
      margin-top: 0;
    }
    .line-left,
    .line-right {
      height: 3px;
      width: 1000px;
      left: 50%;
      background: #6e46cf;
      position: absolute;
      margin-left: -1490px;
      border: none;
      opacity: .8;
      @media screen and (max-width: 1000px) {
        margin-left: -1404px;
      }
      @media screen and (max-width: 600px) {
        margin-left: -687px;
        height: 1px;
      }
    }
    .line-right {
      margin-left: 492px;
      @media screen and (max-width: 1000px) {
        margin-left: 472px;
      }
      @media screen and (max-width: 600px) {
        margin-left: 190px;
        height: 1px;
      }
    }
  }
}
.hero-banner.loaded {
  .text {
    opacity: 1;
  }
  .hero-grid-wrapper {
    opacity: 1;
  }
}
html,
body {
  width: 100%;
  overflow-x: hidden
}
@media (max-width: 1024px) {
  .container {
    width: 100%;
    padding-left: 2.5rem;
    padding-right: 2.5rem;
  }
  .site_copy > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1.25rem * var(--tw-space-y-reverse));
  }
  .site_copy {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .map-question,
  .card_switcher {
    margin-left: 0px;
    margin-right: 0px;
  }
}
@media (max-width: 768px) {
  h5 {
    font-size: 25px;
  }
  .card_switcher li {
    .percentages span {
      font-size: 40px;
    }
    .bar-chart-wrapper {
      height: 175px;
    }
  }
  .circle-section-wrapper {
    margin-top: -50px;
  }
  .zone-tip {
    .tip-text {}
  }
}
@media (max-width: 767px) {
  section {
    width: 100%;
  }
  body {
    font-size: 16px;
  }
  h3 {
    font-size: 35px;
  }
  h4 {
    font-size: 25px;
  }
  .container {
    padding: 0 15px;
  }
  .welcome_copy {
    padding: 50px 0;
  }
  .welcome_copy > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(30px * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(30px * var(--tw-space-y-reverse));
  }
  .welcome_copy {
    & ul {
      gap: 5px;
      & li {
        width: 33.33%;
        padding: 0 0 20px 0;
        border-radius: 12px;
        p {
          height: 20vw;
          padding: 20px 6vw 0 6vw;
          margin-bottom: 10px;
        }
        h6 {
          font-size: 1rem;
          padding: 0 10px;
        }
      }
    }
  }
  .btn_download {
    span {
      font-size: 25px;
    }
  }
  .healthcare-content {
    padding: 0 10px;
  }
  .healthcare-content > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(10px * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(10px * var(--tw-space-y-reverse));
  }
  .healthcare-label-nederland h4,
  .healthcare-label h4 {
    font-size: 14px;
  }
  .healthcare-label,
  .healthcare-label-nederland {
    min-width: 70px;
  }
  .healthcare-track,
  .healthcare-track-nederland {
    height: 100px;
  }
  .healthcare-grid-lines span {
    height: calc(100% - 113px);
  }
  .healthcare-play-icon {
    padding: 5px;
  }
  .healthcare {
    padding-bottom: 50px;
  }
  .section_belief_check {
    overflow: hidden;
  }
  .section_switcher {
    padding-top: 50px;
    overflow: hidden;
    .copy > :not([hidden]) ~ :not([hidden]) {
      --tw-space-y-reverse: 0;
      margin-top: calc(30px * calc(1 - var(--tw-space-y-reverse)));
      margin-bottom: calc(30px * var(--tw-space-y-reverse));
    }
  }
  .card_switcher {
    gap: 10px;
    margin-left: -5px;
    margin-right: -5px;
  }
  .card_switcher li {
    margin: 0px;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    .percentages {
      margin-bottom: 30px;
    }
    .percentages span {
      font-size: 30px;
    }
  }
  .card_switcher {
    & li {
      h5 {
        font-size: 16px;
        padding-top: 10px;
      }
    }
    & li {
      padding-top: 1.25rem;
      padding-bottom: 1.25rem;
    }
    & li {
      .bar-chart-wrapper {
        height: 125px;
      }
      & .labels {
        & div {
          p {
            font-size: 10px;
          }
        }
      }
    }
  }
  .section_switcher {
    .copy_with_img {
      padding: 10px 0 50px 0;
      gap: 20px;
    }
    .interactive {
      padding-top: 50px;
      padding-bottom: 50px;
    }
  }
  .swipe-card-style1 {
    margin-top: 50px;
  }
  .interactive_wrap {}
  .interactive-quiz {
    & li {
      & .answer-text {
        padding: 20px 15px;
        p {
          font-size: 16px;
        }
      }
    }
    & li {
      .quiz-percentage-wrapper {
        .quiz-percentage {
          padding-right: 0;
        }
      }
      .quiz-percentage {
        font-size: 25px;
        min-width: unset;
      }
    }
  }
  .quiz-tooltip {
    top: 210%;
    right: 5px;
    .quiz-tooltip-content img {
      width: 15px;
    }
  }
  .quiz-tooltip-text {
    font-size: 14px;
  }
  .quiz-explanation {
    gap: 20px;
    margin-top: 50px;
  }
  .quiz-explanation-content {}
  .zones-wrapper {
    height: 250px;
  }
  .zone-question {
    padding: 10px 20px 20px 20px;
  }
  .healthcare-footer {
    gap: 0;
    padding-bottom: 20px;
  }
  .healthcare-footer h2 {
    font-size: 22px;
  }
  .healthcare-question,
  .healthcare-value-nederland {
    font-size: 25px;
  }
  .healthcare-pointer img {
    width: 30px;
    height: 30px;
  }
  .btn_purple,
  .btn_yellow {
    padding: 6px 30px;
    border-radius: 12px;
    font-size: 14px;
  }
  .zone-container {
    gap: 50px;
  }
  .map-question__card,
  .vertical-container,
  .interactive-quiz,
  .zone-content-wrapper {
    border-radius: 12px;
  }
  .zone-question {
    gap: 10px;
    h2 {
      grid-column: span 4;
      font-size: 16px;
    }
  }
  .zone-tip {
    margin: 0;
    padding: 0;
    gap: 20px;
  }
  .circle-section-wrapper {
    .circle-container {
      padding: 0;
    }
  }
  .progress-content {
    width: 190px;
  }
  .healthcare-op2 {
    margin-top: 40px;
    padding-bottom: 20px;
  }
  .healthcare-op3 {
    margin-top: 0;
    padding-bottom: 0;
  }
  .healthcare-bars {
    margin-bottom: 10px;
  }
  .healthcare-op3,
  .healthcare-op2 {
    .healthcare-footer h2 {
      font-size: 16px;
      padding-right: 10px;
    }
  }
  .satisfied-section-wrapper {
    margin-top: 60px;
  }
  .satisfied-tip {
    margin-top: -20px;
  }
  .map-question {
    padding: 0;
  }
  .section_complexity {
    margin-top: -50px;
  }
  .vertical-section-wrapper {
    margin-top: 40px;
  }
  .vertical-bar-item {
    transform: translateY(-1px);
  }
  .vertical-container {
    padding: 15px;
  }
  .vertical-question {
    gap: 10px;
  }
  .vertical-question h2 {
    font-size: 18px;
  }
  .map-question__stat-value {
    padding-top: 20px;
  }
  .map-question__stat {
    top: 72%;
    left: 72%;
  }
  .map-question__card--least .map-question__stat {
    top: 65%;
    left: 36%;
  }
  .map-question__stat {
    filter: drop-shadow(0);
  }
  .map-question__card--least .map-question__stat .map-question__stat-content  {
    transform: scale(.6) translate3d(-10px, 20px, -50px);
  }
  .map-question__stat-content {
    transform: scale(.6) translate3d(-30px, -80px, -50px);
  }
  .map-question__label.is-correct,
  .map-question__label {
    text-shadow: none;
  }
  .cta_download {
    padding: 10px 20px;
    font-size: 14px;
  }
  .card_switcher {
    & li {
        .grid-lines {
            margin-left: -0.5rem;
            margin-right: -0.5rem;
        }
    }
  }
}
@media (min-width: 768px) {

  .md\:mb-24 {
    margin-bottom: 6rem;
  }

  .md\:mb-6 {
    margin-bottom: 1.5rem;
  }

  .md\:mt-6 {
    margin-top: 1.5rem;
  }

  .md\:text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
  }

  .md\:text-6xl {
    font-size: 3.75rem;
    line-height: 1;
  }

  .md\:text-\[25px\] {
    font-size: 25px;
  }
}
@media (min-width: 1024px) {

  .lg\:mb-60 {
    margin-bottom: 15rem;
  }

  .lg\:mb-8 {
    margin-bottom: 2rem;
  }

  .lg\:mt-8 {
    margin-top: 2rem;
  }

  .lg\:text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
  }

  .lg\:text-7xl {
    font-size: 4.5rem;
    line-height: 1;
  }
}
@media (min-width: 1280px) {

  .xl\:text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }

  .xl\:text-8xl {
    font-size: 6rem;
    line-height: 1;
  }
}
@media (max-width: 767px) {

  ._mb\:\!mt-\[50px\] {
    margin-top: 50px !important;
  }

  ._mb\:\!pb-\[40px\] {
    padding-bottom: 40px !important;
  }

  ._mb\:pb-\[20px\] {
    padding-bottom: 20px;
  }

  ._mb\:pb-\[50px\] {
    padding-bottom: 50px;
  }
}
