/*! tailwindcss v4.1.3 | MIT License | https://tailwindcss.com */
@layer properties {
  @supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
    *, :before, :after, ::backdrop {
      --tw-border-spacing-x: 0;
      --tw-border-spacing-y: 0;
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-rotate-x: rotateX(0);
      --tw-rotate-y: rotateY(0);
      --tw-rotate-z: rotateZ(0);
      --tw-skew-x: skewX(0);
      --tw-skew-y: skewY(0);
      --tw-space-y-reverse: 0;
      --tw-space-x-reverse: 0;
      --tw-border-style: solid;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-tracking: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-duration: initial;
      --tw-ease: initial;
    }
  }
}

@layer theme {
  :root, :host {
    --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --color-red-50: oklch(.971 .013 17.38);
    --color-red-100: oklch(.936 .032 17.717);
    --color-red-200: oklch(.885 .062 18.334);
    --color-red-600: oklch(.577 .245 27.325);
    --color-red-700: oklch(.505 .213 27.518);
    --color-orange-500: oklch(.705 .213 47.604);
    --color-yellow-50: oklch(.987 .026 102.212);
    --color-yellow-100: oklch(.973 .071 103.193);
    --color-yellow-200: oklch(.945 .129 101.54);
    --color-yellow-500: oklch(.795 .184 86.047);
    --color-yellow-700: oklch(.554 .135 66.442);
    --color-yellow-800: oklch(.476 .114 61.907);
    --color-green-50: oklch(.982 .018 155.826);
    --color-green-100: oklch(.962 .044 156.743);
    --color-green-200: oklch(.925 .084 155.995);
    --color-green-500: oklch(.723 .219 149.579);
    --color-green-600: oklch(.627 .194 149.214);
    --color-green-700: oklch(.527 .154 150.069);
    --color-green-800: oklch(.448 .119 151.328);
    --color-blue-50: oklch(.97 .014 254.604);
    --color-blue-100: oklch(.932 .032 255.585);
    --color-blue-500: oklch(.623 .214 259.815);
    --color-blue-800: oklch(.424 .199 265.638);
    --color-purple-500: oklch(.627 .265 303.9);
    --color-gray-50: oklch(.985 .002 247.839);
    --color-gray-100: oklch(.967 .003 264.542);
    --color-gray-200: oklch(.928 .006 264.531);
    --color-gray-300: oklch(.872 .01 258.338);
    --color-gray-400: oklch(.707 .022 261.325);
    --color-gray-500: oklch(.551 .027 264.364);
    --color-gray-600: oklch(.446 .03 256.802);
    --color-gray-700: oklch(.373 .034 259.733);
    --color-gray-800: oklch(.278 .033 256.848);
    --color-gray-900: oklch(.21 .034 264.665);
    --color-black: #000;
    --color-white: #fff;
    --spacing: .25rem;
    --container-md: 28rem;
    --container-lg: 32rem;
    --container-2xl: 42rem;
    --container-3xl: 48rem;
    --container-4xl: 56rem;
    --container-7xl: 80rem;
    --text-xs: .75rem;
    --text-xs--line-height: calc(1 / .75);
    --text-sm: .875rem;
    --text-sm--line-height: calc(1.25 / .875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --text-3xl: 1.875rem;
    --text-3xl--line-height: calc(2.25 / 1.875);
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --tracking-wide: .025em;
    --tracking-widest: .1em;
    --leading-tight: 1.25;
    --leading-relaxed: 1.625;
    --radius-xs: .125rem;
    --radius-lg: var(--radius);
    --radius-2xl: 1rem;
    --ease-out: cubic-bezier(0, 0, .2, 1);
    --ease-in-out: cubic-bezier(.4, 0, .2, 1);
    --default-transition-duration: .15s;
    --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    --default-font-family: var(--font-sans);
    --default-font-feature-settings: var(--font-sans--font-feature-settings);
    --default-font-variation-settings: var(--font-sans--font-variation-settings);
    --default-mono-font-family: var(--font-mono);
    --default-mono-font-feature-settings: var(--font-mono--font-feature-settings);
    --default-mono-font-variation-settings: var(--font-mono--font-variation-settings);
    --color-foreground: var(--foreground);
    --color-card: var(--card);
    --color-muted: var(--muted);
    --color-muted-foreground: var(--muted-foreground);
    --color-border: var(--border);
    --color-ring: var(--ring);
    --color-sidebar: var(--sidebar);
    --color-sidebar-foreground: var(--sidebar-foreground);
    --color-sidebar-accent: var(--sidebar-accent);
    --color-sidebar-separator: var(--sidebar-separator);
    --color-sidebar-separator-hover: var(--sidebar-separator-hover);
    --color-sidebar-module-dashboard: var(--sidebar-module-dashboard);
    --color-sidebar-module-dashboard-foreground: var(--sidebar-module-dashboard-foreground);
    --color-sidebar-module-dashboard-hover: var(--sidebar-module-dashboard-hover);
    --color-sidebar-module-dashboard-pressed: var(--sidebar-module-dashboard-pressed);
    --color-sidebar-module-piping: var(--sidebar-module-piping);
    --color-sidebar-module-piping-foreground: var(--sidebar-module-piping-foreground);
    --color-sidebar-module-piping-hover: var(--sidebar-module-piping-hover);
    --color-sidebar-module-piping-pressed: var(--sidebar-module-piping-pressed);
    --color-sidebar-module-structural: var(--sidebar-module-structural);
    --color-sidebar-module-structural-foreground: var(--sidebar-module-structural-foreground);
    --color-sidebar-module-structural-hover: var(--sidebar-module-structural-hover);
    --color-sidebar-module-structural-pressed: var(--sidebar-module-structural-pressed);
    --color-sidebar-module-rc: var(--sidebar-module-rc);
    --color-sidebar-module-rc-foreground: var(--sidebar-module-rc-foreground);
    --color-sidebar-module-rc-hover: var(--sidebar-module-rc-hover);
    --color-sidebar-module-rc-pressed: var(--sidebar-module-rc-pressed);
    --color-sidebar-module-mep: var(--sidebar-module-mep);
    --color-sidebar-module-mep-foreground: var(--sidebar-module-mep-foreground);
    --color-sidebar-module-mep-hover: var(--sidebar-module-mep-hover);
    --color-sidebar-module-mep-pressed: var(--sidebar-module-mep-pressed);
    --color-sidebar-module-library: var(--sidebar-module-library);
    --color-sidebar-module-library-foreground: var(--sidebar-module-library-foreground);
    --color-sidebar-module-library-hover: var(--sidebar-module-library-hover);
    --color-sidebar-module-library-pressed: var(--sidebar-module-library-pressed);
    --color-sidebar-module-calculators: var(--sidebar-module-calculators);
    --color-sidebar-module-calculators-foreground: var(--sidebar-module-calculators-foreground);
    --color-sidebar-module-calculators-hover: var(--sidebar-module-calculators-hover);
    --color-sidebar-module-calculators-pressed: var(--sidebar-module-calculators-pressed);
    --color-sidebar-module-project-boards: var(--sidebar-module-project-boards);
    --color-sidebar-module-project-boards-foreground: var(--sidebar-module-project-boards-foreground);
    --color-sidebar-module-project-boards-hover: var(--sidebar-module-project-boards-hover);
    --color-sidebar-module-project-boards-pressed: var(--sidebar-module-project-boards-pressed);
    --color-sidebar-module-deliverables: var(--sidebar-module-deliverables);
    --color-sidebar-module-deliverables-foreground: var(--sidebar-module-deliverables-foreground);
    --color-sidebar-module-deliverables-hover: var(--sidebar-module-deliverables-hover);
    --color-sidebar-module-deliverables-pressed: var(--sidebar-module-deliverables-pressed);
    --color-sidebar-module-engineering: var(--sidebar-module-engineering);
    --color-sidebar-module-engineering-foreground: var(--sidebar-module-engineering-foreground);
    --color-sidebar-module-engineering-hover: var(--sidebar-module-engineering-hover);
    --color-sidebar-module-engineering-pressed: var(--sidebar-module-engineering-pressed);
    --color-sidebar-piping-tier1: var(--sidebar-piping-tier1);
    --color-sidebar-piping-tier2: var(--sidebar-piping-tier2);
    --color-sidebar-piping-tier3: var(--sidebar-piping-tier3);
    --color-sidebar-piping-tier4: var(--sidebar-piping-tier4);
    --color-sidebar-structural-tier1: var(--sidebar-structural-tier1);
    --color-sidebar-structural-tier2: var(--sidebar-structural-tier2);
    --color-sidebar-structural-tier3: var(--sidebar-structural-tier3);
    --color-sidebar-structural-tier4: var(--sidebar-structural-tier4);
    --color-sidebar-library-tier1: var(--sidebar-library-tier1);
    --color-sidebar-library-tier2: var(--sidebar-library-tier2);
    --color-sidebar-library-tier3: var(--sidebar-library-tier3);
    --color-sidebar-library-tier4: var(--sidebar-library-tier4);
    --color-sidebar-calculators-tier1: var(--sidebar-calculators-tier1);
    --color-sidebar-calculators-tier2: var(--sidebar-calculators-tier2);
    --color-sidebar-calculators-tier3: var(--sidebar-calculators-tier3);
    --color-sidebar-calculators-tier4: var(--sidebar-calculators-tier4);
    --color-sidebar-deliverables-tier1: var(--sidebar-deliverables-tier1);
    --color-sidebar-deliverables-tier2: var(--sidebar-deliverables-tier2);
    --color-sidebar-deliverables-tier3: var(--sidebar-deliverables-tier3);
    --color-sidebar-deliverables-tier4: var(--sidebar-deliverables-tier4);
  }
}

@layer base {
  *, :after, :before, ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  ::file-selector-button {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  html, :host {
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    line-height: 1.5;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }

  body {
    line-height: inherit;
  }

  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }

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

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

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

  b, strong {
    font-weight: bolder;
  }

  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }

  small {
    font-size: 80%;
  }

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

  sub {
    bottom: -.25em;
  }

  sup {
    top: -.5em;
  }

  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }

  :-moz-focusring {
    outline: auto;
  }

  progress {
    vertical-align: baseline;
  }

  summary {
    display: list-item;
  }

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

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

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

  button, input, select, optgroup, textarea {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }

  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }

  ::file-selector-button {
    margin-inline-end: 4px;
  }

  ::placeholder {
    opacity: 1;
    color: currentColor;
  }

  @supports (color: color-mix(in lab, red, red)) {
    ::placeholder {
      color: color-mix(in oklab, currentColor 50%, transparent);
    }
  }

  textarea {
    resize: vertical;
  }

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

  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }

  ::-webkit-datetime-edit {
    display: inline-flex;
  }

  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }

  ::-webkit-datetime-edit {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-year-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-month-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-day-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-hour-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-minute-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-second-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-millisecond-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }

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

  button, input:where([type="button"], [type="reset"], [type="submit"]) {
    appearance: button;
  }

  ::file-selector-button {
    appearance: button;
  }

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

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

  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }

  * {
    border-color: var(--border);
    outline-color: var(--ring);
  }

  @supports (color: color-mix(in lab, red, red)) {
    * {
      outline-color: color-mix(in oklab, var(--ring) 50%, transparent);
    }
  }

  * {
    border-color: var(--border);
    outline-color: var(--ring);
  }

  @supports (color: color-mix(in lab, red, red)) {
    * {
      outline-color: color-mix(in oklab, var(--ring) 50%, transparent);
    }
  }

  body {
    background-color: var(--background);
    color: var(--foreground);
  }

  *, :before, :after {
    box-shadow: none !important;
  }

  .dropdown-menu, .popover, .tooltip, .dialog, .alert-dialog, .sheet, .context-menu, .hover-card, [data-radix-popper-content-wrapper], [data-state="open"][role="dialog"], [data-state="open"][role="menu"] {
    box-shadow: 0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a !important;
  }

  :where(:not(:has([class*=" text-"]), :not(:has([class^="text-"])))) h1 {
    font-size: var(--text-2xl);
    font-weight: var(--font-weight-medium);
    line-height: 1.5;
  }

  :where(:not(:has([class*=" text-"]), :not(:has([class^="text-"])))) h2 {
    font-size: var(--text-xl);
    font-weight: var(--font-weight-medium);
    line-height: 1.5;
  }

  :where(:not(:has([class*=" text-"]), :not(:has([class^="text-"])))) h3 {
    font-size: var(--text-lg);
    font-weight: var(--font-weight-medium);
    line-height: 1.5;
  }

  :where(:not(:has([class*=" text-"]), :not(:has([class^="text-"])))) h4 {
    font-size: var(--text-base);
    font-weight: var(--font-weight-medium);
    line-height: 1.5;
  }

  :where(:not(:has([class*=" text-"]), :not(:has([class^="text-"])))) p {
    font-size: var(--text-base);
    font-weight: var(--font-weight-normal);
    line-height: 1.5;
  }

  :where(:not(:has([class*=" text-"]), :not(:has([class^="text-"])))) label, :where(:not(:has([class*=" text-"]), :not(:has([class^="text-"])))) button {
    font-size: var(--text-base);
    font-weight: var(--font-weight-medium);
    line-height: 1.5;
  }

  :where(:not(:has([class*=" text-"]), :not(:has([class^="text-"])))) input {
    font-size: var(--text-base);
    font-weight: var(--font-weight-normal);
    line-height: 1.5;
  }
}

@layer utilities {
  .\@container\/card-header {
    container: card-header / inline-size;
  }

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

  .collapse {
    visibility: collapse;
  }

  .visible {
    visibility: visible;
  }

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

  .absolute {
    position: absolute;
  }

  .fixed {
    position: fixed;
  }

  .relative {
    position: relative;
  }

  .static {
    position: static;
  }

  .sticky {
    position: sticky;
  }

  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }

  .inset-6 {
    inset: calc(var(--spacing) * 6);
  }

  .inset-y-0 {
    inset-block: calc(var(--spacing) * 0);
  }

  .top-0 {
    top: calc(var(--spacing) * 0);
  }

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

  .top-4 {
    top: calc(var(--spacing) * 4);
  }

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

  .right-0 {
    right: calc(var(--spacing) * 0);
  }

  .right-2 {
    right: calc(var(--spacing) * 2);
  }

  .right-4 {
    right: calc(var(--spacing) * 4);
  }

  .right-6 {
    right: calc(var(--spacing) * 6);
  }

  .bottom-0 {
    bottom: calc(var(--spacing) * 0);
  }

  .bottom-1 {
    bottom: calc(var(--spacing) * 1);
  }

  .bottom-4 {
    bottom: calc(var(--spacing) * 4);
  }

  .bottom-6 {
    bottom: calc(var(--spacing) * 6);
  }

  .left-0 {
    left: calc(var(--spacing) * 0);
  }

  .left-1 {
    left: calc(var(--spacing) * 1);
  }

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

  .left-2 {
    left: calc(var(--spacing) * 2);
  }

  .left-3 {
    left: calc(var(--spacing) * 3);
  }

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

  .left-full {
    left: 100%;
  }

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

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

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

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

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

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

  .col-start-2 {
    grid-column-start: 2;
  }

  .row-span-2 {
    grid-row: span 2 / span 2;
  }

  .row-start-1 {
    grid-row-start: 1;
  }

  .container {
    width: 100%;
  }

  @media (width >= 40rem) {
    .container {
      max-width: 40rem;
    }
  }

  @media (width >= 48rem) {
    .container {
      max-width: 48rem;
    }
  }

  @media (width >= 64rem) {
    .container {
      max-width: 64rem;
    }
  }

  @media (width >= 80rem) {
    .container {
      max-width: 80rem;
    }
  }

  @media (width >= 96rem) {
    .container {
      max-width: 96rem;
    }
  }

  .-mx-1 {
    margin-inline: calc(var(--spacing) * -1);
  }

  .mx-4 {
    margin-inline: calc(var(--spacing) * 4);
  }

  .mx-auto {
    margin-inline: auto;
  }

  .my-1 {
    margin-block: calc(var(--spacing) * 1);
  }

  .my-2 {
    margin-block: calc(var(--spacing) * 2);
  }

  .my-4 {
    margin-block: calc(var(--spacing) * 4);
  }

  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }

  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }

  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }

  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }

  .mt-8 {
    margin-top: calc(var(--spacing) * 8);
  }

  .mt-12 {
    margin-top: calc(var(--spacing) * 12);
  }

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

  .mr-1 {
    margin-right: calc(var(--spacing) * 1);
  }

  .mr-2 {
    margin-right: calc(var(--spacing) * 2);
  }

  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }

  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }

  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }

  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }

  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }

  .ml-1 {
    margin-left: calc(var(--spacing) * 1);
  }

  .ml-2 {
    margin-left: calc(var(--spacing) * 2);
  }

  .ml-6 {
    margin-left: calc(var(--spacing) * 6);
  }

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

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

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

  .block {
    display: block;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

  .inline {
    display: inline;
  }

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

  .table {
    display: table;
  }

  .table-caption {
    display: table-caption;
  }

  .table-cell {
    display: table-cell;
  }

  .table-row {
    display: table-row;
  }

  .field-sizing-content {
    field-sizing: content;
  }

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

  .size-2 {
    width: calc(var(--spacing) * 2);
    height: calc(var(--spacing) * 2);
  }

  .size-2\.5 {
    width: calc(var(--spacing) * 2.5);
    height: calc(var(--spacing) * 2.5);
  }

  .size-3\.5 {
    width: calc(var(--spacing) * 3.5);
    height: calc(var(--spacing) * 3.5);
  }

  .size-4 {
    width: calc(var(--spacing) * 4);
    height: calc(var(--spacing) * 4);
  }

  .size-9 {
    width: calc(var(--spacing) * 9);
    height: calc(var(--spacing) * 9);
  }

  .size-10 {
    width: calc(var(--spacing) * 10);
    height: calc(var(--spacing) * 10);
  }

  .size-full {
    width: 100%;
    height: 100%;
  }

  .h-1\.5 {
    height: calc(var(--spacing) * 1.5);
  }

  .h-2 {
    height: calc(var(--spacing) * 2);
  }

  .h-2\.5 {
    height: calc(var(--spacing) * 2.5);
  }

  .h-3 {
    height: calc(var(--spacing) * 3);
  }

  .h-4 {
    height: calc(var(--spacing) * 4);
  }

  .h-5 {
    height: calc(var(--spacing) * 5);
  }

  .h-6 {
    height: calc(var(--spacing) * 6);
  }

  .h-8 {
    height: calc(var(--spacing) * 8);
  }

  .h-9 {
    height: calc(var(--spacing) * 9);
  }

  .h-10 {
    height: calc(var(--spacing) * 10);
  }

  .h-12 {
    height: calc(var(--spacing) * 12);
  }

  .h-16 {
    height: calc(var(--spacing) * 16);
  }

  .h-24 {
    height: calc(var(--spacing) * 24);
  }

  .h-\[1\.15rem\] {
    height: 1.15rem;
  }

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

  .h-\[calc\(100\%-1px\)\] {
    height: calc(100% - 1px);
  }

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

  .h-auto {
    height: auto;
  }

  .h-full {
    height: 100%;
  }

  .h-px {
    height: 1px;
  }

  .h-screen {
    height: 100vh;
  }

  .max-h-\(--radix-dropdown-menu-content-available-height\) {
    max-height: var(--radix-dropdown-menu-content-available-height);
  }

  .max-h-\(--radix-select-content-available-height\) {
    max-height: var(--radix-select-content-available-height);
  }

  .max-h-64 {
    max-height: calc(var(--spacing) * 64);
  }

  .max-h-96 {
    max-height: calc(var(--spacing) * 96);
  }

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

  .min-h-16 {
    min-height: calc(var(--spacing) * 16);
  }

  .min-h-48 {
    min-height: calc(var(--spacing) * 48);
  }

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

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

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

  .w-1\.5 {
    width: calc(var(--spacing) * 1.5);
  }

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

  .w-2 {
    width: calc(var(--spacing) * 2);
  }

  .w-2\.5 {
    width: calc(var(--spacing) * 2.5);
  }

  .w-3 {
    width: calc(var(--spacing) * 3);
  }

  .w-4 {
    width: calc(var(--spacing) * 4);
  }

  .w-5 {
    width: calc(var(--spacing) * 5);
  }

  .w-6 {
    width: calc(var(--spacing) * 6);
  }

  .w-8 {
    width: calc(var(--spacing) * 8);
  }

  .w-10 {
    width: calc(var(--spacing) * 10);
  }

  .w-12 {
    width: calc(var(--spacing) * 12);
  }

  .w-16 {
    width: calc(var(--spacing) * 16);
  }

  .w-20 {
    width: calc(var(--spacing) * 20);
  }

  .w-24 {
    width: calc(var(--spacing) * 24);
  }

  .w-32 {
    width: calc(var(--spacing) * 32);
  }

  .w-36 {
    width: calc(var(--spacing) * 36);
  }

  .w-40 {
    width: calc(var(--spacing) * 40);
  }

  .w-48 {
    width: calc(var(--spacing) * 48);
  }

  .w-64 {
    width: calc(var(--spacing) * 64);
  }

  .w-80 {
    width: calc(var(--spacing) * 80);
  }

  .w-auto {
    width: auto;
  }

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

  .w-full {
    width: 100%;
  }

  .w-px {
    width: 1px;
  }

  .max-w-2xl {
    max-width: var(--container-2xl);
  }

  .max-w-3xl {
    max-width: var(--container-3xl);
  }

  .max-w-4xl {
    max-width: var(--container-4xl);
  }

  .max-w-7xl {
    max-width: var(--container-7xl);
  }

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

  .max-w-md {
    max-width: var(--container-md);
  }

  .min-w-0 {
    min-width: calc(var(--spacing) * 0);
  }

  .min-w-32 {
    min-width: calc(var(--spacing) * 32);
  }

  .min-w-48 {
    min-width: calc(var(--spacing) * 48);
  }

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

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

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

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

  .flex-1 {
    flex: 1;
  }

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

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

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

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

  .border-spacing-0 {
    --tw-border-spacing-x: calc(var(--spacing) * 0);
    --tw-border-spacing-y: calc(var(--spacing) * 0);
    border-spacing: var(--tw-border-spacing-x) var(--tw-border-spacing-y);
  }

  .origin-\(--radix-dropdown-menu-content-transform-origin\) {
    transform-origin: var(--radix-dropdown-menu-content-transform-origin);
  }

  .origin-\(--radix-select-content-transform-origin\) {
    transform-origin: var(--radix-select-content-transform-origin);
  }

  .origin-\(--radix-tooltip-content-transform-origin\) {
    transform-origin: var(--radix-tooltip-content-transform-origin);
  }

  .-translate-x-1\/2 {
    --tw-translate-x: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .-translate-x-full {
    --tw-translate-x: -100%;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .translate-x-0 {
    --tw-translate-x: calc(var(--spacing) * 0);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .translate-x-\[-50\%\] {
    --tw-translate-x: -50%;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .-translate-y-1\/2 {
    --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .translate-y-\[-50\%\] {
    --tw-translate-y: -50%;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .translate-y-\[calc\(-50\%_-_2px\)\] {
    --tw-translate-y: calc(-50% - 2px);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .rotate-45 {
    rotate: 45deg;
  }

  .transform {
    transform: var(--tw-rotate-x) var(--tw-rotate-y) var(--tw-rotate-z) var(--tw-skew-x) var(--tw-skew-y);
  }

  .animate-in {
    animation: enter var(--tw-duration, .15s) var(--tw-ease, ease);
  }

  .cursor-default {
    cursor: default;
  }

  .cursor-grab {
    cursor: grab;
  }

  .cursor-move {
    cursor: move;
  }

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

  .cursor-pointer {
    cursor: pointer;
  }

  .cursor-se-resize {
    cursor: se-resize;
  }

  .resize {
    resize: both;
  }

  .resize-none {
    resize: none;
  }

  .scroll-my-1 {
    scroll-margin-block: calc(var(--spacing) * 1);
  }

  .appearance-none {
    appearance: none;
  }

  .auto-rows-min {
    grid-auto-rows: min-content;
  }

  .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-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }

  .grid-rows-\[auto_auto\] {
    grid-template-rows: auto auto;
  }

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

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

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

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

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

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

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

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

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

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

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

  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }

  .gap-1\.5 {
    gap: calc(var(--spacing) * 1.5);
  }

  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }

  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }

  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }

  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }

  .gap-8 {
    gap: calc(var(--spacing) * 8);
  }

  :where(.space-y-0 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 0) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 0) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-1 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-2 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-3 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-4 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-5 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 5) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 5) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-6 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.-space-x-1 > :not(:last-child)) {
    --tw-space-x-reverse: 0;
    margin-inline-start: calc(calc(var(--spacing) * -1) * var(--tw-space-x-reverse));
    margin-inline-end: calc(calc(var(--spacing) * -1) * calc(1 - var(--tw-space-x-reverse)));
  }

  :where(.space-x-2 > :not(:last-child)) {
    --tw-space-x-reverse: 0;
    margin-inline-start: calc(calc(var(--spacing) * 2) * var(--tw-space-x-reverse));
    margin-inline-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-x-reverse)));
  }

  :where(.space-x-3 > :not(:last-child)) {
    --tw-space-x-reverse: 0;
    margin-inline-start: calc(calc(var(--spacing) * 3) * var(--tw-space-x-reverse));
    margin-inline-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-x-reverse)));
  }

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

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

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

  .overflow-auto {
    overflow: auto;
  }

  .overflow-hidden {
    overflow: hidden;
  }

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

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

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

  .rounded {
    border-radius: .25rem;
  }

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

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

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

  .rounded-full {
    border-radius: 3.40282e38px;
  }

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

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

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

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

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

  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }

  .border-0 {
    border-style: var(--tw-border-style);
    border-width: 0;
  }

  .border-2 {
    border-style: var(--tw-border-style);
    border-width: 2px;
  }

  .border-y-2 {
    border-block-style: var(--tw-border-style);
    border-block-width: 2px;
  }

  .border-t {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }

  .border-t-2 {
    border-top-style: var(--tw-border-style);
    border-top-width: 2px;
  }

  .border-t-4 {
    border-top-style: var(--tw-border-style);
    border-top-width: 4px;
  }

  .border-r {
    border-right-style: var(--tw-border-style);
    border-right-width: 1px;
  }

  .border-b {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }

  .border-b-2 {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 2px;
  }

  .border-l-4 {
    border-left-style: var(--tw-border-style);
    border-left-width: 4px;
  }

  .border-dashed {
    --tw-border-style: dashed;
    border-style: dashed;
  }

  .border-none {
    --tw-border-style: none;
    border-style: none;
  }

  .border-\[\#F2CC8F\] {
    border-color: #f2cc8f;
  }

  .border-border {
    border-color: var(--border);
  }

  .border-current {
    border-color: currentColor;
  }

  .border-gray-100 {
    border-color: var(--color-gray-100);
  }

  .border-gray-200 {
    border-color: var(--color-gray-200);
  }

  .border-gray-300 {
    border-color: var(--color-gray-300);
  }

  .border-green-200 {
    border-color: var(--color-green-200);
  }

  .border-input {
    border-color: var(--input);
  }

  .border-red-200 {
    border-color: var(--color-red-200);
  }

  .border-sidebar-border {
    border-color: var(--sidebar-border);
  }

  .border-sidebar-module-calculators {
    border-color: var(--sidebar-module-calculators);
  }

  .border-sidebar-module-calculators\/20 {
    border-color: var(--sidebar-module-calculators);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-sidebar-module-calculators\/20 {
      border-color: color-mix(in oklab, var(--sidebar-module-calculators) 20%, transparent);
    }
  }

  .border-sidebar-module-library {
    border-color: var(--sidebar-module-library);
  }

  .border-sidebar-module-library\/20 {
    border-color: var(--sidebar-module-library);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-sidebar-module-library\/20 {
      border-color: color-mix(in oklab, var(--sidebar-module-library) 20%, transparent);
    }
  }

  .border-sidebar-module-piping {
    border-color: var(--sidebar-module-piping);
  }

  .border-sidebar-module-piping\/20 {
    border-color: var(--sidebar-module-piping);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-sidebar-module-piping\/20 {
      border-color: color-mix(in oklab, var(--sidebar-module-piping) 20%, transparent);
    }
  }

  .border-sidebar-module-project-boards {
    border-color: var(--sidebar-module-project-boards);
  }

  .border-sidebar-module-structural {
    border-color: var(--sidebar-module-structural);
  }

  .border-sidebar-module-structural-foreground\/20 {
    border-color: var(--sidebar-module-structural-foreground);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-sidebar-module-structural-foreground\/20 {
      border-color: color-mix(in oklab, var(--sidebar-module-structural-foreground) 20%, transparent);
    }
  }

  .border-sidebar-module-structural\/20 {
    border-color: var(--sidebar-module-structural);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-sidebar-module-structural\/20 {
      border-color: color-mix(in oklab, var(--sidebar-module-structural) 20%, transparent);
    }
  }

  .border-transparent {
    border-color: #0000;
  }

  .border-white {
    border-color: var(--color-white);
  }

  .border-yellow-200 {
    border-color: var(--color-yellow-200);
  }

  .border-l-sidebar-module-structural {
    border-left-color: var(--sidebar-module-structural);
  }

  .bg-\[\#F2CC8F\] {
    background-color: #f2cc8f;
  }

  .bg-accent {
    background-color: var(--accent);
  }

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

  .bg-black\/50 {
    background-color: #00000080;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-black\/50 {
      background-color: color-mix(in oklab, var(--color-black) 50%, transparent);
    }
  }

  .bg-blue-50 {
    background-color: var(--color-blue-50);
  }

  .bg-blue-100 {
    background-color: var(--color-blue-100);
  }

  .bg-blue-500 {
    background-color: var(--color-blue-500);
  }

  .bg-border {
    background-color: var(--border);
  }

  .bg-card {
    background-color: var(--card);
  }

  .bg-destructive {
    background-color: var(--destructive);
  }

  .bg-gray-50 {
    background-color: var(--color-gray-50);
  }

  .bg-gray-100 {
    background-color: var(--color-gray-100);
  }

  .bg-gray-300 {
    background-color: var(--color-gray-300);
  }

  .bg-green-50 {
    background-color: var(--color-green-50);
  }

  .bg-green-100 {
    background-color: var(--color-green-100);
  }

  .bg-green-500 {
    background-color: var(--color-green-500);
  }

  .bg-input-background {
    background-color: var(--input-background);
  }

  .bg-muted {
    background-color: var(--muted);
  }

  .bg-muted\/30 {
    background-color: var(--muted);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-muted\/30 {
      background-color: color-mix(in oklab, var(--muted) 30%, transparent);
    }
  }

  .bg-muted\/50 {
    background-color: var(--muted);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-muted\/50 {
      background-color: color-mix(in oklab, var(--muted) 50%, transparent);
    }
  }

  .bg-orange-500 {
    background-color: var(--color-orange-500);
  }

  .bg-popover {
    background-color: var(--popover);
  }

  .bg-primary {
    background-color: var(--primary);
  }

  .bg-purple-500 {
    background-color: var(--color-purple-500);
  }

  .bg-red-50 {
    background-color: var(--color-red-50);
  }

  .bg-secondary {
    background-color: var(--secondary);
  }

  .bg-sidebar {
    background-color: var(--sidebar);
  }

  .bg-sidebar-foreground {
    background-color: var(--sidebar-foreground);
  }

  .bg-sidebar-module-calculators\/5 {
    background-color: var(--sidebar-module-calculators);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-sidebar-module-calculators\/5 {
      background-color: color-mix(in oklab, var(--sidebar-module-calculators) 5%, transparent);
    }
  }

  .bg-sidebar-module-calculators\/10 {
    background-color: var(--sidebar-module-calculators);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-sidebar-module-calculators\/10 {
      background-color: color-mix(in oklab, var(--sidebar-module-calculators) 10%, transparent);
    }
  }

  .bg-sidebar-module-deliverables {
    background-color: var(--sidebar-module-deliverables);
  }

  .bg-sidebar-module-engineering {
    background-color: var(--sidebar-module-engineering);
  }

  .bg-sidebar-module-library\/5 {
    background-color: var(--sidebar-module-library);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-sidebar-module-library\/5 {
      background-color: color-mix(in oklab, var(--sidebar-module-library) 5%, transparent);
    }
  }

  .bg-sidebar-module-library\/10 {
    background-color: var(--sidebar-module-library);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-sidebar-module-library\/10 {
      background-color: color-mix(in oklab, var(--sidebar-module-library) 10%, transparent);
    }
  }

  .bg-sidebar-module-mep {
    background-color: var(--sidebar-module-mep);
  }

  .bg-sidebar-module-piping {
    background-color: var(--sidebar-module-piping);
  }

  .bg-sidebar-module-piping\/5 {
    background-color: var(--sidebar-module-piping);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-sidebar-module-piping\/5 {
      background-color: color-mix(in oklab, var(--sidebar-module-piping) 5%, transparent);
    }
  }

  .bg-sidebar-module-piping\/10 {
    background-color: var(--sidebar-module-piping);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-sidebar-module-piping\/10 {
      background-color: color-mix(in oklab, var(--sidebar-module-piping) 10%, transparent);
    }
  }

  .bg-sidebar-module-project-boards {
    background-color: var(--sidebar-module-project-boards);
  }

  .bg-sidebar-module-rc {
    background-color: var(--sidebar-module-rc);
  }

  .bg-sidebar-module-structural {
    background-color: var(--sidebar-module-structural);
  }

  .bg-sidebar-module-structural-sub {
    background-color: var(--sidebar-module-structural-sub);
  }

  .bg-sidebar-module-structural\/5 {
    background-color: var(--sidebar-module-structural);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-sidebar-module-structural\/5 {
      background-color: color-mix(in oklab, var(--sidebar-module-structural) 5%, transparent);
    }
  }

  .bg-sidebar-module-structural\/10 {
    background-color: var(--sidebar-module-structural);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-sidebar-module-structural\/10 {
      background-color: color-mix(in oklab, var(--sidebar-module-structural) 10%, transparent);
    }
  }

  .bg-transparent {
    background-color: #0000;
  }

  .bg-white {
    background-color: var(--color-white);
  }

  .bg-yellow-50 {
    background-color: var(--color-yellow-50);
  }

  .bg-yellow-100 {
    background-color: var(--color-yellow-100);
  }

  .fill-current {
    fill: currentColor;
  }

  .fill-primary {
    fill: var(--primary);
  }

  .p-0 {
    padding: calc(var(--spacing) * 0);
  }

  .p-1 {
    padding: calc(var(--spacing) * 1);
  }

  .p-2 {
    padding: calc(var(--spacing) * 2);
  }

  .p-3 {
    padding: calc(var(--spacing) * 3);
  }

  .p-4 {
    padding: calc(var(--spacing) * 4);
  }

  .p-6 {
    padding: calc(var(--spacing) * 6);
  }

  .p-8 {
    padding: calc(var(--spacing) * 8);
  }

  .p-\[3px\] {
    padding: 3px;
  }

  .px-1 {
    padding-inline: calc(var(--spacing) * 1);
  }

  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }

  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }

  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }

  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }

  .py-0\.5 {
    padding-block: calc(var(--spacing) * .5);
  }

  .py-1 {
    padding-block: calc(var(--spacing) * 1);
  }

  .py-1\.5 {
    padding-block: calc(var(--spacing) * 1.5);
  }

  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }

  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }

  .py-4 {
    padding-block: calc(var(--spacing) * 4);
  }

  .py-6 {
    padding-block: calc(var(--spacing) * 6);
  }

  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }

  .py-12 {
    padding-block: calc(var(--spacing) * 12);
  }

  .pt-2 {
    padding-top: calc(var(--spacing) * 2);
  }

  .pt-4 {
    padding-top: calc(var(--spacing) * 4);
  }

  .pt-6 {
    padding-top: calc(var(--spacing) * 6);
  }

  .pr-2 {
    padding-right: calc(var(--spacing) * 2);
  }

  .pr-8 {
    padding-right: calc(var(--spacing) * 8);
  }

  .pb-1 {
    padding-bottom: calc(var(--spacing) * 1);
  }

  .pb-2 {
    padding-bottom: calc(var(--spacing) * 2);
  }

  .pb-3 {
    padding-bottom: calc(var(--spacing) * 3);
  }

  .pb-4 {
    padding-bottom: calc(var(--spacing) * 4);
  }

  .pb-6 {
    padding-bottom: calc(var(--spacing) * 6);
  }

  .pb-20 {
    padding-bottom: calc(var(--spacing) * 20);
  }

  .pl-2 {
    padding-left: calc(var(--spacing) * 2);
  }

  .pl-6 {
    padding-left: calc(var(--spacing) * 6);
  }

  .pl-8 {
    padding-left: calc(var(--spacing) * 8);
  }

  .pl-10 {
    padding-left: calc(var(--spacing) * 10);
  }

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

  .text-left {
    text-align: left;
  }

  .text-right {
    text-align: right;
  }

  .align-middle {
    vertical-align: middle;
  }

  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }

  .text-3xl {
    font-size: var(--text-3xl);
    line-height: var(--tw-leading, var(--text-3xl--line-height));
  }

  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }

  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }

  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }

  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }

  .leading-none {
    --tw-leading: 1;
    line-height: 1;
  }

  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }

  .leading-tight {
    --tw-leading: var(--leading-tight);
    line-height: var(--leading-tight);
  }

  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }

  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }

  .font-normal {
    --tw-font-weight: var(--font-weight-normal);
    font-weight: var(--font-weight-normal);
  }

  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }

  .tracking-wide {
    --tw-tracking: var(--tracking-wide);
    letter-spacing: var(--tracking-wide);
  }

  .tracking-widest {
    --tw-tracking: var(--tracking-widest);
    letter-spacing: var(--tracking-widest);
  }

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

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

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

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

  .text-\[\#F2CC8F\] {
    color: #f2cc8f;
  }

  .text-\[var\(--color-sidebar-module-calculators\)\] {
    color: var(--color-sidebar-module-calculators);
  }

  .text-\[var\(--color-sidebar-module-piping\)\] {
    color: var(--color-sidebar-module-piping);
  }

  .text-\[var\(--color-sidebar-module-structural\)\] {
    color: var(--color-sidebar-module-structural);
  }

  .text-black {
    color: var(--color-black);
  }

  .text-blue-800 {
    color: var(--color-blue-800);
  }

  .text-card-foreground {
    color: var(--card-foreground);
  }

  .text-current {
    color: currentColor;
  }

  .text-destructive {
    color: var(--destructive);
  }

  .text-destructive-foreground {
    color: var(--destructive-foreground);
  }

  .text-foreground {
    color: var(--foreground);
  }

  .text-gray-400 {
    color: var(--color-gray-400);
  }

  .text-gray-500 {
    color: var(--color-gray-500);
  }

  .text-gray-600 {
    color: var(--color-gray-600);
  }

  .text-gray-700 {
    color: var(--color-gray-700);
  }

  .text-gray-800 {
    color: var(--color-gray-800);
  }

  .text-gray-900 {
    color: var(--color-gray-900);
  }

  .text-green-600 {
    color: var(--color-green-600);
  }

  .text-green-700 {
    color: var(--color-green-700);
  }

  .text-green-800 {
    color: var(--color-green-800);
  }

  .text-muted-foreground {
    color: var(--muted-foreground);
  }

  .text-popover-foreground {
    color: var(--popover-foreground);
  }

  .text-primary {
    color: var(--primary);
  }

  .text-primary-foreground {
    color: var(--primary-foreground);
  }

  .text-red-600 {
    color: var(--color-red-600);
  }

  .text-red-700 {
    color: var(--color-red-700);
  }

  .text-secondary-foreground {
    color: var(--secondary-foreground);
  }

  .text-sidebar {
    color: var(--sidebar);
  }

  .text-sidebar-foreground {
    color: var(--sidebar-foreground);
  }

  .text-sidebar-module-calculators {
    color: var(--sidebar-module-calculators);
  }

  .text-sidebar-module-library {
    color: var(--sidebar-module-library);
  }

  .text-sidebar-module-piping {
    color: var(--sidebar-module-piping);
  }

  .text-sidebar-module-project-boards-foreground {
    color: var(--sidebar-module-project-boards-foreground);
  }

  .text-sidebar-module-structural {
    color: var(--sidebar-module-structural);
  }

  .text-sidebar-module-structural-foreground {
    color: var(--sidebar-module-structural-foreground);
  }

  .text-white {
    color: var(--color-white);
  }

  .text-yellow-500 {
    color: var(--color-yellow-500);
  }

  .text-yellow-700 {
    color: var(--color-yellow-700);
  }

  .text-yellow-800 {
    color: var(--color-yellow-800);
  }

  .capitalize {
    text-transform: capitalize;
  }

  .uppercase {
    text-transform: uppercase;
  }

  .italic {
    font-style: italic;
  }

  .underline-offset-4 {
    text-underline-offset: 4px;
  }

  .placeholder-gray-500::placeholder {
    color: var(--color-gray-500);
  }

  .opacity-0 {
    opacity: 0;
  }

  .opacity-30 {
    opacity: .3;
  }

  .opacity-50 {
    opacity: .5;
  }

  .opacity-60 {
    opacity: .6;
  }

  .opacity-70 {
    opacity: .7;
  }

  .opacity-75 {
    opacity: .75;
  }

  .shadow-lg {
    --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, #0000001a), 0 4px 6px -4px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-md {
    --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, #0000001a), 0 2px 4px -2px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-none {
    --tw-shadow: 0 0 #0000;
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-sm {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-xs {
    --tw-shadow: 0 1px 2px 0 var(--tw-shadow-color, #0000000d);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .ring {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .ring-0 {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .ring-3 {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .ring-white {
    --tw-ring-color: var(--color-white);
  }

  .ring-offset-background {
    --tw-ring-offset-color: var(--background);
  }

  .outline-hidden {
    --tw-outline-style: none;
    outline-style: none;
  }

  @media (forced-colors: active) {
    .outline-hidden {
      outline-offset: 2px;
      outline: 2px solid #0000;
    }
  }

  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }

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

  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-\[color\,box-shadow\] {
    transition-property: color, box-shadow;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-colors {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-opacity {
    transition-property: opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-shadow {
    transition-property: box-shadow;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-transform {
    transition-property: transform, translate, scale, rotate;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-none {
    transition-property: none;
  }

  .duration-150 {
    --tw-duration: .15s;
    transition-duration: .15s;
  }

  .duration-200 {
    --tw-duration: .2s;
    transition-duration: .2s;
  }

  .duration-300 {
    --tw-duration: .3s;
    transition-duration: .3s;
  }

  .ease-in-out {
    --tw-ease: var(--ease-in-out);
    transition-timing-function: var(--ease-in-out);
  }

  .ease-out {
    --tw-ease: var(--ease-out);
    transition-timing-function: var(--ease-out);
  }

  .outline-none {
    --tw-outline-style: none;
    outline-style: none;
  }

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

  .fade-in-0 {
    --tw-enter-opacity: 0;
  }

  .zoom-in-95 {
    --tw-enter-scale: .95;
  }

  @media (hover: hover) {
    .group-hover\:bg-sidebar-module-calculators-sub:is(:where(.group):hover *) {
      background-color: var(--sidebar-module-calculators-sub);
    }
  }

  @media (hover: hover) {
    .group-hover\:bg-sidebar-module-library-sub:is(:where(.group):hover *) {
      background-color: var(--sidebar-module-library-sub);
    }
  }

  @media (hover: hover) {
    .group-hover\:bg-sidebar-module-piping-sub:is(:where(.group):hover *) {
      background-color: var(--sidebar-module-piping-sub);
    }
  }

  @media (hover: hover) {
    .group-hover\:bg-sidebar-module-structural-sub:is(:where(.group):hover *) {
      background-color: var(--sidebar-module-structural-sub);
    }
  }

  @media (hover: hover) {
    .group-hover\:text-foreground:is(:where(.group):hover *) {
      color: var(--foreground);
    }
  }

  @media (hover: hover) {
    .group-hover\:text-sidebar-module-calculators:is(:where(.group):hover *) {
      color: var(--sidebar-module-calculators);
    }
  }

  @media (hover: hover) {
    .group-hover\:text-sidebar-module-library:is(:where(.group):hover *) {
      color: var(--sidebar-module-library);
    }
  }

  @media (hover: hover) {
    .group-hover\:text-sidebar-module-piping:is(:where(.group):hover *) {
      color: var(--sidebar-module-piping);
    }
  }

  @media (hover: hover) {
    .group-hover\:text-sidebar-module-structural:is(:where(.group):hover *) {
      color: var(--sidebar-module-structural);
    }
  }

  @media (hover: hover) {
    .group-hover\:opacity-100:is(:where(.group):hover *) {
      opacity: 1;
    }
  }

  .group-data-\[disabled\=true\]\:pointer-events-none:is(:where(.group)[data-disabled="true"] *) {
    pointer-events: none;
  }

  .group-data-\[disabled\=true\]\:opacity-50:is(:where(.group)[data-disabled="true"] *) {
    opacity: .5;
  }

  .peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled ~ *) {
    cursor: not-allowed;
  }

  .peer-disabled\:opacity-50:is(:where(.peer):disabled ~ *) {
    opacity: .5;
  }

  .selection\:bg-primary ::selection, .selection\:bg-primary::selection {
    background-color: var(--primary);
  }

  .selection\:text-primary-foreground ::selection, .selection\:text-primary-foreground::selection {
    color: var(--primary-foreground);
  }

  .file\:inline-flex::file-selector-button {
    display: inline-flex;
  }

  .file\:h-7::file-selector-button {
    height: calc(var(--spacing) * 7);
  }

  .file\:border-0::file-selector-button {
    border-style: var(--tw-border-style);
    border-width: 0;
  }

  .file\:bg-transparent::file-selector-button {
    background-color: #0000;
  }

  .file\:text-sm::file-selector-button {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }

  .file\:font-medium::file-selector-button {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }

  .file\:text-foreground::file-selector-button {
    color: var(--foreground);
  }

  .placeholder\:text-muted-foreground::placeholder {
    color: var(--muted-foreground);
  }

  .focus-within\:ring-2:focus-within {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .focus-within\:ring-sidebar-module-calculators:focus-within {
    --tw-ring-color: var(--sidebar-module-calculators);
  }

  .focus-within\:ring-sidebar-module-library:focus-within {
    --tw-ring-color: var(--sidebar-module-library);
  }

  .focus-within\:ring-sidebar-module-piping:focus-within {
    --tw-ring-color: var(--sidebar-module-piping);
  }

  .focus-within\:ring-sidebar-module-structural:focus-within {
    --tw-ring-color: var(--sidebar-module-structural);
  }

  .focus-within\:ring-offset-2:focus-within {
    --tw-ring-offset-width: 2px;
    --tw-ring-offset-shadow: var(--tw-ring-inset, ) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  }

  @media (hover: hover) {
    .hover\:border-gray-300:hover {
      border-color: var(--color-gray-300);
    }
  }

  @media (hover: hover) {
    .hover\:border-gray-400:hover {
      border-color: var(--color-gray-400);
    }
  }

  @media (hover: hover) {
    .hover\:border-sidebar-module-calculators:hover {
      border-color: var(--sidebar-module-calculators);
    }
  }

  @media (hover: hover) {
    .hover\:border-sidebar-module-calculators\/50:hover {
      border-color: var(--sidebar-module-calculators);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:border-sidebar-module-calculators\/50:hover {
        border-color: color-mix(in oklab, var(--sidebar-module-calculators) 50%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:border-sidebar-module-library:hover {
      border-color: var(--sidebar-module-library);
    }
  }

  @media (hover: hover) {
    .hover\:border-sidebar-module-piping:hover {
      border-color: var(--sidebar-module-piping);
    }
  }

  @media (hover: hover) {
    .hover\:border-sidebar-module-structural:hover {
      border-color: var(--sidebar-module-structural);
    }
  }

  @media (hover: hover) {
    .hover\:bg-\[\#F8E4C3\]:hover {
      background-color: #f8e4c3;
    }
  }

  @media (hover: hover) {
    .hover\:bg-accent:hover {
      background-color: var(--accent);
    }
  }

  @media (hover: hover) {
    .hover\:bg-destructive\/90:hover {
      background-color: var(--destructive);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-destructive\/90:hover {
        background-color: color-mix(in oklab, var(--destructive) 90%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-gray-50:hover {
      background-color: var(--color-gray-50);
    }
  }

  @media (hover: hover) {
    .hover\:bg-gray-100:hover {
      background-color: var(--color-gray-100);
    }
  }

  @media (hover: hover) {
    .hover\:bg-muted\/30:hover {
      background-color: var(--muted);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-muted\/30:hover {
        background-color: color-mix(in oklab, var(--muted) 30%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-muted\/50:hover {
      background-color: var(--muted);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-muted\/50:hover {
        background-color: color-mix(in oklab, var(--muted) 50%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-primary\/90:hover {
      background-color: var(--primary);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-primary\/90:hover {
        background-color: color-mix(in oklab, var(--primary) 90%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-red-100:hover {
      background-color: var(--color-red-100);
    }
  }

  @media (hover: hover) {
    .hover\:bg-secondary\/80:hover {
      background-color: var(--secondary);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-secondary\/80:hover {
        background-color: color-mix(in oklab, var(--secondary) 80%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-sidebar-accent:hover {
      background-color: var(--sidebar-accent);
    }
  }

  @media (hover: hover) {
    .hover\:bg-sidebar-accent\/60:hover {
      background-color: var(--sidebar-accent);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-sidebar-accent\/60:hover {
        background-color: color-mix(in oklab, var(--sidebar-accent) 60%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-sidebar-module-project-boards-hover:hover {
      background-color: var(--sidebar-module-project-boards-hover);
    }
  }

  @media (hover: hover) {
    .hover\:text-\[\#D9B578\]:hover {
      color: #d9b578;
    }
  }

  @media (hover: hover) {
    .hover\:text-accent-foreground:hover {
      color: var(--accent-foreground);
    }
  }

  @media (hover: hover) {
    .hover\:text-destructive:hover {
      color: var(--destructive);
    }
  }

  @media (hover: hover) {
    .hover\:text-foreground:hover {
      color: var(--foreground);
    }
  }

  @media (hover: hover) {
    .hover\:text-gray-600:hover {
      color: var(--color-gray-600);
    }
  }

  @media (hover: hover) {
    .hover\:text-gray-700:hover {
      color: var(--color-gray-700);
    }
  }

  @media (hover: hover) {
    .hover\:text-gray-800:hover {
      color: var(--color-gray-800);
    }
  }

  @media (hover: hover) {
    .hover\:text-gray-900:hover {
      color: var(--color-gray-900);
    }
  }

  @media (hover: hover) {
    .hover\:underline:hover {
      text-decoration-line: underline;
    }
  }

  @media (hover: hover) {
    .hover\:opacity-100:hover {
      opacity: 1;
    }
  }

  @media (hover: hover) {
    .hover\:shadow-lg:hover {
      --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, #0000001a), 0 4px 6px -4px var(--tw-shadow-color, #0000001a);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }

  @media (hover: hover) {
    .hover\:shadow-sm:hover {
      --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }

  @media (hover: hover) {
    .hover\:brightness-110:hover {
      --tw-brightness: brightness(110%);
      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, );
    }
  }

  .focus\:border:focus {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }

  .focus\:border-\[\#F2CC8F\]:focus {
    border-color: #f2cc8f;
  }

  .focus\:bg-accent:focus {
    background-color: var(--accent);
  }

  .focus\:bg-white:focus {
    background-color: var(--color-white);
  }

  .focus\:px-2:focus {
    padding-inline: calc(var(--spacing) * 2);
  }

  .focus\:py-1:focus {
    padding-block: calc(var(--spacing) * 1);
  }

  .focus\:text-accent-foreground:focus {
    color: var(--accent-foreground);
  }

  .focus\:ring-0:focus {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .focus\:ring-2:focus {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .focus\:ring-ring:focus {
    --tw-ring-color: var(--ring);
  }

  .focus\:ring-offset-2:focus {
    --tw-ring-offset-width: 2px;
    --tw-ring-offset-shadow: var(--tw-ring-inset, ) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  }

  .focus\:outline-hidden:focus {
    --tw-outline-style: none;
    outline-style: none;
  }

  @media (forced-colors: active) {
    .focus\:outline-hidden:focus {
      outline-offset: 2px;
      outline: 2px solid #0000;
    }
  }

  .focus\:outline-none:focus {
    --tw-outline-style: none;
    outline-style: none;
  }

  .focus-visible\:border-ring:focus-visible {
    border-color: var(--ring);
  }

  .focus-visible\:ring-\[3px\]:focus-visible {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .focus-visible\:ring-destructive\/20:focus-visible {
    --tw-ring-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .focus-visible\:ring-destructive\/20:focus-visible {
      --tw-ring-color: color-mix(in oklab, var(--destructive) 20%, transparent);
    }
  }

  .focus-visible\:ring-ring\/50:focus-visible {
    --tw-ring-color: var(--ring);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .focus-visible\:ring-ring\/50:focus-visible {
      --tw-ring-color: color-mix(in oklab, var(--ring) 50%, transparent);
    }
  }

  .focus-visible\:outline-1:focus-visible {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }

  .focus-visible\:outline-ring:focus-visible {
    outline-color: var(--ring);
  }

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

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

  .disabled\:opacity-50:disabled {
    opacity: .5;
  }

  .has-data-\[slot\=card-action\]\:grid-cols-\[1fr_auto\]:has([data-slot="card-action"]) {
    grid-template-columns: 1fr auto;
  }

  .has-\[\>svg\]\:px-2\.5:has( > svg) {
    padding-inline: calc(var(--spacing) * 2.5);
  }

  .has-\[\>svg\]\:px-3:has( > svg) {
    padding-inline: calc(var(--spacing) * 3);
  }

  .has-\[\>svg\]\:px-4:has( > svg) {
    padding-inline: calc(var(--spacing) * 4);
  }

  .aria-invalid\:border-destructive[aria-invalid="true"] {
    border-color: var(--destructive);
  }

  .aria-invalid\:ring-destructive\/20[aria-invalid="true"] {
    --tw-ring-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .aria-invalid\:ring-destructive\/20[aria-invalid="true"] {
      --tw-ring-color: color-mix(in oklab, var(--destructive) 20%, transparent);
    }
  }

  .data-\[disabled\]\:pointer-events-none[data-disabled] {
    pointer-events: none;
  }

  .data-\[disabled\]\:opacity-50[data-disabled] {
    opacity: .5;
  }

  .data-\[inset\]\:pl-8[data-inset] {
    padding-left: calc(var(--spacing) * 8);
  }

  .data-\[orientation\=horizontal\]\:h-px[data-orientation="horizontal"] {
    height: 1px;
  }

  .data-\[orientation\=horizontal\]\:w-full[data-orientation="horizontal"] {
    width: 100%;
  }

  .data-\[orientation\=vertical\]\:h-full[data-orientation="vertical"] {
    height: 100%;
  }

  .data-\[orientation\=vertical\]\:w-px[data-orientation="vertical"] {
    width: 1px;
  }

  .data-\[placeholder\]\:text-muted-foreground[data-placeholder] {
    color: var(--muted-foreground);
  }

  .data-\[side\=bottom\]\:translate-y-1[data-side="bottom"] {
    --tw-translate-y: calc(var(--spacing) * 1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .data-\[side\=bottom\]\:slide-in-from-top-2[data-side="bottom"] {
    --tw-enter-translate-y: calc(2 * var(--spacing) * -1);
  }

  .data-\[side\=left\]\:-translate-x-1[data-side="left"] {
    --tw-translate-x: calc(var(--spacing) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .data-\[side\=left\]\:slide-in-from-right-2[data-side="left"] {
    --tw-enter-translate-x: calc(2 * var(--spacing));
  }

  .data-\[side\=right\]\:translate-x-1[data-side="right"] {
    --tw-translate-x: calc(var(--spacing) * 1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .data-\[side\=right\]\:slide-in-from-left-2[data-side="right"] {
    --tw-enter-translate-x: calc(2 * var(--spacing) * -1);
  }

  .data-\[side\=top\]\:-translate-y-1[data-side="top"] {
    --tw-translate-y: calc(var(--spacing) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .data-\[side\=top\]\:slide-in-from-bottom-2[data-side="top"] {
    --tw-enter-translate-y: calc(2 * var(--spacing));
  }

  .data-\[size\=default\]\:h-9[data-size="default"] {
    height: calc(var(--spacing) * 9);
  }

  .data-\[size\=sm\]\:h-8[data-size="sm"] {
    height: calc(var(--spacing) * 8);
  }

  :is(.\*\:data-\[slot\=select-value\]\:line-clamp-1 > *)[data-slot="select-value"] {
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
  }

  :is(.\*\:data-\[slot\=select-value\]\:flex > *)[data-slot="select-value"] {
    display: flex;
  }

  :is(.\*\:data-\[slot\=select-value\]\:items-center > *)[data-slot="select-value"] {
    align-items: center;
  }

  :is(.\*\:data-\[slot\=select-value\]\:gap-2 > *)[data-slot="select-value"] {
    gap: calc(var(--spacing) * 2);
  }

  .data-\[state\=active\]\:bg-card[data-state="active"] {
    background-color: var(--card);
  }

  .data-\[state\=active\]\:bg-sidebar-module-structural[data-state="active"] {
    background-color: var(--sidebar-module-structural);
  }

  .data-\[state\=active\]\:text-sidebar-module-structural-foreground[data-state="active"] {
    color: var(--sidebar-module-structural-foreground);
  }

  .data-\[state\=checked\]\:translate-x-\[calc\(100\%-2px\)\][data-state="checked"] {
    --tw-translate-x: calc(100% - 2px);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .data-\[state\=checked\]\:border-primary[data-state="checked"] {
    border-color: var(--primary);
  }

  .data-\[state\=checked\]\:bg-primary[data-state="checked"] {
    background-color: var(--primary);
  }

  .data-\[state\=checked\]\:text-primary-foreground[data-state="checked"] {
    color: var(--primary-foreground);
  }

  .data-\[state\=closed\]\:animate-out[data-state="closed"] {
    animation: exit var(--tw-duration, .15s) var(--tw-ease, ease);
  }

  .data-\[state\=closed\]\:fade-out-0[data-state="closed"] {
    --tw-exit-opacity: 0;
  }

  .data-\[state\=closed\]\:zoom-out-95[data-state="closed"] {
    --tw-exit-scale: .95;
  }

  .data-\[state\=open\]\:animate-in[data-state="open"] {
    animation: enter var(--tw-duration, .15s) var(--tw-ease, ease);
  }

  .data-\[state\=open\]\:bg-accent[data-state="open"] {
    background-color: var(--accent);
  }

  .data-\[state\=open\]\:text-accent-foreground[data-state="open"] {
    color: var(--accent-foreground);
  }

  .data-\[state\=open\]\:text-muted-foreground[data-state="open"] {
    color: var(--muted-foreground);
  }

  .data-\[state\=open\]\:fade-in-0[data-state="open"] {
    --tw-enter-opacity: 0;
  }

  .data-\[state\=open\]\:zoom-in-95[data-state="open"] {
    --tw-enter-scale: .95;
  }

  .data-\[state\=selected\]\:bg-muted[data-state="selected"] {
    background-color: var(--muted);
  }

  .data-\[state\=unchecked\]\:translate-x-0[data-state="unchecked"] {
    --tw-translate-x: calc(var(--spacing) * 0);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .data-\[state\=unchecked\]\:bg-switch-background[data-state="unchecked"] {
    background-color: var(--switch-background);
  }

  .data-\[variant\=destructive\]\:text-destructive[data-variant="destructive"] {
    color: var(--destructive);
  }

  .data-\[variant\=destructive\]\:focus\:bg-destructive\/10[data-variant="destructive"]:focus {
    background-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .data-\[variant\=destructive\]\:focus\:bg-destructive\/10[data-variant="destructive"]:focus {
      background-color: color-mix(in oklab, var(--destructive) 10%, transparent);
    }
  }

  .data-\[variant\=destructive\]\:focus\:text-destructive[data-variant="destructive"]:focus {
    color: var(--destructive);
  }

  @media (width >= 40rem) {
    .sm\:block {
      display: block;
    }
  }

  @media (width >= 40rem) {
    .sm\:inline {
      display: inline;
    }
  }

  @media (width >= 40rem) {
    .sm\:max-w-\[500px\] {
      max-width: 500px;
    }
  }

  @media (width >= 40rem) {
    .sm\:max-w-lg {
      max-width: var(--container-lg);
    }
  }

  @media (width >= 40rem) {
    .sm\:flex-row {
      flex-direction: row;
    }
  }

  @media (width >= 40rem) {
    .sm\:justify-end {
      justify-content: flex-end;
    }
  }

  @media (width >= 40rem) {
    .sm\:gap-2\.5 {
      gap: calc(var(--spacing) * 2.5);
    }
  }

  @media (width >= 40rem) {
    .sm\:text-left {
      text-align: left;
    }
  }

  @media (width >= 48rem) {
    .md\:flex {
      display: flex;
    }
  }

  @media (width >= 48rem) {
    .md\:hidden {
      display: none;
    }
  }

  @media (width >= 48rem) {
    .md\:w-auto {
      width: auto;
    }
  }

  @media (width >= 48rem) {
    .md\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (width >= 48rem) {
    .md\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (width >= 48rem) {
    .md\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }

  @media (width >= 48rem) {
    .md\:grid-cols-5 {
      grid-template-columns: repeat(5, minmax(0, 1fr));
    }
  }

  @media (width >= 48rem) {
    .md\:text-sm {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
    }
  }

  @media (width >= 64rem) {
    .lg\:col-span-1 {
      grid-column: span 1 / span 1;
    }
  }

  @media (width >= 64rem) {
    .lg\:col-span-2 {
      grid-column: span 2 / span 2;
    }
  }

  @media (width >= 64rem) {
    .lg\:col-span-3 {
      grid-column: span 3 / span 3;
    }
  }

  @media (width >= 64rem) {
    .lg\:col-span-4 {
      grid-column: span 4 / span 4;
    }
  }

  @media (width >= 64rem) {
    .lg\:col-span-5 {
      grid-column: span 5 / span 5;
    }
  }

  @media (width >= 64rem) {
    .lg\:col-span-6 {
      grid-column: span 6 / span 6;
    }
  }

  @media (width >= 64rem) {
    .lg\:col-span-8 {
      grid-column: span 8 / span 8;
    }
  }

  @media (width >= 64rem) {
    .lg\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (width >= 64rem) {
    .lg\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (width >= 64rem) {
    .lg\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }

  @media (width >= 64rem) {
    .lg\:grid-cols-5 {
      grid-template-columns: repeat(5, minmax(0, 1fr));
    }
  }

  @media (width >= 64rem) {
    .lg\:grid-cols-12 {
      grid-template-columns: repeat(12, minmax(0, 1fr));
    }
  }

  @media (width >= 80rem) {
    .xl\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (width >= 80rem) {
    .xl\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }

  .dark\:border-input:is(.dark *) {
    border-color: var(--input);
  }

  .dark\:bg-destructive\/60:is(.dark *) {
    background-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:bg-destructive\/60:is(.dark *) {
      background-color: color-mix(in oklab, var(--destructive) 60%, transparent);
    }
  }

  .dark\:bg-input\/30:is(.dark *) {
    background-color: var(--input);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:bg-input\/30:is(.dark *) {
      background-color: color-mix(in oklab, var(--input) 30%, transparent);
    }
  }

  .dark\:text-muted-foreground:is(.dark *) {
    color: var(--muted-foreground);
  }

  @media (hover: hover) {
    .dark\:hover\:bg-accent\/50:is(.dark *):hover {
      background-color: var(--accent);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .dark\:hover\:bg-accent\/50:is(.dark *):hover {
        background-color: color-mix(in oklab, var(--accent) 50%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .dark\:hover\:bg-input\/50:is(.dark *):hover {
      background-color: var(--input);
    }

    @supports (color: color-mix(in lab, red, red)) {
      .dark\:hover\:bg-input\/50:is(.dark *):hover {
        background-color: color-mix(in oklab, var(--input) 50%, transparent);
      }
    }
  }

  .dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible {
    --tw-ring-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible {
      --tw-ring-color: color-mix(in oklab, var(--destructive) 40%, transparent);
    }
  }

  .dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid="true"] {
    --tw-ring-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid="true"] {
      --tw-ring-color: color-mix(in oklab, var(--destructive) 40%, transparent);
    }
  }

  .dark\:data-\[state\=active\]\:border-input:is(.dark *)[data-state="active"] {
    border-color: var(--input);
  }

  .dark\:data-\[state\=active\]\:bg-input\/30:is(.dark *)[data-state="active"] {
    background-color: var(--input);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:data-\[state\=active\]\:bg-input\/30:is(.dark *)[data-state="active"] {
      background-color: color-mix(in oklab, var(--input) 30%, transparent);
    }
  }

  .dark\:data-\[state\=active\]\:text-foreground:is(.dark *)[data-state="active"] {
    color: var(--foreground);
  }

  .dark\:data-\[state\=checked\]\:bg-primary:is(.dark *)[data-state="checked"] {
    background-color: var(--primary);
  }

  .dark\:data-\[state\=checked\]\:bg-primary-foreground:is(.dark *)[data-state="checked"] {
    background-color: var(--primary-foreground);
  }

  .dark\:data-\[state\=unchecked\]\:bg-card-foreground:is(.dark *)[data-state="unchecked"] {
    background-color: var(--card-foreground);
  }

  .dark\:data-\[state\=unchecked\]\:bg-input\/80:is(.dark *)[data-state="unchecked"] {
    background-color: var(--input);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:data-\[state\=unchecked\]\:bg-input\/80:is(.dark *)[data-state="unchecked"] {
      background-color: color-mix(in oklab, var(--input) 80%, transparent);
    }
  }

  .dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:is(.dark *)[data-variant="destructive"]:focus {
    background-color: var(--destructive);
  }

  @supports (color: color-mix(in lab, red, red)) {
    .dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:is(.dark *)[data-variant="destructive"]:focus {
      background-color: color-mix(in oklab, var(--destructive) 20%, transparent);
    }
  }

  .\[\&_svg\]\:pointer-events-none svg {
    pointer-events: none;
  }

  .\[\&_svg\]\:shrink-0 svg {
    flex-shrink: 0;
  }

  .\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*="size-"]) {
    width: calc(var(--spacing) * 4);
    height: calc(var(--spacing) * 4);
  }

  .\[\&_svg\:not\(\[class\*\=\'text-\'\]\)\]\:text-muted-foreground svg:not([class*="text-"]) {
    color: var(--muted-foreground);
  }

  .\[\&_tr\]\:border-b tr {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }

  .\[\&_tr\:last-child\]\:border-0 tr:last-child {
    border-style: var(--tw-border-style);
    border-width: 0;
  }

  .\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role="checkbox"]) {
    padding-right: calc(var(--spacing) * 0);
  }

  .\[\.border-b\]\:pb-6.border-b {
    padding-bottom: calc(var(--spacing) * 6);
  }

  .\[\.border-t\]\:pt-6.border-t {
    padding-top: calc(var(--spacing) * 6);
  }

  :is(.\*\:\[span\]\:last\:flex > *):is(span):last-child {
    display: flex;
  }

  :is(.\*\:\[span\]\:last\:items-center > *):is(span):last-child {
    align-items: center;
  }

  :is(.\*\:\[span\]\:last\:gap-2 > *):is(span):last-child {
    gap: calc(var(--spacing) * 2);
  }

  :is(.data-\[variant\=destructive\]\:\*\:\[svg\]\:\!text-destructive[data-variant="destructive"] > *):is(svg) {
    color: var(--destructive) !important;
  }

  .\[\&\:last-child\]\:pb-6:last-child {
    padding-bottom: calc(var(--spacing) * 6);
  }

  .\[\&\>\[role\=checkbox\]\]\:translate-y-\[2px\] > [role="checkbox"] {
    --tw-translate-y: 2px;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .\[\&\>svg\]\:pointer-events-none > svg {
    pointer-events: none;
  }

  .\[\&\>svg\]\:size-3 > svg {
    width: calc(var(--spacing) * 3);
    height: calc(var(--spacing) * 3);
  }

  .\[\&\>svg\]\:size-3\.5 > svg {
    width: calc(var(--spacing) * 3.5);
    height: calc(var(--spacing) * 3.5);
  }

  .\[\&\>tr\]\:last\:border-b-0 > tr:last-child {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 0;
  }

  @media (hover: hover) {
    a.\[a\&\]\:hover\:bg-accent:hover {
      background-color: var(--accent);
    }
  }

  @media (hover: hover) {
    a.\[a\&\]\:hover\:bg-destructive\/90:hover {
      background-color: var(--destructive);
    }

    @supports (color: color-mix(in lab, red, red)) {
      a.\[a\&\]\:hover\:bg-destructive\/90:hover {
        background-color: color-mix(in oklab, var(--destructive) 90%, transparent);
      }
    }
  }

  @media (hover: hover) {
    a.\[a\&\]\:hover\:bg-primary\/90:hover {
      background-color: var(--primary);
    }

    @supports (color: color-mix(in lab, red, red)) {
      a.\[a\&\]\:hover\:bg-primary\/90:hover {
        background-color: color-mix(in oklab, var(--primary) 90%, transparent);
      }
    }
  }

  @media (hover: hover) {
    a.\[a\&\]\:hover\:bg-secondary\/90:hover {
      background-color: var(--secondary);
    }

    @supports (color: color-mix(in lab, red, red)) {
      a.\[a\&\]\:hover\:bg-secondary\/90:hover {
        background-color: color-mix(in oklab, var(--secondary) 90%, transparent);
      }
    }
  }

  @media (hover: hover) {
    a.\[a\&\]\:hover\:text-accent-foreground:hover {
      color: var(--accent-foreground);
    }
  }

  .alloy-title {
    font-size: .875rem;
    font-weight: 600;
    line-height: 1.5;
  }

  .alloy-heading {
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
  }

  .alloy-label {
    font-size: .75rem;
    font-weight: 400;
    line-height: 1.5;
  }

  .alloy-value {
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
  }

  .alloy-value-lg {
    font-size: .875rem;
    font-weight: 600;
    line-height: 1.5;
  }

  .alloy-body {
    color: var(--color-muted-foreground);
    font-size: .75rem;
    font-weight: 400;
    line-height: 1.5;
  }

  .alloy-caption {
    color: var(--color-muted-foreground);
    font-size: .688rem;
    font-weight: 400;
    line-height: 1.4;
  }

  .alloy-btn-dashboard {
    background-color: var(--color-sidebar-module-dashboard);
    color: var(--color-sidebar-module-dashboard-foreground);
    border: 2px solid var(--color-sidebar-module-dashboard);
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
    transition: all .2s ease-in-out;
  }

  .alloy-btn-dashboard:hover:not(:disabled) {
    background-color: var(--color-sidebar-module-dashboard-hover);
    border-color: var(--color-sidebar-module-dashboard-hover);
    color: var(--color-sidebar-module-dashboard-foreground);
  }

  .alloy-btn-dashboard:active:not(:disabled) {
    background-color: var(--color-sidebar-module-dashboard-pressed);
    border-color: var(--color-sidebar-module-dashboard-pressed);
    color: var(--color-sidebar-module-dashboard-foreground);
  }

  .alloy-btn-piping {
    background-color: var(--color-sidebar-module-piping);
    color: var(--color-sidebar-module-piping-foreground);
    border: 2px solid var(--color-sidebar-module-piping);
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
    transition: all .2s ease-in-out;
  }

  .alloy-btn-piping:hover:not(:disabled) {
    background-color: var(--color-sidebar-module-piping-hover);
    border-color: var(--color-sidebar-module-piping-hover);
    color: var(--color-sidebar-module-piping-foreground);
  }

  .alloy-btn-piping:active:not(:disabled) {
    background-color: var(--color-sidebar-module-piping-pressed);
    border-color: var(--color-sidebar-module-piping-pressed);
    color: var(--color-sidebar-module-piping-foreground);
  }

  .alloy-btn-structural {
    background-color: var(--color-sidebar-module-structural);
    color: var(--color-sidebar-module-structural-foreground);
    border: 2px solid var(--color-sidebar-module-structural);
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
    transition: all .2s ease-in-out;
  }

  .alloy-btn-structural:hover:not(:disabled) {
    background-color: var(--color-sidebar-module-structural-hover);
    border-color: var(--color-sidebar-module-structural-hover);
    color: var(--color-sidebar-module-structural-foreground);
  }

  .alloy-btn-structural:active:not(:disabled) {
    background-color: var(--color-sidebar-module-structural-pressed);
    border-color: var(--color-sidebar-module-structural-pressed);
    color: var(--color-sidebar-module-structural-foreground);
  }

  .alloy-btn-rc {
    background-color: var(--color-sidebar-module-rc);
    color: var(--color-sidebar-module-rc-foreground);
    border: 2px solid var(--color-sidebar-module-rc);
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
    transition: all .2s ease-in-out;
  }

  .alloy-btn-rc:hover:not(:disabled) {
    background-color: var(--color-sidebar-module-rc-hover);
    border-color: var(--color-sidebar-module-rc-hover);
    color: var(--color-sidebar-module-rc-foreground);
  }

  .alloy-btn-rc:active:not(:disabled) {
    background-color: var(--color-sidebar-module-rc-pressed);
    border-color: var(--color-sidebar-module-rc-pressed);
    color: var(--color-sidebar-module-rc-foreground);
  }

  .alloy-btn-mep {
    background-color: var(--color-sidebar-module-mep);
    color: var(--color-sidebar-module-mep-foreground);
    border: 2px solid var(--color-sidebar-module-mep);
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
    transition: all .2s ease-in-out;
  }

  .alloy-btn-mep:hover:not(:disabled) {
    background-color: var(--color-sidebar-module-mep-hover);
    border-color: var(--color-sidebar-module-mep-hover);
    color: var(--color-sidebar-module-mep-foreground);
  }

  .alloy-btn-mep:active:not(:disabled) {
    background-color: var(--color-sidebar-module-mep-pressed);
    border-color: var(--color-sidebar-module-mep-pressed);
    color: var(--color-sidebar-module-mep-foreground);
  }

  .alloy-btn-library {
    background-color: var(--color-sidebar-module-library);
    color: var(--color-sidebar-module-library-foreground);
    border: 2px solid var(--color-sidebar-module-library);
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
    transition: all .2s ease-in-out;
  }

  .alloy-btn-library:hover:not(:disabled) {
    background-color: var(--color-sidebar-module-library-hover);
    border-color: var(--color-sidebar-module-library-hover);
    color: var(--color-sidebar-module-library-foreground);
  }

  .alloy-btn-library:active:not(:disabled) {
    background-color: var(--color-sidebar-module-library-pressed);
    border-color: var(--color-sidebar-module-library-pressed);
    color: var(--color-sidebar-module-library-foreground);
  }

  .alloy-btn-calculators {
    background-color: var(--color-sidebar-module-calculators);
    color: var(--color-sidebar-module-calculators-foreground);
    border: 2px solid var(--color-sidebar-module-calculators);
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
    transition: all .2s ease-in-out;
  }

  .alloy-btn-calculators:hover:not(:disabled) {
    background-color: var(--color-sidebar-module-calculators-hover);
    border-color: var(--color-sidebar-module-calculators-hover);
    color: var(--color-sidebar-module-calculators-foreground);
  }

  .alloy-btn-calculators:active:not(:disabled) {
    background-color: var(--color-sidebar-module-calculators-pressed);
    border-color: var(--color-sidebar-module-calculators-pressed);
    color: var(--color-sidebar-module-calculators-foreground);
  }

  .alloy-btn-project-boards {
    background-color: var(--color-sidebar-module-project-boards);
    color: var(--color-sidebar-module-project-boards-foreground);
    border: 2px solid var(--color-sidebar-module-project-boards);
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
    transition: all .2s ease-in-out;
  }

  .alloy-btn-project-boards:hover:not(:disabled) {
    background-color: var(--color-sidebar-module-project-boards-hover);
    border-color: var(--color-sidebar-module-project-boards-hover);
    color: var(--color-sidebar-module-project-boards-foreground);
  }

  .alloy-btn-project-boards:active:not(:disabled) {
    background-color: var(--color-sidebar-module-project-boards-pressed);
    border-color: var(--color-sidebar-module-project-boards-pressed);
    color: var(--color-sidebar-module-project-boards-foreground);
  }

  .alloy-btn-deliverables {
    background-color: var(--color-sidebar-module-deliverables);
    color: var(--color-sidebar-module-deliverables-foreground);
    border: 2px solid var(--color-sidebar-module-deliverables);
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
    transition: all .2s ease-in-out;
  }

  .alloy-btn-deliverables:hover:not(:disabled) {
    background-color: var(--color-sidebar-module-deliverables-hover);
    border-color: var(--color-sidebar-module-deliverables-hover);
    color: var(--color-sidebar-module-deliverables-foreground);
  }

  .alloy-btn-deliverables:active:not(:disabled) {
    background-color: var(--color-sidebar-module-deliverables-pressed);
    border-color: var(--color-sidebar-module-deliverables-pressed);
    color: var(--color-sidebar-module-deliverables-foreground);
  }

  .alloy-btn-engineering {
    background-color: var(--color-sidebar-module-engineering);
    color: var(--color-sidebar-module-engineering-foreground);
    border: 2px solid var(--color-sidebar-module-engineering);
    font-size: .75rem;
    font-weight: 600;
    line-height: 1.5;
    transition: all .2s ease-in-out;
  }

  .alloy-btn-engineering:hover:not(:disabled) {
    background-color: var(--color-sidebar-module-engineering-hover);
    border-color: var(--color-sidebar-module-engineering-hover);
    color: var(--color-sidebar-module-engineering-foreground);
  }

  .alloy-btn-engineering:active:not(:disabled) {
    background-color: var(--color-sidebar-module-engineering-pressed);
    border-color: var(--color-sidebar-module-engineering-pressed);
    color: var(--color-sidebar-module-engineering-foreground);
  }

  .alloy-btn-secondary {
    background-color: var(--color-card);
    color: var(--color-muted-foreground);
    border: 2px solid var(--color-border);
    font-size: .75rem;
    font-weight: 400;
    line-height: 1.5;
  }

  .alloy-btn-secondary:hover:not(:disabled) {
    background-color: var(--color-muted);
    border-color: var(--color-muted-foreground);
  }

  .alloy-btn-secondary:active:not(:disabled) {
    font-weight: 500;
  }

  .alloy-panel-dashboard {
    border-top: 2px solid var(--color-sidebar-module-dashboard);
    border: 1px solid #e0e0e0;
    border-top: 2px solid var(--color-sidebar-module-dashboard);
    border-radius: var(--radius-lg);
    box-shadow: none;
    background-color: #fff;
    overflow: hidden;
  }

  .alloy-panel-piping {
    border-top: 2px solid var(--color-sidebar-module-piping);
    border: 1px solid #e0e0e0;
    border-top: 2px solid var(--color-sidebar-module-piping);
    border-radius: var(--radius-lg);
    box-shadow: none;
    background-color: #fff;
    overflow: hidden;
  }

  .alloy-panel-structural {
    border-top: 2px solid var(--color-sidebar-module-structural);
    border: 1px solid #e0e0e0;
    border-top: 2px solid var(--color-sidebar-module-structural);
    border-radius: var(--radius-lg);
    box-shadow: none;
    background-color: #fff;
    overflow: hidden;
  }

  .alloy-panel-rc {
    border-top: 2px solid var(--color-sidebar-module-rc);
    border: 1px solid #e0e0e0;
    border-top: 2px solid var(--color-sidebar-module-rc);
    border-radius: var(--radius-lg);
    box-shadow: none;
    background-color: #fff;
    overflow: hidden;
  }

  .alloy-panel-mep {
    border-top: 2px solid var(--color-sidebar-module-mep);
    border: 1px solid #e0e0e0;
    border-top: 2px solid var(--color-sidebar-module-mep);
    border-radius: var(--radius-lg);
    box-shadow: none;
    background-color: #fff;
    overflow: hidden;
  }

  .alloy-panel-library {
    border-top: 2px solid var(--color-sidebar-module-library);
    border: 1px solid #e0e0e0;
    border-top: 2px solid var(--color-sidebar-module-library);
    border-radius: var(--radius-lg);
    box-shadow: none;
    background-color: #fff;
    overflow: hidden;
  }

  .alloy-panel-calculators {
    border-top: 2px solid var(--color-sidebar-module-calculators);
    border: 1px solid #e0e0e0;
    border-top: 2px solid var(--color-sidebar-module-calculators);
    border-radius: var(--radius-lg);
    box-shadow: none;
    background-color: #fff;
    overflow: hidden;
  }

  .alloy-panel-project-boards {
    border-top: 2px solid var(--color-sidebar-module-project-boards);
    border: 1px solid #e0e0e0;
    border-top: 2px solid var(--color-sidebar-module-project-boards);
    border-radius: var(--radius-lg);
    box-shadow: none;
    background-color: #fff;
    overflow: hidden;
  }

  .alloy-panel-deliverables {
    border-top: 2px solid var(--color-sidebar-module-deliverables);
    border: 1px solid #e0e0e0;
    border-top: 2px solid var(--color-sidebar-module-deliverables);
    border-radius: var(--radius-lg);
    box-shadow: none;
    background-color: #fff;
    overflow: hidden;
  }

  .alloy-panel-engineering {
    border-top: 2px solid var(--color-sidebar-module-engineering);
    border: 1px solid #e0e0e0;
    border-top: 2px solid var(--color-sidebar-module-engineering);
    border-radius: var(--radius-lg);
    box-shadow: none;
    background-color: #fff;
    overflow: hidden;
  }

  .alloy-panel-flat {
    border-radius: var(--radius-lg);
    box-shadow: none;
    background-color: #fff;
    border: 1px solid #e0e0e0;
    overflow: hidden;
  }

  .alloy-panel-header-dashboard, .alloy-panel-header-piping, .alloy-panel-header-structural, .alloy-panel-header-rc, .alloy-panel-header-mep, .alloy-panel-header-library, .alloy-panel-header-calculators, .alloy-panel-header-project-boards, .alloy-panel-header-deliverables, .alloy-panel-header-engineering {
    background-color: var(--color-muted);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    border-bottom: 1px solid var(--color-border);
    align-items: center;
    gap: .75rem;
    min-height: 4rem;
    padding: 1rem 1.5rem;
    display: flex;
  }

  .alloy-header-content {
    flex: 1;
    align-items: center;
    gap: .75rem;
    min-height: 2rem;
    display: flex;
  }

  .alloy-header-title-group {
    flex-shrink: 0;
    align-items: center;
    gap: .5rem;
    display: flex;
  }

  .alloy-header-description {
    flex: 1;
    align-items: center;
    display: flex;
  }

  .alloy-filter-bar {
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
    display: flex;
  }

  .alloy-filter-group {
    align-items: center;
    gap: .5rem;
    display: flex;
  }

  .alloy-filter-details {
    border-left: 1px solid var(--color-border);
    align-items: center;
    gap: 1rem;
    margin-left: 2rem;
    padding-left: 1rem;
    display: flex;
  }

  .alloy-filter-detail-item {
    align-items: center;
    gap: .25rem;
    display: flex;
  }

  @media (width <= 768px) {
    .alloy-panel-header-piping, .alloy-panel-header-structural, .alloy-panel-header-rc, .alloy-panel-header-mep, .alloy-panel-header-library, .alloy-panel-header-calculators {
      flex-direction: column;
      align-items: flex-start;
      gap: .5rem;
      min-height: 3.5rem;
      padding: .875rem 1rem;
    }

    .alloy-header-content {
      flex-direction: column;
      align-items: flex-start;
      gap: .5rem;
      width: 100%;
    }

    .alloy-header-description {
      width: 100%;
    }

    .alloy-filter-bar {
      flex-direction: column;
      align-items: stretch;
      gap: .75rem;
    }

    .alloy-filter-group {
      justify-content: space-between;
      width: 100%;
    }

    .alloy-filter-details {
      border-left: none;
      border-top: 1px solid var(--color-border);
      flex-wrap: wrap;
      gap: .75rem;
      margin-left: 0;
      padding-top: .75rem;
      padding-left: 0;
    }

    .alloy-filter-group .alloy-label {
      min-width: fit-content;
    }

    .alloy-filter-group .w-48, .alloy-filter-group .w-36, .alloy-filter-group .w-28 {
      width: 100%;
      max-width: none;
    }
  }

  .alloy-icon-dashboard {
    color: var(--color-sidebar-module-dashboard);
  }

  .alloy-icon-dashboard-sidebar, .sidebar-home-icon {
    color: #000 !important;
  }

  .alloy-icon-piping {
    color: var(--color-sidebar-module-piping);
  }

  .alloy-icon-structural {
    color: var(--color-sidebar-module-structural);
  }

  .alloy-icon-rc {
    color: var(--color-sidebar-module-rc);
  }

  .alloy-icon-mep {
    color: var(--color-sidebar-module-mep);
  }

  .alloy-icon-library {
    color: var(--color-sidebar-module-library);
  }

  .alloy-icon-calculators {
    color: var(--color-sidebar-module-calculators);
  }

  .alloy-icon-project-boards {
    color: var(--color-sidebar-module-project-boards);
  }

  .alloy-icon-deliverables {
    color: var(--color-sidebar-module-deliverables);
  }

  .alloy-icon-engineering {
    color: var(--color-sidebar-module-engineering);
  }

  .sidebar-nav-link {
    transition: all .2s ease-in-out;
    position: relative;
  }

  .sidebar-separator {
    background-color: var(--color-sidebar-separator);
    height: 1px;
    margin: .5rem 1rem;
    transition: background-color .15s ease-in-out;
  }

  .sidebar-separator.hover {
    background-color: var(--color-sidebar-separator-hover);
  }

  .sidebar-separator-animated {
    transition: background-color .2s ease-in-out;
  }

  .sidebar-nav-item {
    position: relative;
  }

  .sidebar-nav-item:hover + .sidebar-separator, .sidebar-separator:has( + .sidebar-nav-item:hover) {
    background-color: var(--color-sidebar-separator-hover);
  }

  .sidebar-nav-link:not(.active):hover {
    background-color: var(--hover-bg, var(--color-sidebar-accent)) !important;
  }

  .sidebar-nav-link.sidebar-sub-item:not(.active):hover {
    background-color: var(--hover-bg, var(--color-sidebar-accent)) !important;
    border-left: var(--hover-border, 2px solid var(--color-sidebar-accent)) !important;
    padding-left: var(--hover-padding, 14px) !important;
  }

  .sidebar-nav-link.sidebar-intermediate-item:not(.active):hover {
    background-color: var(--hover-bg, var(--color-sidebar-accent)) !important;
    border-left: var(--hover-border, 4px solid var(--color-sidebar-accent)) !important;
    padding-left: var(--hover-padding, 12px) !important;
    color: var(--hover-color, var(--color-sidebar-foreground)) !important;
  }

  .sidebar-nav-link.sidebar-intermediate-item:not(.active):hover svg {
    color: var(--hover-color, var(--color-sidebar-foreground)) !important;
  }

  .sidebar-nav-link:not(:hover):not(.active) {
    background-color: var(--color-sidebar) !important;
    border-left: none !important;
    padding-left: 12px !important;
  }

  .sidebar-nav-link.sidebar-sub-item:not(:hover):not(.active) {
    border-left: none !important;
    padding-left: 12px !important;
  }

  .sidebar-nav-link.sidebar-intermediate-item:not(:hover):not(.active) {
    color: var(--color-sidebar-foreground) !important;
    border-left: none !important;
    padding-left: 12px !important;
  }

  .sidebar-nav-link.sidebar-intermediate-item:not(:hover):not(.active) svg {
    color: var(--color-sidebar-foreground) !important;
  }

  .alloy-tab-dashboard.active {
    border-bottom: 2px solid var(--color-sidebar-module-dashboard);
    color: var(--color-sidebar-module-dashboard);
    background-color: var(--color-sidebar-module-dashboard-hover);
  }

  .alloy-tab-piping.active {
    border-bottom: 2px solid var(--color-sidebar-module-piping);
    color: var(--color-sidebar-module-piping);
    background-color: var(--color-sidebar-module-piping-hover);
  }

  .alloy-tab-structural.active {
    border-bottom: 2px solid var(--color-sidebar-module-structural);
    color: var(--color-sidebar-module-structural);
    background-color: var(--color-sidebar-module-structural-hover);
  }

  .alloy-tab-rc.active {
    border-bottom: 2px solid var(--color-sidebar-module-rc);
    color: var(--color-sidebar-module-rc);
    background-color: var(--color-sidebar-module-rc-hover);
  }

  .alloy-tab-mep.active {
    border-bottom: 2px solid var(--color-sidebar-module-mep);
    color: var(--color-sidebar-module-mep);
    background-color: var(--color-sidebar-module-mep-hover);
  }

  .alloy-tab-library.active {
    border-bottom: 2px solid var(--color-sidebar-module-library);
    color: var(--color-sidebar-module-library);
    background-color: var(--color-sidebar-module-library-hover);
  }

  .alloy-tab-calculators.active {
    border-bottom: 2px solid var(--color-sidebar-module-calculators);
    color: var(--color-sidebar-module-calculators);
    background-color: var(--color-sidebar-module-calculators-hover);
  }

  .alloy-tab-project-boards.active, .alloy-tab-projects.active {
    border-bottom: 2px solid var(--color-sidebar-module-project-boards);
    color: var(--color-sidebar-module-project-boards);
    background-color: var(--color-sidebar-module-project-boards-hover);
  }

  .alloy-tab-deliverables.active {
    border-bottom: 2px solid var(--color-sidebar-module-deliverables);
    color: var(--color-sidebar-module-deliverables);
    background-color: var(--color-sidebar-module-deliverables-hover);
  }

  nav a[href="/"], nav a[href="/"].active, nav a[href="/"]:hover, nav a[href="/"]:focus, nav a[href="/"]:active, nav a[href="/"] svg, nav a[href="/"].active svg, nav a[href="/"]:hover svg, nav a[href="/"]:focus svg, nav a[href="/"]:active svg, nav a[href="/"] span, nav a[href="/"].active span, nav a[href="/"]:hover span, nav a[href="/"]:focus span, nav a[href="/"]:active span, .sidebar-nav-link[href="/"], .sidebar-nav-link[href="/"].active, .sidebar-nav-link[href="/"]:hover, .sidebar-nav-link[href="/"]:focus, .sidebar-nav-link[href="/"]:active, .sidebar-nav-link[href="/"] svg, .sidebar-nav-link[href="/"] span, .alloy-breadcrumb-dashboard {
    color: #000 !important;
  }

  .alloy-breadcrumb-piping {
    color: var(--color-sidebar-module-piping);
  }

  .alloy-breadcrumb-structural {
    color: var(--color-sidebar-module-structural);
  }

  .alloy-breadcrumb-rc {
    color: var(--color-sidebar-module-rc);
  }

  .alloy-breadcrumb-mep {
    color: var(--color-sidebar-module-mep);
  }

  .alloy-breadcrumb-library {
    color: var(--color-sidebar-module-library);
  }

  .alloy-breadcrumb-calculators {
    color: var(--color-sidebar-module-calculators);
  }

  .alloy-breadcrumb-project-boards, .alloy-breadcrumb-projects {
    color: var(--color-sidebar-module-project-boards);
  }

  .alloy-breadcrumb-deliverables {
    color: var(--color-sidebar-module-deliverables);
  }

  .alloy-breadcrumb-engineering {
    color: var(--color-sidebar-module-engineering);
  }

  .alloy-flat {
    background-color: #fff;
    border: 1px solid #e0e0e0;
    box-shadow: none !important;
  }

  .alloy-table-flat {
    border-radius: var(--radius-lg);
    border: 1px solid #e0e0e0;
    overflow: hidden;
    box-shadow: none !important;
  }

  .alloy-table-flat th {
    box-shadow: none;
    background-color: #f8f9fa;
    border-bottom: 1px solid #e0e0e0;
  }

  .alloy-table-flat td {
    box-shadow: none;
    border-bottom: 1px solid #f0f0f0;
  }

  .alloy-input-flat {
    border-radius: calc(var(--radius)  - 2px);
    background-color: #fff;
    border: 1px solid #e0e0e0;
    box-shadow: none !important;
  }

  .alloy-input-flat:focus {
    border: 1px solid var(--color-ring);
    outline: none;
    box-shadow: none !important;
  }

  .alloy-btn-flat {
    border-radius: calc(var(--radius)  - 2px);
    background-color: #fff;
    border: 1px solid #e0e0e0;
    box-shadow: none !important;
  }

  .alloy-btn-flat:hover {
    background-color: #f8f9fa;
    border: 1px solid #d0d0d0;
    box-shadow: none !important;
  }

  .alloy-btn-flat:active {
    background-color: #e8e9ea;
    border: 1px solid silver;
    box-shadow: none !important;
  }

  .ui-card, .ui-panel, .card, .panel, [data-ui="card"], [data-ui="panel"], [data-component="card"], [data-component="panel"], .rounded-lg, .rounded-xl, .rounded-2xl, table, .table {
    box-shadow: none !important;
  }

  .form-container, .input-group, .calculator-panel, .analysis-panel {
    border: 1px solid #e0e0e0;
    box-shadow: none !important;
  }

  [data-slot="card"] {
    box-shadow: none !important;
    background-color: #fff !important;
    border: 1px solid #e0e0e0 !important;
  }

  [data-slot="card-header"] {
    background-color: #f8f9fa;
    border-bottom: 1px solid #e0e0e0;
    box-shadow: none !important;
  }

  .fastener-calculator-panel, .fastener-analysis-panel, .sections-panel, .plates-panel, .fasteners-panel, .assembly-panel {
    overflow: hidden;
    box-shadow: none !important;
    border-radius: var(--radius-lg) !important;
    background-color: #fff !important;
    border: 1px solid #e0e0e0 !important;
  }

  .fastener-calculator-panel, .fastener-analysis-panel {
    border-top: 2px solid var(--color-sidebar-module-structural) !important;
  }

  .piping-detail-panel, .piping-calculator-panel {
    overflow: hidden;
    box-shadow: none !important;
    border: 1px solid #e0e0e0 !important;
    border-top: 2px solid var(--color-sidebar-module-piping) !important;
    border-radius: var(--radius-lg) !important;
    background-color: #fff !important;
  }

  .library-bolt-panel, .library-nut-panel, .library-washer-panel, .library-steel-panel, .library-weld-panel {
    overflow: hidden;
    box-shadow: none !important;
    border: 1px solid #e0e0e0 !important;
    border-top: 2px solid var(--color-sidebar-module-library) !important;
    border-radius: var(--radius-lg) !important;
    background-color: #fff !important;
  }

  .shim-pack-panel, .backmarks-panel, .bolt-length-panel {
    overflow: hidden;
    box-shadow: none !important;
    border: 1px solid #e0e0e0 !important;
    border-top: 2px solid var(--color-sidebar-module-calculators) !important;
    border-radius: var(--radius-lg) !important;
    background-color: #fff !important;
  }

  .rc-panel, .mep-panel {
    overflow: hidden;
    box-shadow: none !important;
    border-radius: var(--radius-lg) !important;
    background-color: #fff !important;
    border: 1px solid #e0e0e0 !important;
  }

  .rc-panel {
    border-top: 2px solid var(--color-sidebar-module-rc) !important;
  }

  .mep-panel {
    border-top: 2px solid var(--color-sidebar-module-mep) !important;
  }

  .component-panel, .module-panel, .surface, .container, .section, .bg-card, .card, .panel, .surface, .rounded, .rounded-sm, .rounded-md, .rounded-lg, .rounded-xl, .rounded-2xl {
    box-shadow: none !important;
  }

  .fastener-calculator, .fastener-analysis, .sections-container, .plates-container, .fasteners-container, .assembly-container {
    box-shadow: none !important;
    border: 1px solid #e0e0e0 !important;
    border-top: 2px solid var(--color-sidebar-module-structural) !important;
    border-radius: var(--radius-lg) !important;
    background-color: #fff !important;
  }

  .piping-component-card, .component-detail-card, .piping-calculator-card {
    box-shadow: none !important;
    border: 1px solid #e0e0e0 !important;
    border-top: 2px solid var(--color-sidebar-module-piping) !important;
    border-radius: var(--radius-lg) !important;
    background-color: #fff !important;
  }

  .module-header, .component-header, .panel-header, .surface-header {
    box-shadow: none !important;
    background-color: #f8f9fa !important;
    border-bottom: 1px solid #e0e0e0 !important;
  }

  .bg-white, .bg-gray-50, .bg-gray-100, .shadow-sm, .shadow, .shadow-md, .shadow-lg, .shadow-xl, .shadow-2xl, .shadow-inner {
    box-shadow: none !important;
  }
}

:root {
  --font-size: 16px;
  --background: #fff;
  --foreground: oklch(.145 0 0);
  --card: #fff;
  --card-foreground: oklch(.145 0 0);
  --popover: oklch(1 0 0);
  --popover-foreground: oklch(.145 0 0);
  --primary: #030213;
  --primary-foreground: oklch(1 0 0);
  --secondary: oklch(.95 .0058 264.53);
  --secondary-foreground: #030213;
  --muted: #ececf0;
  --muted-foreground: #717182;
  --accent: #e9ebef;
  --accent-foreground: #030213;
  --destructive: #d4183d;
  --destructive-foreground: #fff;
  --border: #0000001a;
  --input: transparent;
  --input-background: #f3f3f5;
  --switch-background: #cbced4;
  --font-weight-medium: 500;
  --font-weight-normal: 400;
  --ring: oklch(.708 0 0);
  --chart-1: oklch(.646 .222 41.116);
  --chart-2: oklch(.6 .118 184.704);
  --chart-3: oklch(.398 .07 227.392);
  --chart-4: oklch(.828 .189 84.429);
  --chart-5: oklch(.769 .188 70.08);
  --radius: .625rem;
  --sidebar: oklch(.985 0 0);
  --sidebar-foreground: oklch(.145 0 0);
  --sidebar-primary: #030213;
  --sidebar-primary-foreground: oklch(.985 0 0);
  --sidebar-accent: oklch(.97 0 0);
  --sidebar-accent-foreground: oklch(.205 0 0);
  --sidebar-border: oklch(.922 0 0);
  --sidebar-ring: oklch(.708 0 0);
  --sidebar-separator: #c8c8c8;
  --sidebar-separator-hover: #a0a0a0;
  --sidebar-module-active: oklch(.98 .01 240);
  --sidebar-module-active-foreground: oklch(.3 .03 240);
  --sidebar-module-dashboard: #f4f1de;
  --sidebar-module-dashboard-foreground: #000;
  --sidebar-module-dashboard-hover: #faf9f3;
  --sidebar-module-dashboard-pressed: #e2dfcc;
  --sidebar-module-dashboard-sub: #faf9f3;
  --sidebar-module-piping: #81b29a;
  --sidebar-module-piping-foreground: #fff;
  --sidebar-module-piping-hover: #a8d1ba;
  --sidebar-module-piping-pressed: #5e8d76;
  --sidebar-module-piping-sub: #a8d1ba;
  --sidebar-module-structural: #eab69f;
  --sidebar-module-structural-foreground: #000;
  --sidebar-module-structural-hover: #f5d2c2;
  --sidebar-module-structural-pressed: #d2967e;
  --sidebar-module-structural-sub: #f5d2c2;
  --sidebar-module-rc: #5f797b;
  --sidebar-module-rc-foreground: #fff;
  --sidebar-module-rc-hover: #7f9a9c;
  --sidebar-module-rc-pressed: #465d5f;
  --sidebar-module-rc-sub: #7f9a9c;
  --sidebar-module-mep: #e07a5f;
  --sidebar-module-mep-foreground: #fff;
  --sidebar-module-mep-hover: #f1a590;
  --sidebar-module-mep-pressed: #c46147;
  --sidebar-module-mep-sub: #f1a590;
  --sidebar-module-library: #8588ad;
  --sidebar-module-library-foreground: #fff;
  --sidebar-module-library-hover: #a6a9c4;
  --sidebar-module-library-pressed: #666886;
  --sidebar-module-library-sub: #a6a9c4;
  --sidebar-module-calculators: #b18787;
  --sidebar-module-calculators-foreground: #fff;
  --sidebar-module-calculators-hover: #cda6a6;
  --sidebar-module-calculators-pressed: #8f6868;
  --sidebar-module-calculators-sub: #cda6a6;
  --sidebar-module-project-boards: #f2cc8f;
  --sidebar-module-project-boards-foreground: #000;
  --sidebar-module-project-boards-hover: #f8e4c3;
  --sidebar-module-project-boards-pressed: #d9b578;
  --sidebar-module-project-boards-sub: #f8e4c3;
  --sidebar-module-deliverables: #7a9294;
  --sidebar-module-deliverables-foreground: #fff;
  --sidebar-module-deliverables-hover: #9bb1b5;
  --sidebar-module-deliverables-pressed: #5d7073;
  --sidebar-module-deliverables-sub: #9bb1b5;
  --sidebar-module-engineering: #4c6a92;
  --sidebar-module-engineering-foreground: #fff;
  --sidebar-module-engineering-hover: #6b89b5;
  --sidebar-module-engineering-pressed: #3a5070;
  --sidebar-module-engineering-sub: #6b89b5;
}

.dark {
  --background: oklch(.145 0 0);
  --foreground: oklch(.985 0 0);
  --card: oklch(.145 0 0);
  --card-foreground: oklch(.985 0 0);
  --popover: oklch(.145 0 0);
  --popover-foreground: oklch(.985 0 0);
  --primary: oklch(.985 0 0);
  --primary-foreground: oklch(.205 0 0);
  --secondary: oklch(.269 0 0);
  --secondary-foreground: oklch(.985 0 0);
  --muted: oklch(.269 0 0);
  --muted-foreground: oklch(.708 0 0);
  --accent: oklch(.269 0 0);
  --accent-foreground: oklch(.985 0 0);
  --destructive: oklch(.396 .141 25.723);
  --destructive-foreground: oklch(.637 .237 25.331);
  --border: oklch(.269 0 0);
  --input: oklch(.269 0 0);
  --ring: oklch(.439 0 0);
  --font-weight-medium: 500;
  --font-weight-normal: 400;
  --chart-1: oklch(.488 .243 264.376);
  --chart-2: oklch(.696 .17 162.48);
  --chart-3: oklch(.769 .188 70.08);
  --chart-4: oklch(.627 .265 303.9);
  --chart-5: oklch(.645 .246 16.439);
  --sidebar: oklch(.205 0 0);
  --sidebar-foreground: oklch(.985 0 0);
  --sidebar-primary: oklch(.488 .243 264.376);
  --sidebar-primary-foreground: oklch(.985 0 0);
  --sidebar-accent: oklch(.269 0 0);
  --sidebar-accent-foreground: oklch(.985 0 0);
  --sidebar-border: oklch(.269 0 0);
  --sidebar-ring: oklch(.439 0 0);
  --sidebar-separator: #4a4a4a;
  --sidebar-separator-hover: #6a6a6a;
  --sidebar-module-active: oklch(.25 .03 240);
  --sidebar-module-active-foreground: oklch(.85 .05 240);
  --sidebar-module-dashboard: #f4f1de;
  --sidebar-module-dashboard-foreground: #000;
  --sidebar-module-dashboard-hover: #faf9f3;
  --sidebar-module-dashboard-pressed: #e2dfcc;
  --sidebar-module-dashboard-sub: #e2dfcc;
  --sidebar-module-piping: #81b29a;
  --sidebar-module-piping-foreground: #fff;
  --sidebar-module-piping-hover: #a8d1ba;
  --sidebar-module-piping-pressed: #5e8d76;
  --sidebar-module-piping-sub: #5e8d76;
  --sidebar-module-structural: #eab69f;
  --sidebar-module-structural-foreground: #000;
  --sidebar-module-structural-hover: #f5d2c2;
  --sidebar-module-structural-pressed: #d2967e;
  --sidebar-module-structural-sub: #d2967e;
  --sidebar-module-rc: #5f797b;
  --sidebar-module-rc-foreground: #fff;
  --sidebar-module-rc-hover: #7f9a9c;
  --sidebar-module-rc-pressed: #465d5f;
  --sidebar-module-rc-sub: #465d5f;
  --sidebar-module-mep: #e07a5f;
  --sidebar-module-mep-foreground: #fff;
  --sidebar-module-mep-hover: #f1a590;
  --sidebar-module-mep-pressed: #c46147;
  --sidebar-module-mep-sub: #c46147;
  --sidebar-module-library: #8588ad;
  --sidebar-module-library-foreground: #fff;
  --sidebar-module-library-hover: #a6a9c4;
  --sidebar-module-library-pressed: #666886;
  --sidebar-module-library-sub: #666886;
  --sidebar-module-calculators: #b18787;
  --sidebar-module-calculators-foreground: #fff;
  --sidebar-module-calculators-hover: #cda6a6;
  --sidebar-module-calculators-pressed: #8f6868;
  --sidebar-module-calculators-sub: #8f6868;
  --sidebar-module-project-boards: #f2cc8f;
  --sidebar-module-project-boards-foreground: #000;
  --sidebar-module-project-boards-hover: #f8e4c3;
  --sidebar-module-project-boards-pressed: #d9b578;
  --sidebar-module-project-boards-sub: #d9b578;
  --sidebar-module-deliverables: #7a9294;
  --sidebar-module-deliverables-foreground: #fff;
  --sidebar-module-deliverables-hover: #9bb1b5;
  --sidebar-module-deliverables-pressed: #5d7073;
  --sidebar-module-deliverables-sub: #5d7073;
  --sidebar-module-engineering: #4c6a92;
  --sidebar-module-engineering-foreground: #fff;
  --sidebar-module-engineering-hover: #6b89b5;
  --sidebar-module-engineering-pressed: #3a5070;
  --sidebar-module-engineering-sub: #3a5070;
  --sidebar-piping-tier1: #81b29a;
  --sidebar-piping-tier2: #a0c3b3;
  --sidebar-piping-tier3: #c2d9cc;
  --sidebar-piping-tier4: #e4f0e6;
  --sidebar-structural-tier1: #eab69f;
  --sidebar-structural-tier2: #f1cbb9;
  --sidebar-structural-tier3: #f8e0d4;
  --sidebar-structural-tier4: #fdf3ee;
  --sidebar-library-tier1: #8588ad;
  --sidebar-library-tier2: #a4a7c2;
  --sidebar-library-tier3: #c4c5d7;
  --sidebar-library-tier4: #e3e3ec;
  --sidebar-calculators-tier1: #b18787;
  --sidebar-calculators-tier2: #c7a3a3;
  --sidebar-calculators-tier3: #ddc0c0;
  --sidebar-calculators-tier4: #f2dddd;
  --sidebar-deliverables-tier1: #7b8d8e;
  --sidebar-deliverables-tier2: #96a5a6;
  --sidebar-deliverables-tier3: #b1bdbe;
  --sidebar-deliverables-tier4: #ccd4d5;
}

html {
  font-size: var(--font-size);
}

@property --tw-border-spacing-x {
  syntax: "<length>";
  inherits: false;
  initial-value: 0;
}

@property --tw-border-spacing-y {
  syntax: "<length>";
  inherits: false;
  initial-value: 0;
}

@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
  initial-value: rotateX(0);
}

@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
  initial-value: rotateY(0);
}

@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
  initial-value: rotateZ(0);
}

@property --tw-skew-x {
  syntax: "*";
  inherits: false;
  initial-value: skewX(0);
}

@property --tw-skew-y {
  syntax: "*";
  inherits: false;
  initial-value: skewY(0);
}

@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-space-x-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

@property --tw-leading {
  syntax: "*";
  inherits: false
}

@property --tw-font-weight {
  syntax: "*";
  inherits: false
}

@property --tw-tracking {
  syntax: "*";
  inherits: false
}

@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-ring-color {
  syntax: "*";
  inherits: false
}

@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false
}

@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-ring-inset {
  syntax: "*";
  inherits: false
}

@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0;
}

@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}

@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

@property --tw-blur {
  syntax: "*";
  inherits: false
}

@property --tw-brightness {
  syntax: "*";
  inherits: false
}

@property --tw-contrast {
  syntax: "*";
  inherits: false
}

@property --tw-grayscale {
  syntax: "*";
  inherits: false
}

@property --tw-hue-rotate {
  syntax: "*";
  inherits: false
}

@property --tw-invert {
  syntax: "*";
  inherits: false
}

@property --tw-opacity {
  syntax: "*";
  inherits: false
}

@property --tw-saturate {
  syntax: "*";
  inherits: false
}

@property --tw-sepia {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false
}

@property --tw-duration {
  syntax: "*";
  inherits: false
}

@property --tw-ease {
  syntax: "*";
  inherits: false
}

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