        /* === Critical mobile guards (prevents sideways pan + FOUC before Tailwind loads) === */
        html, body { width: 100%; max-width: 100%; overflow-x: hidden; }
        html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
        .hidden { display: none; }
        html.omni-preload #omniSiteSidebar{ transition:none !important; }
        html.omni-preload #omniSiteSidebarBackdrop{ transition:none !important; }
                /* Critical layout (prevents sidebar from rendering in the wrong place before Tailwind classes apply) */
        body { display:flex; flex-direction:column; }
        main { width: 100%; max-width: 100%; }
        @media (min-width: 768px){
          body { display:flex; flex-direction:row; }
          body > main { flex: 1 1 0% !important; width: auto !important; min-width: 0 !important; }
          main { flex: 1 1 auto; min-width: 0; }
          #omniSiteSidebar { flex: 0 0 auto; }
          /* Default collapsed width; expand only when not collapsed */
          #omniSiteSidebar { width: 5rem; }
          #omniSiteSidebar:not(.is-collapsed) { width: 24rem; }
        }


/* Mobile: force layout to use viewport width (prevents any flex/sidebar width influencing content) */
@media (max-width: 767px){
  body { flex-direction: column; }
  body > main { width: 100% !important; }
  main { width: 100vw !important; max-width: 100vw !important; }
  #omniContentContainer { width: 100vw !important; max-width: 100vw !important; margin-left: 0 !important; margin-right: 0 !important; }
} /* ensure elements truly hide even before Tailwind loads */
        main, #omniContentContainer, #toolContainer { min-width: 0; max-width: 100vw; overflow-x: hidden; }
        img, svg, video, canvas, iframe { max-width: 100%; }

        /* Allow horizontal chip/tab scrollers while still preventing page sideways-pan */
        #omniContentContainer { overscroll-behavior-x: none; }
        .omni-hscroll { overflow-x: auto; -webkit-overflow-scrolling: touch; touch-action: pan-x; overscroll-behavior-x: contain; }

/* Custom Scrollbar */
        ::-webkit-scrollbar {
            width: 8px;
            height: 8px;
        }
        ::-webkit-scrollbar-track {
            background: #0B0C10; 
        }
        ::-webkit-scrollbar-thumb {
            background: #1F2833; 
            border-radius: 4px;
        }
        ::-webkit-scrollbar-thumb:hover {
            background: #45A29E; 
        }

        /* Hide scrollbar helper (for horizontal chip rows) */
        .no-scrollbar::-webkit-scrollbar { display: none; }
        .no-scrollbar { -ms-overflow-style: none; scrollbar-width: none; }

        /* Login Screen Specific Utilities */
        .glass-panel-login {
            background: rgba(10, 20, 35, 0.7);
            backdrop-filter: blur(12px);
            -webkit-backdrop-filter: blur(12px);
            border: 1px solid rgba(0, 242, 255, 0.1);
            box-shadow: 0 0 40px rgba(0, 0, 0, 0.5);
        }

        .input-field {
            background: rgba(0, 0, 0, 0.4);
            border: 1px solid rgba(255, 255, 255, 0.1);
            transition: all 0.3s ease;
        }

        .input-field:focus {
            border-color: #00f2ff;
            box-shadow: 0 0 15px rgba(0, 242, 255, 0.2);
            outline: none;
        }

        .btn-primary-login {
            background: linear-gradient(90deg, #00c6ff 0%, #0072ff 100%);
            position: relative;
            overflow: hidden;
            transition: all 0.3s ease;
        }

        .btn-primary-login::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
            transition: 0.5s;
        }

        .btn-primary-login:hover::before {
            left: 100%;
        }

        .btn-primary-login:hover {
            transform: translateY(-2px);
            box-shadow: 0 0 20px rgba(0, 114, 255, 0.4);
        }

        .btn-secondary-login {
            background: transparent;
            border: 1px solid rgba(0, 242, 255, 0.3);
            color: #00f2ff;
            transition: all 0.3s ease;
        }

        .btn-secondary-login:hover {
            background: rgba(0, 242, 255, 0.1);
            border-color: #00f2ff;
            box-shadow: 0 0 15px rgba(0, 242, 255, 0.2);
        }

        .auth-mode-btn{
            border: 1px solid rgba(0, 242, 255, 0.18);
            background: rgba(0,0,0,0.25);
            color: rgba(224,255,255,0.8);
            transition: all 0.25s ease;
        }
        .auth-mode-btn:hover{
            border-color: rgba(0, 242, 255, 0.45);
            box-shadow: 0 0 16px rgba(0, 242, 255, 0.12);
            color: rgba(224,255,255,0.95);
        }
        .auth-mode-active{
            background: linear-gradient(90deg, rgba(0, 198, 255, 0.22), rgba(112, 0, 255, 0.18));
            border-color: rgba(0, 242, 255, 0.55);
            box-shadow: 0 0 18px rgba(0, 242, 255, 0.16);
        }


        /* Background grid animation for Login */
        .bg-grid {
            background-size: 50px 50px;
            background-image: 
                linear-gradient(to right, rgba(0, 242, 255, 0.05) 1px, transparent 1px),
                linear-gradient(to bottom, rgba(0, 242, 255, 0.05) 1px, transparent 1px);
            mask-image: radial-gradient(circle at center, black 40%, transparent 100%);
        }

        .glitch-hover:hover {
            animation: glitch 0.3s cubic-bezier(.25, .46, .45, .94) both infinite;
            color: #00f2ff;
        }

        @keyframes glitch {
            0% { transform: translate(0) }
            20% { transform: translate(-2px, 2px) }
            40% { transform: translate(-2px, -2px) }
            60% { transform: translate(2px, 2px) }
            80% { transform: translate(2px, -2px) }
            100% { transform: translate(0) }
        }
        
        .shake {
            animation: shake 0.5s cubic-bezier(.36,.07,.19,.97) both;
        }
        
        @keyframes shake {
            10%, 90% { transform: translate3d(-1px, 0, 0); }
            20%, 80% { transform: translate3d(2px, 0, 0); }
            30%, 50%, 70% { transform: translate3d(-4px, 0, 0); }
            40%, 60% { transform: translate3d(4px, 0, 0); }
        }


        /* Employee Badge */
        .employee-badge{
            display:inline-flex;
            align-items:center;
            gap:0.4rem;
            padding:0.15rem 0.5rem;
            border-radius:999px;
            border:1px solid rgba(102,252,241,0.35);
            background: linear-gradient(90deg, rgba(102,252,241,0.12), rgba(139,92,246,0.10));
            box-shadow: 0 0 18px rgba(102,252,241,0.12);
            font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
            letter-spacing:0.08em;
            text-transform:uppercase;
            user-select:none;
            width:max-content;
        }
        .employee-badge-dot{
            width:8px;
            height:8px;
            border-radius:999px;
            background:#66FCF1;
            box-shadow: 0 0 10px rgba(102,252,241,0.8);
            animation: pulse 2.2s cubic-bezier(0.4,0,0.6,1) infinite;
        }
        .employee-badge-text{
            font-size:10px;
            font-weight:800;
            color:#CFFCF8;
        }

        /* General App Styles */
        details > summary {
            list-style: none;
        }
        details > summary::-webkit-details-marker {
            display: none;
        }
        details[open] summary ~ * {
            animation: sweep .3s ease-in-out;
        }
        
        .glass-panel {
            background: rgba(31, 40, 51, 0.6);
            backdrop-filter: blur(10px);
            border: 1px solid rgba(102, 252, 241, 0.1);
        }

        #omniSiteSidebar {
            transition: width 0.3s ease-in-out, transform 0.3s ease-in-out;
            overflow: hidden; 
        }

        #omniSiteSidebar .nav-btn {
            min-height: 2.75rem;
        }

        #omniSiteSidebar .sidebar-text {
            line-height: 1.35;
        }

        @media (min-width: 768px) {
            #omniSiteSidebar:not(.is-collapsed) .nav-btn {
                font-size: 0.975rem;
            }
        }

        @media (max-width: 767px) {
            #omniSiteSidebar .nav-btn {
                min-height: 3rem;
            }

            #omniSiteSidebar .sidebar-text {
                font-size: 0.98rem;
            }
        }

        @media (min-width: 768px) {
            #omniSiteSidebar.is-collapsed { width: 5rem; }
            #omniSiteSidebar.is-collapsed .sidebar-text { display: none; opacity: 0; }
            #omniSiteSidebar.is-collapsed .logo-container { justify-content: center; }
            #omniSiteSidebar.is-collapsed .nav-btn { justify-content: center; }
            #omniSiteSidebar.is-collapsed .nav-section-title { display: none; }
            #omniSiteSidebar.is-collapsed .tool-chevron { display: none; }
            #omniSiteSidebar.is-collapsed .footer-links { display: none; }
        }

        /* Sidebar overlay (mobile-first): never participates in layout -> main never compresses */
        #omniSiteSidebar{
            position: fixed;
            top: var(--omni-safe-top);
            left: 0;
            bottom: var(--omni-safe-bottom);
            height: calc(var(--omni-shell-height, 100dvh) - var(--omni-safe-top) - var(--omni-safe-bottom));
            z-index: 220;
            transform: translateX(-100%);
            will-change: transform;
            overscroll-behavior: contain;
        }
        #omniSiteSidebar.is-open{ transform: translateX(0); }

        @media (min-width: 768px) {
            #omniSiteSidebar{
                position: relative;
                top: auto;
                left: auto;
                bottom: auto;
                height: 100%;
                z-index: 200;
                transform: none;
            }
        }

        /* Touch devices using "Desktop site": still behave like mobile (overlay nav; no layout compression) */
        @media (min-width: 768px) and (hover: none) and (pointer: coarse) {
            body { flex-direction: column !important; }
            body > main { width: 100% !important; }
            main { width: 100vw !important; max-width: 100vw !important; }
            #omniContentContainer { width: 100vw !important; max-width: 100vw !important; margin-left: 0 !important; margin-right: 0 !important; }

            #omniSiteSidebar{
                position: fixed !important;
                top: var(--omni-safe-top) !important; left: 0; bottom: var(--omni-safe-bottom) !important;
                width: min(24rem, 94vw) !important;
                height: calc(var(--omni-shell-height, 100dvh) - var(--omni-safe-top) - var(--omni-safe-bottom)) !important;
                z-index: 220 !important;
                transform: translateX(-100%) !important;
            }
            #omniSiteSidebar.is-open{ transform: translateX(0) !important; }
        }


        #purchaseModal {
            transition: opacity 0.3s ease, visibility 0.3s ease;
        }
        #purchaseModal.hidden {
            opacity: 0;
            visibility: hidden;
            pointer-events: none;
        }
        #purchaseModal:not(.hidden) {
            opacity: 1;
            visibility: visible;
            pointer-events: auto;
        }
        
        .policy-content {
            white-space: pre-wrap;
            word-wrap: break-word;
        }
        
        /* Transition for login overlay */
        #loginOverlayContainer {
            transition: opacity 0.5s ease-in-out;
        }
        #loginOverlayContainer.hidden-viz {
            opacity: 0;
            pointer-events: none;
        }

/* --- Omni fallback layering: keep login UI visible even if Tailwind CDN fails --- */
#loginOverlayContainer > .absolute { z-index: 0 !important; }
#loginOverlayContainer .bg-grid { z-index: 0 !important; }
#loginOverlayContainer > main,
#loginOverlayContainer > footer,
#loginOverlayContainer #loginStatusOverlay { position: relative !important; z-index: 10 !important; }

/* Mobile devices in "Desktop site" mode: still behave like mobile (overlay nav; no compression) */
@media (hover: none) and (pointer: coarse){
  body { flex-direction: column !important; }
  body > main { width: 100% !important; }
  main { width: 100vw !important; max-width: 100vw !important; }
  #omniContentContainer { width: 100vw !important; max-width: 100vw !important; margin-left: 0 !important; margin-right: 0 !important; }
}



        /* Never show app sidebar while login overlay is visible (prevents right-side flash on first load),
           except on the employee restricted-access screen where navigation must remain reachable. */
        body:not(.omni-restricted-active) #loginOverlayContainer:not(.hidden):not(.hidden-viz) + #omniSiteSidebar{
            display: none !important;
        }

        /* Restricted-access screen: raise the navigation above the auth overlay so the button can actually open it. */
        body.omni-restricted-active #omniSiteSidebar{
            z-index: 320 !important;
        }
        body.omni-restricted-active #omniSiteSidebarBackdrop{
            z-index: 310 !important;
        }
    

/* OMNI responsive viewport fixes */
:root { --omni-vh: 1vh; --omni-safe-top: env(safe-area-inset-top, 0px); --omni-safe-right: env(safe-area-inset-right, 0px); --omni-safe-bottom: env(safe-area-inset-bottom, 0px); --omni-safe-left: env(safe-area-inset-left, 0px); }

/* Prefer modern dynamic viewport units; fall back to JS-updated --omni-vh */
body { height: var(--omni-shell-height, 100dvh); min-height: var(--omni-shell-height, 100dvh); }
#loginOverlayContainer, #toolContainer, #omniSiteSidebar { height: var(--omni-shell-height, 100dvh); }

@supports not (height: 100dvh) {
  body { height: var(--omni-shell-height, calc(var(--omni-vh) * 100)); min-height: var(--omni-shell-height, calc(var(--omni-vh) * 100)); }
  #loginOverlayContainer, #toolContainer, #omniSiteSidebar { height: var(--omni-shell-height, calc(var(--omni-vh) * 100)); }
}

/* Make auth/restricted overlay scroll safely on short devices */
#loginOverlayContainer {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: var(--omni-safe-bottom);
}

/* Sidebar width clamps for ultra-narrow devices */
@media (max-width: 767px) {
  #omniSiteSidebar { width: min(24rem, 94vw) !important; }
}

/* Avoid footer overlap on very short viewports */
@media (max-height: 700px) {
  #loginOverlayContainer footer {
    position: relative !important;
    bottom: auto !important;
    margin-top: 1.25rem;
  }
}



/* === Enhanced Omni "always visible / always scrollable" safety net === */

/* Let overflow containers actually scroll within flex layouts */
#omniContentContainer { min-height: 0; overflow-y: auto; overflow-x: hidden; -webkit-overflow-scrolling: touch; touch-action: pan-y; padding-bottom: var(--omni-safe-bottom); padding-left: var(--omni-safe-left); padding-right: var(--omni-safe-right); scroll-padding-bottom: calc(var(--omni-safe-bottom) + 0.75rem); }
#toolContainer { min-height: 0; }
#toolFrame { display: block; min-height: 0; }

/* Make login/signup/restricted overlay *always* reachable on any device */
#loginOverlayContainer{
  /* Ensure the first pixels at the top are reachable (notch + browser UI) */
  padding-top: max(16px, var(--omni-safe-top));
  padding-left: max(12px, var(--omni-safe-left));
  padding-right: max(12px, var(--omni-safe-right));
  padding-bottom: max(16px, var(--omni-safe-bottom));

  /* Default to top-aligned so you can always scroll to the very top */
  justify-content: flex-start !important;

  /* Better touch scrolling behavior */
  overscroll-behavior: contain;
  touch-action: pan-y;
}

/* On larger/taller viewports, re-center the auth card for aesthetics */
@media (min-height: 820px) and (min-width: 768px){
  #loginOverlayContainer{ justify-content: center !important; }
}

/* Footer should never get trapped off-screen */
#loginOverlayContainer footer{
  position: relative !important;
  bottom: auto !important;
}

/* If we have room, pin footer to the bottom without breaking scroll on short screens */
@media (min-height: 820px){
  #loginOverlayContainer footer{
    position: absolute !important;
    left: 0; right: 0;
    bottom: calc(1rem + var(--omni-safe-bottom)) !important;
    margin-top: 0 !important;
  }
}

/* Make all modal bodies scroll on short screens */
.modal-scroll, .policy-content{
  max-height: min(70dvh, 520px);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}


/* === Omni cross-app scaling hardening (Android WebView / Capacitor / in-app browsers) === */

/* Prevent “page wider than screen” issues + Android text autosizing surprises */
html, body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
  overscroll-behavior-x: none;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

/* Keep sizing sane across nested flex layouts */
*, *::before, *::after { box-sizing: border-box; }

/* Ensure the main shells never exceed the viewport width */
main, #omniSiteSidebar, #loginOverlayContainer, #toolContainer, #omniContentContainer {
  max-width: 100vw;
}

/* Make tool container + iframe strictly viewport-bound on mobile webviews */
#toolContainer{
  width: 100dvw;
  max-width: 100dvw;
}
@supports not (width: 100dvw) {
  #toolContainer{ width: 100vw; max-width: 100vw; }
}

#toolFrame{
  width: 100% !important;
  max-width: 100vw !important;
  height: 100% !important;
}

/* If any embedded content tries to go wide, clip it rather than forcing page zoom */
#omniContentContainer { overflow-x: hidden; }


/* === Omni Glow + Motion pack (adds life without becoming noisy) === */
:root{
  --omni-glow-cyan: rgba(102,252,241,0.35);
  --omni-glow-cyan-strong: rgba(102,252,241,0.55);
  --omni-glow-violet: rgba(139,92,246,0.28);
  --omni-glow-violet-strong: rgba(139,92,246,0.45);
}

@keyframes omniDrift {
  0% { transform: translate3d(0,0,0) scale(1); opacity: .28; }
  50% { transform: translate3d(18px,-14px,0) scale(1.05); opacity: .42; }
  100% { transform: translate3d(0,0,0) scale(1); opacity: .28; }
}
@keyframes omniSheen {
  0% { transform: translateX(-140%) skewX(-14deg); opacity: 0; }
  8% { opacity: .75; }
  28% { opacity: .75; }
  40% { transform: translateX(140%) skewX(-14deg); opacity: 0; }
  100% { transform: translateX(140%) skewX(-14deg); opacity: 0; }
}
@keyframes omniFloat2 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}
@keyframes omniPop {
  0% { opacity: 0; transform: translateY(10px) scale(.985); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

/* Ambient glow backdrop */
body::before, body::after{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events:none;
  z-index: 0;
  filter: blur(50px);
  opacity: .28;
  transform: translateZ(0);
  animation: omniDrift 10s ease-in-out infinite;
}
body::before{
  background:
    radial-gradient(closest-side at 25% 20%, var(--omni-glow-cyan), transparent 60%),
    radial-gradient(closest-side at 55% 45%, rgba(0,242,255,0.10), transparent 62%);
}
body::after{
  animation-duration: 13s;
  background:
    radial-gradient(closest-side at 78% 72%, var(--omni-glow-violet), transparent 58%),
    radial-gradient(closest-side at 40% 85%, rgba(112,0,255,0.10), transparent 62%);
}

/* Ensure app layers are above ambient glows */
/* Flex shrink safety to prevent horizontal overflow on narrow screens */
main, #omniContentContainer, #toolContainer { min-width: 0; }

/* Mobile GPU + WebView safety: lighter ambient glows to avoid rendering glitches */
@media (max-width: 767px){
  body::before, body::after{
    inset: 0;
    filter: blur(34px);
    opacity: .18;
    animation-duration: 16s;
  }
}

#loginOverlayContainer, main, #purchaseModal { position: relative; z-index: 1; }

/* Card / panel glow + hover lift */
.glass-panel, .glass-panel-login{
  position: relative;
  overflow: hidden;
  transform: translateZ(0);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, background-color .25s ease;
}
.glass-panel:hover{
  border-color: rgba(102,252,241,0.26);
  box-shadow:
    0 0 0 1px rgba(102,252,241,0.10) inset,
    0 0 28px rgba(102,252,241,0.10);
  transform: translateY(-2px);
}
.glass-panel::after, .glass-panel-login::after{
  content:"";
  position:absolute;
  top:-20%;
  left:-60%;
  width: 60%;
  height: 140%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.10), transparent);
  transform: translateX(-140%) skewX(-14deg);
  opacity: 0;
  pointer-events:none;
}
.glass-panel:hover::after, .glass-panel-login:hover::after{
  animation: omniSheen 4.8s ease-in-out infinite;
}

/* Sidebar nav buttons: more “alive” on hover */
.nav-btn{
  position: relative;
  overflow:hidden;
  transition: transform .20s ease, box-shadow .20s ease, background-color .20s ease;
}
.nav-btn:hover{
  transform: translateX(2px);
  box-shadow: 0 0 14px rgba(102,252,241,0.10);
}
.nav-btn::after{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(circle at 30% 50%, rgba(102,252,241,0.10), transparent 55%);
  opacity:0;
  transition: opacity .20s ease;
  pointer-events:none;
}
.nav-btn:hover::after{ opacity:1; }

/* Tool floating buttons (fullscreen / sidebar) */
#toolContainer .omni-fab{
  box-shadow:
    0 0 0 1px rgba(102,252,241,0.16) inset,
    0 0 22px rgba(102,252,241,0.18);
}
#toolContainer .omni-fab--desktop{
  opacity: .82 !important; /* override tailwind opacity */
}
#toolContainer .omni-fab--desktop:hover{
  box-shadow:
    0 0 0 1px rgba(102,252,241,0.22) inset,
    0 0 34px rgba(102,252,241,0.30);
}

/* Page transitions + reveal-on-scroll */
#omniContentContainer.omni-page-enter{
  animation: omniPop .24s ease-out both;
}
.omni-reveal{
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .35s ease, transform .35s ease;
  will-change: opacity, transform;
}
.omni-reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  body::before, body::after{ animation: none !important; }
  .glass-panel, .glass-panel-login, .nav-btn{ transition: none !important; }
  .glass-panel::after, .glass-panel-login::after{ display:none !important; }
  #omniContentContainer.omni-page-enter{ animation: none !important; }
  .omni-reveal{ opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* === Omni Tool Tabs (Native apps only) === */
#toolTabsShell { padding-right: 0; }
.omni-tool-tabs-row { min-width: 0; }
#toolTabsShell .omni-hscroll { padding-bottom: 2px; }
#toolTabsControls { flex: 0 0 auto; }
#toolContainer.tool-tabs-active #toolFloatingControls { display: none; }

.omni-tool-tab{
  display:inline-flex;
  align-items:center;
  gap:0.55rem;
  max-width: 260px;
  padding: 0.45rem 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(31,40,51,0.75);
  background: rgba(31,40,51,0.35);
  color: rgba(197,198,199,0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 0 18px rgba(0,0,0,0.25);
  transition: transform .18s ease, border-color .18s ease, background-color .18s ease, box-shadow .18s ease;
  user-select:none;
}
.omni-tool-tab:hover{
  transform: translateY(-1px);
  border-color: rgba(102,252,241,0.28);
  box-shadow: 0 0 22px rgba(102,252,241,0.08);
}
.omni-tool-tab.is-active{
  background: linear-gradient(90deg, rgba(102,252,241,0.22), rgba(139,92,246,0.12));
  border-color: rgba(102,252,241,0.55);
  box-shadow: 0 0 28px rgba(102,252,241,0.10);
}
.omni-tool-tab .omni-tool-tab-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(102,252,241,0.55);
  box-shadow: 0 0 10px rgba(102,252,241,0.45);
  flex: 0 0 auto;
}
.omni-tool-tab.is-active .omni-tool-tab-dot{
  background: rgba(102,252,241,0.95);
  box-shadow: 0 0 14px rgba(102,252,241,0.75);
}
.omni-tool-tab .omni-tool-tab-title{
  display:block;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-family: 'Orbitron', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, 'Noto Sans', 'Liberation Sans', sans-serif;
}
.omni-tool-tab .omni-tool-tab-close{
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 1px solid rgba(31,40,51,0.75);
  background: rgba(0,0,0,0.22);
  color: rgba(197,198,199,0.85);
  display:flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
  transition: background-color .18s ease, color .18s ease, border-color .18s ease, transform .18s ease;
}
.omni-tool-tab .omni-tool-tab-close:hover{
  background: rgba(255, 60, 60, 0.10);
  border-color: rgba(255, 80, 80, 0.35);
  color: rgba(255, 170, 170, 0.95);
  transform: rotate(90deg);
}

/* --- Tool Frames: stack iframes so tab switching always shows correctly --- */
#toolFramesHost{ position: relative; overflow: hidden; }
.omni-tool-frame{ position: absolute !important; inset: 0 !important; width: 100% !important; height: 100% !important; display: block; }

/* --- Tool Tabs: mobile sizing + reliable horizontal scrolling --- */
#toolTabsShell .omni-hscroll{ overflow-x: auto; overflow-y: hidden; -webkit-overflow-scrolling: touch; touch-action: pan-x !important; overscroll-behavior-x: contain; }
#toolTabsBar{ width: max-content; min-width: max-content; }
@media (max-width: 767px){
  .omni-tool-tab{ max-width: 180px; padding: 0.42rem 0.65rem; }
  .omni-tool-tab .omni-tool-tab-title{ font-size: 11px; letter-spacing: .06em; }
  .omni-tool-tab .omni-tool-tab-close{ width: 22px; height: 22px; }
}

/* Omni Native/Core visibility contract
   Omni-Bot AI UI is available on the website and apps through Cloudflare Pages.
   Native-only and Omni-Engine controls remain hidden until Capacitor/Tauri runtime classes are applied. */
[data-omni-native-only],
[data-omni-engine-ui] {
  display: none !important;
}

[data-omni-ai-ui] {
  display: block !important;
}

[data-omni-ai-ui][data-omni-display="inline"] { display: inline !important; }
[data-omni-ai-ui][data-omni-display="inline-block"] { display: inline-block !important; }
[data-omni-ai-ui][data-omni-display="flex"] { display: flex !important; }
[data-omni-ai-ui][data-omni-display="inline-flex"] { display: inline-flex !important; }
[data-omni-ai-ui][data-omni-display="grid"] { display: grid !important; }
[data-omni-ai-ui][data-omni-display="contents"] { display: contents !important; }

.omni-runtime-native [data-omni-native-only],
.omni-runtime-native [data-omni-engine-ui] {
  display: block !important;
}

.omni-runtime-native [data-omni-display="inline"] { display: inline !important; }
.omni-runtime-native [data-omni-display="inline-block"] { display: inline-block !important; }
.omni-runtime-native [data-omni-display="flex"] { display: flex !important; }
.omni-runtime-native [data-omni-display="inline-flex"] { display: inline-flex !important; }
.omni-runtime-native [data-omni-display="grid"] { display: grid !important; }
.omni-runtime-native [data-omni-display="contents"] { display: contents !important; }

