@charset 'UTF-8';
/* Slick Carousel CSS */
/* Slider */
.slick-slider
{
    position: relative;

    display: block;
    box-sizing: border-box;

    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;

    -webkit-touch-callout: none;
    -khtml-user-select: none;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}
.slick-list
{
    position: relative;

    display: block;
    overflow: hidden;

    margin: 0;
    padding: 0;
}
.slick-list:focus
{
    outline: none;
}
.slick-list.dragging
{
    cursor: pointer;
    cursor: hand;
}
.slick-slider .slick-track,
.slick-slider .slick-list
{
    transform: translate3d(0, 0, 0);
}
.slick-track
{
    position: relative;
    top: 0;
    left: 0;

    display: block;
    margin-left: auto;
    margin-right: auto;
}
.slick-track:before,
.slick-track:after
{
    display: table;

    content: '';
}
.slick-track:after
{
    clear: both;
}
.slick-loading .slick-track
{
    visibility: hidden;
}
.slick-slide
{
    display: none;
    float: left;

    height: 100%;
    min-height: 1px;
}
[dir='rtl'] .slick-slide
{
    float: right;
}
.slick-slide img
{
    display: block;
}
.slick-slide.slick-loading img
{
    display: none;
}
.slick-slide.dragging img
{
    pointer-events: none;
}
.slick-initialized .slick-slide
{
    display: block;
}
.slick-loading .slick-slide
{
    visibility: hidden;
}
.slick-vertical .slick-slide
{
    display: block;

    height: auto;

    border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
    display: none;
}
/* Slider */
.slick-loading .slick-list
{
    background: #fff url('/assets/ajax-loader-BcnMEykj.gif') center center no-repeat;
}
/* Icons */
@font-face
{
    font-family: 'slick';
    font-weight: normal;
    font-style: normal;

    src: url('data:application/vnd.ms-fontobject;base64,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');
    src: url('data:application/vnd.ms-fontobject;base64,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') format('embedded-opentype'), url('data:font/woff;base64,d09GRk9UVE8AAAVkAAsAAAAAB1wAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABDRkYgAAABCAAAAi4AAAKbH/pWDkZGVE0AAAM4AAAAGgAAABxt0civR0RFRgAAA1QAAAAcAAAAIAAyAARPUy8yAAADcAAAAFIAAABgUBj/rmNtYXAAAAPEAAAAUAAAAWIiC0SwaGVhZAAABBQAAAAuAAAANgABMftoaGVhAAAERAAAABwAAAAkA+UCA2htdHgAAARgAAAADgAAAA4ESgBKbWF4cAAABHAAAAAGAAAABgAFUABuYW1lAAAEeAAAANwAAAFuBSeBwnBvc3QAAAVUAAAAEAAAACAAAwABeJw9ks9vEkEUx2cpWyeUoFYgNkHi2Wt7N3rVm3cTs3UVLC4LxIWEQvi1P3i7O1tYLJDAmlgKGEhQrsajf0j7J3jYTXrQWUrMJG+++b55n5e8NwwKBhHDMLv5kxT3ATEBxKBn3qOAl9zxHgb1MAPhHQgHkyF08Gr/L8B/Eb6zWnmCJ7AJVLubQOheArXvJ1A4EXi6j4I+Zg9F0QFKvsnlBCmXeve+sFEnb/nCptdtQ4QYhVFRAT1HrF8UQK/RL/SbmUbclsvGVFXRZKDHUE38cc4qpkbAAsuwiImvro+ufcfaOIQ6szlrmjRJDaKZKnbjN3GWKIbiIzRFUfCffuxxKOL+3LDlDVvx2TdxN84qZEsnhNBa6pgm2dAsnzbLsETdsmRFxUeHV4e+I2/ptN8TyqV8T3Dt29t7EYOuajVIw2y1Wy3M86w0zg/Fz2IvawmQAUHOVrPVfLkoScVynsqsTG0MGUs4z55nh3mnOJa+li+rl9WpPIcFfDubDeaDC+fLBdYN3QADzLauGfj4B6sZmq6CCpqmtSvF0qlUl2qf5AJIUCSlTqlb7lUG+LRfGzZGzZEyBgccMu6MuqPecNDvD4Y9Kjtj4gD+DsvKVMTcMdtqtZtmkzQstQvYje7Syep0PDSAhSOeHYXYWThEF//A/0YvYV1fSQtpKU5STtrhbQ444OtpKSWJIg3pOg8cBs7maTY1EZf07aq+hjWs7IWzdCYTGhb2CtZ47x+Uhx28AAB4nGNgYGBkAIJz765vANHnCyvqYTQAWnkHswAAeJxjYGRgYOADYgkGEGBiYARCFjAG8RgABHYAN3icY2BmYmCcwMDKwMHow5jGwMDgDqW/MkgytDAwMDGwcjKAQQMDAyOQUmCAgoA01xQGB4ZExUmMD/4/YNBjvP3/NgNEDQPjbbBKBQZGADfLDgsAAHicY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQzMCQqKClOUJz0/z9YHRLv/+L7D+8V3cuHmgAHjGwM6ELUByxUMIOZCmbgAAA5LQ8XeJxjYGRgYABiO68w73h+m68M3EwMIHC+sKIeTqsyqDLeZrwN5HIwgKUB/aYJUgAAeJxjYGRgYLzNwMCgx8QAAkA2IwMqYAIAMGIB7QIAAAACAAAlACUAJQAlAAAAAFAAAAUAAHicbY49asNAEIU/2ZJDfkiRIvXapUFCEqpcptABUrg3ZhEiQoKVfY9UqVLlGDlADpAT5e16IUWysMz3hjfzBrjjjQT/EjKpCy+4YhN5yZoxcirPe+SMWz4jr6S+5UzSa3VuwpTnBfc8RF7yxDZyKs9r5IxHPiKv1P9iZqDnyAvMQ39UecbScVb/gJO03Xk4CFom3XYK1clhMdQUlKo7/d9NF13RkIdfy+MV7TSe2sl11tRFaXYmJKpWTd7kdVnJ8veevZKc+n3I93t9Jnvr5n4aTVWU/0z9AI2qMkV4nGNgZkAGjAxoAAAAjgAF') format('woff'), url('data:font/ttf;base64,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') format('truetype'), url('/assets/slick-BlzDm7g2.svg#slick') format('svg');
}
/* Arrows */
.slick-prev,
.slick-next
{
    font-size: 0;
    line-height: 0;

    position: absolute;
    top: 50%;

    display: block;

    width: 20px;
    height: 20px;
    padding: 0;
    transform: translate(0, -50%);

    cursor: pointer;

    color: transparent;
    border: none;
    outline: none;
    background: transparent;
}
.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus
{
    color: transparent;
    outline: none;
    background: transparent;
}
.slick-prev:hover:before,
.slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before
{
    opacity: 1;
}
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before
{
    opacity: .25;
}
.slick-prev:before,
.slick-next:before
{
    font-family: 'slick';
    font-size: 20px;
    line-height: 1;

    opacity: .75;
    color: white;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.slick-prev
{
    left: -25px;
}
[dir='rtl'] .slick-prev
{
    right: -25px;
    left: auto;
}
.slick-prev:before
{
    content: '←';
}
[dir='rtl'] .slick-prev:before
{
    content: '→';
}
.slick-next
{
    right: -25px;
}
[dir='rtl'] .slick-next
{
    right: auto;
    left: -25px;
}
.slick-next:before
{
    content: '→';
}
[dir='rtl'] .slick-next:before
{
    content: '←';
}
/* Dots */
.slick-dotted.slick-slider
{
    margin-bottom: 30px;
}
.slick-dots
{
    position: absolute;
    bottom: -25px;

    display: block;

    width: 100%;
    padding: 0;
    margin: 0;

    list-style: none;

    text-align: center;
}
.slick-dots li
{
    position: relative;

    display: inline-block;

    width: 20px;
    height: 20px;
    margin: 0 5px;
    padding: 0;

    cursor: pointer;
}
.slick-dots li button
{
    font-size: 0;
    line-height: 0;

    display: block;

    width: 20px;
    height: 20px;
    padding: 5px;

    cursor: pointer;

    color: transparent;
    border: 0;
    outline: none;
    background: transparent;
}
.slick-dots li button:hover,
.slick-dots li button:focus
{
    outline: none;
}
.slick-dots li button:hover:before,
.slick-dots li button:focus:before
{
    opacity: 1;
}
.slick-dots li button:before
{
    font-family: 'slick';
    font-size: 6px;
    line-height: 20px;

    position: absolute;
    top: 0;
    left: 0;

    width: 20px;
    height: 20px;

    content: '•';
    text-align: center;

    opacity: .25;
    color: black;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before
{
    opacity: .75;
    color: black;
}
*, ::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.17 | 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: #e5e7eb; /* 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;
}
.tw-container{
    width: 100%;
}
@media (min-width: 640px){
    .tw-container{
        max-width: 640px;
    }
}
@media (min-width: 768px){
    .tw-container{
        max-width: 768px;
    }
}
@media (min-width: 1024px){
    .tw-container{
        max-width: 1024px;
    }
}
@media (min-width: 1280px){
    .tw-container{
        max-width: 1280px;
    }
}
@media (min-width: 1536px){
    .tw-container{
        max-width: 1536px;
    }
}
.tw-pointer-events-none{
    pointer-events: none;
}
.tw-pointer-events-auto{
    pointer-events: auto;
}
.tw-invisible{
    visibility: hidden;
}
.tw-fixed{
    position: fixed;
}
.tw-absolute{
    position: absolute;
}
.tw-relative{
    position: relative;
}
.tw-sticky{
    position: sticky;
}
.tw-inset-0{
    inset: 0px;
}
.tw-inset-x-2{
    left: 0.5rem;
    right: 0.5rem;
}
.tw-bottom-0{
    bottom: 0px;
}
.tw-bottom-16{
    bottom: 4rem;
}
.tw-bottom-2{
    bottom: 0.5rem;
}
.tw-bottom-3{
    bottom: 0.75rem;
}
.tw-bottom-4{
    bottom: 1rem;
}
.tw-bottom-5{
    bottom: 1.25rem;
}
.tw-bottom-8{
    bottom: 2rem;
}
.tw-bottom-\[4\.75rem\]{
    bottom: 4.75rem;
}
.tw-bottom-full{
    bottom: 100%;
}
.tw-left-0{
    left: 0px;
}
.tw-left-1{
    left: 0.25rem;
}
.tw-left-1\.5{
    left: 0.375rem;
}
.tw-left-1\/2{
    left: 50%;
}
.tw-left-2{
    left: 0.5rem;
}
.tw-left-3{
    left: 0.75rem;
}
.tw-left-5{
    left: 1.25rem;
}
.tw-left-\[148px\]{
    left: 148px;
}
.tw-left-\[32\%\]{
    left: 32%;
}
.tw-left-\[4\.17px\]{
    left: 4.17px;
}
.tw-left-\[43\.5\%\]{
    left: 43.5%;
}
.tw-left-\[50\%\]{
    left: 50%;
}
.tw-left-\[7\.8\%\]{
    left: 7.8%;
}
.tw-left-\[80\%\]{
    left: 80%;
}
.tw-left-\[calc\(100\%\+1rem\)\]{
    left: calc(100% + 1rem);
}
.tw-right-0{
    right: 0px;
}
.tw-right-1{
    right: 0.25rem;
}
.tw-right-1\.5{
    right: 0.375rem;
}
.tw-right-2{
    right: 0.5rem;
}
.tw-right-3{
    right: 0.75rem;
}
.tw-right-4{
    right: 1rem;
}
.tw-right-5{
    right: 1.25rem;
}
.tw-top-0{
    top: 0px;
}
.tw-top-1\/2{
    top: 50%;
}
.tw-top-2{
    top: 0.5rem;
}
.tw-top-4{
    top: 1rem;
}
.tw-top-5{
    top: 1.25rem;
}
.tw-top-6{
    top: 1.5rem;
}
.tw-top-8{
    top: 2rem;
}
.tw-top-\[20\%\]{
    top: 20%;
}
.tw-top-\[28\%\]{
    top: 28%;
}
.tw-top-\[34px\]{
    top: 34px;
}
.tw-top-\[4\.17px\]{
    top: 4.17px;
}
.tw-top-\[42\%\]{
    top: 42%;
}
.tw-top-\[50\%\]{
    top: 50%;
}
.tw-top-\[59\%\]{
    top: 59%;
}
.tw-top-\[60\%\]{
    top: 60%;
}
.tw-top-\[70\%\]{
    top: 70%;
}
.tw-top-\[782px\]{
    top: 782px;
}
.tw-top-\[84\%\]{
    top: 84%;
}
.tw-top-full{
    top: 100%;
}
.tw-isolate{
    isolation: isolate;
}
.tw-z-0{
    z-index: 0;
}
.tw-z-10{
    z-index: 10;
}
.tw-z-20{
    z-index: 20;
}
.tw-z-30{
    z-index: 30;
}
.tw-z-40{
    z-index: 40;
}
.tw-z-50{
    z-index: 50;
}
.tw-z-\[10000\]{
    z-index: 10000;
}
.tw-z-\[1100\]{
    z-index: 1100;
}
.tw-z-\[1200\]{
    z-index: 1200;
}
.tw-z-\[1300\]{
    z-index: 1300;
}
.tw-z-\[1\]{
    z-index: 1;
}
.tw-z-\[2147483647\]{
    z-index: 2147483647;
}
.tw-z-\[2\]{
    z-index: 2;
}
.tw-z-\[60\]{
    z-index: 60;
}
.tw-z-\[80\]{
    z-index: 80;
}
.tw-order-1{
    order: 1;
}
.tw-order-2{
    order: 2;
}
.tw-order-3{
    order: 3;
}
.tw-order-4{
    order: 4;
}
.tw-order-5{
    order: 5;
}
.tw-col-span-1{
    grid-column: span 1 / span 1;
}
.tw-col-span-2{
    grid-column: span 2 / span 2;
}
.tw-col-start-1{
    grid-column-start: 1;
}
.tw-row-span-1{
    grid-row: span 1 / span 1;
}
.tw-row-span-2{
    grid-row: span 2 / span 2;
}
.tw-m-1{
    margin: 0.25rem;
}
.tw-mx-2{
    margin-left: 0.5rem;
    margin-right: 0.5rem;
}
.tw-mx-4{
    margin-left: 1rem;
    margin-right: 1rem;
}
.tw-mx-auto{
    margin-left: auto;
    margin-right: auto;
}
.tw-my-2{
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
}
.tw-my-3{
    margin-top: 0.75rem;
    margin-bottom: 0.75rem;
}
.tw-my-4{
    margin-top: 1rem;
    margin-bottom: 1rem;
}
.tw-my-6{
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
}
.-tw-ml-px{
    margin-left: -1px;
}
.-tw-mt-3{
    margin-top: -0.75rem;
}
.tw-mb-0{
    margin-bottom: 0px;
}
.tw-mb-1{
    margin-bottom: 0.25rem;
}
.tw-mb-16{
    margin-bottom: 4rem;
}
.tw-mb-2{
    margin-bottom: 0.5rem;
}
.tw-mb-3{
    margin-bottom: 0.75rem;
}
.tw-mb-4{
    margin-bottom: 1rem;
}
.tw-mb-6{
    margin-bottom: 1.5rem;
}
.tw-mb-8{
    margin-bottom: 2rem;
}
.tw-ml-1{
    margin-left: 0.25rem;
}
.tw-ml-2{
    margin-left: 0.5rem;
}
.tw-ml-\[5px\]{
    margin-left: 5px;
}
.tw-ml-auto{
    margin-left: auto;
}
.tw-mr-2{
    margin-right: 0.5rem;
}
.tw-mt-0{
    margin-top: 0px;
}
.tw-mt-0\.5{
    margin-top: 0.125rem;
}
.tw-mt-1{
    margin-top: 0.25rem;
}
.tw-mt-2{
    margin-top: 0.5rem;
}
.tw-mt-3{
    margin-top: 0.75rem;
}
.tw-mt-4{
    margin-top: 1rem;
}
.tw-mt-6{
    margin-top: 1.5rem;
}
.tw-mt-8{
    margin-top: 2rem;
}
.tw-mt-\[10px\]{
    margin-top: 10px;
}
.tw-block{
    display: block;
}
.tw-inline-block{
    display: inline-block;
}
.tw-flex{
    display: flex;
}
.tw-inline-flex{
    display: inline-flex;
}
.tw-grid{
    display: grid;
}
.\!tw-hidden{
    display: none !important;
}
.tw-hidden{
    display: none;
}
.\!tw-aspect-auto{
    aspect-ratio: auto !important;
}
.tw-aspect-\[481\/378\]{
    aspect-ratio: 481/378;
}
.tw-aspect-square{
    aspect-ratio: 1 / 1;
}
.\!tw-size-\[44px\]{
    width: 44px !important;
    height: 44px !important;
}
.tw-size-10{
    width: 2.5rem;
    height: 2.5rem;
}
.tw-size-32{
    width: 8rem;
    height: 8rem;
}
.tw-size-36{
    width: 9rem;
    height: 9rem;
}
.tw-size-4{
    width: 1rem;
    height: 1rem;
}
.tw-size-5{
    width: 1.25rem;
    height: 1.25rem;
}
.tw-size-8{
    width: 2rem;
    height: 2rem;
}
.tw-size-9{
    width: 2.25rem;
    height: 2.25rem;
}
.tw-size-\[7rem\]{
    width: 7rem;
    height: 7rem;
}
.\!tw-h-11{
    height: 2.75rem !important;
}
.\!tw-h-12{
    height: 3rem !important;
}
.\!tw-h-16{
    height: 4rem !important;
}
.\!tw-h-6{
    height: 1.5rem !important;
}
.\!tw-h-8{
    height: 2rem !important;
}
.\!tw-h-9{
    height: 2.25rem !important;
}
.\!tw-h-\[140px\]{
    height: 140px !important;
}
.\!tw-h-\[40px\]{
    height: 40px !important;
}
.tw-h-0{
    height: 0px;
}
.tw-h-1{
    height: 0.25rem;
}
.tw-h-1\.5{
    height: 0.375rem;
}
.tw-h-1\/2{
    height: 50%;
}
.tw-h-10{
    height: 2.5rem;
}
.tw-h-12{
    height: 3rem;
}
.tw-h-14{
    height: 3.5rem;
}
.tw-h-16{
    height: 4rem;
}
.tw-h-2{
    height: 0.5rem;
}
.tw-h-20{
    height: 5rem;
}
.tw-h-3{
    height: 0.75rem;
}
.tw-h-3\.5{
    height: 0.875rem;
}
.tw-h-4{
    height: 1rem;
}
.tw-h-4\/5{
    height: 80%;
}
.tw-h-44{
    height: 11rem;
}
.tw-h-48{
    height: 12rem;
}
.tw-h-5{
    height: 1.25rem;
}
.tw-h-6{
    height: 1.5rem;
}
.tw-h-8{
    height: 2rem;
}
.tw-h-9{
    height: 2.25rem;
}
.tw-h-\[168px\]{
    height: 168px;
}
.tw-h-\[16px\]{
    height: 16px;
}
.tw-h-\[22px\]{
    height: 22px;
}
.tw-h-\[240px\]{
    height: 240px;
}
.tw-h-\[24rem\]{
    height: 24rem;
}
.tw-h-\[26px\]{
    height: 26px;
}
.tw-h-\[280px\]{
    height: 280px;
}
.tw-h-\[28px\]{
    height: 28px;
}
.tw-h-\[34px\]{
    height: 34px;
}
.tw-h-\[40px\]{
    height: 40px;
}
.tw-h-\[42px\]{
    height: 42px;
}
.tw-h-\[536px\]{
    height: 536px;
}
.tw-h-\[72px\]{
    height: 72px;
}
.tw-h-\[848px\]{
    height: 848px;
}
.tw-h-\[90px\]{
    height: 90px;
}
.tw-h-\[90vh\]{
    height: 90vh;
}
.tw-h-\[96px\]{
    height: 96px;
}
.tw-h-\[99svh\]{
    height: 99svh;
}
.tw-h-\[calc\(92svh-56px\)\]{
    height: calc(92svh - 56px);
}
.tw-h-auto{
    height: auto;
}
.tw-h-fit{
    height: -moz-fit-content;
    height: fit-content;
}
.tw-h-full{
    height: 100%;
}
.tw-h-px{
    height: 1px;
}
.tw-h-screen{
    height: 100vh;
}
.tw-max-h-72{
    max-height: 18rem;
}
.tw-max-h-\[200px\]{
    max-height: 200px;
}
.tw-max-h-\[70vh\]{
    max-height: 70vh;
}
.tw-max-h-\[90vh\]{
    max-height: 90vh;
}
.tw-max-h-\[99svh\]{
    max-height: 99svh;
}
.tw-max-h-\[calc\(100vh-1rem\)\]{
    max-height: calc(100vh - 1rem);
}
.tw-max-h-\[calc\(100vh-32px\)\]{
    max-height: calc(100vh - 32px);
}
.tw-min-h-0{
    min-height: 0px;
}
.tw-min-h-\[1\.25rem\]{
    min-height: 1.25rem;
}
.tw-min-h-\[100px\]{
    min-height: 100px;
}
.tw-min-h-screen{
    min-height: 100vh;
}
.\!tw-w-12{
    width: 3rem !important;
}
.\!tw-w-16{
    width: 4rem !important;
}
.\!tw-w-6{
    width: 1.5rem !important;
}
.\!tw-w-\[140px\]{
    width: 140px !important;
}
.\!tw-w-full{
    width: 100% !important;
}
.tw-w-0{
    width: 0px;
}
.tw-w-1\/2{
    width: 50%;
}
.tw-w-10{
    width: 2.5rem;
}
.tw-w-11{
    width: 2.75rem;
}
.tw-w-12{
    width: 3rem;
}
.tw-w-16{
    width: 4rem;
}
.tw-w-2{
    width: 0.5rem;
}
.tw-w-20{
    width: 5rem;
}
.tw-w-28{
    width: 7rem;
}
.tw-w-3{
    width: 0.75rem;
}
.tw-w-3\.5{
    width: 0.875rem;
}
.tw-w-3\/4{
    width: 75%;
}
.tw-w-32{
    width: 8rem;
}
.tw-w-4{
    width: 1rem;
}
.tw-w-4\/5{
    width: 80%;
}
.tw-w-4\/6{
    width: 66.666667%;
}
.tw-w-40{
    width: 10rem;
}
.tw-w-5{
    width: 1.25rem;
}
.tw-w-5\/6{
    width: 83.333333%;
}
.tw-w-52{
    width: 13rem;
}
.tw-w-6{
    width: 1.5rem;
}
.tw-w-7{
    width: 1.75rem;
}
.tw-w-8{
    width: 2rem;
}
.tw-w-80{
    width: 20rem;
}
.tw-w-9{
    width: 2.25rem;
}
.tw-w-96{
    width: 24rem;
}
.tw-w-\[1\.5px\]{
    width: 1.5px;
}
.tw-w-\[112px\]{
    width: 112px;
}
.tw-w-\[120px\]{
    width: 120px;
}
.tw-w-\[16px\]{
    width: 16px;
}
.tw-w-\[200px\]{
    width: 200px;
}
.tw-w-\[22px\]{
    width: 22px;
}
.tw-w-\[24rem\]{
    width: 24rem;
}
.tw-w-\[26px\]{
    width: 26px;
}
.tw-w-\[28px\]{
    width: 28px;
}
.tw-w-\[5\.5rem\]{
    width: 5.5rem;
}
.tw-w-\[516px\]{
    width: 516px;
}
.tw-w-\[552px\]{
    width: 552px;
}
.tw-w-\[848px\]{
    width: 848px;
}
.tw-w-\[96px\]{
    width: 96px;
}
.tw-w-\[98vw\]{
    width: 98vw;
}
.tw-w-\[min\(92vw\,320px\)\]{
    width: min(92vw,320px);
}
.tw-w-auto{
    width: auto;
}
.tw-w-fit{
    width: -moz-fit-content;
    width: fit-content;
}
.tw-w-full{
    width: 100%;
}
.tw-w-max{
    width: -moz-max-content;
    width: max-content;
}
.tw-w-px{
    width: 1px;
}
.tw-w-screen{
    width: 100vw;
}
.tw-min-w-0{
    min-width: 0px;
}
.tw-min-w-14{
    min-width: 3.5rem;
}
.tw-min-w-48{
    min-width: 12rem;
}
.tw-min-w-5{
    min-width: 1.25rem;
}
.tw-min-w-64{
    min-width: 16rem;
}
.tw-min-w-9{
    min-width: 2.25rem;
}
.tw-min-w-\[160px\]{
    min-width: 160px;
}
.tw-min-w-\[164px\]{
    min-width: 164px;
}
.tw-min-w-\[20px\]{
    min-width: 20px;
}
.tw-min-w-\[36px\]{
    min-width: 36px;
}
.tw-min-w-\[640px\]{
    min-width: 640px;
}
.tw-min-w-\[88px\]{
    min-width: 88px;
}
.tw-max-w-16{
    max-width: 4rem;
}
.tw-max-w-3xl{
    max-width: 48rem;
}
.tw-max-w-6xl{
    max-width: 72rem;
}
.tw-max-w-72{
    max-width: 18rem;
}
.tw-max-w-7xl{
    max-width: 80rem;
}
.tw-max-w-\[180px\]{
    max-width: 180px;
}
.tw-max-w-\[200px\]{
    max-width: 200px;
}
.tw-max-w-\[420px\]{
    max-width: 420px;
}
.tw-max-w-\[500px\]{
    max-width: 500px;
}
.tw-max-w-\[520px\]{
    max-width: 520px;
}
.tw-max-w-\[640px\]{
    max-width: 640px;
}
.tw-max-w-\[98vw\]{
    max-width: 98vw;
}
.tw-max-w-\[min\(100\%\,30rem\)\]{
    max-width: min(100%,30rem);
}
.tw-max-w-full{
    max-width: 100%;
}
.tw-max-w-md{
    max-width: 28rem;
}
.tw-max-w-none{
    max-width: none;
}
.tw-max-w-xl{
    max-width: 36rem;
}
.tw-max-w-xs{
    max-width: 20rem;
}
.tw-flex-1{
    flex: 1 1 0%;
}
.tw-flex-shrink-0{
    flex-shrink: 0;
}
.tw-shrink-0{
    flex-shrink: 0;
}
.tw-border-collapse{
    border-collapse: collapse;
}
.-tw-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));
}
.tw--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));
}
.tw--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));
}
.tw-translate-x-0{
    --tw-translate-x: 0px;
    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));
}
.tw-translate-x-\[18px\]{
    --tw-translate-x: 18px;
    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));
}
.tw-translate-x-\[3px\]{
    --tw-translate-x: 3px;
    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));
}
.tw-translate-x-\[60px\]{
    --tw-translate-x: 60px;
    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));
}
.tw-translate-x-full{
    --tw-translate-x: 100%;
    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));
}
.tw-translate-y-0{
    --tw-translate-y: 0px;
    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));
}
.tw-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));
}
.tw-translate-y-1\/4{
    --tw-translate-y: 25%;
    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));
}
.tw-translate-y-2{
    --tw-translate-y: 0.5rem;
    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));
}
.tw-translate-y-full{
    --tw-translate-y: 100%;
    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));
}
.tw-rotate-180{
    --tw-rotate: 180deg;
    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));
}
.tw-rotate-45{
    --tw-rotate: 45deg;
    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));
}
.tw-scale-125{
    --tw-scale-x: 1.25;
    --tw-scale-y: 1.25;
    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));
}
.tw-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));
}
@keyframes tw-pulse{
    50%{
        opacity: .5;
    }
}
.tw-animate-pulse{
    animation: tw-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}
@keyframes tw-spin{
    to{
        transform: rotate(360deg);
    }
}
.tw-animate-spin{
    animation: tw-spin 1s linear infinite;
}
.tw-cursor-help{
    cursor: help;
}
.tw-cursor-not-allowed{
    cursor: not-allowed;
}
.tw-cursor-pointer{
    cursor: pointer;
}
.tw-cursor-zoom-in{
    cursor: zoom-in;
}
.tw-select-none{
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
}
.tw-resize-none{
    resize: none;
}
.tw-scroll-mt-4{
    scroll-margin-top: 1rem;
}
.tw-grid-flow-col{
    grid-auto-flow: column;
}
.tw-grid-cols-1{
    grid-template-columns: repeat(1, minmax(0, 1fr));
}
.tw-grid-cols-2{
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.tw-grid-cols-3{
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.tw-grid-cols-5{
    grid-template-columns: repeat(5, minmax(0, 1fr));
}
.tw-grid-cols-\[1fr_auto_1fr\]{
    grid-template-columns: 1fr auto 1fr;
}
.tw-grid-rows-2{
    grid-template-rows: repeat(2, minmax(0, 1fr));
}
.tw-flex-row{
    flex-direction: row;
}
.tw-flex-col{
    flex-direction: column;
}
.tw-flex-wrap{
    flex-wrap: wrap;
}
.tw-flex-nowrap{
    flex-wrap: nowrap;
}
.tw-items-start{
    align-items: flex-start;
}
.tw-items-end{
    align-items: flex-end;
}
.tw-items-center{
    align-items: center;
}
.tw-items-stretch{
    align-items: stretch;
}
.tw-justify-start{
    justify-content: flex-start;
}
.tw-justify-end{
    justify-content: flex-end;
}
.tw-justify-center{
    justify-content: center;
}
.tw-justify-between{
    justify-content: space-between;
}
.tw-gap-0{
    gap: 0px;
}
.tw-gap-0\.5{
    gap: 0.125rem;
}
.tw-gap-1{
    gap: 0.25rem;
}
.tw-gap-1\.5{
    gap: 0.375rem;
}
.tw-gap-2{
    gap: 0.5rem;
}
.tw-gap-2\.5{
    gap: 0.625rem;
}
.tw-gap-3{
    gap: 0.75rem;
}
.tw-gap-3\.5{
    gap: 0.875rem;
}
.tw-gap-4{
    gap: 1rem;
}
.tw-gap-6{
    gap: 1.5rem;
}
.tw-gap-7{
    gap: 1.75rem;
}
.tw-gap-8{
    gap: 2rem;
}
.tw-gap-x-0\.5{
    -moz-column-gap: 0.125rem;
         column-gap: 0.125rem;
}
.tw-gap-x-1{
    -moz-column-gap: 0.25rem;
         column-gap: 0.25rem;
}
.tw-gap-x-3{
    -moz-column-gap: 0.75rem;
         column-gap: 0.75rem;
}
.tw-gap-x-4{
    -moz-column-gap: 1rem;
         column-gap: 1rem;
}
.tw-gap-x-6{
    -moz-column-gap: 1.5rem;
         column-gap: 1.5rem;
}
.tw-gap-y-0\.5{
    row-gap: 0.125rem;
}
.tw-gap-y-1{
    row-gap: 0.25rem;
}
.tw-gap-y-2{
    row-gap: 0.5rem;
}
.tw-gap-y-5{
    row-gap: 1.25rem;
}
.tw-space-x-1 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(0.25rem * var(--tw-space-x-reverse));
    margin-left: calc(0.25rem * calc(1 - var(--tw-space-x-reverse)));
}
.tw-space-x-2 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(0.5rem * var(--tw-space-x-reverse));
    margin-left: calc(0.5rem * calc(1 - var(--tw-space-x-reverse)));
}
.tw-space-x-3 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(0.75rem * var(--tw-space-x-reverse));
    margin-left: calc(0.75rem * calc(1 - var(--tw-space-x-reverse)));
}
.tw-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));
}
.tw-space-y-1 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(0.25rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.25rem * var(--tw-space-y-reverse));
}
.tw-space-y-2 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.5rem * var(--tw-space-y-reverse));
}
.tw-space-y-3 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.75rem * var(--tw-space-y-reverse));
}
.tw-space-y-4 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1rem * var(--tw-space-y-reverse));
}
.tw-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));
}
.tw-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));
}
.tw-space-y-8 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(2rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(2rem * var(--tw-space-y-reverse));
}
.tw-self-stretch{
    align-self: stretch;
}
.tw-justify-self-start{
    justify-self: start;
}
.tw-justify-self-end{
    justify-self: end;
}
.tw-justify-self-center{
    justify-self: center;
}
.tw-overflow-auto{
    overflow: auto;
}
.tw-overflow-hidden{
    overflow: hidden;
}
.tw-overflow-visible{
    overflow: visible;
}
.tw-overflow-x-auto{
    overflow-x: auto;
}
.tw-overflow-y-auto{
    overflow-y: auto;
}
.tw-overflow-x-hidden{
    overflow-x: hidden;
}
.tw-overflow-y-hidden{
    overflow-y: hidden;
}
.tw-overflow-y-scroll{
    overflow-y: scroll;
}
.tw-scroll-smooth{
    scroll-behavior: smooth;
}
.tw-truncate{
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.tw-whitespace-normal{
    white-space: normal;
}
.tw-whitespace-nowrap{
    white-space: nowrap;
}
.tw-text-nowrap{
    text-wrap: nowrap;
}
.tw-break-words{
    overflow-wrap: break-word;
}
.tw-rounded{
    border-radius: 0.25rem;
}
.tw-rounded-\[10px\]{
    border-radius: 10px;
}
.tw-rounded-\[11px\]{
    border-radius: 11px;
}
.tw-rounded-\[1px\]{
    border-radius: 1px;
}
.tw-rounded-\[20px\]{
    border-radius: 20px;
}
.tw-rounded-\[30px\]{
    border-radius: 30px;
}
.tw-rounded-\[50px\]{
    border-radius: 50px;
}
.tw-rounded-\[8px\]{
    border-radius: 8px;
}
.tw-rounded-full{
    border-radius: 9999px;
}
.tw-rounded-lg{
    border-radius: 0.5rem;
}
.tw-rounded-md{
    border-radius: 0.375rem;
}
.tw-rounded-xl{
    border-radius: 0.75rem;
}
.tw-rounded-b-lg{
    border-bottom-right-radius: 0.5rem;
    border-bottom-left-radius: 0.5rem;
}
.tw-rounded-l-\[11px\]{
    border-top-left-radius: 11px;
    border-bottom-left-radius: 11px;
}
.tw-rounded-l-lg{
    border-top-left-radius: 0.5rem;
    border-bottom-left-radius: 0.5rem;
}
.tw-rounded-l-md{
    border-top-left-radius: 0.375rem;
    border-bottom-left-radius: 0.375rem;
}
.tw-rounded-r-\[11px\]{
    border-top-right-radius: 11px;
    border-bottom-right-radius: 11px;
}
.tw-rounded-r-lg{
    border-top-right-radius: 0.5rem;
    border-bottom-right-radius: 0.5rem;
}
.tw-rounded-r-md{
    border-top-right-radius: 0.375rem;
    border-bottom-right-radius: 0.375rem;
}
.tw-rounded-bl-md{
    border-bottom-left-radius: 0.375rem;
}
.tw-rounded-br{
    border-bottom-right-radius: 0.25rem;
}
.tw-rounded-br-md{
    border-bottom-right-radius: 0.375rem;
}
.tw-rounded-tl-md{
    border-top-left-radius: 0.375rem;
}
.tw-rounded-tr-md{
    border-top-right-radius: 0.375rem;
}
.tw-border{
    border-width: 1px;
}
.tw-border-0{
    border-width: 0px;
}
.tw-border-2{
    border-width: 2px;
}
.tw-border-4{
    border-width: 4px;
}
.tw-border-x-\[9px\]{
    border-left-width: 9px;
    border-right-width: 9px;
}
.tw-border-y{
    border-top-width: 1px;
    border-bottom-width: 1px;
}
.tw-border-b{
    border-bottom-width: 1px;
}
.tw-border-b-2{
    border-bottom-width: 2px;
}
.tw-border-b-\[9px\]{
    border-bottom-width: 9px;
}
.tw-border-r{
    border-right-width: 1px;
}
.tw-border-t{
    border-top-width: 1px;
}
.tw-border-t-2{
    border-top-width: 2px;
}
.tw-border-dashed{
    border-style: dashed;
}
.tw-border-none{
    border-style: none;
}
.tw-border-\[\#E7E3DB\]{
    --tw-border-opacity: 1;
    border-color: rgb(231 227 219 / var(--tw-border-opacity, 1));
}
.tw-border-\[\#EDE9E1\]{
    --tw-border-opacity: 1;
    border-color: rgb(237 233 225 / var(--tw-border-opacity, 1));
}
.tw-border-amber-200{
    --tw-border-opacity: 1;
    border-color: rgb(253 230 138 / var(--tw-border-opacity, 1));
}
.tw-border-amber-500{
    --tw-border-opacity: 1;
    border-color: rgb(245 158 11 / var(--tw-border-opacity, 1));
}
.tw-border-current{
    border-color: currentColor;
}
.tw-border-emerald-200{
    --tw-border-opacity: 1;
    border-color: rgb(167 243 208 / var(--tw-border-opacity, 1));
}
.tw-border-gray-100{
    --tw-border-opacity: 1;
    border-color: rgb(243 244 246 / var(--tw-border-opacity, 1));
}
.tw-border-gray-200{
    --tw-border-opacity: 1;
    border-color: rgb(229 231 235 / var(--tw-border-opacity, 1));
}
.tw-border-gray-200\/80{
    border-color: rgb(229 231 235 / 0.8);
}
.tw-border-gray-300{
    --tw-border-opacity: 1;
    border-color: rgb(209 213 219 / var(--tw-border-opacity, 1));
}
.tw-border-gray-400{
    --tw-border-opacity: 1;
    border-color: rgb(156 163 175 / var(--tw-border-opacity, 1));
}
.tw-border-gray-500{
    --tw-border-opacity: 1;
    border-color: rgb(107 114 128 / var(--tw-border-opacity, 1));
}
.tw-border-gray-900{
    --tw-border-opacity: 1;
    border-color: rgb(17 24 39 / var(--tw-border-opacity, 1));
}
.tw-border-green-200{
    --tw-border-opacity: 1;
    border-color: rgb(187 247 208 / var(--tw-border-opacity, 1));
}
.tw-border-red-200{
    --tw-border-opacity: 1;
    border-color: rgb(254 202 202 / var(--tw-border-opacity, 1));
}
.tw-border-red-500{
    --tw-border-opacity: 1;
    border-color: rgb(239 68 68 / var(--tw-border-opacity, 1));
}
.tw-border-sky-200{
    --tw-border-opacity: 1;
    border-color: rgb(186 230 253 / var(--tw-border-opacity, 1));
}
.tw-border-slate-200{
    --tw-border-opacity: 1;
    border-color: rgb(226 232 240 / var(--tw-border-opacity, 1));
}
.tw-border-transparent{
    border-color: transparent;
}
.tw-border-white{
    --tw-border-opacity: 1;
    border-color: rgb(255 255 255 / var(--tw-border-opacity, 1));
}
.tw-border-yellow-400{
    --tw-border-opacity: 1;
    border-color: rgb(250 204 21 / var(--tw-border-opacity, 1));
}
.tw-border-x-transparent{
    border-left-color: transparent;
    border-right-color: transparent;
}
.tw-border-t-transparent{
    border-top-color: transparent;
}
.\!tw-bg-gray-200{
    --tw-bg-opacity: 1 !important;
    background-color: rgb(229 231 235 / var(--tw-bg-opacity, 1)) !important;
}
.tw-bg-\[\#DEA193\]{
    --tw-bg-opacity: 1;
    background-color: rgb(222 161 147 / var(--tw-bg-opacity, 1));
}
.tw-bg-\[\#ECDFFB\]{
    --tw-bg-opacity: 1;
    background-color: rgb(236 223 251 / var(--tw-bg-opacity, 1));
}
.tw-bg-\[\#bdeaff\]{
    --tw-bg-opacity: 1;
    background-color: rgb(189 234 255 / var(--tw-bg-opacity, 1));
}
.tw-bg-\[\#f6f1e8\]{
    --tw-bg-opacity: 1;
    background-color: rgb(246 241 232 / var(--tw-bg-opacity, 1));
}
.tw-bg-\[var\(--gemtheon-accent\,\#7F5AF0\)\]{
    background-color: var(--gemtheon-accent,#7F5AF0);
}
.tw-bg-amber-50{
    --tw-bg-opacity: 1;
    background-color: rgb(255 251 235 / var(--tw-bg-opacity, 1));
}
.tw-bg-black{
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}
.tw-bg-black\/20{
    background-color: rgb(0 0 0 / 0.2);
}
.tw-bg-black\/40{
    background-color: rgb(0 0 0 / 0.4);
}
.tw-bg-black\/50{
    background-color: rgb(0 0 0 / 0.5);
}
.tw-bg-black\/60{
    background-color: rgb(0 0 0 / 0.6);
}
.tw-bg-black\/70{
    background-color: rgb(0 0 0 / 0.7);
}
.tw-bg-black\/75{
    background-color: rgb(0 0 0 / 0.75);
}
.tw-bg-blue-500{
    --tw-bg-opacity: 1;
    background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1));
}
.tw-bg-emerald-50{
    --tw-bg-opacity: 1;
    background-color: rgb(236 253 245 / var(--tw-bg-opacity, 1));
}
.tw-bg-gray-100{
    --tw-bg-opacity: 1;
    background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1));
}
.tw-bg-gray-100\/90{
    background-color: rgb(243 244 246 / 0.9);
}
.tw-bg-gray-200{
    --tw-bg-opacity: 1;
    background-color: rgb(229 231 235 / var(--tw-bg-opacity, 1));
}
.tw-bg-gray-300{
    --tw-bg-opacity: 1;
    background-color: rgb(209 213 219 / var(--tw-bg-opacity, 1));
}
.tw-bg-gray-400{
    --tw-bg-opacity: 1;
    background-color: rgb(156 163 175 / var(--tw-bg-opacity, 1));
}
.tw-bg-gray-400\/50{
    background-color: rgb(156 163 175 / 0.5);
}
.tw-bg-gray-50{
    --tw-bg-opacity: 1;
    background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1));
}
.tw-bg-gray-900{
    --tw-bg-opacity: 1;
    background-color: rgb(17 24 39 / var(--tw-bg-opacity, 1));
}
.tw-bg-green-50{
    --tw-bg-opacity: 1;
    background-color: rgb(240 253 244 / var(--tw-bg-opacity, 1));
}
.tw-bg-red-50{
    --tw-bg-opacity: 1;
    background-color: rgb(254 242 242 / var(--tw-bg-opacity, 1));
}
.tw-bg-red-500{
    --tw-bg-opacity: 1;
    background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1));
}
.tw-bg-red-600{
    --tw-bg-opacity: 1;
    background-color: rgb(220 38 38 / var(--tw-bg-opacity, 1));
}
.tw-bg-sky-50{
    --tw-bg-opacity: 1;
    background-color: rgb(240 249 255 / var(--tw-bg-opacity, 1));
}
.tw-bg-slate-100{
    --tw-bg-opacity: 1;
    background-color: rgb(241 245 249 / var(--tw-bg-opacity, 1));
}
.tw-bg-slate-500\/40{
    background-color: rgb(100 116 139 / 0.4);
}
.tw-bg-stone-300{
    --tw-bg-opacity: 1;
    background-color: rgb(214 211 209 / var(--tw-bg-opacity, 1));
}
.tw-bg-stone-50{
    --tw-bg-opacity: 1;
    background-color: rgb(250 250 249 / var(--tw-bg-opacity, 1));
}
.tw-bg-transparent{
    background-color: transparent;
}
.tw-bg-violet-500{
    --tw-bg-opacity: 1;
    background-color: rgb(139 92 246 / var(--tw-bg-opacity, 1));
}
.tw-bg-white{
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.tw-bg-white\/25{
    background-color: rgb(255 255 255 / 0.25);
}
.tw-bg-white\/55{
    background-color: rgb(255 255 255 / 0.55);
}
.tw-bg-white\/80{
    background-color: rgb(255 255 255 / 0.8);
}
.tw-bg-white\/85{
    background-color: rgb(255 255 255 / 0.85);
}
.tw-bg-white\/90{
    background-color: rgb(255 255 255 / 0.9);
}
.tw-bg-white\/95{
    background-color: rgb(255 255 255 / 0.95);
}
.tw-bg-yellow-400{
    --tw-bg-opacity: 1;
    background-color: rgb(250 204 21 / var(--tw-bg-opacity, 1));
}
.tw-bg-yellow-500{
    --tw-bg-opacity: 1;
    background-color: rgb(234 179 8 / var(--tw-bg-opacity, 1));
}
.tw-bg-opacity-50{
    --tw-bg-opacity: 0.5;
}
.tw-bg-opacity-60{
    --tw-bg-opacity: 0.6;
}
.tw-bg-opacity-70{
    --tw-bg-opacity: 0.7;
}
.tw-bg-opacity-80{
    --tw-bg-opacity: 0.8;
}
.tw-bg-opacity-90{
    --tw-bg-opacity: 0.9;
}
.\!tw-bg-none{
    background-image: none !important;
}
.tw-bg-gradient-to-l{
    background-image: linear-gradient(to left, var(--tw-gradient-stops));
}
.tw-bg-gradient-to-r{
    background-image: linear-gradient(to right, var(--tw-gradient-stops));
}
.tw-bg-none{
    background-image: none;
}
.tw-from-violet-950{
    --tw-gradient-from: #2e1065 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(46 16 101 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.tw-from-white{
    --tw-gradient-from: #fff var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.tw-via-white\/85{
    --tw-gradient-to: rgb(255 255 255 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), rgb(255 255 255 / 0.85) var(--tw-gradient-via-position), var(--tw-gradient-to);
}
.tw-to-transparent{
    --tw-gradient-to: transparent var(--tw-gradient-to-position);
}
.tw-to-violet-500{
    --tw-gradient-to: #8b5cf6 var(--tw-gradient-to-position);
}
.tw-bg-cover{
    background-size: cover;
}
.tw-bg-bottom{
    background-position: bottom;
}
.tw-bg-no-repeat{
    background-repeat: no-repeat;
}
.tw-fill-gray-500{
    fill: #6b7280;
}
.tw-object-contain{
    -o-object-fit: contain;
       object-fit: contain;
}
.tw-object-cover{
    -o-object-fit: cover;
       object-fit: cover;
}
.tw-object-center{
    -o-object-position: center;
       object-position: center;
}
.\!tw-p-0{
    padding: 0px !important;
}
.tw-p-0{
    padding: 0px;
}
.tw-p-0\.5{
    padding: 0.125rem;
}
.tw-p-1{
    padding: 0.25rem;
}
.tw-p-2{
    padding: 0.5rem;
}
.tw-p-3{
    padding: 0.75rem;
}
.tw-p-4{
    padding: 1rem;
}
.tw-p-5{
    padding: 1.25rem;
}
.tw-p-6{
    padding: 1.5rem;
}
.\!tw-px-2{
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
}
.\!tw-px-4{
    padding-left: 1rem !important;
    padding-right: 1rem !important;
}
.\!tw-px-8{
    padding-left: 2rem !important;
    padding-right: 2rem !important;
}
.\!tw-py-1{
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
}
.\!tw-py-1\.5{
    padding-top: 0.375rem !important;
    padding-bottom: 0.375rem !important;
}
.tw-px-0{
    padding-left: 0px;
    padding-right: 0px;
}
.tw-px-1{
    padding-left: 0.25rem;
    padding-right: 0.25rem;
}
.tw-px-1\.5{
    padding-left: 0.375rem;
    padding-right: 0.375rem;
}
.tw-px-10{
    padding-left: 2.5rem;
    padding-right: 2.5rem;
}
.tw-px-16{
    padding-left: 4rem;
    padding-right: 4rem;
}
.tw-px-2{
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}
.tw-px-2\.5{
    padding-left: 0.625rem;
    padding-right: 0.625rem;
}
.tw-px-3{
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}
.tw-px-4{
    padding-left: 1rem;
    padding-right: 1rem;
}
.tw-px-5{
    padding-left: 1.25rem;
    padding-right: 1.25rem;
}
.tw-px-6{
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}
.tw-px-8{
    padding-left: 2rem;
    padding-right: 2rem;
}
.tw-py-0{
    padding-top: 0px;
    padding-bottom: 0px;
}
.tw-py-0\.5{
    padding-top: 0.125rem;
    padding-bottom: 0.125rem;
}
.tw-py-1{
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
}
.tw-py-1\.5{
    padding-top: 0.375rem;
    padding-bottom: 0.375rem;
}
.tw-py-12{
    padding-top: 3rem;
    padding-bottom: 3rem;
}
.tw-py-2{
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}
.tw-py-2\.5{
    padding-top: 0.625rem;
    padding-bottom: 0.625rem;
}
.tw-py-3{
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}
.tw-py-4{
    padding-top: 1rem;
    padding-bottom: 1rem;
}
.tw-py-5{
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
}
.tw-py-6{
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
}
.tw-py-8{
    padding-top: 2rem;
    padding-bottom: 2rem;
}
.tw-py-\[1px\]{
    padding-top: 1px;
    padding-bottom: 1px;
}
.tw-py-\[2px\]{
    padding-top: 2px;
    padding-bottom: 2px;
}
.tw-py-\[5px\]{
    padding-top: 5px;
    padding-bottom: 5px;
}
.\!tw-pl-6{
    padding-left: 1.5rem !important;
}
.\!tw-pl-9{
    padding-left: 2.25rem !important;
}
.\!tw-pr-10{
    padding-right: 2.5rem !important;
}
.\!tw-pr-2{
    padding-right: 0.5rem !important;
}
.\!tw-pr-8{
    padding-right: 2rem !important;
}
.tw-pb-0{
    padding-bottom: 0px;
}
.tw-pb-1{
    padding-bottom: 0.25rem;
}
.tw-pb-2{
    padding-bottom: 0.5rem;
}
.tw-pb-20{
    padding-bottom: 5rem;
}
.tw-pb-3{
    padding-bottom: 0.75rem;
}
.tw-pb-4{
    padding-bottom: 1rem;
}
.tw-pb-5{
    padding-bottom: 1.25rem;
}
.tw-pb-6{
    padding-bottom: 1.5rem;
}
.tw-pb-8{
    padding-bottom: 2rem;
}
.tw-pl-1{
    padding-left: 0.25rem;
}
.tw-pl-2{
    padding-left: 0.5rem;
}
.tw-pl-2\.5{
    padding-left: 0.625rem;
}
.tw-pl-3{
    padding-left: 0.75rem;
}
.tw-pl-4{
    padding-left: 1rem;
}
.tw-pr-1{
    padding-right: 0.25rem;
}
.tw-pr-2\.5{
    padding-right: 0.625rem;
}
.tw-pr-3{
    padding-right: 0.75rem;
}
.tw-pr-4{
    padding-right: 1rem;
}
.tw-pt-0{
    padding-top: 0px;
}
.tw-pt-1{
    padding-top: 0.25rem;
}
.tw-pt-2{
    padding-top: 0.5rem;
}
.tw-pt-2\.5{
    padding-top: 0.625rem;
}
.tw-pt-3{
    padding-top: 0.75rem;
}
.tw-pt-4{
    padding-top: 1rem;
}
.tw-pt-5{
    padding-top: 1.25rem;
}
.tw-pt-6{
    padding-top: 1.5rem;
}
.tw-text-left{
    text-align: left;
}
.tw-text-center{
    text-align: center;
}
.tw-text-right{
    text-align: right;
}
.tw-text-start{
    text-align: start;
}
.tw-font-\[\'Be_Vietnam_Pro\'\]{
    font-family: 'Be Vietnam Pro';
}
.tw-font-\[\'Manrope\'\]{
    font-family: 'Manrope';
}
.tw-font-bevietnam{
    font-family: 'Be Vietnam Pro', sans-serif;
}
.tw-font-lovelace{
    font-family: Lovelace, serif;
}
.\!tw-text-\[10px\]{
    font-size: 10px !important;
}
.\!tw-text-\[14px\]{
    font-size: 14px !important;
}
.\!tw-text-base{
    font-size: 1rem !important;
    line-height: 1.5rem !important;
}
.\!tw-text-sm{
    font-size: 0.875rem !important;
    line-height: 1.25rem !important;
}
.\!tw-text-xs{
    font-size: 0.75rem !important;
    line-height: 1rem !important;
}
.tw-text-2xl{
    font-size: 1.5rem;
    line-height: 2rem;
}
.tw-text-3xl{
    font-size: 1.875rem;
    line-height: 2.25rem;
}
.tw-text-\[10px\]{
    font-size: 10px;
}
.tw-text-\[11px\]{
    font-size: 11px;
}
.tw-text-\[12px\]{
    font-size: 12px;
}
.tw-text-\[18px\]{
    font-size: 18px;
}
.tw-text-\[8px\]{
    font-size: 8px;
}
.tw-text-\[9px\]{
    font-size: 9px;
}
.tw-text-base{
    font-size: 1rem;
    line-height: 1.5rem;
}
.tw-text-lg{
    font-size: 1.125rem;
    line-height: 1.75rem;
}
.tw-text-sm{
    font-size: 0.875rem;
    line-height: 1.25rem;
}
.tw-text-xl{
    font-size: 1.25rem;
    line-height: 1.75rem;
}
.tw-text-xs{
    font-size: 0.75rem;
    line-height: 1rem;
}
.tw-font-bold{
    font-weight: 700;
}
.tw-font-light{
    font-weight: 300;
}
.tw-font-medium{
    font-weight: 500;
}
.tw-font-normal{
    font-weight: 400;
}
.tw-font-semibold{
    font-weight: 600;
}
.tw-uppercase{
    text-transform: uppercase;
}
.tw-capitalize{
    text-transform: capitalize;
}
.tw-leading-3{
    line-height: .75rem;
}
.tw-leading-4{
    line-height: 1rem;
}
.tw-leading-5{
    line-height: 1.25rem;
}
.tw-leading-6{
    line-height: 1.5rem;
}
.tw-leading-\[52px\]{
    line-height: 52px;
}
.tw-leading-none{
    line-height: 1;
}
.tw-leading-relaxed{
    line-height: 1.625;
}
.tw-leading-snug{
    line-height: 1.375;
}
.tw-leading-tight{
    line-height: 1.25;
}
.tw-tracking-\[0\.01em\]{
    letter-spacing: 0.01em;
}
.tw-tracking-\[0\.08em\]{
    letter-spacing: 0.08em;
}
.tw-tracking-\[0\.2em\]{
    letter-spacing: 0.2em;
}
.tw-tracking-wide{
    letter-spacing: 0.025em;
}
.tw-tracking-wider{
    letter-spacing: 0.05em;
}
.\!tw-text-gray-500{
    --tw-text-opacity: 1 !important;
    color: rgb(107 114 128 / var(--tw-text-opacity, 1)) !important;
}
.\!tw-text-white{
    --tw-text-opacity: 1 !important;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1)) !important;
}
.tw-text-\[\#202020\]{
    --tw-text-opacity: 1;
    color: rgb(32 32 32 / var(--tw-text-opacity, 1));
}
.tw-text-\[\#666666\]{
    --tw-text-opacity: 1;
    color: rgb(102 102 102 / var(--tw-text-opacity, 1));
}
.tw-text-\[var\(--gemtheon-primary\)\]{
    color: var(--gemtheon-primary);
}
.tw-text-amber-400{
    --tw-text-opacity: 1;
    color: rgb(251 191 36 / var(--tw-text-opacity, 1));
}
.tw-text-amber-600{
    --tw-text-opacity: 1;
    color: rgb(217 119 6 / var(--tw-text-opacity, 1));
}
.tw-text-amber-800{
    --tw-text-opacity: 1;
    color: rgb(146 64 14 / var(--tw-text-opacity, 1));
}
.tw-text-amber-950{
    --tw-text-opacity: 1;
    color: rgb(69 26 3 / var(--tw-text-opacity, 1));
}
.tw-text-blue-600{
    --tw-text-opacity: 1;
    color: rgb(37 99 235 / var(--tw-text-opacity, 1));
}
.tw-text-current{
    color: currentColor;
}
.tw-text-emerald-600{
    --tw-text-opacity: 1;
    color: rgb(5 150 105 / var(--tw-text-opacity, 1));
}
.tw-text-emerald-800{
    --tw-text-opacity: 1;
    color: rgb(6 95 70 / var(--tw-text-opacity, 1));
}
.tw-text-emerald-950{
    --tw-text-opacity: 1;
    color: rgb(2 44 34 / var(--tw-text-opacity, 1));
}
.tw-text-gray-300{
    --tw-text-opacity: 1;
    color: rgb(209 213 219 / var(--tw-text-opacity, 1));
}
.tw-text-gray-400{
    --tw-text-opacity: 1;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}
.tw-text-gray-500{
    --tw-text-opacity: 1;
    color: rgb(107 114 128 / var(--tw-text-opacity, 1));
}
.tw-text-gray-600{
    --tw-text-opacity: 1;
    color: rgb(75 85 99 / var(--tw-text-opacity, 1));
}
.tw-text-gray-700{
    --tw-text-opacity: 1;
    color: rgb(55 65 81 / var(--tw-text-opacity, 1));
}
.tw-text-gray-800{
    --tw-text-opacity: 1;
    color: rgb(31 41 55 / var(--tw-text-opacity, 1));
}
.tw-text-gray-900{
    --tw-text-opacity: 1;
    color: rgb(17 24 39 / var(--tw-text-opacity, 1));
}
.tw-text-green-400{
    --tw-text-opacity: 1;
    color: rgb(74 222 128 / var(--tw-text-opacity, 1));
}
.tw-text-green-500{
    --tw-text-opacity: 1;
    color: rgb(34 197 94 / var(--tw-text-opacity, 1));
}
.tw-text-green-700{
    --tw-text-opacity: 1;
    color: rgb(21 128 61 / var(--tw-text-opacity, 1));
}
.tw-text-indigo-600{
    --tw-text-opacity: 1;
    color: rgb(79 70 229 / var(--tw-text-opacity, 1));
}
.tw-text-neutral-400{
    --tw-text-opacity: 1;
    color: rgb(163 163 163 / var(--tw-text-opacity, 1));
}
.tw-text-red-400{
    --tw-text-opacity: 1;
    color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}
.tw-text-red-500{
    --tw-text-opacity: 1;
    color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}
.tw-text-red-600{
    --tw-text-opacity: 1;
    color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}
.tw-text-red-700{
    --tw-text-opacity: 1;
    color: rgb(185 28 28 / var(--tw-text-opacity, 1));
}
.tw-text-red-800{
    --tw-text-opacity: 1;
    color: rgb(153 27 27 / var(--tw-text-opacity, 1));
}
.tw-text-red-950{
    --tw-text-opacity: 1;
    color: rgb(69 10 10 / var(--tw-text-opacity, 1));
}
.tw-text-sky-600{
    --tw-text-opacity: 1;
    color: rgb(2 132 199 / var(--tw-text-opacity, 1));
}
.tw-text-sky-800{
    --tw-text-opacity: 1;
    color: rgb(7 89 133 / var(--tw-text-opacity, 1));
}
.tw-text-sky-950{
    --tw-text-opacity: 1;
    color: rgb(8 47 73 / var(--tw-text-opacity, 1));
}
.tw-text-slate-500{
    --tw-text-opacity: 1;
    color: rgb(100 116 139 / var(--tw-text-opacity, 1));
}
.tw-text-slate-700{
    --tw-text-opacity: 1;
    color: rgb(51 65 85 / var(--tw-text-opacity, 1));
}
.tw-text-slate-900{
    --tw-text-opacity: 1;
    color: rgb(15 23 42 / var(--tw-text-opacity, 1));
}
.tw-text-violet-500{
    --tw-text-opacity: 1;
    color: rgb(139 92 246 / var(--tw-text-opacity, 1));
}
.tw-text-violet-950{
    --tw-text-opacity: 1;
    color: rgb(46 16 101 / var(--tw-text-opacity, 1));
}
.tw-text-white{
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.tw-text-zinc-600{
    --tw-text-opacity: 1;
    color: rgb(82 82 91 / var(--tw-text-opacity, 1));
}
.tw-text-zinc-900{
    --tw-text-opacity: 1;
    color: rgb(24 24 27 / var(--tw-text-opacity, 1));
}
.tw-underline{
    text-decoration-line: underline;
}
.tw-opacity-0{
    opacity: 0;
}
.tw-opacity-100{
    opacity: 1;
}
.tw-opacity-25{
    opacity: 0.25;
}
.tw-opacity-40{
    opacity: 0.4;
}
.tw-opacity-60{
    opacity: 0.6;
}
.tw-opacity-70{
    opacity: 0.7;
}
.tw-opacity-75{
    opacity: 0.75;
}
.tw-opacity-90{
    opacity: 0.9;
}
.tw-mix-blend-multiply{
    mix-blend-mode: multiply;
}
.tw-shadow{
    --tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-shadow-2xl{
    --tw-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    --tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-shadow-\[0_0_0_1px_\#fff\]{
    --tw-shadow: 0 0 0 1px #fff;
    --tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-shadow-\[0_0_0_9999px_rgba\(255\,255\,255\,0\.12\)\]{
    --tw-shadow: 0 0 0 9999px rgba(255,255,255,0.12);
    --tw-shadow-colored: 0 0 0 9999px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-shadow-\[0_2px_12px_rgba\(0\,0\,0\,0\.08\)\]{
    --tw-shadow: 0 2px 12px rgba(0,0,0,0.08);
    --tw-shadow-colored: 0 2px 12px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-shadow-\[0px_2px_6px_0px_rgba\(112\,76\,221\,0\.15\)\]{
    --tw-shadow: 0px 2px 6px 0px rgba(112,76,221,0.15);
    --tw-shadow-colored: 0px 2px 6px 0px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-shadow-\[inset_0px_4px_4px_0px_rgba\(255\,255\,255\,0\.15\)\]{
    --tw-shadow: inset 0px 4px 4px 0px rgba(255,255,255,0.15);
    --tw-shadow-colored: inset 0px 4px 4px 0px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-shadow-inner{
    --tw-shadow: inset 0 2px 4px 0 rgb(0 0 0 / 0.05);
    --tw-shadow-colored: inset 0 2px 4px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-shadow-lg{
    --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-shadow-md{
    --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-shadow-sm{
    --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-shadow-xl{
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-outline-none{
    outline: 2px solid transparent;
    outline-offset: 2px;
}
.tw-outline{
    outline-style: solid;
}
.tw-outline-1{
    outline-width: 1px;
}
.tw-outline-2{
    outline-width: 2px;
}
.tw-outline-\[0\.50px\]{
    outline-width: 0.50px;
}
.tw-outline-offset-\[-0\.50px\]{
    outline-offset: -0.50px;
}
.tw-outline-offset-\[-1px\]{
    outline-offset: -1px;
}
.tw-outline-offset-\[-2px\]{
    outline-offset: -2px;
}
.tw-outline-gray-200{
    outline-color: #e5e7eb;
}
.tw-outline-indigo-300{
    outline-color: #a5b4fc;
}
.tw-outline-slate-950\/5{
    outline-color: rgb(2 6 23 / 0.05);
}
.tw-ring-1{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.tw-ring-2{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.tw-ring-\[1\.5px\]{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1.5px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.tw-ring-transparent{
    --tw-ring-color: transparent;
}
.tw-ring-white{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(255 255 255 / var(--tw-ring-opacity, 1));
}
.tw-backdrop-blur{
    --tw-backdrop-blur: blur(8px);
    -webkit-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);
    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);
}
.tw-backdrop-blur-\[190px\]{
    --tw-backdrop-blur: blur(190px);
    -webkit-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);
    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);
}
.tw-backdrop-blur-sm{
    --tw-backdrop-blur: blur(4px);
    -webkit-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);
    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);
}
.tw-transition-all{
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}
.tw-transition-colors{
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}
.tw-transition-opacity{
    transition-property: opacity;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}
.tw-transition-shadow{
    transition-property: box-shadow;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}
.tw-transition-transform{
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}
.tw-duration-150{
    transition-duration: 150ms;
}
.tw-duration-200{
    transition-duration: 200ms;
}
.tw-duration-300{
    transition-duration: 300ms;
}
.tw-ease-in-out{
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
.tw-ease-out{
    transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}
/* Mobile-specific scrollbar */
.tw-no-scrollbar {
    overflow: hidden;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
.tw-no-scrollbar::-webkit-scrollbar {
    display: none;
  }
.tw-scrollbar-none {
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
.tw-scrollbar-none::-webkit-scrollbar {
    display: none;
  }
/* Font faces are injected at runtime by dynamicFontService or the bundled
   font imports used elsewhere in the app. */
/* Reset some default styles to avoid conflicts */
body {
  margin: 0;
  font-family:
    var(--font-body, "Manrope"),
    system-ui,
    -apple-system,
    sans-serif;
}
#cdn-app,
#root {
  min-height: 100vh;
}
/* Custom scrollbar styles for mobile */
.placeholder\:tw-text-gray-400::-moz-placeholder{
    --tw-text-opacity: 1;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}
.placeholder\:tw-text-gray-400::placeholder{
    --tw-text-opacity: 1;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}
.hover\:tw-scale-105:hover{
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05;
    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));
}
.hover\:tw-scale-110: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));
}
.hover\:tw-border-gray-300:hover{
    --tw-border-opacity: 1;
    border-color: rgb(209 213 219 / var(--tw-border-opacity, 1));
}
.hover\:tw-border-gray-400:hover{
    --tw-border-opacity: 1;
    border-color: rgb(156 163 175 / var(--tw-border-opacity, 1));
}
.hover\:tw-border-gray-600:hover{
    --tw-border-opacity: 1;
    border-color: rgb(75 85 99 / var(--tw-border-opacity, 1));
}
.hover\:tw-border-transparent:hover{
    border-color: transparent;
}
.hover\:tw-bg-\[\#DFE3FF\]:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(223 227 255 / var(--tw-bg-opacity, 1));
}
.hover\:tw-bg-black:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}
.hover\:tw-bg-blue-600:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(37 99 235 / var(--tw-bg-opacity, 1));
}
.hover\:tw-bg-gray-100:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1));
}
.hover\:tw-bg-gray-50:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1));
}
.hover\:tw-bg-gray-800:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1));
}
.hover\:tw-bg-red-500:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1));
}
.hover\:tw-bg-slate-50:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(248 250 252 / var(--tw-bg-opacity, 1));
}
.hover\:tw-bg-white:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.hover\:tw-bg-opacity-10:hover{
    --tw-bg-opacity: 0.1;
}
.hover\:tw-bg-opacity-100:hover{
    --tw-bg-opacity: 1;
}
.hover\:tw-bg-opacity-20:hover{
    --tw-bg-opacity: 0.2;
}
.hover\:tw-bg-opacity-80:hover{
    --tw-bg-opacity: 0.8;
}
.hover\:tw-bg-opacity-90:hover{
    --tw-bg-opacity: 0.9;
}
.hover\:tw-text-blue-600:hover{
    --tw-text-opacity: 1;
    color: rgb(37 99 235 / var(--tw-text-opacity, 1));
}
.hover\:tw-text-gray-400:hover{
    --tw-text-opacity: 1;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}
.hover\:tw-text-gray-600:hover{
    --tw-text-opacity: 1;
    color: rgb(75 85 99 / var(--tw-text-opacity, 1));
}
.hover\:tw-text-gray-700:hover{
    --tw-text-opacity: 1;
    color: rgb(55 65 81 / var(--tw-text-opacity, 1));
}
.hover\:tw-text-gray-800:hover{
    --tw-text-opacity: 1;
    color: rgb(31 41 55 / var(--tw-text-opacity, 1));
}
.hover\:tw-text-gray-900:hover{
    --tw-text-opacity: 1;
    color: rgb(17 24 39 / var(--tw-text-opacity, 1));
}
.hover\:tw-text-red-600:hover{
    --tw-text-opacity: 1;
    color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}
.hover\:tw-text-slate-900:hover{
    --tw-text-opacity: 1;
    color: rgb(15 23 42 / var(--tw-text-opacity, 1));
}
.hover\:tw-text-white:hover{
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.hover\:tw-underline:hover{
    text-decoration-line: underline;
}
.hover\:tw-opacity-90:hover{
    opacity: 0.9;
}
.hover\:tw-shadow-\[0_4px_16px_rgba\(0\2c 0\2c 0\2c 0\.12\)\]:hover{
    --tw-shadow: 0 4px 16px rgba(0,0,0,0.12);
    --tw-shadow-colored: 0 4px 16px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.hover\:tw-shadow-md:hover{
    --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.hover\:tw-shadow-sm:hover{
    --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.focus\:tw-border-\[var\(--gemtheon-primary\)\]:focus{
    border-color: var(--gemtheon-primary);
}
.focus\:tw-border-slate-300:focus{
    --tw-border-opacity: 1;
    border-color: rgb(203 213 225 / var(--tw-border-opacity, 1));
}
.focus\:tw-outline-none:focus{
    outline: 2px solid transparent;
    outline-offset: 2px;
}
.focus\:tw-ring-0:focus{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.focus\:tw-ring-2:focus{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.focus\:tw-ring-slate-200:focus{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(226 232 240 / var(--tw-ring-opacity, 1));
}
.focus\:tw-ring-offset-2:focus{
    --tw-ring-offset-width: 2px;
}
.focus-visible\:tw-border-slate-300:focus-visible{
    --tw-border-opacity: 1;
    border-color: rgb(203 213 225 / var(--tw-border-opacity, 1));
}
.focus-visible\:tw-outline-none:focus-visible{
    outline: 2px solid transparent;
    outline-offset: 2px;
}
.focus-visible\:tw-ring-2:focus-visible{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.focus-visible\:tw-ring-slate-200:focus-visible{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(226 232 240 / var(--tw-ring-opacity, 1));
}
.focus-visible\:tw-ring-slate-300:focus-visible{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(203 213 225 / var(--tw-ring-opacity, 1));
}
.active\:tw-border-transparent:active{
    border-color: transparent;
}
.active\:tw-text-white:active{
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.disabled\:tw-pointer-events-none:disabled{
    pointer-events: none;
}
.disabled\:tw-cursor-not-allowed:disabled{
    cursor: not-allowed;
}
.disabled\:tw-opacity-40:disabled{
    opacity: 0.4;
}
.disabled\:tw-opacity-50:disabled{
    opacity: 0.5;
}
.disabled\:tw-opacity-60:disabled{
    opacity: 0.6;
}
.disabled\:hover\:tw-border-gray-300:hover:disabled{
    --tw-border-opacity: 1;
    border-color: rgb(209 213 219 / var(--tw-border-opacity, 1));
}
.tw-group:hover .group-hover\:tw-scale-105{
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05;
    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));
}
.tw-group:hover .group-hover\:tw-scale-110{
    --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));
}
.tw-group:hover .group-hover\:tw-bg-gray-200{
    --tw-bg-opacity: 1;
    background-color: rgb(229 231 235 / var(--tw-bg-opacity, 1));
}
.tw-group:hover .group-hover\:tw-text-white{
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.tw-group:hover .group-hover\:tw-ring-gray-400{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(156 163 175 / var(--tw-ring-opacity, 1));
}
.data-\[stuck\]\:tw-rounded-md[data-stuck]{
    border-radius: 0.375rem;
}
.data-\[stuck\]\:tw-border[data-stuck]{
    border-width: 1px;
}
.data-\[stuck\]\:tw-border-gray-200[data-stuck]{
    --tw-border-opacity: 1;
    border-color: rgb(229 231 235 / var(--tw-border-opacity, 1));
}
.data-\[stuck\]\:tw-shadow-\[0_2px_8px_-4px_rgba\(0\2c 0\2c 0\2c 0\.18\)\][data-stuck]{
    --tw-shadow: 0 2px 8px -4px rgba(0,0,0,0.18);
    --tw-shadow-colored: 0 2px 8px -4px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.tw-group[data-stuck] .group-data-\[stuck\]\:tw-shadow-md{
    --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px 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 not all and (min-width: 1024px){
    .max-lg\:-tw-ml-\[5px\]{
        margin-left: -5px;
    }
    .max-lg\:tw-border-t-0{
        border-top-width: 0px;
    }
    .max-lg\:tw-pt-4{
        padding-top: 1rem;
    }
    .max-lg\:\!tw-text-xs{
        font-size: 0.75rem !important;
        line-height: 1rem !important;
    }
    .max-lg\:tw-text-xs{
        font-size: 0.75rem;
        line-height: 1rem;
    }
}
@media (min-width: 640px){
    .sm\:tw-right-3{
        right: 0.75rem;
    }
    .sm\:tw-top-3{
        top: 0.75rem;
    }
    .sm\:tw-order-1{
        order: 1;
    }
    .sm\:tw-order-2{
        order: 2;
    }
    .sm\:tw-order-4{
        order: 4;
    }
    .sm\:tw-my-6{
        margin-top: 1.5rem;
        margin-bottom: 1.5rem;
    }
    .sm\:tw-my-8{
        margin-top: 2rem;
        margin-bottom: 2rem;
    }
    .sm\:tw-mb-6{
        margin-bottom: 1.5rem;
    }
    .sm\:tw-mb-8{
        margin-bottom: 2rem;
    }
    .sm\:tw-mt-0{
        margin-top: 0px;
    }
    .sm\:tw-mt-4{
        margin-top: 1rem;
    }
    .sm\:tw-block{
        display: block;
    }
    .sm\:\!tw-flex{
        display: flex !important;
    }
    .sm\:tw-flex{
        display: flex;
    }
    .sm\:tw-hidden{
        display: none;
    }
    .sm\:tw-h-10{
        height: 2.5rem;
    }
    .sm\:tw-h-12{
        height: 3rem;
    }
    .sm\:tw-h-28{
        height: 7rem;
    }
    .sm\:tw-h-36{
        height: 9rem;
    }
    .sm\:tw-h-4{
        height: 1rem;
    }
    .sm\:tw-h-6{
        height: 1.5rem;
    }
    .sm\:tw-h-8{
        height: 2rem;
    }
    .sm\:tw-h-\[320px\]{
        height: 320px;
    }
    .sm\:tw-h-\[32px\]{
        height: 32px;
    }
    .sm\:tw-h-\[40px\]{
        height: 40px;
    }
    .sm\:tw-w-20{
        width: 5rem;
    }
    .sm\:tw-w-28{
        width: 7rem;
    }
    .sm\:tw-w-36{
        width: 9rem;
    }
    .sm\:tw-w-4{
        width: 1rem;
    }
    .sm\:tw-w-6{
        width: 1.5rem;
    }
    .sm\:tw-w-64{
        width: 16rem;
    }
    .sm\:tw-w-\[32px\]{
        width: 32px;
    }
    .sm\:tw-w-\[40px\]{
        width: 40px;
    }
    .sm\:tw-w-auto{
        width: auto;
    }
    .sm\:tw-w-fit{
        width: -moz-fit-content;
        width: fit-content;
    }
    .sm\:tw-w-full{
        width: 100%;
    }
    .sm\:tw-max-w-sm{
        max-width: 24rem;
    }
    .sm\:tw-flex-1{
        flex: 1 1 0%;
    }
    .sm\:tw-grid-cols-2{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .sm\:tw-flex-row{
        flex-direction: row;
    }
    .sm\:tw-flex-wrap{
        flex-wrap: wrap;
    }
    .sm\:tw-items-center{
        align-items: center;
    }
    .sm\:tw-justify-end{
        justify-content: flex-end;
    }
    .sm\:tw-justify-between{
        justify-content: space-between;
    }
    .sm\:tw-gap-2{
        gap: 0.5rem;
    }
    .sm\:tw-gap-3{
        gap: 0.75rem;
    }
    .sm\:tw-gap-4{
        gap: 1rem;
    }
    .sm\:tw-space-x-2 > :not([hidden]) ~ :not([hidden]){
        --tw-space-x-reverse: 0;
        margin-right: calc(0.5rem * var(--tw-space-x-reverse));
        margin-left: calc(0.5rem * calc(1 - var(--tw-space-x-reverse)));
    }
    .sm\:tw-border-0{
        border-width: 0px;
    }
    .sm\:tw-border-y-0{
        border-top-width: 0px;
        border-bottom-width: 0px;
    }
    .sm\:tw-border-t{
        border-top-width: 1px;
    }
    .sm\:tw-p-2{
        padding: 0.5rem;
    }
    .sm\:tw-p-6{
        padding: 1.5rem;
    }
    .sm\:tw-px-4{
        padding-left: 1rem;
        padding-right: 1rem;
    }
    .sm\:tw-px-8{
        padding-left: 2rem;
        padding-right: 2rem;
    }
    .sm\:tw-py-4{
        padding-top: 1rem;
        padding-bottom: 1rem;
    }
    .sm\:tw-py-8{
        padding-top: 2rem;
        padding-bottom: 2rem;
    }
    .sm\:tw-pl-0{
        padding-left: 0px;
    }
    .sm\:tw-pt-0{
        padding-top: 0px;
    }
    .sm\:\!tw-text-2xl{
        font-size: 1.5rem !important;
        line-height: 2rem !important;
    }
    .sm\:\!tw-text-base{
        font-size: 1rem !important;
        line-height: 1.5rem !important;
    }
    .sm\:\!tw-text-sm{
        font-size: 0.875rem !important;
        line-height: 1.25rem !important;
    }
    .sm\:\!tw-text-xl{
        font-size: 1.25rem !important;
        line-height: 1.75rem !important;
    }
    .sm\:\!tw-text-xs{
        font-size: 0.75rem !important;
        line-height: 1rem !important;
    }
    .sm\:tw-text-3xl{
        font-size: 1.875rem;
        line-height: 2.25rem;
    }
    .sm\:tw-text-base{
        font-size: 1rem;
        line-height: 1.5rem;
    }
    .sm\:tw-text-lg{
        font-size: 1.125rem;
        line-height: 1.75rem;
    }
    .sm\:tw-text-sm{
        font-size: 0.875rem;
        line-height: 1.25rem;
    }
    .sm\:tw-text-xl{
        font-size: 1.25rem;
        line-height: 1.75rem;
    }
    .sm\:tw-text-xs{
        font-size: 0.75rem;
        line-height: 1rem;
    }
}
@media (min-width: 768px){
    .md\:tw-mx-2{
        margin-left: 0.5rem;
        margin-right: 0.5rem;
    }
    .md\:tw-block{
        display: block;
    }
    .md\:tw-flex{
        display: flex;
    }
    .md\:tw-hidden{
        display: none;
    }
    .md\:tw-grid-cols-2{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .md\:tw-justify-start{
        justify-content: flex-start;
    }
    .md\:tw-gap-3{
        gap: 0.75rem;
    }
    .md\:tw-py-0{
        padding-top: 0px;
        padding-bottom: 0px;
    }
    .md\:tw-text-4xl{
        font-size: 2.25rem;
        line-height: 2.5rem;
    }
    .md\:tw-text-xs{
        font-size: 0.75rem;
        line-height: 1rem;
    }
}
@media (min-width: 1024px){
    .lg\:tw-top-0{
        top: 0px;
    }
    .lg\:tw-order-1{
        order: 1;
    }
    .lg\:tw-order-2{
        order: 2;
    }
    .lg\:tw-order-3{
        order: 3;
    }
    .lg\:tw-col-span-2{
        grid-column: span 2 / span 2;
    }
    .lg\:tw-row-span-2{
        grid-row: span 2 / span 2;
    }
    .lg\:tw-m-8{
        margin: 2rem;
    }
    .lg\:tw-mx-4{
        margin-left: 1rem;
        margin-right: 1rem;
    }
    .lg\:tw-mx-auto{
        margin-left: auto;
        margin-right: auto;
    }
    .lg\:tw-mb-0{
        margin-bottom: 0px;
    }
    .lg\:tw-ml-0{
        margin-left: 0px;
    }
    .lg\:tw-ml-\[7px\]{
        margin-left: 7px;
    }
    .lg\:tw-mt-0{
        margin-top: 0px;
    }
    .lg\:tw-block{
        display: block;
    }
    .lg\:tw-flex{
        display: flex;
    }
    .lg\:tw-grid{
        display: grid;
    }
    .lg\:tw-hidden{
        display: none;
    }
    .lg\:tw-h-\[380px\]{
        height: 380px;
    }
    .lg\:tw-h-\[90svh\]{
        height: 90svh;
    }
    .lg\:tw-h-\[calc\(88svh-56px\)\]{
        height: calc(88svh - 56px);
    }
    .lg\:tw-max-h-\[90svh\]{
        max-height: 90svh;
    }
    .lg\:tw-w-1\/2{
        width: 50%;
    }
    .lg\:tw-w-48{
        width: 12rem;
    }
    .lg\:tw-w-\[30rem\]{
        width: 30rem;
    }
    .lg\:tw-w-\[80vw\]{
        width: 80vw;
    }
    .lg\:tw-max-w-7xl{
        max-width: 80rem;
    }
    .lg\:tw-max-w-\[720px\]{
        max-width: 720px;
    }
    .lg\:tw-max-w-\[80vw\]{
        max-width: 80vw;
    }
    .lg\:tw-grid-cols-2{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .lg\:tw-grid-cols-3{
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .lg\:tw-grid-cols-4{
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
    .lg\:tw-grid-cols-\[24rem_minmax\(0\2c 1fr\)\]{
        grid-template-columns: 24rem minmax(0,1fr);
    }
    .lg\:tw-flex-row{
        flex-direction: row;
    }
    .lg\:tw-items-start{
        align-items: flex-start;
    }
    .lg\:tw-items-center{
        align-items: center;
    }
    .lg\:tw-gap-3{
        gap: 0.75rem;
    }
    .lg\:tw-gap-4{
        gap: 1rem;
    }
    .lg\:tw-gap-6{
        gap: 1.5rem;
    }
    .lg\:tw-space-x-6 > :not([hidden]) ~ :not([hidden]){
        --tw-space-x-reverse: 0;
        margin-right: calc(1.5rem * var(--tw-space-x-reverse));
        margin-left: calc(1.5rem * calc(1 - var(--tw-space-x-reverse)));
    }
    .lg\:tw-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));
    }
    .lg\:tw-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));
    }
    .lg\:tw-overflow-y-auto{
        overflow-y: auto;
    }
    .lg\:tw-rounded-\[10px\]{
        border-radius: 10px;
    }
    .lg\:tw-border-0{
        border-width: 0px;
    }
    .lg\:tw-border-y{
        border-top-width: 1px;
        border-bottom-width: 1px;
    }
    .lg\:tw-border-b{
        border-bottom-width: 1px;
    }
    .lg\:tw-border-gray-200{
        --tw-border-opacity: 1;
        border-color: rgb(229 231 235 / var(--tw-border-opacity, 1));
    }
    .lg\:tw-p-6{
        padding: 1.5rem;
    }
    .lg\:tw-p-8{
        padding: 2rem;
    }
    .lg\:tw-px-2{
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }
    .lg\:tw-px-6{
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
    .lg\:tw-px-8{
        padding-left: 2rem;
        padding-right: 2rem;
    }
    .lg\:tw-py-0{
        padding-top: 0px;
        padding-bottom: 0px;
    }
    .lg\:tw-py-2\.5{
        padding-top: 0.625rem;
        padding-bottom: 0.625rem;
    }
    .lg\:tw-py-3{
        padding-top: 0.75rem;
        padding-bottom: 0.75rem;
    }
    .lg\:tw-py-4{
        padding-top: 1rem;
        padding-bottom: 1rem;
    }
    .lg\:tw-py-6{
        padding-top: 1.5rem;
        padding-bottom: 1.5rem;
    }
    .lg\:tw-pb-6{
        padding-bottom: 1.5rem;
    }
    .lg\:tw-pb-8{
        padding-bottom: 2rem;
    }
    .lg\:tw-pt-0{
        padding-top: 0px;
    }
    .lg\:tw-pt-4{
        padding-top: 1rem;
    }
    .lg\:tw-pt-8{
        padding-top: 2rem;
    }
    .lg\:tw-text-2xl{
        font-size: 1.5rem;
        line-height: 2rem;
    }
    .lg\:tw-text-3xl{
        font-size: 1.875rem;
        line-height: 2.25rem;
    }
    .lg\:tw-text-4xl{
        font-size: 2.25rem;
        line-height: 2.5rem;
    }
    .lg\:tw-text-base{
        font-size: 1rem;
        line-height: 1.5rem;
    }
    .lg\:tw-text-lg{
        font-size: 1.125rem;
        line-height: 1.75rem;
    }
}
@media (min-width: 1280px){
    .xl\:tw-block{
        display: block;
    }
}
/* App styles */
#leva__root {
    display: none;
}/* ===== DIAMOND THEME - CUSTOM STYLES ===== */
/* 
 * Senior Developer Optimized Version
 * Features:
 * - CSS Custom Properties for maintainability
 * - Logical grouping and organization
 * - Improved specificity and performance
 * - Better responsive design patterns
 * - Cleaner structure and naming conventions
 * 
 * Note: Variables use --gemtheon-* prefix for consistency with dynamic theme API
 */

/* Fonts are injected dynamically from API via theme/fonts endpoint */

/* ===== CSS CUSTOM PROPERTIES ===== */
:root {
  /* ===== DESIGN SYSTEM COLORS ===== */

  /* Base Colors */
  --color-white: #ffffff;
  --color-dark-blue-title: #0f0d72;
  --color-black-header: #000000;

  /* Gray Scale */
  --color-gray-1-body: #585a5c;
  --color-gray-2-sub: #666666;
  --color-gray-3-disable: #999999;
  --color-gray-4-line-border: #e8e8e8;
  --color-gray-5-background: #f9f9f9;

  /* Secondary Colors */
  --color-secondary-1: #a1acff;
  --color-secondary-2: #dfe3ff;
  --color-secondary-3: #ecdffb;
  --color-secondary-4: #f2bbff;
  --color-secondary-5: #bdeaff;
  --color-secondary-6: #eff1ff;
  --color-secondary-6-bg-button: #f8f8ff;

  /* Linear Gradient Colors */
  --color-linear-1: #0f0d72;
  --color-linear-2: #4a3c99;
  --color-linear-3: #a1acff;

  /* ===== GEMTHEON THEME VARIABLES (Dynamic Theme API compatible) ===== */
  /* These are fallback values, will be overridden by API when provided */
  --gemtheon-primary: #7f5af0;
  --gemtheon-secondary: #f9f9f9;
  --gemtheon-tertiary: #ffffff;
  --gemtheon-accent: #7f5af0;
  --gemtheon-light: #ffffff;
  --gemtheon-dark: #0f0d72;
  --gemtheon-neutral: #999999;
  --gemtheon-gold: #edbd22;

  /* Backward compatibility: --color-primary now references --gemtheon-primary */
  /* This ensures when API injects --gemtheon-primary, --color-primary also updates */
  --color-primary: var(--gemtheon-primary);

  /* Gradients (left-to-right, two stops) */
  /* Note: These are fallback gradients. Dynamic theme API will override with auto-generated gradients */
  /* Use --gemtheon-dark for gradient start, --gemtheon-primary for gradient end */
  --gemtheon-primary-gradient: linear-gradient(
    90deg,
    var(--gemtheon-dark) 0%,
    var(--gemtheon-primary) 100%
  );
  --gemtheon-primary-gradient-hover: linear-gradient(
    90deg,
    var(--gemtheon-light) 0%,
    var(--gemtheon-accent) 100%
  );
  --color-primary-gradient: var(--gemtheon-primary-gradient);
  --linear-1: linear-gradient(
    90deg,
    var(--gemtheon-dark) 0%,
    var(--gemtheon-primary) 100%
  );

  /* ===== DIAMOND SCORING (brand-tied) ===== */
  /* All tokens reference --gemtheon-* so changing the theme (static edit or the
     dynamic-theme API that overrides --gemtheon-primary/-gold/...) automatically
     re-colors every scoring template — no per-component change needed. */
  --gemtheon-score-track: color-mix(in srgb, var(--gemtheon-primary) 12%, #ffffff);
  --gemtheon-score-fill: var(--gemtheon-primary);
  --gemtheon-score-fill-gradient: var(--gemtheon-primary-gradient);
  --gemtheon-score-on-fill: #ffffff;
  /* Grade tiers run along the brand ramp primary → gold. */
  --gemtheon-score-grade-high: var(--gemtheon-gold, #edbd22); /* A+/A */
  --gemtheon-score-grade-good: var(--gemtheon-primary, #7f5af0); /* B+/B */
  --gemtheon-score-grade-mid: color-mix(
    in srgb,
    var(--gemtheon-primary) 55%,
    var(--gemtheon-gold) 45%
  ); /* C+/C */
  --gemtheon-score-grade-low: var(--gemtheon-neutral, #999999); /* D */

  /* Spacing */
  --gemtheon-spacing-xs: 0.25rem;
  --gemtheon-spacing-sm: 0.5rem;
  --gemtheon-spacing-md: 0.75rem;
  --gemtheon-spacing-lg: 1.25rem;

  /* Transitions */
  --gemtheon-transition-fast: 0.2s ease;
  --gemtheon-transition-normal: 0.3s ease;

  /* Shadows */
  --gemtheon-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --gemtheon-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  --gemtheon-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);

  /* Border Radius */
  --gemtheon-radius-sm: 2px;
  --gemtheon-radius-md: 4px;
  --gemtheon-radius-lg: 8px;
  --gemtheon-radius-xl: 12px;
  --gemtheon-radius-full: 9999px;
  --gemtheon-dot-bg: var(--gemtheon-accent);

  --di-gold: var(--gemtheon-primary);
  --di-cream: var(--gemtheon-light);
  --di-border: var(--gemtheon-dark);
  --di-muted: var(--gemtheon-neutral);

  /* ===== DESIGN SYSTEM TYPOGRAPHY SYSTEM ===== */

  /* Font Families */
  --font-heading: "Be Vietnam Pro", sans-serif;
  --font-body: "Manrope", sans-serif;
  --font-display: "Be Vietnam Pro", sans-serif;

  /* Line Heights */
  --line-height-heading: 120%;
  --line-height-body: 140%;
  --line-height-display: 100%;

  /* Heading Sizes (Be Vietnam Pro) */
  --h1-size: 64px;
  --h2-size: 56px;
  --h3-size: 44px;
  --h4-size: 36px;
  --h5-size: 32px;
  --h6-size: 28px;

  /* Heading Weights */
  --h1-weight: 800;
  --h2-weight: 700;
  --h3-weight: 700;
  --h4-weight: 600;
  --h5-weight: 600;
  --h6-weight: 600;

  /* Body Sizes (Manrope) */
  --body-xl-size: 24px;
  --body-lg-size: 20px;
  --body-md-size: 16px;
  --body-sm-size: 14px;
  --body-s2-size: 13px;
  --body-xs-size: 12px;
  --body-xxs-size: 10px;

  /* Body Weights */
  --font-weight-bold: 700;
  --font-weight-semibold: 600;
  --font-weight-regular: 400;
  --font-weight-light: 300;

  /* Display Sizes */
  --display-1-size: 56px;
  --display-2-size: 36px;
  --display-3-size: 20px;
  --display-4-size: 12px;
  --display-5-size: 10px;

  /* Display Weight */
  --display-weight: 400;
}

/* Chrome, Edge, Safari */
::-webkit-scrollbar {
  width: 3px;
  height: 3px;
  background: #f3f3f3;
}

::-webkit-scrollbar-thumb {
  background: var(--gemtheon-primary, #1e90ff);
  border-radius: 8px;
}

::-webkit-scrollbar-track {
  background: #f3f3f3;
  border-radius: 8px;
}

.custom-scrollbar::-webkit-scrollbar {
  width: 2px;
  height: 2px;
  background: #f3f3f3;
}

.custom-scrollbar::-webkit-scrollbar-thumb {
  background: var(--gemtheon-primary, #1e90ff);
  border-radius: 8px;
}

.custom-scrollbar::-webkit-scrollbar-track {
  background: #f3f3f3;
  border-radius: 8px;
}

.custom-scrollbar {
  scrollbar-width: thin;
  scrollbar-color: var(--gemtheon-primary, #1e90ff) #f3f3f3;
}

.custom-scrollbar::-webkit-scrollbar-thumb:hover {
  background: var(--gemtheon-primary, #1870c7);
}

/* ===== BASE STYLES ===== */
/* Background Colors */
.tw-bg-primary {
  background-color: var(--gemtheon-secondary);
}

.tw-bg-secondary {
  background: var(--gemtheon-primary-gradient);
}

.tw-bg-tertiary {
  background-color: var(--gemtheon-tertiary);
}

/* Text Colors */
.tw-text-primary {
  color: var(--gemtheon-primary);
}

.tw-text-secondary {
  color: var(--gemtheon-light);
}

/* Border Colors */
.tw-border-dark-blue {
  border-color: var(--gemtheon-dark);
}

.tw-border-primary {
  border-color: var(--gemtheon-primary);
}

.tw-border-secondary {
  border-color: var(--gemtheon-secondary);
}

.tw-border-tertiary {
  border-color: var(--gemtheon-tertiary);
}

.tw-border-accent {
  border-color: var(--gemtheon-accent);
}

.tw-border-neutral {
  border-color: var(--gemtheon-neutral);
}

.tw-border-gold {
  border-color: var(--gemtheon-gold);
}

.tw-border-shape {
  border-color: var(--gemtheon-primary);
}

/* Interactive Elements */
.tw-bg-slider-handle {
  background-color: var(--gemtheon-accent);
}

.tw-bg-checkbox {
  accent-color: var(--gemtheon-accent);
}

.tw-bg-button {
  background-color: var(--gemtheon-tertiary);
}

/* ===== DESIGN SYSTEM UTILITY CLASSES ===== */

/* Background Colors */
.tw-bg-white {
  background-color: var(--color-white);
}
.tw-bg-gray-1 {
  background-color: var(--color-gray-1-body);
}
.tw-bg-gray-2 {
  background-color: var(--color-gray-2-sub);
}
.tw-bg-gray-3 {
  background-color: var(--color-gray-3-disable);
}
.tw-bg-gray-4 {
  background-color: var(--color-gray-4-line-border);
}
.tw-bg-gray-5 {
  background-color: var(--color-gray-5-background);
}
.tw-bg-secondary-1 {
  background-color: var(--color-secondary-1);
}
.tw-bg-secondary-2 {
  background-color: var(--color-secondary-2);
}
.tw-bg-secondary-3 {
  background-color: var(--color-secondary-3);
}
.tw-bg-secondary-4 {
  background-color: var(--color-secondary-4);
}
.tw-bg-secondary-5 {
  background-color: var(--color-secondary-5);
}
.tw-bg-secondary-6 {
  background-color: var(--color-secondary-6-bg-button);
}

/* Text Colors */
.tw-text-white {
  color: var(--color-white);
}
.tw-text-dark-blue {
  color: var(--gemtheon-dark);
}
.tw-text-black {
  color: var(--color-black-header);
}
.tw-text-gray-1 {
  color: var(--color-gray-1-body);
}
.tw-text-gray-2 {
  color: var(--color-gray-2-sub);
}
.tw-text-gray-3 {
  color: var(--color-gray-3-disable);
}
.tw-text-secondary-1 {
  color: var(--color-secondary-1);
}

/* Border Colors */
.tw-border-gray-4 {
  border-color: var(--color-gray-4-line-border);
}
.tw-border-secondary-1 {
  border-color: var(--color-secondary-1);
}

/* Gradient Backgrounds */
.tw-bg-primary-gradient {
  background: var(--gemtheon-primary-gradient);
}
.tw-bg-linear-gradient {
  background: linear-gradient(
    90deg,
    var(--gemtheon-dark) 0%,
    var(--gemtheon-primary) 50%,
    var(--gemtheon-accent) 100%
  );
}

:where(.tw-bg-gradient--hover) {
  position: relative;
  isolation: isolate;
}

.tw-bg-gradient--hover::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--gemtheon-primary-gradient-hover);
  opacity: 0;
  transition: opacity 200ms ease;
  pointer-events: none;
  z-index: -1;
}

.tw-bg-gradient--hover:hover::before,
.tw-bg-gradient--hover:active::before {
  opacity: 1;
}

/* Button radius helpers driven by dynamic theme tokens */
.gemtheon-button-radius-rounded {
  border-radius: var(--gemtheon-radius-lg);
}

.gemtheon-button-radius-pill {
  border-radius: var(--gemtheon-radius-full);
}

.gemtheon-button-radius-square {
  border-radius: 0;
}

.gemtheon-radius-sm {
  border-radius: var(--gemtheon-radius-sm);
}

.gemtheon-radius-md {
  border-radius: var(--gemtheon-radius-md);
}

.gemtheon-radius-lg {
  border-radius: var(--gemtheon-radius-lg);
}

.gemtheon-radius-pill {
  border-radius: var(--gemtheon-radius-full);
}

.gemtheon-radius-top-lg {
  border-top-left-radius: var(--gemtheon-radius-lg);
  border-top-right-radius: var(--gemtheon-radius-lg);
}

.gemtheon-radius-bottom-lg {
  border-bottom-left-radius: var(--gemtheon-radius-lg);
  border-bottom-right-radius: var(--gemtheon-radius-lg);
}

.gemtheon-radius-left-pill {
  border-top-left-radius: var(--gemtheon-radius-full);
  border-bottom-left-radius: var(--gemtheon-radius-full);
}

.gemtheon-radius-right-pill {
  border-top-right-radius: var(--gemtheon-radius-full);
  border-bottom-right-radius: var(--gemtheon-radius-full);
}

/* Tailwind radius utility overrides so existing tw-rounded-* classes become dynamic */
.tw-rounded-none {
  border-radius: 0;
}

.tw-rounded-sm {
  border-radius: var(--gemtheon-radius-sm);
}

.tw-rounded,
.tw-rounded-md {
  border-radius: var(--gemtheon-radius-md);
}

.tw-rounded-lg {
  border-radius: var(--gemtheon-radius-lg);
}

.tw-rounded-xl {
  border-radius: var(--gemtheon-radius-xl);
}

.tw-rounded-full {
  border-radius: var(--gemtheon-radius-full);
}

.tw-rounded-t-none {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.tw-rounded-t-lg {
  border-top-left-radius: var(--gemtheon-radius-lg);
  border-top-right-radius: var(--gemtheon-radius-lg);
}

.tw-rounded-b-lg {
  border-bottom-left-radius: var(--gemtheon-radius-lg);
  border-bottom-right-radius: var(--gemtheon-radius-lg);
}

.tw-rounded-l-md {
  border-top-left-radius: var(--gemtheon-radius-md);
  border-bottom-left-radius: var(--gemtheon-radius-md);
}

.tw-rounded-r-md {
  border-top-right-radius: var(--gemtheon-radius-md);
  border-bottom-right-radius: var(--gemtheon-radius-md);
}

.tw-rounded-l-lg {
  border-top-left-radius: var(--gemtheon-radius-lg);
  border-bottom-left-radius: var(--gemtheon-radius-lg);
}

.tw-rounded-r-lg {
  border-top-right-radius: var(--gemtheon-radius-lg);
  border-bottom-right-radius: var(--gemtheon-radius-lg);
}

.tw-rounded-l-full {
  border-top-left-radius: var(--gemtheon-radius-full);
  border-bottom-left-radius: var(--gemtheon-radius-full);
}

.tw-rounded-r-full {
  border-top-right-radius: var(--gemtheon-radius-full);
  border-bottom-right-radius: var(--gemtheon-radius-full);
}

.tw-rounded-br,
.tw-rounded-br-md {
  border-bottom-right-radius: var(--gemtheon-radius-md);
}

.tw-rounded-br-lg {
  border-bottom-right-radius: var(--gemtheon-radius-lg);
}

/* Headings */
.tw-h1 {
  font-family: var(--font-heading);
  font-size: var(--h1-size);
  font-weight: var(--h1-weight);
  line-height: var(--line-height-heading);
}

.tw-h2 {
  font-family: var(--font-heading);
  font-size: var(--h2-size);
  font-weight: var(--h2-weight);
  line-height: var(--line-height-heading);
}

.tw-h3 {
  font-family: var(--font-heading);
  font-size: var(--h3-size);
  font-weight: var(--h3-weight);
  line-height: var(--line-height-heading);
}

.tw-h4 {
  font-family: var(--font-heading);
  font-size: var(--h4-size);
  font-weight: var(--h4-weight);
  line-height: var(--line-height-heading);
}

.tw-h5 {
  font-family: var(--font-heading);
  font-size: var(--h5-size);
  font-weight: var(--h5-weight);
  line-height: var(--line-height-heading);
}

.tw-h6 {
  font-family: var(--font-heading);
  font-size: var(--h6-size);
  font-weight: var(--h6-weight);
  line-height: var(--line-height-heading);
}

/* Body */
.tw-body-xl {
  font-family: var(--font-body);
  font-size: var(--body-xl-size);
  line-height: var(--line-height-body);
}

.tw-body-lg {
  font-family: var(--font-body);
  font-size: var(--body-lg-size);
  line-height: var(--line-height-body);
}

.tw-body-md {
  font-family: var(--font-body);
  font-size: var(--body-md-size);
  line-height: var(--line-height-body);
}

.tw-body-sm {
  font-family: var(--font-body);
  font-size: var(--body-sm-size);
  line-height: var(--line-height-body);
}

.tw-body-s2 {
  font-family: var(--font-body);
  font-size: var(--body-s2-size);
  line-height: var(--line-height-body);
}

.tw-body-xs {
  font-family: var(--font-body);
  font-size: var(--body-xs-size);
  line-height: var(--line-height-body);
}

.tw-body-xxs {
  font-family: var(--font-body);
  font-size: var(--body-xxs-size);
  line-height: var(--line-height-body);
}

/* Display */

.tw-display-1 {
  font-family: var(--font-display);
  font-size: var(--display-1-size);
  font-weight: var(--display-weight);
  line-height: var(--line-height-display);
}

.tw-display-2 {
  font-family: var(--font-display);
  font-size: var(--display-2-size);
  font-weight: var(--display-weight);
  line-height: var(--line-height-display);
}

.tw-display-3 {
  font-family: var(--font-display);
  font-size: var(--display-3-size);
  font-weight: var(--display-weight);
  line-height: var(--line-height-display);
}

.tw-display-4 {
  font-family: var(--font-display);
  font-size: var(--display-4-size);
  font-weight: var(--display-weight);
  line-height: var(--line-height-display);
}

.tw-display-5 {
  font-family: var(--font-display);
  font-size: var(--display-5-size);
  font-weight: var(--display-weight);
  line-height: var(--line-height-display);
}

/* ===== COMPONENT STYLES ===== */
.tw-fw-300 {
  font-weight: 300;
}

/* ===== SLIDER HANDLES ===== */
.gemtheon-slider-handle {
  position: relative;
  border-radius: 50%;
  transform-origin: center center;
}

.gemtheon-slider-handle:hover {
  transform: translateX(-50%) rotate(45deg) scale(1.1);
}

.gemtheon-slider-handle-inner {
  width: 16px;
  height: 16px;
  background: var(--gemtheon-primary);
  border-radius: 50%;
}

.gemtheon-slider-handle-inner:hover {
  background: var(--gemtheon-primary-gradient);
}

/* ===== SHAPE BUTTONS ===== */
.gemtheon-shape-button {
  position: relative;
  transition: all var(--gemtheon-transition-fast);
  transform: scale(1);
  cursor: pointer;
}

.gemtheon-shape-button:hover {
  transform: scale(1.05);
  box-shadow: var(--gemtheon-shadow-md);
}

.gemtheon-shape-button.selected {
  box-shadow: var(--gemtheon-shadow-md);
  transform: scale(1.02);
}

.gemtheon-shape-button:active {
  transform: scale(0.98);
}

/* ===== RANK LABELS ===== */
.gemtheon-rank-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--gemtheon-spacing-xs);
}

.gemtheon-rank-label .rank-name {
  color: var(--gemtheon-primary);
}

.gemtheon-rank-label .rank-number {
  color: var(--gemtheon-neutral);
}

.gemtheon-info-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  line-height: 0;
}

.gemtheon-info-icon:focus-visible {
  outline: none;
  border-radius: 50%;
  box-shadow: 0 0 0 2px rgb(from var(--gemtheon-primary) r g b / 0.3);
}

/* ===== INPUT FIELDS ===== */
.gemtheon-input-field {
  transition:
    border-color var(--gemtheon-transition-fast),
    box-shadow var(--gemtheon-transition-fast);
}

.gemtheon-input-field:focus {
  outline: none;
  border-color: transparent;
  box-shadow: 0 0 0 3px rgba(194, 176, 152, 0.2);
}

/* ===== RANGE DISPLAY ===== */
.gemtheon-range-display,
.gemtheon-range-base-display {
  background: var(--gemtheon-accent);
  color: var(--gemtheon-light);
  border-radius: var(--gemtheon-radius-xl);
  text-align: center;
}

.gemtheon-range-display:hover,
.gemtheon-range-base-display:hover {
  background: var(--gemtheon-accent);
  box-shadow: var(--gemtheon-shadow-sm);
}

/* ===== ADVANCED TOGGLE ===== */
.gemtheon-advanced-toggle {
  transition: all var(--gemtheon-transition-fast);
}

.gemtheon-advanced-toggle.expanded svg {
  transform: rotate(180deg);
  transition: transform var(--gemtheon-transition-normal);
}

/* ===== UTILITY CLASSES ===== */
.gemtheon-fade-in {
  animation: fadeIn var(--gemtheon-transition-normal) ease-in-out;
}

.gemtheon-slide-up {
  animation: slideUp var(--gemtheon-transition-normal) ease-out;
}

/* Ensure carousel container has proper width */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

/* Debug: Ensure mobile carousel is visible */
@media (max-width: 1023px) {
  .slick-slider {
    display: block !important;
  }

  .slick-list {
    overflow: hidden !important;
  }

  .slick-track {
    display: flex !important;
  }
}

/* Reduce spacing between carousel items */
.slick-slide {
  padding-left: 2px !important;
  padding-right: 2px !important;
}

.slick-slide > div {
  margin-left: 1px !important;
  margin-right: 1px !important;
}

.gemtheon-option-carousel .slick-list {
  overflow: visible !important;
  padding-left: 4px !important;
  padding-right: 4px !important;
}

.gemtheon-option-carousel .slick-slide {
  padding-left: 4px !important;
  padding-right: 4px !important;
}

.gemtheon-option-carousel .slick-slide > div {
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-top: 2px;
  padding-bottom: 2px;
}

.style-mobile-carousel .slick-list {
  overflow: hidden !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.style-mobile-carousel .slick-slide {
  padding-left: 2px !important;
  padding-right: 2px !important;
}

/* Specific spacing for Style carousel - make it tighter */
.style-carousel .slick-slide {
  padding-left: 1px !important;
  padding-right: 1px !important;
}

.style-carousel .slick-slide > div {
  margin-left: 0px !important;
  margin-right: 0px !important;
}

/* ===== ANIMATIONS ===== */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ===== RESPONSIVE DESIGN ===== */
@media (max-width: 480px) {
  /* Mobile-only - Hide step numbers and details */
  /* Mobile-specific adjustments */
  .gemtheon-slider-handle {
    width: var(--gemtheon-spacing-lg);
    height: var(--gemtheon-spacing-lg);
  }

  /* .gemtheon-slider-handle-inner {
    width: 0.75rem;
    height: 0.75rem;
  } */

  .gemtheon-shape-button:hover {
    transform: scale(1.02); /* Reduced scale on mobile */
  }

  .gemtheon-selected-tag {
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
  }

  /* Step Indicator Mobile Responsive - Keep horizontal layout but simplify content */
  .di-step {
    min-height: 40px !important;
    padding: 12px 6px !important;
  }

  .di-left {
    gap: 0px !important; /* Remove gap since we're hiding the index section */
  }

  .di-index {
    display: none !important; /* Hide step numbers and status dots on mobile */
  }

  .di-txt {
    width: 100% !important;
    text-align: center !important; /* Center the title since no number/dot */
  }

  .di-title {
    font-size: 11px !important;
    white-space: nowrap;
    font-weight: 500;
  }

  .di-suptitle {
    display: none !important; /* Hide "STEP X" text on mobile */
  }

  .di-sub {
    display: none !important; /* Hide subtitle details on mobile */
  }

  .di-price {
    display: none !important; /* Hide price on mobile */
  }

  .di-links {
    display: flex !important; /* Keep View/Change links on mobile */
    margin-left: 0 !important;
    justify-content: center;
    gap: 8px !important;
  }

  .di-links span {
    font-size: 9px !important;
  }

  .di-meta {
    display: none !important; /* Hide entire meta section on mobile */
  }
}

/* Tablet and larger mobile - Show step numbers and some details */
@media (min-width: 481px) and (max-width: 768px) {
  .di-index {
    display: flex; /* Show step numbers and dots back on tablet */
  }

  .di-left {
    gap: 8px; /* Restore gap for tablet */
  }

  .di-txt {
    text-align: left; /* Left align text when index is visible */
  }

  .di-suptitle {
    display: block;
    font-size: 9px;
  }

  .di-title {
    font-size: 12px;
  }

  .di-num {
    font-size: 15px;
  }

  .di-step {
    min-height: 55px;
    padding: 12px 10px;
  }
}

/* Desktop - Show all step indicator details */
@media (min-width: 769px) {
  .di-index {
    display: flex !important;
  }

  .di-left {
    gap: 12px !important;
  }

  .di-txt {
    text-align: left !important;
  }

  .di-suptitle {
    display: block !important;
  }

  .di-sub {
    display: block !important;
  }

  .di-price {
    display: block !important;
  }

  .di-links {
    display: flex !important;
  }

  .di-meta {
    display: flex !important;
  }
}

@media (max-width: 480px) {
  /* Small mobile adjustments for diamond components */
  .gemtheon-range-display,
  .gemtheon-range-base-display {
    padding: var(--gemtheon-spacing-xs) var(--gemtheon-spacing-sm);
    font-size: 0.875rem;
  }

  .gemtheon-rank-label .rank-name {
    font-size: 0.875rem;
  }
}

/* ===== ACCESSIBILITY IMPROVEMENTS ===== */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .gemtheon-slider-handle,
  .gemtheon-shape-button,
  .gemtheon-selected-tag,
  .gemtheon-range-display,
  .gemtheon-range-base-display {
    transition: none;
  }
}

* {
  scrollbar-width: thin;
  scrollbar-color: var(--gemtheon-primary, #1e90ff) #f3f3f3;
}

.di-container {
  display: flex;
  border: 1px solid var(--di-border);
  /* overflow: hidden; */
  border-radius: 10px;
}

.di-step {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1 1 0%;
  /* height: 80px; */
  padding: 12px 8px;
  background: var(--di-cream);
  transition: background 0.2s ease;
  text-align: left;
  z-index: 1;
}

/* .di-step:first-of-type {
  border-top-left-radius: 9px;
  border-bottom-left-radius: 9px;
}

.di-step:last-of-type {
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
} */

.di-step--active {
  background: var(--linear-1);
  color: #fff;
  z-index: 3;
}
.di-step--done {
  background: var(--gemtheon-light);
  outline: var(--gemtheon-dark);
}
.di-step--idle {
  background: var(--gemtheon-light);
  outline: var(--gemtheon-dark);
}

.di-left {
  display: flex;
  gap: 12px;
  align-items: center;
  flex: 1;
  min-width: 0;
}
.di-index {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding-top: 2px;
  width: 48px;
}
.di-num {
  font-weight: 700;
  font-size: 28px;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.di-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  outline: 1px solid rgba(0, 0, 0, 0.25);
  outline-offset: 1px;
  background: transparent;
}
.di-step--active .di-dot {
  outline-color: rgba(255, 255, 255, 0.6);
}
.di-dot--on {
  background: #9b8d78;
}

.di-txt {
  min-width: 0;
  flex: 1;
}
.di-suptitle {
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--di-muted);
}
.di-suptitle--light {
  color: rgba(255, 255, 255, 0.85);
}

.di-title-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 8px;
}
.di-title {
  font-size: 14px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.di-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #111;
}
.di-meta--light {
  color: rgba(255, 255, 255, 0.9);
}

.di-sub {
  max-width: 38ch;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.di-price {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.di-links {
  display: flex;
  gap: 12px;
  color: var(--color-gray-1-body);
}
.di-links--light {
  color: rgba(255, 255, 255, 0.9);
}
.di-links span {
  font-size: 12px;
  letter-spacing: 0.06em;
  cursor: pointer;
}

/* ===== STEP INDICATOR CHEVRON SHAPES =====
   Each step is shaped via clip-path so its background gradient flows
   continuously through the chevron tip. No SVG arrows are needed. */

.di-shape {
  position: relative;
}

.di-shape--first {
  clip-path: polygon(
    0 0,
    calc(100% - 28px) 0,
    100% 50%,
    calc(100% - 28px) 100%,
    0 100%
  );
  padding-right: 36px;
}

.di-shape--middle {
  clip-path: polygon(
    0 0,
    calc(100% - 28px) 0,
    100% 50%,
    calc(100% - 28px) 100%,
    0 100%,
    28px 50%
  );
  padding-left: 36px;
  padding-right: 36px;
  margin-left: -28px;
}

.di-shape--last {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 28px 50%);
  padding-left: 36px;
  margin-left: -28px;
}

@media (max-width: 480px) {
  /* .di-shape--first,
  .di-shape--middle,
  .di-shape--last {
    clip-path: none;
    padding: 12px 8px;
    margin-left: 0;
  } */

  .di-shape--first {
    clip-path: polygon(
      0 0,
      calc(100% - 20px) 0,
      100% 50%,
      calc(100% - 20px) 100%,
      0 100%
    );
    padding-right: 28px;
  }

  .di-shape--middle {
    clip-path: polygon(
      0 0,
      calc(100% - 20px) 0,
      100% 50%,
      calc(100% - 20px) 100%,
      0 100%,
      20px 50%
    );
    padding-left: 28px;
    padding-right: 28px;
    margin-left: -20px;
  }

  .di-shape--last {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 20px 50%);
    padding-left: 28px;
    margin-left: -20px;
  }
}

/* Active step must overlay neighbours so its chevron tip
   is not occluded by the next step's notch boundary. */
.di-shape.di-step--active {
  z-index: 3;
}
.di-shape.di-step--done,
.di-shape.di-step--idle {
  z-index: 1;
  /* drop-shadow traces the exact clip-path silhouette (including diagonal chevron edges).
     Four 0-blur directional shadows combine into a crisp 1px outline. */
  /* filter:
    drop-shadow(0 1px 0 var(--gemtheon-dark))
    drop-shadow(0 -1px 0 var(--gemtheon-dark))
    drop-shadow(1px 0 0 var(--gemtheon-dark))
    drop-shadow(-1px 0 0 var(--gemtheon-dark)); */
}

/* Outline is clipped — fall back to inset shadow for keyboard focus. */
.di-shape:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 2px var(--gemtheon-primary);
}
