/**
 * TreeView Component Styles
 * 
 * Fully integrated with app design system
 * Mobile-first responsive layout using CSS Grid for perfect alignment
 */

/* ===== CONTAINER ===== */

.xv-bim-viewer-root #xv-tree-view {
    width: 100%;
    height: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0.125rem;
    font-size: 0.625rem;
    line-height: 1.4;
    color: #374151;
}

.xv-bim-viewer-root.dark #xv-tree-view {
    color: #d1d5db;
}

/* ===== LIST STRUCTURE ===== */

.xv-bim-viewer-root #xv-tree-view ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

/* Tree indentation for nested levels */

.xv-bim-viewer-root #xv-tree-view ul ul {
    padding-left: 1rem;
}

/* ===== LIST ITEMS - CSS GRID FOR PERFECT ALIGNMENT ===== */

.xv-bim-viewer-root #xv-tree-view ul li {
    position: relative;
    display: grid;
    grid-template-columns: 1rem 0.75rem 1fr;
    gap: 0.25rem;
    align-items: start;
    padding: 0.0625rem 0;
    margin: 0;
}

/* Items without expand button - create invisible placeholder in first column */

.xv-bim-viewer-root #xv-tree-view ul li:not(:has(> a))::before {
    content: '';
    grid-column: 1;
}

/* ===== EXPAND/COLLAPSE BUTTONS ===== */

.xv-bim-viewer-root #xv-tree-view ul li > a {
    grid-column: 1;
    width: 1rem;
    height: 1rem;
    min-width: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 0.125rem;
    background-color: #00ebd2;
    color: #000000;
    border-radius: 0.25rem;
    font-size: 0.625rem;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
    pointer-events: all;
    transition: all 150ms ease;
}

.xv-bim-viewer-root #xv-tree-view ul li > a:hover {
    background-color: #00bca8;
    transform: scale(1.05);
}

.xv-bim-viewer-root #xv-tree-view ul li > a:active {
    transform: scale(0.95);
}

.xv-bim-viewer-root #xv-tree-view ul li > a:focus-visible {
    outline: 2px solid #00ebd2;
    outline-offset: 2px;
}

.xv-bim-viewer-root.dark #xv-tree-view ul li > a {
    background-color: #00ebd2;
    color: #000000;
}

.xv-bim-viewer-root.dark #xv-tree-view ul li > a:hover {
    background-color: #00bca8;
}

/* ===== CHECKBOXES ===== */

.xv-bim-viewer-root #xv-tree-view ul li input[type='checkbox'] {
    grid-column: 2;
    width: 0.75rem;
    height: 0.75rem;
    min-width: 0.75rem;
    margin: 0;
    margin-top: 0.25rem;
    cursor: pointer;
    pointer-events: all;
    accent-color: #00ebd2;
    flex-shrink: 0;
}

.xv-bim-viewer-root #xv-tree-view ul li input[type='checkbox']:focus-visible {
    outline: 2px solid #00ebd2;
    outline-offset: 2px;
}

/* ===== NODE LABELS ===== */

.xv-bim-viewer-root #xv-tree-view ul li span {
    grid-column: 3;
    padding: 0.375rem 0.5rem;
    min-height: 1.5rem;
    display: flex;
    align-items: center;
    border-radius: 0.25rem;
    font-weight: 500;
    cursor: default;
    pointer-events: auto;
    transition: all 150ms ease;
    white-space: nowrap;
    overflow: visible;
    text-overflow: clip;
}

.xv-bim-viewer-root #xv-tree-view ul li span:hover {
    background-color: #f0f0f0;
}

.xv-bim-viewer-root.dark #xv-tree-view ul li span:hover {
    background-color: #2d2d2d;
}

/* Selected/highlighted node */

.xv-bim-viewer-root #xv-tree-view .xv-highlighted-node {
    background-color: #00ebd2 !important;
    color: #000000 !important;
    font-weight: 600;
}

.xv-bim-viewer-root.dark #xv-tree-view .xv-highlighted-node {
    background-color: #00ebd2 !important;
    color: #000000 !important;
}

.xv-bim-viewer-root #xv-tree-view ul li span:focus-visible {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

/* ===== SCROLLBAR ===== */

.xv-bim-viewer-root #xv-tree-view::-webkit-scrollbar {
    width: 0.5rem;
}

.xv-bim-viewer-root #xv-tree-view::-webkit-scrollbar-track {
    background-color: transparent;
}

.xv-bim-viewer-root #xv-tree-view::-webkit-scrollbar-thumb {
    background-color: #9ca3af;
    border-radius: 9999px;
}

.xv-bim-viewer-root #xv-tree-view::-webkit-scrollbar-thumb:hover {
    background-color: #6b7280;
}

.xv-bim-viewer-root.dark #xv-tree-view::-webkit-scrollbar-thumb {
    background-color: #4b5563;
}

.xv-bim-viewer-root.dark #xv-tree-view::-webkit-scrollbar-thumb:hover {
    background-color: #6b7280;
}

/* ===== RESPONSIVE BREAKPOINTS ===== */

/* Tablet (768px+) */

@media (min-width: 768px) {
    .xv-bim-viewer-root #xv-tree-view {
        padding: 0.25rem;
        font-size: 0.6875rem;
    }

    .xv-bim-viewer-root #xv-tree-view ul ul {
        padding-left: 1.125rem;
    }

    .xv-bim-viewer-root #xv-tree-view ul li {
        grid-template-columns: 1.125rem 0.875rem 1fr;
        gap: 0.375rem;
    }

    .xv-bim-viewer-root #xv-tree-view ul li > a {
        width: 1.125rem;
        height: 1.125rem;
        min-width: 1.125rem;
    }

    .xv-bim-viewer-root #xv-tree-view ul li input[type='checkbox'] {
        width: 0.875rem;
        height: 0.875rem;
        min-width: 0.875rem;
    }

    .xv-bim-viewer-root #xv-tree-view ul li span {
        padding: 0.375rem 0.625rem;
    }
}

/* Desktop (1024px+) */

@media (min-width: 1024px) {
    .xv-bim-viewer-root #xv-tree-view {
        padding: 0.375rem;
        font-size: 0.75rem;
    }

    .xv-bim-viewer-root #xv-tree-view ul ul {
        padding-left: 1.25rem;
    }

    .xv-bim-viewer-root #xv-tree-view ul li {
        grid-template-columns: 1.25rem 1rem 1fr;
        gap: 0.375rem;
    }

    .xv-bim-viewer-root #xv-tree-view ul li > a {
        width: 1.25rem;
        height: 1.25rem;
        min-width: 1.25rem;
    }

    .xv-bim-viewer-root #xv-tree-view ul li input[type='checkbox'] {
        width: 1rem;
        height: 1rem;
        min-width: 1rem;
    }

    .xv-bim-viewer-root #xv-tree-view ul li span {
        padding: 0.375rem 0.75rem;
    }
}

/**
 * Context Menu Styles
 * 
 * Custom styling for xeokit ContextMenu matching app design system
 * Based on xeokit's base CSS structure
 * Note: xeokit appends context menu to document.body, so styles are global but use specific selectors
 * The dark mode is triggered by the .dark class on the html element
 */

/* ===== CONTAINER ===== */

.xeokit-context-menu {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', sans-serif;
    /* Mobile-first: Start with larger mobile sizes */
    font-size: 16px;
    min-width: 200px;
    padding: 0.5rem;
    display: none;
    z-index: 300000;
    border-radius: 0.5rem;
    backdrop-filter: blur(10px);
    overflow: hidden;
    box-sizing: border-box;
    /* Light mode by default */
    background: #ffffff;
    border: 1px solid #d1d5db;
    box-shadow:
        0 10px 25px -5px rgba(0, 0, 0, 0.1),
        0 8px 10px -6px rgba(0, 0, 0, 0.1);
}

/* Dark mode - xeokit menu is appended to body, check html element */

html.dark .xeokit-context-menu {
    background: #0a1e1c !important;
    border: 1px solid #005378 !important;
    box-shadow:
        0 10px 25px -5px rgba(0, 0, 0, 0.7),
        0 8px 10px -6px rgba(0, 0, 0, 0.5) !important;
}

/* ===== MENU LIST ===== */

.xeokit-context-menu ul {
    list-style: none;
    margin-left: 0;
    padding: 0;
}

/* ===== MENU ITEMS ===== */

.xeokit-context-menu-item {
    list-style-type: none;
    /* Mobile-first: Larger touch-friendly padding */
    padding: 0.625rem 0.875rem;
    background: transparent;
    cursor: pointer;
    width: calc(100% - 0.25rem);
    max-width: 100%;
    border-radius: 0.375rem;
    transition: all 120ms cubic-bezier(0.4, 0, 0.2, 1);
    -moz-user-select: none;
         user-select: none;
    -webkit-user-select: none;
    white-space: nowrap;
    margin-bottom: 0.125rem;
    box-sizing: border-box;
    overflow: hidden;
    text-overflow: ellipsis;
    /* Light mode by default */
    color: #1f2937;
}

/* Dark mode - xeokit menu is appended to body, check html element */

html.dark .xeokit-context-menu-item {
    color: #e5e7eb !important;
}

/* Hover state - Blue-green highlight */

.xeokit-context-menu-item:hover {
    background: #00ebd2;
    color: #000000;
    font-weight: 500;
}

/* Menu item span */

.xeokit-context-menu-item span {
    display: inline-block;
}

/* ===== DISABLED STATE ===== */

/* ===== DISABLED STATE ===== */

.xeokit-context-menu .disabled {
    display: inline-block;
    cursor: default;
    font-weight: normal;
    opacity: 0.5;
    /* Light mode by default */
    color: #9ca3af;
}

/* Dark mode - xeokit menu is appended to body, check html element */

html.dark .xeokit-context-menu .disabled {
    color: #6b7280 !important;
}

.xeokit-context-menu .disabled:hover {
    cursor: default;
    background: transparent;
    font-weight: normal;
    /* Light mode by default */
    color: #9ca3af;
}

/* Dark mode - xeokit menu is appended to body, check html element */

html.dark .xeokit-context-menu .disabled:hover {
    color: #6b7280 !important;
    background: transparent !important;
}

/* ===== SEPARATOR ===== */

.xeokit-context-menu-item-separator {
    height: 1px;
    width: 100%;
    margin: 0.375rem 0;
    padding: 0;
    /* Light mode by default */
    background: #e5e7eb;
}

/* Dark mode - xeokit menu is appended to body, check html element */

html.dark .xeokit-context-menu-item-separator {
    background: #005378 !important;
}

/* ===== SUBMENU INDICATOR ===== */

.xeokit-context-menu-item.has-submenu::after {
    content: '›';
    float: right;
    margin-left: 1.5rem;
    font-size: 1.125rem;
    opacity: 0.7;
    font-weight: 300;
}

/* ===== RESPONSIVE ===== */

/* Mobile-first: Default styles above are for mobile, enhance for larger screens */

@media (min-width: 769px) {
    .xeokit-context-menu {
        font-size: 14px;
        min-width: 180px;
        padding: 0.25rem;
    }

    .xeokit-context-menu-item {
        padding: 0.5rem 0.75rem;
    }
}

/* ===== ANIMATION ===== */

@keyframes contextMenuFadeIn {
    from {
        opacity: 0;
        transform: scale(0.95) translateY(-4px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.xeokit-context-menu[style*='display: block'] {
    animation: contextMenuFadeIn 150ms cubic-bezier(0.4, 0, 0.2, 1);
    transform-origin: top left;
}

/* Annotation container - must be positioned for absolute children */

.xv-bim-viewer-root #xv-annotationContainer {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 999;
}

.xv-bim-viewer-root .xv-bulldozair-annotation {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: absolute;
    transform: translate(calc(-50% + 0.90625rem), calc(-100% + 0.90625rem)); /* 14.5px -> 0.90625rem */
    cursor: pointer;
    z-index: 1000 !important;
    touch-action: none;
    pointer-events: auto;
}

.xv-bim-viewer-root .xv-bulldozair-annotation:hover {
    cursor: pointer;
}

.xv-bim-viewer-root .xv-bulldozair-annotation-moving {
    cursor: grabbing;
}

.xv-bim-viewer-root .xv-bulldozair-annotation-label {
    background-color: white;
    color: black;
    font-size: 0.75rem; /* 12px -> 0.75rem */
    padding: 0.125rem 0.375rem; /* 2px 6px -> 0.125rem 0.375rem */
    border-radius: 0.25rem; /* 4px -> 0.25rem */
    margin-bottom: 0.3125rem; /* 5px -> 0.3125rem */
    user-select: none; /* Standard property */
    -webkit-user-select: none; /* For iOS Safari and WebKit-based browsers */
    -ms-user-select: none; /* For older versions of Internet Explorer */
    -moz-user-select: none; /* For older versions of Firefox */
}

.xv-bim-viewer-root .xv-bulldozair-annotation-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 2.1875rem; /* 35px -> 2.1875rem */
    height: 2.1875rem; /* 35px -> 2.1875rem */
}

.xv-bim-viewer-root .xv-bulldozair-annotation-icon svg {
    display: block;
}

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

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

/*! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
 */

/*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

.xv-bim-viewer-root *,
.xv-bim-viewer-root ::before,
.xv-bim-viewer-root ::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}

.xv-bim-viewer-root ::before,
.xv-bim-viewer-root ::after {
  --tw-content: '';
}

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

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

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

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

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

.xv-bim-viewer-root hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}

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

.xv-bim-viewer-root abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

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

.xv-bim-viewer-root h1,
.xv-bim-viewer-root h2,
.xv-bim-viewer-root h3,
.xv-bim-viewer-root h4,
.xv-bim-viewer-root h5,
.xv-bim-viewer-root h6 {
  font-size: inherit;
  font-weight: inherit;
}

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

.xv-bim-viewer-root a {
  color: inherit;
  text-decoration: inherit;
}

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

.xv-bim-viewer-root b,
.xv-bim-viewer-root strong {
  font-weight: bolder;
}

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

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

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

.xv-bim-viewer-root small {
  font-size: 80%;
}

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

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

.xv-bim-viewer-root sub {
  bottom: -0.25em;
}

.xv-bim-viewer-root sup {
  top: -0.5em;
}

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

.xv-bim-viewer-root table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}

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

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

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

.xv-bim-viewer-root button,
.xv-bim-viewer-root select {
  text-transform: none;
}

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

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

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

.xv-bim-viewer-root :-moz-focusring {
  outline: auto;
}

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

.xv-bim-viewer-root :-moz-ui-invalid {
  box-shadow: none;
}

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

.xv-bim-viewer-root progress {
  vertical-align: baseline;
}

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

.xv-bim-viewer-root ::-webkit-inner-spin-button,
.xv-bim-viewer-root ::-webkit-outer-spin-button {
  height: auto;
}

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

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

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

.xv-bim-viewer-root ::-webkit-search-decoration {
  -webkit-appearance: none;
}

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

.xv-bim-viewer-root ::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

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

.xv-bim-viewer-root summary {
  display: list-item;
}

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

.xv-bim-viewer-root blockquote,
.xv-bim-viewer-root dl,
.xv-bim-viewer-root dd,
.xv-bim-viewer-root h1,
.xv-bim-viewer-root h2,
.xv-bim-viewer-root h3,
.xv-bim-viewer-root h4,
.xv-bim-viewer-root h5,
.xv-bim-viewer-root h6,
.xv-bim-viewer-root hr,
.xv-bim-viewer-root figure,
.xv-bim-viewer-root p,
.xv-bim-viewer-root pre {
  margin: 0;
}

.xv-bim-viewer-root fieldset {
  margin: 0;
  padding: 0;
}

.xv-bim-viewer-root legend {
  padding: 0;
}

.xv-bim-viewer-root ol,
.xv-bim-viewer-root ul,
.xv-bim-viewer-root menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

/*
Reset default styling for dialogs.
*/

.xv-bim-viewer-root dialog {
  padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

.xv-bim-viewer-root textarea {
  resize: vertical;
}

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

.xv-bim-viewer-root input::-moz-placeholder, .xv-bim-viewer-root textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

.xv-bim-viewer-root input::placeholder,
.xv-bim-viewer-root textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

/*
Set the default cursor for buttons.
*/

.xv-bim-viewer-root button,
.xv-bim-viewer-root [role="button"] {
  cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/

.xv-bim-viewer-root :disabled {
  cursor: default;
}

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

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

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

.xv-bim-viewer-root img,
.xv-bim-viewer-root video {
  max-width: 100%;
  height: auto;
}

/* Make elements with the HTML hidden attribute stay hidden by default */

.xv-bim-viewer-root [hidden]:where(:not([hidden="until-found"])) {
  display: none;
}

.xv-bim-viewer-root * {
        border-color: var(--border-border);
        border-style: solid;
    }

.xv-bim-viewer-root body {
        background-color: var(--color-light-bg);
        color: #1a202c;
        @media (prefers-color-scheme: dark) {
            background-color: var(--color-dark-bg);
            color: #f3f4f6;
        }
        font-smooth: always;
        font-family:
            -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu', 'Cantarell', 'Fira Sans',
            'Droid Sans', 'Helvetica Neue', sans-serif;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }

.xv-bim-viewer-root code {
        font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New', monospace;
    }

/* Scrollbar styling */

.xv-bim-viewer-root ::-webkit-scrollbar {
        width: 0.5rem;
        height: 0.5rem;
    }

.xv-bim-viewer-root ::-webkit-scrollbar-track {
        background-color: var(--color-light-surface);
    }

@media (prefers-color-scheme: dark) {
        .xv-bim-viewer-root ::-webkit-scrollbar-track {
            background-color: var(--color-dark-surface);
        }
    }

.xv-bim-viewer-root ::-webkit-scrollbar-thumb {
        background-color: #9ca3af; /* gray-400 */
        border-radius: 9999px;
    }

@media (prefers-color-scheme: dark) {
        .xv-bim-viewer-root ::-webkit-scrollbar-thumb {
            background-color: #4b5563; /* gray-600 */
        }
    }

.xv-bim-viewer-root ::-webkit-scrollbar-thumb:hover {
        background-color: #6b7280; /* gray-500 */
    }

@media (prefers-color-scheme: dark) {
        .xv-bim-viewer-root ::-webkit-scrollbar-thumb:hover {
            background-color: #6b7280; /* gray-500 */
        }
    }

/* Focus visible styles for accessibility */

.xv-bim-viewer-root .xv-focus-ring:focus-visible {
    outline: 2px solid transparent;
    outline-offset: 2px;
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(0 235 210 / var(--tw-ring-opacity, 1));
    --tw-ring-offset-width: 2px;
}

.xv-bim-viewer-root .xv-focus-ring:focus-visible:is(.xv-xv-bim-viewer-root *) {
    --tw-ring-offset-color: #0a1e1c;
}

/* Button base styles */

.xv-bim-viewer-root .xv-btn-base {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.5rem;
    font-weight: 500;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.xv-bim-viewer-root .xv-btn-base:disabled {
    cursor: not-allowed;
    opacity: 0.5;
}

.xv-bim-viewer-root .xv-btn-base:focus-visible {
    outline: 2px solid transparent;
    outline-offset: 2px;
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(0 235 210 / var(--tw-ring-opacity, 1));
    --tw-ring-offset-width: 2px;
}

.xv-bim-viewer-root .xv-btn-base:focus-visible:is(.xv-xv-bim-viewer-root *) {
    --tw-ring-offset-color: #0a1e1c;
}

/* Panel base styles */

.xv-bim-viewer-root .xv-panel-base {
    border-radius: 0.5rem;
    border-width: 1px;
    --tw-border-opacity: 1;
    border-color: rgb(179 255 249 / var(--tw-border-opacity, 1));
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
    --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.xv-bim-viewer-root .xv-panel-base:is(.xv-xv-bim-viewer-root *) {
    --tw-border-opacity: 1;
    border-color: rgb(0 83 120 / var(--tw-border-opacity, 1));
    --tw-bg-opacity: 1;
    background-color: rgb(26 72 67 / var(--tw-bg-opacity, 1));
}

/* Toolbar button styles */

.xv-bim-viewer-root .xv-toolbar-btn {
    display: flex;
    height: 2.5rem;
    width: 2.5rem;
    align-items: center;
    justify-content: center;
    border-radius: 0.5rem;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

@media (min-width: 640px) {

    .xv-bim-viewer-root .xv-toolbar-btn {
        height: 3rem;
        width: 3rem;
    }
}

.xv-bim-viewer-root .xv-toolbar-btn:focus-visible {
    outline: 2px solid transparent;
    outline-offset: 2px;
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(0 235 210 / var(--tw-ring-opacity, 1));
    --tw-ring-offset-width: 2px;
}

.xv-bim-viewer-root .xv-toolbar-btn:focus-visible:is(.xv-xv-bim-viewer-root *) {
    --tw-ring-offset-color: #0a1e1c;
}

.xv-bim-viewer-root .xv-toolbar-btn:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(230 255 254 / var(--tw-bg-opacity, 1));
}

.xv-bim-viewer-root .xv-toolbar-btn:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1;
    background-color: rgb(26 93 86 / var(--tw-bg-opacity, 1));
}

.xv-bim-viewer-root .xv-toolbar-btn[aria-pressed="true"] {
    --tw-bg-opacity: 1;
    background-color: rgb(204 255 252 / var(--tw-bg-opacity, 1));
}

.xv-bim-viewer-root .xv-toolbar-btn[aria-pressed="true"]:is(.xv-xv-bim-viewer-root *) {
    background-color: rgb(0 47 42 / 0.3);
}

.xv-bim-viewer-root .xv-toolbar-btn[aria-pressed="true"] {
    --tw-text-opacity: 1;
    color: rgb(0 141 126 / var(--tw-text-opacity, 1));
}

.xv-bim-viewer-root .xv-toolbar-btn[aria-pressed="true"]:is(.xv-xv-bim-viewer-root *) {
    --tw-text-opacity: 1;
    color: rgb(51 255 243 / var(--tw-text-opacity, 1));
}

.xv-bim-viewer-root .xv-pointer-events-none {
    pointer-events: none !important;
}

.xv-bim-viewer-root .xv-pointer-events-auto {
    pointer-events: auto !important;
}

.xv-bim-viewer-root .xv-fixed {
    position: fixed !important;
}

.xv-bim-viewer-root .xv-absolute {
    position: absolute !important;
}

.xv-bim-viewer-root .xv-relative {
    position: relative !important;
}

.xv-bim-viewer-root .xv-sticky {
    position: sticky !important;
}

.xv-bim-viewer-root .xv-inset-0 {
    inset: 0px !important;
}

.xv-bim-viewer-root .xv-inset-4 {
    inset: 1rem !important;
}

.xv-bim-viewer-root .xv-bottom-0 {
    bottom: 0px !important;
}

.xv-bim-viewer-root .xv-bottom-2 {
    bottom: 0.5rem !important;
}

.xv-bim-viewer-root .xv-bottom-20 {
    bottom: 5rem !important;
}

.xv-bim-viewer-root .xv-bottom-4 {
    bottom: 1rem !important;
}

.xv-bim-viewer-root .xv-bottom-6 {
    bottom: 1.5rem !important;
}

.xv-bim-viewer-root .xv-left-0 {
    left: 0px !important;
}

.xv-bim-viewer-root .xv-left-1\/2 {
    left: 50% !important;
}

.xv-bim-viewer-root .xv-left-2 {
    left: 0.5rem !important;
}

.xv-bim-viewer-root .xv-left-4 {
    left: 1rem !important;
}

.xv-bim-viewer-root .xv-right-0 {
    right: 0px !important;
}

.xv-bim-viewer-root .xv-right-2 {
    right: 0.5rem !important;
}

.xv-bim-viewer-root .xv-right-4 {
    right: 1rem !important;
}

.xv-bim-viewer-root .xv-right-6 {
    right: 1.5rem !important;
}

.xv-bim-viewer-root .xv-top-0 {
    top: 0px !important;
}

.xv-bim-viewer-root .xv-top-1\/2 {
    top: 50% !important;
}

.xv-bim-viewer-root .xv-top-16 {
    top: 4rem !important;
}

.xv-bim-viewer-root .xv-top-2 {
    top: 0.5rem !important;
}

.xv-bim-viewer-root .xv-top-20 {
    top: 5rem !important;
}

.xv-bim-viewer-root .xv-top-24 {
    top: 6rem !important;
}

.xv-bim-viewer-root .xv-top-full {
    top: 100% !important;
}

.xv-bim-viewer-root .\!xv-z-\[12000\] {
    z-index: 12000 !important;
}

.xv-bim-viewer-root .\!xv-z-\[12500\] {
    z-index: 12500 !important;
}

.xv-bim-viewer-root .\!xv-z-\[13000\] {
    z-index: 13000 !important;
}

.xv-bim-viewer-root .xv-z-10 {
    z-index: 10 !important;
}

.xv-bim-viewer-root .xv-z-50 {
    z-index: 50 !important;
}

.xv-bim-viewer-root .xv-z-\[1000\] {
    z-index: 1000 !important;
}

.xv-bim-viewer-root .xv-z-\[11000\] {
    z-index: 11000 !important;
}

.xv-bim-viewer-root .xv-z-\[13000\] {
    z-index: 13000 !important;
}

.xv-bim-viewer-root .xv-z-\[1500\] {
    z-index: 1500 !important;
}

.xv-bim-viewer-root .xv-z-\[2000\] {
    z-index: 2000 !important;
}

.xv-bim-viewer-root .xv-z-\[2500\] {
    z-index: 2500 !important;
}

.xv-bim-viewer-root .xv-z-\[3000\] {
    z-index: 3000 !important;
}

.xv-bim-viewer-root .xv-z-\[4000\] {
    z-index: 4000 !important;
}

.xv-bim-viewer-root .xv-z-\[5000\] {
    z-index: 5000 !important;
}

.xv-bim-viewer-root .xv-z-\[6000\] {
    z-index: 6000 !important;
}

.xv-bim-viewer-root .xv-z-\[9999\] {
    z-index: 9999 !important;
}

.xv-bim-viewer-root .xv-m-auto {
    margin: auto !important;
}

.xv-bim-viewer-root .xv-mb-0\.5 {
    margin-bottom: 0.125rem !important;
}

.xv-bim-viewer-root .xv-mb-1 {
    margin-bottom: 0.25rem !important;
}

.xv-bim-viewer-root .xv-mb-2 {
    margin-bottom: 0.5rem !important;
}

.xv-bim-viewer-root .xv-mr-1 {
    margin-right: 0.25rem !important;
}

.xv-bim-viewer-root .xv-mt-0\.5 {
    margin-top: 0.125rem !important;
}

.xv-bim-viewer-root .xv-mt-2 {
    margin-top: 0.5rem !important;
}

.xv-bim-viewer-root .xv-mt-4 {
    margin-top: 1rem !important;
}

.xv-bim-viewer-root .xv-mt-6 {
    margin-top: 1.5rem !important;
}

.xv-bim-viewer-root .xv-inline-block {
    display: inline-block !important;
}

.xv-bim-viewer-root .xv-flex {
    display: flex !important;
}

.xv-bim-viewer-root .xv-inline-flex {
    display: inline-flex !important;
}

.xv-bim-viewer-root .xv-grid {
    display: grid !important;
}

.xv-bim-viewer-root .xv-hidden {
    display: none !important;
}

.xv-bim-viewer-root .xv-h-1 {
    height: 0.25rem !important;
}

.xv-bim-viewer-root .xv-h-10 {
    height: 2.5rem !important;
}

.xv-bim-viewer-root .xv-h-12 {
    height: 3rem !important;
}

.xv-bim-viewer-root .xv-h-16 {
    height: 4rem !important;
}

.xv-bim-viewer-root .xv-h-2 {
    height: 0.5rem !important;
}

.xv-bim-viewer-root .xv-h-20 {
    height: 5rem !important;
}

.xv-bim-viewer-root .xv-h-3 {
    height: 0.75rem !important;
}

.xv-bim-viewer-root .xv-h-4 {
    height: 1rem !important;
}

.xv-bim-viewer-root .xv-h-5 {
    height: 1.25rem !important;
}

.xv-bim-viewer-root .xv-h-6 {
    height: 1.5rem !important;
}

.xv-bim-viewer-root .xv-h-8 {
    height: 2rem !important;
}

.xv-bim-viewer-root .xv-h-9 {
    height: 2.25rem !important;
}

.xv-bim-viewer-root .xv-h-\[calc\(100\%-3\.5rem\)\] {
    height: calc(100% - 3.5rem) !important;
}

.xv-bim-viewer-root .xv-h-\[calc\(100\%-6\.5rem\)\] {
    height: calc(100% - 6.5rem) !important;
}

.xv-bim-viewer-root .xv-h-full {
    height: 100% !important;
}

.xv-bim-viewer-root .xv-max-h-80 {
    max-height: 20rem !important;
}

.xv-bim-viewer-root .xv-max-h-96 {
    max-height: 24rem !important;
}

.xv-bim-viewer-root .xv-max-h-\[400px\] {
    max-height: 400px !important;
}

.xv-bim-viewer-root .xv-max-h-\[80vh\] {
    max-height: 80vh !important;
}

.xv-bim-viewer-root .xv-max-h-\[calc\(100vh-2rem\)\] {
    max-height: calc(100vh - 2rem) !important;
}

.xv-bim-viewer-root .xv-max-h-\[calc\(80vh-5rem\)\] {
    max-height: calc(80vh - 5rem) !important;
}

.xv-bim-viewer-root .xv-min-h-\[16px\] {
    min-height: 16px !important;
}

.xv-bim-viewer-root .xv-min-h-\[36px\] {
    min-height: 36px !important;
}

.xv-bim-viewer-root .xv-min-h-\[44px\] {
    min-height: 44px !important;
}

.xv-bim-viewer-root .xv-min-h-\[48px\] {
    min-height: 48px !important;
}

.xv-bim-viewer-root .xv-w-0 {
    width: 0px !important;
}

.xv-bim-viewer-root .xv-w-1 {
    width: 0.25rem !important;
}

.xv-bim-viewer-root .xv-w-10 {
    width: 2.5rem !important;
}

.xv-bim-viewer-root .xv-w-12 {
    width: 3rem !important;
}

.xv-bim-viewer-root .xv-w-16 {
    width: 4rem !important;
}

.xv-bim-viewer-root .xv-w-2 {
    width: 0.5rem !important;
}

.xv-bim-viewer-root .xv-w-20 {
    width: 5rem !important;
}

.xv-bim-viewer-root .xv-w-3 {
    width: 0.75rem !important;
}

.xv-bim-viewer-root .xv-w-4 {
    width: 1rem !important;
}

.xv-bim-viewer-root .xv-w-5 {
    width: 1.25rem !important;
}

.xv-bim-viewer-root .xv-w-56 {
    width: 14rem !important;
}

.xv-bim-viewer-root .xv-w-6 {
    width: 1.5rem !important;
}

.xv-bim-viewer-root .xv-w-72 {
    width: 18rem !important;
}

.xv-bim-viewer-root .xv-w-8 {
    width: 2rem !important;
}

.xv-bim-viewer-root .xv-w-80 {
    width: 20rem !important;
}

.xv-bim-viewer-root .xv-w-9 {
    width: 2.25rem !important;
}

.xv-bim-viewer-root .xv-w-\[17rem\] {
    width: 17rem !important;
}

.xv-bim-viewer-root .xv-w-\[280px\] {
    width: 280px !important;
}

.xv-bim-viewer-root .xv-w-auto {
    width: auto !important;
}

.xv-bim-viewer-root .xv-w-full {
    width: 100% !important;
}

.xv-bim-viewer-root .xv-w-px {
    width: 1px !important;
}

.xv-bim-viewer-root .xv-min-w-0 {
    min-width: 0px !important;
}

.xv-bim-viewer-root .xv-min-w-\[120px\] {
    min-width: 120px !important;
}

.xv-bim-viewer-root .xv-min-w-\[16px\] {
    min-width: 16px !important;
}

.xv-bim-viewer-root .xv-min-w-\[2\.75rem\] {
    min-width: 2.75rem !important;
}

.xv-bim-viewer-root .xv-min-w-\[280px\] {
    min-width: 280px !important;
}

.xv-bim-viewer-root .xv-min-w-\[2rem\] {
    min-width: 2rem !important;
}

.xv-bim-viewer-root .xv-min-w-\[300px\] {
    min-width: 300px !important;
}

.xv-bim-viewer-root .xv-min-w-\[36px\] {
    min-width: 36px !important;
}

.xv-bim-viewer-root .xv-min-w-\[44px\] {
    min-width: 44px !important;
}

.xv-bim-viewer-root .xv-min-w-\[48px\] {
    min-width: 48px !important;
}

.xv-bim-viewer-root .xv-max-w-\[400px\] {
    max-width: 400px !important;
}

.xv-bim-viewer-root .xv-max-w-\[calc\(100vw-2rem\)\] {
    max-width: calc(100vw - 2rem) !important;
}

.xv-bim-viewer-root .xv-max-w-lg {
    max-width: 32rem !important;
}

.xv-bim-viewer-root .xv-max-w-md {
    max-width: 28rem !important;
}

.xv-bim-viewer-root .xv-flex-1 {
    flex: 1 1 0% !important;
}

.xv-bim-viewer-root .xv-flex-shrink-0 {
    flex-shrink: 0 !important;
}

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

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

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

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

.xv-bim-viewer-root .xv-translate-y-0 {
    --tw-translate-y: 0px !important;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) !important;
}

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

.xv-bim-viewer-root .xv--rotate-90 {
    --tw-rotate: -90deg !important;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) !important;
}

.xv-bim-viewer-root .xv-rotate-180 {
    --tw-rotate: 180deg !important;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) !important;
}

.xv-bim-viewer-root .xv-scale-100 {
    --tw-scale-x: 1 !important;
    --tw-scale-y: 1 !important;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) !important;
}

.xv-bim-viewer-root .xv-scale-110 {
    --tw-scale-x: 1.1 !important;
    --tw-scale-y: 1.1 !important;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) !important;
}

@keyframes xv-fadeIn {

    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

.xv-bim-viewer-root .xv-animate-fade-in {
    animation: xv-fadeIn 0.2s ease-in !important;
}

.xv-bim-viewer-root .xv-cursor-grab {
    cursor: grab !important;
}

.xv-bim-viewer-root .xv-cursor-grabbing {
    cursor: grabbing !important;
}

.xv-bim-viewer-root .xv-cursor-not-allowed {
    cursor: not-allowed !important;
}

.xv-bim-viewer-root .xv-cursor-pointer {
    cursor: pointer !important;
}

.xv-bim-viewer-root .xv-touch-none {
    touch-action: none !important;
}

.xv-bim-viewer-root .xv-select-none {
    -webkit-user-select: none !important;
       -moz-user-select: none !important;
            user-select: none !important;
}

.xv-bim-viewer-root .xv-grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.xv-bim-viewer-root .xv-flex-col {
    flex-direction: column !important;
}

.xv-bim-viewer-root .xv-items-start {
    align-items: flex-start !important;
}

.xv-bim-viewer-root .xv-items-center {
    align-items: center !important;
}

.xv-bim-viewer-root .xv-items-baseline {
    align-items: baseline !important;
}

.xv-bim-viewer-root .xv-justify-center {
    justify-content: center !important;
}

.xv-bim-viewer-root .xv-justify-between {
    justify-content: space-between !important;
}

.xv-bim-viewer-root .xv-gap-0\.5 {
    gap: 0.125rem !important;
}

.xv-bim-viewer-root .xv-gap-1 {
    gap: 0.25rem !important;
}

.xv-bim-viewer-root .xv-gap-1\.5 {
    gap: 0.375rem !important;
}

.xv-bim-viewer-root .xv-gap-2 {
    gap: 0.5rem !important;
}

.xv-bim-viewer-root .xv-gap-3 {
    gap: 0.75rem !important;
}

.xv-bim-viewer-root .xv-space-y-1 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0 !important;
    margin-top: calc(0.25rem * calc(1 - var(--tw-space-y-reverse))) !important;
    margin-bottom: calc(0.25rem * var(--tw-space-y-reverse)) !important;
}

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

.xv-bim-viewer-root .xv-space-y-2 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0 !important;
    margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse))) !important;
    margin-bottom: calc(0.5rem * var(--tw-space-y-reverse)) !important;
}

.xv-bim-viewer-root .xv-space-y-3 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0 !important;
    margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse))) !important;
    margin-bottom: calc(0.75rem * var(--tw-space-y-reverse)) !important;
}

.xv-bim-viewer-root .xv-space-y-4 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0 !important;
    margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse))) !important;
    margin-bottom: calc(1rem * var(--tw-space-y-reverse)) !important;
}

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

.xv-bim-viewer-root .xv-divide-light-border > :not([hidden]) ~ :not([hidden]) {
    --tw-divide-opacity: 1 !important;
    border-color: rgb(179 255 249 / var(--tw-divide-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-overflow-hidden {
    overflow: hidden !important;
}

.xv-bim-viewer-root .xv-overflow-y-auto {
    overflow-y: auto !important;
}

.xv-bim-viewer-root .xv-overflow-x-hidden {
    overflow-x: hidden !important;
}

.xv-bim-viewer-root .xv-truncate {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.xv-bim-viewer-root .xv-whitespace-nowrap {
    white-space: nowrap !important;
}

.xv-bim-viewer-root .xv-rounded {
    border-radius: 0.25rem !important;
}

.xv-bim-viewer-root .xv-rounded-full {
    border-radius: 9999px !important;
}

.xv-bim-viewer-root .xv-rounded-lg {
    border-radius: 0.5rem !important;
}

.xv-bim-viewer-root .xv-rounded-md {
    border-radius: 0.375rem !important;
}

.xv-bim-viewer-root .xv-rounded-xl {
    border-radius: 0.75rem !important;
}

.xv-bim-viewer-root .xv-rounded-l-2xl {
    border-top-left-radius: 1rem !important;
    border-bottom-left-radius: 1rem !important;
}

.xv-bim-viewer-root .xv-rounded-r-2xl {
    border-top-right-radius: 1rem !important;
    border-bottom-right-radius: 1rem !important;
}

.xv-bim-viewer-root .xv-border {
    border-width: 1px !important;
}

.xv-bim-viewer-root .xv-border-2 {
    border-width: 2px !important;
}

.xv-bim-viewer-root .xv-border-b {
    border-bottom-width: 1px !important;
}

.xv-bim-viewer-root .xv-border-b-2 {
    border-bottom-width: 2px !important;
}

.xv-bim-viewer-root .xv-border-t {
    border-top-width: 1px !important;
}

.xv-bim-viewer-root .xv-border-blue-500 {
    --tw-border-opacity: 1 !important;
    border-color: rgb(59 130 246 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-border-gray-100 {
    --tw-border-opacity: 1 !important;
    border-color: rgb(243 244 246 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-border-gray-200 {
    --tw-border-opacity: 1 !important;
    border-color: rgb(229 231 235 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-border-gray-300 {
    --tw-border-opacity: 1 !important;
    border-color: rgb(209 213 219 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-border-gray-500 {
    --tw-border-opacity: 1 !important;
    border-color: rgb(107 114 128 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-border-gray-800 {
    --tw-border-opacity: 1 !important;
    border-color: rgb(31 41 55 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-border-light-border {
    --tw-border-opacity: 1 !important;
    border-color: rgb(179 255 249 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-border-light-border\/50 {
    border-color: rgb(179 255 249 / 0.5) !important;
}

.xv-bim-viewer-root .xv-border-orange-500 {
    --tw-border-opacity: 1 !important;
    border-color: rgb(249 115 22 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-border-primary-200 {
    --tw-border-opacity: 1 !important;
    border-color: rgb(153 255 249 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-border-primary-300 {
    --tw-border-opacity: 1 !important;
    border-color: rgb(102 255 246 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-border-primary-500 {
    --tw-border-opacity: 1 !important;
    border-color: rgb(0 235 210 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-border-primary-600 {
    --tw-border-opacity: 1 !important;
    border-color: rgb(0 188 168 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .\!xv-bg-\[\#005378\] {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 83 120 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .\!xv-bg-\[\#00EBD2\] {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 235 210 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-black\/50 {
    background-color: rgb(0 0 0 / 0.5) !important;
}

.xv-bim-viewer-root .xv-bg-blue-500 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-blue-500\/20 {
    background-color: rgb(59 130 246 / 0.2) !important;
}

.xv-bim-viewer-root .xv-bg-blue-600 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(37 99 235 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-blue-700 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(29 78 216 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-gray-200 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(229 231 235 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-gray-300 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(209 213 219 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-gray-50 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-gray-900 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(17 24 39 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-green-500 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(34 197 94 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-green-600 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(22 163 74 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-green-700 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(21 128 61 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-light-bg {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-light-border {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(179 255 249 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-light-elevated {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-light-elevated\/80 {
    background-color: rgb(255 255 255 / 0.8) !important;
}

.xv-bim-viewer-root .xv-bg-light-elevated\/95 {
    background-color: rgb(255 255 255 / 0.95) !important;
}

.xv-bim-viewer-root .xv-bg-light-surface {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(240 255 253 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-orange-500 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(249 115 22 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-orange-500\/30 {
    background-color: rgb(249 115 22 / 0.3) !important;
}

.xv-bim-viewer-root .xv-bg-orange-600 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(234 88 12 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-orange-700 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(194 65 12 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-primary-100 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(204 255 252 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-primary-50 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(230 255 254 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-primary-500 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 235 210 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-primary-600 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 188 168 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-red-600 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(220 38 38 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-red-700 {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(185 28 28 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-transparent {
    background-color: transparent !important;
}

.xv-bim-viewer-root .xv-bg-white {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-bg-white\/30 {
    background-color: rgb(255 255 255 / 0.3) !important;
}

.xv-bim-viewer-root .xv-bg-white\/50 {
    background-color: rgb(255 255 255 / 0.5) !important;
}

.xv-bim-viewer-root .xv-bg-gradient-to-br {
    background-image: linear-gradient(to bottom right, var(--tw-gradient-stops)) !important;
}

.xv-bim-viewer-root .xv-from-gray-100 {
    --tw-gradient-from: #f3f4f6 var(--tw-gradient-from-position) !important;
    --tw-gradient-to: rgb(243 244 246 / 0) var(--tw-gradient-to-position) !important;
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important;
}

.xv-bim-viewer-root .xv-to-gray-200 {
    --tw-gradient-to: #e5e7eb var(--tw-gradient-to-position) !important;
}

.xv-bim-viewer-root .xv-p-1 {
    padding: 0.25rem !important;
}

.xv-bim-viewer-root .xv-p-1\.5 {
    padding: 0.375rem !important;
}

.xv-bim-viewer-root .xv-p-2 {
    padding: 0.5rem !important;
}

.xv-bim-viewer-root .xv-p-3 {
    padding: 0.75rem !important;
}

.xv-bim-viewer-root .xv-p-4 {
    padding: 1rem !important;
}

.xv-bim-viewer-root .xv-p-6 {
    padding: 1.5rem !important;
}

.xv-bim-viewer-root .xv-px-1\.5 {
    padding-left: 0.375rem !important;
    padding-right: 0.375rem !important;
}

.xv-bim-viewer-root .xv-px-2 {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
}

.xv-bim-viewer-root .xv-px-2\.5 {
    padding-left: 0.625rem !important;
    padding-right: 0.625rem !important;
}

.xv-bim-viewer-root .xv-px-3 {
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
}

.xv-bim-viewer-root .xv-px-4 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
}

.xv-bim-viewer-root .xv-px-6 {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
}

.xv-bim-viewer-root .xv-py-0\.5 {
    padding-top: 0.125rem !important;
    padding-bottom: 0.125rem !important;
}

.xv-bim-viewer-root .xv-py-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
}

.xv-bim-viewer-root .xv-py-1\.5 {
    padding-top: 0.375rem !important;
    padding-bottom: 0.375rem !important;
}

.xv-bim-viewer-root .xv-py-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
}

.xv-bim-viewer-root .xv-py-2\.5 {
    padding-top: 0.625rem !important;
    padding-bottom: 0.625rem !important;
}

.xv-bim-viewer-root .xv-py-3 {
    padding-top: 0.75rem !important;
    padding-bottom: 0.75rem !important;
}

.xv-bim-viewer-root .xv-py-4 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
}

.xv-bim-viewer-root .xv-pb-3 {
    padding-bottom: 0.75rem !important;
}

.xv-bim-viewer-root .xv-pl-7 {
    padding-left: 1.75rem !important;
}

.xv-bim-viewer-root .xv-pr-2 {
    padding-right: 0.5rem !important;
}

.xv-bim-viewer-root .xv-pr-4 {
    padding-right: 1rem !important;
}

.xv-bim-viewer-root .xv-text-left {
    text-align: left !important;
}

.xv-bim-viewer-root .xv-text-center {
    text-align: center !important;
}

.xv-bim-viewer-root .xv-text-\[10px\] {
    font-size: 10px !important;
}

.xv-bim-viewer-root .xv-text-base {
    font-size: 1rem !important;
    line-height: 1.5rem !important;
}

.xv-bim-viewer-root .xv-text-lg {
    font-size: 1.125rem !important;
    line-height: 1.75rem !important;
}

.xv-bim-viewer-root .xv-text-sm {
    font-size: 0.875rem !important;
    line-height: 1.25rem !important;
}

.xv-bim-viewer-root .xv-text-xl {
    font-size: 1.25rem !important;
    line-height: 1.75rem !important;
}

.xv-bim-viewer-root .xv-text-xs {
    font-size: 0.75rem !important;
    line-height: 1rem !important;
}

.xv-bim-viewer-root .xv-font-bold {
    font-weight: 700 !important;
}

.xv-bim-viewer-root .xv-font-medium {
    font-weight: 500 !important;
}

.xv-bim-viewer-root .xv-font-semibold {
    font-weight: 600 !important;
}

.xv-bim-viewer-root .xv-uppercase {
    text-transform: uppercase !important;
}

.xv-bim-viewer-root .xv-capitalize {
    text-transform: capitalize !important;
}

.xv-bim-viewer-root .xv-tracking-wide {
    letter-spacing: 0.025em !important;
}

.xv-bim-viewer-root .\!xv-text-black {
    --tw-text-opacity: 1 !important;
    color: rgb(0 0 0 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-text-black {
    --tw-text-opacity: 1 !important;
    color: rgb(0 0 0 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-text-gray-400 {
    --tw-text-opacity: 1 !important;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-text-gray-500 {
    --tw-text-opacity: 1 !important;
    color: rgb(107 114 128 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-text-gray-600 {
    --tw-text-opacity: 1 !important;
    color: rgb(75 85 99 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-text-gray-700 {
    --tw-text-opacity: 1 !important;
    color: rgb(55 65 81 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-text-gray-900 {
    --tw-text-opacity: 1 !important;
    color: rgb(17 24 39 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-text-primary-600 {
    --tw-text-opacity: 1 !important;
    color: rgb(0 188 168 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-text-primary-700 {
    --tw-text-opacity: 1 !important;
    color: rgb(0 141 126 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-text-primary-900 {
    --tw-text-opacity: 1 !important;
    color: rgb(0 47 42 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-text-white {
    --tw-text-opacity: 1 !important;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .xv-accent-primary-600 {
    accent-color: #00bca8 !important;
}

.xv-bim-viewer-root .xv-opacity-0 {
    opacity: 0 !important;
}

.xv-bim-viewer-root .xv-opacity-100 {
    opacity: 1 !important;
}

.xv-bim-viewer-root .xv-opacity-50 {
    opacity: 0.5 !important;
}

.xv-bim-viewer-root .xv-shadow-2xl {
    --tw-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25) !important;
    --tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color) !important;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
}

.xv-bim-viewer-root .xv-shadow-lg {
    --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1) !important;
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color) !important;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
}

.xv-bim-viewer-root .xv-shadow-md {
    --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1) !important;
    --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color) !important;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
}

.xv-bim-viewer-root .xv-shadow-sm {
    --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05) !important;
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color) !important;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
}

.xv-bim-viewer-root .xv-shadow-xl {
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1) !important;
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color) !important;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
}

.xv-bim-viewer-root .xv-shadow-black\/10 {
    --tw-shadow-color: rgb(0 0 0 / 0.1) !important;
    --tw-shadow: var(--tw-shadow-colored) !important;
}

.xv-bim-viewer-root .xv-backdrop-blur-lg {
    --tw-backdrop-blur: blur(16px) !important;
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia) !important;
}

.xv-bim-viewer-root .xv-backdrop-blur-md {
    --tw-backdrop-blur: blur(12px) !important;
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia) !important;
}

.xv-bim-viewer-root .xv-backdrop-saturate-150 {
    --tw-backdrop-saturate: saturate(1.5) !important;
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia) !important;
}

.xv-bim-viewer-root .xv-transition-all {
    transition-property: all !important;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
    transition-duration: 150ms !important;
}

.xv-bim-viewer-root .xv-transition-colors {
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke !important;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
    transition-duration: 150ms !important;
}

.xv-bim-viewer-root .xv-transition-opacity {
    transition-property: opacity !important;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
    transition-duration: 150ms !important;
}

.xv-bim-viewer-root .xv-transition-transform {
    transition-property: transform !important;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
    transition-duration: 150ms !important;
}

.xv-bim-viewer-root .xv-duration-200 {
    transition-duration: 200ms !important;
}

.xv-bim-viewer-root .xv-duration-300 {
    transition-duration: 300ms !important;
}

.xv-bim-viewer-root .xv-duration-75 {
    transition-duration: 75ms !important;
}

.xv-bim-viewer-root .xv-ease-in-out {
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.xv-bim-viewer-root .xv-ease-out {
    transition-timing-function: cubic-bezier(0, 0, 0.2, 1) !important;
}

/* Minimum touch target size for accessibility */

.xv-bim-viewer-root .xv-touch-target {
    min-height: 44px;
    min-width: 44px;
}

/* Hide scrollbar but keep functionality */

.xv-bim-viewer-root .xv-scrollbar-hide {
        -ms-overflow-style: none !important;
        scrollbar-width: none !important;
    }

.xv-bim-viewer-root .xv-scrollbar-hide::-webkit-scrollbar {
        display: none !important;
    }

/* Root container containment */

.xv-bim-viewer-root {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    isolation: isolate;
    contain: layout style paint;
}

.xv-bim-viewer-root #xv-movement-joystick-container {
    position: absolute;
    bottom: 10%;
    left: 20%;
}

.xv-bim-viewer-root #xv-rotation-joystick-container {
    position: absolute;
    bottom: 10%;
    right: 20%;
}

/* ===== MEASUREMENT STYLES ===== */

/* Override xeokit's default z-index values to keep measurements behind panels and menus */

/* Z-index hierarchy: canvas (0) < measurements (1000-2000) < dropdowns (3000) < panels/toolbar (12000) < tooltips (99999) */

/* Measurement wires (lines connecting measurement points) */

.xv-bim-viewer-root .xeokit-measurement-wire,
.xv-bim-viewer-root .xeokit-measurement-wire-clickable {
    z-index: 1000 !important; /* Below all UI elements */
}

/* Measurement dots (clickable points) */

.xv-bim-viewer-root .xeokit-measurement-dot,
.xv-bim-viewer-root .xeokit-measurement-dot-clickable {
    z-index: 1500 !important; /* Above wires but below UI */
}

/* Measurement labels (distance/angle text) */

.xv-bim-viewer-root .xeokit-measurement-label {
    z-index: 1800 !important; /* Above dots but below UI */
}

/* Measurement axis labels */

.xv-bim-viewer-root .xeokit-measurement-axis-label {
    z-index: 1800 !important; /* Same as regular labels */
}

/* Ensure measurements stay contained within viewer root */

.xv-bim-viewer-root .xeokit-measurement-wire,
.xv-bim-viewer-root .xeokit-measurement-wire-clickable,
.xv-bim-viewer-root .xeokit-measurement-dot,
.xv-bim-viewer-root .xeokit-measurement-dot-clickable,
.xv-bim-viewer-root .xeokit-measurement-label,
.xv-bim-viewer-root .xeokit-measurement-axis-label {
    position: absolute !important;
}

.xv-bim-viewer-root .placeholder\:xv-text-gray-400::-moz-placeholder {
    --tw-text-opacity: 1 !important;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .placeholder\:xv-text-gray-400::placeholder {
    --tw-text-opacity: 1 !important;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .last\:xv-border-b-0:last-child {
    border-bottom-width: 0px !important;
}

.xv-bim-viewer-root .hover\:xv-scale-105:hover {
    --tw-scale-x: 1.05 !important;
    --tw-scale-y: 1.05 !important;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) !important;
}

.xv-bim-viewer-root .hover\:xv-border-primary-500\/50:hover {
    border-color: rgb(0 235 210 / 0.5) !important;
}

.xv-bim-viewer-root .hover\:xv-border-red-500\/50:hover {
    border-color: rgb(239 68 68 / 0.5) !important;
}

.xv-bim-viewer-root .hover\:\!xv-bg-\[\#004260\]:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 66 96 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:\!xv-bg-\[\#00bca8\]:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 188 168 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-bg-gray-100:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-bg-gray-300:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(209 213 219 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-bg-gray-50:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-bg-gray-800:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-bg-green-700:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(21 128 61 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-bg-light-hover:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(230 255 254 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-bg-primary-600:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 188 168 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-bg-primary-700:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 141 126 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-bg-red-700:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(185 28 28 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-bg-white:hover {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-bg-white\/20:hover {
    background-color: rgb(255 255 255 / 0.2) !important;
}

.xv-bim-viewer-root .hover\:xv-text-gray-900:hover {
    --tw-text-opacity: 1 !important;
    color: rgb(17 24 39 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-text-primary-500:hover {
    --tw-text-opacity: 1 !important;
    color: rgb(0 235 210 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-text-primary-700:hover {
    --tw-text-opacity: 1 !important;
    color: rgb(0 141 126 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-text-red-500:hover {
    --tw-text-opacity: 1 !important;
    color: rgb(239 68 68 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .hover\:xv-underline:hover {
    text-decoration-line: underline !important;
}

.xv-bim-viewer-root .hover\:xv-shadow-2xl:hover {
    --tw-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25) !important;
    --tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color) !important;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
}

.xv-bim-viewer-root .hover\:xv-shadow-xl:hover {
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1) !important;
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color) !important;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
}

.xv-bim-viewer-root .hover\:xv-shadow-primary-500\/20:hover {
    --tw-shadow-color: rgb(0 235 210 / 0.2) !important;
    --tw-shadow: var(--tw-shadow-colored) !important;
}

.xv-bim-viewer-root .hover\:xv-shadow-red-500\/20:hover {
    --tw-shadow-color: rgb(239 68 68 / 0.2) !important;
    --tw-shadow: var(--tw-shadow-colored) !important;
}

.xv-bim-viewer-root .focus\:xv-outline-none:focus {
    outline: 2px solid transparent !important;
    outline-offset: 2px !important;
}

.xv-bim-viewer-root .focus\:xv-ring-2:focus {
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) !important;
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color) !important;
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000) !important;
}

.xv-bim-viewer-root .focus\:xv-ring-primary-500:focus {
    --tw-ring-opacity: 1 !important;
    --tw-ring-color: rgb(0 235 210 / var(--tw-ring-opacity, 1)) !important;
}

.xv-bim-viewer-root .focus\:xv-ring-primary-500\/50:focus {
    --tw-ring-color: rgb(0 235 210 / 0.5) !important;
}

.xv-bim-viewer-root .focus\:xv-ring-offset-2:focus {
    --tw-ring-offset-width: 2px !important;
}

.xv-bim-viewer-root .active\:\!xv-bg-\[\#003550\]:active {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 53 80 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .active\:\!xv-bg-\[\#00a895\]:active {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 168 149 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .active\:xv-bg-primary-800:active {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 94 84 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .active\:xv-bg-red-800:active {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(153 27 27 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .disabled\:xv-cursor-not-allowed:disabled {
    cursor: not-allowed !important;
}

.xv-bim-viewer-root .disabled\:xv-bg-gray-300:disabled {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(209 213 219 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .disabled\:xv-opacity-50:disabled {
    opacity: 0.5 !important;
}

.xv-bim-viewer-root .xv-group:hover .group-hover\:xv-opacity-100 {
    opacity: 1 !important;
}

.xv-bim-viewer-root .dark\:xv-divide-dark-border:is(.xv-xv-bim-viewer-root *) > :not([hidden]) ~ :not([hidden]) {
    --tw-divide-opacity: 1 !important;
    border-color: rgb(0 83 120 / var(--tw-divide-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-border-dark-border:is(.xv-xv-bim-viewer-root *) {
    --tw-border-opacity: 1 !important;
    border-color: rgb(0 83 120 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-border-dark-border\/50:is(.xv-xv-bim-viewer-root *) {
    border-color: rgb(0 83 120 / 0.5) !important;
}

.xv-bim-viewer-root .dark\:xv-border-gray-600:is(.xv-xv-bim-viewer-root *) {
    --tw-border-opacity: 1 !important;
    border-color: rgb(75 85 99 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-border-gray-700:is(.xv-xv-bim-viewer-root *) {
    --tw-border-opacity: 1 !important;
    border-color: rgb(55 65 81 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-border-gray-700\/50:is(.xv-xv-bim-viewer-root *) {
    border-color: rgb(55 65 81 / 0.5) !important;
}

.xv-bim-viewer-root .dark\:xv-border-primary-400:is(.xv-xv-bim-viewer-root *) {
    --tw-border-opacity: 1 !important;
    border-color: rgb(51 255 243 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-border-primary-700:is(.xv-xv-bim-viewer-root *) {
    --tw-border-opacity: 1 !important;
    border-color: rgb(0 141 126 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-border-primary-800:is(.xv-xv-bim-viewer-root *) {
    --tw-border-opacity: 1 !important;
    border-color: rgb(0 94 84 / var(--tw-border-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:\!xv-bg-\[\#005378\]:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 83 120 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:\!xv-bg-\[\#00EBD2\]:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 235 210 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-blue-500:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-blue-600:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(37 99 235 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-dark-border:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 83 120 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-dark-elevated:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(26 72 67 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-dark-elevated\/80:is(.xv-xv-bim-viewer-root *) {
    background-color: rgb(26 72 67 / 0.8) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-dark-elevated\/95:is(.xv-xv-bim-viewer-root *) {
    background-color: rgb(26 72 67 / 0.95) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-dark-surface:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(16 51 48 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-gray-100:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-gray-600:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(75 85 99 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-gray-700:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(55 65 81 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-gray-800:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-gray-800\/50:is(.xv-xv-bim-viewer-root *) {
    background-color: rgb(31 41 55 / 0.5) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-gray-900:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(17 24 39 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-gray-900\/50:is(.xv-xv-bim-viewer-root *) {
    background-color: rgb(17 24 39 / 0.5) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-green-400:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(74 222 128 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-green-500:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(34 197 94 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-green-600:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(22 163 74 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-orange-500:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(249 115 22 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-orange-600:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(234 88 12 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-primary-500:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 235 210 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-primary-700:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 141 126 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-primary-900\/20:is(.xv-xv-bim-viewer-root *) {
    background-color: rgb(0 47 42 / 0.2) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-primary-900\/30:is(.xv-xv-bim-viewer-root *) {
    background-color: rgb(0 47 42 / 0.3) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-red-500:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-bg-red-600:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(220 38 38 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-from-gray-900:is(.xv-xv-bim-viewer-root *) {
    --tw-gradient-from: #111827 var(--tw-gradient-from-position) !important;
    --tw-gradient-to: rgb(17 24 39 / 0) var(--tw-gradient-to-position) !important;
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important;
}

.xv-bim-viewer-root .dark\:xv-to-gray-800:is(.xv-xv-bim-viewer-root *) {
    --tw-gradient-to: #1f2937 var(--tw-gradient-to-position) !important;
}

.xv-bim-viewer-root .dark\:xv-text-gray-100:is(.xv-xv-bim-viewer-root *) {
    --tw-text-opacity: 1 !important;
    color: rgb(243 244 246 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-text-gray-200:is(.xv-xv-bim-viewer-root *) {
    --tw-text-opacity: 1 !important;
    color: rgb(229 231 235 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-text-gray-300:is(.xv-xv-bim-viewer-root *) {
    --tw-text-opacity: 1 !important;
    color: rgb(209 213 219 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-text-gray-400:is(.xv-xv-bim-viewer-root *) {
    --tw-text-opacity: 1 !important;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-text-gray-500:is(.xv-xv-bim-viewer-root *) {
    --tw-text-opacity: 1 !important;
    color: rgb(107 114 128 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-text-gray-900:is(.xv-xv-bim-viewer-root *) {
    --tw-text-opacity: 1 !important;
    color: rgb(17 24 39 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-text-primary-100:is(.xv-xv-bim-viewer-root *) {
    --tw-text-opacity: 1 !important;
    color: rgb(204 255 252 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-text-primary-400:is(.xv-xv-bim-viewer-root *) {
    --tw-text-opacity: 1 !important;
    color: rgb(51 255 243 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:xv-shadow-black\/50:is(.xv-xv-bim-viewer-root *) {
    --tw-shadow-color: rgb(0 0 0 / 0.5) !important;
    --tw-shadow: var(--tw-shadow-colored) !important;
}

.xv-bim-viewer-root .dark\:placeholder\:xv-text-gray-500:is(.xv-xv-bim-viewer-root *)::-moz-placeholder {
    --tw-text-opacity: 1 !important;
    color: rgb(107 114 128 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:placeholder\:xv-text-gray-500:is(.xv-xv-bim-viewer-root *)::placeholder {
    --tw-text-opacity: 1 !important;
    color: rgb(107 114 128 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-border-primary-400\/50:hover:is(.xv-xv-bim-viewer-root *) {
    border-color: rgb(51 255 243 / 0.5) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-border-red-400\/50:hover:is(.xv-xv-bim-viewer-root *) {
    border-color: rgb(248 113 113 / 0.5) !important;
}

.xv-bim-viewer-root .dark\:hover\:\!xv-bg-\[\#004260\]:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 66 96 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:\!xv-bg-\[\#00bca8\]:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 188 168 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-bg-dark-hover:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(26 93 86 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-bg-gray-600:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(75 85 99 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-bg-gray-700:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(55 65 81 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-bg-gray-700\/50:hover:is(.xv-xv-bim-viewer-root *) {
    background-color: rgb(55 65 81 / 0.5) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-bg-gray-800:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-bg-green-600:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(22 163 74 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-bg-primary-600:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(0 188 168 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-bg-red-600:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(220 38 38 / var(--tw-bg-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-text-gray-100:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-text-opacity: 1 !important;
    color: rgb(243 244 246 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-text-primary-300:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-text-opacity: 1 !important;
    color: rgb(102 255 246 / var(--tw-text-opacity, 1)) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-shadow-primary-400\/20:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-shadow-color: rgb(51 255 243 / 0.2) !important;
    --tw-shadow: var(--tw-shadow-colored) !important;
}

.xv-bim-viewer-root .dark\:hover\:xv-shadow-red-400\/20:hover:is(.xv-xv-bim-viewer-root *) {
    --tw-shadow-color: rgb(248 113 113 / 0.2) !important;
    --tw-shadow: var(--tw-shadow-colored) !important;
}

.xv-bim-viewer-root .dark\:disabled\:xv-bg-gray-700:disabled:is(.xv-xv-bim-viewer-root *) {
    --tw-bg-opacity: 1 !important;
    background-color: rgb(55 65 81 / var(--tw-bg-opacity, 1)) !important;
}

@media (min-width: 640px) {

    .xv-bim-viewer-root .sm\:xv-inset-x-6 {
        left: 1.5rem !important;
        right: 1.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-inset-y-8 {
        top: 2rem !important;
        bottom: 2rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-left-6 {
        left: 1.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-left-auto {
        left: auto !important;
    }

    .xv-bim-viewer-root .sm\:xv-right-0 {
        right: 0px !important;
    }

    .xv-bim-viewer-root .sm\:xv-right-6 {
        right: 1.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-top-20 {
        top: 5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-top-24 {
        top: 6rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-top-28 {
        top: 7rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-h-10 {
        height: 2.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-h-4 {
        height: 1rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-h-5 {
        height: 1.25rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-h-8 {
        height: 2rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-max-h-\[calc\(100vh-4rem\)\] {
        max-height: calc(100vh - 4rem) !important;
    }

    .xv-bim-viewer-root .sm\:xv-w-10 {
        width: 2.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-w-4 {
        width: 1rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-w-5 {
        width: 1.25rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-w-80 {
        width: 20rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-w-\[20\.4rem\] {
        width: 20.4rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-min-w-\[140px\] {
        min-width: 140px !important;
    }

    .xv-bim-viewer-root .sm\:xv-min-w-\[2\.5rem\] {
        min-width: 2.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-max-w-lg {
        max-width: 32rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-translate-x-0 {
        --tw-translate-x: 0px !important;
        transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) !important;
    }

    .xv-bim-viewer-root .sm\:xv-gap-1 {
        gap: 0.25rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-gap-2 {
        gap: 0.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-gap-3 {
        gap: 0.75rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-space-y-2 > :not([hidden]) ~ :not([hidden]) {
        --tw-space-y-reverse: 0 !important;
        margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse))) !important;
        margin-bottom: calc(0.5rem * var(--tw-space-y-reverse)) !important;
    }

    .xv-bim-viewer-root .sm\:xv-space-y-3 > :not([hidden]) ~ :not([hidden]) {
        --tw-space-y-reverse: 0 !important;
        margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse))) !important;
        margin-bottom: calc(0.75rem * var(--tw-space-y-reverse)) !important;
    }

    .xv-bim-viewer-root .sm\:xv-space-y-6 > :not([hidden]) ~ :not([hidden]) {
        --tw-space-y-reverse: 0 !important;
        margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse))) !important;
        margin-bottom: calc(1.5rem * var(--tw-space-y-reverse)) !important;
    }

    .xv-bim-viewer-root .sm\:xv-rounded-2xl {
        border-radius: 1rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-rounded-xl {
        border-radius: 0.75rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-p-1\.5 {
        padding: 0.375rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-p-3 {
        padding: 0.75rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-p-4 {
        padding: 1rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-p-6 {
        padding: 1.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-px-2 {
        padding-left: 0.5rem !important;
        padding-right: 0.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-px-2\.5 {
        padding-left: 0.625rem !important;
        padding-right: 0.625rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-px-3 {
        padding-left: 0.75rem !important;
        padding-right: 0.75rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-px-4 {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-px-6 {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-py-1 {
        padding-top: 0.25rem !important;
        padding-bottom: 0.25rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-py-1\.5 {
        padding-top: 0.375rem !important;
        padding-bottom: 0.375rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-py-2 {
        padding-top: 0.5rem !important;
        padding-bottom: 0.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-py-2\.5 {
        padding-top: 0.625rem !important;
        padding-bottom: 0.625rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-py-3 {
        padding-top: 0.75rem !important;
        padding-bottom: 0.75rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-py-6 {
        padding-top: 1.5rem !important;
        padding-bottom: 1.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-text-2xl {
        font-size: 1.5rem !important;
        line-height: 2rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-text-base {
        font-size: 1rem !important;
        line-height: 1.5rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-text-sm {
        font-size: 0.875rem !important;
        line-height: 1.25rem !important;
    }

    .xv-bim-viewer-root .sm\:xv-text-xl {
        font-size: 1.25rem !important;
        line-height: 1.75rem !important;
    }
}

@media (min-width: 768px) {

    .xv-bim-viewer-root .md\:xv-inset-auto {
        inset: auto !important;
    }

    .xv-bim-viewer-root .md\:xv-left-1\/2 {
        left: 50% !important;
    }

    .xv-bim-viewer-root .md\:xv-top-1\/2 {
        top: 50% !important;
    }

    .xv-bim-viewer-root .md\:xv-top-24 {
        top: 6rem !important;
    }

    .xv-bim-viewer-root .md\:xv-m-0 {
        margin: 0px !important;
    }

    .xv-bim-viewer-root .md\:xv-max-w-xl {
        max-width: 36rem !important;
    }

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

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

    .xv-bim-viewer-root .md\:xv-gap-1 {
        gap: 0.25rem !important;
    }

    .xv-bim-viewer-root .md\:xv-gap-2 {
        gap: 0.5rem !important;
    }

    .xv-bim-viewer-root .md\:xv-gap-3 {
        gap: 0.75rem !important;
    }

    .xv-bim-viewer-root .md\:xv-px-2\.5 {
        padding-left: 0.625rem !important;
        padding-right: 0.625rem !important;
    }

    .xv-bim-viewer-root .md\:xv-px-4 {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .xv-bim-viewer-root .md\:xv-px-6 {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }

    .xv-bim-viewer-root .md\:xv-py-2 {
        padding-top: 0.5rem !important;
        padding-bottom: 0.5rem !important;
    }

    .xv-bim-viewer-root .md\:xv-py-3 {
        padding-top: 0.75rem !important;
        padding-bottom: 0.75rem !important;
    }

    .xv-bim-viewer-root .md\:xv-py-4 {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
    }
}

@media (min-width: 1024px) {

    .xv-bim-viewer-root .lg\:xv-block {
        display: block !important;
    }

    .xv-bim-viewer-root .lg\:xv-inline {
        display: inline !important;
    }

    .xv-bim-viewer-root .lg\:xv-flex {
        display: flex !important;
    }

    .xv-bim-viewer-root .lg\:xv-hidden {
        display: none !important;
    }

    .xv-bim-viewer-root .lg\:xv-w-\[25\.5rem\] {
        width: 25.5rem !important;
    }

    .xv-bim-viewer-root .lg\:xv-min-w-\[100px\] {
        min-width: 100px !important;
    }

    .xv-bim-viewer-root .lg\:xv-max-w-2xl {
        max-width: 42rem !important;
    }

    .xv-bim-viewer-root .lg\:xv-px-3 {
        padding-left: 0.75rem !important;
        padding-right: 0.75rem !important;
    }
}

@media (min-width: 1280px) {

    .xv-bim-viewer-root .xl\:xv-w-\[29\.75rem\] {
        width: 29.75rem !important;
    }
}
