/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-font-weight:initial;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-gray-100:oklch(96.7% .003 264.542);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-medium:500;--font-weight-bold:700;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.h-4{height:calc(var(--spacing) * 4)}.h-6{height:calc(var(--spacing) * 6)}.min-h-screen{min-height:100vh}.w-4{width:calc(var(--spacing) * 4)}.w-6{width:calc(var(--spacing) * 6)}.w-full{width:100%}.max-w-full{max-width:100%}.max-w-md{max-width:var(--container-md)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-3{gap:calc(var(--spacing) * 3)}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}.overflow-x-auto{overflow-x:auto}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-gray-300{border-color:var(--color-gray-300)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-transparent{background-color:#0000}.p-4{padding:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.text-center{text-align:center}.text-left{text-align:left}.font-sans{font-family:var(--font-sans)}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.break-all{word-break:break-all}.text-\[\#272B3A\]{color:#272b3a}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-white{color:var(--color-white)}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media(hover:hover){.hover\:bg-gray-100:hover{background-color:var(--color-gray-100)}.hover\:opacity-90:hover{opacity:.9}}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-\[var\(--color-primary\)\]:focus-visible{--tw-ring-color:var(--color-primary)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:outline:focus-visible{outline-style:var(--tw-outline-style);outline-width:1px}.dark\:border-gray-600:where(.dark,.dark *){border-color:var(--color-gray-600)}.dark\:bg-gray-800:where(.dark,.dark *){background-color:var(--color-gray-800)}.dark\:text-\[\#F2F2F3\]:where(.dark,.dark *){color:#f2f2f3}.dark\:text-gray-300:where(.dark,.dark *){color:var(--color-gray-300)}.dark\:text-gray-400:where(.dark,.dark *){color:var(--color-gray-400)}@media(hover:hover){.dark\:hover\:bg-gray-800:where(.dark,.dark *):hover{background-color:var(--color-gray-800)}}}:root{--font-sans:"RajDhani", -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-size-h1:4.5rem;--font-size-h2:3rem;--font-size-h3:2.5rem;--font-size-h4:2rem;--font-size-h5:1.25rem;--font-size-h6:.875rem;--color-primary:#ba0c2f;--color-primary-hover:#9a0a27;--color-primary-light:#ba0c2f4d;--color-primary-dark:#ba0c2f66;--color-white:#f2f2f3;--color-dark-gray:#272b3a;--color-black:#232324;--color-gray:#232324;--color-success-light:#dcfce7;--color-success:#16a34a;--color-success-dark:#15803d;--color-warning-light:#fef3c7;--color-warning:#d97706;--color-warning-dark:#b45309;--color-error-light:#fee2e2;--color-error:#dc2626;--color-error-dark:#b91c1c;--color-info-light:#dbeafe;--color-info:#2563eb;--color-info-dark:#1e40af;--color-accent:#2dd4bf;--color-accent-hover:#26b5a3;--color-warning-accent:#facc15;--color-tag-srt:#60a5fa;--color-tag-rtsp:#c084fc;--color-neutral-muted:#6b7280;--overlay-heavy:#000000bf;--overlay-medium:#00000080;--overlay-light:#00000059;--overlay-subtle:#00000040;--overlay-backdrop:#000000b3;--overlay-modal:#000c;--overlay-solid:#080a10;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-sm:0 1px 3px #00000047;--shadow-md:0 2px 8px #00000042;--shadow-lg:0 4px 12px #00000047;--shadow-xl:0 8px 24px #0000004d;--transition-fast:.15s;--transition-base:.2s;--transition-slow:.3s;--z-base:0;--z-dropdown:1000;--z-sticky:1100;--z-fixed:1200;--z-modal-backdrop:1300;--z-modal:1400;--z-popover:1500;--z-tooltip:1600;--pane-bg:#181b268c;--pane-bg-subtle:#ffffff3b;--pane-border:#ffffff47;--pane-border-subtle:#ffffff42;--panel-bg:#181b2680;--panel-bg-solid:#181b26bf;--popover-bg:#181b26;--popover-border:#ffffff4d;--popover-shadow:0 8px 32px #0009;--text-primary:#fff;--text-secondary:#fff;--text-tertiary:#ffffffe6;--text-muted:#ffffffbf;--hover-bg:#ffffff70;--hover-text:#fff;--active-text:#fff;--strip-hover-bg:#ffffff1a;--active-row-bg:#181b2680;--active-mix:#fff;--accent-bg:#2dd4bf59;--accent-bg-subtle:#2dd4bf26;--accent-bg-faint:#2dd4bf1a;--accent-border:#2dd4bf80;--accent-border-subtle:#2dd4bf4d;--accent-glow:#2dd4bfb3;--error-bg:#ef444426;--error-bg-strong:#ef44444d;--error-border:#ef444480;--error-border-strong:#ef4444b3;--error-text:#ef4444e6;--error-text-solid:#ef4444;--success-bg:#4ade8026;--success-bg-strong:#4ade8040;--success-bg-accent:#4ade8059;--success-border:#4ade804d;--success-border-strong:#4ade8080;--success-text:#4ade80;--warning-bg:#facc154d;--tag-srt-bg:#3b82f666;--tag-rtsp-bg:#a855f766;--chip-border:#ffffff14;--chip-hover-bg:#ffffff0f;--chip-hover-border:#ffffff24;--metrics-hover-bg:#ffffff0a}.light{--pane-bg:#ffffff8c;--pane-bg-subtle:#00000038;--pane-border:#00000047;--pane-border-subtle:#00000042;--panel-bg:#ffffff80;--panel-bg-solid:#ffffffbf;--popover-bg:#fff;--popover-border:#0000004d;--popover-shadow:0 8px 32px #00000052;--text-primary:#111;--text-secondary:#000;--text-tertiary:#000c;--text-muted:#000000a6;--hover-bg:#0000005c;--hover-text:#000;--active-text:#111;--strip-hover-bg:#00000014;--active-row-bg:#ffffff80;--active-mix:#000;--accent-bg:#2dd4bf40;--accent-bg-subtle:#2dd4bf1a;--accent-bg-faint:#2dd4bf0f;--accent-border:#2dd4bf66;--accent-border-subtle:#2dd4bf33;--accent-glow:#2dd4bf80;--error-bg:#ef44441a;--error-bg-strong:#ef444433;--error-border:#ef444466;--error-border-strong:#ef444499;--error-text:#ef4444d9;--error-text-solid:#ef4444;--success-bg:#4ade801a;--success-bg-strong:#4ade8033;--success-bg-accent:#4ade8040;--success-border:#4ade8033;--success-border-strong:#4ade8066;--success-text:#16a34a;--warning-bg:#facc1533;--tag-srt-bg:#3b82f64d;--tag-rtsp-bg:#a855f74d;--chip-border:#00000014;--chip-hover-bg:#0000000a;--chip-hover-border:#00000024;--metrics-hover-bg:#0000000a}html,body{font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-white);color:var(--color-dark-gray);overscroll-behavior:none}.dark html,.dark body{background-color:var(--color-black);color:var(--color-white)}@media(prefers-color-scheme:dark){html:not(.light) body{background-color:var(--color-black);color:var(--color-white)}html{color-scheme:dark}}h1{font-size:4.5rem;font-weight:700;line-height:1.25}h2{font-size:3rem;font-weight:700;line-height:1.25}h3{font-size:2.5rem;font-weight:600;line-height:1.25}h4{font-size:2rem;font-weight:600;line-height:1.375}h5{font-size:1.25rem;font-weight:500;line-height:1.5}h6{font-size:.875rem;font-weight:500;line-height:1.5}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.skip-to-main{clip:rect(0,0,0,0);white-space:nowrap;background-color:var(--color-primary);width:1px;height:1px;color:var(--color-white);border-width:0;margin:-1px;padding:0;position:absolute;overflow:hidden}.skip-to-main:focus{clip:auto;white-space:normal;z-index:9999;border-radius:.375rem;width:auto;height:auto;margin:0;padding:.5rem 1rem;position:absolute;top:1rem;left:1rem;overflow:visible}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.not-sr-only{clip:auto;white-space:normal;width:auto;height:auto;margin:0;padding:0;position:static;overflow:visible}.app-shell{background-color:var(--color-black);touch-action:none;overscroll-behavior:none;-webkit-overflow-scrolling:auto;position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden}.main-content{z-index:0;position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.nav-loading{background-color:#fff;justify-content:center;align-items:center;display:flex;position:absolute;top:0;right:0;bottom:0;left:0}.dark .nav-loading{background-color:#000}.top-bar{top:0;left:var(--sidebar-width,14rem);z-index:30;border-bottom:1px solid var(--pane-border);background-color:var(--pane-bg);-webkit-backdrop-filter:blur(16px);pointer-events:auto;height:3rem;transition:left var(--transition-base) ease;justify-content:space-between;align-items:center;padding-left:1rem;padding-right:1rem;display:none;position:fixed;right:0}@media(min-width:768px){.top-bar{display:flex}}.top-bar-left{align-items:center;gap:.75rem;display:flex}.top-bar-page-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:600;overflow:hidden}.top-bar-right{align-items:center;gap:1rem;display:flex}.top-bar-user{width:2rem;height:2rem;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:9999px;justify-content:center;align-items:center;display:flex}.top-bar-user:hover,.top-bar-user[data-active]{background-color:var(--hover-bg);color:var(--hover-text)}.top-bar-divider{background-color:var(--pane-border);flex-shrink:0;width:1px;height:3rem;margin:0 -.125rem}.sidebar{z-index:35;border-right:1px solid var(--pane-border);background-color:var(--pane-bg);-webkit-backdrop-filter:blur(16px);pointer-events:auto;width:14rem;transition:width var(--transition-base) ease;flex-direction:column;display:none;position:fixed;top:0;bottom:0;left:0;overflow:hidden}@media(min-width:768px){.sidebar{display:flex}}.sidebar-collapsed{width:4.5rem}.sidebar-header{border-bottom:1px solid var(--pane-border);flex-shrink:0;align-items:center;gap:.75rem;height:3rem;padding-left:1rem;padding-right:.75rem;display:flex}.sidebar-toggle{width:2.5rem;height:2.5rem;color:var(--text-primary);cursor:pointer;transition:background-color var(--transition-base) ease,color var(--transition-base) ease;background:0 0;border:none;border-radius:.375rem;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.sidebar-toggle:hover{background-color:var(--hover-bg);color:var(--active-text)}.sidebar-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar-toggle-lines{flex-direction:column;gap:4px;width:1rem;display:flex}.sidebar-toggle-lines span{background:currentColor;border-radius:9999px;width:100%;height:2px;display:block}.sidebar-brand{flex:1;align-items:center;min-width:0;display:flex;overflow:hidden}.sidebar-logo{flex-shrink:0;width:auto;max-width:9rem;height:1.25rem}.sidebar-nav{flex-direction:column;flex:1;gap:0;min-width:0;padding:0;display:flex;overflow:hidden auto}.sidebar-link{box-sizing:border-box;width:100%;min-width:0;max-width:100%;font:inherit;text-align:left;cursor:pointer;white-space:nowrap;transition:background-color var(--transition-base) ease,box-shadow var(--transition-base) ease,color var(--transition-base) ease;background:0 0;border:none;border-radius:0;align-items:center;gap:.75rem;padding:.5rem .625rem .5rem 1.625rem;text-decoration:none;display:flex;position:relative;overflow:hidden}.sidebar-link-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.sidebar-link-label{text-overflow:ellipsis;white-space:nowrap;opacity:1;width:9.75rem;transition:opacity var(--transition-base) ease;flex:none;overflow:hidden}.sidebar-collapsed .sidebar-link-label{opacity:0}.sidebar-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar-link-default{color:var(--text-primary)}.sidebar-link-default:hover{background-color:var(--hover-bg);color:var(--active-text)}.sidebar-link-active{background-color:var(--active-row-bg);box-shadow:inset 0 0 0 100px var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.sidebar-link-active{box-shadow:inset 0 0 0 100px color-mix(in srgb,var(--color-primary) 38%,transparent)}}.sidebar-link-active{color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.sidebar-link-active{color:color-mix(in srgb,var(--color-primary) 45%,var(--active-mix))}}.sidebar-link-active:hover{background-color:var(--active-row-bg);box-shadow:inset 0 0 0 100px var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.sidebar-link-active:hover{box-shadow:inset 0 0 0 100px color-mix(in srgb,var(--color-primary) 58%,transparent)}}.sidebar-link-active:hover{color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.sidebar-link-active:hover{color:color-mix(in srgb,var(--color-primary) 30%,var(--active-mix))}}.sidebar-group{max-height:0;transition:max-height var(--transition-base) cubic-bezier(.4,0,.2,1);overflow:hidden}.sidebar-group--open{max-height:12rem;transition:max-height var(--transition-slow) cubic-bezier(.4,0,.2,1)}.sidebar-collapsed .sidebar-group{max-height:0;transition:max-height var(--transition-fast) cubic-bezier(.4,0,.2,1)}.sidebar-sublink{opacity:0;transition:opacity var(--transition-base) ease,transform var(--transition-base) ease;padding-left:3.625rem;font-size:.875rem;transform:translateY(-4px)}.sidebar-group--open .sidebar-sublink{opacity:1;transform:translateY(0)}.sidebar-group--open .sidebar-sublink:first-child{transition-delay:30ms}.sidebar-group--open .sidebar-sublink:nth-child(2){transition-delay:60ms}.sidebar-group--open .sidebar-sublink:nth-child(3){transition-delay:90ms}.sidebar-group--open .sidebar-sublink:nth-child(4){transition-delay:.12s}.sidebar-group--open .sidebar-sublink:nth-child(5){transition-delay:.15s}.sidebar-group-link{min-width:0;color:inherit;flex:1;align-items:center;gap:.75rem;text-decoration:none;display:flex;overflow:hidden}.sidebar-group-toggle{width:2.25rem;color:inherit;cursor:pointer;opacity:1;transition:opacity var(--transition-base) ease,background-color var(--transition-fast) ease;background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:absolute;top:0;bottom:0;right:0}.sidebar-group-toggle:hover{background-color:var(--strip-hover-bg)}.sidebar-group-toggle svg{transition:transform var(--transition-base) ease}.sidebar-group-toggle--open svg{transform:rotate(90deg)}.sidebar-collapsed .sidebar-group-toggle{opacity:0;pointer-events:none}.sidebar-hidden-trigger{box-sizing:border-box;cursor:default;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;outline:none;flex-shrink:0;width:100%;min-height:20px;padding:.5rem .625rem .5rem 1.625rem}.sidebar-footer{border-top:1px solid var(--pane-border);flex-direction:column;gap:0;min-width:0;padding:0;display:flex;overflow:hidden}.rsidebar{z-index:36;border-left:1px solid var(--pane-border);background-color:var(--pane-bg);-webkit-backdrop-filter:blur(16px);pointer-events:auto;width:14rem;transition:transform var(--transition-base) ease;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden;transform:translate(100%)}.rsidebar--open{transform:translate(0)}.rsidebar-header{border-bottom:1px solid var(--pane-border);flex-shrink:0;justify-content:space-between;align-items:center;height:3rem;padding:0 .75rem 0 1rem;display:flex}.rsidebar-header-title{color:var(--text-primary);font-size:.8125rem;font-weight:600}.rsidebar-close{width:2rem;height:2rem;color:var(--text-tertiary);cursor:pointer;transition:background-color var(--transition-base) ease,color var(--transition-base) ease;background:0 0;border:none;border-radius:.375rem;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.rsidebar-close:hover{background-color:var(--hover-bg);color:var(--active-text)}.rsidebar-nav{flex-direction:column;flex:1;gap:0;min-width:0;padding:0;display:flex;overflow:hidden auto}.rsidebar-link{box-sizing:border-box;width:100%;min-width:0;max-width:100%;font:inherit;text-align:left;cursor:pointer;white-space:nowrap;transition:background-color var(--transition-base) ease,box-shadow var(--transition-base) ease,color var(--transition-base) ease;background:0 0;border:none;border-radius:0;align-items:center;gap:.75rem;padding:.5rem .625rem .5rem 1rem;text-decoration:none;display:flex;position:relative;overflow:hidden}.rsidebar-link-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.rsidebar-link-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.rsidebar-link-default{color:var(--text-primary)}.rsidebar-link-default:hover{background-color:var(--hover-bg);color:var(--active-text)}.rsidebar-link-danger{color:var(--text-primary)}.rsidebar-link-danger:hover{background-color:var(--hover-bg);color:var(--color-error)}.rsidebar-divider{background-color:var(--pane-border);height:1px;margin:.25rem 0}.rsidebar-footer{border-top:1px solid var(--pane-border);flex-direction:column;gap:0;min-width:0;padding:0;display:flex;overflow:hidden}.rsidebar-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);align-items:center;gap:.375rem;padding:.5rem .625rem .25rem 1rem;font-size:.5625rem;font-weight:700;display:flex}.top-bar.rsidebar-active{transition:left var(--transition-base) ease,right var(--transition-base) ease;right:14rem}.mobile-drawer-backdrop{z-index:50;background-color:var(--overlay-backdrop);position:fixed;top:0;right:0;bottom:0;left:0}@media(min-width:768px){.mobile-drawer-backdrop{display:none}}.mobile-drawer-panel{z-index:60;border-right:1px solid var(--pane-border);background-color:var(--pane-bg);-webkit-backdrop-filter:blur(20px);flex-direction:column;width:18rem;display:flex;position:fixed;inset:0 auto 0 0}@media(min-width:768px){.mobile-drawer-panel{display:none}}.mobile-drawer-header{border-bottom:1px solid var(--pane-border);background-color:var(--pane-bg-subtle);align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.mobile-drawer-close{width:2.25rem;height:2.25rem;color:var(--text-primary);cursor:pointer;transition:background-color var(--transition-base) ease,color var(--transition-base) ease;background:0 0;border:none;border-radius:.375rem;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.mobile-drawer-close:hover{background-color:var(--hover-bg);color:var(--active-text)}.mobile-drawer-logo-link{flex:1;align-items:center;min-width:0;display:flex}.mobile-drawer-logo{width:auto;max-width:9rem;height:1.25rem}.mobile-drawer-nav{flex-direction:column;flex:1;gap:2px;padding:.75rem;display:flex;overflow-y:auto}.mobile-drawer-link{white-space:nowrap;color:var(--text-primary);transition:background-color var(--transition-base) ease,color var(--transition-base) ease;border-radius:.375rem;align-items:center;gap:.75rem;padding:.5rem .875rem;font-size:1rem;text-decoration:none;display:flex}.mobile-drawer-link:hover{background-color:var(--hover-bg);color:var(--active-text)}.mobile-drawer-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.mobile-drawer-link-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.mobile-drawer-theme{border-top:1px solid var(--pane-border);padding:.75rem}.mobile-drawer-theme-row{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.mobile-drawer-theme-label{color:var(--text-muted);font-size:.75rem;font-weight:500}.mobile-header{z-index:40;border-bottom:1px solid;border-bottom-color:var(--pane-border);background-color:var(--pane-bg);-webkit-backdrop-filter:blur(20px);pointer-events:auto;flex-shrink:0;grid-template-columns:2.5rem 1fr 2.5rem;align-items:center;height:3.5rem;padding-left:1rem;padding-right:1rem;display:grid;position:fixed;top:0;left:0;right:0}@media(min-width:768px){.mobile-header{display:none}}.mobile-menu-btn{color:var(--text-secondary);cursor:pointer;transition:background-color var(--transition-base) ease,color var(--transition-base) ease;background:0 0;border:none;border-radius:.375rem;justify-content:center;align-items:center;padding:.375rem;display:flex}.mobile-menu-btn:hover{background-color:var(--hover-bg);color:var(--hover-text)}.mobile-menu-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.mobile-logo{object-fit:contain;width:auto;height:1.5rem;margin:0 auto;display:block}.mobile-header-spacer{width:2.5rem;height:2.5rem}.mobile-drawer-focus-btn{width:2rem;height:2rem;color:var(--text-primary);cursor:pointer;transition:background-color var(--transition-base) ease,color var(--transition-base) ease;background:0 0;border:none;border-radius:.375rem;justify-content:center;align-items:center;display:inline-flex}.mobile-drawer-focus-btn:hover{background-color:var(--hover-bg);color:var(--active-text)}.page-container{width:100%;max-width:80rem;margin-left:auto;margin-right:auto;padding:2.5rem 1.5rem}@media(min-width:640px){.page-container{padding-left:2rem;padding-right:2rem}}@media(min-width:1024px){.page-container{padding-left:2.5rem;padding-right:2.5rem}}.page-container-narrow{width:100%;max-width:56rem;margin-left:auto;margin-right:auto;padding:1.5rem 1rem}@media(min-width:640px){.page-container-narrow{padding-left:1.5rem;padding-right:1.5rem}}@media(min-width:1024px){.page-container-narrow{padding-left:2rem;padding-right:2rem}}.page-container-wide{width:100%;margin-left:auto;margin-right:auto;padding:1.5rem 1rem}@media(min-width:640px){.page-container-wide{padding-left:1.5rem;padding-right:1.5rem}}@media(min-width:1024px){.page-container-wide{padding-left:2rem;padding-right:2rem}}.app-shell{min-height:100vh;display:flex}.app-shell-main{flex-direction:column;flex:1;display:flex}.app-shell-content{flex:1}.section{padding-top:4rem;padding-bottom:4rem}.section-header{margin-bottom:2rem}.section-title{color:#272b3a;font-size:1.875rem;font-weight:700;line-height:2.25rem}.dark .section-title{color:#f2f2f3}.section-description{color:#4b5563;margin-top:.5rem}.dark .section-description{color:#9ca3af}.grid-2{gap:1.5rem;display:grid}@media(min-width:768px){.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}}.grid-3{gap:1.5rem;display:grid}@media(min-width:768px){.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}}.grid-4{gap:1.5rem;display:grid}@media(min-width:768px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-col-center{flex-direction:column;justify-content:center;align-items:center;display:flex}.breadcrumbs{color:#4b5563;align-items:center;gap:.5rem;font-size:.875rem;line-height:1.25rem;display:flex}.dark .breadcrumbs{color:#9ca3af}.breadcrumbs-item{align-items:center;gap:.5rem;display:flex}.breadcrumbs-sep{color:#9ca3af}.dark .breadcrumbs-sep{color:#6b7280}.breadcrumb-link{color:inherit;border-radius:.25rem}.breadcrumb-link:hover{color:var(--color-primary);text-decoration:underline}.breadcrumb-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.breadcrumb-current{color:var(--color-dark-gray);font-weight:500}.dark .breadcrumb-current{color:var(--color-white)}.api-guide{width:100%;min-height:100%;display:flex}.api-guide-nav{scrollbar-width:none;flex-shrink:0;align-self:flex-start;width:14rem;max-height:100vh;padding:1.5rem 0 2rem 1.25rem;position:sticky;top:0;overflow-y:auto}.api-guide-nav::-webkit-scrollbar{display:none}.api-guide-filter{margin-bottom:1rem;padding-right:.5rem}.api-guide-filter-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.25rem;font-size:.5625rem;font-weight:600;display:block}.api-guide-filter-select{border:1px solid var(--pane-border-subtle);background:var(--pane-bg);width:100%;color:var(--text-secondary);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-position:right .375rem center;background-repeat:no-repeat;background-size:8px 5px;border-radius:.25rem;outline:none;padding:.25rem 1.25rem .25rem .375rem;font-family:inherit;font-size:.6875rem;transition:border-color .15s}.api-guide-filter-select:focus{border-color:var(--color-primary)}.api-guide-nav-list{margin:0;padding:0;list-style:none;position:relative}.api-guide-nav-list:before{content:"";background:var(--pane-border-subtle);width:1px;position:absolute;top:0;bottom:0;left:0}.api-guide-nav-section{margin-bottom:.125rem}.api-guide-nav-section-btn{cursor:pointer;text-transform:uppercase;letter-spacing:.04em;width:100%;color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;text-align:left;background:0 0;border:none;align-items:center;gap:.25rem;margin:0;padding:.3rem .5rem .3rem .75rem;font-size:.6875rem;font-weight:600;transition:color .15s;display:flex;position:relative;overflow:hidden}.api-guide-nav-section-btn:hover,.api-guide-nav-section-btn[data-active=true]{color:var(--text-primary)}.api-guide-nav-section-btn:before{content:"";background:0 0;border-radius:1px;width:2px;transition:background .2s;position:absolute;top:.25rem;bottom:.25rem;left:0}.api-guide-nav-section-btn[data-active=true]:before{background:var(--color-primary)}.api-guide-nav-chevron{opacity:.5;flex-shrink:0;width:10px;height:10px;transition:transform .2s}.api-guide-nav-section-btn:hover .api-guide-nav-chevron{opacity:.8}.api-guide-nav-chevron[data-open=true]{transform:rotate(90deg)}.api-guide-nav-children{opacity:0;max-height:0;transition:max-height .25s,opacity .2s;overflow:hidden}.api-guide-nav-children[data-open=true]{opacity:1;max-height:50rem}.api-guide-nav-msg{margin-bottom:.0625rem}.api-guide-nav-msg-btn{cursor:pointer;width:100%;color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;text-align:left;background:0 0;border:none;align-items:center;gap:.2rem;margin:0;padding:.2rem .5rem .2rem 1.25rem;font-size:.6875rem;font-weight:500;transition:color .15s;display:flex;position:relative;overflow:hidden}.api-guide-nav-msg-btn:hover{color:var(--text-secondary)}.api-guide-nav-msg-btn[data-active=true]{color:var(--text-primary)}.api-guide-nav-msg-btn:before{content:"";background:0 0;border-radius:1px;width:2px;transition:background .2s;position:absolute;top:.15rem;bottom:.15rem;left:0}.api-guide-nav-msg-btn[data-active=true]:before{background:var(--color-primary)}.api-guide-nav-variant{margin-bottom:0}.api-guide-nav-variant-btn{cursor:pointer;width:100%;color:var(--text-muted);opacity:.7;white-space:nowrap;text-overflow:ellipsis;text-align:left;background:0 0;border:none;margin:0;padding:.15rem .5rem .15rem 2rem;font-size:.625rem;font-weight:400;transition:color .15s,opacity .15s;display:block;position:relative;overflow:hidden}.api-guide-nav-variant-btn:hover{color:var(--text-secondary);opacity:1}.api-guide-nav-variant-btn[data-active=true]{color:var(--color-primary);opacity:1}.api-guide-nav-variant-btn:before{content:"";background:0 0;border-radius:1px;width:2px;transition:background .2s;position:absolute;top:.1rem;bottom:.1rem;left:0}.api-guide-nav-variant-btn[data-active=true]:before{background:var(--color-primary)}.api-guide-content{flex:1;min-width:0;max-width:48rem;padding:2.5rem 1.5rem 2.5rem 2rem}.api-guide-code{background:var(--pane-bg);border:1px solid var(--pane-border-subtle);color:var(--text-secondary);white-space:pre;border-radius:.375rem;margin:0;padding:.75rem 1rem;font-family:monospace;font-size:.75rem;line-height:1.5;display:block;overflow-x:auto}@media(max-width:960px){.api-guide-nav{display:none}.api-guide-content{padding:2rem 1rem}}.btn{cursor:pointer;min-width:44px;min-height:44px;transition:background-color var(--transition-base) ease,color var(--transition-base) ease,border-color var(--transition-base) ease,box-shadow var(--transition-base) ease,transform var(--transition-base) ease;border-radius:9999px;justify-content:center;align-items:center;font-weight:500;display:inline-flex}.btn:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline-offset:2px;outline-style:solid}.btn:disabled{pointer-events:none;opacity:.7;cursor:not-allowed}@media(min-width:640px){.btn{min-width:0;min-height:0}}@media(prefers-reduced-motion:reduce){.btn{transition-duration:.01ms}}.btn:active:not(:disabled){transform:scale(.98)}@media(prefers-reduced-motion:reduce){.btn:active:not(:disabled){transform:none}}.btn-primary{box-shadow:var(--shadow-sm);background-color:var(--color-primary);color:var(--color-white)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){box-shadow:var(--shadow-sm)}.btn-secondary{color:var(--color-white);box-shadow:var(--shadow-sm);background-color:var(--color-dark-gray)}.btn-secondary:hover:not(:disabled){filter:brightness(1.08);box-shadow:var(--shadow-md)}.btn-secondary:active:not(:disabled){filter:brightness();box-shadow:var(--shadow-sm)}.btn-ghost{color:var(--color-primary);background-color:#0000}.btn-ghost:hover:not(:disabled){background-color:var(--color-primary-light)}.dark .btn-ghost:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn-danger{border:2px solid;border-color:var(--color-error);color:var(--color-error);background-color:#0000}.btn-danger:hover:not(:disabled){background-color:var(--color-error-light);border-color:var(--color-error-dark)}.dark .btn-danger:hover:not(:disabled){background-color:#7f1d1d66}.btn-sm{padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem}.btn-md{padding:.625rem 1.5rem;font-size:1rem;line-height:1.5rem}.btn-lg{padding:.75rem 2rem;font-size:1.125rem;line-height:1.75rem}.btn-full-width{width:100%}.btn-icon-only{padding:.5rem}.card{border-radius:.75rem;padding:1.5rem;transition-property:color,background-color,border-color;transition-duration:.15s;transition-timing-function:ease}.card-elevated{box-shadow:var(--shadow-md);background-color:#fff}.dark .card-elevated{background-color:var(--color-dark-gray);box-shadow:0 2px 8px #0006}.card-outlined{background-color:#fff;border:1px solid #e5e7ebcc}.dark .card-outlined{background-color:var(--color-dark-gray);border-color:#374151cc}.card-header{color:var(--color-dark-gray);margin-bottom:1rem;font-weight:600}.dark .card-header{color:var(--color-white)}.card-content{color:#4b5563;font-size:.875rem;line-height:1.25rem}.dark .card-content{color:#9ca3af}.card-footer{border-color:#e5e7eb;border-top-style:solid;border-top-width:1px;margin-top:1rem;padding-top:1rem}.dark .card-footer{border-color:#374151}.badge{border-radius:9999px;align-items:center;padding:.125rem .625rem;font-size:.75rem;font-weight:500;line-height:1rem;display:inline-flex}.badge-success{color:#166534;background-color:#dcfce7}.dark .badge-success{color:#86efac;background-color:#14532d66}.badge-warning{color:#92400e;background-color:#fef3c7}.dark .badge-warning{color:#fcd34d;background-color:#78350f66}.badge-error{color:#991b1b;background-color:#fee2e2}.dark .badge-error{color:#fca5a5;background-color:#7f1d1d66}.badge-info{color:#1e40af;background-color:#dbeafe}.dark .badge-info{color:#93c5fd;background-color:#1e3a8a66}.badge-neutral{color:#1f2937;background-color:#f3f4f6}.dark .badge-neutral{color:#d1d5db;background-color:#1f2937}.badge-sm{padding:.125rem .5rem;font-size:10px}.badge-md{padding:.125rem .625rem;font-size:.75rem;line-height:1rem}.badge-lg{padding:.25rem .75rem;font-size:.875rem;line-height:1.25rem}.input-wrapper{width:100%}.input-label{color:var(--color-dark-gray);margin-bottom:.375rem;font-size:.875rem;font-weight:500;line-height:1.25rem;display:block}.dark .input-label{color:var(--color-white)}.input{background-color:var(--color-white);width:100%;color:var(--color-dark-gray);border:1px solid;border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem;line-height:1.25rem;transition-property:color,background-color,border-color;transition-duration:.15s;transition-timing-function:ease}.input:disabled{pointer-events:none;opacity:.7;cursor:not-allowed}.input::placeholder{color:#9ca3af}.dark .input::placeholder{color:#6b7280}.dark .input{background-color:var(--color-dark-gray);color:var(--color-white)}.input:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.input-default{border-color:#e5e7eb}.dark .input-default{border-color:#4b5563}.input-error{border-color:#ef4444}.dark .input-error{border-color:#dc2626}.input-error-message{color:#dc2626;margin-top:.375rem;font-size:.875rem;line-height:1.25rem}.dark .input-error-message{color:#f87171}.modal-wrapper{z-index:50;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.modal-backdrop{background-color:#00000080;position:fixed;top:0;right:0;bottom:0;left:0}.modal-content{z-index:10;background-color:var(--color-white);border-radius:.5rem;width:100%;max-width:28rem;padding:1.5rem;position:relative;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.dark .modal-content{background-color:var(--color-dark-gray)}.modal-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.modal-title{color:var(--color-dark-gray);font-size:1.125rem;font-weight:600;line-height:1.75rem}.dark .modal-title{color:var(--color-white)}.modal-close{color:#6b7280;border-radius:.375rem;margin-left:auto;padding:.25rem}.modal-close:hover{color:#374151;background-color:#f3f4f6}.dark .modal-close{color:#9ca3af}.dark .modal-close:hover{color:#d1d5db;background-color:#374151}.modal-close:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.modal-body{margin-top:1rem}.table-container{border:1px solid #e5e7eb;border-radius:.5rem;width:100%;overflow-x:auto}.dark .table-container{border-color:#374151}.table{border-collapse:collapse;width:100%;font-size:.875rem;line-height:1.25rem}.table-header{background-color:#f9fafb}.dark .table-header{background-color:#272b3a}.table-header-cell{text-align:left;color:#272b3a;border-bottom:1px solid #e5e7eb;padding:.75rem 1rem;font-weight:600}.dark .table-header-cell{color:#f2f2f3;border-bottom-color:#374151}.table-body{background-color:#fff}.dark .table-body{background-color:#232324}.table-row{border-bottom:1px solid #e5e7eb;transition-property:color,background-color,border-color;transition-duration:.15s;transition-timing-function:ease}.dark .table-row{border-bottom-color:#374151}.table-row:hover{background-color:#f9fafb}.dark .table-row:hover{background-color:#272b3a80}.table-row:last-child{border-bottom:0}.table-cell{color:#272b3a;padding:.75rem 1rem}.dark .table-cell{color:#f2f2f3}.table-striped .table-row:nth-child(2n){background-color:#f9fafb80}.dark .table-striped .table-row:nth-child(2n){background-color:#272b3a4d}.table-compact .table-header-cell,.table-compact .table-cell{padding:.5rem .75rem}.table-row-selected{background-color:#ba0c2f1a}.dark .table-row-selected{background-color:#ba0c2f33}.table-row-clickable{cursor:pointer}.loading-spinner{border:4px solid #e5e7eb;border-top-color:#ba0c2f;border-radius:9999px;animation:1s linear infinite spin;display:inline-block}.dark .loading-spinner{border-color:#ba0c2f #374151 #374151}.loading-spinner-sm{border-width:2px;width:1rem;height:1rem}.loading-spinner-md{border-width:4px;width:2rem;height:2rem}.loading-spinner-lg{border-width:4px;width:3rem;height:3rem}.loading-container{justify-content:center;align-items:center;min-height:200px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.error-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:200px;padding:2rem;display:flex}.error-state-icon{color:#dc2626;margin-bottom:1rem}.dark .error-state-icon{color:#f87171}.error-state-title{color:#272b3a;margin-bottom:.5rem;font-size:1.125rem;font-weight:600;line-height:1.75rem}.dark .error-state-title{color:#f2f2f3}.error-state-message{color:#4b5563;margin-bottom:1rem;font-size:.875rem;line-height:1.25rem}.dark .error-state-message{color:#9ca3af}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:200px;padding:2rem;display:flex}.empty-state-icon{color:#9ca3af;margin-bottom:1rem}.dark .empty-state-icon{color:#4b5563}.empty-state-title{color:#272b3a;margin-bottom:.5rem;font-size:1.125rem;font-weight:600;line-height:1.75rem}.dark .empty-state-title{color:#f2f2f3}.empty-state-message{color:#4b5563;margin-bottom:1rem;font-size:.875rem;line-height:1.25rem}.dark .empty-state-message{color:#9ca3af}.toast-container{z-index:1600;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1rem;right:1rem}.toast{pointer-events:auto;border-radius:.5rem;min-width:300px;max-width:28rem;animation:.2s ease-out slideInRight;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.toast-success{background-color:#fff;border-left:4px solid #22c55e}.dark .toast-success{background-color:#272b3a}.toast-error{background-color:#fff;border-left:4px solid #ef4444}.dark .toast-error{background-color:#272b3a}.toast-warning{background-color:#fff;border-left:4px solid #f59e0b}.dark .toast-warning{background-color:#272b3a}.toast-info{background-color:#fff;border-left:4px solid #3b82f6}.dark .toast-info{background-color:#272b3a}.toast-content{align-items:flex-start;gap:.75rem;padding:1rem;display:flex}.toast-icon{flex-shrink:0}.toast-body{flex:1}.toast-title{color:#272b3a;font-weight:600}.dark .toast-title{color:#f2f2f3}.toast-message{color:#4b5563;margin-top:.25rem;font-size:.875rem;line-height:1.25rem}.dark .toast-message{color:#9ca3af}.toast-close{color:#9ca3af;border-radius:.375rem;flex-shrink:0;padding:.25rem}.toast-close:hover{color:#4b5563}.dark .toast-close{color:#6b7280}.dark .toast-close:hover{color:#d1d5db}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.theme-toggle{background-color:#f3f4f6;border:1px solid #e5e7eb;border-radius:9999px;justify-content:space-between;align-items:center;width:100%;padding:.125rem;display:flex}.dark .theme-toggle{background-color:#1f2937;border-color:#374151}.theme-toggle-option{border-radius:9999px;justify-content:center;align-items:center;gap:.375rem;padding:.375rem .625rem;font-size:.875rem;font-weight:500;line-height:1.25rem;transition-property:color,background-color,border-color;transition-duration:.15s;transition-timing-function:ease;display:flex}.theme-toggle-option:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.theme-toggle-option-active{background-color:var(--color-white);color:var(--color-dark-gray);box-shadow:0 1px 2px #0000000d}.dark .theme-toggle-option-active{background-color:var(--color-dark-gray);color:var(--color-white)}.theme-toggle-option-inactive{color:#4b5563}.theme-toggle-option-inactive:hover{color:#111827}.dark .theme-toggle-option-inactive{color:#9ca3af}.dark .theme-toggle-option-inactive:hover{color:#f3f4f6}.theme-toggle-option-label{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.edge-panel{z-index:15;pointer-events:auto;background:var(--panel-bg);-webkit-backdrop-filter:blur(20px);-webkit-user-select:none;user-select:none;transition:width var(--transition-base) ease 0s,height var(--transition-base) ease var(--transition-base),left var(--transition-base) ease,background var(--transition-slow) ease;flex-direction:row;display:flex;position:absolute;top:3rem;overflow:hidden}.edge-panel--focused{background:var(--panel-bg-solid)}.edge-panel--collapsed{cursor:pointer;transition:width var(--transition-base) ease var(--transition-base),height var(--transition-base) ease 0s,left var(--transition-base) ease,background var(--transition-slow) ease}.edge-panel--collapsed.edge-panel--strip-el{transition:background var(--transition-fast) ease,left var(--transition-base) ease}.edge-panel--collapsed.edge-panel--strip-el:hover{background:var(--strip-hover-bg)}.edge-panel--collapsed.edge-panel--strip-el:hover .edge-panel__strip-icon,.edge-panel--collapsed.edge-panel--strip-el:hover .edge-panel__strip-label{color:var(--text-primary)}.edge-panel--left{border-right:1px solid var(--pane-border);border-bottom:1px solid var(--pane-border);border-radius:0 0 8px}.edge-panel--right{border-left:1px solid var(--pane-border);border-bottom:1px solid var(--pane-border);border-radius:0 0 0 8px;flex-direction:row-reverse;right:0}.edge-panel--detached.edge-panel--left{border-top:1px solid var(--pane-border);border-radius:0 8px 8px 0}.edge-panel--detached.edge-panel--right{border-top:1px solid var(--pane-border);border-radius:8px 0 0 8px}.edge-panel--bottom.edge-panel--left{border-radius:0 8px 8px 0}.edge-panel--bottom.edge-panel--right{border-radius:8px 0 0 8px}.edge-panel--resizing,.edge-panel--resizing *{transition:none!important}.edge-panel__resize-handle{cursor:ns-resize;z-index:5;border-top:1px solid var(--pane-border-subtle);flex-shrink:0;justify-content:center;align-items:center;height:14px;display:flex;position:relative}.edge-panel__resize-handle:before{content:"";background:var(--text-muted);opacity:.55;width:28px;height:3px;transition:opacity var(--transition-fast) ease;border-radius:2px}.edge-panel__resize-handle:hover:before{opacity:.9}.edge-panel__resize-handle--top{border-top:none;border-bottom:1px solid var(--pane-border-subtle)}.edge-panel__strip{flex-direction:column;flex-shrink:0;align-items:center;gap:10px;width:36px;padding-top:16px;display:flex}.edge-panel__strip-icon{color:var(--text-secondary);flex-shrink:0}.edge-panel__strip-details{opacity:1;max-height:300px;transition:opacity var(--transition-base) ease .4s,max-height var(--transition-base) ease .4s;flex-direction:column;align-items:center;gap:10px;display:flex;overflow:hidden}.edge-panel__strip-details--hidden{opacity:0;pointer-events:none;max-height:0;transition:opacity var(--transition-fast) ease 0s,max-height var(--transition-fast) ease 0s}.edge-panel__strip-badge{border-radius:11px;justify-content:center;align-items:center;min-width:22px;height:22px;font-size:12px;font-weight:700;display:flex}.edge-panel__strip-badge--active{background:var(--accent-bg);color:var(--color-accent)}.edge-panel__strip-badge--inactive{background:var(--hover-bg);color:var(--text-tertiary)}.edge-panel__strip-label{writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-secondary);text-align:center;margin:0 auto;padding-bottom:14px;font-size:12px;font-weight:600}.edge-panel--right .edge-panel__strip-label{padding-top:14px;transform:rotate(180deg)}.edge-panel__main{opacity:1;min-width:0;min-height:0;transition:opacity var(--transition-base) ease .4s;flex-direction:column;flex:1;display:flex;overflow:hidden}.edge-panel--collapsed .edge-panel__main{opacity:0;pointer-events:none;transition:opacity var(--transition-fast) ease 0s}.edge-panel__header{border-bottom:1px solid var(--pane-border-subtle);flex-shrink:0;align-items:center;gap:8px;padding:10px 8px;display:flex}.edge-panel__header-title{color:var(--text-primary);white-space:nowrap;flex:1;font-size:13px;font-weight:600}.edge-panel__header-subtitle{color:var(--text-muted);white-space:nowrap;font-size:11px;font-weight:400}.edge-panel__header-actions{flex-shrink:0;gap:4px;display:flex}.edge-panel__collapse-btn{width:24px;height:24px;color:var(--text-muted);cursor:pointer;transition:color var(--transition-base) ease,background-color var(--transition-base) ease;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.edge-panel__collapse-btn:hover{color:var(--active-text);background:var(--hover-bg)}.edge-panel__body{touch-action:pan-y;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--pane-border-subtle) transparent;flex:1;min-height:0;padding:4px 0;overflow:hidden scroll}.edge-panel__body::-webkit-scrollbar{width:6px}.edge-panel__body::-webkit-scrollbar-track{background:0 0}.edge-panel__body::-webkit-scrollbar-thumb{background:var(--pane-border-subtle);border-radius:3px}.edge-panel__body::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.edge-panel__body::-webkit-scrollbar-thumb:active{background:var(--text-secondary)}@media(max-width:767px){.edge-panel{top:3.5rem}}@media(min-width:768px)and (max-width:1024px){.edge-panel--left:not(.edge-panel--collapsed){max-width:240px}.edge-panel--right:not(.edge-panel--collapsed){max-width:280px}}.page-inset{top:3rem;left:var(--sidebar-width,14rem);pointer-events:auto;transition:left var(--transition-base) ease;position:absolute;bottom:0;right:0}.page-inset-scroll{scrollbar-width:thin;scrollbar-color:var(--pane-border-subtle) transparent;width:100%;height:100%;overflow:hidden auto}@media(max-width:767px){.page-inset{top:3.5rem;left:0}}.map-container{border-radius:.75rem;width:100%;height:280px;overflow:hidden}.cesium-viewer-bottom{display:none!important}.map-settings{position:relative}.map-settings__bar{border:1px solid var(--pane-border);background:0 0;border-radius:8px;align-items:center;gap:0;height:32px;padding:0;display:flex}.map-settings__toggle{border:1px solid var(--pane-border);background:0 0;border-radius:8px;align-items:center;gap:0;height:100%;margin:-1px 0 -1px -1px;padding:3px;display:flex;position:relative}.map-settings__toggle:before{content:"";background:var(--color-primary);border-radius:8px;width:50%;position:absolute;top:0;right:0;bottom:0;left:0}@supports (color:color-mix(in lab,red,red)){.map-settings__toggle:before{background:color-mix(in srgb,var(--color-primary) 38%,transparent)}}.map-settings__toggle:before{box-shadow:inset 0 0 0 100px var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.map-settings__toggle:before{box-shadow:inset 0 0 0 100px color-mix(in srgb,var(--color-primary) 18%,transparent)}}.map-settings__toggle:before{transition:transform var(--transition-base) cubic-bezier(.4,0,.2,1);z-index:0}.map-settings__toggle[data-mode="2d"]:before{transform:translate(100%)}.map-settings__toggle-btn{z-index:1;height:100%;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:color var(--transition-base) ease;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;gap:4px;padding:0 10px;font-size:11px;font-weight:600;display:flex;position:relative}.map-settings__toggle-btn:hover{color:var(--text-secondary)}.map-settings__toggle-btn[data-active]{color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.map-settings__toggle-btn[data-active]{color:color-mix(in srgb,var(--color-primary) 45%,var(--active-mix))}}.map-settings__cog{width:32px;height:100%;color:var(--text-muted);cursor:pointer;transition:background-color var(--transition-fast) ease,color var(--transition-fast) ease;background:0 0;border:none;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.map-settings__cog:hover{color:var(--text-secondary)}.map-settings__cog[data-open]{color:var(--text-primary)}.map-settings__menu{z-index:50;border:1px solid var(--popover-border);background:var(--popover-bg);-webkit-backdrop-filter:blur(20px);width:200px;box-shadow:var(--popover-shadow);border-radius:10px;margin-top:.5rem;padding:8px 0;position:absolute;top:100%;right:0;overflow:hidden}.map-settings__title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;padding:6px 14px 8px;font-size:10px;font-weight:700}.map-settings__item{justify-content:space-between;align-items:center;padding:7px 14px;transition:background-color .1s;display:flex}.map-settings__item:not([data-disabled]):hover{background:var(--hover-bg)}.map-settings__item[data-disabled]{opacity:.55;cursor:not-allowed}.map-settings__item:not([data-disabled]){cursor:pointer}.map-settings__item-label{color:var(--text-primary);font-size:12px;font-weight:500}.map-settings__divider{background:var(--popover-border);height:1px;margin:6px 0}.map-settings__layer-grid{grid-template-columns:1fr 1fr;gap:4px;padding:4px 10px 6px;display:grid}.map-settings__layer-chip{border:1px solid var(--chip-border);color:var(--text-secondary);cursor:pointer;text-align:center;background:0 0;border-radius:6px;padding:5px 0;font-size:10px;font-weight:500;transition:background-color .15s,border-color .15s,color .15s}.map-settings__layer-chip:hover{background:var(--chip-hover-bg);border-color:var(--chip-hover-border)}.map-settings__layer-chip[data-active]{background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.map-settings__layer-chip[data-active]{background:color-mix(in srgb,var(--color-primary) 15%,transparent)}}.map-settings__layer-chip[data-active]{border-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.map-settings__layer-chip[data-active]{border-color:color-mix(in srgb,var(--color-primary) 50%,transparent)}}.map-settings__layer-chip[data-active]{color:var(--color-primary)}.whep-player{border-radius:var(--radius-md);background:var(--color-black);border:1px solid var(--pane-border);aspect-ratio:16/9;position:relative;overflow:hidden}.whep-player__video{object-fit:contain;width:100%;height:100%}.whep-player__status{background:var(--overlay-heavy);justify-content:center;align-items:center;padding:12px;display:flex;position:absolute;top:0;right:0;bottom:0;left:0}.whep-player__status-text{color:var(--color-primary);text-align:center;font-size:11px;line-height:1.5}.stream-metrics{border-top:1px solid var(--pane-border);background:var(--overlay-light);border-radius:0 0 var(--radius-md) var(--radius-md);font-family:SF Mono,Fira Code,Consolas,monospace;font-size:10px}.stream-metrics__toggle{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:5px;padding:3px 6px;line-height:1.4;display:flex}.stream-metrics__toggle:hover{background:var(--metrics-hover-bg)}.stream-metrics__summary{white-space:nowrap;flex:1;align-items:center;min-width:0;display:flex;overflow:hidden}.stream-metrics__summary>span{text-align:left;font-variant-numeric:tabular-nums;min-width:48px}.stream-metrics__sep{color:var(--text-muted)}.stream-metrics__sep:before{content:"·";color:var(--text-muted);opacity:.4;margin:0 5px}.stream-metrics__chevron{color:var(--text-muted);flex-shrink:0}.stream-metrics__detail{grid-template-columns:1fr auto;gap:1px 8px;padding:2px 6px 5px;display:grid}.stream-metrics__row{display:contents}.stream-metrics__label{color:var(--text-muted);white-space:nowrap;padding:1px 0}.stream-metrics__value{color:var(--text-secondary);text-align:right;font-variant-numeric:tabular-nums;min-width:56px;padding:1px 0}.device-row-wrapper{position:relative}.device-row{border-bottom:1px solid var(--pane-border-subtle);transition:background-color var(--transition-base) ease,border-left-color var(--transition-base) ease;border-left:2px solid #0000;align-items:stretch;display:flex}.device-row[data-tracked]{background:var(--warning-bg);border-left-color:var(--color-warning-accent)}.device-row__main{cursor:pointer;text-align:left;color:var(--text-primary);background:0 0;border:none;flex-direction:column;flex:1;gap:3px;padding:8px 4px 8px 12px;transition:background-color .1s;display:flex}.device-row__main:hover{background:var(--hover-bg)}.device-row__name-line{align-items:center;gap:6px;display:flex}.device-row__name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12px;font-weight:600;overflow:hidden}.device-row__callsign{color:var(--text-muted);font-family:monospace;font-size:10px}.device-row__tags{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.device-row__telemetry{color:var(--text-muted);align-items:center;gap:8px;font-size:10px;display:flex}.device-row__telemetry-item{align-items:center;gap:3px;display:flex}.device-row__actions{flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;padding-right:2px;display:flex}.device-row__gear{cursor:pointer;width:24px;height:24px;color:var(--text-muted);transition:color var(--transition-fast) ease;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.device-row__gear:hover,.device-row__gear[data-active]{color:var(--color-accent)}.device-row__delete{cursor:pointer;width:24px;height:24px;color:var(--text-muted);transition:color var(--transition-fast) ease;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.device-row__delete:hover{color:var(--color-error)}.device-empty{color:var(--text-muted);text-align:center;padding:16px 12px;font-size:12px}.status-dot{background:var(--color-neutral-muted);border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.status-dot[data-online]{background:var(--color-accent);box-shadow:0 0 6px var(--accent-glow)}.ui-tag{border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:1px 5px;font-size:9px;font-weight:600}.ui-toggle{background:var(--hover-bg);cursor:pointer;width:28px;height:16px;transition:background var(--transition-fast) ease;border:none;border-radius:8px;flex-shrink:0;padding:0;position:relative}.ui-toggle[data-checked]{background:var(--color-accent)}.ui-toggle[data-disabled]{opacity:.55;cursor:not-allowed}.ui-toggle__thumb{background:var(--text-primary);width:12px;height:12px;transition:left var(--transition-fast) ease;border-radius:50%;position:absolute;top:2px;left:2px}.ui-toggle[data-checked] .ui-toggle__thumb{left:14px}.viz-popover{z-index:9999;background:var(--popover-bg);border:1px solid var(--popover-border);width:220px;box-shadow:var(--popover-shadow);-webkit-backdrop-filter:blur(16px);pointer-events:auto;border-radius:10px;padding:10px 12px;position:fixed}.viz-popover__title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;font-size:11px;font-weight:700}.viz-popover__row{justify-content:space-between;align-items:center;gap:8px;padding:5px 0;display:flex}.viz-popover__row--wrap{flex-wrap:wrap;gap:4px}.viz-popover__label{color:var(--text-tertiary);flex:1;font-size:11px}.viz-popover__label--full{width:100%;margin-bottom:2px}.viz-popover__label-hint{opacity:.6;font-size:9px}.viz-popover__divider{background:var(--pane-border-subtle);height:1px;margin:6px 0}.viz-popover__chip-group{flex-wrap:wrap;gap:3px;display:flex}.viz-popover__chip{border-radius:var(--radius-sm);border:1px solid var(--pane-border);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast) ease;background:0 0;padding:2px 7px;font-size:10px;font-weight:600}.viz-popover__chip:hover{border-color:var(--text-tertiary);color:var(--text-secondary)}.viz-popover__chip[data-active]{border-color:var(--color-accent);background:var(--accent-bg);color:var(--color-accent)}.device-add-section{border-top:1px solid var(--pane-border-subtle);margin-top:auto;padding:6px 10px 10px}.device-add-btn{border-radius:var(--radius-md);border:1px dashed var(--pane-border);width:100%;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast) ease,border-color var(--transition-fast) ease;background:0 0;align-items:center;gap:6px;padding:6px 8px;font-size:11px;display:flex}.device-add-btn:hover{color:var(--text-secondary);border-color:var(--text-muted)}.add-device-form{border-radius:var(--radius-md);background:var(--overlay-light);border:1px solid var(--pane-border-subtle);flex-direction:column;gap:6px;padding:8px;display:flex}.dark .add-device-form{background:var(--overlay-light)}.light .add-device-form{background:var(--overlay-subtle)}.add-device-form__header{justify-content:space-between;align-items:center;display:flex}.add-device-form__hint{color:var(--text-muted);font-size:10px;line-height:1.3}.add-device-form__hint strong{color:var(--color-accent);font-weight:600}.add-device-form__title{color:var(--text-muted);font-size:11px;font-weight:600}.add-device-form__close{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast) ease;background:0 0;border:none;padding:0;display:flex}.add-device-form__close:hover{color:var(--text-primary)}.add-device-form__select{border:1px solid var(--pane-border);background:var(--popover-bg);width:100%;color:var(--text-primary);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:border-color var(--transition-fast) ease;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23999' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border-radius:5px;padding:6px 24px 6px 8px;font-size:12px}.add-device-form__select:focus{border-color:var(--color-primary);outline:none}.add-device-form__select:disabled{opacity:.45;cursor:not-allowed;color:var(--text-muted)}.add-device-form__input{border:1px solid var(--pane-border);background:var(--popover-bg);color:var(--text-primary);transition:border-color var(--transition-fast) ease;border-radius:5px;padding:6px 8px;font-size:12px}.add-device-form__input::placeholder{color:var(--text-muted)}.add-device-form__input:focus{border-color:var(--color-primary);outline:none}.add-device-form__error{color:var(--color-error);font-size:11px;line-height:1.3}.add-device-form__submit{background:var(--color-primary);color:var(--color-white);cursor:pointer;transition:background-color var(--transition-fast) ease;border:none;border-radius:5px;padding:6px 10px;font-size:12px;font-weight:600}.add-device-form__submit:hover{background:var(--color-primary-hover)}.add-device-form__submit:disabled{opacity:.7;cursor:wait}.device-created-protocol-tag{text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-sm);background:var(--accent-bg-subtle);color:var(--color-accent);padding:2px 7px;font-size:10px;font-weight:700}.telemetry-panel{flex-direction:column;gap:8px;padding:8px 10px 10px;display:flex}.telemetry-panel__empty{color:var(--text-muted);text-align:center;padding:12px 0;font-size:12px}.telemetry-panel__select{border:1px solid var(--pane-border);background:var(--popover-bg);width:100%;color:var(--text-primary);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23999' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border-radius:5px;padding:5px 24px 5px 8px;font-size:11px}.telemetry-panel__select:focus{border-color:var(--color-primary);outline:none}.telemetry-group{flex-direction:column;gap:1px;display:flex}.telemetry-group__title{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);border-bottom:1px solid var(--pane-border-subtle);margin-bottom:2px;padding:4px 0 2px;font-size:9px;font-weight:700}.telemetry-row{justify-content:space-between;align-items:center;padding:2px 0;display:flex}.telemetry-row__label{color:var(--text-tertiary);font-size:11px}.telemetry-row__value{color:var(--text-primary);font-family:monospace;font-size:11px;font-weight:600}.telemetry-row__unit{color:var(--text-muted);margin-left:2px;font-weight:400}.logs-panel{flex-direction:column;gap:8px;padding:8px 10px 10px;display:flex}.logs-panel__empty{color:var(--text-muted);text-align:center;padding:12px 0;font-size:12px}.logs-panel__select{border:1px solid var(--pane-border);background:var(--popover-bg);width:100%;color:var(--text-primary);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23999' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border-radius:5px;padding:5px 24px 5px 8px;font-size:11px}.logs-panel__select:focus{border-color:var(--color-primary);outline:none}.logs-panel__list{flex-direction:column;gap:2px;display:flex}.logs-row{border-radius:var(--radius-sm);border-bottom:1px solid var(--pane-border-subtle);transition:background-color var(--transition-fast) ease;align-items:center;gap:6px;padding:6px 8px;display:flex}.logs-row:hover{background:var(--hover-bg)}.logs-row__info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.logs-row__name-line{align-items:center;gap:5px;display:flex}.logs-row__filename{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:600;overflow:hidden}.logs-row__meta{color:var(--text-muted);align-items:center;gap:8px;font-size:10px;display:flex}.logs-row__status{text-transform:uppercase;letter-spacing:.3px;font-size:9px;font-weight:600}.logs-row__status--completed{color:var(--color-accent)}.logs-row__status--pending{color:var(--color-warning-accent)}.logs-row__status--expired{color:var(--text-muted)}.logs-row__status--failed{color:var(--color-error)}.logs-row__status-icon{flex-shrink:0}.logs-row__status-icon--completed{color:var(--color-accent)}.logs-row__status-icon--pending{color:var(--color-warning-accent)}.logs-row__status-icon--expired{color:var(--text-muted)}.logs-row__status-icon--failed{color:var(--color-error)}.logs-row__download{cursor:pointer;width:24px;height:24px;color:var(--text-muted);border-radius:var(--radius-sm);transition:color var(--transition-fast) ease,background-color var(--transition-fast) ease;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.logs-row__download:hover{color:var(--color-accent);background:var(--accent-bg-faint)}.logs-row__download:disabled{opacity:.5;cursor:wait}@media(max-width:767px){.device-row__callsign{display:none}.device-row__telemetry{flex-wrap:wrap}}.panel-icon-btn{border-radius:var(--radius-md);border:1px solid var(--pane-border);background:var(--pane-bg-subtle);width:28px;height:28px;color:var(--text-tertiary);cursor:pointer;transition:background-color var(--transition-base) ease,color var(--transition-base) ease;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.panel-icon-btn:hover,.panel-icon-btn--active{background:var(--hover-bg);color:var(--text-primary)}.panel-icon-btn--sm{width:26px;height:26px}.panel-icon-btn--md{width:32px;height:32px}.panel-icon-btn--xs{border-radius:var(--radius-sm);width:auto;height:auto;padding:2px 6px;font-size:10px}.panel-icon-btn--danger{border-color:var(--error-border);color:var(--error-text)}.panel-icon-btn--danger:hover{border-color:var(--error-border-strong);color:var(--error-text-solid);background:var(--error-bg-strong)}.vsp-body{touch-action:pan-y;overscroll-behavior:contain;flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.vsp-stream-tile{flex-direction:column;gap:4px;display:flex}.vsp-stream-tile__header{justify-content:space-between;align-items:center;display:flex}.vsp-stream-tile__label{color:var(--text-primary);font-size:11px;font-weight:600}.vsp-stream-tile__actions{gap:3px;display:flex}.vsp-stream-tile__player{position:relative}.vsp-stream-tile__info-btn{z-index:2;border-radius:var(--radius-sm);background:var(--overlay-heavy);width:18px;height:18px;color:var(--text-muted);cursor:pointer;opacity:.8;transition:opacity var(--transition-fast) ease;border:none;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;top:4px;right:4px}.vsp-stream-tile__info-btn:hover{opacity:1}.vsp-stream-toggle{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background-color var(--transition-fast) ease,color var(--transition-fast) ease,border-color var(--transition-fast) ease;border:1px solid #0000;align-items:center;gap:4px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-flex}.vsp-stream-toggle--start{background:var(--success-bg);color:var(--success-text);border-color:var(--success-border)}.vsp-stream-toggle--start:hover{background:var(--success-bg-strong);border-color:var(--success-border-strong)}.vsp-stream-toggle--stop{background:var(--error-bg);color:var(--color-error);border-color:var(--error-border)}.vsp-stream-toggle--stop:hover{background:var(--error-bg-strong);border-color:var(--error-border-strong)}.vsp-stream-toggle:disabled{opacity:.5;cursor:wait}.vsp-stream-toggle__spinner{border:1.5px solid;border-top-color:#0000;border-radius:50%;width:10px;height:10px;animation:.6s linear infinite vsp-spin;display:inline-block}@keyframes vsp-spin{to{transform:rotate(360deg)}}.vsp-stream-tile__idle{border-radius:var(--radius-md);background:var(--overlay-subtle);border:1px dashed var(--pane-border-subtle);color:var(--text-muted);justify-content:center;align-items:center;gap:6px;padding:16px 8px;font-size:11px;display:flex}.vsp-compact-grid{grid-template-columns:repeat(2,1fr);gap:4px;display:grid}.vsp-compact-tile{position:relative}.vsp-compact-tile-actions{z-index:2;gap:2px;display:flex;position:absolute;top:3px;right:3px}.vsp-tile-overlay-btn{border-radius:var(--radius-sm);background:var(--overlay-modal);width:16px;height:16px;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast) ease;border:none;justify-content:center;align-items:center;padding:0;display:flex}.vsp-tile-overlay-btn:hover{color:var(--text-primary)}.vsp-tile-overlay-btn--danger{color:var(--error-text-solid)}.vsp-tile-overlay-btn--danger:hover{color:var(--color-error)}.vsp-minimized-btn{border-radius:var(--radius-md);border:1px solid var(--pane-border-subtle);background:var(--pane-bg-subtle);color:var(--text-tertiary);cursor:pointer;text-align:left;width:100%;transition:background-color var(--transition-fast) ease;align-items:center;gap:6px;padding:6px 10px;font-size:11px;display:flex}.vsp-minimized-btn:hover{background:var(--hover-bg)}.vsp-minimized-btn__label{font-weight:600}.vsp-minimized-btn__tag{opacity:.6;margin-left:auto;font-size:10px}.vsp-add-section{border-top:1px solid var(--pane-border-subtle);margin-top:auto;padding-top:4px}.vsp-add-btn{border-radius:var(--radius-md);border:1px dashed var(--pane-border);width:100%;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast) ease,border-color var(--transition-fast) ease;background:0 0;align-items:center;gap:6px;padding:6px 8px;font-size:11px;display:flex}.vsp-add-btn:hover{color:var(--text-secondary);border-color:var(--text-muted)}.add-stream-form{border-radius:var(--radius-md);background:var(--overlay-light);border:1px solid var(--pane-border-subtle);flex-direction:column;gap:6px;padding:8px;display:flex}.dark .add-stream-form{background:var(--overlay-light)}.light .add-stream-form{background:var(--overlay-subtle)}.add-stream-form__header{justify-content:space-between;align-items:center;display:flex}.add-stream-form__title{color:var(--text-muted);font-size:11px;font-weight:600}.add-stream-form__close{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast) ease;background:0 0;border:none;padding:0;display:flex}.add-stream-form__close:hover{color:var(--text-primary)}.add-stream-form__input,.add-stream-form__select{border:1px solid var(--pane-border);background:var(--popover-bg);color:var(--text-primary);transition:border-color var(--transition-fast) ease;border-radius:5px;padding:6px 8px;font-size:12px}.add-stream-form__input::placeholder{color:var(--text-muted)}.add-stream-form__input:focus,.add-stream-form__select:focus{border-color:var(--color-primary);outline:none}.add-stream-form__select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23999' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;padding-right:24px}.add-stream-form__error{color:var(--color-error);font-size:11px;line-height:1.3}.add-stream-form__submit{background:var(--color-primary);color:var(--color-white);cursor:pointer;transition:background-color var(--transition-fast) ease;border:none;border-radius:5px;padding:6px 10px;font-size:12px;font-weight:600}.add-stream-form__submit:hover{background:var(--color-primary-hover)}.add-stream-form__submit:disabled{opacity:.7;cursor:wait}.add-stream-form__checkbox-label{color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;font-size:11px;display:flex}.add-stream-form__checkbox-label input[type=checkbox]{width:13px;height:13px;accent-color:var(--color-primary);cursor:pointer}.stream-modal-overlay{z-index:10000;background:var(--overlay-modal);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);justify-content:center;align-items:center;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.stream-modal-panel{border-radius:var(--radius-lg);background:var(--popover-bg);border:1px solid var(--popover-border);max-width:90vw;box-shadow:0 20px 60px var(--overlay-backdrop);overflow:hidden}.stream-modal-header{border-bottom:1px solid var(--pane-border-subtle);background:var(--pane-bg-subtle);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.stream-modal-title{color:var(--text-primary);font-size:14px;font-weight:600}.stream-modal-body{flex-direction:column;gap:14px;padding:16px 18px;display:flex}.stream-modal-hint{color:var(--text-tertiary);margin:0;font-size:12px;line-height:1.5}.stream-modal-urls{flex-direction:column;gap:8px;display:flex}.stream-modal-name-row{align-items:center;gap:8px;display:flex}.stream-protocol-tag{text-transform:uppercase;letter-spacing:.05em;border-radius:3px;padding:2px 6px;font-size:10px;font-weight:700}.stream-protocol-tag[data-protocol=srt]{background:var(--tag-srt-bg);color:var(--color-tag-srt)}.stream-protocol-tag[data-protocol=rtsp]{background:var(--tag-rtsp-bg);color:var(--color-tag-rtsp)}.stream-modal-stream-name{color:var(--text-primary);font-size:13px;font-weight:600}.stream-modal-transcode-note{color:var(--color-primary);margin:0;font-size:11px;line-height:1.4}.stream-modal-warning{color:var(--text-muted);margin:0;font-size:11px;font-style:italic;line-height:1.4}.stream-modal-footer{border-top:1px solid var(--pane-border-subtle);justify-content:flex-end;padding:12px 18px;display:flex}.stream-modal-done-btn{border-radius:var(--radius-md);background:var(--color-primary);color:var(--color-white);cursor:pointer;transition:background-color var(--transition-fast) ease;border:none;padding:7px 16px;font-size:12px;font-weight:600}.stream-modal-done-btn:hover{background:var(--color-primary-hover)}.stream-modal-delete-msg{color:var(--text-muted);margin:0;font-size:12px;line-height:1.5}.stream-modal-delete-msg strong{color:var(--text-secondary)}.stream-modal-actions{justify-content:flex-end;gap:8px;padding:10px 18px 14px;display:flex}.stream-modal-cancel-btn{border-radius:var(--radius-md);border:1px solid var(--pane-border);color:var(--text-tertiary);cursor:pointer;transition:background-color var(--transition-fast) ease,color var(--transition-fast) ease;background:0 0;padding:7px 14px;font-size:12px;font-weight:500}.stream-modal-cancel-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.stream-modal-delete-btn{border-radius:var(--radius-md);background:var(--color-error);color:var(--color-white);cursor:pointer;transition:background-color var(--transition-fast) ease;border:none;padding:7px 14px;font-size:12px;font-weight:600}.stream-modal-delete-btn:hover{background:var(--color-error-dark)}.url-block{border-radius:var(--radius-md);background:var(--overlay-medium);border:1px solid var(--pane-border-subtle);padding:10px 12px}.light .url-block{background:var(--overlay-subtle)}.url-block__header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.url-block__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:600}.url-block__value{word-break:break-all;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;line-height:1.5;display:block}.copy-btn{border-radius:var(--radius-sm);border:1px solid var(--pane-border);background:var(--pane-bg-subtle);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast) ease;align-items:center;gap:4px;padding:3px 8px;font-size:11px;display:flex}.copy-btn:hover{color:var(--text-primary);background:var(--hover-bg)}.copy-btn[data-copied]{background:var(--success-bg-accent);color:var(--success-text);border-color:var(--success-border-strong)}.fs-grid-overlay{z-index:9999;background:var(--overlay-solid);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-direction:column;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.fs-grid-header{border-bottom:1px solid var(--pane-border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.fs-grid-title{color:var(--text-primary);font-size:15px;font-weight:600}.fs-grid-body{flex-direction:column;flex:1;gap:10px;min-height:0;padding:12px;display:flex;overflow-y:auto}.fs-grid-tiles{flex:1;align-content:start;gap:10px;display:grid}.fs-grid-tile{flex-direction:column;gap:4px;display:flex}.fs-grid-tile-header{justify-content:space-between;align-items:center;display:flex}.fs-grid-tile-label{color:var(--text-primary);font-size:12px;font-weight:600}.fs-grid-minimized-bar{border-top:1px solid var(--pane-border-subtle);flex-wrap:wrap;gap:6px;padding:8px 0;display:flex}.fs-grid-minimized-btn{border-radius:var(--radius-md);border:1px solid var(--pane-border);background:var(--pane-bg-subtle);color:var(--text-tertiary);cursor:pointer;transition:background-color var(--transition-fast) ease;align-items:center;gap:5px;padding:5px 10px;font-size:11px;display:flex}.fs-grid-minimized-btn:hover{background:var(--hover-bg)}@media(max-width:767px){.fs-grid-tiles{grid-template-columns:1fr!important}.fs-grid-header{padding:10px 16px}.fs-grid-title{font-size:13px}.vsp-compact-grid{grid-template-columns:1fr}.stream-modal-panel{max-width:95vw}}@media(min-width:768px)and (max-width:1024px){.fs-grid-tiles{grid-template-columns:repeat(2,1fr)!important}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
