@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=JetBrains+Mono:wght@400;500;600;700&family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@400;500;600;700&display=swap');

#lovable-badge {
  display: none !important;
}

*, ::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: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, 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;
}

:root {
    /* ── Dark theme — Apple-like (Build 269 refresh) ──
       Filosofia: backgrounds próximos do true black, surfaces com lift sutil
       (não cinza chapado), borders quase invisíveis (white 6–10%), primário
       laranja com curva mais quente (menos neon, mais Dynamic Island). */

    --background: 224 14% 3%;          /* near-black com leve azul, profundidade */
    --foreground: 210 14% 96%;         /* branco quente, não estéril */

    --card: 224 13% 6%;                /* +3% lift do bg */
    --card-foreground: 210 14% 95%;

    --popover: 224 13% 7%;             /* popover lifta um pouco mais */
    --popover-foreground: 210 14% 95%;

    --primary: 26 100% 54%;            /* laranja Apple Maps — ligeiramente mais quente */
    --primary-hot: 18 100% 52%;        /* gradient end — mais quente */
    --primary-warm: 28 100% 60%;       /* gradient start — mais claro */
    --primary-foreground: 24 30% 6%;   /* não preto puro, marrom muito escuro p/ contraste suave */

    --secondary: 224 12% 9%;           /* superfície interativa neutra */
    --secondary-foreground: 210 14% 95%;

    --muted: 224 11% 12%;              /* chips, badges quietos */
    --muted-foreground: 215 9% 65%;    /* +contraste vs antes (era 72%, ajustado p/ menos washed) */

    --accent: 224 11% 13%;             /* hover state */
    --accent-foreground: 210 14% 96%;

    --destructive: 4 78% 56%;          /* vermelho Apple SF — mais coral, menos sangue */
    --destructive-foreground: 0 0% 100%;

    --success: 142 60% 42%;            /* verde SF — mais saturado e vivo */
    --success-foreground: 0 0% 100%;

    --info: 211 100% 56%;              /* azul iOS system blue */
    --info-foreground: 0 0% 100%;

    --purple: 264 65% 60%;             /* roxo SF mais vibrante */
    --purple-foreground: 0 0% 100%;

    --warning: 36 100% 54%;            /* amarelo-laranja SF */
    --warning-foreground: 24 30% 8%;

    --border: 220 10% 100% / 0;        /* placeholder, override abaixo */
    --border: 220 13% 18%;             /* borda visível mas discreta */
    --input: 224 12% 10%;
    --ring: 26 100% 54%;

    --surface: 224 13% 6%;             /* nível 1 */
    --surface-2: 224 12% 9%;           /* nível 2 — lift +3% */
    --surface-3: 224 11% 13%;          /* nível 3 — lift +4% (modais, sheets) */

    --sidebar-background: 224 13% 5%;
    --sidebar-foreground: 210 14% 95%;
    --sidebar-primary: 26 100% 54%;
    --sidebar-primary-foreground: 24 30% 6%;
    --sidebar-accent: 224 12% 9%;
    --sidebar-accent-foreground: 210 14% 95%;
    --sidebar-border: 224 12% 11%;
    --sidebar-ring: 26 100% 54%;

    /* Hover/disabled tokens — Build 270 (premium contrast pass) */
    --hover-overlay: 220 13% 100% / 0.06;   /* white film p/ "lift" no dark */
    --hover-overlay-strong: 220 13% 100% / 0.10;
    --press-overlay: 224 14% 1% / 0.18;     /* black film p/ "press" */
    --disabled-fg: 215 9% 50%;              /* foreground dimado mas legível (4.5:1) */
    --disabled-bg: 224 12% 10%;             /* surface neutra p/ disabled */

    /* Modal backdrop — preto puro com blur (vibrancy iOS) */
    --overlay: 224 14% 1% / 0.78;

    /* ── Build 689 — Design tokens unificados (radius, elevation, ring) ──
       Fonte única de verdade. NUNCA usar rounded-[18px]/shadow-[...] arbitrário
       em features novas — sempre usar token semântico. */

    /* Radius scale */
    --radius-xs: 6px;
    --radius-sm: 8px;
    --radius: 12px;
    --radius-md: 16px;
    --radius-lg: 20px;          /* FABs, cards de mapa, drawers compactos */
    --radius-xl: 24px;          /* sheets, modais */
    --radius-2xl: 28px;
    --radius-pill: 9999px;

    /* Elevation / shadows — emparelhadas com cor primária pra FABs primários */
    --elev-1: 0 2px 6px -2px rgba(0,0,0,0.30), inset 0 1px 0 rgba(255,255,255,0.04);
    --elev-2: 0 6px 18px -8px rgba(0,0,0,0.55), 0 2px 6px -2px rgba(0,0,0,0.30), inset 0 1px 0 rgba(255,255,255,0.06);
    --elev-3: 0 12px 36px -10px rgba(0,0,0,0.60), 0 4px 12px -4px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.07);
    --elev-primary: 0 8px 24px -6px hsl(var(--primary) / 0.55), 0 2px 6px -2px rgba(0,0,0,0.40), inset 0 1px 0 rgba(255,255,255,0.22);
    --elev-primary-hover: 0 10px 28px -6px hsl(var(--primary) / 0.65), 0 2px 6px -2px rgba(0,0,0,0.40), inset 0 1px 0 rgba(255,255,255,0.22);

    /* Ring tokens (focus / hairline) */
    --ring-hairline: inset 0 0 0 1px hsl(var(--foreground) / 0.06);
    --ring-primary-soft: 0 0 0 1px hsl(var(--primary) / 0.30);

    /* Shadow system — two-layer Apple "close + ambient" */
    --shadow-card:
      0 0 0 0.5px hsl(220 13% 100% / 0.03) inset,
      0 1px 3px hsl(0 0% 0% / 0.32),
      0 4px 16px hsl(0 0% 0% / 0.18);
    --shadow-premium:
      0 0 0 0.5px hsl(220 13% 100% / 0.04) inset,
      0 1px 0 0 hsl(220 13% 100% / 0.05) inset,
      0 1px 2px hsl(0 0% 0% / 0.5),
      0 6px 20px hsl(0 0% 0% / 0.35),
      0 20px 60px hsl(0 0% 0% / 0.22);
    --shadow-glow-primary:
      0 0 32px -6px hsl(26 100% 54% / 0.32),
      0 4px 24px -4px hsl(0 0% 0% / 0.5);
    --shadow-glow-success:
      0 0 32px -6px hsl(142 60% 42% / 0.32),
      0 4px 24px -4px hsl(0 0% 0% / 0.5);

    /* Font families */
    --font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
    --font-display: 'Space Grotesk', system-ui, sans-serif;
    --font-body: 'DM Sans', system-ui, -apple-system, sans-serif;

    /* ── Logo camaleão — dark default ── */
    --logo-bg:     #0E0F12;
    --logo-stroke: #FAF8F4;

    /* ── Brand semantic tokens (Mobile App template) ── */
    --success-hi:        hsl(142 60% 55%);   /* verde vivo pra badges/ícones */
    --ink-mute:          hsl(215 9% 45%);    /* texto muito quieto */
    --ink-faint:         hsl(215 9% 32%);    /* quase invisível */
    --tracking-eyebrow:  0.18em;             /* JetBrains Mono eyebrow */
    --tracking-mono:     0.14em;             /* JetBrains Mono labels */
    --tracking-heading:  0.06em;             /* Bebas Neue headings */

    /* Zone colors (carregar/zona template) */
    --zone-frente:   hsl(142 60% 55%);   /* verde */
    --zone-traseiro: hsl(38 92% 56%);    /* âmbar */
    --zone-malas:    hsl(4 78% 66%);     /* coral */

    /* ── Type tokens (Build 691) — fonte ÚNICA pra badges/pílulas/coachmarks.
       Cada papel tipográfico tem 4 variáveis: size (clamp fluido), weight,
       tracking, line-height. Classes .map-* abaixo só consomem essas vars —
       qualquer mudança de hierarquia se faz aqui, em UM lugar. */
    --type-eyebrow-size: clamp(10px, 0.55vw + 8.5px, 12px);
    --type-eyebrow-weight: 700;
    --type-eyebrow-tracking: 0.16em;
    --type-eyebrow-leading: 14px;

    --type-title-size: clamp(14.5px, 0.7vw + 12px, 17px);
    --type-title-weight: 600;
    --type-title-tracking: -0.012em;
    --type-title-leading: 1.28;

    --type-label-size: clamp(13px, 0.55vw + 11px, 15px);
    --type-label-weight: 600;
    --type-label-tracking: -0.011em;
    --type-label-leading: 1.15;

    --type-body-size: clamp(12.5px, 0.5vw + 11px, 14.5px);
    --type-body-weight: 500;
    --type-body-tracking: -0.003em;
    --type-body-leading: 1.5;

    --type-meta-size: clamp(11px, 0.4vw + 10px, 13px);
    --type-meta-weight: 600;
    --type-meta-tracking: 0.002em;
    --type-meta-leading: 1.2;

    --type-caption-size: clamp(11px, 0.4vw + 10px, 13px);
    --type-caption-weight: 500;
    --type-caption-tracking: -0.002em;
    --type-caption-leading: 1.45;
  }

html[data-ui-scale="compact"] { --ui-scale: 0.92; }

html[data-ui-scale="standard"] { --ui-scale: 1; }

html[data-ui-scale="large"] { --ui-scale: 1.08; }

/* Acessibilidade: compensa zoom de sistema sem quebrar layout base. */

#root {
    zoom: var(--ui-scale);
  }

/* Fallback para engines sem suporte a zoom */

@supports not (zoom: 1) {
    #root {
      transform: scale(var(--ui-scale));
      transform-origin: top center;
      width: calc(100% / var(--ui-scale));
    }
  }

html[data-reduce-motion="true"] *,
  html[data-reduce-motion="true"] *::before,
  html[data-reduce-motion="true"] *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

/* ── Light mode v4 — Brand Identity v4 Light (fonte da verdade: brand/v4-light.html) ── */

.light {
    /* surfaces */
    --background:   40 33% 97%;          /* #FAF8F4 */
    --foreground:   225 14% 8%;          /* #0E0F12 */
    --card:         0 0% 100%;           /* #FFFFFF */
    --card-foreground: 225 14% 8%;
    --popover:      0 0% 100%;
    --popover-foreground: 225 14% 8%;

    /* Logo camaleão — light override */
    --logo-bg:     #FAF8F4;
    --logo-stroke: #0E0F12;

    /* primary — brasa #E55A0E */
    --primary:      18 93% 48%;          /* #E55A0E */
    --primary-foreground: 0 0% 100%;
    --primary-hot:  14 95% 50%;          /* #C24800 lo */
    --primary-warm: 22 100% 56%;         /* #FF6F1F hi */

    /* secondary / muted */
    --secondary:    36 22% 93%;          /* #F4F1EB surface-raised */
    --secondary-foreground: 225 14% 8%;
    --muted:        36 18% 91%;          /* #EFEBE2 surface-soft */
    --muted-foreground: 220 8% 55%;      /* #8B8F99 ink-3 */

    /* accent */
    --accent:       36 22% 93%;
    --accent-foreground: 225 14% 8%;

    /* semantic */
    --destructive:  0 72% 42%;           /* #B91C1C */
    --destructive-foreground: 0 0% 100%;
    --success:      145 64% 30%;         /* #1B7F3F */
    --success-foreground: 0 0% 100%;
    --info:         212 88% 44%;
    --info-foreground: 0 0% 100%;
    --warning:      36 100% 39%;         /* #C77800 */
    --warning-foreground: 0 0% 100%;
    --purple:       268 58% 48%;
    --purple-foreground: 0 0% 100%;

    /* borders */
    --border:       36 16% 87%;          /* #E6E2D9 */
    --input:        36 16% 87%;
    --ring:         18 93% 48%;

    /* surfaces */
    --surface:      0 0% 100%;
    --surface-2:    36 22% 93%;          /* #F4F1EB */
    --surface-3:    36 18% 91%;          /* #EFEBE2 */

    /* sidebar */
    --sidebar-background: 40 33% 97%;
    --sidebar-foreground: 225 14% 8%;
    --sidebar-primary: 18 93% 48%;
    --sidebar-primary-foreground: 0 0% 100%;
    --sidebar-accent: 36 22% 93%;
    --sidebar-accent-foreground: 225 14% 8%;
    --sidebar-border: 36 16% 87%;
    --sidebar-ring: 18 93% 48%;

    /* hover/disabled — light (preto com alpha) */
    --hover-overlay: 225 14% 8% / 0.05;
    --hover-overlay-strong: 225 14% 8% / 0.08;
    --press-overlay: 225 14% 8% / 0.10;
    --disabled-fg: 220 8% 55%;
    --disabled-bg: 36 16% 92%;
    --overlay: 225 14% 8% / 0.45;

    /* elevations — light (sombras suaves) */
    --elev-1: 0 1px 0 rgba(14,15,18,0.04);
    --elev-2: 0 1px 2px rgba(14,15,18,0.04), 0 4px 12px rgba(14,15,18,0.04);
    --elev-3: 0 8px 24px rgba(14,15,18,0.08), 0 2px 4px rgba(14,15,18,0.04);
    --elev-primary: 0 8px 22px -6px hsl(18 93% 48% / 0.30), 0 2px 6px -2px rgba(14,15,18,0.06), inset 0 1px 0 rgba(255,255,255,0.30);
    --elev-primary-hover: 0 10px 26px -6px hsl(18 93% 48% / 0.40), 0 2px 6px -2px rgba(14,15,18,0.06), inset 0 1px 0 rgba(255,255,255,0.30);
    --ring-hairline: inset 0 0 0 1px rgba(14,15,18,0.06);
    --ring-primary-soft: 0 0 0 1px hsl(18 93% 48% / 0.25);

    /* shadow system — light */
    --shadow-card:    0 1px 0 rgba(14,15,18,0.04), 0 1px 3px rgba(14,15,18,0.06);
    --shadow-premium: 0 1px 2px rgba(14,15,18,0.06), 0 4px 16px rgba(14,15,18,0.06);
    --shadow-glow-primary: 0 0 24px -6px hsl(18 93% 48% / 0.25), 0 2px 8px rgba(14,15,18,0.06);
    --shadow-glow-success:  0 0 24px -6px hsl(145 64% 30% / 0.25), 0 2px 8px rgba(14,15,18,0.06);
    --shadow-input-focus:   0 0 0 3px hsl(18 93% 48% / 0.15), 0 0 0 0.5px hsl(18 93% 48% / 0.35) inset;

    /* v4 semantic extras */
    --success-hi:    145 64% 40%;
    --ink-mute:      220 8% 55%;
    --ink-faint:     220 8% 72%;
    --zone-frente:   145 64% 30%;
    --zone-traseiro: 36 100% 39%;
    --zone-malas:    0 72% 42%;
  }

*{
  border-color: hsl(var(--border));
}

html {
    scroll-behavior: smooth;
    /* Block native Chrome Android pull-to-refresh so our custom one works */
    overscroll-behavior-y: contain;
  }

body{
  background-color: hsl(var(--background));
  color: hsl(var(--foreground));
    font-family: 'DM Sans', system-ui, -apple-system, sans-serif;
    -webkit-tap-highlight-color: transparent;
    overflow-x: hidden;
    overscroll-behavior-y: contain;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: 'cv11', 'ss01';
    font-variation-settings: 'opsz' 32;
    background:
      radial-gradient(ellipse 800px 600px at 20% 0%, hsl(26 60% 14% / 0.25), transparent 60%),
      radial-gradient(ellipse 700px 500px at 100% 100%, hsl(220 50% 12% / 0.25), transparent 60%),
      hsl(var(--background));
    background-attachment: fixed;
}

/* v4 Light body background — fiel ao brand/v4-light.html */

html.light body {
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    background:
      radial-gradient(ellipse 1200px 600px at 88% -8%, #FFE9D6 0%, transparent 55%),
      radial-gradient(ellipse 800px 500px at 4% 22%, #F4F1EB 0%, transparent 60%),
      #FAF8F4;
    background-attachment: fixed;
  }

.font-heading {
    font-family: 'Bebas Neue', sans-serif;
    letter-spacing: 0.06em;
  }

/* v4 Light: Space Grotesk como display quando tema light ativo */

.light .font-heading {
    font-family: 'Space Grotesk', system-ui, sans-serif;
    letter-spacing: -0.02em;
  }

.font-display {
    font-family: 'Space Grotesk', system-ui, sans-serif;
  }

::-moz-selection {
    background: hsl(26 100% 54% / 0.3);
    color: hsl(210 14% 96%);
  }

::selection {
    background: hsl(26 100% 54% / 0.3);
    color: hsl(210 14% 96%);
  }

input::-moz-placeholder, textarea::-moz-placeholder {
    color: hsl(215 9% 38%);
  }

input::placeholder, textarea::placeholder {
    color: hsl(215 9% 38%);
  }

/* ── Mobile UX: eliminate 300ms tap delay on all interactive elements ── */

/* Skill: touch-action: manipulation removes the tap delay on iOS/Android */

button, [role="button"], a, label, select {
    touch-action: manipulation;
  }

/* ── Prevent accidental text selection on long-press (one-thumb, dirty hands) ── */

button, [role="button"] {
    -moz-user-select: none;
         user-select: none;
    -webkit-user-select: none;
  }

/* ── Prevent iOS auto-zoom on input focus (requires font-size >= 16px) ── */

/* Skill: inputs < 16px trigger iOS viewport zoom which breaks single-thumb UX */

input, select, textarea {
    font-size: max(16px, 1em);
  }

.container{
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 2rem;
  padding-left: 2rem;
}

@media (min-width: 1400px){

  .container{
    max-width: 1400px;
  }
}

.sr-only{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.pointer-events-none{
  pointer-events: none;
}

.pointer-events-auto{
  pointer-events: auto;
}

.\!visible{
  visibility: visible !important;
}

.visible{
  visibility: visible;
}

.invisible{
  visibility: hidden;
}

.collapse{
  visibility: collapse;
}

.static{
  position: static;
}

.fixed{
  position: fixed;
}

.absolute{
  position: absolute;
}

.relative{
  position: relative;
}

.sticky{
  position: sticky;
}

.-inset-1{
  inset: -0.25rem;
}

.inset-0{
  inset: 0px;
}

.inset-4{
  inset: 1rem;
}

.inset-\[10px\]{
  inset: 10px;
}

.inset-\[20px\]{
  inset: 20px;
}

.inset-\[6px\]{
  inset: 6px;
}

.inset-x-0{
  left: 0px;
  right: 0px;
}

.inset-x-2{
  left: 0.5rem;
  right: 0.5rem;
}

.inset-x-3{
  left: 0.75rem;
  right: 0.75rem;
}

.inset-x-4{
  left: 1rem;
  right: 1rem;
}

.inset-x-8{
  left: 2rem;
  right: 2rem;
}

.inset-y-0{
  top: 0px;
  bottom: 0px;
}

.\!bottom-2{
  bottom: 0.5rem !important;
}

.\!left-2{
  left: 0.5rem !important;
}

.\!right-2{
  right: 0.5rem !important;
}

.\!top-auto{
  top: auto !important;
}

.-bottom-12{
  bottom: -3rem;
}

.-bottom-2{
  bottom: -0.5rem;
}

.-bottom-32{
  bottom: -8rem;
}

.-left-10{
  left: -2.5rem;
}

.-left-12{
  left: -3rem;
}

.-left-3{
  left: -0.75rem;
}

.-left-\[1\.4rem\]{
  left: -1.4rem;
}

.-right-0\.5{
  right: -0.125rem;
}

.-right-1{
  right: -0.25rem;
}

.-right-12{
  right: -3rem;
}

.-right-16{
  right: -4rem;
}

.-right-20{
  right: -5rem;
}

.-right-3{
  right: -0.75rem;
}

.-top-0\.5{
  top: -0.125rem;
}

.-top-1{
  top: -0.25rem;
}

.-top-1\.5{
  top: -0.375rem;
}

.-top-12{
  top: -3rem;
}

.-top-16{
  top: -4rem;
}

.-top-2\.5{
  top: -0.625rem;
}

.-top-20{
  top: -5rem;
}

.bottom-0{
  bottom: 0px;
}

.bottom-1{
  bottom: 0.25rem;
}

.bottom-2{
  bottom: 0.5rem;
}

.bottom-20{
  bottom: 5rem;
}

.bottom-3{
  bottom: 0.75rem;
}

.bottom-4{
  bottom: 1rem;
}

.bottom-\[-15\%\]{
  bottom: -15%;
}

.bottom-\[14px\]{
  bottom: 14px;
}

.bottom-\[68px\]{
  bottom: 68px;
}

.bottom-\[88px\]{
  bottom: 88px;
}

.bottom-\[calc\(env\(safe-area-inset-bottom\2c 0px\)\+12px\)\]{
  bottom: calc(env(safe-area-inset-bottom,0px) + 12px);
}

.bottom-\[max\(3rem\2c env\(safe-area-inset-bottom\2c 3rem\)\)\]{
  bottom: max(3rem,env(safe-area-inset-bottom,3rem));
}

.bottom-full{
  bottom: 100%;
}

.left-0{
  left: 0px;
}

.left-1{
  left: 0.25rem;
}

.left-1\/2{
  left: 50%;
}

.left-1\/3{
  left: 33.333333%;
}

.left-2{
  left: 0.5rem;
}

.left-2\.5{
  left: 0.625rem;
}

.left-3{
  left: 0.75rem;
}

.left-4{
  left: 1rem;
}

.left-7{
  left: 1.75rem;
}

.left-8{
  left: 2rem;
}

.left-\[-10\%\]{
  left: -10%;
}

.left-\[10\%\]{
  left: 10%;
}

.left-\[100px\]{
  left: 100px;
}

.left-\[14px\]{
  left: 14px;
}

.left-\[25\%\]{
  left: 25%;
}

.left-\[3px\]{
  left: 3px;
}

.left-\[50\%\]{
  left: 50%;
}

.left-\[80\%\]{
  left: 80%;
}

.left-\[calc\(64px\+env\(safe-area-inset-left\2c 0px\)\)\]{
  left: calc(64px + env(safe-area-inset-left,0px));
}

.right-0{
  right: 0px;
}

.right-1{
  right: 0.25rem;
}

.right-1\.5{
  right: 0.375rem;
}

.right-1\/3{
  right: 33.333333%;
}

.right-2{
  right: 0.5rem;
}

.right-2\.5{
  right: 0.625rem;
}

.right-3{
  right: 0.75rem;
}

.right-3\.5{
  right: 0.875rem;
}

.right-4{
  right: 1rem;
}

.right-5{
  right: 1.25rem;
}

.right-6{
  right: 1.5rem;
}

.right-7{
  right: 1.75rem;
}

.right-\[-10\%\]{
  right: -10%;
}

.right-\[-15\%\]{
  right: -15%;
}

.right-\[100px\]{
  right: 100px;
}

.right-\[14px\]{
  right: 14px;
}

.right-\[72px\]{
  right: 72px;
}

.top-0{
  top: 0px;
}

.top-0\.5{
  top: 0.125rem;
}

.top-1{
  top: 0.25rem;
}

.top-1\.5{
  top: 0.375rem;
}

.top-1\/2{
  top: 50%;
}

.top-11{
  top: 2.75rem;
}

.top-14{
  top: 3.5rem;
}

.top-16{
  top: 4rem;
}

.top-2{
  top: 0.5rem;
}

.top-2\.5{
  top: 0.625rem;
}

.top-3{
  top: 0.75rem;
}

.top-3\.5{
  top: 0.875rem;
}

.top-4{
  top: 1rem;
}

.top-5{
  top: 1.25rem;
}

.top-\[-15\%\]{
  top: -15%;
}

.top-\[-20\%\]{
  top: -20%;
}

.top-\[-40\%\]{
  top: -40%;
}

.top-\[106px\]{
  top: 106px;
}

.top-\[12\%\]{
  top: 12%;
}

.top-\[14px\]{
  top: 14px;
}

.top-\[15\%\]{
  top: 15%;
}

.top-\[1px\]{
  top: 1px;
}

.top-\[3px\]{
  top: 3px;
}

.top-\[50\%\]{
  top: 50%;
}

.top-\[60\%\]{
  top: 60%;
}

.top-\[88px\]{
  top: 88px;
}

.top-\[calc\(112px\+env\(safe-area-inset-top\2c 0px\)\)\]{
  top: calc(112px + env(safe-area-inset-top,0px));
}

.top-\[calc\(12px\+env\(safe-area-inset-top\2c 0px\)\)\]{
  top: calc(12px + env(safe-area-inset-top,0px));
}

.top-\[calc\(64px\+env\(safe-area-inset-top\2c 0px\)\)\]{
  top: calc(64px + env(safe-area-inset-top,0px));
}

.top-\[calc\(env\(safe-area-inset-top\2c 0px\)\+12px\)\]{
  top: calc(env(safe-area-inset-top,0px) + 12px);
}

.top-\[clamp\(142px\2c 34dvh\2c 300px\)\]{
  top: clamp(142px,34dvh,300px);
}

.top-auto{
  top: auto;
}

.top-full{
  top: 100%;
}

.isolate{
  isolation: isolate;
}

.z-0{
  z-index: 0;
}

.z-10{
  z-index: 10;
}

.z-20{
  z-index: 20;
}

.z-30{
  z-index: 30;
}

.z-40{
  z-index: 40;
}

.z-50{
  z-index: 50;
}

.z-\[10000\]{
  z-index: 10000;
}

.z-\[1000\]{
  z-index: 1000;
}

.z-\[1001\]{
  z-index: 1001;
}

.z-\[1002\]{
  z-index: 1002;
}

.z-\[100\]{
  z-index: 100;
}

.z-\[1010\]{
  z-index: 1010;
}

.z-\[1011\]{
  z-index: 1011;
}

.z-\[101\]{
  z-index: 101;
}

.z-\[1080\]{
  z-index: 1080;
}

.z-\[1100\]{
  z-index: 1100;
}

.z-\[110\]{
  z-index: 110;
}

.z-\[1180\]{
  z-index: 1180;
}

.z-\[1182\]{
  z-index: 1182;
}

.z-\[1200\]{
  z-index: 1200;
}

.z-\[1201\]{
  z-index: 1201;
}

.z-\[1202\]{
  z-index: 1202;
}

.z-\[120\]{
  z-index: 120;
}

.z-\[1250\]{
  z-index: 1250;
}

.z-\[1260\]{
  z-index: 1260;
}

.z-\[12\]{
  z-index: 12;
}

.z-\[1300\]{
  z-index: 1300;
}

.z-\[1305\]{
  z-index: 1305;
}

.z-\[130\]{
  z-index: 130;
}

.z-\[1400\]{
  z-index: 1400;
}

.z-\[140\]{
  z-index: 140;
}

.z-\[141\]{
  z-index: 141;
}

.z-\[145\]{
  z-index: 145;
}

.z-\[148\]{
  z-index: 148;
}

.z-\[1500\]{
  z-index: 1500;
}

.z-\[150\]{
  z-index: 150;
}

.z-\[151\]{
  z-index: 151;
}

.z-\[1550\]{
  z-index: 1550;
}

.z-\[1600\]{
  z-index: 1600;
}

.z-\[160\]{
  z-index: 160;
}

.z-\[1700\]{
  z-index: 1700;
}

.z-\[1800\]{
  z-index: 1800;
}

.z-\[1801\]{
  z-index: 1801;
}

.z-\[180\]{
  z-index: 180;
}

.z-\[1\]{
  z-index: 1;
}

.z-\[200\]{
  z-index: 200;
}

.z-\[201\]{
  z-index: 201;
}

.z-\[209\]{
  z-index: 209;
}

.z-\[210\]{
  z-index: 210;
}

.z-\[211\]{
  z-index: 211;
}

.z-\[230\]{
  z-index: 230;
}

.z-\[240\]{
  z-index: 240;
}

.z-\[250\]{
  z-index: 250;
}

.z-\[270\]{
  z-index: 270;
}

.z-\[300\]{
  z-index: 300;
}

.z-\[30\]{
  z-index: 30;
}

.z-\[400\]{
  z-index: 400;
}

.z-\[450\]{
  z-index: 450;
}

.z-\[590\]{
  z-index: 590;
}

.z-\[600\]{
  z-index: 600;
}

.z-\[60\]{
  z-index: 60;
}

.z-\[700\]{
  z-index: 700;
}

.z-\[70\]{
  z-index: 70;
}

.z-\[800\]{
  z-index: 800;
}

.z-\[900\]{
  z-index: 900;
}

.z-\[95\]{
  z-index: 95;
}

.z-\[998\]{
  z-index: 998;
}

.z-\[9998\]{
  z-index: 9998;
}

.z-\[9999\]{
  z-index: 9999;
}

.z-\[999\]{
  z-index: 999;
}

.z-\[99\]{
  z-index: 99;
}

.order-1{
  order: 1;
}

.order-2{
  order: 2;
}

.col-span-2{
  grid-column: span 2 / span 2;
}

.col-span-3{
  grid-column: span 3 / span 3;
}

.m-0{
  margin: 0px;
}

.-mx-1{
  margin-left: -0.25rem;
  margin-right: -0.25rem;
}

.-mx-1\.5{
  margin-left: -0.375rem;
  margin-right: -0.375rem;
}

.-mx-2{
  margin-left: -0.5rem;
  margin-right: -0.5rem;
}

.-mx-3{
  margin-left: -0.75rem;
  margin-right: -0.75rem;
}

.-mx-4{
  margin-left: -1rem;
  margin-right: -1rem;
}

.-mx-5{
  margin-left: -1.25rem;
  margin-right: -1.25rem;
}

.-mx-6{
  margin-left: -1.5rem;
  margin-right: -1.5rem;
}

.-my-1{
  margin-top: -0.25rem;
  margin-bottom: -0.25rem;
}

.-my-4{
  margin-top: -1rem;
  margin-bottom: -1rem;
}

.mx-0\.5{
  margin-left: 0.125rem;
  margin-right: 0.125rem;
}

.mx-1{
  margin-left: 0.25rem;
  margin-right: 0.25rem;
}

.mx-1\.5{
  margin-left: 0.375rem;
  margin-right: 0.375rem;
}

.mx-2{
  margin-left: 0.5rem;
  margin-right: 0.5rem;
}

.mx-3{
  margin-left: 0.75rem;
  margin-right: 0.75rem;
}

.mx-3\.5{
  margin-left: 0.875rem;
  margin-right: 0.875rem;
}

.mx-4{
  margin-left: 1rem;
  margin-right: 1rem;
}

.mx-6{
  margin-left: 1.5rem;
  margin-right: 1.5rem;
}

.mx-auto{
  margin-left: auto;
  margin-right: auto;
}

.my-1{
  margin-top: 0.25rem;
  margin-bottom: 0.25rem;
}

.my-2{
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}

.my-4{
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.my-7{
  margin-top: 1.75rem;
  margin-bottom: 1.75rem;
}

.-mb-3{
  margin-bottom: -0.75rem;
}

.-ml-1{
  margin-left: -0.25rem;
}

.-ml-2{
  margin-left: -0.5rem;
}

.-ml-4{
  margin-left: -1rem;
}

.-mr-0\.5{
  margin-right: -0.125rem;
}

.-mr-1{
  margin-right: -0.25rem;
}

.-mt-0\.5{
  margin-top: -0.125rem;
}

.-mt-1{
  margin-top: -0.25rem;
}

.-mt-4{
  margin-top: -1rem;
}

.mb-0\.5{
  margin-bottom: 0.125rem;
}

.mb-1{
  margin-bottom: 0.25rem;
}

.mb-1\.5{
  margin-bottom: 0.375rem;
}

.mb-10{
  margin-bottom: 2.5rem;
}

.mb-12{
  margin-bottom: 3rem;
}

.mb-2{
  margin-bottom: 0.5rem;
}

.mb-2\.5{
  margin-bottom: 0.625rem;
}

.mb-3{
  margin-bottom: 0.75rem;
}

.mb-4{
  margin-bottom: 1rem;
}

.mb-5{
  margin-bottom: 1.25rem;
}

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

.mb-7{
  margin-bottom: 1.75rem;
}

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

.mb-\[2px\]{
  margin-bottom: 2px;
}

.mb-\[3px\]{
  margin-bottom: 3px;
}

.ml-0\.5{
  margin-left: 0.125rem;
}

.ml-1{
  margin-left: 0.25rem;
}

.ml-1\.5{
  margin-left: 0.375rem;
}

.ml-14{
  margin-left: 3.5rem;
}

.ml-2{
  margin-left: 0.5rem;
}

.ml-3{
  margin-left: 0.75rem;
}

.ml-4{
  margin-left: 1rem;
}

.ml-5{
  margin-left: 1.25rem;
}

.ml-6{
  margin-left: 1.5rem;
}

.ml-8{
  margin-left: 2rem;
}

.ml-9{
  margin-left: 2.25rem;
}

.ml-\[34px\]{
  margin-left: 34px;
}

.ml-auto{
  margin-left: auto;
}

.mr-1{
  margin-right: 0.25rem;
}

.mr-1\.5{
  margin-right: 0.375rem;
}

.mr-2{
  margin-right: 0.5rem;
}

.mt-0{
  margin-top: 0px;
}

.mt-0\.5{
  margin-top: 0.125rem;
}

.mt-1{
  margin-top: 0.25rem;
}

.mt-1\.5{
  margin-top: 0.375rem;
}

.mt-2{
  margin-top: 0.5rem;
}

.mt-2\.5{
  margin-top: 0.625rem;
}

.mt-24{
  margin-top: 6rem;
}

.mt-3{
  margin-top: 0.75rem;
}

.mt-3\.5{
  margin-top: 0.875rem;
}

.mt-4{
  margin-top: 1rem;
}

.mt-5{
  margin-top: 1.25rem;
}

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

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

.mt-\[2px\]{
  margin-top: 2px;
}

.mt-auto{
  margin-top: auto;
}

.mt-px{
  margin-top: 1px;
}

.box-border{
  box-sizing: border-box;
}

.line-clamp-1{
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}

.line-clamp-2{
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.line-clamp-3{
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.block{
  display: block;
}

.inline-block{
  display: inline-block;
}

.inline{
  display: inline;
}

.flex{
  display: flex;
}

.inline-flex{
  display: inline-flex;
}

.table{
  display: table;
}

.grid{
  display: grid;
}

.hidden{
  display: none;
}

.aspect-\[3\/4\]{
  aspect-ratio: 3/4;
}

.aspect-\[4\/3\]{
  aspect-ratio: 4/3;
}

.aspect-square{
  aspect-ratio: 1 / 1;
}

.size-4{
  width: 1rem;
  height: 1rem;
}

.\!h-6{
  height: 1.5rem !important;
}

.h-0{
  height: 0px;
}

.h-0\.5{
  height: 0.125rem;
}

.h-1{
  height: 0.25rem;
}

.h-1\.5{
  height: 0.375rem;
}

.h-10{
  height: 2.5rem;
}

.h-11{
  height: 2.75rem;
}

.h-12{
  height: 3rem;
}

.h-14{
  height: 3.5rem;
}

.h-16{
  height: 4rem;
}

.h-2{
  height: 0.5rem;
}

.h-2\.5{
  height: 0.625rem;
}

.h-20{
  height: 5rem;
}

.h-24{
  height: 6rem;
}

.h-28{
  height: 7rem;
}

.h-3{
  height: 0.75rem;
}

.h-3\.5{
  height: 0.875rem;
}

.h-32{
  height: 8rem;
}

.h-36{
  height: 9rem;
}

.h-4{
  height: 1rem;
}

.h-40{
  height: 10rem;
}

.h-44{
  height: 11rem;
}

.h-48{
  height: 12rem;
}

.h-5{
  height: 1.25rem;
}

.h-56{
  height: 14rem;
}

.h-6{
  height: 1.5rem;
}

.h-64{
  height: 16rem;
}

.h-7{
  height: 1.75rem;
}

.h-72{
  height: 18rem;
}

.h-8{
  height: 2rem;
}

.h-9{
  height: 2.25rem;
}

.h-96{
  height: 24rem;
}

.h-\[100dvh\]{
  height: 100dvh;
}

.h-\[10px\]{
  height: 10px;
}

.h-\[110px\]{
  height: 110px;
}

.h-\[112px\]{
  height: 112px;
}

.h-\[11px\]{
  height: 11px;
}

.h-\[120px\]{
  height: 120px;
}

.h-\[12px\]{
  height: 12px;
}

.h-\[130px\]{
  height: 130px;
}

.h-\[140px\]{
  height: 140px;
}

.h-\[150px\]{
  height: 150px;
}

.h-\[15px\]{
  height: 15px;
}

.h-\[160px\]{
  height: 160px;
}

.h-\[16px\]{
  height: 16px;
}

.h-\[180px\]{
  height: 180px;
}

.h-\[18px\]{
  height: 18px;
}

.h-\[19px\]{
  height: 19px;
}

.h-\[1px\]{
  height: 1px;
}

.h-\[200px\]{
  height: 200px;
}

.h-\[220px\]{
  height: 220px;
}

.h-\[260px\]{
  height: 260px;
}

.h-\[26px\]{
  height: 26px;
}

.h-\[28px\]{
  height: 28px;
}

.h-\[2px\]{
  height: 2px;
}

.h-\[30px\]{
  height: 30px;
}

.h-\[340px\]{
  height: 340px;
}

.h-\[34px\]{
  height: 34px;
}

.h-\[36px\]{
  height: 36px;
}

.h-\[38px\]{
  height: 38px;
}

.h-\[3px\]{
  height: 3px;
}

.h-\[40px\]{
  height: 40px;
}

.h-\[42px\]{
  height: 42px;
}

.h-\[44px\]{
  height: 44px;
}

.h-\[46px\]{
  height: 46px;
}

.h-\[48px\]{
  height: 48px;
}

.h-\[4px\]{
  height: 4px;
}

.h-\[50\%\]{
  height: 50%;
}

.h-\[500px\]{
  height: 500px;
}

.h-\[50px\]{
  height: 50px;
}

.h-\[52px\]{
  height: 52px;
}

.h-\[56px\]{
  height: 56px;
}

.h-\[58px\]{
  height: 58px;
}

.h-\[5px\]{
  height: 5px;
}

.h-\[60\%\]{
  height: 60%;
}

.h-\[60px\]{
  height: 60px;
}

.h-\[60vh\]{
  height: 60vh;
}

.h-\[64px\]{
  height: 64px;
}

.h-\[68px\]{
  height: 68px;
}

.h-\[6px\]{
  height: 6px;
}

.h-\[70\%\]{
  height: 70%;
}

.h-\[72px\]{
  height: 72px;
}

.h-\[76px\]{
  height: 76px;
}

.h-\[7px\]{
  height: 7px;
}

.h-\[88px\]{
  height: 88px;
}

.h-\[8px\]{
  height: 8px;
}

.h-\[var\(--radix-navigation-menu-viewport-height\)\]{
  height: var(--radix-navigation-menu-viewport-height);
}

.h-\[var\(--radix-select-trigger-height\)\]{
  height: var(--radix-select-trigger-height);
}

.h-auto{
  height: auto;
}

.h-dvh{
  height: 100dvh;
}

.h-full{
  height: 100%;
}

.h-px{
  height: 1px;
}

.h-svh{
  height: 100svh;
}

.max-h-24{
  max-height: 6rem;
}

.max-h-32{
  max-height: 8rem;
}

.max-h-40{
  max-height: 10rem;
}

.max-h-48{
  max-height: 12rem;
}

.max-h-56{
  max-height: 14rem;
}

.max-h-64{
  max-height: 16rem;
}

.max-h-72{
  max-height: 18rem;
}

.max-h-96{
  max-height: 24rem;
}

.max-h-\[100dvh\]{
  max-height: 100dvh;
}

.max-h-\[180px\]{
  max-height: 180px;
}

.max-h-\[200px\]{
  max-height: 200px;
}

.max-h-\[240px\]{
  max-height: 240px;
}

.max-h-\[260px\]{
  max-height: 260px;
}

.max-h-\[280px\]{
  max-height: 280px;
}

.max-h-\[300px\]{
  max-height: 300px;
}

.max-h-\[36rem\]{
  max-height: 36rem;
}

.max-h-\[400px\]{
  max-height: 400px;
}

.max-h-\[40vh\]{
  max-height: 40vh;
}

.max-h-\[420px\]{
  max-height: 420px;
}

.max-h-\[480px\]{
  max-height: 480px;
}

.max-h-\[50vh\]{
  max-height: 50vh;
}

.max-h-\[55vh\]{
  max-height: 55vh;
}

.max-h-\[60\%\]{
  max-height: 60%;
}

.max-h-\[600px\]{
  max-height: 600px;
}

.max-h-\[60vh\]{
  max-height: 60vh;
}

.max-h-\[680px\]{
  max-height: 680px;
}

.max-h-\[70vh\]{
  max-height: 70vh;
}

.max-h-\[72\%\]{
  max-height: 72%;
}

.max-h-\[75vh\]{
  max-height: 75vh;
}

.max-h-\[78dvh\]{
  max-height: 78dvh;
}

.max-h-\[80vh\]{
  max-height: 80vh;
}

.max-h-\[82vh\]{
  max-height: 82vh;
}

.max-h-\[85dvh\]{
  max-height: 85dvh;
}

.max-h-\[85vh\]{
  max-height: 85vh;
}

.max-h-\[88dvh\]{
  max-height: 88dvh;
}

.max-h-\[90dvh\]{
  max-height: 90dvh;
}

.max-h-\[90vh\]{
  max-height: 90vh;
}

.max-h-\[92dvh\]{
  max-height: 92dvh;
}

.max-h-\[92vh\]{
  max-height: 92vh;
}

.max-h-\[calc\(100dvh-2rem\)\]{
  max-height: calc(100dvh - 2rem);
}

.max-h-\[min\(46dvh\2c 360px\)\]{
  max-height: min(46dvh,360px);
}

.max-h-screen{
  max-height: 100vh;
}

.min-h-0{
  min-height: 0px;
}

.min-h-11{
  min-height: 2.75rem;
}

.min-h-12{
  min-height: 3rem;
}

.min-h-5{
  min-height: 1.25rem;
}

.min-h-6{
  min-height: 1.5rem;
}

.min-h-7{
  min-height: 1.75rem;
}

.min-h-\[100dvh\]{
  min-height: 100dvh;
}

.min-h-\[100px\]{
  min-height: 100px;
}

.min-h-\[110px\]{
  min-height: 110px;
}

.min-h-\[120px\]{
  min-height: 120px;
}

.min-h-\[14px\]{
  min-height: 14px;
}

.min-h-\[150px\]{
  min-height: 150px;
}

.min-h-\[200px\]{
  min-height: 200px;
}

.min-h-\[20px\]{
  min-height: 20px;
}

.min-h-\[220px\]{
  min-height: 220px;
}

.min-h-\[24px\]{
  min-height: 24px;
}

.min-h-\[280px\]{
  min-height: 280px;
}

.min-h-\[32px\]{
  min-height: 32px;
}

.min-h-\[34px\]{
  min-height: 34px;
}

.min-h-\[36px\]{
  min-height: 36px;
}

.min-h-\[40px\]{
  min-height: 40px;
}

.min-h-\[40vh\]{
  min-height: 40vh;
}

.min-h-\[42px\]{
  min-height: 42px;
}

.min-h-\[44px\]{
  min-height: 44px;
}

.min-h-\[46px\]{
  min-height: 46px;
}

.min-h-\[48px\]{
  min-height: 48px;
}

.min-h-\[52px\]{
  min-height: 52px;
}

.min-h-\[54px\]{
  min-height: 54px;
}

.min-h-\[56px\]{
  min-height: 56px;
}

.min-h-\[58px\]{
  min-height: 58px;
}

.min-h-\[60px\]{
  min-height: 60px;
}

.min-h-\[60vh\]{
  min-height: 60vh;
}

.min-h-\[64px\]{
  min-height: 64px;
}

.min-h-\[65px\]{
  min-height: 65px;
}

.min-h-\[70px\]{
  min-height: 70px;
}

.min-h-\[72px\]{
  min-height: 72px;
}

.min-h-\[76px\]{
  min-height: 76px;
}

.min-h-\[80px\]{
  min-height: 80px;
}

.min-h-\[88px\]{
  min-height: 88px;
}

.min-h-\[90px\]{
  min-height: 90px;
}

.min-h-screen{
  min-height: 100vh;
}

.min-h-svh{
  min-height: 100svh;
}

.\!w-6{
  width: 1.5rem !important;
}

.\!w-auto{
  width: auto !important;
}

.w-0{
  width: 0px;
}

.w-1{
  width: 0.25rem;
}

.w-1\.5{
  width: 0.375rem;
}

.w-1\/3{
  width: 33.333333%;
}

.w-10{
  width: 2.5rem;
}

.w-11{
  width: 2.75rem;
}

.w-12{
  width: 3rem;
}

.w-14{
  width: 3.5rem;
}

.w-16{
  width: 4rem;
}

.w-2{
  width: 0.5rem;
}

.w-2\.5{
  width: 0.625rem;
}

.w-20{
  width: 5rem;
}

.w-24{
  width: 6rem;
}

.w-28{
  width: 7rem;
}

.w-3{
  width: 0.75rem;
}

.w-3\.5{
  width: 0.875rem;
}

.w-3\/4{
  width: 75%;
}

.w-32{
  width: 8rem;
}

.w-36{
  width: 9rem;
}

.w-4{
  width: 1rem;
}

.w-44{
  width: 11rem;
}

.w-48{
  width: 12rem;
}

.w-5{
  width: 1.25rem;
}

.w-52{
  width: 13rem;
}

.w-56{
  width: 14rem;
}

.w-6{
  width: 1.5rem;
}

.w-64{
  width: 16rem;
}

.w-7{
  width: 1.75rem;
}

.w-72{
  width: 18rem;
}

.w-8{
  width: 2rem;
}

.w-80{
  width: 20rem;
}

.w-9{
  width: 2.25rem;
}

.w-\[--sidebar-width\]{
  width: var(--sidebar-width);
}

.w-\[112px\]{
  width: 112px;
}

.w-\[11px\]{
  width: 11px;
}

.w-\[120px\]{
  width: 120px;
}

.w-\[140px\]{
  width: 140px;
}

.w-\[150px\]{
  width: 150px;
}

.w-\[156px\]{
  width: 156px;
}

.w-\[15px\]{
  width: 15px;
}

.w-\[16px\]{
  width: 16px;
}

.w-\[18px\]{
  width: 18px;
}

.w-\[19px\]{
  width: 19px;
}

.w-\[1px\]{
  width: 1px;
}

.w-\[204px\]{
  width: 204px;
}

.w-\[256px\]{
  width: 256px;
}

.w-\[26px\]{
  width: 26px;
}

.w-\[280px\]{
  width: 280px;
}

.w-\[28px\]{
  width: 28px;
}

.w-\[30px\]{
  width: 30px;
}

.w-\[36px\]{
  width: 36px;
}

.w-\[3px\]{
  width: 3px;
}

.w-\[40\%\]{
  width: 40%;
}

.w-\[42px\]{
  width: 42px;
}

.w-\[45\%\]{
  width: 45%;
}

.w-\[48px\]{
  width: 48px;
}

.w-\[4px\]{
  width: 4px;
}

.w-\[50\%\]{
  width: 50%;
}

.w-\[52px\]{
  width: 52px;
}

.w-\[5px\]{
  width: 5px;
}

.w-\[60\%\]{
  width: 60%;
}

.w-\[60px\]{
  width: 60px;
}

.w-\[64px\]{
  width: 64px;
}

.w-\[68px\]{
  width: 68px;
}

.w-\[6px\]{
  width: 6px;
}

.w-\[70\%\]{
  width: 70%;
}

.w-\[70px\]{
  width: 70px;
}

.w-\[72px\]{
  width: 72px;
}

.w-\[7px\]{
  width: 7px;
}

.w-\[80\%\]{
  width: 80%;
}

.w-\[86\%\]{
  width: 86%;
}

.w-\[88px\]{
  width: 88px;
}

.w-\[8px\]{
  width: 8px;
}

.w-\[calc\(100\%-1\.5rem\)\]{
  width: calc(100% - 1.5rem);
}

.w-\[calc\(100\%-1rem\)\]{
  width: calc(100% - 1rem);
}

.w-\[calc\(100\%-2rem\)\]{
  width: calc(100% - 2rem);
}

.w-\[calc\(100vw-1\.5rem\)\]{
  width: calc(100vw - 1.5rem);
}

.w-\[calc\(100vw-1rem\)\]{
  width: calc(100vw - 1rem);
}

.w-\[min\(18rem\2c calc\(100\%-1\.5rem\)\)\]{
  width: min(18rem,calc(100% - 1.5rem));
}

.w-\[min\(280px\2c calc\(100vw-48px\)\)\]{
  width: min(280px,calc(100vw - 48px));
}

.w-\[min\(320px\2c calc\(100vw-32px\)\)\]{
  width: min(320px,calc(100vw - 32px));
}

.w-auto{
  width: auto;
}

.w-fit{
  width: -moz-fit-content;
  width: fit-content;
}

.w-full{
  width: 100%;
}

.w-max{
  width: -moz-max-content;
  width: max-content;
}

.w-px{
  width: 1px;
}

.w-screen{
  width: 100vw;
}

.min-w-0{
  min-width: 0px;
}

.min-w-11{
  min-width: 2.75rem;
}

.min-w-5{
  min-width: 1.25rem;
}

.min-w-6{
  min-width: 1.5rem;
}

.min-w-9{
  min-width: 2.25rem;
}

.min-w-\[120px\]{
  min-width: 120px;
}

.min-w-\[12rem\]{
  min-width: 12rem;
}

.min-w-\[140px\]{
  min-width: 140px;
}

.min-w-\[1500px\]{
  min-width: 1500px;
}

.min-w-\[160px\]{
  min-width: 160px;
}

.min-w-\[16px\]{
  min-width: 16px;
}

.min-w-\[180px\]{
  min-width: 180px;
}

.min-w-\[18px\]{
  min-width: 18px;
}

.min-w-\[22px\]{
  min-width: 22px;
}

.min-w-\[28px\]{
  min-width: 28px;
}

.min-w-\[2px\]{
  min-width: 2px;
}

.min-w-\[320px\]{
  min-width: 320px;
}

.min-w-\[32px\]{
  min-width: 32px;
}

.min-w-\[34px\]{
  min-width: 34px;
}

.min-w-\[44px\]{
  min-width: 44px;
}

.min-w-\[46px\]{
  min-width: 46px;
}

.min-w-\[480px\]{
  min-width: 480px;
}

.min-w-\[520px\]{
  min-width: 520px;
}

.min-w-\[52px\]{
  min-width: 52px;
}

.min-w-\[680px\]{
  min-width: 680px;
}

.min-w-\[720px\]{
  min-width: 720px;
}

.min-w-\[760px\]{
  min-width: 760px;
}

.min-w-\[820px\]{
  min-width: 820px;
}

.min-w-\[84px\]{
  min-width: 84px;
}

.min-w-\[8rem\]{
  min-width: 8rem;
}

.min-w-\[920px\]{
  min-width: 920px;
}

.min-w-\[980px\]{
  min-width: 980px;
}

.min-w-\[var\(--radix-select-trigger-width\)\]{
  min-width: var(--radix-select-trigger-width);
}

.min-w-full{
  min-width: 100%;
}

.\!max-w-none{
  max-width: none !important;
}

.max-w-2xl{
  max-width: 42rem;
}

.max-w-3xl{
  max-width: 48rem;
}

.max-w-4xl{
  max-width: 56rem;
}

.max-w-5xl{
  max-width: 64rem;
}

.max-w-6xl{
  max-width: 72rem;
}

.max-w-\[--skeleton-width\]{
  max-width: var(--skeleton-width);
}

.max-w-\[100px\]{
  max-width: 100px;
}

.max-w-\[120px\]{
  max-width: 120px;
}

.max-w-\[140px\]{
  max-width: 140px;
}

.max-w-\[180px\]{
  max-width: 180px;
}

.max-w-\[200px\]{
  max-width: 200px;
}

.max-w-\[220px\]{
  max-width: 220px;
}

.max-w-\[240px\]{
  max-width: 240px;
}

.max-w-\[260px\]{
  max-width: 260px;
}

.max-w-\[280px\]{
  max-width: 280px;
}

.max-w-\[28rem\]{
  max-width: 28rem;
}

.max-w-\[300px\]{
  max-width: 300px;
}

.max-w-\[320px\]{
  max-width: 320px;
}

.max-w-\[340px\]{
  max-width: 340px;
}

.max-w-\[360px\]{
  max-width: 360px;
}

.max-w-\[380px\]{
  max-width: 380px;
}

.max-w-\[400px\]{
  max-width: 400px;
}

.max-w-\[42\%\]{
  max-width: 42%;
}

.max-w-\[420px\]{
  max-width: 420px;
}

.max-w-\[430px\]{
  max-width: 430px;
}

.max-w-\[440px\]{
  max-width: 440px;
}

.max-w-\[45\%\]{
  max-width: 45%;
}

.max-w-\[460px\]{
  max-width: 460px;
}

.max-w-\[480px\]{
  max-width: 480px;
}

.max-w-\[500px\]{
  max-width: 500px;
}

.max-w-\[520px\]{
  max-width: 520px;
}

.max-w-\[55\%\]{
  max-width: 55%;
}

.max-w-\[550px\]{
  max-width: 550px;
}

.max-w-\[560px\]{
  max-width: 560px;
}

.max-w-\[60\%\]{
  max-width: 60%;
}

.max-w-\[620px\]{
  max-width: 620px;
}

.max-w-\[700px\]{
  max-width: 700px;
}

.max-w-\[80\%\]{
  max-width: 80%;
}

.max-w-\[88vw\]{
  max-width: 88vw;
}

.max-w-\[96px\]{
  max-width: 96px;
}

.max-w-\[calc\(100\%-132px\)\]{
  max-width: calc(100% - 132px);
}

.max-w-\[calc\(100\%-1rem\)\]{
  max-width: calc(100% - 1rem);
}

.max-w-\[calc\(100\%-4\.75rem\)\]{
  max-width: calc(100% - 4.75rem);
}

.max-w-\[calc\(100vw-1rem\)\]{
  max-width: calc(100vw - 1rem);
}

.max-w-\[calc\(100vw-2rem\)\]{
  max-width: calc(100vw - 2rem);
}

.max-w-\[min\(16rem\2c calc\(100\%-1\.5rem\)\)\]{
  max-width: min(16rem,calc(100% - 1.5rem));
}

.max-w-full{
  max-width: 100%;
}

.max-w-lg{
  max-width: 32rem;
}

.max-w-max{
  max-width: -moz-max-content;
  max-width: max-content;
}

.max-w-md{
  max-width: 28rem;
}

.max-w-none{
  max-width: none;
}

.max-w-prose{
  max-width: 65ch;
}

.max-w-sm{
  max-width: 24rem;
}

.max-w-xl{
  max-width: 36rem;
}

.max-w-xs{
  max-width: 20rem;
}

.flex-1{
  flex: 1 1 0%;
}

.flex-\[1\.4\]{
  flex: 1.4;
}

.flex-\[1\.5\]{
  flex: 1.5;
}

.flex-\[1\.6\]{
  flex: 1.6;
}

.flex-\[2\]{
  flex: 2;
}

.flex-shrink-0{
  flex-shrink: 0;
}

.shrink-0{
  flex-shrink: 0;
}

.grow{
  flex-grow: 1;
}

.grow-0{
  flex-grow: 0;
}

.basis-full{
  flex-basis: 100%;
}

.caption-bottom{
  caption-side: bottom;
}

.border-collapse{
  border-collapse: collapse;
}

.origin-left{
  transform-origin: left;
}

.\!translate-x-0{
  --tw-translate-x: 0px !important;
  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)) !important;
}

.\!translate-y-0{
  --tw-translate-y: 0px !important;
  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)) !important;
}

.-translate-x-1\/2{
  --tw-translate-x: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-x-px{
  --tw-translate-x: -1px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-y-1\/2{
  --tw-translate-y: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-y-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));
}

.-translate-y-\[calc\(100\%\+18px\)\]{
  --tw-translate-y: calc(calc(100% + 18px) * -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));
}

.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));
}

.translate-x-0\.5{
  --tw-translate-x: 0.125rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-1\/2{
  --tw-translate-x: 50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-2{
  --tw-translate-x: 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));
}

.translate-x-4{
  --tw-translate-x: 1rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-\[-50\%\]{
  --tw-translate-x: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.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));
}

.translate-x-px{
  --tw-translate-x: 1px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-y-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));
}

.translate-y-\[-50\%\]{
  --tw-translate-y: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.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));
}

.-rotate-90{
  --tw-rotate: -90deg;
  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));
}

.rotate-0{
  --tw-rotate: 0deg;
  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));
}

.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));
}

.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));
}

.rotate-90{
  --tw-rotate: 90deg;
  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));
}

.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));
}

.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));
}

.scale-\[0\.92\]{
  --tw-scale-x: 0.92;
  --tw-scale-y: 0.92;
  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));
}

.scale-\[0\.998\]{
  --tw-scale-x: 0.998;
  --tw-scale-y: 0.998;
  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));
}

.scale-\[1\.01\]{
  --tw-scale-x: 1.01;
  --tw-scale-y: 1.01;
  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));
}

.scale-\[1\.02\]{
  --tw-scale-x: 1.02;
  --tw-scale-y: 1.02;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.transform{
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.animate-\[mr-long-press-fill_470ms_linear_forwards\]{
  animation: mr-long-press-fill 470ms linear forwards;
}

.animate-\[shimmer_1\.5s_ease-in-out_infinite\]{
  animation: shimmer 1.5s ease-in-out infinite;
}

@keyframes fade-in{

  0%{
    opacity: 0;
    transform: translateY(8px);
  }

  100%{
    opacity: 1;
    transform: translateY(0);
  }
}

.animate-fade-in{
  animation: fade-in 0.35s ease-out;
}

@keyframes ping{

  75%, 100%{
    transform: scale(2);
    opacity: 0;
  }
}

.animate-ping{
  animation: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite;
}

@keyframes ping-slow{

  0%{
    transform: scale(1);
    opacity: 0.5;
  }

  75%, 100%{
    transform: scale(1.08);
    opacity: 0;
  }
}

.animate-ping-slow{
  animation: ping-slow 2.2s cubic-bezier(0,0,0.2,1) infinite;
}

@keyframes pulse{

  50%{
    opacity: .5;
  }
}

.animate-pulse{
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes pulse-soft{

  0%, 100%{
    opacity: 1;
  }

  50%{
    opacity: 0.78;
  }
}

.animate-pulse-soft{
  animation: pulse-soft 2.4s ease-in-out infinite;
}

@keyframes scale-in{

  0%{
    transform: scale(0.96);
    opacity: 0;
  }

  100%{
    transform: scale(1);
    opacity: 1;
  }
}

.animate-scale-in{
  animation: scale-in 0.25s ease-out;
}

@keyframes spin{

  to{
    transform: rotate(360deg);
  }
}

.animate-spin{
  animation: spin 1s linear infinite;
}

.cursor-default{
  cursor: default;
}

.cursor-grab{
  cursor: grab;
}

.cursor-help{
  cursor: help;
}

.cursor-not-allowed{
  cursor: not-allowed;
}

.cursor-pointer{
  cursor: pointer;
}

.cursor-wait{
  cursor: wait;
}

.touch-none{
  touch-action: none;
}

.touch-pan-y{
  --tw-pan-y: pan-y;
  touch-action: var(--tw-pan-x) var(--tw-pan-y) var(--tw-pinch-zoom);
}

.touch-manipulation{
  touch-action: manipulation;
}

.select-none{
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.resize-none{
  resize: none;
}

.resize-y{
  resize: vertical;
}

.resize{
  resize: both;
}

.snap-center{
  scroll-snap-align: center;
}

.scroll-mt-4{
  scroll-margin-top: 1rem;
}

.list-inside{
  list-style-position: inside;
}

.list-decimal{
  list-style-type: decimal;
}

.list-disc{
  list-style-type: disc;
}

.list-none{
  list-style-type: none;
}

.grid-cols-1{
  grid-template-columns: repeat(1, minmax(0, 1fr));
}

.grid-cols-2{
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-cols-3{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-cols-4{
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.grid-cols-5{
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.grid-cols-\[1fr_1fr\]{
  grid-template-columns: 1fr 1fr;
}

.grid-cols-\[1fr_auto_auto_auto_auto\]{
  grid-template-columns: 1fr auto auto auto auto;
}

.grid-cols-\[auto\2c 1fr\]{
  grid-template-columns: auto 1fr;
}

.grid-cols-\[auto_1fr\]{
  grid-template-columns: auto 1fr;
}

.grid-rows-\[0fr\]{
  grid-template-rows: 0fr;
}

.grid-rows-\[1fr\]{
  grid-template-rows: 1fr;
}

.flex-row{
  flex-direction: row;
}

.flex-col{
  flex-direction: column;
}

.flex-col-reverse{
  flex-direction: column-reverse;
}

.flex-wrap{
  flex-wrap: wrap;
}

.place-items-center{
  place-items: center;
}

.items-start{
  align-items: flex-start;
}

.items-end{
  align-items: flex-end;
}

.items-center{
  align-items: center;
}

.items-baseline{
  align-items: baseline;
}

.items-stretch{
  align-items: stretch;
}

.justify-start{
  justify-content: flex-start;
}

.justify-end{
  justify-content: flex-end;
}

.justify-center{
  justify-content: center;
}

.justify-between{
  justify-content: space-between;
}

.justify-around{
  justify-content: space-around;
}

.gap-0{
  gap: 0px;
}

.gap-0\.5{
  gap: 0.125rem;
}

.gap-1{
  gap: 0.25rem;
}

.gap-1\.5{
  gap: 0.375rem;
}

.gap-2{
  gap: 0.5rem;
}

.gap-2\.5{
  gap: 0.625rem;
}

.gap-3{
  gap: 0.75rem;
}

.gap-3\.5{
  gap: 0.875rem;
}

.gap-4{
  gap: 1rem;
}

.gap-5{
  gap: 1.25rem;
}

.gap-6{
  gap: 1.5rem;
}

.gap-\[1\.5\%\]{
  gap: 1.5%;
}

.gap-\[10px\]{
  gap: 10px;
}

.gap-\[2px\]{
  gap: 2px;
}

.gap-\[3px\]{
  gap: 3px;
}

.gap-\[6px\]{
  gap: 6px;
}

.gap-px{
  gap: 1px;
}

.gap-x-1\.5{
  -moz-column-gap: 0.375rem;
       column-gap: 0.375rem;
}

.gap-x-2{
  -moz-column-gap: 0.5rem;
       column-gap: 0.5rem;
}

.gap-x-3{
  -moz-column-gap: 0.75rem;
       column-gap: 0.75rem;
}

.gap-x-4{
  -moz-column-gap: 1rem;
       column-gap: 1rem;
}

.gap-y-0\.5{
  row-gap: 0.125rem;
}

.gap-y-1{
  row-gap: 0.25rem;
}

.gap-y-1\.5{
  row-gap: 0.375rem;
}

.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)));
}

.space-x-4 > :not([hidden]) ~ :not([hidden]){
  --tw-space-x-reverse: 0;
  margin-right: calc(1rem * var(--tw-space-x-reverse));
  margin-left: calc(1rem * calc(1 - var(--tw-space-x-reverse)));
}

.space-y-0 > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(0px * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0px * var(--tw-space-y-reverse));
}

.space-y-0\.5 > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(0.125rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.125rem * var(--tw-space-y-reverse));
}

.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));
}

.space-y-1\.5 > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(0.375rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.375rem * var(--tw-space-y-reverse));
}

.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));
}

.space-y-2\.5 > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(0.625rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.625rem * var(--tw-space-y-reverse));
}

.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));
}

.space-y-3\.5 > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(0.875rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.875rem * var(--tw-space-y-reverse));
}

.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));
}

.space-y-5 > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.25rem * var(--tw-space-y-reverse));
}

.space-y-6 > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}

.space-y-7 > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(1.75rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.75rem * var(--tw-space-y-reverse));
}

.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));
}

.divide-y > :not([hidden]) ~ :not([hidden]){
  --tw-divide-y-reverse: 0;
  border-top-width: calc(1px * calc(1 - var(--tw-divide-y-reverse)));
  border-bottom-width: calc(1px * var(--tw-divide-y-reverse));
}

.divide-border > :not([hidden]) ~ :not([hidden]){
  border-color: hsl(var(--border));
}

.divide-border\/10 > :not([hidden]) ~ :not([hidden]){
  border-color: hsl(var(--border) / 0.1);
}

.divide-border\/15 > :not([hidden]) ~ :not([hidden]){
  border-color: hsl(var(--border) / 0.15);
}

.divide-border\/20 > :not([hidden]) ~ :not([hidden]){
  border-color: hsl(var(--border) / 0.2);
}

.divide-border\/30 > :not([hidden]) ~ :not([hidden]){
  border-color: hsl(var(--border) / 0.3);
}

.divide-border\/40 > :not([hidden]) ~ :not([hidden]){
  border-color: hsl(var(--border) / 0.4);
}

.self-start{
  align-self: flex-start;
}

.self-end{
  align-self: flex-end;
}

.self-center{
  align-self: center;
}

.overflow-auto{
  overflow: auto;
}

.overflow-hidden{
  overflow: hidden;
}

.overflow-visible{
  overflow: visible;
}

.overflow-x-auto{
  overflow-x: auto;
}

.overflow-y-auto{
  overflow-y: auto;
}

.overflow-x-hidden{
  overflow-x: hidden;
}

.overflow-y-visible{
  overflow-y: visible;
}

.overscroll-contain{
  overscroll-behavior: contain;
}

.scroll-smooth{
  scroll-behavior: smooth;
}

.truncate{
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.text-ellipsis{
  text-overflow: ellipsis;
}

.whitespace-normal{
  white-space: normal;
}

.whitespace-nowrap{
  white-space: nowrap;
}

.whitespace-pre-line{
  white-space: pre-line;
}

.whitespace-pre-wrap{
  white-space: pre-wrap;
}

.text-wrap{
  text-wrap: wrap;
}

.break-words{
  overflow-wrap: break-word;
}

.break-all{
  word-break: break-all;
}

.rounded{
  border-radius: 0.25rem;
}

.rounded-2xl{
  border-radius: calc(var(--radius) + 8px);
}

.rounded-3xl{
  border-radius: 1.5rem;
}

.rounded-\[10px\]{
  border-radius: 10px;
}

.rounded-\[11px\]{
  border-radius: 11px;
}

.rounded-\[12px\]{
  border-radius: 12px;
}

.rounded-\[13px\]{
  border-radius: 13px;
}

.rounded-\[14px\]{
  border-radius: 14px;
}

.rounded-\[15px\]{
  border-radius: 15px;
}

.rounded-\[16px\]{
  border-radius: 16px;
}

.rounded-\[18px\]{
  border-radius: 18px;
}

.rounded-\[20px\]{
  border-radius: 20px;
}

.rounded-\[22px\]{
  border-radius: 22px;
}

.rounded-\[24px\]{
  border-radius: 24px;
}

.rounded-\[26px\]{
  border-radius: 26px;
}

.rounded-\[28px\]{
  border-radius: 28px;
}

.rounded-\[2px\]{
  border-radius: 2px;
}

.rounded-\[5px\]{
  border-radius: 5px;
}

.rounded-\[6px\]{
  border-radius: 6px;
}

.rounded-\[8px\]{
  border-radius: 8px;
}

.rounded-\[calc\(var\(--radius-lg\)-2px\)\]{
  border-radius: calc(var(--radius-lg) - 2px);
}

.rounded-\[inherit\]{
  border-radius: inherit;
}

.rounded-full{
  border-radius: 9999px;
}

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

.rounded-md{
  border-radius: calc(var(--radius) - 2px);
}

.rounded-none{
  border-radius: 0px;
}

.rounded-sm{
  border-radius: calc(var(--radius) - 4px);
}

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

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

.rounded-token-pill{
  border-radius: var(--radius-pill);
}

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

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

.rounded-xl{
  border-radius: calc(var(--radius) + 4px);
}

.rounded-b-2xl{
  border-bottom-right-radius: calc(var(--radius) + 8px);
  border-bottom-left-radius: calc(var(--radius) + 8px);
}

.rounded-b-\[12px\]{
  border-bottom-right-radius: 12px;
  border-bottom-left-radius: 12px;
}

.rounded-b-\[16px\]{
  border-bottom-right-radius: 16px;
  border-bottom-left-radius: 16px;
}

.rounded-b-\[20px\]{
  border-bottom-right-radius: 20px;
  border-bottom-left-radius: 20px;
}

.rounded-b-\[24px\]{
  border-bottom-right-radius: 24px;
  border-bottom-left-radius: 24px;
}

.rounded-b-none{
  border-bottom-right-radius: 0px;
  border-bottom-left-radius: 0px;
}

.rounded-l-\[18px\]{
  border-top-left-radius: 18px;
  border-bottom-left-radius: 18px;
}

.rounded-l-\[20px\]{
  border-top-left-radius: 20px;
  border-bottom-left-radius: 20px;
}

.rounded-l-full{
  border-top-left-radius: 9999px;
  border-bottom-left-radius: 9999px;
}

.rounded-r-full{
  border-top-right-radius: 9999px;
  border-bottom-right-radius: 9999px;
}

.rounded-t{
  border-top-left-radius: 0.25rem;
  border-top-right-radius: 0.25rem;
}

.rounded-t-2xl{
  border-top-left-radius: calc(var(--radius) + 8px);
  border-top-right-radius: calc(var(--radius) + 8px);
}

.rounded-t-3xl{
  border-top-left-radius: 1.5rem;
  border-top-right-radius: 1.5rem;
}

.rounded-t-\[10px\]{
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.rounded-t-\[16px\]{
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
}

.rounded-t-\[20px\]{
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
}

.rounded-t-\[22px\]{
  border-top-left-radius: 22px;
  border-top-right-radius: 22px;
}

.rounded-t-\[24px\]{
  border-top-left-radius: 24px;
  border-top-right-radius: 24px;
}

.rounded-t-\[28px\]{
  border-top-left-radius: 28px;
  border-top-right-radius: 28px;
}

.rounded-t-\[32px\]{
  border-top-left-radius: 32px;
  border-top-right-radius: 32px;
}

.rounded-t-sm{
  border-top-left-radius: calc(var(--radius) - 4px);
  border-top-right-radius: calc(var(--radius) - 4px);
}

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

.rounded-t-token-xl{
  border-top-left-radius: var(--radius-xl);
  border-top-right-radius: var(--radius-xl);
}

.rounded-bl-lg{
  border-bottom-left-radius: var(--radius);
}

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

.rounded-tl-lg{
  border-top-left-radius: var(--radius);
}

.rounded-tl-sm{
  border-top-left-radius: calc(var(--radius) - 4px);
}

.rounded-tr-lg{
  border-top-right-radius: var(--radius);
}

.border{
  border-width: 1px;
}

.border-0{
  border-width: 0px;
}

.border-2{
  border-width: 2px;
}

.border-\[2\.5px\]{
  border-width: 2.5px;
}

.border-\[2px\]{
  border-width: 2px;
}

.border-\[3px\]{
  border-width: 3px;
}

.border-\[6px\]{
  border-width: 6px;
}

.border-x{
  border-left-width: 1px;
  border-right-width: 1px;
}

.border-x-\[5px\]{
  border-left-width: 5px;
  border-right-width: 5px;
}

.border-y{
  border-top-width: 1px;
  border-bottom-width: 1px;
}

.border-b{
  border-bottom-width: 1px;
}

.border-b-2{
  border-bottom-width: 2px;
}

.border-l{
  border-left-width: 1px;
}

.border-l-2{
  border-left-width: 2px;
}

.border-l-4{
  border-left-width: 4px;
}

.border-l-\[3px\]{
  border-left-width: 3px;
}

.border-l-\[5px\]{
  border-left-width: 5px;
}

.border-r{
  border-right-width: 1px;
}

.border-r-2{
  border-right-width: 2px;
}

.border-r-\[5px\]{
  border-right-width: 5px;
}

.border-t{
  border-top-width: 1px;
}

.border-t-2{
  border-top-width: 2px;
}

.border-t-\[5px\]{
  border-top-width: 5px;
}

.border-dashed{
  border-style: dashed;
}

.border-none{
  border-style: none;
}

.border-\[\#25D366\]\/20{
  border-color: rgb(37 211 102 / 0.2);
}

.border-\[\#25D366\]\/25{
  border-color: rgb(37 211 102 / 0.25);
}

.border-\[\#25D366\]\/30{
  border-color: rgb(37 211 102 / 0.3);
}

.border-\[\#25D366\]\/40{
  border-color: rgb(37 211 102 / 0.4);
}

.border-accent\/15{
  border-color: hsl(var(--accent) / 0.15);
}

.border-amber-200{
  --tw-border-opacity: 1;
  border-color: rgb(253 230 138 / var(--tw-border-opacity, 1));
}

.border-amber-300\/50{
  border-color: rgb(252 211 77 / 0.5);
}

.border-amber-400\/35{
  border-color: rgb(251 191 36 / 0.35);
}

.border-amber-500\/30{
  border-color: rgb(245 158 11 / 0.3);
}

.border-amber-500\/40{
  border-color: rgb(245 158 11 / 0.4);
}

.border-background{
  border-color: hsl(var(--background));
}

.border-border{
  border-color: hsl(var(--border));
}

.border-border\/10{
  border-color: hsl(var(--border) / 0.1);
}

.border-border\/15{
  border-color: hsl(var(--border) / 0.15);
}

.border-border\/20{
  border-color: hsl(var(--border) / 0.2);
}

.border-border\/25{
  border-color: hsl(var(--border) / 0.25);
}

.border-border\/30{
  border-color: hsl(var(--border) / 0.3);
}

.border-border\/35{
  border-color: hsl(var(--border) / 0.35);
}

.border-border\/40{
  border-color: hsl(var(--border) / 0.4);
}

.border-border\/50{
  border-color: hsl(var(--border) / 0.5);
}

.border-border\/55{
  border-color: hsl(var(--border) / 0.55);
}

.border-border\/60{
  border-color: hsl(var(--border) / 0.6);
}

.border-border\/70{
  border-color: hsl(var(--border) / 0.7);
}

.border-current{
  border-color: currentColor;
}

.border-destructive{
  border-color: hsl(var(--destructive));
}

.border-destructive\/10{
  border-color: hsl(var(--destructive) / 0.1);
}

.border-destructive\/15{
  border-color: hsl(var(--destructive) / 0.15);
}

.border-destructive\/20{
  border-color: hsl(var(--destructive) / 0.2);
}

.border-destructive\/25{
  border-color: hsl(var(--destructive) / 0.25);
}

.border-destructive\/30{
  border-color: hsl(var(--destructive) / 0.3);
}

.border-destructive\/35{
  border-color: hsl(var(--destructive) / 0.35);
}

.border-destructive\/40{
  border-color: hsl(var(--destructive) / 0.4);
}

.border-destructive\/50{
  border-color: hsl(var(--destructive) / 0.5);
}

.border-destructive\/55{
  border-color: hsl(var(--destructive) / 0.55);
}

.border-destructive\/60{
  border-color: hsl(var(--destructive) / 0.6);
}

.border-foreground{
  border-color: hsl(var(--foreground));
}

.border-foreground\/\[0\.06\]{
  border-color: hsl(var(--foreground) / 0.06);
}

.border-green-800\/50{
  border-color: rgb(22 101 52 / 0.5);
}

.border-info{
  border-color: hsl(var(--info));
}

.border-info\/10{
  border-color: hsl(var(--info) / 0.1);
}

.border-info\/15{
  border-color: hsl(var(--info) / 0.15);
}

.border-info\/20{
  border-color: hsl(var(--info) / 0.2);
}

.border-info\/25{
  border-color: hsl(var(--info) / 0.25);
}

.border-info\/30{
  border-color: hsl(var(--info) / 0.3);
}

.border-info\/35{
  border-color: hsl(var(--info) / 0.35);
}

.border-info\/40{
  border-color: hsl(var(--info) / 0.4);
}

.border-info\/45{
  border-color: hsl(var(--info) / 0.45);
}

.border-input{
  border-color: hsl(var(--input));
}

.border-muted-foreground\/20{
  border-color: hsl(var(--muted-foreground) / 0.2);
}

.border-muted-foreground\/30{
  border-color: hsl(var(--muted-foreground) / 0.3);
}

.border-muted-foreground\/40{
  border-color: hsl(var(--muted-foreground) / 0.4);
}

.border-neutral-950\/10{
  border-color: rgb(10 10 10 / 0.1);
}

.border-orange-300{
  --tw-border-opacity: 1;
  border-color: rgb(253 186 116 / var(--tw-border-opacity, 1));
}

.border-orange-300\/40{
  border-color: rgb(253 186 116 / 0.4);
}

.border-orange-500\/25{
  border-color: rgb(249 115 22 / 0.25);
}

.border-orange-500\/30{
  border-color: rgb(249 115 22 / 0.3);
}

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

.border-primary-foreground\/25{
  border-color: hsl(var(--primary-foreground) / 0.25);
}

.border-primary\/10{
  border-color: hsl(var(--primary) / 0.1);
}

.border-primary\/15{
  border-color: hsl(var(--primary) / 0.15);
}

.border-primary\/20{
  border-color: hsl(var(--primary) / 0.2);
}

.border-primary\/25{
  border-color: hsl(var(--primary) / 0.25);
}

.border-primary\/30{
  border-color: hsl(var(--primary) / 0.3);
}

.border-primary\/35{
  border-color: hsl(var(--primary) / 0.35);
}

.border-primary\/40{
  border-color: hsl(var(--primary) / 0.4);
}

.border-primary\/45{
  border-color: hsl(var(--primary) / 0.45);
}

.border-primary\/50{
  border-color: hsl(var(--primary) / 0.5);
}

.border-primary\/55{
  border-color: hsl(var(--primary) / 0.55);
}

.border-primary\/60{
  border-color: hsl(var(--primary) / 0.6);
}

.border-primary\/65{
  border-color: hsl(var(--primary) / 0.65);
}

.border-primary\/70{
  border-color: hsl(var(--primary) / 0.7);
}

.border-primary\/80{
  border-color: hsl(var(--primary) / 0.8);
}

.border-purple-500\/30{
  border-color: rgb(168 85 247 / 0.3);
}

.border-purple\/20{
  border-color: hsl(var(--purple) / 0.2);
}

.border-purple\/25{
  border-color: hsl(var(--purple) / 0.25);
}

.border-purple\/30{
  border-color: hsl(var(--purple) / 0.3);
}

.border-purple\/40{
  border-color: hsl(var(--purple) / 0.4);
}

.border-red-200\/40{
  border-color: rgb(254 202 202 / 0.4);
}

.border-red-300{
  --tw-border-opacity: 1;
  border-color: rgb(252 165 165 / var(--tw-border-opacity, 1));
}

.border-red-700{
  --tw-border-opacity: 1;
  border-color: rgb(185 28 28 / var(--tw-border-opacity, 1));
}

.border-red-800{
  --tw-border-opacity: 1;
  border-color: rgb(153 27 27 / var(--tw-border-opacity, 1));
}

.border-red-800\/30{
  border-color: rgb(153 27 27 / 0.3);
}

.border-red-800\/50{
  border-color: rgb(153 27 27 / 0.5);
}

.border-sidebar-border{
  border-color: hsl(var(--sidebar-border));
}

.border-success{
  border-color: hsl(var(--success));
}

.border-success\/10{
  border-color: hsl(var(--success) / 0.1);
}

.border-success\/15{
  border-color: hsl(var(--success) / 0.15);
}

.border-success\/20{
  border-color: hsl(var(--success) / 0.2);
}

.border-success\/25{
  border-color: hsl(var(--success) / 0.25);
}

.border-success\/30{
  border-color: hsl(var(--success) / 0.3);
}

.border-success\/35{
  border-color: hsl(var(--success) / 0.35);
}

.border-success\/40{
  border-color: hsl(var(--success) / 0.4);
}

.border-success\/50{
  border-color: hsl(var(--success) / 0.5);
}

.border-success\/55{
  border-color: hsl(var(--success) / 0.55);
}

.border-transparent{
  border-color: transparent;
}

.border-warning{
  border-color: hsl(var(--warning));
}

.border-warning\/10{
  border-color: hsl(var(--warning) / 0.1);
}

.border-warning\/20{
  border-color: hsl(var(--warning) / 0.2);
}

.border-warning\/25{
  border-color: hsl(var(--warning) / 0.25);
}

.border-warning\/30{
  border-color: hsl(var(--warning) / 0.3);
}

.border-warning\/35{
  border-color: hsl(var(--warning) / 0.35);
}

.border-warning\/40{
  border-color: hsl(var(--warning) / 0.4);
}

.border-warning\/50{
  border-color: hsl(var(--warning) / 0.5);
}

.border-white{
  --tw-border-opacity: 1;
  border-color: rgb(255 255 255 / var(--tw-border-opacity, 1));
}

.border-white\/10{
  border-color: rgb(255 255 255 / 0.1);
}

.border-white\/20{
  border-color: rgb(255 255 255 / 0.2);
}

.border-white\/5{
  border-color: rgb(255 255 255 / 0.05);
}

.border-white\/50{
  border-color: rgb(255 255 255 / 0.5);
}

.border-white\/65{
  border-color: rgb(255 255 255 / 0.65);
}

.border-white\/70{
  border-color: rgb(255 255 255 / 0.7);
}

.border-white\/\[0\.06\]{
  border-color: rgb(255 255 255 / 0.06);
}

.border-white\/\[0\.08\]{
  border-color: rgb(255 255 255 / 0.08);
}

.border-zinc-600{
  --tw-border-opacity: 1;
  border-color: rgb(82 82 91 / var(--tw-border-opacity, 1));
}

.border-x-transparent{
  border-left-color: transparent;
  border-right-color: transparent;
}

.border-b-primary{
  border-bottom-color: hsl(var(--primary));
}

.border-b-primary\/30{
  border-bottom-color: hsl(var(--primary) / 0.3);
}

.border-l-destructive{
  border-left-color: hsl(var(--destructive));
}

.border-l-destructive\/70{
  border-left-color: hsl(var(--destructive) / 0.7);
}

.border-l-info{
  border-left-color: hsl(var(--info));
}

.border-l-info\/70{
  border-left-color: hsl(var(--info) / 0.7);
}

.border-l-primary{
  border-left-color: hsl(var(--primary));
}

.border-l-success\/70{
  border-left-color: hsl(var(--success) / 0.7);
}

.border-l-transparent{
  border-left-color: transparent;
}

.border-l-warning{
  border-left-color: hsl(var(--warning));
}

.border-l-warning\/70{
  border-left-color: hsl(var(--warning) / 0.7);
}

.border-r-transparent{
  border-right-color: transparent;
}

.border-t-border\/60{
  border-top-color: hsl(var(--border) / 0.6);
}

.border-t-destructive\/40{
  border-top-color: hsl(var(--destructive) / 0.4);
}

.border-t-popover\/95{
  border-top-color: hsl(var(--popover) / 0.95);
}

.border-t-primary{
  border-top-color: hsl(var(--primary));
}

.border-t-primary-foreground{
  border-top-color: hsl(var(--primary-foreground));
}

.border-t-transparent{
  border-top-color: transparent;
}

.bg-\[\#010101\]{
  --tw-bg-opacity: 1;
  background-color: rgb(1 1 1 / var(--tw-bg-opacity, 1));
}

.bg-\[\#101318\]{
  --tw-bg-opacity: 1;
  background-color: rgb(16 19 24 / var(--tw-bg-opacity, 1));
}

.bg-\[\#25D366\]{
  --tw-bg-opacity: 1;
  background-color: rgb(37 211 102 / var(--tw-bg-opacity, 1));
}

.bg-\[\#25D366\]\/10{
  background-color: rgb(37 211 102 / 0.1);
}

.bg-\[\#25D366\]\/15{
  background-color: rgb(37 211 102 / 0.15);
}

.bg-\[\#25D366\]\/20{
  background-color: rgb(37 211 102 / 0.2);
}

.bg-\[\#25D366\]\/40{
  background-color: rgb(37 211 102 / 0.4);
}

.bg-\[\#dcf8c6\]{
  --tw-bg-opacity: 1;
  background-color: rgb(220 248 198 / var(--tw-bg-opacity, 1));
}

.bg-\[hsl\(78\2c 78\%\2c 58\%\)\]{
  --tw-bg-opacity: 1;
  background-color: hsl(78 78% 58% / var(--tw-bg-opacity, 1));
}

.bg-\[hsl\(var\(--overlay\)\)\]{
  background-color: hsl(var(--overlay));
}

.bg-\[hsl\(var\(--warning\)\/0\.15\)\]{
  background-color: hsl(var(--warning)/0.15);
}

.bg-\[hsl\(var\(--warning\2c 40_100\%_50\%\)\)\]{
  background-color: hsl(var(--warning,40 100% 50%));
}

.bg-\[radial-gradient\(circle_at_top_left\2c hsl\(var\(--primary\)\/0\.14\)\2c transparent_38\%\)\2c hsl\(var\(--card\)\)\]{
  background-color: radial-gradient(circle at top left,hsl(var(--primary)/0.14),transparent 38%),hsl(var(--card));
}

.bg-accent{
  background-color: hsl(var(--accent));
}

.bg-amber-50{
  --tw-bg-opacity: 1;
  background-color: rgb(255 251 235 / var(--tw-bg-opacity, 1));
}

.bg-amber-50\/40{
  background-color: rgb(255 251 235 / 0.4);
}

.bg-amber-500{
  --tw-bg-opacity: 1;
  background-color: rgb(245 158 11 / var(--tw-bg-opacity, 1));
}

.bg-amber-500\/10{
  background-color: rgb(245 158 11 / 0.1);
}

.bg-amber-500\/15{
  background-color: rgb(245 158 11 / 0.15);
}

.bg-amber-500\/20{
  background-color: rgb(245 158 11 / 0.2);
}

.bg-amber-500\/5{
  background-color: rgb(245 158 11 / 0.05);
}

.bg-background{
  background-color: hsl(var(--background));
}

.bg-background\/20{
  background-color: hsl(var(--background) / 0.2);
}

.bg-background\/30{
  background-color: hsl(var(--background) / 0.3);
}

.bg-background\/35{
  background-color: hsl(var(--background) / 0.35);
}

.bg-background\/40{
  background-color: hsl(var(--background) / 0.4);
}

.bg-background\/45{
  background-color: hsl(var(--background) / 0.45);
}

.bg-background\/50{
  background-color: hsl(var(--background) / 0.5);
}

.bg-background\/55{
  background-color: hsl(var(--background) / 0.55);
}

.bg-background\/60{
  background-color: hsl(var(--background) / 0.6);
}

.bg-background\/65{
  background-color: hsl(var(--background) / 0.65);
}

.bg-background\/70{
  background-color: hsl(var(--background) / 0.7);
}

.bg-background\/75{
  background-color: hsl(var(--background) / 0.75);
}

.bg-background\/80{
  background-color: hsl(var(--background) / 0.8);
}

.bg-background\/85{
  background-color: hsl(var(--background) / 0.85);
}

.bg-background\/90{
  background-color: hsl(var(--background) / 0.9);
}

.bg-background\/95{
  background-color: hsl(var(--background) / 0.95);
}

.bg-black{
  --tw-bg-opacity: 1;
  background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}

.bg-black\/20{
  background-color: rgb(0 0 0 / 0.2);
}

.bg-black\/30{
  background-color: rgb(0 0 0 / 0.3);
}

.bg-black\/40{
  background-color: rgb(0 0 0 / 0.4);
}

.bg-black\/50{
  background-color: rgb(0 0 0 / 0.5);
}

.bg-black\/55{
  background-color: rgb(0 0 0 / 0.55);
}

.bg-black\/60{
  background-color: rgb(0 0 0 / 0.6);
}

.bg-black\/70{
  background-color: rgb(0 0 0 / 0.7);
}

.bg-black\/90{
  background-color: rgb(0 0 0 / 0.9);
}

.bg-blue-100{
  --tw-bg-opacity: 1;
  background-color: rgb(219 234 254 / var(--tw-bg-opacity, 1));
}

.bg-blue-500{
  --tw-bg-opacity: 1;
  background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1));
}

.bg-border{
  background-color: hsl(var(--border));
}

.bg-border\/10{
  background-color: hsl(var(--border) / 0.1);
}

.bg-border\/15{
  background-color: hsl(var(--border) / 0.15);
}

.bg-border\/20{
  background-color: hsl(var(--border) / 0.2);
}

.bg-border\/25{
  background-color: hsl(var(--border) / 0.25);
}

.bg-border\/30{
  background-color: hsl(var(--border) / 0.3);
}

.bg-border\/40{
  background-color: hsl(var(--border) / 0.4);
}

.bg-border\/50{
  background-color: hsl(var(--border) / 0.5);
}

.bg-border\/60{
  background-color: hsl(var(--border) / 0.6);
}

.bg-border\/70{
  background-color: hsl(var(--border) / 0.7);
}

.bg-border\/80{
  background-color: hsl(var(--border) / 0.8);
}

.bg-card{
  background-color: hsl(var(--card));
}

.bg-card\/30{
  background-color: hsl(var(--card) / 0.3);
}

.bg-card\/35{
  background-color: hsl(var(--card) / 0.35);
}

.bg-card\/40{
  background-color: hsl(var(--card) / 0.4);
}

.bg-card\/50{
  background-color: hsl(var(--card) / 0.5);
}

.bg-card\/60{
  background-color: hsl(var(--card) / 0.6);
}

.bg-card\/70{
  background-color: hsl(var(--card) / 0.7);
}

.bg-card\/75{
  background-color: hsl(var(--card) / 0.75);
}

.bg-card\/80{
  background-color: hsl(var(--card) / 0.8);
}

.bg-card\/90{
  background-color: hsl(var(--card) / 0.9);
}

.bg-card\/95{
  background-color: hsl(var(--card) / 0.95);
}

.bg-current{
  background-color: currentColor;
}

.bg-destructive{
  background-color: hsl(var(--destructive));
}

.bg-destructive-foreground{
  background-color: hsl(var(--destructive-foreground));
}

.bg-destructive\/10{
  background-color: hsl(var(--destructive) / 0.1);
}

.bg-destructive\/15{
  background-color: hsl(var(--destructive) / 0.15);
}

.bg-destructive\/20{
  background-color: hsl(var(--destructive) / 0.2);
}

.bg-destructive\/25{
  background-color: hsl(var(--destructive) / 0.25);
}

.bg-destructive\/5{
  background-color: hsl(var(--destructive) / 0.05);
}

.bg-destructive\/60{
  background-color: hsl(var(--destructive) / 0.6);
}

.bg-destructive\/70{
  background-color: hsl(var(--destructive) / 0.7);
}

.bg-destructive\/80{
  background-color: hsl(var(--destructive) / 0.8);
}

.bg-destructive\/90{
  background-color: hsl(var(--destructive) / 0.9);
}

.bg-destructive\/\[0\.06\]{
  background-color: hsl(var(--destructive) / 0.06);
}

.bg-destructive\/\[0\.08\]{
  background-color: hsl(var(--destructive) / 0.08);
}

.bg-emerald-100{
  --tw-bg-opacity: 1;
  background-color: rgb(209 250 229 / var(--tw-bg-opacity, 1));
}

.bg-emerald-500{
  --tw-bg-opacity: 1;
  background-color: rgb(16 185 129 / var(--tw-bg-opacity, 1));
}

.bg-foreground{
  background-color: hsl(var(--foreground));
}

.bg-foreground\/10{
  background-color: hsl(var(--foreground) / 0.1);
}

.bg-foreground\/15{
  background-color: hsl(var(--foreground) / 0.15);
}

.bg-foreground\/20{
  background-color: hsl(var(--foreground) / 0.2);
}

.bg-foreground\/5{
  background-color: hsl(var(--foreground) / 0.05);
}

.bg-foreground\/95{
  background-color: hsl(var(--foreground) / 0.95);
}

.bg-foreground\/\[0\.02\]{
  background-color: hsl(var(--foreground) / 0.02);
}

.bg-foreground\/\[0\.04\]{
  background-color: hsl(var(--foreground) / 0.04);
}

.bg-foreground\/\[0\.05\]{
  background-color: hsl(var(--foreground) / 0.05);
}

.bg-foreground\/\[0\.06\]{
  background-color: hsl(var(--foreground) / 0.06);
}

.bg-foreground\/\[0\.07\]{
  background-color: hsl(var(--foreground) / 0.07);
}

.bg-gray-100{
  --tw-bg-opacity: 1;
  background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1));
}

.bg-gray-200{
  --tw-bg-opacity: 1;
  background-color: rgb(229 231 235 / var(--tw-bg-opacity, 1));
}

.bg-green-400\/10{
  background-color: rgb(74 222 128 / 0.1);
}

.bg-green-500{
  --tw-bg-opacity: 1;
  background-color: rgb(34 197 94 / var(--tw-bg-opacity, 1));
}

.bg-green-500\/15{
  background-color: rgb(34 197 94 / 0.15);
}

.bg-green-900\/20{
  background-color: rgb(20 83 45 / 0.2);
}

.bg-info{
  background-color: hsl(var(--info));
}

.bg-info\/10{
  background-color: hsl(var(--info) / 0.1);
}

.bg-info\/15{
  background-color: hsl(var(--info) / 0.15);
}

.bg-info\/20{
  background-color: hsl(var(--info) / 0.2);
}

.bg-info\/25{
  background-color: hsl(var(--info) / 0.25);
}

.bg-info\/5{
  background-color: hsl(var(--info) / 0.05);
}

.bg-info\/60{
  background-color: hsl(var(--info) / 0.6);
}

.bg-info\/70{
  background-color: hsl(var(--info) / 0.7);
}

.bg-info\/\[0\.04\]{
  background-color: hsl(var(--info) / 0.04);
}

.bg-info\/\[0\.05\]{
  background-color: hsl(var(--info) / 0.05);
}

.bg-info\/\[0\.06\]{
  background-color: hsl(var(--info) / 0.06);
}

.bg-info\/\[0\.07\]{
  background-color: hsl(var(--info) / 0.07);
}

.bg-info\/\[0\.08\]{
  background-color: hsl(var(--info) / 0.08);
}

.bg-lime-400\/80{
  background-color: rgb(163 230 53 / 0.8);
}

.bg-muted{
  background-color: hsl(var(--muted));
}

.bg-muted-foreground{
  background-color: hsl(var(--muted-foreground));
}

.bg-muted-foreground\/20{
  background-color: hsl(var(--muted-foreground) / 0.2);
}

.bg-muted-foreground\/30{
  background-color: hsl(var(--muted-foreground) / 0.3);
}

.bg-muted-foreground\/40{
  background-color: hsl(var(--muted-foreground) / 0.4);
}

.bg-muted-foreground\/50{
  background-color: hsl(var(--muted-foreground) / 0.5);
}

.bg-muted\/10{
  background-color: hsl(var(--muted) / 0.1);
}

.bg-muted\/20{
  background-color: hsl(var(--muted) / 0.2);
}

.bg-muted\/25{
  background-color: hsl(var(--muted) / 0.25);
}

.bg-muted\/30{
  background-color: hsl(var(--muted) / 0.3);
}

.bg-muted\/35{
  background-color: hsl(var(--muted) / 0.35);
}

.bg-muted\/40{
  background-color: hsl(var(--muted) / 0.4);
}

.bg-muted\/5{
  background-color: hsl(var(--muted) / 0.05);
}

.bg-muted\/50{
  background-color: hsl(var(--muted) / 0.5);
}

.bg-muted\/60{
  background-color: hsl(var(--muted) / 0.6);
}

.bg-muted\/70{
  background-color: hsl(var(--muted) / 0.7);
}

.bg-muted\/80{
  background-color: hsl(var(--muted) / 0.8);
}

.bg-neutral-50{
  --tw-bg-opacity: 1;
  background-color: rgb(250 250 250 / var(--tw-bg-opacity, 1));
}

.bg-neutral-950\/20{
  background-color: rgb(10 10 10 / 0.2);
}

.bg-neutral-950\/\[0\.025\]{
  background-color: rgb(10 10 10 / 0.025);
}

.bg-orange-50\/30{
  background-color: rgb(255 247 237 / 0.3);
}

.bg-orange-500{
  --tw-bg-opacity: 1;
  background-color: rgb(249 115 22 / var(--tw-bg-opacity, 1));
}

.bg-orange-500\/10{
  background-color: rgb(249 115 22 / 0.1);
}

.bg-orange-600{
  --tw-bg-opacity: 1;
  background-color: rgb(234 88 12 / var(--tw-bg-opacity, 1));
}

.bg-popover{
  background-color: hsl(var(--popover));
}

.bg-popover\/95{
  background-color: hsl(var(--popover) / 0.95);
}

.bg-primary{
  background-color: hsl(var(--primary));
}

.bg-primary-foreground{
  background-color: hsl(var(--primary-foreground));
}

.bg-primary-foreground\/10{
  background-color: hsl(var(--primary-foreground) / 0.1);
}

.bg-primary-foreground\/15{
  background-color: hsl(var(--primary-foreground) / 0.15);
}

.bg-primary-foreground\/20{
  background-color: hsl(var(--primary-foreground) / 0.2);
}

.bg-primary-foreground\/40{
  background-color: hsl(var(--primary-foreground) / 0.4);
}

.bg-primary\/10{
  background-color: hsl(var(--primary) / 0.1);
}

.bg-primary\/15{
  background-color: hsl(var(--primary) / 0.15);
}

.bg-primary\/20{
  background-color: hsl(var(--primary) / 0.2);
}

.bg-primary\/40{
  background-color: hsl(var(--primary) / 0.4);
}

.bg-primary\/5{
  background-color: hsl(var(--primary) / 0.05);
}

.bg-primary\/60{
  background-color: hsl(var(--primary) / 0.6);
}

.bg-primary\/70{
  background-color: hsl(var(--primary) / 0.7);
}

.bg-primary\/90{
  background-color: hsl(var(--primary) / 0.9);
}

.bg-primary\/\[0\.025\]{
  background-color: hsl(var(--primary) / 0.025);
}

.bg-primary\/\[0\.03\]{
  background-color: hsl(var(--primary) / 0.03);
}

.bg-primary\/\[0\.04\]{
  background-color: hsl(var(--primary) / 0.04);
}

.bg-primary\/\[0\.05\]{
  background-color: hsl(var(--primary) / 0.05);
}

.bg-primary\/\[0\.06\]{
  background-color: hsl(var(--primary) / 0.06);
}

.bg-primary\/\[0\.07\]{
  background-color: hsl(var(--primary) / 0.07);
}

.bg-primary\/\[0\.08\]{
  background-color: hsl(var(--primary) / 0.08);
}

.bg-primary\/\[0\.10\]{
  background-color: hsl(var(--primary) / 0.10);
}

.bg-primary\/\[0\.12\]{
  background-color: hsl(var(--primary) / 0.12);
}

.bg-primary\/\[0\.1\]{
  background-color: hsl(var(--primary) / 0.1);
}

.bg-purple{
  background-color: hsl(var(--purple));
}

.bg-purple-500{
  --tw-bg-opacity: 1;
  background-color: rgb(168 85 247 / var(--tw-bg-opacity, 1));
}

.bg-purple-500\/15{
  background-color: rgb(168 85 247 / 0.15);
}

.bg-purple-500\/60{
  background-color: rgb(168 85 247 / 0.6);
}

.bg-purple\/10{
  background-color: hsl(var(--purple) / 0.1);
}

.bg-purple\/15{
  background-color: hsl(var(--purple) / 0.15);
}

.bg-purple\/20{
  background-color: hsl(var(--purple) / 0.2);
}

.bg-purple\/5{
  background-color: hsl(var(--purple) / 0.05);
}

.bg-purple\/\[0\.05\]{
  background-color: hsl(var(--purple) / 0.05);
}

.bg-purple\/\[0\.06\]{
  background-color: hsl(var(--purple) / 0.06);
}

.bg-purple\/\[0\.10\]{
  background-color: hsl(var(--purple) / 0.10);
}

.bg-red-100{
  --tw-bg-opacity: 1;
  background-color: rgb(254 226 226 / var(--tw-bg-opacity, 1));
}

.bg-red-400\/10{
  background-color: rgb(248 113 113 / 0.1);
}

.bg-red-50\/50{
  background-color: rgb(254 242 242 / 0.5);
}

.bg-red-500{
  --tw-bg-opacity: 1;
  background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1));
}

.bg-red-600{
  --tw-bg-opacity: 1;
  background-color: rgb(220 38 38 / var(--tw-bg-opacity, 1));
}

.bg-red-700{
  --tw-bg-opacity: 1;
  background-color: rgb(185 28 28 / var(--tw-bg-opacity, 1));
}

.bg-red-900\/10{
  background-color: rgb(127 29 29 / 0.1);
}

.bg-red-900\/20{
  background-color: rgb(127 29 29 / 0.2);
}

.bg-red-900\/30{
  background-color: rgb(127 29 29 / 0.3);
}

.bg-secondary{
  background-color: hsl(var(--secondary));
}

.bg-secondary\/10{
  background-color: hsl(var(--secondary) / 0.1);
}

.bg-secondary\/15{
  background-color: hsl(var(--secondary) / 0.15);
}

.bg-secondary\/20{
  background-color: hsl(var(--secondary) / 0.2);
}

.bg-secondary\/25{
  background-color: hsl(var(--secondary) / 0.25);
}

.bg-secondary\/30{
  background-color: hsl(var(--secondary) / 0.3);
}

.bg-secondary\/35{
  background-color: hsl(var(--secondary) / 0.35);
}

.bg-secondary\/40{
  background-color: hsl(var(--secondary) / 0.4);
}

.bg-secondary\/50{
  background-color: hsl(var(--secondary) / 0.5);
}

.bg-secondary\/60{
  background-color: hsl(var(--secondary) / 0.6);
}

.bg-secondary\/70{
  background-color: hsl(var(--secondary) / 0.7);
}

.bg-secondary\/80{
  background-color: hsl(var(--secondary) / 0.8);
}

.bg-secondary\/\[0\.06\]{
  background-color: hsl(var(--secondary) / 0.06);
}

.bg-sidebar{
  background-color: hsl(var(--sidebar-background));
}

.bg-sidebar-border{
  background-color: hsl(var(--sidebar-border));
}

.bg-success{
  background-color: hsl(var(--success));
}

.bg-success\/10{
  background-color: hsl(var(--success) / 0.1);
}

.bg-success\/15{
  background-color: hsl(var(--success) / 0.15);
}

.bg-success\/20{
  background-color: hsl(var(--success) / 0.2);
}

.bg-success\/5{
  background-color: hsl(var(--success) / 0.05);
}

.bg-success\/50{
  background-color: hsl(var(--success) / 0.5);
}

.bg-success\/60{
  background-color: hsl(var(--success) / 0.6);
}

.bg-success\/\[0\.045\]{
  background-color: hsl(var(--success) / 0.045);
}

.bg-success\/\[0\.04\]{
  background-color: hsl(var(--success) / 0.04);
}

.bg-success\/\[0\.05\]{
  background-color: hsl(var(--success) / 0.05);
}

.bg-success\/\[0\.06\]{
  background-color: hsl(var(--success) / 0.06);
}

.bg-success\/\[0\.07\]{
  background-color: hsl(var(--success) / 0.07);
}

.bg-success\/\[0\.08\]{
  background-color: hsl(var(--success) / 0.08);
}

.bg-success\/\[0\.14\]{
  background-color: hsl(var(--success) / 0.14);
}

.bg-surface\/80{
  background-color: hsl(var(--surface) / 0.8);
}

.bg-surface\/95{
  background-color: hsl(var(--surface) / 0.95);
}

.bg-transparent{
  background-color: transparent;
}

.bg-warning{
  background-color: hsl(var(--warning));
}

.bg-warning-foreground\/15{
  background-color: hsl(var(--warning-foreground) / 0.15);
}

.bg-warning\/10{
  background-color: hsl(var(--warning) / 0.1);
}

.bg-warning\/15{
  background-color: hsl(var(--warning) / 0.15);
}

.bg-warning\/20{
  background-color: hsl(var(--warning) / 0.2);
}

.bg-warning\/25{
  background-color: hsl(var(--warning) / 0.25);
}

.bg-warning\/5{
  background-color: hsl(var(--warning) / 0.05);
}

.bg-warning\/60{
  background-color: hsl(var(--warning) / 0.6);
}

.bg-warning\/70{
  background-color: hsl(var(--warning) / 0.7);
}

.bg-warning\/90{
  background-color: hsl(var(--warning) / 0.9);
}

.bg-warning\/\[0\.06\]{
  background-color: hsl(var(--warning) / 0.06);
}

.bg-warning\/\[0\.07\]{
  background-color: hsl(var(--warning) / 0.07);
}

.bg-warning\/\[0\.08\]{
  background-color: hsl(var(--warning) / 0.08);
}

.bg-warning\/\[0\.10\]{
  background-color: hsl(var(--warning) / 0.10);
}

.bg-warning\/\[0\.1\]{
  background-color: hsl(var(--warning) / 0.1);
}

.bg-white{
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}

.bg-white\/20{
  background-color: rgb(255 255 255 / 0.2);
}

.bg-white\/30{
  background-color: rgb(255 255 255 / 0.3);
}

.bg-white\/50{
  background-color: rgb(255 255 255 / 0.5);
}

.bg-white\/\[0\.025\]{
  background-color: rgb(255 255 255 / 0.025);
}

.bg-white\/\[0\.03\]{
  background-color: rgb(255 255 255 / 0.03);
}

.bg-white\/\[0\.04\]{
  background-color: rgb(255 255 255 / 0.04);
}

.bg-white\/\[0\.06\]{
  background-color: rgb(255 255 255 / 0.06);
}

.bg-white\/\[0\.08\]{
  background-color: rgb(255 255 255 / 0.08);
}

.bg-white\/\[0\.10\]{
  background-color: rgb(255 255 255 / 0.10);
}

.bg-white\/\[0\.86\]{
  background-color: rgb(255 255 255 / 0.86);
}

.bg-yellow-400\/10{
  background-color: rgb(250 204 21 / 0.1);
}

.bg-yellow-500{
  --tw-bg-opacity: 1;
  background-color: rgb(234 179 8 / var(--tw-bg-opacity, 1));
}

.bg-zinc-600{
  --tw-bg-opacity: 1;
  background-color: rgb(82 82 91 / var(--tw-bg-opacity, 1));
}

.bg-zinc-800{
  --tw-bg-opacity: 1;
  background-color: rgb(39 39 42 / var(--tw-bg-opacity, 1));
}

.bg-\[linear-gradient\(135deg\2c hsl\(var\(--primary\)\/0\.10\)_0\%\2c hsl\(var\(--primary\)\/0\.03\)_60\%\2c transparent_100\%\)\]{
  background-image: linear-gradient(135deg,hsl(var(--primary)/0.10) 0%,hsl(var(--primary)/0.03) 60%,transparent 100%);
}

.bg-gradient-to-b{
  background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
}

.bg-gradient-to-br{
  background-image: linear-gradient(to bottom right, var(--tw-gradient-stops));
}

.bg-gradient-to-l{
  background-image: linear-gradient(to left, var(--tw-gradient-stops));
}

.bg-gradient-to-r{
  background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

.bg-gradient-to-t{
  background-image: linear-gradient(to top, var(--tw-gradient-stops));
}

.from-\[\#833ab4\]{
  --tw-gradient-from: #833ab4 var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(131 58 180 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-\[hsl\(28_100\%_60\%\)\]{
  --tw-gradient-from: hsl(28 100% 60%) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(28 100% 60% / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-background{
  --tw-gradient-from: hsl(var(--background)) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--background) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-background\/30{
  --tw-gradient-from: hsl(var(--background) / 0.3) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--background) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-background\/40{
  --tw-gradient-from: hsl(var(--background) / 0.4) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--background) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-black\/80{
  --tw-gradient-from: rgb(0 0 0 / 0.8) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-destructive\/10{
  --tw-gradient-from: hsl(var(--destructive) / 0.1) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--destructive) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-destructive\/15{
  --tw-gradient-from: hsl(var(--destructive) / 0.15) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--destructive) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-green-600{
  --tw-gradient-from: #16a34a var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(22 163 74 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-info{
  --tw-gradient-from: hsl(var(--info)) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--info) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-info\/10{
  --tw-gradient-from: hsl(var(--info) / 0.1) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--info) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-muted{
  --tw-gradient-from: hsl(var(--muted)) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--muted) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-orange-500{
  --tw-gradient-from: #f97316 var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(249 115 22 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-orange-500\/15{
  --tw-gradient-from: rgb(249 115 22 / 0.15) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(249 115 22 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary{
  --tw-gradient-from: hsl(var(--primary)) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary\/10{
  --tw-gradient-from: hsl(var(--primary) / 0.1) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary\/15{
  --tw-gradient-from: hsl(var(--primary) / 0.15) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary\/20{
  --tw-gradient-from: hsl(var(--primary) / 0.2) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary\/25{
  --tw-gradient-from: hsl(var(--primary) / 0.25) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary\/30{
  --tw-gradient-from: hsl(var(--primary) / 0.3) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary\/40{
  --tw-gradient-from: hsl(var(--primary) / 0.4) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary\/\[0\.05\]{
  --tw-gradient-from: hsl(var(--primary) / 0.05) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary\/\[0\.10\]{
  --tw-gradient-from: hsl(var(--primary) / 0.10) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-success{
  --tw-gradient-from: hsl(var(--success)) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--success) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-success\/10{
  --tw-gradient-from: hsl(var(--success) / 0.1) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--success) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-success\/15{
  --tw-gradient-from: hsl(var(--success) / 0.15) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--success) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-success\/\[0\.08\]{
  --tw-gradient-from: hsl(var(--success) / 0.08) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--success) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-transparent{
  --tw-gradient-from: transparent var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-warning\/10{
  --tw-gradient-from: hsl(var(--warning) / 0.1) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--warning) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-warning\/15{
  --tw-gradient-from: hsl(var(--warning) / 0.15) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--warning) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.via-\[\#fd1d1d\]{
  --tw-gradient-to: rgb(253 29 29 / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), #fd1d1d var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-\[hsl\(26\2c 100\%\2c 52\%\)\]{
  --tw-gradient-to: hsl(26 100% 52% / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(26,100%,52%) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-\[hsl\(45\2c 90\%\2c 50\%\)\]{
  --tw-gradient-to: hsl(45 90% 50% / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(45,90%,50%) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-background\/70{
  --tw-gradient-to: hsl(var(--background) / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--background) / 0.7) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-background\/80{
  --tw-gradient-to: hsl(var(--background) / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--background) / 0.8) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-foreground\/20{
  --tw-gradient-to: hsl(var(--foreground) / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--foreground) / 0.2) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-info\/5{
  --tw-gradient-to: hsl(var(--info) / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--info) / 0.05) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-primary{
  --tw-gradient-to: hsl(var(--primary) / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--primary)) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-primary\/10{
  --tw-gradient-to: hsl(var(--primary) / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--primary) / 0.1) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-primary\/35{
  --tw-gradient-to: hsl(var(--primary) / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--primary) / 0.35) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-primary\/5{
  --tw-gradient-to: hsl(var(--primary) / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--primary) / 0.05) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-success{
  --tw-gradient-to: hsl(var(--success) / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--success)) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.to-\[\#fcb045\]{
  --tw-gradient-to: #fcb045 var(--tw-gradient-to-position);
}

.to-\[hsl\(142\2c 60\%\2c 38\%\)\]{
  --tw-gradient-to: hsl(142,60%,38%) var(--tw-gradient-to-position);
}

.to-\[hsl\(150\2c 55\%\2c 36\%\)\]{
  --tw-gradient-to: hsl(150,55%,36%) var(--tw-gradient-to-position);
}

.to-\[hsl\(155\2c 60\%\2c 38\%\)\]{
  --tw-gradient-to: hsl(155,60%,38%) var(--tw-gradient-to-position);
}

.to-\[hsl\(18_100\%_52\%\)\]{
  --tw-gradient-to: hsl(18 100% 52%) var(--tw-gradient-to-position);
}

.to-\[hsl\(210\2c 100\%\2c 55\%\)\]{
  --tw-gradient-to: hsl(210,100%,55%) var(--tw-gradient-to-position);
}

.to-\[hsl\(22\2c 100\%\2c 54\%\)\]{
  --tw-gradient-to: hsl(22,100%,54%) var(--tw-gradient-to-position);
}

.to-\[hsl\(24\2c 100\%\2c 55\%\)\]{
  --tw-gradient-to: hsl(24,100%,55%) var(--tw-gradient-to-position);
}

.to-\[hsl\(28_100\%_46\%\)\]{
  --tw-gradient-to: hsl(28 100% 46%) var(--tw-gradient-to-position);
}

.to-amber-500\/15{
  --tw-gradient-to: rgb(245 158 11 / 0.15) var(--tw-gradient-to-position);
}

.to-background{
  --tw-gradient-to: hsl(var(--background)) var(--tw-gradient-to-position);
}

.to-background\/40{
  --tw-gradient-to: hsl(var(--background) / 0.4) var(--tw-gradient-to-position);
}

.to-card{
  --tw-gradient-to: hsl(var(--card)) var(--tw-gradient-to-position);
}

.to-destructive{
  --tw-gradient-to: hsl(var(--destructive)) var(--tw-gradient-to-position);
}

.to-destructive\/5{
  --tw-gradient-to: hsl(var(--destructive) / 0.05) var(--tw-gradient-to-position);
}

.to-destructive\/\[0\.02\]{
  --tw-gradient-to: hsl(var(--destructive) / 0.02) var(--tw-gradient-to-position);
}

.to-green-500{
  --tw-gradient-to: #22c55e var(--tw-gradient-to-position);
}

.to-info{
  --tw-gradient-to: hsl(var(--info)) var(--tw-gradient-to-position);
}

.to-orange-400{
  --tw-gradient-to: #fb923c var(--tw-gradient-to-position);
}

.to-primary{
  --tw-gradient-to: hsl(var(--primary)) var(--tw-gradient-to-position);
}

.to-primary\/10{
  --tw-gradient-to: hsl(var(--primary) / 0.1) var(--tw-gradient-to-position);
}

.to-primary\/40{
  --tw-gradient-to: hsl(var(--primary) / 0.4) var(--tw-gradient-to-position);
}

.to-primary\/5{
  --tw-gradient-to: hsl(var(--primary) / 0.05) var(--tw-gradient-to-position);
}

.to-primary\/70{
  --tw-gradient-to: hsl(var(--primary) / 0.7) var(--tw-gradient-to-position);
}

.to-primary\/\[0\.04\]{
  --tw-gradient-to: hsl(var(--primary) / 0.04) var(--tw-gradient-to-position);
}

.to-success\/5{
  --tw-gradient-to: hsl(var(--success) / 0.05) var(--tw-gradient-to-position);
}

.to-success\/\[0\.02\]{
  --tw-gradient-to: hsl(var(--success) / 0.02) var(--tw-gradient-to-position);
}

.to-transparent{
  --tw-gradient-to: transparent var(--tw-gradient-to-position);
}

.to-warning\/5{
  --tw-gradient-to: hsl(var(--warning) / 0.05) var(--tw-gradient-to-position);
}

.to-warning\/\[0\.02\]{
  --tw-gradient-to: hsl(var(--warning) / 0.02) var(--tw-gradient-to-position);
}

.fill-current{
  fill: currentColor;
}

.fill-popover{
  fill: hsl(var(--popover));
}

.fill-white{
  fill: #fff;
}

.stroke-destructive{
  stroke: hsl(var(--destructive));
}

.stroke-muted-foreground\/40{
  stroke: hsl(var(--muted-foreground) / 0.4);
}

.stroke-primary{
  stroke: hsl(var(--primary));
}

.stroke-secondary\/30{
  stroke: hsl(var(--secondary) / 0.3);
}

.stroke-success{
  stroke: hsl(var(--success));
}

.stroke-warning{
  stroke: hsl(var(--warning));
}

.object-contain{
  -o-object-fit: contain;
     object-fit: contain;
}

.object-cover{
  -o-object-fit: cover;
     object-fit: cover;
}

.p-0{
  padding: 0px;
}

.p-0\.5{
  padding: 0.125rem;
}

.p-1{
  padding: 0.25rem;
}

.p-1\.5{
  padding: 0.375rem;
}

.p-10{
  padding: 2.5rem;
}

.p-2{
  padding: 0.5rem;
}

.p-2\.5{
  padding: 0.625rem;
}

.p-3{
  padding: 0.75rem;
}

.p-3\.5{
  padding: 0.875rem;
}

.p-4{
  padding: 1rem;
}

.p-5{
  padding: 1.25rem;
}

.p-6{
  padding: 1.5rem;
}

.p-7{
  padding: 1.75rem;
}

.p-8{
  padding: 2rem;
}

.p-\[14px\]{
  padding: 14px;
}

.p-\[1px\]{
  padding: 1px;
}

.p-\[6px\]{
  padding: 6px;
}

.px-0\.5{
  padding-left: 0.125rem;
  padding-right: 0.125rem;
}

.px-1{
  padding-left: 0.25rem;
  padding-right: 0.25rem;
}

.px-1\.5{
  padding-left: 0.375rem;
  padding-right: 0.375rem;
}

.px-2{
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

.px-2\.5{
  padding-left: 0.625rem;
  padding-right: 0.625rem;
}

.px-3{
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

.px-3\.5{
  padding-left: 0.875rem;
  padding-right: 0.875rem;
}

.px-4{
  padding-left: 1rem;
  padding-right: 1rem;
}

.px-5{
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}

.px-6{
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

.px-8{
  padding-left: 2rem;
  padding-right: 2rem;
}

.px-\[18px\]{
  padding-left: 18px;
  padding-right: 18px;
}

.py-0{
  padding-top: 0px;
  padding-bottom: 0px;
}

.py-0\.5{
  padding-top: 0.125rem;
  padding-bottom: 0.125rem;
}

.py-1{
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}

.py-1\.5{
  padding-top: 0.375rem;
  padding-bottom: 0.375rem;
}

.py-10{
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

.py-12{
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.py-14{
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
}

.py-16{
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.py-2{
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.py-2\.5{
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
}

.py-20{
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.py-3{
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.py-3\.5{
  padding-top: 0.875rem;
  padding-bottom: 0.875rem;
}

.py-4{
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.py-5{
  padding-top: 1.25rem;
  padding-bottom: 1.25rem;
}

.py-6{
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}

.py-7{
  padding-top: 1.75rem;
  padding-bottom: 1.75rem;
}

.py-8{
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.py-\[18px\]{
  padding-top: 18px;
  padding-bottom: 18px;
}

.py-\[2px\]{
  padding-top: 2px;
  padding-bottom: 2px;
}

.py-\[3px\]{
  padding-top: 3px;
  padding-bottom: 3px;
}

.py-px{
  padding-top: 1px;
  padding-bottom: 1px;
}

.pb-1{
  padding-bottom: 0.25rem;
}

.pb-1\.5{
  padding-bottom: 0.375rem;
}

.pb-2{
  padding-bottom: 0.5rem;
}

.pb-2\.5{
  padding-bottom: 0.625rem;
}

.pb-20{
  padding-bottom: 5rem;
}

.pb-24{
  padding-bottom: 6rem;
}

.pb-3{
  padding-bottom: 0.75rem;
}

.pb-3\.5{
  padding-bottom: 0.875rem;
}

.pb-32{
  padding-bottom: 8rem;
}

.pb-4{
  padding-bottom: 1rem;
}

.pb-5{
  padding-bottom: 1.25rem;
}

.pb-6{
  padding-bottom: 1.5rem;
}

.pb-8{
  padding-bottom: 2rem;
}

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

.pb-\[calc\(3\.5rem\+max\(1rem\2c env\(safe-area-inset-bottom\)\)\)\]{
  padding-bottom: calc(3.5rem + max(1rem,env(safe-area-inset-bottom)));
}

.pb-\[calc\(env\(safe-area-inset-bottom\2c 0px\)\+18px\)\]{
  padding-bottom: calc(env(safe-area-inset-bottom,0px) + 18px);
}

.pb-\[env\(safe-area-inset-bottom\)\]{
  padding-bottom: env(safe-area-inset-bottom);
}

.pb-\[max\(0\.5rem\2c env\(safe-area-inset-bottom\)\)\]{
  padding-bottom: max(0.5rem,env(safe-area-inset-bottom));
}

.pb-\[max\(1\.25rem\2c env\(safe-area-inset-bottom\)\)\]{
  padding-bottom: max(1.25rem,env(safe-area-inset-bottom));
}

.pb-\[max\(1\.5rem\2c env\(safe-area-inset-bottom\)\)\]{
  padding-bottom: max(1.5rem,env(safe-area-inset-bottom));
}

.pb-\[max\(24px\2c env\(safe-area-inset-bottom\)\)\]{
  padding-bottom: max(24px,env(safe-area-inset-bottom));
}

.pb-\[max\(env\(safe-area-inset-bottom\)\2c 0\.5rem\)\]{
  padding-bottom: max(env(safe-area-inset-bottom),0.5rem);
}

.pb-\[max\(env\(safe-area-inset-bottom\)\2c 0\.75rem\)\]{
  padding-bottom: max(env(safe-area-inset-bottom),0.75rem);
}

.pb-\[max\(env\(safe-area-inset-bottom\)\2c 16px\)\]{
  padding-bottom: max(env(safe-area-inset-bottom),16px);
}

.pb-\[max\(env\(safe-area-inset-bottom\)\2c 1rem\)\]{
  padding-bottom: max(env(safe-area-inset-bottom),1rem);
}

.pl-1{
  padding-left: 0.25rem;
}

.pl-1\.5{
  padding-left: 0.375rem;
}

.pl-10{
  padding-left: 2.5rem;
}

.pl-2{
  padding-left: 0.5rem;
}

.pl-2\.5{
  padding-left: 0.625rem;
}

.pl-3{
  padding-left: 0.75rem;
}

.pl-3\.5{
  padding-left: 0.875rem;
}

.pl-4{
  padding-left: 1rem;
}

.pl-5{
  padding-left: 1.25rem;
}

.pl-6{
  padding-left: 1.5rem;
}

.pl-7{
  padding-left: 1.75rem;
}

.pl-8{
  padding-left: 2rem;
}

.pl-9{
  padding-left: 2.25rem;
}

.pr-1{
  padding-right: 0.25rem;
}

.pr-1\.5{
  padding-right: 0.375rem;
}

.pr-10{
  padding-right: 2.5rem;
}

.pr-12{
  padding-right: 3rem;
}

.pr-2{
  padding-right: 0.5rem;
}

.pr-2\.5{
  padding-right: 0.625rem;
}

.pr-3{
  padding-right: 0.75rem;
}

.pr-4{
  padding-right: 1rem;
}

.pr-5{
  padding-right: 1.25rem;
}

.pr-6{
  padding-right: 1.5rem;
}

.pr-7{
  padding-right: 1.75rem;
}

.pr-8{
  padding-right: 2rem;
}

.pr-9{
  padding-right: 2.25rem;
}

.pr-\[22px\]{
  padding-right: 22px;
}

.pt-0{
  padding-top: 0px;
}

.pt-0\.5{
  padding-top: 0.125rem;
}

.pt-1{
  padding-top: 0.25rem;
}

.pt-1\.5{
  padding-top: 0.375rem;
}

.pt-10{
  padding-top: 2.5rem;
}

.pt-12{
  padding-top: 3rem;
}

.pt-2{
  padding-top: 0.5rem;
}

.pt-2\.5{
  padding-top: 0.625rem;
}

.pt-3{
  padding-top: 0.75rem;
}

.pt-3\.5{
  padding-top: 0.875rem;
}

.pt-4{
  padding-top: 1rem;
}

.pt-5{
  padding-top: 1.25rem;
}

.pt-6{
  padding-top: 1.5rem;
}

.pt-\[6px\]{
  padding-top: 6px;
}

.pt-\[max\(0\.625rem\2c env\(safe-area-inset-top\)\)\]{
  padding-top: max(0.625rem,env(safe-area-inset-top));
}

.pt-\[max\(0\.75rem\2c env\(safe-area-inset-top\)\)\]{
  padding-top: max(0.75rem,env(safe-area-inset-top));
}

.pt-\[max\(1rem\2c env\(safe-area-inset-top\)\)\]{
  padding-top: max(1rem,env(safe-area-inset-top));
}

.text-left{
  text-align: left;
}

.text-center{
  text-align: center;
}

.text-right{
  text-align: right;
}

.text-justify{
  text-align: justify;
}

.align-top{
  vertical-align: top;
}

.align-middle{
  vertical-align: middle;
}

.align-text-bottom{
  vertical-align: text-bottom;
}

.font-\[\'Bebas_Neue\'\]{
  font-family: 'Bebas Neue';
}

.font-\[\'DM_Sans\'\]{
  font-family: 'DM Sans';
}

.font-body{
  font-family: "DM Sans", system-ui, -apple-system, sans-serif;
}

.font-display{
  font-family: "Space Grotesk", system-ui, sans-serif;
}

.font-heading{
  font-family: "Bebas Neue", sans-serif;
}

.font-mono{
  font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
}

.font-sans{
  font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}

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

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

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

.text-5xl{
  font-size: 3rem;
  line-height: 1;
}

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

.text-\[0\.53rem\]{
  font-size: 0.53rem;
}

.text-\[0\.54rem\]{
  font-size: 0.54rem;
}

.text-\[0\.55rem\]{
  font-size: 0.55rem;
}

.text-\[0\.56rem\]{
  font-size: 0.56rem;
}

.text-\[0\.57rem\]{
  font-size: 0.57rem;
}

.text-\[0\.58rem\]{
  font-size: 0.58rem;
}

.text-\[0\.5rem\]{
  font-size: 0.5rem;
}

.text-\[0\.62rem\]{
  font-size: 0.62rem;
}

.text-\[0\.63rem\]{
  font-size: 0.63rem;
}

.text-\[0\.64rem\]{
  font-size: 0.64rem;
}

.text-\[0\.65rem\]{
  font-size: 0.65rem;
}

.text-\[0\.66rem\]{
  font-size: 0.66rem;
}

.text-\[0\.68rem\]{
  font-size: 0.68rem;
}

.text-\[0\.6rem\]{
  font-size: 0.6rem;
}

.text-\[0\.74rem\]{
  font-size: 0.74rem;
}

.text-\[0\.7rem\]{
  font-size: 0.7rem;
}

.text-\[0\.8rem\]{
  font-size: 0.8rem;
}

.text-\[0\.92rem\]{
  font-size: 0.92rem;
}

.text-\[1\.1rem\]{
  font-size: 1.1rem;
}

.text-\[1\.2rem\]{
  font-size: 1.2rem;
}

.text-\[1\.35rem\]{
  font-size: 1.35rem;
}

.text-\[1\.3rem\]{
  font-size: 1.3rem;
}

.text-\[1\.4rem\]{
  font-size: 1.4rem;
}

.text-\[1\.55rem\]{
  font-size: 1.55rem;
}

.text-\[1\.5rem\]{
  font-size: 1.5rem;
}

.text-\[1\.6rem\]{
  font-size: 1.6rem;
}

.text-\[1\.7rem\]{
  font-size: 1.7rem;
}

.text-\[10\.5px\]{
  font-size: 10.5px;
}

.text-\[10px\]{
  font-size: 10px;
}

.text-\[11\.5px\]{
  font-size: 11.5px;
}

.text-\[11px\]{
  font-size: 11px;
}

.text-\[12\.5px\]{
  font-size: 12.5px;
}

.text-\[12px\]{
  font-size: 12px;
}

.text-\[13px\]{
  font-size: 13px;
}

.text-\[14px\]{
  font-size: 14px;
}

.text-\[15px\]{
  font-size: 15px;
}

.text-\[16px\]{
  font-size: 16px;
}

.text-\[17px\]{
  font-size: 17px;
}

.text-\[18px\]{
  font-size: 18px;
}

.text-\[19px\]{
  font-size: 19px;
}

.text-\[1rem\]{
  font-size: 1rem;
}

.text-\[2\.2rem\]{
  font-size: 2.2rem;
}

.text-\[2\.4rem\]{
  font-size: 2.4rem;
}

.text-\[20px\]{
  font-size: 20px;
}

.text-\[22px\]{
  font-size: 22px;
}

.text-\[24px\]{
  font-size: 24px;
}

.text-\[26px\]{
  font-size: 26px;
}

.text-\[28px\]{
  font-size: 28px;
}

.text-\[2rem\]{
  font-size: 2rem;
}

.text-\[30px\]{
  font-size: 30px;
}

.text-\[32px\]{
  font-size: 32px;
}

.text-\[34px\]{
  font-size: 34px;
}

.text-\[36px\]{
  font-size: 36px;
}

.text-\[3rem\]{
  font-size: 3rem;
}

.text-\[40px\]{
  font-size: 40px;
}

.text-\[44px\]{
  font-size: 44px;
}

.text-\[48px\]{
  font-size: 48px;
}

.text-\[4rem\]{
  font-size: 4rem;
}

.text-\[52px\]{
  font-size: 52px;
}

.text-\[64px\]{
  font-size: 64px;
}

.text-\[7\.5px\]{
  font-size: 7.5px;
}

.text-\[72px\]{
  font-size: 72px;
}

.text-\[7px\]{
  font-size: 7px;
}

.text-\[8\.5px\]{
  font-size: 8.5px;
}

.text-\[80px\]{
  font-size: 80px;
}

.text-\[8px\]{
  font-size: 8px;
}

.text-\[9\.5px\]{
  font-size: 9.5px;
}

.text-\[9px\]{
  font-size: 9px;
}

.text-\[clamp\(10px\2c 2\.7vw\2c 10\.5px\)\]{
  font-size: clamp(10px,2.7vw,10.5px);
}

.text-\[clamp\(10px\2c 2\.8vw\2c 11px\)\]{
  font-size: clamp(10px,2.8vw,11px);
}

.text-\[clamp\(11px\2c 3\.2vw\2c 12\.5px\)\]{
  font-size: clamp(11px,3.2vw,12.5px);
}

.text-\[clamp\(11px\2c 3\.2vw\2c 12px\)\]{
  font-size: clamp(11px,3.2vw,12px);
}

.text-\[clamp\(14px\2c 3\.8vw\2c 15px\)\]{
  font-size: clamp(14px,3.8vw,15px);
}

.text-\[clamp\(22px\2c 6\.4vw\2c 28px\)\]{
  font-size: clamp(22px,6.4vw,28px);
}

.text-\[clamp\(8px\2c 2\.3vw\2c 9px\)\]{
  font-size: clamp(8px,2.3vw,9px);
}

.text-\[clamp\(9px\2c 2\.4vw\2c 9\.5px\)\]{
  font-size: clamp(9px,2.4vw,9.5px);
}

.text-\[clamp\(9px\2c 2\.5vw\2c 10px\)\]{
  font-size: clamp(9px,2.5vw,10px);
}

.text-base{
  font-size: 1rem;
  line-height: 1.5rem;
}

.text-lg{
  font-size: 1.125rem;
  line-height: 1.75rem;
}

.text-sm{
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.text-token-title{
  font-size: var(--type-title-size);
  line-height: var(--type-title-leading);
  letter-spacing: var(--type-title-tracking);
  font-weight: var(--type-title-weight);
}

.text-xl{
  font-size: 1.25rem;
  line-height: 1.75rem;
}

.text-xs{
  font-size: 0.75rem;
  line-height: 1rem;
}

.font-black{
  font-weight: 900;
}

.font-bold{
  font-weight: 700;
}

.font-extrabold{
  font-weight: 800;
}

.font-medium{
  font-weight: 500;
}

.font-normal{
  font-weight: 400;
}

.font-semibold{
  font-weight: 600;
}

.uppercase{
  text-transform: uppercase;
}

.lowercase{
  text-transform: lowercase;
}

.capitalize{
  text-transform: capitalize;
}

.normal-case{
  text-transform: none;
}

.italic{
  font-style: italic;
}

.not-italic{
  font-style: normal;
}

.ordinal{
  --tw-ordinal: ordinal;
  font-variant-numeric: var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction);
}

.slashed-zero{
  --tw-slashed-zero: slashed-zero;
  font-variant-numeric: var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction);
}

.tabular-nums{
  --tw-numeric-spacing: tabular-nums;
  font-variant-numeric: var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction);
}

.leading-5{
  line-height: 1.25rem;
}

.leading-\[1\.05\]{
  line-height: 1.05;
}

.leading-\[1\.08\]{
  line-height: 1.08;
}

.leading-\[1\.25\]{
  line-height: 1.25;
}

.leading-\[1\.32\]{
  line-height: 1.32;
}

.leading-\[1\.3\]{
  line-height: 1.3;
}

.leading-none{
  line-height: 1;
}

.leading-relaxed{
  line-height: 1.625;
}

.leading-snug{
  line-height: 1.375;
}

.leading-tight{
  line-height: 1.25;
}

.tracking-\[-0\.015em\]{
  letter-spacing: -0.015em;
}

.tracking-\[-0\.01em\]{
  letter-spacing: -0.01em;
}

.tracking-\[-0\.025em\]{
  letter-spacing: -0.025em;
}

.tracking-\[-0\.02em\]{
  letter-spacing: -0.02em;
}

.tracking-\[0\.02em\]{
  letter-spacing: 0.02em;
}

.tracking-\[0\.04em\]{
  letter-spacing: 0.04em;
}

.tracking-\[0\.06em\]{
  letter-spacing: 0.06em;
}

.tracking-\[0\.08em\]{
  letter-spacing: 0.08em;
}

.tracking-\[0\.10em\]{
  letter-spacing: 0.10em;
}

.tracking-\[0\.12em\]{
  letter-spacing: 0.12em;
}

.tracking-\[0\.14em\]{
  letter-spacing: 0.14em;
}

.tracking-\[0\.15em\]{
  letter-spacing: 0.15em;
}

.tracking-\[0\.16em\]{
  letter-spacing: 0.16em;
}

.tracking-\[0\.18em\]{
  letter-spacing: 0.18em;
}

.tracking-\[0\.1em\]{
  letter-spacing: 0.1em;
}

.tracking-\[0\.22em\]{
  letter-spacing: 0.22em;
}

.tracking-\[0\.2em\]{
  letter-spacing: 0.2em;
}

.tracking-\[0\.3px\]{
  letter-spacing: 0.3px;
}

.tracking-\[0\.5px\]{
  letter-spacing: 0.5px;
}

.tracking-\[1\.2px\]{
  letter-spacing: 1.2px;
}

.tracking-\[1\.4px\]{
  letter-spacing: 1.4px;
}

.tracking-\[1\.5px\]{
  letter-spacing: 1.5px;
}

.tracking-\[1px\]{
  letter-spacing: 1px;
}

.tracking-\[2\.5px\]{
  letter-spacing: 2.5px;
}

.tracking-\[2px\]{
  letter-spacing: 2px;
}

.tracking-\[3px\]{
  letter-spacing: 3px;
}

.tracking-\[4px\]{
  letter-spacing: 4px;
}

.tracking-\[6px\]{
  letter-spacing: 6px;
}

.tracking-normal{
  letter-spacing: 0em;
}

.tracking-tight{
  letter-spacing: -0.025em;
}

.tracking-wide{
  letter-spacing: 0.025em;
}

.tracking-wider{
  letter-spacing: 0.05em;
}

.tracking-widest{
  letter-spacing: 0.1em;
}

.text-\[\#25D366\]{
  --tw-text-opacity: 1;
  color: rgb(37 211 102 / var(--tw-text-opacity, 1));
}

.text-\[Xpx\]{
  color: Xpx;
}

.text-\[hsl\(45\2c 90\%\2c 50\%\)\]{
  --tw-text-opacity: 1;
  color: hsl(45 90% 50% / var(--tw-text-opacity, 1));
}

.text-\[hsl\(var\(--warning\)\)\]{
  color: hsl(var(--warning));
}

.text-accent-foreground{
  color: hsl(var(--accent-foreground));
}

.text-amber-200{
  --tw-text-opacity: 1;
  color: rgb(253 230 138 / var(--tw-text-opacity, 1));
}

.text-amber-200\/60{
  color: rgb(253 230 138 / 0.6);
}

.text-amber-200\/70{
  color: rgb(253 230 138 / 0.7);
}

.text-amber-300{
  --tw-text-opacity: 1;
  color: rgb(252 211 77 / var(--tw-text-opacity, 1));
}

.text-amber-400{
  --tw-text-opacity: 1;
  color: rgb(251 191 36 / var(--tw-text-opacity, 1));
}

.text-amber-500{
  --tw-text-opacity: 1;
  color: rgb(245 158 11 / var(--tw-text-opacity, 1));
}

.text-amber-600{
  --tw-text-opacity: 1;
  color: rgb(217 119 6 / var(--tw-text-opacity, 1));
}

.text-amber-700{
  --tw-text-opacity: 1;
  color: rgb(180 83 9 / var(--tw-text-opacity, 1));
}

.text-amber-900{
  --tw-text-opacity: 1;
  color: rgb(120 53 15 / var(--tw-text-opacity, 1));
}

.text-amber-950{
  --tw-text-opacity: 1;
  color: rgb(69 26 3 / var(--tw-text-opacity, 1));
}

.text-background{
  color: hsl(var(--background));
}

.text-background\/70{
  color: hsl(var(--background) / 0.7);
}

.text-blue-400{
  --tw-text-opacity: 1;
  color: rgb(96 165 250 / var(--tw-text-opacity, 1));
}

.text-blue-700{
  --tw-text-opacity: 1;
  color: rgb(29 78 216 / var(--tw-text-opacity, 1));
}

.text-card-foreground{
  color: hsl(var(--card-foreground));
}

.text-current{
  color: currentColor;
}

.text-cyan-400{
  --tw-text-opacity: 1;
  color: rgb(34 211 238 / var(--tw-text-opacity, 1));
}

.text-destructive{
  color: hsl(var(--destructive));
}

.text-destructive-foreground{
  color: hsl(var(--destructive-foreground));
}

.text-destructive-foreground\/90{
  color: hsl(var(--destructive-foreground) / 0.9);
}

.text-destructive\/50{
  color: hsl(var(--destructive) / 0.5);
}

.text-destructive\/60{
  color: hsl(var(--destructive) / 0.6);
}

.text-destructive\/70{
  color: hsl(var(--destructive) / 0.7);
}

.text-destructive\/80{
  color: hsl(var(--destructive) / 0.8);
}

.text-destructive\/90{
  color: hsl(var(--destructive) / 0.9);
}

.text-emerald-400{
  --tw-text-opacity: 1;
  color: rgb(52 211 153 / var(--tw-text-opacity, 1));
}

.text-emerald-600{
  --tw-text-opacity: 1;
  color: rgb(5 150 105 / var(--tw-text-opacity, 1));
}

.text-emerald-700{
  --tw-text-opacity: 1;
  color: rgb(4 120 87 / var(--tw-text-opacity, 1));
}

.text-foreground{
  color: hsl(var(--foreground));
}

.text-foreground\/35{
  color: hsl(var(--foreground) / 0.35);
}

.text-foreground\/40{
  color: hsl(var(--foreground) / 0.4);
}

.text-foreground\/45{
  color: hsl(var(--foreground) / 0.45);
}

.text-foreground\/50{
  color: hsl(var(--foreground) / 0.5);
}

.text-foreground\/55{
  color: hsl(var(--foreground) / 0.55);
}

.text-foreground\/60{
  color: hsl(var(--foreground) / 0.6);
}

.text-foreground\/65{
  color: hsl(var(--foreground) / 0.65);
}

.text-foreground\/70{
  color: hsl(var(--foreground) / 0.7);
}

.text-foreground\/75{
  color: hsl(var(--foreground) / 0.75);
}

.text-foreground\/80{
  color: hsl(var(--foreground) / 0.8);
}

.text-foreground\/85{
  color: hsl(var(--foreground) / 0.85);
}

.text-foreground\/90{
  color: hsl(var(--foreground) / 0.9);
}

.text-foreground\/95{
  color: hsl(var(--foreground) / 0.95);
}

.text-gray-300{
  --tw-text-opacity: 1;
  color: rgb(209 213 219 / var(--tw-text-opacity, 1));
}

.text-gray-700{
  --tw-text-opacity: 1;
  color: rgb(55 65 81 / var(--tw-text-opacity, 1));
}

.text-green-400{
  --tw-text-opacity: 1;
  color: rgb(74 222 128 / var(--tw-text-opacity, 1));
}

.text-green-500{
  --tw-text-opacity: 1;
  color: rgb(34 197 94 / var(--tw-text-opacity, 1));
}

.text-green-600{
  --tw-text-opacity: 1;
  color: rgb(22 163 74 / var(--tw-text-opacity, 1));
}

.text-indigo-400{
  --tw-text-opacity: 1;
  color: rgb(129 140 248 / var(--tw-text-opacity, 1));
}

.text-info{
  color: hsl(var(--info));
}

.text-info-foreground{
  color: hsl(var(--info-foreground));
}

.text-info-foreground\/90{
  color: hsl(var(--info-foreground) / 0.9);
}

.text-info\/60{
  color: hsl(var(--info) / 0.6);
}

.text-info\/70{
  color: hsl(var(--info) / 0.7);
}

.text-info\/75{
  color: hsl(var(--info) / 0.75);
}

.text-info\/80{
  color: hsl(var(--info) / 0.8);
}

.text-info\/85{
  color: hsl(var(--info) / 0.85);
}

.text-info\/90{
  color: hsl(var(--info) / 0.9);
}

.text-lime-400{
  --tw-text-opacity: 1;
  color: rgb(163 230 53 / var(--tw-text-opacity, 1));
}

.text-muted-foreground{
  color: hsl(var(--muted-foreground));
}

.text-muted-foreground\/20{
  color: hsl(var(--muted-foreground) / 0.2);
}

.text-muted-foreground\/25{
  color: hsl(var(--muted-foreground) / 0.25);
}

.text-muted-foreground\/30{
  color: hsl(var(--muted-foreground) / 0.3);
}

.text-muted-foreground\/35{
  color: hsl(var(--muted-foreground) / 0.35);
}

.text-muted-foreground\/40{
  color: hsl(var(--muted-foreground) / 0.4);
}

.text-muted-foreground\/45{
  color: hsl(var(--muted-foreground) / 0.45);
}

.text-muted-foreground\/50{
  color: hsl(var(--muted-foreground) / 0.5);
}

.text-muted-foreground\/55{
  color: hsl(var(--muted-foreground) / 0.55);
}

.text-muted-foreground\/60{
  color: hsl(var(--muted-foreground) / 0.6);
}

.text-muted-foreground\/65{
  color: hsl(var(--muted-foreground) / 0.65);
}

.text-muted-foreground\/70{
  color: hsl(var(--muted-foreground) / 0.7);
}

.text-muted-foreground\/75{
  color: hsl(var(--muted-foreground) / 0.75);
}

.text-muted-foreground\/80{
  color: hsl(var(--muted-foreground) / 0.8);
}

.text-muted-foreground\/85{
  color: hsl(var(--muted-foreground) / 0.85);
}

.text-muted-foreground\/90{
  color: hsl(var(--muted-foreground) / 0.9);
}

.text-neutral-500{
  --tw-text-opacity: 1;
  color: rgb(115 115 115 / var(--tw-text-opacity, 1));
}

.text-neutral-600{
  --tw-text-opacity: 1;
  color: rgb(82 82 82 / var(--tw-text-opacity, 1));
}

.text-neutral-700{
  --tw-text-opacity: 1;
  color: rgb(64 64 64 / var(--tw-text-opacity, 1));
}

.text-neutral-800{
  --tw-text-opacity: 1;
  color: rgb(38 38 38 / var(--tw-text-opacity, 1));
}

.text-neutral-900{
  --tw-text-opacity: 1;
  color: rgb(23 23 23 / var(--tw-text-opacity, 1));
}

.text-neutral-950{
  --tw-text-opacity: 1;
  color: rgb(10 10 10 / var(--tw-text-opacity, 1));
}

.text-orange-100{
  --tw-text-opacity: 1;
  color: rgb(255 237 213 / var(--tw-text-opacity, 1));
}

.text-orange-200{
  --tw-text-opacity: 1;
  color: rgb(254 215 170 / var(--tw-text-opacity, 1));
}

.text-orange-400{
  --tw-text-opacity: 1;
  color: rgb(251 146 60 / var(--tw-text-opacity, 1));
}

.text-orange-400\/80{
  color: rgb(251 146 60 / 0.8);
}

.text-orange-500{
  --tw-text-opacity: 1;
  color: rgb(249 115 22 / var(--tw-text-opacity, 1));
}

.text-orange-600{
  --tw-text-opacity: 1;
  color: rgb(234 88 12 / var(--tw-text-opacity, 1));
}

.text-orange-700{
  --tw-text-opacity: 1;
  color: rgb(194 65 12 / var(--tw-text-opacity, 1));
}

.text-pink-300{
  --tw-text-opacity: 1;
  color: rgb(249 168 212 / var(--tw-text-opacity, 1));
}

.text-pink-400{
  --tw-text-opacity: 1;
  color: rgb(244 114 182 / var(--tw-text-opacity, 1));
}

.text-popover-foreground{
  color: hsl(var(--popover-foreground));
}

.text-primary{
  color: hsl(var(--primary));
}

.text-primary-foreground{
  color: hsl(var(--primary-foreground));
}

.text-primary-foreground\/75{
  color: hsl(var(--primary-foreground) / 0.75);
}

.text-primary-foreground\/80{
  color: hsl(var(--primary-foreground) / 0.8);
}

.text-primary\/15{
  color: hsl(var(--primary) / 0.15);
}

.text-primary\/40{
  color: hsl(var(--primary) / 0.4);
}

.text-primary\/50{
  color: hsl(var(--primary) / 0.5);
}

.text-primary\/60{
  color: hsl(var(--primary) / 0.6);
}

.text-primary\/65{
  color: hsl(var(--primary) / 0.65);
}

.text-primary\/70{
  color: hsl(var(--primary) / 0.7);
}

.text-primary\/75{
  color: hsl(var(--primary) / 0.75);
}

.text-primary\/80{
  color: hsl(var(--primary) / 0.8);
}

.text-primary\/90{
  color: hsl(var(--primary) / 0.9);
}

.text-purple{
  color: hsl(var(--purple));
}

.text-purple-400{
  --tw-text-opacity: 1;
  color: rgb(192 132 252 / var(--tw-text-opacity, 1));
}

.text-purple\/50{
  color: hsl(var(--purple) / 0.5);
}

.text-purple\/60{
  color: hsl(var(--purple) / 0.6);
}

.text-purple\/70{
  color: hsl(var(--purple) / 0.7);
}

.text-purple\/80{
  color: hsl(var(--purple) / 0.8);
}

.text-red-400{
  --tw-text-opacity: 1;
  color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}

.text-red-400\/60{
  color: rgb(248 113 113 / 0.6);
}

.text-red-400\/80{
  color: rgb(248 113 113 / 0.8);
}

.text-red-500{
  --tw-text-opacity: 1;
  color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}

.text-red-600{
  --tw-text-opacity: 1;
  color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}

.text-red-700{
  --tw-text-opacity: 1;
  color: rgb(185 28 28 / var(--tw-text-opacity, 1));
}

.text-rose-400{
  --tw-text-opacity: 1;
  color: rgb(251 113 133 / var(--tw-text-opacity, 1));
}

.text-secondary-foreground{
  color: hsl(var(--secondary-foreground));
}

.text-sidebar-foreground{
  color: hsl(var(--sidebar-foreground));
}

.text-sidebar-foreground\/70{
  color: hsl(var(--sidebar-foreground) / 0.7);
}

.text-sky-400{
  --tw-text-opacity: 1;
  color: rgb(56 189 248 / var(--tw-text-opacity, 1));
}

.text-slate-400{
  --tw-text-opacity: 1;
  color: rgb(148 163 184 / var(--tw-text-opacity, 1));
}

.text-success{
  color: hsl(var(--success));
}

.text-success-foreground{
  color: hsl(var(--success-foreground));
}

.text-success-foreground\/90{
  color: hsl(var(--success-foreground) / 0.9);
}

.text-success\/40{
  color: hsl(var(--success) / 0.4);
}

.text-success\/60{
  color: hsl(var(--success) / 0.6);
}

.text-success\/70{
  color: hsl(var(--success) / 0.7);
}

.text-success\/75{
  color: hsl(var(--success) / 0.75);
}

.text-success\/80{
  color: hsl(var(--success) / 0.8);
}

.text-success\/85{
  color: hsl(var(--success) / 0.85);
}

.text-success\/90{
  color: hsl(var(--success) / 0.9);
}

.text-transparent{
  color: transparent;
}

.text-violet-400{
  --tw-text-opacity: 1;
  color: rgb(167 139 250 / var(--tw-text-opacity, 1));
}

.text-warning{
  color: hsl(var(--warning));
}

.text-warning-foreground{
  color: hsl(var(--warning-foreground));
}

.text-warning\/50{
  color: hsl(var(--warning) / 0.5);
}

.text-warning\/60{
  color: hsl(var(--warning) / 0.6);
}

.text-warning\/70{
  color: hsl(var(--warning) / 0.7);
}

.text-warning\/80{
  color: hsl(var(--warning) / 0.8);
}

.text-warning\/85{
  color: hsl(var(--warning) / 0.85);
}

.text-warning\/90{
  color: hsl(var(--warning) / 0.9);
}

.text-white{
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.text-white\/20{
  color: rgb(255 255 255 / 0.2);
}

.text-white\/40{
  color: rgb(255 255 255 / 0.4);
}

.text-white\/80{
  color: rgb(255 255 255 / 0.8);
}

.text-white\/90{
  color: rgb(255 255 255 / 0.9);
}

.text-yellow-400{
  --tw-text-opacity: 1;
  color: rgb(250 204 21 / var(--tw-text-opacity, 1));
}

.text-zinc-500{
  --tw-text-opacity: 1;
  color: rgb(113 113 122 / var(--tw-text-opacity, 1));
}

.underline{
  text-decoration-line: underline;
}

.line-through{
  text-decoration-line: line-through;
}

.no-underline{
  text-decoration-line: none;
}

.decoration-destructive\/40{
  text-decoration-color: hsl(var(--destructive) / 0.4);
}

.decoration-\[1px\]{
  text-decoration-thickness: 1px;
}

.underline-offset-2{
  text-underline-offset: 2px;
}

.underline-offset-4{
  text-underline-offset: 4px;
}

.accent-\[\#25D366\]{
  accent-color: #25D366;
}

.accent-destructive{
  accent-color: hsl(var(--destructive));
}

.accent-primary{
  accent-color: hsl(var(--primary));
}

.opacity-0{
  opacity: 0;
}

.opacity-100{
  opacity: 1;
}

.opacity-25{
  opacity: 0.25;
}

.opacity-30{
  opacity: 0.3;
}

.opacity-40{
  opacity: 0.4;
}

.opacity-50{
  opacity: 0.5;
}

.opacity-60{
  opacity: 0.6;
}

.opacity-70{
  opacity: 0.7;
}

.opacity-75{
  opacity: 0.75;
}

.opacity-80{
  opacity: 0.8;
}

.opacity-85{
  opacity: 0.85;
}

.opacity-90{
  opacity: 0.9;
}

.opacity-\[0\.10\]{
  opacity: 0.10;
}

.opacity-\[0\.18\]{
  opacity: 0.18;
}

.opacity-\[0\.22\]{
  opacity: 0.22;
}

.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);
}

.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);
}

.shadow-\[-22px_0_44px_-24px_rgba\(0\2c 0\2c 0\2c 0\.85\)\]{
  --tw-shadow: -22px 0 44px -24px rgba(0,0,0,0.85);
  --tw-shadow-colored: -22px 0 44px -24px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_-12px_48px_-8px_rgba\(0\2c 0\2c 0\2c 0\.65\)\]{
  --tw-shadow: 0 -12px 48px -8px rgba(0,0,0,0.65);
  --tw-shadow-colored: 0 -12px 48px -8px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_-16px_48px_-8px_rgba\(0\2c 0\2c 0\2c 0\.65\)\2c inset_0_1px_0_rgba\(255\2c 255\2c 255\2c 0\.06\)\]{
  --tw-shadow: 0 -16px 48px -8px rgba(0,0,0,0.65),inset 0 1px 0 rgba(255,255,255,0.06);
  --tw-shadow-colored: 0 -16px 48px -8px var(--tw-shadow-color), inset 0 1px 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);
}

.shadow-\[0_-24px_48px_-28px_rgba\(0\2c 0\2c 0\2c 0\.72\)\]{
  --tw-shadow: 0 -24px 48px -28px rgba(0,0,0,0.72);
  --tw-shadow-colored: 0 -24px 48px -28px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_0_1px_hsl\(var\(--primary\)\/0\.08\)\]{
  --tw-shadow: 0 0 0 1px hsl(var(--primary)/0.08);
  --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);
}

.shadow-\[0_0_0_1px_hsl\(var\(--primary\)\/0\.18\)\]{
  --tw-shadow: 0 0 0 1px hsl(var(--primary)/0.18);
  --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);
}

.shadow-\[0_0_0_1px_hsl\(var\(--primary\)\/0\.2\)\2c 0_2px_8px_hsl\(var\(--primary\)\/0\.25\)\]{
  --tw-shadow: 0 0 0 1px hsl(var(--primary)/0.2),0 2px 8px hsl(var(--primary)/0.25);
  --tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color), 0 2px 8px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_0_1px_hsl\(var\(--sidebar-border\)\)\]{
  --tw-shadow: 0 0 0 1px hsl(var(--sidebar-border));
  --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);
}

.shadow-\[0_0_0_3px_hsl\(var\(--\$\{c\}\)\/0\.18\)\]{
  --tw-shadow: 0 0 0 3px hsl(var(--${c})/0.18);
  --tw-shadow-colored: 0 0 0 3px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_0_3px_hsl\(var\(--warning\)\/0\.18\)\]{
  --tw-shadow: 0 0 0 3px hsl(var(--warning)/0.18);
  --tw-shadow-colored: 0 0 0 3px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_24px_-8px_hsl\(var\(--destructive\)\)\]{
  --tw-shadow: 0 0 24px -8px hsl(var(--destructive));
  --tw-shadow-colored: 0 0 24px -8px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_24px_-8px_hsl\(var\(--success\)\)\]{
  --tw-shadow: 0 0 24px -8px hsl(var(--success));
  --tw-shadow-colored: 0 0 24px -8px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_24px_-8px_hsl\(var\(--warning\)\)\]{
  --tw-shadow: 0 0 24px -8px hsl(var(--warning));
  --tw-shadow-colored: 0 0 24px -8px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_6px_hsl\(142_60\%_42\%\/0\.7\)\]{
  --tw-shadow: 0 0 6px hsl(142 60% 42%/0.7);
  --tw-shadow-colored: 0 0 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);
}

.shadow-\[0_0_6px_hsl\(var\(--success\)\/0\.4\)\]{
  --tw-shadow: 0 0 6px hsl(var(--success)/0.4);
  --tw-shadow-colored: 0 0 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);
}

.shadow-\[0_0_8px_hsl\(142_60\%_42\%\/0\.5\)\]{
  --tw-shadow: 0 0 8px hsl(142 60% 42%/0.5);
  --tw-shadow-colored: 0 0 8px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_8px_hsl\(var\(--success\)\)\]{
  --tw-shadow: 0 0 8px hsl(var(--success));
  --tw-shadow-colored: 0 0 8px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_12px_32px_rgba\(0\2c 0\2c 0\2c 0\.4\)\]{
  --tw-shadow: 0 12px 32px rgba(0,0,0,0.4);
  --tw-shadow-colored: 0 12px 32px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_12px_40px_-8px_hsl\(var\(--primary\)\/0\.35\)\2c 0_2px_8px_rgba\(0\2c 0\2c 0\2c 0\.3\)\2c inset_0_1px_0_rgba\(255\2c 255\2c 255\2c 0\.06\)\]{
  --tw-shadow: 0 12px 40px -8px hsl(var(--primary)/0.35),0 2px 8px rgba(0,0,0,0.3),inset 0 1px 0 rgba(255,255,255,0.06);
  --tw-shadow-colored: 0 12px 40px -8px var(--tw-shadow-color), 0 2px 8px var(--tw-shadow-color), inset 0 1px 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);
}

.shadow-\[0_12px_40px_-8px_rgba\(0\2c 0\2c 0\2c 0\.6\)\2c 0_0_0_1px_hsl\(var\(--primary\)\/0\.15\)\]{
  --tw-shadow: 0 12px 40px -8px rgba(0,0,0,0.6),0 0 0 1px hsl(var(--primary)/0.15);
  --tw-shadow-colored: 0 12px 40px -8px var(--tw-shadow-color), 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);
}

.shadow-\[0_18px_42px_-24px_rgba\(15\2c 23\2c 42\2c 0\.34\)\]{
  --tw-shadow: 0 18px 42px -24px rgba(15,23,42,0.34);
  --tw-shadow-colored: 0 18px 42px -24px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_18px_42px_-24px_rgba\(15\2c 23\2c 42\2c 0\.38\)\]{
  --tw-shadow: 0 18px 42px -24px rgba(15,23,42,0.38);
  --tw-shadow-colored: 0 18px 42px -24px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_18px_44px_-22px_rgba\(0\2c 0\2c 0\2c 0\.78\)\]{
  --tw-shadow: 0 18px 44px -22px rgba(0,0,0,0.78);
  --tw-shadow-colored: 0 18px 44px -22px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_18px_44px_-22px_rgba\(0\2c 0\2c 0\2c 0\.82\)\]{
  --tw-shadow: 0 18px 44px -22px rgba(0,0,0,0.82);
  --tw-shadow-colored: 0 18px 44px -22px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_2px_8px_rgba\(0\2c 0\2c 0\2c 0\.25\)\]{
  --tw-shadow: 0 2px 8px rgba(0,0,0,0.25);
  --tw-shadow-colored: 0 2px 8px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_4px_14px_-2px_hsl\(var\(--primary\)\/0\.45\)\]{
  --tw-shadow: 0 4px 14px -2px hsl(var(--primary)/0.45);
  --tw-shadow-colored: 0 4px 14px -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);
}

.shadow-\[0_4px_14px_-2px_hsl\(var\(--primary\)\/0\.5\)\]{
  --tw-shadow: 0 4px 14px -2px hsl(var(--primary)/0.5);
  --tw-shadow-colored: 0 4px 14px -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);
}

.shadow-\[0_6px_18px_-10px_rgba\(0\2c 0\2c 0\2c 0\.75\)\2c inset_0_1px_0_hsl\(var\(--foreground\)\/0\.08\)\]{
  --tw-shadow: 0 6px 18px -10px rgba(0,0,0,0.75),inset 0 1px 0 hsl(var(--foreground)/0.08);
  --tw-shadow-colored: 0 6px 18px -10px var(--tw-shadow-color), inset 0 1px 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);
}

.shadow-\[0_8px_24px_-18px_rgba\(0\2c 0\2c 0\2c 0\.7\)\]{
  --tw-shadow: 0 8px 24px -18px rgba(0,0,0,0.7);
  --tw-shadow-colored: 0 8px 24px -18px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_8px_24px_-4px_rgba\(0\2c 0\2c 0\2c 0\.5\)\2c 0_0_0_1px_hsl\(var\(--primary\)\/0\.5\)\]{
  --tw-shadow: 0 8px 24px -4px rgba(0,0,0,0.5),0 0 0 1px hsl(var(--primary)/0.5);
  --tw-shadow-colored: 0 8px 24px -4px var(--tw-shadow-color), 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);
}

.shadow-\[0_8px_24px_-4px_rgba\(37\2c 211\2c 102\2c 0\.5\)\]{
  --tw-shadow: 0 8px 24px -4px rgba(37,211,102,0.5);
  --tw-shadow-colored: 0 8px 24px -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);
}

.shadow-\[0_8px_24px_-6px_rgba\(0\2c 0\2c 0\2c 0\.35\)\2c inset_0_1px_0_rgba\(255\2c 255\2c 255\2c 0\.04\)\]{
  --tw-shadow: 0 8px 24px -6px rgba(0,0,0,0.35),inset 0 1px 0 rgba(255,255,255,0.04);
  --tw-shadow-colored: 0 8px 24px -6px var(--tw-shadow-color), inset 0 1px 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);
}

.shadow-\[inset_0_1px_0_rgba\(255\2c 255\2c 255\2c 0\.04\)\]{
  --tw-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
  --tw-shadow-colored: inset 0 1px 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);
}

.shadow-elev-1{
  --tw-shadow: var(--elev-1);
  --tw-shadow-colored: var(--elev-1);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-elev-2{
  --tw-shadow: var(--elev-2);
  --tw-shadow-colored: var(--elev-2);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-elev-3{
  --tw-shadow: var(--elev-3);
  --tw-shadow-colored: var(--elev-3);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-elev-primary{
  --tw-shadow: var(--elev-primary);
  --tw-shadow-colored: var(--elev-primary);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.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);
}

.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);
}

.shadow-none{
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-ring-primary-soft{
  --tw-shadow: var(--ring-primary-soft);
  --tw-shadow-colored: var(--ring-primary-soft);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.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);
}

.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);
}

.shadow-\[long_string\]{
  --tw-shadow-color: long string;
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-black\/60{
  --tw-shadow-color: rgb(0 0 0 / 0.6);
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-card{
  --tw-shadow-color: hsl(var(--card));
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-destructive\/10{
  --tw-shadow-color: hsl(var(--destructive) / 0.1);
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-info\/25{
  --tw-shadow-color: hsl(var(--info) / 0.25);
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-input{
  --tw-shadow-color: hsl(var(--input));
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-primary\/10{
  --tw-shadow-color: hsl(var(--primary) / 0.1);
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-primary\/20{
  --tw-shadow-color: hsl(var(--primary) / 0.2);
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-primary\/30{
  --tw-shadow-color: hsl(var(--primary) / 0.3);
  --tw-shadow: var(--tw-shadow-colored);
}

.shadow-primary\/40{
  --tw-shadow-color: hsl(var(--primary) / 0.4);
  --tw-shadow: var(--tw-shadow-colored);
}

.outline-none{
  outline: 2px solid transparent;
  outline-offset: 2px;
}

.outline{
  outline-style: solid;
}

.ring{
  --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(3px + 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);
}

.ring-0{
  --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);
}

.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);
}

.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);
}

.ring-\[hsl\(var\(--warning\)\/0\.3\)\]{
  --tw-ring-color: hsl(var(--warning)/0.3);
}

.ring-border\/40{
  --tw-ring-color: hsl(var(--border) / 0.4);
}

.ring-destructive\/25{
  --tw-ring-color: hsl(var(--destructive) / 0.25);
}

.ring-destructive\/30{
  --tw-ring-color: hsl(var(--destructive) / 0.3);
}

.ring-destructive\/40{
  --tw-ring-color: hsl(var(--destructive) / 0.4);
}

.ring-destructive\/60{
  --tw-ring-color: hsl(var(--destructive) / 0.6);
}

.ring-info{
  --tw-ring-color: hsl(var(--info));
}

.ring-info\/25{
  --tw-ring-color: hsl(var(--info) / 0.25);
}

.ring-info\/70{
  --tw-ring-color: hsl(var(--info) / 0.7);
}

.ring-muted-foreground\/20{
  --tw-ring-color: hsl(var(--muted-foreground) / 0.2);
}

.ring-primary{
  --tw-ring-color: hsl(var(--primary));
}

.ring-primary-foreground\/15{
  --tw-ring-color: hsl(var(--primary-foreground) / 0.15);
}

.ring-primary-foreground\/20{
  --tw-ring-color: hsl(var(--primary-foreground) / 0.2);
}

.ring-primary\/20{
  --tw-ring-color: hsl(var(--primary) / 0.2);
}

.ring-primary\/25{
  --tw-ring-color: hsl(var(--primary) / 0.25);
}

.ring-primary\/30{
  --tw-ring-color: hsl(var(--primary) / 0.3);
}

.ring-primary\/40{
  --tw-ring-color: hsl(var(--primary) / 0.4);
}

.ring-primary\/50{
  --tw-ring-color: hsl(var(--primary) / 0.5);
}

.ring-primary\/60{
  --tw-ring-color: hsl(var(--primary) / 0.6);
}

.ring-purple\/25{
  --tw-ring-color: hsl(var(--purple) / 0.25);
}

.ring-ring{
  --tw-ring-color: hsl(var(--ring));
}

.ring-sidebar-ring{
  --tw-ring-color: hsl(var(--sidebar-ring));
}

.ring-success\/25{
  --tw-ring-color: hsl(var(--success) / 0.25);
}

.ring-success\/30{
  --tw-ring-color: hsl(var(--success) / 0.3);
}

.ring-success\/35{
  --tw-ring-color: hsl(var(--success) / 0.35);
}

.ring-transparent{
  --tw-ring-color: transparent;
}

.ring-warning\/25{
  --tw-ring-color: hsl(var(--warning) / 0.25);
}

.ring-warning\/30{
  --tw-ring-color: hsl(var(--warning) / 0.3);
}

.ring-warning\/40{
  --tw-ring-color: hsl(var(--warning) / 0.4);
}

.ring-offset-0{
  --tw-ring-offset-width: 0px;
}

.ring-offset-background{
  --tw-ring-offset-color: hsl(var(--background));
}

.blur{
  --tw-blur: blur(8px);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.blur-2xl{
  --tw-blur: blur(40px);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.blur-3xl{
  --tw-blur: blur(64px);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.blur-\[100px\]{
  --tw-blur: blur(100px);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.blur-\[120px\]{
  --tw-blur: blur(120px);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.blur-\[90px\]{
  --tw-blur: blur(90px);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.blur-xl{
  --tw-blur: blur(24px);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.brightness-50{
  --tw-brightness: brightness(.5);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.brightness-75{
  --tw-brightness: brightness(.75);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.brightness-\[0\.35\]{
  --tw-brightness: brightness(0.35);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.drop-shadow{
  --tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / 0.1)) drop-shadow(0 1px 1px rgb(0 0 0 / 0.06));
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.drop-shadow-lg{
  --tw-drop-shadow: drop-shadow(0 10px 8px rgb(0 0 0 / 0.04)) drop-shadow(0 4px 3px rgb(0 0 0 / 0.1));
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.drop-shadow-sm{
  --tw-drop-shadow: drop-shadow(0 1px 1px rgb(0 0 0 / 0.05));
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.saturate-0{
  --tw-saturate: saturate(0);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.saturate-150{
  --tw-saturate: saturate(1.5);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.\!filter{
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow) !important;
}

.filter{
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.backdrop-blur{
  --tw-backdrop-blur: blur(8px);
  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-blur-2xl{
  --tw-backdrop-blur: blur(40px);
  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-blur-\[1px\]{
  --tw-backdrop-blur: blur(1px);
  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-blur-\[2px\]{
  --tw-backdrop-blur: blur(2px);
  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-blur-\[3px\]{
  --tw-backdrop-blur: blur(3px);
  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-blur-lg{
  --tw-backdrop-blur: blur(16px);
  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-blur-md{
  --tw-backdrop-blur: blur(12px);
  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-blur-sm{
  --tw-backdrop-blur: blur(4px);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.backdrop-blur-xl{
  --tw-backdrop-blur: blur(24px);
  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-saturate-150{
  --tw-backdrop-saturate: saturate(1.5);
  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{
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.transition{
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-\[bottom\]{
  transition-property: bottom;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-\[filter\]{
  transition-property: filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-\[height\]{
  transition-property: height;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-\[left\2c right\2c width\]{
  transition-property: left,right,width;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-\[margin\2c opa\]{
  transition-property: margin,opa;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-\[opacity\2c transform\]{
  transition-property: opacity,transform;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-\[width\2c height\2c padding\]{
  transition-property: width,height,padding;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-\[width\]{
  transition-property: width;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-all{
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-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;
}

.transition-opacity{
  transition-property: opacity;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-shadow{
  transition-property: box-shadow;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-transform{
  transition-property: transform;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.duration-100{
  transition-duration: 100ms;
}

.duration-1000{
  transition-duration: 1000ms;
}

.duration-150{
  transition-duration: 150ms;
}

.duration-200{
  transition-duration: 200ms;
}

.duration-300{
  transition-duration: 300ms;
}

.duration-500{
  transition-duration: 500ms;
}

.duration-700{
  transition-duration: 700ms;
}

.ease-in-out{
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.ease-linear{
  transition-timing-function: linear;
}

.ease-out{
  transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}

@keyframes enter{

  from{
    opacity: var(--tw-enter-opacity, 1);
    transform: translate3d(var(--tw-enter-translate-x, 0), var(--tw-enter-translate-y, 0), 0) scale3d(var(--tw-enter-scale, 1), var(--tw-enter-scale, 1), var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0));
  }
}

@keyframes exit{

  to{
    opacity: var(--tw-exit-opacity, 1);
    transform: translate3d(var(--tw-exit-translate-x, 0), var(--tw-exit-translate-y, 0), 0) scale3d(var(--tw-exit-scale, 1), var(--tw-exit-scale, 1), var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0));
  }
}

.animate-in{
  animation-name: enter;
  animation-duration: 150ms;
  --tw-enter-opacity: initial;
  --tw-enter-scale: initial;
  --tw-enter-rotate: initial;
  --tw-enter-translate-x: initial;
  --tw-enter-translate-y: initial;
}

.fade-in{
  --tw-enter-opacity: 0;
}

.fade-in-0{
  --tw-enter-opacity: 0;
}

.fade-in-80{
  --tw-enter-opacity: 0.8;
}

.fade-out{
  --tw-exit-opacity: 0;
}

.zoom-in-95{
  --tw-enter-scale: .95;
}

.zoom-out{
  --tw-exit-scale: 0;
}

.slide-in-from-bottom{
  --tw-enter-translate-y: 100%;
}

.slide-in-from-bottom-1{
  --tw-enter-translate-y: 0.25rem;
}

.slide-in-from-bottom-4{
  --tw-enter-translate-y: 1rem;
}

.slide-in-from-right-2{
  --tw-enter-translate-x: 0.5rem;
}

.slide-in-from-right-4{
  --tw-enter-translate-x: 1rem;
}

.slide-in-from-top{
  --tw-enter-translate-y: -100%;
}

.slide-in-from-top-1{
  --tw-enter-translate-y: -0.25rem;
}

.slide-in-from-top-2{
  --tw-enter-translate-y: -0.5rem;
}

.slide-in-from-top-4{
  --tw-enter-translate-y: -1rem;
}

.duration-100{
  animation-duration: 100ms;
}

.duration-1000{
  animation-duration: 1000ms;
}

.duration-150{
  animation-duration: 150ms;
}

.duration-200{
  animation-duration: 200ms;
}

.duration-300{
  animation-duration: 300ms;
}

.duration-500{
  animation-duration: 500ms;
}

.duration-700{
  animation-duration: 700ms;
}

.ease-in-out{
  animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.ease-linear{
  animation-timing-function: linear;
}

.ease-out{
  animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
}

.\!running{
  animation-play-state: running !important;
}

.running{
  animation-play-state: running;
}

.paused{
  animation-play-state: paused;
}

/* ── Build 383 — Mapa Trincheira: modos imersivos ──
     Quando a Tab Mapa entra em modo "expanded" ou "immersive", o TabMapa
     escreve `data-map-mode` no <html>. CSS aqui esconde tab bar/header sem
     precisar refatorar AppShell (desacoplado, reversível, zero risco).

     Hierarquia:
       compact   → comportamento normal (default)
       expanded  → tab bar e progress sobem com translateY; header vira faixa fina
       immersive → tudo translada pra fora; só mapa + overlays do próprio mapa
  */

html[data-map-mode="expanded"] .glass-strong.sticky.top-\[105px\],
  html[data-map-mode="immersive"] .glass-strong.sticky.top-\[105px\] {
    transform: translateY(-100%);
    pointer-events: none;
    opacity: 0;
    transition: transform 0.28s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.2s ease;
  }

html[data-map-mode="expanded"] .app-header,
  html[data-map-mode="immersive"] .app-header {
    transform: translateY(-100%);
    pointer-events: none;
    opacity: 0;
    transition: transform 0.28s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.2s ease;
  }

/* Esconde barras KPI/status do TabMapa em modo expanded/immersive —
     informação migra para o KPI pill flutuante dentro do mapa */

html[data-map-mode="expanded"] .map-kpi-bar,
  html[data-map-mode="immersive"] .map-kpi-bar {
    display: none;
  }

/* Build 730 — esconde a bottom tab bar fixa em modo imersivo */

html[data-map-mode="immersive"] nav[role="tablist"],
  html[data-map-mode="expanded"] nav[role="tablist"] {
    transform: translateY(100%);
    pointer-events: none;
    opacity: 0;
    transition: transform 0.28s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.2s ease;
  }

nav[role="tablist"] {
    transition: transform 0.28s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.2s ease;
  }

/* Smooth transition coming back too */

.app-header,
  .glass-strong.sticky.top-\[105px\] {
    transition: transform 0.28s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.2s ease;
  }

/* Disable pull-to-refresh while immersive */

html[data-map-mode="immersive"] {
    overscroll-behavior-y: none;
  }

/* ── Build 705 — Mapa 60fps: atmosfera premium SEM custo de pintura.
     Regras:
       1. Filters/blends/drop-shadows ATIVOS apenas em estado idle.
       2. Durante pan/zoom (Leaflet aplica .leaflet-zoom-anim no container e
          .leaflet-drag-target/.leaflet-dragging no body), TODOS os efeitos
          que forçam repaint do compositor são desligados → 60fps no mobile.
       3. Panes que se movem (overlay, marker, tile) ganham promoção GPU
          (translateZ + will-change: transform).
       4. mix-blend-mode trocado por gradient com alpha (composição barata).
       5. Tiles sem animação por-tile (custo O(N tiles) em pan); fade-in fica
          a cargo da transição padrão do .leaflet-tile-loaded. */

.map-tactical {
    isolation: isolate;
    background:
      radial-gradient(ellipse 120% 80% at 50% 0%, hsl(30 100% 50% / 0.04), transparent 60%),
      radial-gradient(ellipse 100% 100% at 50% 100%, hsl(220 40% 8% / 0.4), transparent 70%),
      hsl(var(--background));
    contain: layout paint;
  }

/* Promove panes pra camadas GPU dedicadas (composição barata) */

.map-tactical .leaflet-tile-pane,
  .map-tactical .leaflet-overlay-pane,
  .map-tactical .leaflet-marker-pane {
    will-change: transform;
    transform: translateZ(0);
    backface-visibility: hidden;
  }

.map-tactical .leaflet-tile-pane {
    filter:
      saturate(0.92)
      contrast(1.06)
      brightness(0.95);
    transition: filter 0.5s cubic-bezier(0.16, 1, 0.3, 1);
  }

.light .map-tactical .leaflet-tile-pane {
    /* Mais vida no light: cores saturadas, contraste rico, sem lavar */
    filter:
      saturate(1.15)
      contrast(1.08)
      brightness(1.0);
  }

.map-tactical[data-tile="satellite"] .leaflet-tile-pane {
    filter:
      saturate(1.12)
      contrast(1.1)
      brightness(0.95);
  }

.light .map-tactical[data-tile="satellite"] .leaflet-tile-pane {
    filter:
      saturate(1.2)
      contrast(1.12)
      brightness(1.02);
  }

/* ⚡ 60fps gate — durante pan/zoom desliga filters do tile-pane e drop-shadows
     dos paths/markers. Repaints caem ~60%, frame-time -8 a -12ms em mid-tier Android. */

.map-tactical .leaflet-container.leaflet-zoom-anim .leaflet-tile-pane,
  .map-tactical .leaflet-container.leaflet-touch-drag .leaflet-tile-pane,
  body.leaflet-dragging .map-tactical .leaflet-tile-pane {
    filter: none !important;
    transition: none !important;
  }

.map-tactical .leaflet-container.leaflet-zoom-anim .leaflet-overlay-pane svg path,
  body.leaflet-dragging .map-tactical .leaflet-overlay-pane svg path {
    filter: none !important;
  }

.map-tactical .leaflet-container.leaflet-zoom-anim .leaflet-marker-icon,
  body.leaflet-dragging .map-tactical .leaflet-marker-icon {
    filter: none !important;
    transition: none !important;
  }

/* Tint atmosférico — gradient warm/cool sofisticado (sem mix-blend-mode) */

.map-tactical .leaflet-container::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 401;
    background:
      linear-gradient(180deg,
        hsl(30 100% 50% / 0.04) 0%,
        transparent 22%,
        transparent 75%,
        hsl(220 50% 4% / 0.28) 100%);
  }

.light .map-tactical .leaflet-container::before {
    /* Light: gradiente sutil amber→cyan no topo, warm no rodapé pra dar profundidade */
    background:
      linear-gradient(180deg,
        hsl(30 95% 55% / 0.05) 0%,
        hsl(200 70% 60% / 0.025) 25%,
        transparent 55%,
        hsl(25 60% 45% / 0.06) 100%);
  }

/* Vinheta dramática + glow brand sutil no rodapé */

.map-tactical .leaflet-container::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 402;
    background:
      radial-gradient(ellipse 88% 68% at 50% 50%, transparent 52%, hsl(220 60% 3% / 0.38) 100%),
      radial-gradient(circle at 50% 100%, hsl(30 100% 50% / 0.07), transparent 38%);
  }

.light .map-tactical .leaflet-container::after {
    /* Light: vinheta mais leve mas com warmth nas bordas pra parar de lavar */
    background:
      radial-gradient(ellipse 95% 78% at 50% 45%, transparent 58%, hsl(25 40% 25% / 0.18) 100%),
      radial-gradient(circle at 50% 100%, hsl(30 100% 50% / 0.05), transparent 40%);
  }

/* Polylines da rota — antialias + sombra UM nível só (era 1 já, mantido) */

.map-tactical .leaflet-overlay-pane svg path {
    stroke-linecap: round;
    stroke-linejoin: round;
    paint-order: stroke;
    filter: drop-shadow(0 1px 2px hsl(0 0% 0% / 0.4));
  }

/* Markers — sombra ÚNICA (era dupla = 2x custo de paint). Visual quase
     idêntico, custo de pintura cai pela metade. */

.map-tactical .leaflet-marker-icon {
    filter: drop-shadow(0 3px 6px hsl(0 0% 0% / 0.5));
    transition: filter 0.2s ease, transform 0.2s cubic-bezier(0.16, 1, 0.3, 1);
  }

.map-tactical .leaflet-marker-icon:hover {
    filter: drop-shadow(0 5px 12px hsl(30 100% 50% / 0.55));
  }

/* Cluster bubbles — glow brand (box-shadow, não filter — composição barata) */

.map-tactical .leaflet-marker-icon.marker-cluster {
    box-shadow: 0 0 0 2px hsl(var(--background) / 0.6), 0 4px 16px hsl(30 100% 50% / 0.35);
  }

/* Tiles fade-in via opacity transition do Leaflet (NÃO @keyframes per tile —
     era O(N tiles) de cost). 240ms é o sweet spot entre suave e rápido. */

.map-tactical .leaflet-tile {
    transition: opacity 0.24s cubic-bezier(0.16, 1, 0.3, 1);
  }

/* Mobile: corta drop-shadows de SVG (mais caro de tudo em pan) e single-shadow
     em markers já é o mínimo. Mapa fica imperceptivelmente menos "premium" mas
     sustenta 60fps em Galaxy A/Moto G. */

@media (max-width: 480px) {
    .map-tactical .leaflet-overlay-pane svg path {
      filter: none;
    }
    .map-tactical .leaflet-marker-icon {
      filter: drop-shadow(0 2px 4px hsl(0 0% 0% / 0.45));
    }
  }

@media (prefers-reduced-motion: reduce) {
    .map-tactical .leaflet-tile { transition: none; }
    .map-tactical .leaflet-tile-pane { transition: none; }
    .map-tactical .leaflet-marker-icon { transition: none; }
  }

/* ── Build 691 — Classes tipográficas: consumidoras puras dos --type-* tokens.
     ZERO valor literal aqui. Pra mudar tamanho/peso/tracking de qualquer papel,
     edite só os --type-*-{size|weight|tracking|leading} no :root.
     Usadas em badges, pílulas, FABs, headers, coachmarks — dentro e fora do mapa. */

.map-eyebrow {
    font-size: var(--type-eyebrow-size);
    font-weight: var(--type-eyebrow-weight);
    letter-spacing: var(--type-eyebrow-tracking);
    line-height: var(--type-eyebrow-leading);
    text-transform: uppercase;
    font-variant-numeric: tabular-nums;
  }

.map-title {
    font-size: var(--type-title-size);
    font-weight: var(--type-title-weight);
    letter-spacing: var(--type-title-tracking);
    line-height: var(--type-title-leading);
    text-wrap: balance;
  }

.map-label {
    font-size: var(--type-label-size);
    font-weight: var(--type-label-weight);
    letter-spacing: var(--type-label-tracking);
    line-height: var(--type-label-leading);
  }

.map-body {
    font-size: var(--type-body-size);
    font-weight: var(--type-body-weight);
    letter-spacing: var(--type-body-tracking);
    line-height: var(--type-body-leading);
    text-wrap: pretty;
  }

.map-meta {
    font-size: var(--type-meta-size);
    font-weight: var(--type-meta-weight);
    letter-spacing: var(--type-meta-tracking);
    line-height: var(--type-meta-leading);
    font-variant-numeric: tabular-nums;
  }

.map-caption {
    font-size: var(--type-caption-size);
    font-weight: var(--type-caption-weight);
    letter-spacing: var(--type-caption-tracking);
    line-height: var(--type-caption-leading);
    color: hsl(var(--muted-foreground));
  }

/* ── Build 692 — Numéricos padronizados.
     Toda combinação número+unidade no mapa (km, m, X/Y paradas, V volumes,
     ORD seqs) usa .map-num pro número e .map-unit pra unidade.
     - tabular-nums + slashed-zero pra alinhar dígitos verticalmente.
     - font-feature-settings 'cv11' garante o "1" sem serifa (DM Sans).
     - .map-unit fica 80% do tamanho atual, peso 600, muted (hierarquia clara).
     Combina com qualquer .map-* (title/label/meta) sem trocar size base.
     Exemplo: <span class="map-meta"><span class="map-num">12.4</span><span class="map-unit">km</span></span> */

.map-num {
    font-variant-numeric: tabular-nums slashed-zero;
    font-feature-settings: 'cv11', 'ss01', 'tnum';
    font-weight: inherit;
    letter-spacing: -0.01em;
  }

.map-unit {
    font-size: 0.78em;
    font-weight: 600;
    letter-spacing: 0.01em;
    color: hsl(var(--muted-foreground));
    margin-left: 0.18em;
    text-transform: lowercase;
    font-variant-numeric: normal;
  }

/* Separador visual entre par num+num (ex: 3/12) — barra mais fina e muted */

.map-num-sep {
    color: hsl(var(--muted-foreground) / 0.7);
    font-weight: 500;
    margin: 0 0.1em;
  }

/* Tablet+ : tokens ganham respiro extra. Mantém ponto único de override. */

@media (min-width: 768px) {
    :root {
      --type-eyebrow-leading: 16px;
      --type-eyebrow-tracking: 0.18em;
      --type-title-leading: 1.32;
      --type-body-leading: 1.55;
    }

    /* Desktop: sem tab bar embaixo — reduz padding-bottom do conteúdo */
    #conteudo-principal {
      padding-bottom: 2rem !important;
    }
  }

/* ── Glass morphism — Apple vibrancy (GPU-accelerated) ── */

.glass {
    background: hsl(224 13% 6% / 0.72);
    backdrop-filter: blur(24px) saturate(1.8);
    -webkit-backdrop-filter: blur(24px) saturate(1.8);
    will-change: transform;
    transform: translateZ(0);
  }

.glass-strong {
    background: hsl(224 13% 5% / 0.92);
    backdrop-filter: blur(32px) saturate(1.8);
    -webkit-backdrop-filter: blur(32px) saturate(1.8);
    will-change: transform;
    transform: translateZ(0);
  }

/* ── Light-mode glass overrides — keep glassmorphism but readable on white ── */

.light .glass {
    background: hsl(0 0% 100% / 0.78);
  }

.light .glass-strong {
    background: hsl(0 0% 100% / 0.94);
  }

.light .glass-card {
    background: linear-gradient(145deg, hsl(0 0% 100% / 0.98), hsl(220 16% 97% / 0.98));
    border: 1px solid hsl(220 16% 84% / 0.7);
    box-shadow:
      0 0 0 0.5px hsl(220 16% 80% / 0.2) inset,
      0 2px 8px hsl(224 18% 12% / 0.06),
      0 8px 32px hsl(224 18% 12% / 0.08);
  }

/* ── Theme-aware modal backdrop (replaces hardcoded bg-black/XX) ── */

.modal-overlay {
    background-color: hsl(var(--overlay));
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
  }

.modal-overlay-strong {
    background-color: hsl(var(--overlay));
    backdrop-filter: blur(12px) saturate(1.2);
    -webkit-backdrop-filter: blur(12px) saturate(1.2);
  }

.glass-card {
    background: linear-gradient(145deg, hsl(224 13% 8% / 0.95), hsl(224 13% 5% / 0.98));
    border: 1px solid hsl(220 13% 100% / 0.06);
    box-shadow:
      0 0 0 0.5px hsl(220 13% 100% / 0.04) inset,
      0 1px 0 0 hsl(220 13% 100% / 0.04) inset,
      0 1px 2px hsl(0 0% 0% / 0.4),
      0 8px 24px hsl(0 0% 0% / 0.32),
      0 24px 64px hsl(0 0% 0% / 0.22);
    transform: translateZ(0);
  }

/* ── Premium shadows — Apple two-layer (close + ambient) ── */

.shadow-glow-primary {
    box-shadow: 0 0 32px -6px hsl(26 100% 54% / 0.32),
                0 4px 24px -4px hsl(0 0% 0% / 0.5);
  }

.shadow-glow-success {
    box-shadow: 0 0 32px -6px hsl(142 60% 42% / 0.32),
                0 4px 24px -4px hsl(0 0% 0% / 0.5);
  }

.shadow-premium {
    box-shadow:
      0 0 0 0.5px hsl(220 13% 100% / 0.04) inset,
      0 1px 0 0 hsl(220 13% 100% / 0.05) inset,
      0 1px 2px hsl(0 0% 0% / 0.5),
      0 6px 20px hsl(0 0% 0% / 0.35),
      0 20px 60px hsl(0 0% 0% / 0.22);
  }

.shadow-card {
    box-shadow:
      0 0 0 0.5px hsl(220 13% 100% / 0.03) inset,
      0 1px 3px hsl(0 0% 0% / 0.32),
      0 4px 16px hsl(0 0% 0% / 0.18);
  }

.shadow-input {
    box-shadow:
      0 0 0 0.5px hsl(220 13% 100% / 0.03) inset,
      0 1px 2px hsl(0 0% 0% / 0.3);
  }

/* ── Gradient text ── */

.text-gradient-primary {
    background: linear-gradient(135deg, hsl(28 100% 60%), hsl(18 100% 52%));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }

.text-gradient-success {
    background: linear-gradient(135deg, hsl(142 60% 50%), hsl(150 55% 44%));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }

/* ── Border glows ── */

.border-glow-primary {
    border-color: hsl(26 100% 54% / 0.4);
    box-shadow: 0 0 0 0.5px hsl(26 100% 54% / 0.12) inset,
                0 0 24px -6px hsl(26 100% 54% / 0.22);
  }

.border-glow-success {
    border-color: hsl(142 60% 42% / 0.4);
    box-shadow: 0 0 0 0.5px hsl(142 60% 42% / 0.12) inset,
                0 0 24px -6px hsl(142 60% 42% / 0.22);
  }

/* ── Noise texture overlay (lightweight) ── */

.noise::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-conic-gradient(hsl(220 10% 60% / 0.022) 0% 25%, transparent 0% 50%) 0 0 / 3px 3px;
    border-radius: inherit;
    pointer-events: none;
    z-index: 1;
    mix-blend-mode: overlay;
  }

/* ── Inner highlight border (Apple top-light) ── */

.inner-border {
    box-shadow:
      0 0 0 0.5px hsl(220 13% 100% / 0.05) inset,
      0 1px 0 0 hsl(220 13% 100% / 0.06) inset;
  }

/* ── Premium card hover effect ── */

/* ══════════════════════════════════════════════════════════════════════
     Build 295 — HUD / Tech-automotive utilities
     Painel de instrumentos: brackets, hairlines, label tracking-widest,
     accent rails. Tudo composable, sem JS, GPU-friendly.
     ══════════════════════════════════════════════════════════════════════ */

/* Hairline divider — 1px ultra-thin com fade nas pontas */

.hud-rule {
    position: relative;
  }

.hud-rule::after {
    content: '';
    position: absolute;
    inset: auto 0 0 0;
    height: 1px;
    background: linear-gradient(90deg,
      transparent 0%,
      hsl(var(--foreground) / 0.10) 20%,
      hsl(var(--foreground) / 0.10) 80%,
      transparent 100%);
  }

/* Vertical hairline para grids de "instrumentos" */

.hud-divide-x > * + * {
    border-left: 1px solid hsl(var(--foreground) / 0.08);
  }

/* Corner brackets — moldura de gauge premium nos 4 cantos */

.hud-corners {
    position: relative;
  }

.hud-corners::before,
  .hud-corners::after {
    content: '';
    position: absolute;
    width: 10px;
    height: 10px;
    pointer-events: none;
  }

.hud-corners::before {
    top: 6px;
    left: 6px;
    border-top: 1px solid hsl(var(--primary) / 0.55);
    border-left: 1px solid hsl(var(--primary) / 0.55);
  }

.hud-corners::after {
    bottom: 6px;
    right: 6px;
    border-bottom: 1px solid hsl(var(--primary) / 0.55);
    border-right: 1px solid hsl(var(--primary) / 0.55);
  }

/* Label de instrumento — tracking-widest mono */

.hud-label {
    font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 9px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: hsl(var(--muted-foreground));
  }

/* Accent rail — barra fina horizontal/vertical no topo de uma cell */

.hud-rail-top {
    position: relative;
  }

.hud-rail-top::before {
    content: '';
    position: absolute;
    top: 0; left: 12%; right: 12%;
    height: 1px;
    background: linear-gradient(90deg,
      transparent,
      hsl(var(--primary) / 0.7),
      transparent);
  }

.hud-rail-top-success::before {
    background: linear-gradient(90deg,
      transparent,
      hsl(var(--success) / 0.7),
      transparent);
  }

.hud-rail-top-muted::before {
    background: linear-gradient(90deg,
      transparent,
      hsl(var(--muted-foreground) / 0.4),
      transparent);
  }

/* Painel HUD base — adapta ao tema. Em light: branco com sombra suave
     + accent rail laranja garante identidade tech. Em dark: cinza grafite
     elevado acima do --card. */

.hud-panel {
    background: hsl(var(--card));
    border: 1px solid hsl(var(--border) / 0.6);
    box-shadow:
      0 1px 0 0 hsl(0 0% 100% / 0.6) inset,
      0 1px 2px hsl(224 18% 12% / 0.04),
      0 8px 24px hsl(224 18% 12% / 0.08);
  }

.dark .hud-panel,
  :root:not(.light) .hud-panel {
    background: linear-gradient(160deg,
      hsl(224 14% 13% / 0.96),
      hsl(224 14% 10% / 0.98));
    border: 1px solid hsl(220 13% 100% / 0.08);
    box-shadow:
      0 0 0 0.5px hsl(220 13% 100% / 0.05) inset,
      0 1px 0 0 hsl(220 13% 100% / 0.08) inset,
      0 1px 2px hsl(0 0% 0% / 0.4),
      0 8px 24px hsl(0 0% 0% / 0.32);
  }

/* Cell de instrumento — fundo translúcido com leve lift do card */

.hud-cell {
    background: hsl(var(--muted) / 0.5);
    border: 1px solid hsl(var(--border) / 0.5);
    border-radius: 12px;
  }

.dark .hud-cell,
  :root:not(.light) .hud-cell {
    background: linear-gradient(180deg,
      hsl(220 13% 100% / 0.04),
      hsl(220 13% 100% / 0.01));
    border: 1px solid hsl(220 13% 100% / 0.07);
  }

/* Tabular nums — pra todos os números do HUD */

.hud-num {
    font-family: var(--font-mono);
    font-variant-numeric: tabular-nums;
    font-feature-settings: 'tnum' 1, 'lnum' 1;
  }

/* Pill de telemetria (ZONA, ETA, LADO, DIST→) */

.hud-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 9px;
    border-radius: 8px;
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.06em;
    background: hsl(var(--muted) / 0.6);
    border: 1px solid hsl(var(--border) / 0.5);
    color: hsl(var(--foreground) / 0.78);
  }

/* Side stripe — listra vertical luxuosa lateral esquerda do hero card */

/* ══════════════════════════════════════════════════════════════════════
     Build 270 — Premium hover/disabled system
     Estratégia: em vez de cortar opacidade do background (vira washed),
     sobrepor um filme branco/preto (Apple-like "lift") e dimar foreground
     no disabled mantendo o background intacto.
     ══════════════════════════════════════════════════════════════════════ */

/* Hover lift — adiciona overlay branco sutil sem mexer no bg base.
     Usar em botões/badges com bg sólido (primary, destructive, success). */

.hover-lift {
    position: relative;
    isolation: isolate;
    transition: filter 0.15s ease, transform 0.15s ease;
  }

.hover-lift::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: hsl(var(--hover-overlay));
    opacity: 0;
    transition: opacity 0.15s ease;
    pointer-events: none;
    z-index: 0;
  }

.hover-lift > * { position: relative; z-index: 1; }

@media (hover: hover) {
    .hover-lift:hover::after { opacity: 1; }
    .hover-lift:hover { filter: brightness(1.06); }
  }

.hover-lift:active { filter: brightness(0.94); transform: scale(0.985); }

/* Hover surface — pra ghost/outline buttons em surface escura.
     Substitui hover:bg-accent (delta de luminância invisível no dark). */

.hover-surface {
    transition: background-color 0.15s ease, color 0.15s ease;
  }

@media (hover: hover) {
    .hover-surface:hover {
      background-color: hsl(var(--hover-overlay-strong));
      color: hsl(var(--foreground));
    }
  }

.hover-surface:active {
    background-color: hsl(var(--press-overlay));
  }

/* Disabled premium — preserva geometria, dima foreground, dessatura levemente.
     Substitui disabled:opacity-50 (que mata contraste do texto preto sobre laranja). */

/* Disabled mantendo brand color (loading states em CTA primário) — só dima */

.disabled-dim:disabled,
  .disabled-dim[aria-disabled="true"] {
    opacity: 0.55;
    filter: saturate(0.85);
    cursor: not-allowed;
    pointer-events: none;
  }

/* Badge outline com border visível no dark (text-foreground sozinho some) */

.badge-outline-premium {
    background: hsl(var(--surface-2));
    border: 1px solid hsl(var(--border));
    color: hsl(var(--foreground));
  }

/* ── Build 730 — Design system utilities (premium tokens) ── */

/* Eyebrow label — JetBrains Mono uppercase, usado em seções e cards */

.eyebrow {
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: hsl(var(--primary) / 0.8);
  }

/* Surface premium — card com borda interna e sombra two-layer */

/* Glow do botão primário */

.\[-\:\\s\]{
  -: \s;
}

.\[-ms-overflow-style\:none\]{
  -ms-overflow-style: none;
}

.\[-webkit-tap-highlight-color\:transparent\]{
  -webkit-tap-highlight-color: transparent;
}

.\[leaderboard\:bucket\]{
  leaderboard: bucket;
}

.\[scrollbar-width\:none\]{
  scrollbar-width: none;
}

.\[transition-duration\:220ms\]{
  transition-duration: 220ms;
}

.\[transition-duration\:80ms\]{
  transition-duration: 80ms;
}

/* ── Safe Area — iPhone notch / Dynamic Island / Android cutout ──────────────
   viewport-fit=cover já está no index.html. Estas vars expõem os insets como
   tokens CSS reutilizáveis em qualquer componente sem repetir env(...).
   Fallback 0px garante que Android sem notch não quebre nada.             */

:root {
  --sat: env(safe-area-inset-top,    0px);
  --sar: env(safe-area-inset-right,  0px);
  --sab: env(safe-area-inset-bottom, 0px);
  --sal: env(safe-area-inset-left,   0px);
}

/* Utilitários Tailwind-like para safe area — use diretamente nas classes */

.pt-safe   { padding-top:    env(safe-area-inset-top,    0px); }

.pb-safe   { padding-bottom: env(safe-area-inset-bottom, 0px); }

.pl-safe   { padding-left:   env(safe-area-inset-left,   0px); }

.pr-safe   { padding-right:  env(safe-area-inset-right,  0px); }

/* Sticky/fixed navbars: padding-top = safe-area-top para não ficar atrás do Dynamic Island */

.sticky-safe-top {
  padding-top: env(safe-area-inset-top, 0px);
}

/* Bottom sheets e footers fixos: padding-bottom = safe-area-bottom + espaço da tab bar */

.pb-safe-tab {
  padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 64px);
}

/* Tab bar do app: altura total = 56px + safe-area-bottom */

.tab-bar-height {
  height: calc(56px + env(safe-area-inset-bottom, 0px));
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

/* ── Light mode: opacity floor for de-emphasised text ──────────────────────
   In dark mode, muted text at /30–/40 opacity sits on a dark bg → still
   readable. On a near-white bg those same opacities render at 1.7–2.4:1
   contrast — below readable threshold. These overrides raise the floor so
   the visual weight is similar to dark mode but contrast stays acceptable. */

.light .text-muted-foreground\/25 { color: hsl(var(--muted-foreground) / 0.50); }

.light .text-muted-foreground\/30 { color: hsl(var(--muted-foreground) / 0.55); }

.light .text-muted-foreground\/35 { color: hsl(var(--muted-foreground) / 0.62); }

.light .text-muted-foreground\/40 { color: hsl(var(--muted-foreground) / 0.68); }

.light .text-muted-foreground\/50 { color: hsl(var(--muted-foreground) / 0.75); }

.light .text-foreground\/30      { color: hsl(var(--foreground) / 0.55); }

.light .text-foreground\/35      { color: hsl(var(--foreground) / 0.60); }

.light .text-foreground\/40      { color: hsl(var(--foreground) / 0.65); }

.light .text-foreground\/50      { color: hsl(var(--foreground) / 0.72); }

/* ── Light mode overrides ── */

.light .glass {
  background: hsl(0 0% 100% / 0.82);
  backdrop-filter: blur(20px) saturate(1.2);
  -webkit-backdrop-filter: blur(20px) saturate(1.2);
}

.light .glass-strong {
  background: hsl(210 20% 98% / 0.96);
  backdrop-filter: blur(28px) saturate(1.2);
  -webkit-backdrop-filter: blur(28px) saturate(1.2);
}

.light .glass-card {
  background: linear-gradient(145deg, hsl(0 0% 100% / 0.98), hsl(210 20% 98% / 0.99));
  border: 1px solid hsl(220 16% 86% / 0.6);
  box-shadow:
    0 0 0 0.5px hsl(220 16% 92% / 0.5) inset,
    0 1px 0 0 hsl(0 0% 100% / 0.9) inset,
    0 2px 8px hsl(0 0% 0% / 0.05),
    0 8px 32px hsl(0 0% 0% / 0.04);
}

.light .shadow-premium {
  box-shadow:
    0 0 0 0.5px hsl(220 16% 88% / 0.4) inset,
    0 1px 0 0 hsl(0 0% 100% / 0.7) inset,
    0 1px 3px hsl(0 0% 0% / 0.06),
    0 6px 24px hsl(0 0% 0% / 0.06),
    0 16px 56px hsl(0 0% 0% / 0.04);
}

.light .shadow-card {
  box-shadow:
    0 0 0 0.5px hsl(220 16% 88% / 0.3) inset,
    0 1px 4px hsl(0 0% 0% / 0.06),
    0 4px 16px hsl(0 0% 0% / 0.04);
}

.light .shadow-input {
  box-shadow:
    0 0 0 0.5px hsl(220 16% 80% / 0.3) inset,
    0 1px 3px hsl(0 0% 0% / 0.06);
}

.light .inner-border {
  box-shadow:
    0 0 0 0.5px hsl(220 16% 84% / 0.3) inset,
    0 1px 0 0 hsl(0 0% 100% / 0.7) inset;
}

.light .noise::before {
  background: repeating-conic-gradient(hsl(0 0% 0% / 0.012) 0% 25%, transparent 0% 50%) 0 0 / 3px 3px;
}

.light .divider-fade {
  background: linear-gradient(90deg, transparent 0%, hsl(220 16% 82%) 30%, hsl(220 16% 82%) 70%, transparent 100%);
}

.light ::-moz-selection {
  background: hsl(28 100% 44% / 0.18);
  color: hsl(224 18% 12%);
}

.light ::selection {
  background: hsl(28 100% 44% / 0.18);
  color: hsl(224 18% 12%);
}

.light input::-moz-placeholder, .light textarea::-moz-placeholder {
  color: hsl(224 10% 58%);
}

.light input::placeholder, .light textarea::placeholder {
  color: hsl(224 10% 58%);
}

/* Scrollbar */

.scrollbar-hide::-webkit-scrollbar { display: none; }

.scrollbar-hide { scrollbar-width: none; }

::-webkit-scrollbar { width: 3px; }

::-webkit-scrollbar-track { background: transparent; }

::-webkit-scrollbar-thumb { background: hsl(224 12% 14%); border-radius: 4px; }

::-webkit-scrollbar-thumb:hover { background: hsl(224 11% 22%); }

.light ::-webkit-scrollbar-thumb { background: hsl(220 16% 76%); }

.light ::-webkit-scrollbar-thumb:hover { background: hsl(220 16% 68%); }

/* ── Leaflet — padronizado com tokens do design system ── */

/* Build 709 — touch-action:none + overscroll-behavior:none cortam scroll
   chaining: gestos no mapa NUNCA viram scroll do documento. Leaflet trata
   pan/zoom via JS, então não precisamos de pan-x/pan-y nativos aqui. */

.leaflet-container {
  background: hsl(var(--background)) !important;
  font-family: inherit !important;
  overscroll-behavior: none;
  touch-action: none;
}

/* Popups — surface-2 com glass premium + entrada animada (Build 752) */

.leaflet-popup {
  animation: mr-popup-in 0.22s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes mr-popup-in {
  from { opacity: 0; transform: scale(0.92) translateY(4px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.leaflet-popup-content-wrapper {
  background: hsl(var(--popover)) !important;
  backdrop-filter: none !important;
  color: hsl(var(--popover-foreground)) !important;
  border-radius: 16px !important;
  border: 1px solid hsl(var(--border)) !important;
  box-shadow:
    0 16px 44px hsl(0 0% 0% / 0.42),
    0 3px 10px hsl(0 0% 0% / 0.18) !important;
}

.leaflet-popup-tip {
  background: hsl(var(--popover)) !important;
  border: 1px solid hsl(var(--border)) !important;
  box-shadow: none !important;
}

.leaflet-popup-content { color: hsl(var(--popover-foreground)) !important; margin: 12px 16px !important; }

.leaflet-popup-close-button {
  color: hsl(var(--muted-foreground)) !important;
  padding: 6px 8px 0 0 !important;
}

.leaflet-popup-close-button:hover { color: hsl(var(--foreground)) !important; }

/* Tooltips */

.leaflet-tooltip {
  background: hsl(var(--popover) / 0.95) !important;
  color: hsl(var(--popover-foreground)) !important;
  border: 1px solid hsl(var(--border) / 0.6) !important;
  border-radius: 8px !important;
  box-shadow: 0 6px 20px hsl(0 0% 0% / 0.35) !important;
  font-family: inherit !important;
}

.leaflet-tooltip-top:before { border-top-color: hsl(var(--border) / 0.6) !important; }

.leaflet-tooltip-bottom:before { border-bottom-color: hsl(var(--border) / 0.6) !important; }

.leaflet-tooltip-left:before { border-left-color: hsl(var(--border) / 0.6) !important; }

.leaflet-tooltip-right:before { border-right-color: hsl(var(--border) / 0.6) !important; }

/* Controles de zoom + genéricos */

/* Build 727 — sobe controle de zoom (bottomleft) acima do dock/card "Parada atual"
   pra não ficar colado no rodapé em mobile. Mobile-first: 132px base, ≥640px volta menor. */

.leaflet-bottom.leaflet-left { margin-bottom: 132px !important; margin-left: 8px !important; }

@media (min-width: 640px) { .leaflet-bottom.leaflet-left { margin-bottom: 96px !important; } }

.leaflet-bar,
.leaflet-control-zoom {
  border: 1px solid hsl(var(--border) / 0.6) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  box-shadow: 0 6px 20px hsl(0 0% 0% / 0.35) !important;
  background: hsl(var(--surface-2) / 0.92) !important;
  backdrop-filter: blur(16px) saturate(1.6) !important;
}

.leaflet-bar a,
.leaflet-control-zoom a {
  background: transparent !important;
  color: hsl(var(--foreground)) !important;
  border-bottom: 1px solid hsl(var(--border) / 0.4) !important;
  transition: background-color 120ms ease, color 120ms ease;
}

.leaflet-bar a:last-child,
.leaflet-control-zoom a:last-child { border-bottom: none !important; }

.leaflet-bar a:hover,
.leaflet-control-zoom a:hover {
  background: hsl(var(--primary) / 0.12) !important;
  color: hsl(var(--primary)) !important;
}

.leaflet-bar a.leaflet-disabled {
  background: transparent !important;
  color: hsl(var(--muted-foreground) / 0.5) !important;
  cursor: not-allowed;
}

/* Attribution */

.leaflet-control-attribution {
  background: hsl(var(--surface) / 0.78) !important;
  backdrop-filter: blur(8px) !important;
  color: hsl(var(--muted-foreground)) !important;
  border-radius: 6px 0 0 0 !important;
  padding: 2px 8px !important;
  font-size: 10px !important;
}

.leaflet-control-attribution a {
  color: hsl(var(--primary)) !important;
  text-decoration: none;
}

.leaflet-control-attribution a:hover { text-decoration: underline; }

/* Scale */

.leaflet-control-scale-line {
  background: hsl(var(--surface-2) / 0.85) !important;
  color: hsl(var(--foreground)) !important;
  border: 1px solid hsl(var(--border) / 0.6) !important;
  border-top: none !important;
  text-shadow: none !important;
  font-family: inherit !important;
}

/* MiniMap */

.leaflet-control-minimap {
  border: 1px solid hsl(var(--border) / 0.6) !important;
  border-radius: 12px !important;
  box-shadow: 0 8px 24px hsl(0 0% 0% / 0.45) !important;
  overflow: hidden !important;
  background: hsl(var(--surface) / 0.6) !important;
}

.leaflet-control-minimap-toggle-display {
  background-color: hsl(var(--primary)) !important;
  color: hsl(var(--primary-foreground)) !important;
  border-radius: 6px !important;
}

/* Light mode — só onde precisa override (popovers já vêm de tokens) */

.light .leaflet-container { background: hsl(var(--background)) !important; }

/* ── Keyframes ── */

@keyframes spin { to { transform: rotate(360deg); } }

.animate-spin-slow { animation: spin 0.8s linear infinite; }

@keyframes pop {
  from { opacity: 0; transform: scale(0.92) translateZ(0); }
  to { opacity: 1; transform: scale(1) translateZ(0); }
}

.animate-pop { animation: pop 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); will-change: transform, opacity; }

/* CargoCounter — pulsa o número quando um pacote sai do carro */

@keyframes cargo-pop {
  0%   { transform: scale(1) translateZ(0); color: hsl(var(--success)); }
  35%  { transform: scale(1.28) translateZ(0); color: hsl(var(--success)); }
  100% { transform: scale(1) translateZ(0); }
}

.animate-cargo-pop { animation: cargo-pop 0.65s cubic-bezier(0.34, 1.56, 0.64, 1); will-change: transform; }

@keyframes float {
  0%, 100% { transform: translateY(0px) translateZ(0); }
  50% { transform: translateY(-6px) translateZ(0); }
}

.animate-float { animation: float 5s ease-in-out infinite; will-change: transform; }

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

@keyframes scanline {
  0%   { top: 0%; }
  50%  { top: calc(100% - 2px); }
  100% { top: 0%; }
}

.scanline-bar {
  top: 0;
  background: linear-gradient(90deg, transparent 0%, hsl(var(--primary)) 30%, hsl(var(--primary)) 70%, transparent 100%);
  box-shadow: 0 0 8px 2px rgba(255, 122, 0, 0.55);
  animation: scanline 2s cubic-bezier(0.45, 0, 0.55, 1) infinite;
  will-change: top;
}

/* FAB: adiciona safe-area-inset-bottom em cima do bottom definido pelo Tailwind */

.fab-safe-bottom {
  bottom: calc(var(--fab-bottom, 1rem) + env(safe-area-inset-bottom, 0px));
}

@media (min-width: 640px) {
  .fab-safe-bottom { --fab-bottom: 1.5rem; }
}

.animate-shimmer {
  background: linear-gradient(90deg, transparent 0%, hsl(26 100% 54% / 0.05) 50%, transparent 100%);
  background-size: 200% 100%;
  animation: shimmer 3.5s ease-in-out infinite;
}

.hud-shimmer-success {
  position: relative;
  overflow: hidden;
}

.hud-shimmer-success::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, transparent 30%, hsl(142 60% 42% / 0.18) 50%, transparent 70%);
  background-size: 250% 100%;
  background-repeat: no-repeat;
  animation: shimmer 6s ease-in-out infinite;
  pointer-events: none;
}

@keyframes pulse-glow {
  0%, 100% { box-shadow: 0 0 0 0 hsl(26 100% 54% / 0.22); }
  50% { box-shadow: 0 0 32px 6px hsl(26 100% 54% / 0.12); }
}

.animate-pulse-glow { animation: pulse-glow 3s ease-in-out infinite; }

@keyframes slide-up-fade {
  from { opacity: 0; transform: translateY(20px) translateZ(0); }
  to { opacity: 1; transform: translateY(0) translateZ(0); }
}

.animate-slide-up { animation: slide-up-fade 0.6s cubic-bezier(0.16, 1, 0.3, 1); will-change: transform, opacity; }

@keyframes reveal {
  from { opacity: 0; transform: translateY(8px) translateZ(0); }
  to { opacity: 1; transform: translateY(0) translateZ(0); }
}

.animate-reveal { animation: reveal 0.4s cubic-bezier(0.16, 1, 0.3, 1) both; will-change: transform, opacity; }

/* OrderBadge pulse — só na parada ATUAL da TabRota.
   Anima opacidade da borda esquerda (anchor visual) sem causar repaint pesado. */

@keyframes order-pulse {
  0%, 100% { border-left-color: hsl(var(--primary)); box-shadow: 0 0 0 0 hsl(var(--primary) / 0.0); }
  50%      { border-left-color: hsl(var(--primary) / 0.5); box-shadow: 0 0 12px 0 hsl(var(--primary) / 0.35); }
}

.animate-order-pulse { animation: order-pulse 2s ease-in-out infinite; will-change: border-left-color, box-shadow; }

/* OrderBadge tap — microanimação de confirmação ao tocar (350ms).
   Squeeze + brilho do anchor laranja confirmam que o tooltip didático abriu. */

@keyframes order-tap {
  0%   { transform: scale(1);    box-shadow: 0 0 0 0 hsl(var(--primary) / 0.0); }
  40%  { transform: scale(0.94); box-shadow: 0 0 0 6px hsl(var(--primary) / 0.25); }
  100% { transform: scale(1);    box-shadow: 0 0 0 0 hsl(var(--primary) / 0.0); }
}

.animate-order-tap { animation: order-tap 0.35s cubic-bezier(0.4, 0, 0.2, 1); }

/* Scanner zone flash — burst branco curto + fade da cor da zona (legível no sol) */

@keyframes flashBurst {
  0% { opacity: 0.85; }
  100% { opacity: 0; }
}

@keyframes flashFade {
  0% { opacity: 0.6; }
  100% { opacity: 0; }
}

/* Build 391 — pulso destacando trecho suspeito clicado no drawer "Trechos pra conferir" */

@keyframes suspectPulse {
  0%, 100% { stroke-opacity: 0.95; stroke-width: 7; }
  50% { stroke-opacity: 0.45; stroke-width: 11; }
}

.suspect-pulse {
  animation: suspectPulse 0.8s ease-in-out infinite;
}

/* ───────────────────────────────────────────────────────────
   Build 698 — Microinterações premium mobile-first
   Press states com spring iOS-like, halo de brand, ripple suave.
   touch-action + user-select: crítico pra UX de polegar único.
   ─────────────────────────────────────────────────────────── */

/* Easing tokens */

:root {
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out-soft: cubic-bezier(0.32, 0.72, 0, 1);
}

/* Build 650 — Fallback haptic para iOS PWA (Vibration API não suportada no Safari).
   Micro-animação scale aplicada via JS em haptics.ts quando navigator.vibrate ausente. */

@keyframes haptic-pulse-anim {
  0%   { transform: scale(1); }
  40%  { transform: scale(0.94); }
  100% { transform: scale(1); }
}

.haptic-pulse {
  animation: haptic-pulse-anim 100ms var(--ease-out-soft) forwards;
}

.btn-press {
  touch-action: manipulation;
  -moz-user-select: none;
       user-select: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
  transition:
    transform 0.18s var(--ease-out-soft),
    box-shadow 0.22s var(--ease-out-soft),
    filter 0.18s var(--ease-out-soft);
  position: relative;
  overflow: hidden;
  will-change: transform;
}

.btn-press:hover { filter: brightness(1.06); }

.btn-press:active {
  transform: scale(0.96);
  filter: brightness(0.92);
  transition-duration: 0.08s;
}

@media (hover: hover) {
  .btn-press:hover { box-shadow: 0 6px 20px -10px hsl(var(--primary) / 0.35); }
}

/* Chip premium — pílulas pequenas com pop sutil */

.chip-press {
  touch-action: manipulation;
  -moz-user-select: none;
       user-select: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
  transition:
    transform 0.16s var(--ease-out-soft),
    background-color 0.18s ease,
    color 0.18s ease,
    box-shadow 0.2s var(--ease-out-soft);
  will-change: transform;
}

.chip-press:active {
  transform: scale(0.94);
  transition-duration: 0.07s;
}

.chip-press:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px hsl(var(--primary) / 0.55);
}

/* Tab premium — feedback ao tocar sem competir com o indicador layoutId */

.tab-press {
  touch-action: manipulation;
  -moz-user-select: none;
       user-select: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
  transition:
    transform 0.18s var(--ease-out-soft),
    color 0.18s ease;
  will-change: transform;
}

.tab-press:active { transform: scale(0.93); }

/* Halo de brand ao pressionar (combina com .btn-press) */

.press-halo { position: relative; }

.press-halo::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: radial-gradient(circle at center, hsl(var(--primary) / 0.35) 0%, transparent 70%);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s var(--ease-out-soft);
  z-index: -1;
}

.press-halo:active::before { opacity: 1; }

/* Ripple effect refinado */

.ripple-container {
  position: relative;
  overflow: hidden;
  -webkit-tap-highlight-color: transparent;
}

.ripple-container::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at var(--ripple-x, 50%) var(--ripple-y, 50%),
    hsl(var(--primary) / 0.22) 0%,
    hsl(var(--primary) / 0.08) 35%,
    transparent 65%
  );
  opacity: 0;
  transform: scale(0);
  transition: none;
  pointer-events: none;
  border-radius: inherit;
}

.ripple-container:active::after {
  opacity: 1;
  transform: scale(2.6);
  transition:
    transform 0.55s var(--ease-out-expo),
    opacity 0.45s ease;
}

/* Respeita preferência de menos movimento */

@media (prefers-reduced-motion: reduce) {
  .btn-press, .chip-press, .tab-press {
    transition: none !important;
  }
  .btn-press:active, .chip-press:active, .tab-press:active {
    transform: none !important;
  }
  .ripple-container::after { display: none !important; }
}

/* Pulse do pin GPS no mapa (TabMapa) */

@keyframes mr-pulse {
  0%   { transform: scale(0.6); opacity: 0.6; }
  70%  { transform: scale(1.8); opacity: 0;   }
  100% { transform: scale(1.8); opacity: 0;   }
}

/* Figma-style divider */

.divider-fade {
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, hsl(224 12% 14%) 30%, hsl(224 12% 14%) 70%, transparent 100%);
}

/* ───────────────────────────────────────────────────────────
   Route Edit — estilos premium 60fps
   Composable GPU-only, sem layout thrashing.
   ─────────────────────────────────────────────────────────── */

/* Pin do mapa de edição — pop sutil ao aparecer */

.edit-pin { transition: none; }

.edit-anchor { transition: none; }

/* Popup dark do mapa de edição */

.edit-popup .leaflet-popup-content-wrapper {
  background: hsl(var(--card)) !important;
  color: hsl(var(--foreground)) !important;
  border: 1px solid hsl(var(--border) / 0.3) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: 0 12px 40px -8px rgba(0,0,0,0.45), 0 0 0 1px hsl(var(--border) / 0.15) !important;
  padding: 0 !important;
}

.edit-popup .leaflet-popup-content {
  margin: 14px 16px !important;
  font-size: 13px !important;
  line-height: 1.4 !important;
}

.edit-popup .leaflet-popup-tip {
  background: hsl(var(--card)) !important;
  border: 1px solid hsl(var(--border) / 0.3) !important;
  box-shadow: none !important;
}

.edit-popup .leaflet-popup-close-button {
  color: hsl(var(--muted-foreground)) !important;
  font-size: 20px !important;
  font-weight: 300 !important;
  top: 8px !important;
  right: 10px !important;
  width: 24px !important;
  height: 24px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  transition: background 0.15s !important;
}

.edit-popup .leaflet-popup-close-button:hover {
  background: hsl(var(--foreground) / 0.08) !important;
}

/* ───────────────────────────────────────────────────────────
   Build 699 — Acessibilidade premium
   Foco visível consistente, contraste mínimo, skip-link,
   suporte a navegação por teclado e leitores de tela.
   ─────────────────────────────────────────────────────────── */

/* Anel de foco global SOMENTE para navegação por teclado.
   Não afeta clique/touch (que continua sem outline). */

*:focus { outline: none; }

*:focus-visible {
  outline: 2px solid hsl(var(--primary));
  outline-offset: 2px;
  border-radius: 6px;
  transition: outline-offset 0.12s ease;
}

button:focus-visible,
a:focus-visible,
[role="button"]:focus-visible,
[role="tab"]:focus-visible {
  outline: 2px solid hsl(var(--primary));
  outline-offset: 3px;
  box-shadow: 0 0 0 4px hsl(var(--primary) / 0.18);
}

input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 2px solid hsl(var(--primary));
  outline-offset: 0;
  box-shadow: 0 0 0 3px hsl(var(--primary) / 0.22);
}

/* Skip-link — primeiro foco do Tab leva direto pro conteúdo. */

.skip-link {
  position: fixed;
  top: 0.5rem;
  left: 0.5rem;
  z-index: 1000;
  padding: 0.6rem 1rem;
  background: hsl(var(--primary));
  color: hsl(var(--primary-foreground));
  font-weight: 600;
  font-size: 0.875rem;
  border-radius: 10px;
  box-shadow: 0 8px 24px -8px hsl(var(--primary) / 0.5);
  transform: translateY(-150%);
  transition: transform 0.2s var(--ease-out-soft, ease);
}

.skip-link:focus,
.skip-link:focus-visible {
  transform: translateY(0);
  outline: 2px solid hsl(var(--foreground));
  outline-offset: 2px;
}

/* Utilitário visualmente oculto pra leitores de tela. */

.sr-only-focusable:not(:focus):not(:focus-within) {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* Reforço de contraste em texto muted (WCAG AA) */

@media (prefers-contrast: more) {
  :root {
    --muted-foreground: 215 12% 78%;
    --border: 220 13% 32%;
  }
}

/* Forced colors (Windows High Contrast) — preserva semântica */

@media (forced-colors: active) {
  *:focus-visible {
    outline: 2px solid CanvasText;
  }
}

/* ───────────────────────────────────────────────────────────
   Scanner premium — viewfinder, scan-line, detecção, overlay
   ─────────────────────────────────────────────────────────── */

/* Linha de scan animada — percorre toda a altura do viewfinder via top */

@keyframes scan-line {
  0%   { top: 0%;                  opacity: 1; }
  49%  { opacity: 1; }
  50%  { top: calc(100% - 2px);    opacity: 0.7; }
  51%  { opacity: 1; }
  100% { top: 0%;                  opacity: 1; }
}

.scanner-line {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, hsl(var(--primary)) 30%, hsl(var(--primary)) 70%, transparent 100%);
  box-shadow: 0 0 10px 2px rgba(255, 122, 0, 0.6), 0 0 20px 4px rgba(255, 122, 0, 0.25);
  animation: scan-line 2s cubic-bezier(0.45, 0, 0.55, 1) infinite;
  border-radius: 1px;
  pointer-events: none;
  will-change: top, opacity;
}

/* Container do viewfinder — isola layout para não propagar reflow */

.scanner-viewfinder {
  contain: layout;
  position: absolute;
  inset: 0;
}

/* Cantos do viewfinder — gradiente + glow */

.vf-corner {
  position: absolute;
  width: 22px;
  height: 22px;
  pointer-events: none;
}

.vf-corner::before,
.vf-corner::after {
  content: '';
  position: absolute;
  background: hsl(var(--primary));
  border-radius: 2px;
  box-shadow: 0 0 6px hsl(var(--primary) / 0.7);
}

.vf-corner::before { width: 100%; height: 3px; top: 0; left: 0; }

.vf-corner::after  { width: 3px; height: 100%; top: 0; left: 0; }

.vf-corner.tr { top: 0; right: 0; transform: scaleX(-1); }

.vf-corner.bl { bottom: 0; left: 0; transform: scaleY(-1); }

.vf-corner.br { bottom: 0; right: 0; transform: scale(-1); }

/* Pulso do viewfinder ao detectar código */

@keyframes vf-detect-pulse {
  0%   { box-shadow: 0 0 0 0 hsl(var(--success) / 0.7); border-color: hsl(var(--success) / 0.8); }
  50%  { box-shadow: 0 0 0 8px hsl(var(--success) / 0); border-color: hsl(var(--success)); }
  100% { box-shadow: 0 0 0 0 hsl(var(--success) / 0); border-color: hsl(var(--success) / 0.8); }
}

.vf-detected {
  animation: vf-detect-pulse 0.5s ease-out forwards;
  will-change: box-shadow, border-color;
}

/* Pulso âmbar — código não reconhecido */

@keyframes vf-warn-pulse {
  0%   { box-shadow: 0 0 0 0 hsl(var(--warning) / 0.7); border-color: hsl(var(--warning) / 0.8); }
  50%  { box-shadow: 0 0 0 8px hsl(var(--warning) / 0); border-color: hsl(var(--warning)); }
  100% { box-shadow: 0 0 0 0 hsl(var(--warning) / 0); border-color: hsl(var(--warning) / 0.8); }
}

.vf-warn {
  animation: vf-warn-pulse 0.5s ease-out forwards;
  will-change: box-shadow, border-color;
}

/* Zoom-in de entrada do viewfinder */

@keyframes vf-enter {
  from { transform: scale(0.95); opacity: 0.7; }
  to   { transform: scale(1);    opacity: 1; }
}

.vf-enter {
  animation: vf-enter 0.2s var(--ease-out-expo) forwards;
}

/* Overlay de resultado full-screen */

@keyframes result-overlay-in {
  from { opacity: 0; transform: scale(0.96); }
  to   { opacity: 1; transform: scale(1); }
}

.scanner-result-overlay {
  animation: result-overlay-in 0.18s var(--ease-out-expo) forwards;
  will-change: opacity, transform;
}

/* Número grande da parada no overlay */

@keyframes stop-num-pop {
  0%   { transform: scale(0.7); opacity: 0; }
  60%  { transform: scale(1.08); }
  100% { transform: scale(1); opacity: 1; }
}

.stop-num-pop {
  animation: stop-num-pop 0.35s var(--ease-spring) forwards;
  will-change: transform, opacity;
}

/* Check animado */

@keyframes check-draw {
  from { stroke-dashoffset: 40; opacity: 0; }
  to   { stroke-dashoffset: 0;  opacity: 1; }
}

.check-draw {
  stroke-dasharray: 40;
  stroke-dashoffset: 40;
  animation: check-draw 0.3s ease-out 0.15s forwards;
}

@media (prefers-reduced-motion: reduce) {
  .scanner-line { animation: none; top: 50%; transform: none; }
  .vf-enter, .vf-detected, .vf-warn { animation: none; will-change: auto; }
  .scanner-result-overlay, .stop-num-pop, .check-draw { animation: none; will-change: auto; }
}

--ui-scale: 1;

.marker\:text-muted-foreground *::marker{
  color: hsl(var(--muted-foreground));
}

.marker\:text-muted-foreground\/40 *::marker{
  color: hsl(var(--muted-foreground) / 0.4);
}

.marker\:text-muted-foreground::marker{
  color: hsl(var(--muted-foreground));
}

.marker\:text-muted-foreground\/40::marker{
  color: hsl(var(--muted-foreground) / 0.4);
}

.file\:border-0::file-selector-button{
  border-width: 0px;
}

.file\:bg-transparent::file-selector-button{
  background-color: transparent;
}

.file\:text-sm::file-selector-button{
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.file\:font-medium::file-selector-button{
  font-weight: 500;
}

.file\:text-foreground::file-selector-button{
  color: hsl(var(--foreground));
}

.placeholder\:text-muted-foreground::-moz-placeholder{
  color: hsl(var(--muted-foreground));
}

.placeholder\:text-muted-foreground::placeholder{
  color: hsl(var(--muted-foreground));
}

.placeholder\:text-muted-foreground\/25::-moz-placeholder{
  color: hsl(var(--muted-foreground) / 0.25);
}

.placeholder\:text-muted-foreground\/25::placeholder{
  color: hsl(var(--muted-foreground) / 0.25);
}

.placeholder\:text-muted-foreground\/40::-moz-placeholder{
  color: hsl(var(--muted-foreground) / 0.4);
}

.placeholder\:text-muted-foreground\/40::placeholder{
  color: hsl(var(--muted-foreground) / 0.4);
}

.placeholder\:text-muted-foreground\/45::-moz-placeholder{
  color: hsl(var(--muted-foreground) / 0.45);
}

.placeholder\:text-muted-foreground\/45::placeholder{
  color: hsl(var(--muted-foreground) / 0.45);
}

.placeholder\:text-muted-foreground\/50::-moz-placeholder{
  color: hsl(var(--muted-foreground) / 0.5);
}

.placeholder\:text-muted-foreground\/50::placeholder{
  color: hsl(var(--muted-foreground) / 0.5);
}

.placeholder\:text-muted-foreground\/60::-moz-placeholder{
  color: hsl(var(--muted-foreground) / 0.6);
}

.placeholder\:text-muted-foreground\/60::placeholder{
  color: hsl(var(--muted-foreground) / 0.6);
}

.placeholder\:text-neutral-500::-moz-placeholder{
  --tw-text-opacity: 1;
  color: rgb(115 115 115 / var(--tw-text-opacity, 1));
}

.placeholder\:text-neutral-500::placeholder{
  --tw-text-opacity: 1;
  color: rgb(115 115 115 / var(--tw-text-opacity, 1));
}

.after\:absolute::after{
  content: var(--tw-content);
  position: absolute;
}

.after\:-inset-2::after{
  content: var(--tw-content);
  inset: -0.5rem;
}

.after\:inset-y-0::after{
  content: var(--tw-content);
  top: 0px;
  bottom: 0px;
}

.after\:left-1\/2::after{
  content: var(--tw-content);
  left: 50%;
}

.after\:w-1::after{
  content: var(--tw-content);
  width: 0.25rem;
}

.after\:w-\[2px\]::after{
  content: var(--tw-content);
  width: 2px;
}

.after\:-translate-x-1\/2::after{
  content: var(--tw-content);
  --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));
}

.first\:mt-0:first-child{
  margin-top: 0px;
}

.first\:rounded-l-md:first-child{
  border-top-left-radius: calc(var(--radius) - 2px);
  border-bottom-left-radius: calc(var(--radius) - 2px);
}

.first\:border-l:first-child{
  border-left-width: 1px;
}

.first\:pt-0:first-child{
  padding-top: 0px;
}

.last\:mb-0:last-child{
  margin-bottom: 0px;
}

.last\:rounded-r-md:last-child{
  border-top-right-radius: calc(var(--radius) - 2px);
  border-bottom-right-radius: calc(var(--radius) - 2px);
}

.last\:border-0:last-child{
  border-width: 0px;
}

.last\:border-b-0:last-child{
  border-bottom-width: 0px;
}

.last\:border-none:last-child{
  border-style: none;
}

.odd\:bg-background:nth-child(odd){
  background-color: hsl(var(--background));
}

.even\:bg-muted\/20:nth-child(even){
  background-color: hsl(var(--muted) / 0.2);
}

.focus-within\:relative:focus-within{
  position: relative;
}

.focus-within\:z-20:focus-within{
  z-index: 20;
}

.focus-within\:border-primary:focus-within{
  border-color: hsl(var(--primary));
}

.hover\:translate-x-0\.5:hover{
  --tw-translate-x: 0.125rem;
  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\: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\:scale-\[1\.01\]:hover{
  --tw-scale-x: 1.01;
  --tw-scale-y: 1.01;
  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\:scale-\[1\.02\]:hover{
  --tw-scale-x: 1.02;
  --tw-scale-y: 1.02;
  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\:border-border:hover{
  border-color: hsl(var(--border));
}

.hover\:border-border\/30:hover{
  border-color: hsl(var(--border) / 0.3);
}

.hover\:border-border\/40:hover{
  border-color: hsl(var(--border) / 0.4);
}

.hover\:border-border\/50:hover{
  border-color: hsl(var(--border) / 0.5);
}

.hover\:border-border\/70:hover{
  border-color: hsl(var(--border) / 0.7);
}

.hover\:border-border\/80:hover{
  border-color: hsl(var(--border) / 0.8);
}

.hover\:border-destructive\/30:hover{
  border-color: hsl(var(--destructive) / 0.3);
}

.hover\:border-info\/30:hover{
  border-color: hsl(var(--info) / 0.3);
}

.hover\:border-info\/60:hover{
  border-color: hsl(var(--info) / 0.6);
}

.hover\:border-primary:hover{
  border-color: hsl(var(--primary));
}

.hover\:border-primary\/20:hover{
  border-color: hsl(var(--primary) / 0.2);
}

.hover\:border-primary\/30:hover{
  border-color: hsl(var(--primary) / 0.3);
}

.hover\:border-primary\/40:hover{
  border-color: hsl(var(--primary) / 0.4);
}

.hover\:border-primary\/45:hover{
  border-color: hsl(var(--primary) / 0.45);
}

.hover\:border-primary\/50:hover{
  border-color: hsl(var(--primary) / 0.5);
}

.hover\:border-success\/60:hover{
  border-color: hsl(var(--success) / 0.6);
}

.hover\:border-warning\/60:hover{
  border-color: hsl(var(--warning) / 0.6);
}

.hover\:bg-\[\#1fbd5a\]:hover{
  --tw-bg-opacity: 1;
  background-color: rgb(31 189 90 / var(--tw-bg-opacity, 1));
}

.hover\:bg-\[\#25D366\]\/15:hover{
  background-color: rgb(37 211 102 / 0.15);
}

.hover\:bg-\[\#25D366\]\/20:hover{
  background-color: rgb(37 211 102 / 0.2);
}

.hover\:bg-accent:hover{
  background-color: hsl(var(--accent));
}

.hover\:bg-accent\/20:hover{
  background-color: hsl(var(--accent) / 0.2);
}

.hover\:bg-amber-400:hover{
  --tw-bg-opacity: 1;
  background-color: rgb(251 191 36 / var(--tw-bg-opacity, 1));
}

.hover\:bg-background:hover{
  background-color: hsl(var(--background));
}

.hover\:bg-background\/20:hover{
  background-color: hsl(var(--background) / 0.2);
}

.hover\:bg-background\/60:hover{
  background-color: hsl(var(--background) / 0.6);
}

.hover\:bg-background\/70:hover{
  background-color: hsl(var(--background) / 0.7);
}

.hover\:bg-background\/90:hover{
  background-color: hsl(var(--background) / 0.9);
}

.hover\:bg-border:hover{
  background-color: hsl(var(--border));
}

.hover\:bg-card:hover{
  background-color: hsl(var(--card));
}

.hover\:bg-card\/70:hover{
  background-color: hsl(var(--card) / 0.7);
}

.hover\:bg-card\/80:hover{
  background-color: hsl(var(--card) / 0.8);
}

.hover\:bg-destructive\/10:hover{
  background-color: hsl(var(--destructive) / 0.1);
}

.hover\:bg-destructive\/15:hover{
  background-color: hsl(var(--destructive) / 0.15);
}

.hover\:bg-destructive\/20:hover{
  background-color: hsl(var(--destructive) / 0.2);
}

.hover\:bg-destructive\/25:hover{
  background-color: hsl(var(--destructive) / 0.25);
}

.hover\:bg-destructive\/30:hover{
  background-color: hsl(var(--destructive) / 0.3);
}

.hover\:bg-destructive\/90:hover{
  background-color: hsl(var(--destructive) / 0.9);
}

.hover\:bg-destructive\/\[0\.12\]:hover{
  background-color: hsl(var(--destructive) / 0.12);
}

.hover\:bg-destructive\/\[0\.14\]:hover{
  background-color: hsl(var(--destructive) / 0.14);
}

.hover\:bg-foreground\/10:hover{
  background-color: hsl(var(--foreground) / 0.1);
}

.hover\:bg-foreground\/5:hover{
  background-color: hsl(var(--foreground) / 0.05);
}

.hover\:bg-foreground\/90:hover{
  background-color: hsl(var(--foreground) / 0.9);
}

.hover\:bg-foreground\/\[0\.04\]:hover{
  background-color: hsl(var(--foreground) / 0.04);
}

.hover\:bg-foreground\/\[0\.05\]:hover{
  background-color: hsl(var(--foreground) / 0.05);
}

.hover\:bg-foreground\/\[0\.06\]:hover{
  background-color: hsl(var(--foreground) / 0.06);
}

.hover\:bg-foreground\/\[0\.08\]:hover{
  background-color: hsl(var(--foreground) / 0.08);
}

.hover\:bg-foreground\/\[0\.09\]:hover{
  background-color: hsl(var(--foreground) / 0.09);
}

.hover\:bg-foreground\/\[0\.12\]:hover{
  background-color: hsl(var(--foreground) / 0.12);
}

.hover\:bg-green-500\/25:hover{
  background-color: rgb(34 197 94 / 0.25);
}

.hover\:bg-info\/10:hover{
  background-color: hsl(var(--info) / 0.1);
}

.hover\:bg-info\/20:hover{
  background-color: hsl(var(--info) / 0.2);
}

.hover\:bg-info\/25:hover{
  background-color: hsl(var(--info) / 0.25);
}

.hover\:bg-info\/30:hover{
  background-color: hsl(var(--info) / 0.3);
}

.hover\:bg-info\/90:hover{
  background-color: hsl(var(--info) / 0.9);
}

.hover\:bg-info\/\[0\.10\]:hover{
  background-color: hsl(var(--info) / 0.10);
}

.hover\:bg-info\/\[0\.14\]:hover{
  background-color: hsl(var(--info) / 0.14);
}

.hover\:bg-muted:hover{
  background-color: hsl(var(--muted));
}

.hover\:bg-muted\/10:hover{
  background-color: hsl(var(--muted) / 0.1);
}

.hover\:bg-muted\/15:hover{
  background-color: hsl(var(--muted) / 0.15);
}

.hover\:bg-muted\/20:hover{
  background-color: hsl(var(--muted) / 0.2);
}

.hover\:bg-muted\/30:hover{
  background-color: hsl(var(--muted) / 0.3);
}

.hover\:bg-muted\/40:hover{
  background-color: hsl(var(--muted) / 0.4);
}

.hover\:bg-muted\/50:hover{
  background-color: hsl(var(--muted) / 0.5);
}

.hover\:bg-muted\/60:hover{
  background-color: hsl(var(--muted) / 0.6);
}

.hover\:bg-muted\/70:hover{
  background-color: hsl(var(--muted) / 0.7);
}

.hover\:bg-muted\/80:hover{
  background-color: hsl(var(--muted) / 0.8);
}

.hover\:bg-neutral-950\/\[0\.04\]:hover{
  background-color: rgb(10 10 10 / 0.04);
}

.hover\:bg-orange-100:hover{
  --tw-bg-opacity: 1;
  background-color: rgb(255 237 213 / var(--tw-bg-opacity, 1));
}

.hover\:bg-orange-50:hover{
  --tw-bg-opacity: 1;
  background-color: rgb(255 247 237 / var(--tw-bg-opacity, 1));
}

.hover\:bg-orange-700:hover{
  --tw-bg-opacity: 1;
  background-color: rgb(194 65 12 / var(--tw-bg-opacity, 1));
}

.hover\:bg-primary:hover{
  background-color: hsl(var(--primary));
}

.hover\:bg-primary-foreground\/15:hover{
  background-color: hsl(var(--primary-foreground) / 0.15);
}

.hover\:bg-primary-foreground\/20:hover{
  background-color: hsl(var(--primary-foreground) / 0.2);
}

.hover\:bg-primary-foreground\/30:hover{
  background-color: hsl(var(--primary-foreground) / 0.3);
}

.hover\:bg-primary-foreground\/95:hover{
  background-color: hsl(var(--primary-foreground) / 0.95);
}

.hover\:bg-primary\/10:hover{
  background-color: hsl(var(--primary) / 0.1);
}

.hover\:bg-primary\/15:hover{
  background-color: hsl(var(--primary) / 0.15);
}

.hover\:bg-primary\/20:hover{
  background-color: hsl(var(--primary) / 0.2);
}

.hover\:bg-primary\/25:hover{
  background-color: hsl(var(--primary) / 0.25);
}

.hover\:bg-primary\/30:hover{
  background-color: hsl(var(--primary) / 0.3);
}

.hover\:bg-primary\/5:hover{
  background-color: hsl(var(--primary) / 0.05);
}

.hover\:bg-primary\/90:hover{
  background-color: hsl(var(--primary) / 0.9);
}

.hover\:bg-primary\/\[0\.09\]:hover{
  background-color: hsl(var(--primary) / 0.09);
}

.hover\:bg-primary\/\[0\.12\]:hover{
  background-color: hsl(var(--primary) / 0.12);
}

.hover\:bg-primary\/\[0\.14\]:hover{
  background-color: hsl(var(--primary) / 0.14);
}

.hover\:bg-primary\/\[0\.18\]:hover{
  background-color: hsl(var(--primary) / 0.18);
}

.hover\:bg-purple\/15:hover{
  background-color: hsl(var(--purple) / 0.15);
}

.hover\:bg-red-700:hover{
  --tw-bg-opacity: 1;
  background-color: rgb(185 28 28 / var(--tw-bg-opacity, 1));
}

.hover\:bg-red-800:hover{
  --tw-bg-opacity: 1;
  background-color: rgb(153 27 27 / var(--tw-bg-opacity, 1));
}

.hover\:bg-secondary:hover{
  background-color: hsl(var(--secondary));
}

.hover\:bg-secondary\/20:hover{
  background-color: hsl(var(--secondary) / 0.2);
}

.hover\:bg-secondary\/30:hover{
  background-color: hsl(var(--secondary) / 0.3);
}

.hover\:bg-secondary\/35:hover{
  background-color: hsl(var(--secondary) / 0.35);
}

.hover\:bg-secondary\/40:hover{
  background-color: hsl(var(--secondary) / 0.4);
}

.hover\:bg-secondary\/45:hover{
  background-color: hsl(var(--secondary) / 0.45);
}

.hover\:bg-secondary\/50:hover{
  background-color: hsl(var(--secondary) / 0.5);
}

.hover\:bg-secondary\/55:hover{
  background-color: hsl(var(--secondary) / 0.55);
}

.hover\:bg-secondary\/60:hover{
  background-color: hsl(var(--secondary) / 0.6);
}

.hover\:bg-secondary\/70:hover{
  background-color: hsl(var(--secondary) / 0.7);
}

.hover\:bg-secondary\/80:hover{
  background-color: hsl(var(--secondary) / 0.8);
}

.hover\:bg-sidebar-accent:hover{
  background-color: hsl(var(--sidebar-accent));
}

.hover\:bg-success\/10:hover{
  background-color: hsl(var(--success) / 0.1);
}

.hover\:bg-success\/15:hover{
  background-color: hsl(var(--success) / 0.15);
}

.hover\:bg-success\/20:hover{
  background-color: hsl(var(--success) / 0.2);
}

.hover\:bg-success\/25:hover{
  background-color: hsl(var(--success) / 0.25);
}

.hover\:bg-success\/90:hover{
  background-color: hsl(var(--success) / 0.9);
}

.hover\:bg-success\/\[0\.14\]:hover{
  background-color: hsl(var(--success) / 0.14);
}

.hover\:bg-transparent:hover{
  background-color: transparent;
}

.hover\:bg-warning:hover{
  background-color: hsl(var(--warning));
}

.hover\:bg-warning-foreground\/25:hover{
  background-color: hsl(var(--warning-foreground) / 0.25);
}

.hover\:bg-warning\/10:hover{
  background-color: hsl(var(--warning) / 0.1);
}

.hover\:bg-warning\/15:hover{
  background-color: hsl(var(--warning) / 0.15);
}

.hover\:bg-warning\/20:hover{
  background-color: hsl(var(--warning) / 0.2);
}

.hover\:bg-warning\/25:hover{
  background-color: hsl(var(--warning) / 0.25);
}

.hover\:bg-warning\/30:hover{
  background-color: hsl(var(--warning) / 0.3);
}

.hover\:bg-warning\/\[0\.09\]:hover{
  background-color: hsl(var(--warning) / 0.09);
}

.hover\:bg-warning\/\[0\.14\]:hover{
  background-color: hsl(var(--warning) / 0.14);
}

.hover\:bg-white\/10:hover{
  background-color: rgb(255 255 255 / 0.1);
}

.hover\:bg-white\/\[0\.06\]:hover{
  background-color: rgb(255 255 255 / 0.06);
}

.hover\:from-background\/60:hover{
  --tw-gradient-from: hsl(var(--background) / 0.6) var(--tw-gradient-from-position);
  --tw-gradient-to: hsl(var(--background) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.hover\:from-green-700:hover{
  --tw-gradient-from: #15803d var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(21 128 61 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.hover\:to-background\/60:hover{
  --tw-gradient-to: hsl(var(--background) / 0.6) var(--tw-gradient-to-position);
}

.hover\:to-green-600:hover{
  --tw-gradient-to: #16a34a var(--tw-gradient-to-position);
}

.hover\:text-accent-foreground:hover{
  color: hsl(var(--accent-foreground));
}

.hover\:text-destructive:hover{
  color: hsl(var(--destructive));
}

.hover\:text-destructive\/80:hover{
  color: hsl(var(--destructive) / 0.8);
}

.hover\:text-foreground:hover{
  color: hsl(var(--foreground));
}

.hover\:text-foreground\/60:hover{
  color: hsl(var(--foreground) / 0.6);
}

.hover\:text-foreground\/80:hover{
  color: hsl(var(--foreground) / 0.8);
}

.hover\:text-foreground\/90:hover{
  color: hsl(var(--foreground) / 0.9);
}

.hover\:text-info:hover{
  color: hsl(var(--info));
}

.hover\:text-muted-foreground:hover{
  color: hsl(var(--muted-foreground));
}

.hover\:text-muted-foreground\/60:hover{
  color: hsl(var(--muted-foreground) / 0.6);
}

.hover\:text-primary:hover{
  color: hsl(var(--primary));
}

.hover\:text-primary-foreground:hover{
  color: hsl(var(--primary-foreground));
}

.hover\:text-primary\/50:hover{
  color: hsl(var(--primary) / 0.5);
}

.hover\:text-primary\/70:hover{
  color: hsl(var(--primary) / 0.7);
}

.hover\:text-primary\/80:hover{
  color: hsl(var(--primary) / 0.8);
}

.hover\:text-purple:hover{
  color: hsl(var(--purple));
}

.hover\:text-purple\/80:hover{
  color: hsl(var(--purple) / 0.8);
}

.hover\:text-sidebar-accent-foreground:hover{
  color: hsl(var(--sidebar-accent-foreground));
}

.hover\:text-success:hover{
  color: hsl(var(--success));
}

.hover\:text-warning:hover{
  color: hsl(var(--warning));
}

.hover\:text-warning\/80:hover{
  color: hsl(var(--warning) / 0.8);
}

.hover\:text-white:hover{
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.hover\:underline:hover{
  text-decoration-line: underline;
}

.hover\:no-underline:hover{
  text-decoration-line: none;
}

.hover\:opacity-100:hover{
  opacity: 1;
}

.hover\:opacity-80:hover{
  opacity: 0.8;
}

.hover\:opacity-90:hover{
  opacity: 0.9;
}

.hover\:shadow-\[0_0_0_1px_hsl\(var\(--sidebar-accent\)\)\]:hover{
  --tw-shadow: 0 0 0 1px hsl(var(--sidebar-accent));
  --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);
}

.hover\:shadow-lg:hover{
  --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);
}

.hover\: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\: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);
}

.hover\:ring-1:hover{
  --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);
}

.hover\:ring-2:hover{
  --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);
}

.hover\:ring-destructive\/40:hover{
  --tw-ring-color: hsl(var(--destructive) / 0.4);
}

.hover\:ring-info\/40:hover{
  --tw-ring-color: hsl(var(--info) / 0.4);
}

.hover\:ring-primary\/30:hover{
  --tw-ring-color: hsl(var(--primary) / 0.3);
}

.hover\:ring-primary\/40:hover{
  --tw-ring-color: hsl(var(--primary) / 0.4);
}

.hover\:ring-primary\/50:hover{
  --tw-ring-color: hsl(var(--primary) / 0.5);
}

.hover\:ring-purple\/40:hover{
  --tw-ring-color: hsl(var(--purple) / 0.4);
}

.hover\:ring-success\/40:hover{
  --tw-ring-color: hsl(var(--success) / 0.4);
}

.hover\:brightness-110:hover{
  --tw-brightness: brightness(1.1);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.hover\:after\:bg-sidebar-border:hover::after{
  content: var(--tw-content);
  background-color: hsl(var(--sidebar-border));
}

.focus\:border-amber-500\/50:focus{
  border-color: rgb(245 158 11 / 0.5);
}

.focus\:border-destructive:focus{
  border-color: hsl(var(--destructive));
}

.focus\:border-destructive\/60:focus{
  border-color: hsl(var(--destructive) / 0.6);
}

.focus\:border-info\/50:focus{
  border-color: hsl(var(--info) / 0.5);
}

.focus\:border-primary:focus{
  border-color: hsl(var(--primary));
}

.focus\:border-primary\/30:focus{
  border-color: hsl(var(--primary) / 0.3);
}

.focus\:border-primary\/40:focus{
  border-color: hsl(var(--primary) / 0.4);
}

.focus\:border-primary\/45:focus{
  border-color: hsl(var(--primary) / 0.45);
}

.focus\:border-primary\/50:focus{
  border-color: hsl(var(--primary) / 0.5);
}

.focus\:bg-accent:focus{
  background-color: hsl(var(--accent));
}

.focus\:bg-primary:focus{
  background-color: hsl(var(--primary));
}

.focus\:text-accent-foreground:focus{
  color: hsl(var(--accent-foreground));
}

.focus\:text-primary-foreground:focus{
  color: hsl(var(--primary-foreground));
}

.focus\:opacity-100:focus{
  opacity: 1;
}

.focus\:outline-none:focus{
  outline: 2px solid transparent;
  outline-offset: 2px;
}

.focus\:ring-1: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(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);
}

.focus\: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\:ring-primary:focus{
  --tw-ring-color: hsl(var(--primary));
}

.focus\:ring-primary\/30:focus{
  --tw-ring-color: hsl(var(--primary) / 0.3);
}

.focus\:ring-primary\/40:focus{
  --tw-ring-color: hsl(var(--primary) / 0.4);
}

.focus\:ring-ring:focus{
  --tw-ring-color: hsl(var(--ring));
}

.focus\:ring-offset-2:focus{
  --tw-ring-offset-width: 2px;
}

.focus\:shadow-input-focus:focus {
    box-shadow:
      0 0 0 3px hsl(26 100% 54% / 0.18),
      0 0 0 0.5px hsl(26 100% 54% / 0.4) inset,
      0 1px 2px hsl(0 0% 0% / 0.3);
  }

.focus-visible\:bg-primary\/5:focus-visible{
  background-color: hsl(var(--primary) / 0.05);
}

.focus-visible\:outline-none:focus-visible{
  outline: 2px solid transparent;
  outline-offset: 2px;
}

.focus-visible\:ring-0: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(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-visible\:ring-1: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(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);
}

.focus-visible\: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\:ring-primary\/35:focus-visible{
  --tw-ring-color: hsl(var(--primary) / 0.35);
}

.focus-visible\:ring-primary\/40:focus-visible{
  --tw-ring-color: hsl(var(--primary) / 0.4);
}

.focus-visible\:ring-primary\/50:focus-visible{
  --tw-ring-color: hsl(var(--primary) / 0.5);
}

.focus-visible\:ring-primary\/60:focus-visible{
  --tw-ring-color: hsl(var(--primary) / 0.6);
}

.focus-visible\:ring-ring:focus-visible{
  --tw-ring-color: hsl(var(--ring));
}

.focus-visible\:ring-sidebar-ring:focus-visible{
  --tw-ring-color: hsl(var(--sidebar-ring));
}

.focus-visible\:ring-offset-0:focus-visible{
  --tw-ring-offset-width: 0px;
}

.focus-visible\:ring-offset-1:focus-visible{
  --tw-ring-offset-width: 1px;
}

.focus-visible\:ring-offset-2:focus-visible{
  --tw-ring-offset-width: 2px;
}

.focus-visible\:ring-offset-background:focus-visible{
  --tw-ring-offset-color: hsl(var(--background));
}

.active\:scale-90:active{
  --tw-scale-x: .9;
  --tw-scale-y: .9;
  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));
}

.active\:scale-95:active{
  --tw-scale-x: .95;
  --tw-scale-y: .95;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.active\:scale-\[0\.92\]:active{
  --tw-scale-x: 0.92;
  --tw-scale-y: 0.92;
  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));
}

.active\:scale-\[0\.97\]:active{
  --tw-scale-x: 0.97;
  --tw-scale-y: 0.97;
  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));
}

.active\:scale-\[0\.98\]:active{
  --tw-scale-x: 0.98;
  --tw-scale-y: 0.98;
  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));
}

.active\:scale-\[0\.995\]:active{
  --tw-scale-x: 0.995;
  --tw-scale-y: 0.995;
  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));
}

.active\:scale-\[0\.998\]:active{
  --tw-scale-x: 0.998;
  --tw-scale-y: 0.998;
  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));
}

.active\:scale-\[0\.99\]:active{
  --tw-scale-x: 0.99;
  --tw-scale-y: 0.99;
  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));
}

.active\:cursor-grabbing:active{
  cursor: grabbing;
}

.active\:bg-accent\/80:active{
  background-color: hsl(var(--accent) / 0.8);
}

.active\:bg-background\/80:active{
  background-color: hsl(var(--background) / 0.8);
}

.active\:bg-destructive\/20:active{
  background-color: hsl(var(--destructive) / 0.2);
}

.active\:bg-destructive\/30:active{
  background-color: hsl(var(--destructive) / 0.3);
}

.active\:bg-destructive\/\[0\.16\]:active{
  background-color: hsl(var(--destructive) / 0.16);
}

.active\:bg-info\/20:active{
  background-color: hsl(var(--info) / 0.2);
}

.active\:bg-info\/35:active{
  background-color: hsl(var(--info) / 0.35);
}

.active\:bg-info\/40:active{
  background-color: hsl(var(--info) / 0.4);
}

.active\:bg-info\/80:active{
  background-color: hsl(var(--info) / 0.8);
}

.active\:bg-muted\/60:active{
  background-color: hsl(var(--muted) / 0.6);
}

.active\:bg-muted\/80:active{
  background-color: hsl(var(--muted) / 0.8);
}

.active\:bg-neutral-100\/80:active{
  background-color: rgb(245 245 245 / 0.8);
}

.active\:bg-primary-foreground\/25:active{
  background-color: hsl(var(--primary-foreground) / 0.25);
}

.active\:bg-primary\/20:active{
  background-color: hsl(var(--primary) / 0.2);
}

.active\:bg-primary\/30:active{
  background-color: hsl(var(--primary) / 0.3);
}

.active\:bg-primary\/5:active{
  background-color: hsl(var(--primary) / 0.05);
}

.active\:bg-primary\/80:active{
  background-color: hsl(var(--primary) / 0.8);
}

.active\:bg-primary\/90:active{
  background-color: hsl(var(--primary) / 0.9);
}

.active\:bg-primary\/95:active{
  background-color: hsl(var(--primary) / 0.95);
}

.active\:bg-primary\/\[0\.22\]:active{
  background-color: hsl(var(--primary) / 0.22);
}

.active\:bg-secondary:active{
  background-color: hsl(var(--secondary));
}

.active\:bg-secondary\/30:active{
  background-color: hsl(var(--secondary) / 0.3);
}

.active\:bg-secondary\/40:active{
  background-color: hsl(var(--secondary) / 0.4);
}

.active\:bg-secondary\/60:active{
  background-color: hsl(var(--secondary) / 0.6);
}

.active\:bg-secondary\/70:active{
  background-color: hsl(var(--secondary) / 0.7);
}

.active\:bg-secondary\/80:active{
  background-color: hsl(var(--secondary) / 0.8);
}

.active\:bg-sidebar-accent:active{
  background-color: hsl(var(--sidebar-accent));
}

.active\:bg-success\/80:active{
  background-color: hsl(var(--success) / 0.8);
}

.active\:bg-white\/10:active{
  background-color: rgb(255 255 255 / 0.1);
}

.active\:text-sidebar-accent-foreground:active{
  color: hsl(var(--sidebar-accent-foreground));
}

.disabled\:pointer-events-none:disabled{
  pointer-events: none;
}

.disabled\:cursor-default:disabled{
  cursor: default;
}

.disabled\:cursor-not-allowed:disabled{
  cursor: not-allowed;
}

.disabled\:cursor-wait:disabled{
  cursor: wait;
}

.disabled\:bg-muted:disabled{
  background-color: hsl(var(--muted));
}

.disabled\:text-muted-foreground:disabled{
  color: hsl(var(--muted-foreground));
}

.disabled\:opacity-20:disabled{
  opacity: 0.2;
}

.disabled\:opacity-30:disabled{
  opacity: 0.3;
}

.disabled\:opacity-35:disabled{
  opacity: 0.35;
}

.disabled\:opacity-40:disabled{
  opacity: 0.4;
}

.disabled\:opacity-45:disabled{
  opacity: 0.45;
}

.disabled\:opacity-50:disabled{
  opacity: 0.5;
}

.disabled\:opacity-55:disabled{
  opacity: 0.55;
}

.disabled\:opacity-60:disabled{
  opacity: 0.6;
}

.disabled\:opacity-70:disabled{
  opacity: 0.7;
}

.disabled\:shadow-none:disabled{
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.group[open] .group-open\: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));
}

.group\/menu-item:focus-within .group-focus-within\/menu-item\:opacity-100{
  opacity: 1;
}

.group:hover .group-hover\:block{
  display: block;
}

.group:hover .group-hover\:translate-x-0\.5{
  --tw-translate-x: 0.125rem;
  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));
}

.group:hover .group-hover\:translate-y-0\.5{
  --tw-translate-y: 0.125rem;
  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));
}

.group:hover .group-hover\: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));
}

.group:hover .group-hover\:text-foreground{
  color: hsl(var(--foreground));
}

.group:hover .group-hover\:text-info{
  color: hsl(var(--info));
}

.group:hover .group-hover\:text-muted-foreground{
  color: hsl(var(--muted-foreground));
}

.group:hover .group-hover\:text-primary{
  color: hsl(var(--primary));
}

.group\/menu-item:hover .group-hover\/menu-item\:opacity-100{
  opacity: 1;
}

.group:hover .group-hover\:opacity-100{
  opacity: 1;
}

.group.destructive .group-\[\.destructive\]\:border-muted\/40{
  border-color: hsl(var(--muted) / 0.4);
}

.group.toaster .group-\[\.toaster\]\:border-border{
  border-color: hsl(var(--border));
}

.group.toast .group-\[\.toast\]\:bg-muted{
  background-color: hsl(var(--muted));
}

.group.toast .group-\[\.toast\]\:bg-primary{
  background-color: hsl(var(--primary));
}

.group.toaster .group-\[\.toaster\]\:bg-background{
  background-color: hsl(var(--background));
}

.group.destructive .group-\[\.destructive\]\:text-red-300{
  --tw-text-opacity: 1;
  color: rgb(252 165 165 / var(--tw-text-opacity, 1));
}

.group.toast .group-\[\.toast\]\:text-muted-foreground{
  color: hsl(var(--muted-foreground));
}

.group.toast .group-\[\.toast\]\:text-primary-foreground{
  color: hsl(var(--primary-foreground));
}

.group.toaster .group-\[\.toaster\]\:text-foreground{
  color: hsl(var(--foreground));
}

.group.toaster .group-\[\.toaster\]\: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);
}

.group.destructive .group-\[\.destructive\]\:hover\:border-destructive\/30:hover{
  border-color: hsl(var(--destructive) / 0.3);
}

.group.destructive .group-\[\.destructive\]\:hover\:bg-destructive:hover{
  background-color: hsl(var(--destructive));
}

.group.destructive .group-\[\.destructive\]\:hover\:text-destructive-foreground:hover{
  color: hsl(var(--destructive-foreground));
}

.group.destructive .group-\[\.destructive\]\:hover\:text-red-50:hover{
  --tw-text-opacity: 1;
  color: rgb(254 242 242 / var(--tw-text-opacity, 1));
}

.group.destructive .group-\[\.destructive\]\:focus\:ring-destructive:focus{
  --tw-ring-color: hsl(var(--destructive));
}

.group.destructive .group-\[\.destructive\]\:focus\:ring-red-400:focus{
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(248 113 113 / var(--tw-ring-opacity, 1));
}

.group.destructive .group-\[\.destructive\]\:focus\:ring-offset-red-600:focus{
  --tw-ring-offset-color: #dc2626;
}

.peer\/menu-button:hover ~ .peer-hover\/menu-button\:text-sidebar-accent-foreground{
  color: hsl(var(--sidebar-accent-foreground));
}

.peer:disabled ~ .peer-disabled\:cursor-not-allowed{
  cursor: not-allowed;
}

.peer:disabled ~ .peer-disabled\:opacity-70{
  opacity: 0.7;
}

.has-\[\[data-variant\=inset\]\]\:bg-sidebar:has([data-variant=inset]){
  background-color: hsl(var(--sidebar-background));
}

.has-\[\:disabled\]\:opacity-50:has(:disabled){
  opacity: 0.5;
}

.group\/menu-item:has([data-sidebar=menu-action]) .group-has-\[\[data-sidebar\=menu-action\]\]\/menu-item\:pr-8{
  padding-right: 2rem;
}

.aria-disabled\:pointer-events-none[aria-disabled="true"]{
  pointer-events: none;
}

.aria-disabled\:opacity-50[aria-disabled="true"]{
  opacity: 0.5;
}

.aria-selected\:bg-accent[aria-selected="true"]{
  background-color: hsl(var(--accent));
}

.aria-selected\:bg-accent\/50[aria-selected="true"]{
  background-color: hsl(var(--accent) / 0.5);
}

.aria-selected\:text-accent-foreground[aria-selected="true"]{
  color: hsl(var(--accent-foreground));
}

.aria-selected\:text-muted-foreground[aria-selected="true"]{
  color: hsl(var(--muted-foreground));
}

.aria-selected\:opacity-100[aria-selected="true"]{
  opacity: 1;
}

.aria-selected\:opacity-30[aria-selected="true"]{
  opacity: 0.3;
}

.data-\[disabled\=true\]\:pointer-events-none[data-disabled="true"]{
  pointer-events: none;
}

.data-\[disabled\]\:pointer-events-none[data-disabled]{
  pointer-events: none;
}

.data-\[panel-group-direction\=vertical\]\:h-px[data-panel-group-direction="vertical"]{
  height: 1px;
}

.data-\[panel-group-direction\=vertical\]\:w-full[data-panel-group-direction="vertical"]{
  width: 100%;
}

.data-\[side\=bottom\]\:translate-y-1[data-side="bottom"]{
  --tw-translate-y: 0.25rem;
  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));
}

.data-\[side\=left\]\:-translate-x-1[data-side="left"]{
  --tw-translate-x: -0.25rem;
  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));
}

.data-\[side\=right\]\:translate-x-1[data-side="right"]{
  --tw-translate-x: 0.25rem;
  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));
}

.data-\[side\=top\]\:-translate-y-1[data-side="top"]{
  --tw-translate-y: -0.25rem;
  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));
}

.data-\[state\=checked\]\:translate-x-5[data-state="checked"]{
  --tw-translate-x: 1.25rem;
  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));
}

.data-\[state\=unchecked\]\:translate-x-0[data-state="unchecked"]{
  --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));
}

.data-\[swipe\=cancel\]\:translate-x-0[data-swipe="cancel"]{
  --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));
}

.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe="end"]{
  --tw-translate-x: var(--radix-toast-swipe-end-x);
  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));
}

.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe="move"]{
  --tw-translate-x: var(--radix-toast-swipe-move-x);
  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 accordion-up{

  from{
    height: var(--radix-accordion-content-height);
  }

  to{
    height: 0;
  }
}

.data-\[state\=closed\]\:animate-accordion-up[data-state="closed"]{
  animation: accordion-up 0.2s ease-out;
}

@keyframes accordion-down{

  from{
    height: 0;
  }

  to{
    height: var(--radix-accordion-content-height);
  }
}

.data-\[state\=open\]\:animate-accordion-down[data-state="open"]{
  animation: accordion-down 0.2s ease-out;
}

.data-\[panel-group-direction\=vertical\]\:flex-col[data-panel-group-direction="vertical"]{
  flex-direction: column;
}

.data-\[selected\=true\]\:border-info\/40[data-selected="true"]{
  border-color: hsl(var(--info) / 0.4);
}

.data-\[selected\=true\]\:border-primary\/40[data-selected="true"]{
  border-color: hsl(var(--primary) / 0.4);
}

.data-\[selected\=true\]\:border-purple\/40[data-selected="true"]{
  border-color: hsl(var(--purple) / 0.4);
}

.data-\[active\=true\]\:bg-sidebar-accent[data-active="true"]{
  background-color: hsl(var(--sidebar-accent));
}

.data-\[active\]\:bg-accent\/50[data-active]{
  background-color: hsl(var(--accent) / 0.5);
}

.data-\[selected\=\'true\'\]\:bg-accent[data-selected='true']{
  background-color: hsl(var(--accent));
}

.data-\[selected\=true\]\:bg-info\/15[data-selected="true"]{
  background-color: hsl(var(--info) / 0.15);
}

.data-\[selected\=true\]\:bg-primary\/15[data-selected="true"]{
  background-color: hsl(var(--primary) / 0.15);
}

.data-\[selected\=true\]\:bg-purple\/15[data-selected="true"]{
  background-color: hsl(var(--purple) / 0.15);
}

.data-\[state\=active\]\:bg-background[data-state="active"]{
  background-color: hsl(var(--background));
}

.data-\[state\=active\]\:bg-primary[data-state="active"]{
  background-color: hsl(var(--primary));
}

.data-\[state\=checked\]\:bg-primary[data-state="checked"]{
  background-color: hsl(var(--primary));
}

.data-\[state\=on\]\:bg-accent[data-state="on"]{
  background-color: hsl(var(--accent));
}

.data-\[state\=open\]\:bg-accent[data-state="open"]{
  background-color: hsl(var(--accent));
}

.data-\[state\=open\]\:bg-accent\/50[data-state="open"]{
  background-color: hsl(var(--accent) / 0.5);
}

.data-\[state\=selected\]\:bg-muted[data-state="selected"]{
  background-color: hsl(var(--muted));
}

.data-\[state\=unchecked\]\:bg-input[data-state="unchecked"]{
  background-color: hsl(var(--input));
}

.data-\[active\=true\]\:font-medium[data-active="true"]{
  font-weight: 500;
}

.data-\[active\=true\]\:text-sidebar-accent-foreground[data-active="true"]{
  color: hsl(var(--sidebar-accent-foreground));
}

.data-\[selected\=true\]\:text-accent-foreground[data-selected="true"]{
  color: hsl(var(--accent-foreground));
}

.data-\[selected\=true\]\:text-info[data-selected="true"]{
  color: hsl(var(--info));
}

.data-\[selected\=true\]\:text-primary[data-selected="true"]{
  color: hsl(var(--primary));
}

.data-\[selected\=true\]\:text-purple[data-selected="true"]{
  color: hsl(var(--purple));
}

.data-\[state\=active\]\:text-foreground[data-state="active"]{
  color: hsl(var(--foreground));
}

.data-\[state\=active\]\:text-primary-foreground[data-state="active"]{
  color: hsl(var(--primary-foreground));
}

.data-\[state\=checked\]\:text-primary-foreground[data-state="checked"]{
  color: hsl(var(--primary-foreground));
}

.data-\[state\=on\]\:text-accent-foreground[data-state="on"]{
  color: hsl(var(--accent-foreground));
}

.data-\[state\=open\]\:text-accent-foreground[data-state="open"]{
  color: hsl(var(--accent-foreground));
}

.data-\[disabled\=true\]\:opacity-50[data-disabled="true"]{
  opacity: 0.5;
}

.data-\[disabled\]\:opacity-50[data-disabled]{
  opacity: 0.5;
}

.data-\[state\=open\]\:opacity-100[data-state="open"]{
  opacity: 1;
}

.data-\[state\=active\]\:shadow-sm[data-state="active"]{
  --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);
}

.data-\[swipe\=move\]\:transition-none[data-swipe="move"]{
  transition-property: none;
}

.data-\[state\=closed\]\:duration-300[data-state="closed"]{
  transition-duration: 300ms;
}

.data-\[state\=open\]\:duration-500[data-state="open"]{
  transition-duration: 500ms;
}

.data-\[motion\^\=from-\]\:animate-in[data-motion^="from-"]{
  animation-name: enter;
  animation-duration: 150ms;
  --tw-enter-opacity: initial;
  --tw-enter-scale: initial;
  --tw-enter-rotate: initial;
  --tw-enter-translate-x: initial;
  --tw-enter-translate-y: initial;
}

.data-\[state\=open\]\:animate-in[data-state="open"]{
  animation-name: enter;
  animation-duration: 150ms;
  --tw-enter-opacity: initial;
  --tw-enter-scale: initial;
  --tw-enter-rotate: initial;
  --tw-enter-translate-x: initial;
  --tw-enter-translate-y: initial;
}

.data-\[state\=visible\]\:animate-in[data-state="visible"]{
  animation-name: enter;
  animation-duration: 150ms;
  --tw-enter-opacity: initial;
  --tw-enter-scale: initial;
  --tw-enter-rotate: initial;
  --tw-enter-translate-x: initial;
  --tw-enter-translate-y: initial;
}

.data-\[motion\^\=to-\]\:animate-out[data-motion^="to-"]{
  animation-name: exit;
  animation-duration: 150ms;
  --tw-exit-opacity: initial;
  --tw-exit-scale: initial;
  --tw-exit-rotate: initial;
  --tw-exit-translate-x: initial;
  --tw-exit-translate-y: initial;
}

.data-\[state\=closed\]\:animate-out[data-state="closed"]{
  animation-name: exit;
  animation-duration: 150ms;
  --tw-exit-opacity: initial;
  --tw-exit-scale: initial;
  --tw-exit-rotate: initial;
  --tw-exit-translate-x: initial;
  --tw-exit-translate-y: initial;
}

.data-\[state\=hidden\]\:animate-out[data-state="hidden"]{
  animation-name: exit;
  animation-duration: 150ms;
  --tw-exit-opacity: initial;
  --tw-exit-scale: initial;
  --tw-exit-rotate: initial;
  --tw-exit-translate-x: initial;
  --tw-exit-translate-y: initial;
}

.data-\[swipe\=end\]\:animate-out[data-swipe="end"]{
  animation-name: exit;
  animation-duration: 150ms;
  --tw-exit-opacity: initial;
  --tw-exit-scale: initial;
  --tw-exit-rotate: initial;
  --tw-exit-translate-x: initial;
  --tw-exit-translate-y: initial;
}

.data-\[motion\^\=from-\]\:fade-in[data-motion^="from-"]{
  --tw-enter-opacity: 0;
}

.data-\[motion\^\=to-\]\:fade-out[data-motion^="to-"]{
  --tw-exit-opacity: 0;
}

.data-\[state\=closed\]\:fade-out-0[data-state="closed"]{
  --tw-exit-opacity: 0;
}

.data-\[state\=closed\]\:fade-out-80[data-state="closed"]{
  --tw-exit-opacity: 0.8;
}

.data-\[state\=hidden\]\:fade-out[data-state="hidden"]{
  --tw-exit-opacity: 0;
}

.data-\[state\=open\]\:fade-in-0[data-state="open"]{
  --tw-enter-opacity: 0;
}

.data-\[state\=visible\]\:fade-in[data-state="visible"]{
  --tw-enter-opacity: 0;
}

.data-\[state\=closed\]\:zoom-out-95[data-state="closed"]{
  --tw-exit-scale: .95;
}

.data-\[state\=open\]\:zoom-in-90[data-state="open"]{
  --tw-enter-scale: .9;
}

.data-\[state\=open\]\:zoom-in-95[data-state="open"]{
  --tw-enter-scale: .95;
}

.data-\[motion\=from-end\]\:slide-in-from-right-52[data-motion="from-end"]{
  --tw-enter-translate-x: 13rem;
}

.data-\[motion\=from-start\]\:slide-in-from-left-52[data-motion="from-start"]{
  --tw-enter-translate-x: -13rem;
}

.data-\[motion\=to-end\]\:slide-out-to-right-52[data-motion="to-end"]{
  --tw-exit-translate-x: 13rem;
}

.data-\[motion\=to-start\]\:slide-out-to-left-52[data-motion="to-start"]{
  --tw-exit-translate-x: -13rem;
}

.data-\[side\=bottom\]\:slide-in-from-top-2[data-side="bottom"]{
  --tw-enter-translate-y: -0.5rem;
}

.data-\[side\=left\]\:slide-in-from-right-2[data-side="left"]{
  --tw-enter-translate-x: 0.5rem;
}

.data-\[side\=right\]\:slide-in-from-left-2[data-side="right"]{
  --tw-enter-translate-x: -0.5rem;
}

.data-\[side\=top\]\:slide-in-from-bottom-2[data-side="top"]{
  --tw-enter-translate-y: 0.5rem;
}

.data-\[state\=closed\]\:slide-out-to-bottom[data-state="closed"]{
  --tw-exit-translate-y: 100%;
}

.data-\[state\=closed\]\:slide-out-to-left[data-state="closed"]{
  --tw-exit-translate-x: -100%;
}

.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state="closed"]{
  --tw-exit-translate-x: -50%;
}

.data-\[state\=closed\]\:slide-out-to-right[data-state="closed"]{
  --tw-exit-translate-x: 100%;
}

.data-\[state\=closed\]\:slide-out-to-right-full[data-state="closed"]{
  --tw-exit-translate-x: 100%;
}

.data-\[state\=closed\]\:slide-out-to-top[data-state="closed"]{
  --tw-exit-translate-y: -100%;
}

.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state="closed"]{
  --tw-exit-translate-y: -48%;
}

.data-\[state\=open\]\:slide-in-from-bottom[data-state="open"]{
  --tw-enter-translate-y: 100%;
}

.data-\[state\=open\]\:slide-in-from-left[data-state="open"]{
  --tw-enter-translate-x: -100%;
}

.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state="open"]{
  --tw-enter-translate-x: -50%;
}

.data-\[state\=open\]\:slide-in-from-right[data-state="open"]{
  --tw-enter-translate-x: 100%;
}

.data-\[state\=open\]\:slide-in-from-top[data-state="open"]{
  --tw-enter-translate-y: -100%;
}

.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state="open"]{
  --tw-enter-translate-y: -48%;
}

.data-\[state\=open\]\:slide-in-from-top-full[data-state="open"]{
  --tw-enter-translate-y: -100%;
}

.data-\[state\=closed\]\:duration-300[data-state="closed"]{
  animation-duration: 300ms;
}

.data-\[state\=open\]\:duration-500[data-state="open"]{
  animation-duration: 500ms;
}

.data-\[panel-group-direction\=vertical\]\:after\:left-0[data-panel-group-direction="vertical"]::after{
  content: var(--tw-content);
  left: 0px;
}

.data-\[panel-group-direction\=vertical\]\:after\:h-1[data-panel-group-direction="vertical"]::after{
  content: var(--tw-content);
  height: 0.25rem;
}

.data-\[panel-group-direction\=vertical\]\:after\:w-full[data-panel-group-direction="vertical"]::after{
  content: var(--tw-content);
  width: 100%;
}

.data-\[panel-group-direction\=vertical\]\:after\:-translate-y-1\/2[data-panel-group-direction="vertical"]::after{
  content: var(--tw-content);
  --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));
}

.data-\[panel-group-direction\=vertical\]\:after\:translate-x-0[data-panel-group-direction="vertical"]::after{
  content: var(--tw-content);
  --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));
}

.data-\[state\=open\]\:hover\:bg-sidebar-accent:hover[data-state="open"]{
  background-color: hsl(var(--sidebar-accent));
}

.data-\[state\=open\]\:hover\:text-sidebar-accent-foreground:hover[data-state="open"]{
  color: hsl(var(--sidebar-accent-foreground));
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\:left-\[calc\(var\(--sidebar-width\)\*-1\)\]{
  left: calc(var(--sidebar-width) * -1);
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\:right-\[calc\(var\(--sidebar-width\)\*-1\)\]{
  right: calc(var(--sidebar-width) * -1);
}

.group[data-side="left"] .group-data-\[side\=left\]\:-right-4{
  right: -1rem;
}

.group[data-side="right"] .group-data-\[side\=right\]\:left-0{
  left: 0px;
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:-mt-8{
  margin-top: -2rem;
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:hidden{
  display: none;
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:\!size-8{
  width: 2rem !important;
  height: 2rem !important;
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:w-\[--sidebar-width-icon\]{
  width: var(--sidebar-width-icon);
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)_\+_theme\(spacing\.4\)\)\]{
  width: calc(var(--sidebar-width-icon) + 1rem);
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)_\+_theme\(spacing\.4\)_\+2px\)\]{
  width: calc(var(--sidebar-width-icon) + 1rem + 2px);
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\:w-0{
  width: 0px;
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\: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));
}

.group[data-side="right"] .group-data-\[side\=right\]\: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));
}

.group[data-state="open"] .group-data-\[state\=open\]\: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));
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:overflow-hidden{
  overflow: hidden;
}

.group[data-variant="floating"] .group-data-\[variant\=floating\]\:rounded-lg{
  border-radius: var(--radius);
}

.group[data-variant="floating"] .group-data-\[variant\=floating\]\:border{
  border-width: 1px;
}

.group[data-side="left"] .group-data-\[side\=left\]\:border-r{
  border-right-width: 1px;
}

.group[data-side="right"] .group-data-\[side\=right\]\:border-l{
  border-left-width: 1px;
}

.group[data-variant="floating"] .group-data-\[variant\=floating\]\:border-sidebar-border{
  border-color: hsl(var(--sidebar-border));
}

.group[data-state="active"] .group-data-\[state\=active\]\:bg-primary-foreground\/20{
  background-color: hsl(var(--primary-foreground) / 0.2);
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:\!p-0{
  padding: 0px !important;
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:\!p-2{
  padding: 0.5rem !important;
}

.group[data-state="active"] .group-data-\[state\=active\]\:text-primary-foreground{
  color: hsl(var(--primary-foreground));
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:opacity-0{
  opacity: 0;
}

.group[data-variant="floating"] .group-data-\[variant\=floating\]\: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);
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\:after\:left-full::after{
  content: var(--tw-content);
  left: 100%;
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\:hover\:bg-sidebar:hover{
  background-color: hsl(var(--sidebar-background));
}

.peer\/menu-button[data-size="default"] ~ .peer-data-\[size\=default\]\/menu-button\:top-1\.5{
  top: 0.375rem;
}

.peer\/menu-button[data-size="lg"] ~ .peer-data-\[size\=lg\]\/menu-button\:top-2\.5{
  top: 0.625rem;
}

.peer\/menu-button[data-size="sm"] ~ .peer-data-\[size\=sm\]\/menu-button\:top-1{
  top: 0.25rem;
}

.peer[data-variant="inset"] ~ .peer-data-\[variant\=inset\]\:min-h-\[calc\(100svh-theme\(spacing\.4\)\)\]{
  min-height: calc(100svh - 1rem);
}

.peer\/menu-button[data-active="true"] ~ .peer-data-\[active\=true\]\/menu-button\:text-sidebar-accent-foreground{
  color: hsl(var(--sidebar-accent-foreground));
}

.dark\:border-destructive:is(.dark *){
  border-color: hsl(var(--destructive));
}

.dark\:border-red-900\/30:is(.dark *){
  border-color: rgb(127 29 29 / 0.3);
}

.dark\:bg-\[\#005c4b\]:is(.dark *){
  --tw-bg-opacity: 1;
  background-color: rgb(0 92 75 / var(--tw-bg-opacity, 1));
}

.dark\:bg-amber-950\/10:is(.dark *){
  background-color: rgb(69 26 3 / 0.1);
}

.dark\:bg-orange-950\/10:is(.dark *){
  background-color: rgb(67 20 7 / 0.1);
}

.dark\:bg-red-950\/10:is(.dark *){
  background-color: rgb(69 10 10 / 0.1);
}

.dark\:text-amber-200:is(.dark *){
  --tw-text-opacity: 1;
  color: rgb(253 230 138 / var(--tw-text-opacity, 1));
}

.dark\:text-amber-400:is(.dark *){
  --tw-text-opacity: 1;
  color: rgb(251 191 36 / var(--tw-text-opacity, 1));
}

.dark\:text-emerald-400:is(.dark *){
  --tw-text-opacity: 1;
  color: rgb(52 211 153 / var(--tw-text-opacity, 1));
}

.dark\:text-green-400:is(.dark *){
  --tw-text-opacity: 1;
  color: rgb(74 222 128 / var(--tw-text-opacity, 1));
}

.dark\:text-orange-400:is(.dark *){
  --tw-text-opacity: 1;
  color: rgb(251 146 60 / var(--tw-text-opacity, 1));
}

.dark\:text-red-400:is(.dark *){
  --tw-text-opacity: 1;
  color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}

.dark\:hover\:bg-orange-950\/20:hover:is(.dark *){
  background-color: rgb(67 20 7 / 0.2);
}

.dark\:hover\:bg-orange-950\/30:hover:is(.dark *){
  background-color: rgb(67 20 7 / 0.3);
}

@media (min-width: 640px){

  .sm\:inset-auto{
    inset: auto;
  }

  .sm\:inset-x-0{
    left: 0px;
    right: 0px;
  }

  .sm\:inset-x-auto{
    left: auto;
    right: auto;
  }

  .sm\:\!bottom-auto{
    bottom: auto !important;
  }

  .sm\:\!left-1\/2{
    left: 50% !important;
  }

  .sm\:\!right-auto{
    right: auto !important;
  }

  .sm\:\!top-1\/2{
    top: 50% !important;
  }

  .sm\:bottom-0{
    bottom: 0px;
  }

  .sm\:bottom-6{
    bottom: 1.5rem;
  }

  .sm\:bottom-8{
    bottom: 2rem;
  }

  .sm\:bottom-auto{
    bottom: auto;
  }

  .sm\:left-1\/2{
    left: 50%;
  }

  .sm\:left-auto{
    left: auto;
  }

  .sm\:right-0{
    right: 0px;
  }

  .sm\:right-6{
    right: 1.5rem;
  }

  .sm\:top-1\/2{
    top: 50%;
  }

  .sm\:top-auto{
    top: auto;
  }

  .sm\:order-1{
    order: 1;
  }

  .sm\:order-2{
    order: 2;
  }

  .sm\:col-span-2{
    grid-column: span 2 / span 2;
  }

  .sm\:-mx-5{
    margin-left: -1.25rem;
    margin-right: -1.25rem;
  }

  .sm\:-mx-6{
    margin-left: -1.5rem;
    margin-right: -1.5rem;
  }

  .sm\:mx-0{
    margin-left: 0px;
    margin-right: 0px;
  }

  .sm\:-mb-5{
    margin-bottom: -1.25rem;
  }

  .sm\:mb-0{
    margin-bottom: 0px;
  }

  .sm\:mb-3{
    margin-bottom: 0.75rem;
  }

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

  .sm\:ml-0{
    margin-left: 0px;
  }

  .sm\:ml-2{
    margin-left: 0.5rem;
  }

  .sm\:mr-1{
    margin-right: 0.25rem;
  }

  .sm\:mt-0{
    margin-top: 0px;
  }

  .sm\:block{
    display: block;
  }

  .sm\:inline{
    display: inline;
  }

  .sm\:flex{
    display: flex;
  }

  .sm\:table-cell{
    display: table-cell;
  }

  .sm\:hidden{
    display: none;
  }

  .sm\:h-10{
    height: 2.5rem;
  }

  .sm\:h-16{
    height: 4rem;
  }

  .sm\:h-64{
    height: 16rem;
  }

  .sm\:h-7{
    height: 1.75rem;
  }

  .sm\:h-8{
    height: 2rem;
  }

  .sm\:max-h-\[85dvh\]{
    max-height: 85dvh;
  }

  .sm\:max-h-\[88vh\]{
    max-height: 88vh;
  }

  .sm\:min-h-\[240px\]{
    min-height: 240px;
  }

  .sm\:min-h-\[260px\]{
    min-height: 260px;
  }

  .sm\:\!w-\[calc\(100vw-2rem\)\]{
    width: calc(100vw - 2rem) !important;
  }

  .sm\:w-10{
    width: 2.5rem;
  }

  .sm\:w-16{
    width: 4rem;
  }

  .sm\:w-64{
    width: 16rem;
  }

  .sm\:w-7{
    width: 1.75rem;
  }

  .sm\:w-8{
    width: 2rem;
  }

  .sm\:w-\[400px\]{
    width: 400px;
  }

  .sm\:w-\[420px\]{
    width: 420px;
  }

  .sm\:w-\[440px\]{
    width: 440px;
  }

  .sm\:w-auto{
    width: auto;
  }

  .sm\:w-full{
    width: 100%;
  }

  .sm\:min-w-\[28px\]{
    min-width: 28px;
  }

  .sm\:min-w-\[360px\]{
    min-width: 360px;
  }

  .sm\:\!max-w-md{
    max-width: 28rem !important;
  }

  .sm\:max-w-2xl{
    max-width: 42rem;
  }

  .sm\:max-w-\[340px\]{
    max-width: 340px;
  }

  .sm\:max-w-\[360px\]{
    max-width: 360px;
  }

  .sm\:max-w-\[400px\]{
    max-width: 400px;
  }

  .sm\:max-w-\[420px\]{
    max-width: 420px;
  }

  .sm\:max-w-\[560px\]{
    max-width: 560px;
  }

  .sm\:max-w-full{
    max-width: 100%;
  }

  .sm\:max-w-lg{
    max-width: 32rem;
  }

  .sm\:max-w-md{
    max-width: 28rem;
  }

  .sm\:max-w-sm{
    max-width: 24rem;
  }

  .sm\:max-w-xl{
    max-width: 36rem;
  }

  .sm\:max-w-xs{
    max-width: 20rem;
  }

  .sm\:flex-1{
    flex: 1 1 0%;
  }

  .sm\:flex-initial{
    flex: 0 1 auto;
  }

  .sm\:flex-none{
    flex: none;
  }

  .sm\:shrink{
    flex-shrink: 1;
  }

  .sm\:shrink-0{
    flex-shrink: 0;
  }

  .sm\:\!-translate-x-1\/2{
    --tw-translate-x: -50% !important;
    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)) !important;
  }

  .sm\:\!-translate-y-1\/2{
    --tw-translate-y: -50% !important;
    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)) !important;
  }

  .sm\:-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));
  }

  .sm\:-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));
  }

  .sm\:grid-cols-2{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sm\:grid-cols-3{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .sm\:grid-cols-4{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .sm\:grid-cols-5{
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .sm\:grid-cols-\[180px\2c 1fr\]{
    grid-template-columns: 180px 1fr;
  }

  .sm\:grid-cols-\[1fr_120px\]{
    grid-template-columns: 1fr 120px;
  }

  .sm\:grid-cols-\[1fr_70px_70px_80px_80px_24px\]{
    grid-template-columns: 1fr 70px 70px 80px 80px 24px;
  }

  .sm\:grid-cols-\[1fr_80px\]{
    grid-template-columns: 1fr 80px;
  }

  .sm\:grid-cols-\[1fr_80px_120px\]{
    grid-template-columns: 1fr 80px 120px;
  }

  .sm\:grid-cols-\[1fr_auto\]{
    grid-template-columns: 1fr auto;
  }

  .sm\:grid-cols-\[minmax\(0\2c 1fr\)_220px\]{
    grid-template-columns: minmax(0,1fr) 220px;
  }

  .sm\:grid-cols-\[minmax\(0\2c 1fr\)_minmax\(220px\2c 0\.75fr\)\]{
    grid-template-columns: minmax(0,1fr) minmax(220px,0.75fr);
  }

  .sm\:flex-row{
    flex-direction: row;
  }

  .sm\:flex-col{
    flex-direction: column;
  }

  .sm\:items-start{
    align-items: flex-start;
  }

  .sm\:items-end{
    align-items: flex-end;
  }

  .sm\:items-center{
    align-items: center;
  }

  .sm\:items-stretch{
    align-items: stretch;
  }

  .sm\:justify-end{
    justify-content: flex-end;
  }

  .sm\:justify-between{
    justify-content: space-between;
  }

  .sm\:gap-0{
    gap: 0px;
  }

  .sm\:gap-2{
    gap: 0.5rem;
  }

  .sm\:gap-2\.5{
    gap: 0.625rem;
  }

  .sm\:gap-3{
    gap: 0.75rem;
  }

  .sm\:gap-4{
    gap: 1rem;
  }

  .sm\:gap-5{
    gap: 1.25rem;
  }

  .sm\: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\:space-x-4 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(1rem * var(--tw-space-x-reverse));
    margin-left: calc(1rem * calc(1 - var(--tw-space-x-reverse)));
  }

  .sm\: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));
  }

  .sm\: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));
  }

  .sm\: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));
  }

  .sm\:self-auto{
    align-self: auto;
  }

  .sm\:rounded-2xl{
    border-radius: calc(var(--radius) + 8px);
  }

  .sm\:rounded-\[28px\]{
    border-radius: 28px;
  }

  .sm\:rounded-lg{
    border-radius: var(--radius);
  }

  .sm\:rounded-xl{
    border-radius: calc(var(--radius) + 4px);
  }

  .sm\:border{
    border-width: 1px;
  }

  .sm\:p-3\.5{
    padding: 0.875rem;
  }

  .sm\:p-4{
    padding: 1rem;
  }

  .sm\:p-5{
    padding: 1.25rem;
  }

  .sm\:p-6{
    padding: 1.5rem;
  }

  .sm\:p-7{
    padding: 1.75rem;
  }

  .sm\:p-8{
    padding: 2rem;
  }

  .sm\:p-9{
    padding: 2.25rem;
  }

  .sm\:px-0{
    padding-left: 0px;
    padding-right: 0px;
  }

  .sm\:px-1{
    padding-left: 0.25rem;
    padding-right: 0.25rem;
  }

  .sm\:px-3{
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }

  .sm\:px-3\.5{
    padding-left: 0.875rem;
    padding-right: 0.875rem;
  }

  .sm\:px-4{
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .sm\:px-5{
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .sm\:px-6{
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  .sm\:py-12{
    padding-top: 3rem;
    padding-bottom: 3rem;
  }

  .sm\:py-2\.5{
    padding-top: 0.625rem;
    padding-bottom: 0.625rem;
  }

  .sm\:py-4{
    padding-top: 1rem;
    padding-bottom: 1rem;
  }

  .sm\:pb-0{
    padding-bottom: 0px;
  }

  .sm\:pb-3{
    padding-bottom: 0.75rem;
  }

  .sm\:pb-4{
    padding-bottom: 1rem;
  }

  .sm\:pb-5{
    padding-bottom: 1.25rem;
  }

  .sm\:pt-5{
    padding-top: 1.25rem;
  }

  .sm\:text-left{
    text-align: left;
  }

  .sm\:text-right{
    text-align: right;
  }

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

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

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

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

  .sm\:text-\[10px\]{
    font-size: 10px;
  }

  .sm\:text-\[12px\]{
    font-size: 12px;
  }

  .sm\:text-\[14px\]{
    font-size: 14px;
  }

  .sm\:text-\[16px\]{
    font-size: 16px;
  }

  .sm\:text-\[2\.6rem\]{
    font-size: 2.6rem;
  }

  .sm\:text-\[23px\]{
    font-size: 23px;
  }

  .sm\:text-\[26px\]{
    font-size: 26px;
  }

  .sm\:text-\[3\.2rem\]{
    font-size: 3.2rem;
  }

  .sm\:text-\[9px\]{
    font-size: 9px;
  }

  .sm\:text-base{
    font-size: 1rem;
    line-height: 1.5rem;
  }

  .sm\:text-lg{
    font-size: 1.125rem;
    line-height: 1.75rem;
  }

  .sm\:text-sm{
    font-size: 0.875rem;
    line-height: 1.25rem;
  }

  .sm\:leading-relaxed{
    line-height: 1.625;
  }

  .sm\:zoom-in-95{
    --tw-enter-scale: .95;
  }

  .data-\[state\=open\]\:sm\:slide-in-from-bottom-full[data-state="open"]{
    --tw-enter-translate-y: 100%;
  }
}

@media (min-width: 768px){

  .md\:fixed{
    position: fixed;
  }

  .md\:absolute{
    position: absolute;
  }

  .md\:sticky{
    position: sticky;
  }

  .md\:inset-y-0{
    top: 0px;
    bottom: 0px;
  }

  .md\:left-0{
    left: 0px;
  }

  .md\:top-0{
    top: 0px;
  }

  .md\:z-\[120\]{
    z-index: 120;
  }

  .md\:col-span-2{
    grid-column: span 2 / span 2;
  }

  .md\:-mx-8{
    margin-left: -2rem;
    margin-right: -2rem;
  }

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

  .md\:ml-\[248px\]{
    margin-left: 248px;
  }

  .md\:block{
    display: block;
  }

  .md\:flex{
    display: flex;
  }

  .md\:inline-flex{
    display: inline-flex;
  }

  .md\:hidden{
    display: none;
  }

  .md\:min-h-screen{
    min-height: 100vh;
  }

  .md\:w-60{
    width: 15rem;
  }

  .md\:w-80{
    width: 20rem;
  }

  .md\:w-\[248px\]{
    width: 248px;
  }

  .md\:w-\[var\(--radix-navigation-menu-viewport-width\)\]{
    width: var(--radix-navigation-menu-viewport-width);
  }

  .md\:w-auto{
    width: auto;
  }

  .md\:max-w-2xl{
    max-width: 42rem;
  }

  .md\:max-w-\[420px\]{
    max-width: 420px;
  }

  .md\:max-w-\[460px\]{
    max-width: 460px;
  }

  .md\:max-w-\[560px\]{
    max-width: 560px;
  }

  .md\:max-w-\[960px\]{
    max-width: 960px;
  }

  .md\:grid-cols-2{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .md\:grid-cols-3{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .md\:grid-cols-4{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .md\:grid-cols-5{
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .md\:flex-row{
    flex-direction: row;
  }

  .md\:flex-col{
    flex-direction: column;
  }

  .md\:items-center{
    align-items: center;
  }

  .md\:justify-between{
    justify-content: space-between;
  }

  .md\: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));
  }

  .md\:rounded-2xl{
    border-radius: calc(var(--radius) + 8px);
  }

  .md\:border-r{
    border-right-width: 1px;
  }

  .md\:border-border\/20{
    border-color: hsl(var(--border) / 0.2);
  }

  .md\:border-border\/30{
    border-color: hsl(var(--border) / 0.3);
  }

  .md\:p-4{
    padding: 1rem;
  }

  .md\:p-5{
    padding: 1.25rem;
  }

  .md\:p-6{
    padding: 1.5rem;
  }

  .md\:p-8{
    padding: 2rem;
  }

  .md\:px-3{
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }

  .md\:px-6{
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  .md\:px-8{
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .md\:py-5{
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
  }

  .md\:py-6{
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }

  .md\:pb-4{
    padding-bottom: 1rem;
  }

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

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

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

  .md\:text-lg{
    font-size: 1.125rem;
    line-height: 1.75rem;
  }

  .md\:text-sm{
    font-size: 0.875rem;
    line-height: 1.25rem;
  }

  .md\:opacity-0{
    opacity: 0;
  }
  html[data-map-mode="expanded"] .md\:sticky.glass-strong.top-\[105px\],
  html[data-map-mode="immersive"] .md\:sticky.glass-strong.top-\[105px\] {
    transform: translateY(-100%);
    pointer-events: none;
    opacity: 0;
    transition: transform 0.28s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.2s ease;
  }
  .md\:sticky
  .glass-strong.top-\[105px\] {
    transition: transform 0.28s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.2s ease;
  }
  .after\:md\:hidden::after{
    content: var(--tw-content);
    display: none;
  }
  .peer[data-variant="inset"] ~ .md\:peer-data-\[variant\=inset\]\:m-2{
    margin: 0.5rem;
  }
  .peer[data-state="collapsed"][data-variant="inset"] ~ .md\:peer-data-\[state\=collapsed\]\:peer-data-\[variant\=inset\]\:ml-2{
    margin-left: 0.5rem;
  }
  .peer[data-variant="inset"] ~ .md\:peer-data-\[variant\=inset\]\:ml-0{
    margin-left: 0px;
  }
  .peer[data-variant="inset"] ~ .md\:peer-data-\[variant\=inset\]\:rounded-xl{
    border-radius: calc(var(--radius) + 4px);
  }
  .peer[data-variant="inset"] ~ .md\:peer-data-\[variant\=inset\]\: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);
  }
}

@media (min-width: 1024px){

  .lg\:ml-\[280px\]{
    margin-left: 280px;
  }

  .lg\:w-\[280px\]{
    width: 280px;
  }

  .lg\:w-\[30\%\]{
    width: 30%;
  }

  .lg\:w-\[34\%\]{
    width: 34%;
  }

  .lg\:max-w-\[1180px\]{
    max-width: 1180px;
  }

  .lg\:max-w-\[620px\]{
    max-width: 620px;
  }

  .lg\:grid-cols-2{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lg\:grid-cols-3{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lg\:grid-cols-4{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .lg\:grid-cols-5{
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .lg\:grid-cols-\[220px_minmax\(0\2c 1fr\)\]{
    grid-template-columns: 220px minmax(0,1fr);
  }

  .lg\:grid-cols-\[minmax\(0\2c 1fr\)_auto\]{
    grid-template-columns: minmax(0,1fr) auto;
  }

  .lg\:flex-row{
    flex-direction: row;
  }

  .lg\:items-start{
    align-items: flex-start;
  }

  .lg\:items-stretch{
    align-items: stretch;
  }

  .lg\:gap-6{
    gap: 1.5rem;
  }

  .lg\:px-8{
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .lg\:py-14{
    padding-top: 3.5rem;
    padding-bottom: 3.5rem;
  }

  .lg\:py-6{
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }

  .lg\:text-\[22px\]{
    font-size: 22px;
  }
}

@media (min-width: 1280px){

  .xl\:ml-\[304px\]{
    margin-left: 304px;
  }

  .xl\:w-\[304px\]{
    width: 304px;
  }

  .xl\:max-w-\[1360px\]{
    max-width: 1360px;
  }

  .xl\:grid-cols-2{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .xl\:grid-cols-3{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .xl\:grid-cols-4{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .xl\:grid-cols-5{
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .xl\:grid-cols-8{
    grid-template-columns: repeat(8, minmax(0, 1fr));
  }

  .xl\:grid-cols-\[280px_1fr\]{
    grid-template-columns: 280px 1fr;
  }

  .xl\:px-10{
    padding-left: 2.5rem;
    padding-right: 2.5rem;
  }
}

@media (min-width: 1536px){

  .\32xl\:max-w-\[1500px\]{
    max-width: 1500px;
  }
}

.\[\&\:\:-webkit-scrollbar-thumb\]\:rounded::-webkit-scrollbar-thumb{
  border-radius: 0.25rem;
}

.\[\&\:\:-webkit-scrollbar-thumb\]\:bg-border\/40::-webkit-scrollbar-thumb{
  background-color: hsl(var(--border) / 0.4);
}

.\[\&\:\:-webkit-scrollbar\]\:hidden::-webkit-scrollbar{
  display: none;
}

.\[\&\:\:-webkit-scrollbar\]\:h-1\.5::-webkit-scrollbar{
  height: 0.375rem;
}

.\[\&\:has\(\[aria-selected\]\)\]\:bg-accent:has([aria-selected]){
  background-color: hsl(var(--accent));
}

.first\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-l-md:has([aria-selected]):first-child{
  border-top-left-radius: calc(var(--radius) - 2px);
  border-bottom-left-radius: calc(var(--radius) - 2px);
}

.last\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-r-md:has([aria-selected]):last-child{
  border-top-right-radius: calc(var(--radius) - 2px);
  border-bottom-right-radius: calc(var(--radius) - 2px);
}

.\[\&\:has\(\[aria-selected\]\.day-outside\)\]\:bg-accent\/50:has([aria-selected].day-outside){
  background-color: hsl(var(--accent) / 0.5);
}

.\[\&\:has\(\[aria-selected\]\.day-range-end\)\]\:rounded-r-md:has([aria-selected].day-range-end){
  border-top-right-radius: calc(var(--radius) - 2px);
  border-bottom-right-radius: calc(var(--radius) - 2px);
}

.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){
  padding-right: 0px;
}

.\[\&\>button\]\:hidden>button{
  display: none;
}

.\[\&\>div\]\:bg-destructive>div{
  background-color: hsl(var(--destructive));
}

.\[\&\>div\]\:bg-success>div{
  background-color: hsl(var(--success));
}

.\[\&\>div\]\:bg-warning>div{
  background-color: hsl(var(--warning));
}

.\[\&\>span\:last-child\]\:truncate>span:last-child{
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.\[\&\>span\]\:line-clamp-1>span{
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}

.\[\&\>svg\+div\]\:translate-y-\[-3px\]>svg+div{
  --tw-translate-y: -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));
}

.\[\&\>svg\]\:absolute>svg{
  position: absolute;
}

.\[\&\>svg\]\:left-4>svg{
  left: 1rem;
}

.\[\&\>svg\]\:top-4>svg{
  top: 1rem;
}

.\[\&\>svg\]\:size-3\.5>svg{
  width: 0.875rem;
  height: 0.875rem;
}

.\[\&\>svg\]\:size-4>svg{
  width: 1rem;
  height: 1rem;
}

.\[\&\>svg\]\:h-3\.5>svg{
  height: 0.875rem;
}

.\[\&\>svg\]\:w-3\.5>svg{
  width: 0.875rem;
}

.\[\&\>svg\]\:shrink-0>svg{
  flex-shrink: 0;
}

.\[\&\>svg\]\:text-destructive>svg{
  color: hsl(var(--destructive));
}

.\[\&\>svg\]\:text-foreground>svg{
  color: hsl(var(--foreground));
}

.\[\&\>svg\]\:text-sidebar-accent-foreground>svg{
  color: hsl(var(--sidebar-accent-foreground));
}

.\[\&\>svg\~\*\]\:pl-7>svg~*{
  padding-left: 1.75rem;
}

.\[\&\>tr\]\:last\:border-b-0:last-child>tr{
  border-bottom-width: 0px;
}

.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div{
  --tw-rotate: 90deg;
  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));
}

.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{
  --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));
}

.\[\&_\[cmdk-group-heading\]\]\:px-2 [cmdk-group-heading]{
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 [cmdk-group-heading]{
  padding-top: 0.375rem;
  padding-bottom: 0.375rem;
}

.\[\&_\[cmdk-group-heading\]\]\:text-xs [cmdk-group-heading]{
  font-size: 0.75rem;
  line-height: 1rem;
}

.\[\&_\[cmdk-group-heading\]\]\:font-medium [cmdk-group-heading]{
  font-weight: 500;
}

.\[\&_\[cmdk-group-heading\]\]\:text-muted-foreground [cmdk-group-heading]{
  color: hsl(var(--muted-foreground));
}

.\[\&_\[cmdk-group\]\:not\(\[hidden\]\)_\~\[cmdk-group\]\]\:pt-0 [cmdk-group]:not([hidden]) ~[cmdk-group]{
  padding-top: 0px;
}

.\[\&_\[cmdk-group\]\]\:px-2 [cmdk-group]{
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

.\[\&_\[cmdk-input-wrapper\]_svg\]\:h-5 [cmdk-input-wrapper] svg{
  height: 1.25rem;
}

.\[\&_\[cmdk-input-wrapper\]_svg\]\:w-5 [cmdk-input-wrapper] svg{
  width: 1.25rem;
}

.\[\&_\[cmdk-input\]\]\:h-12 [cmdk-input]{
  height: 3rem;
}

.\[\&_\[cmdk-item\]\]\:px-2 [cmdk-item]{
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

.\[\&_\[cmdk-item\]\]\:py-3 [cmdk-item]{
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.\[\&_\[cmdk-item\]_svg\]\:h-5 [cmdk-item] svg{
  height: 1.25rem;
}

.\[\&_\[cmdk-item\]_svg\]\:w-5 [cmdk-item] svg{
  width: 1.25rem;
}

.\[\&_p\]\:leading-relaxed p{
  line-height: 1.625;
}

.\[\&_svg\]\:pointer-events-none svg{
  pointer-events: none;
}

.\[\&_svg\]\:size-4 svg{
  width: 1rem;
  height: 1rem;
}

.\[\&_svg\]\:shrink-0 svg{
  flex-shrink: 0;
}

.\[\&_tr\:last-child\]\:border-0 tr:last-child{
  border-width: 0px;
}

.\[\&_tr\]\:border-b tr{
  border-bottom-width: 1px;
}

[data-side=left][data-collapsible=offcanvas] .\[\[data-side\=left\]\[data-collapsible\=offcanvas\]_\&\]\:-right-2{
  right: -0.5rem;
}

[data-side=left][data-state=collapsed] .\[\[data-side\=left\]\[data-state\=collapsed\]_\&\]\:cursor-e-resize{
  cursor: e-resize;
}

[data-side=left] .\[\[data-side\=left\]_\&\]\:cursor-w-resize{
  cursor: w-resize;
}

[data-side=right][data-collapsible=offcanvas] .\[\[data-side\=right\]\[data-collapsible\=offcanvas\]_\&\]\:-left-2{
  left: -0.5rem;
}

[data-side=right][data-state=collapsed] .\[\[data-side\=right\]\[data-state\=collapsed\]_\&\]\:cursor-w-resize{
  cursor: w-resize;
}

[data-side=right] .\[\[data-side\=right\]_\&\]\:cursor-e-resize{
  cursor: e-resize;
}
