.toast-container{display:flex;flex-direction:column;gap:10px;max-width:400px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:9999}.toast{background:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 4px 12px #00000026;cursor:pointer;margin:0;max-width:400px;min-width:300px;opacity:0;padding:0;pointer-events:auto;transform:translateX(100%);transition:all .3s cubic-bezier(.4,0,.2,1)}.toast-visible{opacity:1;transform:translateX(0)}.toast-leaving{opacity:0;transform:translateX(100%)}.toast-content{align-items:flex-start;display:flex;gap:12px;padding:16px}.toast-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:20px;justify-content:center;margin-top:2px;width:20px}.toast-message{word-wrap:break-word;color:#374151;flex:1 1;font-size:14px;line-height:1.4}.toast-close{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:20px;justify-content:center;padding:0;transition:all .2s ease;width:20px}.toast-close:hover{background-color:#f3f4f6;color:#6b7280}.toast-success{border-left-color:#10b981}.toast-success .toast-icon{background-color:#d1fae5;color:#065f46}.toast-error{border-left-color:#ef4444}.toast-error .toast-icon{background-color:#fee2e2;color:#991b1b}.toast-warning{border-left-color:#f59e0b}.toast-warning .toast-icon{background-color:#fef3c7;color:#92400e}.toast-info{border-left-color:#3b82f6}.toast-info .toast-icon{background-color:#dbeafe;color:#1e40af}.toast:hover{box-shadow:0 6px 16px #0003;transform:translateX(-4px)}.toast-leaving:hover{transform:translateX(100%)}@media (max-width:480px){.toast-container{left:10px;max-width:none;right:10px;top:10px}.toast{max-width:none;min-width:auto}}.toast:first-child{animation-delay:0ms}.toast:nth-child(2){animation-delay:.1s}.toast:nth-child(3){animation-delay:.2s}.toast:nth-child(4){animation-delay:.3s}.toast:nth-child(5){animation-delay:.4s}*{font-family:Roboto,sans-serif}.disabled{cursor:not-allowed;opacity:.5}.text-button-variant{border-radius:10px;color:#2932e5;font-family:Roboto,sans-serif;font-weight:500;padding:5px 15px;text-transform:none}.text-button-variant-hover{color:#2932e5}.text-button-variant-disabled{color:#9ca3af}.text-button-variant-active{color:#2932e5}.contained-button-variant{background-color:#2932e5;border-radius:10px;box-shadow:none;color:#fff;font-family:Roboto,sans-serif;font-weight:500;padding:5px 15px;&:hover{background-color:#1f28b8;box-shadow:none}&:disabled{background-color:#9ca3af;box-shadow:none}}.cam360-controls.hidden,.cam360-quad-zoom-overlay.hidden,.camera-info-overlay.hidden,.recording-overlay.hidden{opacity:0;pointer-events:none;transform:translateY(10px)}.cam360-controls.visible,.cam360-quad-zoom-overlay.visible,.camera-info-overlay.visible,.recording-overlay.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.cam360-controls,.cam360-quad-zoom-overlay,.camera-info-overlay,.recording-overlay{transition:all .3s ease}.cam360-controls{contain:layout;overflow:hidden}.cam360-controls,.cam360-controls *{box-sizing:border-box}.control-btn{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.control-btn:focus{outline:2px solid #ffffff4d;outline-offset:2px}.primary-btn{background:#ffffffe6!important;color:#000!important}.secondary-btn{background:#ffffff1a!important;color:#fff!important}.mode-btn{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.preset-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:12px;padding-right:28px!important}.cam360-root{border:1px solid #ffffff14;border-radius:12px;box-shadow:0 4px 20px #0000004d,0 1px 3px #0003;gap:0}.cam360-root,.cam360-stage{background:#000;display:flex;flex-direction:column;margin:0;padding:0}.cam360-stage{align-items:stretch;border-radius:12px;box-shadow:inset 0 2px 8px #0000004d;height:100%;justify-content:stretch;position:relative;width:100%}.cam360-canvas,.cam360-stage{flex:1 1 auto;overflow:hidden}.cam360-canvas{border-radius:8px;display:block;height:100%!important;object-fit:cover!important;transition:transform .2s ease;width:100%!important}.cam360-video-hidden{height:0;opacity:0;pointer-events:none;position:absolute;width:0}.cam360-controls{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000d9;border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 8px 32px #0006;display:flex;flex-wrap:wrap;gap:12px;padding:12px 20px}.cam360-controls button,.cam360-controls select{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;box-shadow:0 2px 8px #0000004d;color:#fff;cursor:pointer;font-weight:600;padding:10px 14px;transition:all .2s ease}.cam360-controls button:hover{background:#fff3;box-shadow:0 4px 12px #0006;transform:scale(1.05)}.cam360-speed{align-items:center}.cam360-presets,.cam360-speed{display:flex;gap:6px}.cam360-timeline{align-items:center;display:flex;gap:10px}.cam360-timeline input[type=range]{flex:1 1}.cam360-time{font:12px/1.2 ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;opacity:.8}.cam360-error{background:#ffe9ec;color:#b00020;padding:6px 8px}.cam360-quad{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;height:100vh;margin:0;padding:0}.cam360-quad-cell{align-items:center;background:#000;border-radius:12px;display:flex;justify-content:center;margin:0;overflow:hidden;padding:0;position:relative}.cam360-quad-cell .cam360-canvas{display:block;height:100%;object-fit:cover;width:100%}.cam360-quad-grid{align-items:stretch;border:1px solid #ffffff14;border-radius:12px;box-shadow:0 4px 16px #0000004d,0 1px 3px #0003;box-sizing:border-box;flex-direction:row;flex-wrap:nowrap;gap:4px;padding:4px;width:100%}.cam360-quad-grid,.cam360-quad-item{background:#000;display:flex;height:100%;justify-content:center;margin:0;overflow:hidden}.cam360-quad-item{align-items:center;border:1px solid #ffffff26;border-radius:8px;box-shadow:0 2px 8px #0000004d,0 1px 2px #0003;cursor:pointer;flex:1 1 auto;min-height:0;min-width:0;position:relative;transition:all .3s ease;width:25%}.cam360-quad-item:hover{border-color:#22c55e99;box-shadow:0 4px 16px #22c55e4d;transform:scale(1.02)}.cam360-quad-item .cam360-canvas{border-radius:8px;display:block;height:100%;image-rendering:high-quality;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;image-rendering:auto;image-rendering:smooth;object-fit:contain;transform:translateZ(0);transition:transform .2s ease;width:100%}.cam360-quad-label{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;border-radius:8px;bottom:12px;box-shadow:0 2px 8px #0000004d;color:#fff;font-size:13px;font-weight:600;left:12px;padding:6px 12px;pointer-events:none;position:absolute}.cam360-mode-toggle{display:flex;gap:8px}.cam360-mode-toggle button{background:#fafafa;border:1px solid #ccc;border-radius:8px;padding:6px 10px}.cam360-mode-toggle .active{background:#eaeaea}.cam360-minimap{border:1px solid #fff3;border-radius:10px;box-shadow:0 6px 16px #00000059;overflow:hidden}.cam360-minimap.hover{outline:2px solid #fff3}.cam360-ptz{align-items:center;display:flex;gap:10px}.cam360-ptz .ptz-pad{flex-direction:column}.cam360-ptz .lr,.cam360-ptz .ptz-pad{align-items:center;display:flex;gap:4px}.cam360-ptz button{background:#f6f6f6;cursor:pointer}.cam360-ptz .ptz-presets,.cam360-ptz button{border:1px solid #ccc;border-radius:8px;padding:6px 10px}.cam360-ptz .ptz-presets{background:#fff}.cam360-pip{background:#000;border-radius:10px;bottom:16px;box-shadow:0 10px 24px #00000073;height:180px;overflow:hidden;position:fixed;right:16px;width:280px;z-index:10}.cam360-pip .pip-header{align-items:center;background:#ffffff1a;color:#fff;cursor:move;display:flex;justify-content:space-between;padding:4px 8px}.cam360-pip .pip-header button{background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:2px 6px}.cam360-quad-label{align-items:center;display:flex;gap:8px}.cam360-quad-label .pip-pin{background:#00000040;border:1px solid #fff6;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;margin-left:8px;padding:2px 6px}.quad-zoom-indicator{background:#000000b3;border-radius:4px;bottom:8px;color:#fff;font-size:11px;opacity:.8;padding:2px 6px;pointer-events:none;position:absolute;right:8px}.cam360-quad-zoom-overlay{bottom:120px;left:12px;pointer-events:none;position:absolute;z-index:1000}.zoom-controls-compact{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#000000d9;border:1px solid #ffffff26;border-radius:12px;box-shadow:0 4px 16px #0006,0 1px 3px #0003;display:flex;flex-direction:column;gap:6px;min-width:180px;padding:10px 14px;pointer-events:auto}.zoom-slider-container{align-items:center;display:flex;gap:8px}.zoom-label{color:#fff;font-size:12px;font-weight:600;min-width:40px}.zoom-slider{-webkit-appearance:none;appearance:none;background:#fff3;border-radius:2px;cursor:pointer;flex:1 1;height:4px;outline:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#3b82f6;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:16px;-webkit-transition:all .2s ease;transition:all .2s ease;width:16px}.zoom-slider::-webkit-slider-thumb:hover{background:#2563eb;transform:scale(1.1)}.zoom-slider::-moz-range-thumb{background:#3b82f6;border:none;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:16px;width:16px}.zoom-value{color:#a1a1aa;font-size:11px;font-weight:600;min-width:35px;text-align:right}.reset-zoom-btn{align-items:center;align-self:flex-end;background:#3b82f6cc;border:none;border-radius:8px;box-shadow:0 2px 8px #3b82f64d;color:#fff;cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.reset-zoom-btn:hover{background:#3b82f6;box-shadow:0 4px 12px #3b82f666;transform:scale(1.05)}.cam360-quad-zoom-overlay.bottom-left{bottom:120px;left:12px;right:auto;top:auto}.cam360-quad-zoom-overlay.bottom-right{bottom:120px;right:16px;top:auto}.cam360-quad-zoom-overlay.top-left{left:16px;right:auto;top:16px}@media (max-width:768px){.zoom-controls-compact{min-width:180px;padding:10px 12px}.zoom-label{font-size:11px;min-width:35px}.zoom-value{font-size:10px;min-width:30px}.reset-zoom-btn{font-size:12px;height:28px;width:28px}}.cam360-quad-zoom{align-items:center;display:flex;font-size:14px;gap:8px}.cam360-quad-zoom input[type=range]{cursor:pointer}.cam360-canvas{image-rendering:high-quality;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;image-rendering:auto;image-rendering:smooth;image-rendering:optimize-quality;transform:translateZ(0);will-change:transform}.cam360-quad-grid[data-cols="2"]{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.cam360-quad-grid[data-cols="3"]{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr)}.cam360-quad-grid[data-cols="4"]{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(3,1fr)}.cam360-quad-item,.cam360-quad-item .cam360-canvas{will-change:transform}.cam360-quad-label{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#000c!important;border:1px solid #ffffff1a}.cam360-quad-info{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 4px 12px #0000004d}.cam360-adaptive-toggle{align-items:center;cursor:pointer;display:flex;font-size:14px;gap:4px}.cam360-adaptive-toggle input[type=checkbox]{cursor:pointer}.cam360-camera-type-indicator{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid #fff3;box-shadow:0 2px 8px #0000004d}.cam360-quad-grid-2x2{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.cam360-quad-grid-1x4{grid-template-columns:repeat(4,1fr);grid-template-rows:1fr}.cam360-quad-grid-4x1{grid-template-columns:1fr;grid-template-rows:repeat(4,1fr)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.camera-info-overlay .live-indicator{animation:pulse 2s infinite}.cam360-controls button,.cam360-quad-item,.cam360-quad-label{animation:fadeIn .3s ease-out}.cam360-controls button:focus,.cam360-quad-item:focus{outline:2px solid #22c55ecc;outline-offset:2px}.cam360-error{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ef44441a;border:1px solid #ef444433;border-radius:8px;color:#ef4444;font-weight:500;padding:12px 16px}.cam360-root{height:80vh;overflow:hidden;position:relative;width:100%}.info-overlay-wrapper{align-items:flex-start;bottom:12px;display:flex;flex-direction:column;font-family:Roboto Mono,monospace;gap:6px;left:12px;position:absolute;z-index:120}.info-toggle-btn{align-items:center;background:#0000008c;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;gap:6px;padding:6px 10px}.info-overlay{background:#000000bf;border-radius:10px;box-shadow:0 6px 18px #00000080;color:#fff;font-size:13px;max-width:420px;min-width:300px;padding:10px 12px}.info-row{display:flex;gap:12px;justify-content:space-between;margin:4px 0}.info-row span:first-child{color:#9ee7ff;opacity:.9}.info-title{border-bottom:1px solid #ffffff0f;font-weight:600;margin-bottom:8px;padding-bottom:6px}@media (max-height:600px){.cam360-root{height:80vh}.cam360-canvas{height:100%!important}}@media (max-height:400px){.cam360-root{height:80vh}.cam360-stage{height:100%}.cam360-canvas{height:100%!important}}@media (max-width:768px){.cam360-root{height:80vh}.cam360-root,.cam360-stage{border-radius:8px}.cam360-canvas{border-radius:6px}}.visually-hidden{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.ds-body{font-family:Roboto,Helvetica,Arial,sans-serif}.ds-text-secondary{color:#0009}.ds-page-title{color:#212121;font-size:20px;font-weight:500}.ds-error-inline{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.ds-btn{background:#fff;border:1px solid #0000003b;border-radius:4px;font-family:Roboto,sans-serif}.ds-btn--primary{border-color:#2932e5}.ds-btn--secondary{background:#f5f5f5}.ds-btn--icon{align-items:center;display:inline-flex;justify-content:center;min-height:40px;min-width:40px;padding:8px}.ds-btn:disabled{opacity:.5}.ds-field{gap:4px}.ds-field__label{color:#000000b3}.ds-input{border:1px solid #0000003b;border-radius:4px;font-size:14px;padding:10px 12px}.ds-field__hint{color:#0000008c;font-size:12px}.ds-modal-backdrop{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1300}.ds-modal{background:#fff;border-radius:8px;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:min(560px,100%);overflow:hidden}.ds-modal__header{align-items:center;border-bottom:1px solid #00000014;display:flex;justify-content:space-between;padding:16px 20px}.ds-modal__title{font-size:18px;font-weight:500;margin:0}.ds-modal__close{background:#0000;border:none;color:#0000008a;cursor:pointer;padding:4px}.ds-modal__body{overflow:auto;padding:20px}.ds-modal__footer{border-top:1px solid #00000014;padding:12px 20px}.ds-w360-page,.ds-w360-shell{box-sizing:border-box}.ds-w360-shell .ds-tp{background:#f5f5f5;border-radius:0}.ds-w360-shell .ds-tp--fill{min-height:0}.ds-w360-shell .ds-tp__header{align-items:center;border-bottom:none;padding:6px 16px 4px}.ds-w360-shell .ds-tp__title{font-size:18px;font-weight:600;letter-spacing:0;line-height:1.3}.ds-w360-shell .ds-tp__header-actions .ds-tp__icon-btn{background:#0000;border-radius:4px;box-shadow:none;color:#00000061;height:28px;padding:2px;width:28px}.ds-w360-shell .ds-tp__header-actions .ds-tp__icon-btn svg{height:18px;width:18px}.ds-w360-shell .ds-tp__header-actions .ds-tp__icon-btn:hover{background:#0000000d;color:#0000008c}.ds-w360-shell .ds-tp__toolbar{align-items:center;border-bottom:1px solid #00000014;flex-wrap:nowrap;gap:10px;padding:4px 16px 8px}.ds-w360-shell .ds-tp__toolbar-left{flex:1 1;flex-wrap:nowrap;gap:8px;min-width:0}.ds-w360-shell .ds-tp__toolbar-right{flex-shrink:0}.ds-w360-shell .ds-tp__toolbar .ds-tp__toolbar-icon{background:#0000;border:1px solid #00000024;border-radius:4px;box-sizing:border-box;color:#0000007a;flex-shrink:0;height:28px;padding:0;width:28px}.ds-w360-shell .ds-tp__toolbar .ds-tp__toolbar-icon svg{height:16px;width:16px}.ds-w360-shell .ds-tp__toolbar .ds-tp__toolbar-icon:hover{background:#2932e50f;border-color:#2932e559;color:#2932e5}.ds-w360-shell .ds-tp__toolbar-icon[aria-pressed=true]{background:#2932e51f;border-color:#2932e5;color:#2932e5}.ds-w360-shell .ds-tp__search-wrap{background:#f5f5f5;border:1px solid #00000024;border-radius:999px;box-shadow:none;flex:1 1 200px;gap:6px;max-width:360px;min-height:32px;min-width:140px;padding:4px 12px}.ds-w360-shell .ds-tp__search{font-size:13px;line-height:1.3}.ds-w360-shell .ds-tp__cta-primary{border-radius:4px;box-shadow:none;font-size:13px;font-weight:600;gap:6px;min-height:32px;padding:6px 12px}.ds-w360-shell .ds-tp__cta-primary svg{height:16px;width:16px}.ds-w360-shell .ds-tp__table-wrap{background:#fff;padding:0 0 4px}.ds-w360-shell .ds-tp__footer{background:#fff;border-top:1px solid #00000014;color:#0000008c;font-size:12px;gap:8px;margin-top:0;padding:6px 16px 8px}.ds-w360-shell .ds-tp__footer-right{gap:10px}.ds-w360-shell .ds-tp__page-select{background:#fff;border:1px solid #0003;border-radius:4px;font-size:12px;padding:2px 6px}.ds-w360-shell .ds-tp__pager{gap:6px}.ds-w360-shell .ds-tp__pager button{background:#0000;color:#00000059;padding:4px 6px}.ds-w360-shell .ds-tp__pager button svg{height:18px;width:18px}.ds-w360-shell .ds-tp__pager span{color:#0000008c;font-size:12px}.ds-w360-shell .ds-tp__footer label.ds-text-secondary{color:#0000008c;font-size:12px;gap:6px}.ds-w360-shell .ds-tp__toolbar-slot{margin-left:0}@media (max-width:720px){.ds-w360-shell .ds-tp__toolbar{flex-wrap:wrap}}.ds-w360-shell .ds-cam-filter-select{background:#fff;border:1px solid #00000024;border-radius:4px;box-sizing:border-box;color:#212121;cursor:pointer;flex-shrink:0;font-size:13px;height:32px;min-width:132px;padding:0 10px}.ds-w360-shell .ds-tp__search-wrap svg{color:#0006;flex-shrink:0}.ds-tp-table thead th[data-align=center] .ds-tp-th-inner{justify-content:center}.ds-w360-shell .ds-tp-table-root{border:none;border-radius:0;box-shadow:none}.ds-w360-shell .ds-tp-table{font-size:13px}.ds-w360-shell .ds-tp-table td,.ds-w360-shell .ds-tp-table th{border-bottom:1px solid #0000000f;border-left:none;border-right:none;padding:5px 10px;vertical-align:middle}.ds-w360-shell .ds-tp-table thead th{background:#fff;border-bottom:1px solid #00000014;color:#2932e5;font-size:11px;font-weight:600;letter-spacing:.04em;padding-bottom:6px;padding-top:6px;text-transform:uppercase}.ds-w360-shell .ds-tp-sort{color:#2932e573;padding:0}.ds-w360-shell .ds-tp-sort[data-active=true]{color:#2932e5}.ds-w360-shell .ds-tp-primary-cell{gap:6px}.ds-w360-shell .ds-tp-primary-cell svg{flex-shrink:0;height:16px;width:16px}.ds-w360-shell .ds-tp-menu-btn{color:#00000073;padding:2px}.ds-w360-shell .ds-tp-menu-btn svg{height:18px;width:18px}.ds-w360-shell .ds-tp-row[data-active=true]{box-shadow:inset 2px 0 0 #2932e5}.ds-tp{color:#212121;font-family:Roboto,sans-serif}.ds-tp--fill{min-height:calc(100vh - 200px)}.ds-tp__header{align-items:center;display:flex;gap:12px;justify-content:space-between;padding:4px 0 14px}.ds-tp__title{color:#212121;font-size:24px;font-weight:700;letter-spacing:-.02em}.ds-tp__title-wrap{align-items:center;display:flex;gap:8px}.ds-tp__title-info{background:#0000;border:none;color:#00000073;cursor:help;padding:4px}.ds-tp__icon-btn{background:#0000000a;border:none;border-radius:8px;color:#000000a6;padding:8px}.ds-tp__icon-btn:hover{background:#2932e514;color:#2932e5}.ds-tp__toolbar-icon[aria-pressed=true]{background:#2932e51f;color:#2932e5}.ds-tp__toolbar{border-bottom:1px solid #00000014;gap:12px;justify-content:space-between;padding:8px 0 16px}.ds-tp__toolbar-left,.ds-tp__toolbar-right{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.ds-tp__search-wrap{align-items:center;background:#fff;border:1px solid #0003;border-radius:8px;display:flex;gap:8px;min-width:240px;padding:6px 14px}.ds-tp__search{border:none;flex:1 1;font-size:14px;min-width:0;outline:none}.ds-tp__cta-primary{align-items:center;background:#2932e5;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 18px}.ds-tp__cta-primary:hover:not(:disabled){background:#212abf}.ds-tp__cta-primary:disabled{cursor:not-allowed;opacity:.5}.ds-tp__table-wrap{min-height:0;padding:8px 0}.ds-cam-empty-panel,.ds-tp__table-wrap{display:flex;flex:1 1;flex-direction:column}.ds-cam-empty-panel{align-items:center;box-sizing:border-box;justify-content:center;min-height:min(420px,calc(100vh - 280px));padding:48px 24px;text-align:center}.ds-cam-empty-panel__title{color:#212121;font-family:Roboto,Helvetica,Arial,sans-serif;font-size:20px;font-weight:600;margin:0 0 12px}.ds-cam-empty-panel__subtitle{color:#0009;font-family:Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5;margin:0 0 24px;max-width:440px}.ds-cam-empty-panel__actions{align-items:center;display:flex;flex-direction:column;gap:12px}.ds-cam-empty-panel__actions .ds-btn--primary{min-width:168px}.ds-tp__error-banner{align-items:center;background:#ffebee;border-radius:4px;color:#b71c1c;display:flex;gap:12px;margin-bottom:12px;padding:12px}.ds-tp__footer{border-top:1px solid #00000014;gap:12px;padding-top:12px}.ds-tp__footer-right{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.ds-tp__page-select{border:1px solid #0000003b;border-radius:4px;padding:6px 8px}.ds-tp__pager button{background:#0000000f;border:none;border-radius:4px;cursor:pointer;padding:6px 10px}.ds-tp__pager button:disabled{cursor:not-allowed;opacity:.4}.ds-tp-table-root{border:none;border-radius:0;overflow:hidden}.ds-tp-table-scroll-inner{max-width:100%;overflow:auto}.ds-tp-table{border-collapse:collapse;font-size:14px;width:100%}.ds-tp-table td,.ds-tp-table th{border-bottom:1px solid #00000014;padding:10px 12px;text-align:left}.ds-tp-table thead th{background:#fafafa;border-bottom:1px solid #2932e52e;color:#2932e5;font-size:13px;font-weight:600;letter-spacing:.01em}.ds-tp-th-inner{align-items:center;display:flex;gap:6px}.ds-tp-sort{background:#0000;border:none;color:#2932e58c;cursor:pointer;padding:2px}.ds-tp-sort[data-active=true]{color:#1a237e}.ds-tp-row{cursor:pointer}.ds-tp-row[data-selected=true]{background:#2932e50f}.ds-tp-row[data-active=true]{box-shadow:inset 3px 0 0 #2932e5}.ds-tp-primary-cell{align-items:center;display:flex;gap:8px;min-width:0}.ds-tp-cell-clip{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ds-tp-menu-btn{background:#0000;border:none;color:#0000008a;cursor:pointer;padding:4px}.ds-tp-dropdown{background:#fff;border:1px solid #0000001f;border-radius:4px;box-shadow:0 4px 12px #00000026;min-width:120px;position:absolute;z-index:20}.ds-tp-dropdown--fixed{position:fixed;z-index:1400}.ds-tp-dropdown button{background:#0000;border:none;cursor:pointer;display:block;font-size:14px;padding:10px 14px;text-align:left;width:100%}.ds-tp-dropdown button:hover{background:#0000000a}.ds-tp-row-actions{position:relative}.ds-tp-skeleton-wrap{padding:12px}.ds-tp-skeleton-row{display:flex;gap:12px;margin-bottom:10px}.ds-skeleton{animation:ds-shimmer 1.2s infinite;background:linear-gradient(90deg,#eee 25%,#f5f5f5 50%,#eee 75%);background-size:200% 100%;border-radius:4px;flex:1 1;height:14px}@keyframes ds-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ds-tp-placeholder{padding:24px;text-align:center}.ds-cam-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.ds-cam-card{background:#fff;border:1px solid #0000001f;border-radius:8px;cursor:pointer;overflow:hidden;position:relative;text-align:left}.ds-cam-card__shot{align-items:center;background:#212121;display:flex;height:140px;justify-content:center}.ds-cam-card__shot-img{height:100%;object-fit:cover;width:100%}.ds-cam-card__shot-placeholder{color:#ffffffb3;font-size:13px;padding:8px;text-align:center}.ds-cam-card__body{padding:12px}.ds-cam-card__title{font-weight:600;margin:0 0 8px}.ds-cam-card__meta,.ds-cam-card__title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ds-cam-card__meta{color:#0009;font-size:12px;margin:0 0 4px}.ds-cam-card__actions{position:absolute;right:8px;top:8px}.ds-cam-filter-select{border:1px solid #0000003b;border-radius:4px;font-size:14px;min-width:160px;padding:8px 10px}.ds-empty{text-align:center}.ds-live-preview__header{gap:16px;margin-bottom:8px}.ds-live-preview__camera{display:flex;flex-direction:column;gap:4px}.ds-live-preview__select{min-width:220px}.ds-header__access-menu,.ds-live-preview__access-menu,.ds-tabs__trailing{align-items:center;display:inline-flex;position:relative}.ds-dual-preview__stage{background:#080810;border-radius:8px;overflow:hidden}.ds-dual-preview__main,.ds-dual-preview__stage{min-height:min(68vh,620px);position:relative;width:100%}.ds-dual-preview__main{background:#000}.ds-dual-preview__video--main{display:block;max-height:82vh;min-height:min(68vh,620px);object-fit:contain;width:100%}.ds-dual-preview__pip{background:#050508;border:1px solid #ffffff24;border-radius:6px;box-shadow:0 8px 32px #0000008c;left:12px;min-width:160px;overflow:hidden;position:absolute;top:12px;width:min(38%,300px);z-index:3}.ds-dual-preview__pip-label{color:#ffffffeb;font-size:11px;font-weight:700;left:10px;letter-spacing:.06em}.ds-dual-preview__pip-label,.ds-dual-preview__pip-status{pointer-events:none;position:absolute;text-shadow:0 1px 6px #000000e6;top:8px;z-index:4}.ds-dual-preview__pip-status{color:#ffffffe0;font-size:10px;left:48px;line-height:1.3;overflow:hidden;right:8px;text-align:right;text-overflow:ellipsis;white-space:nowrap}.ds-dual-preview__video--pip{background:#000;display:block;height:auto;max-height:170px;min-height:88px;object-fit:cover;width:100%}.ds-dual-preview__main>.ds-dual-preview__empty{align-items:center;background:#111118;border-radius:0;color:#ffffff73;display:flex;font-size:13px;height:auto;justify-content:center;min-height:min(68vh,620px)}.ds-dual-preview__pip .ds-dual-preview__empty{align-items:center;background:#14141c;border-radius:0;color:#fff6;display:flex;font-size:12px;height:120px;justify-content:center;min-height:100px}.ds-dual-preview__hud-bottom{grid-gap:8px 16px;align-items:end;background:linear-gradient(180deg,#0000,#0000008c 40%,#000000d1);bottom:0;display:grid;gap:8px 16px;grid-template-columns:minmax(0,1fr) auto minmax(0,1.15fr);left:0;padding:10px 14px 14px;pointer-events:none;position:absolute;right:0;z-index:4}.ds-dual-preview__hud-bottom .ds-dual-preview__d-btn,.ds-dual-preview__hud-bottom .ds-dual-preview__mini-btn,.ds-dual-preview__hud-bottom .ds-dual-preview__zoom-slider{pointer-events:auto}.ds-dual-preview__hud-bottom-left{justify-self:start;padding-bottom:2px}.ds-dual-preview__hud-compact{font-feature-settings:"tnum";color:#ffffffe0;font-size:12px;font-variant-numeric:tabular-nums;font-weight:600;text-shadow:0 1px 8px #000000d9}.ds-dual-preview__d-pad{grid-gap:4px;display:grid;gap:4px;grid-template-columns:8px 40px 8px;grid-template-rows:40px 40px 40px;justify-content:center;margin-bottom:2px;pointer-events:auto}.ds-dual-preview__d-pad-cell{min-width:8px;width:8px}.ds-dual-preview__d-btn{background:#14141cb8;border:1px solid #ffffff38;border-radius:10px;color:#ffffffd9;cursor:not-allowed;font-size:16px;height:40px;line-height:1;opacity:.65;padding:0;width:40px}.ds-dual-preview__hud-panel{background:#0000008c;border:1px solid #ffffff1a;border-radius:8px;justify-self:end;max-width:100%;padding:10px 12px;pointer-events:auto}.ds-dual-preview__hud-readout{font-feature-settings:"tnum";color:#ffffffeb;font-size:12px;font-variant-numeric:tabular-nums;margin:0 0 8px;white-space:nowrap}.ds-dual-preview__hud-readout--muted{color:#ffffff80}.ds-dual-preview__zoom-slider{cursor:not-allowed;margin-bottom:8px;max-width:220px;min-width:140px;opacity:.55;width:100%}.ds-dual-preview__hud-zoom-btns{display:flex;flex-wrap:wrap;gap:6px}.ds-dual-preview__mini-btn{background:#23232de6;border:1px solid #ffffff2e;border-radius:4px;color:#ffffffbf;cursor:not-allowed;font-size:11px;opacity:.6;padding:5px 10px}@media (max-width:720px){.ds-dual-preview__hud-bottom{grid-template-columns:1fr;justify-items:center;text-align:center}.ds-dual-preview__hud-bottom-left{justify-self:center}.ds-dual-preview__hud-panel{justify-self:stretch;width:100%}.ds-dual-preview__hud-readout{white-space:normal}}.ds-live-preview{box-sizing:border-box;max-width:100%;width:100%}.ds-live-preview__header{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.ds-live-preview__title{flex:1 1 auto;min-width:0}.ds-live-preview__camera{align-items:center;display:inline-flex;flex-direction:row;flex-wrap:nowrap;gap:8px;min-width:0}.ds-live-preview__camera-label{white-space:nowrap}.ds-live-preview__select{flex:0 1 auto;max-width:100%;min-width:160px}.ds-live-preview__controls-cluster{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;margin-left:auto}.ds-live-preview__controls{align-items:center;display:flex;margin-left:0}.ds-live-preview__access-menu{align-items:center;display:flex;flex-shrink:0;position:relative}@media (max-width:520px){.ds-live-preview__controls-cluster{justify-content:flex-start;margin-left:0;width:100%}}@media (max-width:380px){.ds-live-preview__camera,.ds-live-preview__header{align-items:stretch;flex-direction:column}.ds-live-preview__select{min-width:0;width:100%}}.ds-pano360-root{inset:0;overflow:hidden;position:absolute}.ds-pano360-canvas{display:block;height:100%;width:100%}.ds-pano360-video-src{height:1px;opacity:0;pointer-events:none;position:absolute;width:1px}.ds-preview-root{background:#fff;border:1px solid #0000001f;display:flex;flex-direction:column;gap:12px;min-height:0;padding:12px}.ds-preview-root,.ds-preview-stage{border-radius:8px;box-sizing:border-box;max-width:100%;position:relative;width:100%}.ds-preview-stage{background:#0b1220;margin-inline:auto;overflow:hidden}.ds-preview-stage--standard{aspect-ratio:16/9;max-height:min(72vh,820px)}.ds-preview-stage--panorama{aspect-ratio:2/1;max-height:min(78vh,900px)}@media (max-width:640px){.ds-preview-stage--panorama{aspect-ratio:16/9;max-height:min(56vh,520px)}.ds-preview-stage--standard{max-height:min(58vh,480px)}}@media (max-height:520px){.ds-preview-stage--panorama,.ds-preview-stage--standard{max-height:min(65vh,360px)}}.ds-preview-root:-webkit-full-screen .ds-preview-stage--standard,.ds-preview-root:fullscreen .ds-preview-stage--standard{aspect-ratio:16/9;border-radius:0;flex:0 1 auto;height:auto;margin-inline:auto;max-height:none!important;max-width:100%;min-height:0;width:min(100dvw,calc(100dvh*16/9))}.ds-preview-main{inset:0;overflow:hidden;position:absolute}.ds-preview-main--immersive{perspective:900px}.ds-preview-flat-surface{inset:0;position:absolute}.ds-preview-flat-surface__media{inset:0;position:absolute;z-index:1}.ds-preview-stream-wrap{background:#0b1220;inset:0;overflow:hidden;position:absolute}.ds-preview-activity-bar{height:3px;left:0;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;z-index:8}.ds-preview-activity-bar__track{background:#ffffff24;height:100%}.ds-preview-activity-bar__fill{animation:ds-preview-activity-shift 1.15s cubic-bezier(.4,0,.2,1) infinite;background:linear-gradient(90deg,#2932e5,#6d74f5,#2932e5);border-radius:0 2px 2px 0;height:100%;width:42%;will-change:transform}@keyframes ds-preview-activity-shift{0%{transform:translateX(-120%)}to{transform:translateX(320%)}}@media (prefers-reduced-motion:reduce){.ds-preview-activity-bar__fill{animation:none;opacity:.45;transform:none;width:100%}}.ds-preview-buffer{align-items:center;background:#0b122073;color:#f9fafb;display:flex;font-size:14px;inset:0;justify-content:center;pointer-events:none;position:absolute;z-index:2}.ds-preview-buffer__label{font-weight:500;letter-spacing:.01em}.ds-preview-buffer--light{background:#0b122052;font-size:13px}.ds-preview-buffer--bootstrap{background:radial-gradient(circle at 50% 40%,#2932e51f,#0b12208c)}.ds-preview-stream-fallback{align-items:center;background:#0b1220;color:#e5e7eb;display:flex;flex-direction:column;font-size:14px;gap:10px;inset:0;justify-content:center;padding:16px;pointer-events:auto;position:absolute;text-align:center;z-index:1}.ds-preview-focus-ring{border:3px solid #fffffff2;border-radius:50%;box-shadow:0 0 0 2px #2932e5d9,inset 0 0 12px #2932e559;box-sizing:border-box;pointer-events:none;position:absolute;z-index:3}.ds-preview-focus-ring--immersive{z-index:4}.ds-ptz-loader{animation:ds-ptz-loader-fade .12s ease-out;background:radial-gradient(circle at center,#0b12202e 0,#0b122000 55%);inset:0;pointer-events:none;position:absolute;z-index:6}.ds-ptz-loader,.ds-ptz-loader__chip{align-items:center;display:flex;justify-content:center}.ds-ptz-loader__chip{animation:ds-ptz-loader-pop .18s cubic-bezier(.2,.8,.2,1);background:#0f172ab8;border-radius:50%;box-shadow:0 6px 20px #0006;height:64px;width:64px}.ds-ptz-loader__svg{display:block;height:56px;width:56px}.ds-ptz-loader__track{stroke:#ffffff2e}.ds-ptz-loader__indicator{stroke:#2932e5;filter:drop-shadow(0 0 4px rgba(41,50,229,.55))}@keyframes ds-ptz-loader-fade{0%{opacity:0}to{opacity:1}}@keyframes ds-ptz-loader-pop{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion:reduce){.ds-ptz-loader,.ds-ptz-loader__chip{animation:none}}.ds-preview-focus-zoom{background:#0b1220d1;border-radius:8px;bottom:clamp(6px,2vw,12px);box-sizing:border-box;color:#e5e7eb;left:50%;max-width:calc(100% - 16px);min-width:0;padding:8px 12px;position:absolute;transform:translateX(-50%);width:min(320px,calc(100% - 24px));z-index:10}.ds-preview-focus-zoom input[type=range]{width:100%}@media (max-width:480px){.ds-preview-focus-zoom{left:8px;right:8px;transform:none;width:auto}}.ds-preview-pip{background:#0b1220;border:1px solid #ffffff1f;border-radius:10px;box-shadow:0 8px 28px #00000073;box-sizing:border-box;display:flex;flex-direction:column;max-height:calc(100% - 12px)!important;max-width:calc(100% - 12px)!important;overflow:hidden;position:absolute;z-index:5}.ds-preview-pip__chrome{align-items:center;background:#0f172af2;color:#f9fafb;cursor:grab;display:flex;flex-wrap:wrap;font-size:12px;font-weight:600;gap:8px;justify-content:space-between;padding:6px 10px;-webkit-user-select:none;user-select:none}.ds-preview-pip__chrome:active{cursor:grabbing}.ds-preview-pip__metrics{color:#cbd5e1;font-size:11px;font-weight:500;line-height:1.3;max-width:100%;text-align:right;word-break:break-word}@media (max-width:480px){.ds-preview-pip__chrome{align-items:flex-start;flex-direction:column}.ds-preview-pip__metrics{font-size:10px;text-align:left;width:100%}}.ds-preview-pip__video{flex:1 1;min-height:0;position:relative}.ds-preview-pip-flat-surface{inset:0;min-height:0;position:absolute}.ds-preview-pip-flat-surface__media{inset:0;position:absolute;z-index:1}.ds-preview-pip__ptz{background:#0f172aeb;padding:6px 8px}.ds-ptz-zoom-panel{background:#0c0e12f5;border:1px solid #ffffff14;border-radius:10px;box-shadow:0 8px 22px #0000006b;box-sizing:border-box;display:flex;flex-direction:column;gap:12px;padding:12px 40px 20px;width:115%}.ds-ptz-zoom-panel--compact{border-radius:8px;gap:8px;padding:8px 10px 10px}.ds-ptz-zoom-panel__metrics{color:#f9fafb;font-size:12px;font-weight:500;letter-spacing:.01em;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ds-ptz-zoom-panel__slider{appearance:none;-webkit-appearance:none;background:#f9fafb;border-radius:999px;box-sizing:border-box;cursor:pointer;height:8px;margin:2px 0 4px;outline:none;width:100%}.ds-ptz-zoom-panel__slider:disabled{cursor:not-allowed;opacity:.45}.ds-ptz-zoom-panel__slider::-webkit-slider-runnable-track{background:#f9fafb;border-radius:999px;height:8px}.ds-ptz-zoom-panel__slider::-webkit-slider-thumb{-webkit-appearance:none;background:radial-gradient(circle at 50% 50%,#dc2626 30%,#fff 31%);border:none;border-radius:50%;box-shadow:0 0 0 2px #fff,0 2px 6px #00000059;cursor:pointer;height:18px;margin-top:-5px;width:18px}.ds-ptz-zoom-panel__slider::-moz-range-track{background:#f9fafb;border-radius:999px;height:8px}.ds-ptz-zoom-panel__slider::-moz-range-thumb{background:radial-gradient(circle at 50% 50%,#dc2626 30%,#fff 31%);border:none;border-radius:50%;box-shadow:0 0 0 2px #fff,0 2px 6px #00000059;cursor:pointer;height:18px;width:18px}.ds-ptz-zoom-panel__row{align-items:stretch;display:flex;flex-direction:row;gap:6px}.ds-ptz-zoom-panel__reset,.ds-ptz-zoom-panel__row .ds-ptz-btn{flex:1 1;min-width:0}.ds-ptz-zoom-panel .ds-ptz-btn.ds-ptz-zoom-panel__btn:not(.ds-ptz-btn--active):not(.ds-ptz-btn--full):not(.ds-ptz-btn--limit){background:#fff!important;border:none!important;border-radius:5px;box-shadow:none!important;color:#0b1220!important;font-size:12px;font-weight:600;min-height:34px}.ds-ptz-zoom-panel .ds-ptz-btn.ds-ptz-zoom-panel__btn.ds-ptz-btn--active{color:#fff!important}.ds-ptz-zoom-panel__reset{background:#fff;border:none;border-radius:5px;color:#0b1220;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;min-height:34px;padding:6px 4px}.ds-ptz-zoom-panel__reset:disabled{cursor:not-allowed;opacity:.45}.ds-preview-pip__ptz .ds-ptz-zoom-panel{max-width:100%}.ds-preview-pip__ptz .ds-ptz-zoom-panel__btn{font-size:11px;min-height:30px;padding-inline:4px}.ds-preview-pip__ptz .ds-ptz-zoom-panel__reset{font-size:11px;min-height:30px}.ds-preview-ptz-fs-overlay{inset:0;pointer-events:none;position:absolute;z-index:4}.ds-preview-ptz-fs-pan,.ds-preview-ptz-fs-zoom{pointer-events:auto}.ds-preview-ptz-fs-pan{align-items:center;bottom:clamp(10px,4vw,20px);display:flex;flex-direction:column;gap:6px;left:50%;max-width:calc(100% - 24px);position:absolute;transform:translateX(-50%)}.ds-preview-ptz-fs-pan-mid{display:flex;gap:10px}.ds-ptz-fab{background:#0f172ae0;border:1px solid #fff3;border-radius:10px;color:#f9fafb;cursor:pointer;font-size:clamp(15px,4vw,18px);height:clamp(38px,10vw,44px);width:clamp(38px,10vw,44px)}.ds-ptz-fab:hover{background:#2932e58c}.ds-ptz-btn{align-items:center;display:inline-flex;gap:6px;isolation:isolate;justify-content:center;min-width:clamp(38px,10vw,44px);padding-inline:8px;position:relative;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease,transform 80ms ease;width:auto!important}.ds-ptz-btn--active{background:#2932e5!important;border-color:#2932e5!important;box-shadow:0 0 0 2px #2932e559,0 6px 18px #2932e573;color:#fff!important}.ds-ptz-btn--full,.ds-ptz-btn[aria-disabled=true]{cursor:not-allowed;filter:grayscale(.5);opacity:.55}.ds-ptz-btn--full{background:#b91c1c!important;border-color:#b91c1c!important;box-shadow:0 0 0 2px #b91c1c59!important}.ds-ptz-btn--limit{background:#0f172a99!important;border-color:#ffffff14!important;box-shadow:none!important;color:#ffffff73!important}.ds-ptz-btn[aria-disabled=true]:focus-visible,.ds-ptz-btn[aria-disabled=true]:hover{transform:none}.ds-ptz-btn__label{font-size:inherit}.ds-ptz-btn__count,.ds-ptz-btn__label{align-items:center;display:inline-flex;justify-content:center;line-height:1}.ds-ptz-btn__count{animation:ds-ptz-count-pop .14s ease-out;background:#fffffff2;border-radius:999px;box-shadow:inset 0 0 0 1px #0000001f,0 2px 6px #00000040;color:#0b1220;font-size:13px;font-weight:800;height:22px;letter-spacing:.02em;min-width:22px;padding:0 7px;pointer-events:none}.ds-ptz-btn--full .ds-ptz-btn__count{background:#fff;color:#b91c1c}.ds-ptz-btn__progress{background:#ffffff38;border-radius:999px;bottom:3px;height:3px;left:4px;overflow:hidden;pointer-events:none;position:absolute;right:4px;z-index:1}.ds-ptz-btn__progress-bar{animation:ds-ptz-btn-progress 1.05s linear infinite;background:#fff;border-radius:inherit;display:block;height:100%;width:40%}@keyframes ds-ptz-count-pop{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}@keyframes ds-ptz-btn-progress{0%{transform:translateX(-110%)}to{transform:translateX(260%)}}@media (prefers-reduced-motion:reduce){.ds-ptz-btn__count,.ds-ptz-btn__progress-bar{animation:none}.ds-ptz-btn__progress-bar{opacity:.7;transform:none;width:100%}}.ds-preview-ptz-fs-zoom{align-items:stretch;bottom:clamp(10px,4vw,20px);display:flex;flex-direction:column;max-width:min(280px,calc(100% - 100px));position:absolute;right:clamp(8px,4vw,80px)}@media (max-width:520px){.ds-preview-ptz-fs-zoom{bottom:10px;max-width:calc(100% - 24px);right:8px}.ds-ptz-zoom-panel__metrics{font-size:11px}}.ds-preview-toast{word-wrap:break-word;background:#111827f2;border-radius:8px;bottom:max(16px,env(safe-area-inset-bottom,0px));box-shadow:0 6px 20px #00000059;box-sizing:border-box;color:#fef3c7;font-size:clamp(12px,3.5vw,14px);left:50%;max-width:min(520px,calc(100vw - 32px));padding:10px 16px;position:fixed;text-align:center;transform:translateX(-50%);width:-webkit-max-content;width:max-content;z-index:80}@media (max-width:480px){.ds-preview-toast{left:16px;right:16px;transform:none;width:auto}}.ds-preview-popover{display:inline-flex;position:relative}.ds-preview-popover__panel{background:#fff;box-shadow:0 12px 32px #0f172a2e;left:auto;max-width:min(360px,calc(100vw - 32px));min-width:280px;position:absolute;right:0;top:calc(100% + 8px);z-index:20}.ds-preview-popover__panel:before{background:#fff;border-left:1px solid #0000001f;border-top:1px solid #0000001f;content:"";height:12px;position:absolute;right:14px;top:-6px;transform:rotate(45deg);width:12px}.ds-preview-controls{align-items:center;display:inline-flex;flex-wrap:wrap;gap:6px}.ds-preview-controls .ds-btn--icon{align-items:center;display:inline-flex;flex:0 0 auto;height:36px;justify-content:center;line-height:1;min-width:36px;padding:0;width:36px}.ds-preview-controls .ds-btn--icon svg{display:block;height:18px;width:18px}.ds-preview-settings{border:1px solid #0000001f;border-radius:8px;box-sizing:border-box;display:flex;flex-direction:column;gap:10px;max-width:min(420px,100%);padding:12px;width:100%}.ds-preview-settings__row label{display:flex;flex-direction:column;font-size:13px;gap:6px}:root{--rpv-core__annotation--link-hover-background-color:#ff03;--rpv-core__annotation-popup-wrapper-background-color:#faf089;--rpv-core__annotation-popup-wrapper-box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--rpv-core__annotation-popup-content-border-top-color:#1a202c;--rpv-core__arrow-border-color:#0000004d;--rpv-core__asking-password-color:#000;--rpv-core__asking-password-wrapper-background-color:#fff;--rpv-core__asking-password-wrapper-border-color:#0000004d;--rpv-core__button-background-color:#0000004d;--rpv-core__button-color:#000;--rpv-core__doc-error-background-color:#fff;--rpv-core__doc-error-text-background-color:#c02424;--rpv-core__doc-error-text-color:#fff;--rpv-core__doc-loading-background-color:#fff;--rpv-core__full-screen-target-background-color:#fff;--rpv-core__inner-page-background-color:#fff;--rpv-core__menu-divider-border-bottom-color:#0000004d;--rpv-core__menu-item-color:#000;--rpv-core__menu-item--hover-background-color:#0000001a;--rpv-core__menu-item--disabled-color:#0000004d;--rpv-core__minimal-button-color:#000;--rpv-core__minimal-button--hover-background-color:#0000001a;--rpv-core__minimal-button--disabled-color:#0000004d;--rpv-core__minimal-button--selected-background-color:#0000001a;--rpv-core__modal-body-background-color:#fff;--rpv-core__modal-body-border-color:#0000004d;--rpv-core__modal-overlay-background-color:#00000080;--rpv-core__page-layer-box-shadow:2px 2px 8px 0 #0003;--rpv-core__popover-body-background-color:#fff;--rpv-core__popover-body-border-color:#0000004d;--rpv-core__popover-body-color:#000;--rpv-core__primary-button-background-color:#2566e8;--rpv-core__primary-button-color:#fff;--rpv-core__progress-bar-background-color:#0000001a;--rpv-core__progress-bar-progress-background-color:#2566e8;--rpv-core__progress-bar-progress-color:#fff;--rpv-core__separator-border-bottom-color:#0000004d;--rpv-core__spinner-border-color:#0006;--rpv-core__spinner-border-transparent-color:#0000;--rpv-core__splitter-background-color:#0000;--rpv-core__splitter--hover-background-color:#0003;--rpv-core__text-layer-text--selection-background-color:#00f;--rpv-core__text-layer-text--selection-color:#0000;--rpv-core__textbox-background-color:#fff;--rpv-core__textbox-border-color:#0003;--rpv-core__textbox-color:#000;--rpv-core__tooltip-body-background-color:#000;--rpv-core__tooltip-body-color:#fff}.rpv-core__viewer--dark{--rpv-core__asking-password-background-color:#363636;--rpv-core__asking-password-color:#fff;--rpv-core__asking-password-wrapper-border-color:#191919;--rpv-core__asking-password-wrapper-background-color:#191919;--rpv-core__button-background-color:#171717;--rpv-core__button-color:#fff;--rpv-core__doc-error-background-color:#191919;--rpv-core__doc-error-text-background-color:#c02323;--rpv-core__doc-error-text-color:#fff;--rpv-core__doc-loading-background-color:#191919;--rpv-core__full-screen-target-background-color:#1a1a1a;--rpv-core__inner-page-background-color:#1a1a1a;--rpv-core__menu-divider-border-bottom-color:#000;--rpv-core__menu-item-color:#fff;--rpv-core__menu-item--hover-background-color:#2566e8;--rpv-core__menu-item--disabled-color:#5e5e5e;--rpv-core__minimal-button-color:#fff;--rpv-core__minimal-button--disabled-color:#5e5e5e;--rpv-core__minimal-button--hover-background-color:#191919;--rpv-core__minimal-button--selected-background-color:#1657bb;--rpv-core__modal-body-background-color:#363636;--rpv-core__primary-button-background-color:#2566e8;--rpv-core__popover-body-background-color:#363636;--rpv-core__popover-body-color:#fff;--rpv-core__progress-bar-background-color:#000;--rpv-core__separator-border-bottom-color:#000;--rpv-core__spinner-border-color:#fff;--rpv-core__splitter-background-color:#1a1a1a;--rpv-core__splitter--hover-background-color:#2566e8;--rpv-core__textbox-background-color:#121212;--rpv-core__textbox-border-color:#121212;--rpv-core__textbox-color:#fff;--rpv-core__tooltip-body-background-color:#414141;--rpv-core__tooltip-body-color:#fff}.rpv-core__annotation{position:absolute}.rpv-core__annotation-layer{z-index:1}.rpv-core__arrow{border-bottom:1px solid #0000004d;border-bottom:1px solid var(--rpv-core__arrow-border-color);border-left-color:#0000004d;border-left-color:var(--rpv-core__arrow-border-color);border-right:1px solid #0000004d;border-right:1px solid var(--rpv-core__arrow-border-color);border-top-color:#0000004d;border-top-color:var(--rpv-core__arrow-border-color);height:10px;position:absolute;width:10px;z-index:0}.rpv-core__arrow--tl{bottom:0;left:0;transform:translate(50%,50%) rotate(45deg)}.rpv-core__arrow--tc{left:50%}.rpv-core__arrow--tc,.rpv-core__arrow--tr{bottom:0;transform:translate(-50%,50%) rotate(45deg)}.rpv-core__arrow--tr{right:0}.rpv-core__arrow--rt{left:0;top:0;transform:translate(-50%,50%) rotate(135deg)}.rpv-core__arrow--rc{top:50%}.rpv-core__arrow--rb,.rpv-core__arrow--rc{left:0;transform:translate(-50%,-50%) rotate(135deg)}.rpv-core__arrow--rb{bottom:0}.rpv-core__arrow--bl{left:0;top:0;transform:translate(50%,-50%) rotate(225deg)}.rpv-core__arrow--bc{left:50%}.rpv-core__arrow--bc,.rpv-core__arrow--br{top:0;transform:translate(-50%,-50%) rotate(225deg)}.rpv-core__arrow--br{right:0}.rpv-core__arrow--lt{right:0;top:0;transform:translate(50%,50%) rotate(315deg)}.rpv-core__arrow--lc{top:50%}.rpv-core__arrow--lb,.rpv-core__arrow--lc{right:0;transform:translate(50%,-50%) rotate(315deg)}.rpv-core__arrow--lb{bottom:0}.rpv-core__asking-password{background-color:var(--rpv-core__asking-password-background-color);border-radius:.25rem;color:#000;color:var(--rpv-core__asking-password-color);padding:2rem}.rpv-core__asking-password--rtl{direction:rtl}.rpv-core__asking-password-wrapper{align-items:center;background-color:#fff;background-color:var(--rpv-core__asking-password-wrapper-background-color);border:1px solid #0000004d;border:1px solid var(--rpv-core__asking-password-wrapper-border-color);display:flex;height:100%;justify-content:center;width:100%}.rpv-core__asking-password-message{margin:.5rem 0}.rpv-core__asking-password-body{align-items:center;display:flex;justify-content:center}.rpv-core__asking-password-input{width:15rem}.rpv-core__asking-password-input--ltr{margin-right:.5rem}.rpv-core__asking-password-input--rtl{margin-left:.5rem}.rpv-core__button{background-color:#0000004d;background-color:var(--rpv-core__button-background-color);border:none;border-radius:.25rem;color:#000;color:var(--rpv-core__button-color);cursor:pointer;height:2rem;padding:0 1rem}.rpv-core__button--rtl{direction:rtl}.rpv-core__canvas-layer{direction:ltr;left:0;overflow:hidden;position:absolute;top:0}.rpv-core__doc-error{align-items:center;background-color:#fff;background-color:var(--rpv-core__doc-error-background-color);display:flex;height:100%;justify-content:center}.rpv-core__doc-error--rtl{direction:rtl}.rpv-core__doc-error-text{background-color:#c02424;background-color:var(--rpv-core__doc-error-text-background-color);border-radius:.25rem;color:#fff;color:var(--rpv-core__doc-error-text-color);line-height:1.5;max-width:50%;padding:.5rem}.rpv-core__doc-loading{align-items:center;background-color:#fff;background-color:var(--rpv-core__doc-loading-background-color);display:flex;height:100%;justify-content:center;min-height:inherit;width:100%}.rpv-core__doc-loading--rtl{direction:rtl}.rpv-core__icon{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1;text-align:center}.rpv-core__icon--rtl{transform:scaleX(-1)}.rpv-core__inner-container{min-height:inherit}.rpv-core__inner-pages{overflow:auto}.rpv-core__inner-pages--rtl{direction:rtl}.rpv-core__inner-pages--single{overflow:hidden}.rpv-core__inner-page-container--single{overflow:auto}.rpv-core__inner-page{background-color:#fff;background-color:var(--rpv-core__inner-page-background-color)}.rpv-core__inner-page--single{align-items:center;display:flex;justify-content:center}.rpv-core__inner-page--dual-even{align-items:center;display:flex;justify-content:flex-end}.rpv-core__inner-page--dual-odd{align-items:center;display:flex;justify-content:flex-start}.rpv-core__inner-page--dual-cover{align-items:center;display:flex;justify-content:center}.rpv-core__inner-page--dual-cover-odd{align-items:center;display:flex;justify-content:flex-end}.rpv-core__inner-page--dual-cover-even{align-items:center;display:flex;justify-content:flex-start}.rpv-core__annotation--link a{height:100%;left:0;position:absolute;top:0;width:100%}.rpv-core__annotation--link a:hover{background-color:#ff03;background-color:var(--rpv-core__annotation--link-hover-background-color)}.rpv-core__menu{display:flex;flex-direction:column}.rpv-core__menu--rtl{direction:rtl;text-align:right}.rpv-core__menu-divider{border-bottom:1px solid #0000004d;border-bottom:1px solid var(--rpv-core__menu-divider-border-bottom-color);margin:.25rem 0}.rpv-core__menu-item{align-items:center;background-color:#0000;border:none;color:#000;color:var(--rpv-core__menu-item-color);cursor:pointer;display:flex;justify-content:center;padding:.25rem 0;width:100%}.rpv-core__menu-item:focus{outline:0}.rpv-core__menu-item:focus,.rpv-core__menu-item:hover{background-color:#0000001a;background-color:var(--rpv-core__menu-item--hover-background-color)}.rpv-core__menu-item-icon{align-items:center;display:flex}.rpv-core__menu-item-icon--ltr{padding-left:1rem;padding-right:.5rem}.rpv-core__menu-item-icon--rtl{padding-left:.5rem;padding-right:1rem}.rpv-core__menu-item-label{flex-grow:1;flex-shrink:1;white-space:nowrap}.rpv-core__menu-item-label--ltr{padding-right:2rem}.rpv-core__menu-item-label--rtl{padding-left:2rem}.rpv-core__menu-item-check--ltr{padding-right:1rem}.rpv-core__menu-item-check--rtl{padding-left:1rem}.rpv-core__menu-item--disabled{color:#0000004d;color:var(--rpv-core__menu-item--disabled-color)}.rpv-core__menu-item--disabled:hover{background-color:#0000}.rpv-core__menu-item--ltr{text-align:left}.rpv-core__menu-item--rtl{direction:rtl;text-align:right}.rpv-core__minimal-button{background-color:#0000;border:none;border-radius:.25rem;color:#000;color:var(--rpv-core__minimal-button-color);cursor:pointer;height:2rem;padding:0 .5rem}.rpv-core__minimal-button:hover{background-color:#0000001a;background-color:var(--rpv-core__minimal-button--hover-background-color)}.rpv-core__minimal-button--disabled{color:#0000004d;color:var(--rpv-core__minimal-button--disabled-color)}.rpv-core__minimal-button--rtl{direction:rtl}.rpv-core__minimal-button--selected{background-color:#0000001a;background-color:var(--rpv-core__minimal-button--selected-background-color)}.rpv-core__modal-body{background-color:#fff;background-color:var(--rpv-core__modal-body-background-color);border:1px solid #0000004d;border:1px solid var(--rpv-core__modal-body-border-color);border-radius:.25rem;margin:1rem;max-width:32rem;overflow:auto}.rpv-core__modal-body--rtl{direction:rtl}.rpv-core__modal-overlay{background-color:#00000080;background-color:var(--rpv-core__modal-overlay-background-color);bottom:0;left:0;position:fixed;right:0;top:0;z-index:9999}.rpv-core__modal-overlay,.rpv-core__page-layer{align-items:center;display:flex;justify-content:center}.rpv-core__page-layer{overflow:visible;position:relative}.rpv-core__page-layer:after{bottom:.25rem;box-shadow:2px 2px 8px 0 #0003;box-shadow:var(--rpv-core__page-layer-box-shadow);content:"";left:.25rem;position:absolute;right:.25rem;top:.25rem}.rpv-core__page-layer--single{margin:0 auto}.rpv-core__page-size-calculator{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.rpv-core__popover-body{border:1px solid #0000004d;border:1px solid var(--rpv-core__popover-body-border-color);border-radius:.25rem;color:#000;color:var(--rpv-core__popover-body-color);left:0;padding:.5rem 0;position:absolute;top:-9999px;z-index:9999}.rpv-core__popover-body,.rpv-core__popover-body-arrow{background-color:#fff;background-color:var(--rpv-core__popover-body-background-color)}.rpv-core__popover-body--rtl{direction:rtl}.rpv-core__popover-overlay{bottom:0;left:0;position:fixed;right:0;top:0}.rpv-core__annotation-popup-wrapper{background-color:#faf089;background-color:var(--rpv-core__annotation-popup-wrapper-background-color);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--rpv-core__annotation-popup-wrapper-box-shadow);font-size:.75rem;padding:.25rem;word-break:break-word}.rpv-core__annotation-popup-wrapper--rtl{direction:rtl}.rpv-core__annotation-popup-title{font-weight:600;margin-bottom:.25rem}.rpv-core__annotation-popup-date{font-size:.5rem}.rpv-core__annotation-popup-content{border-top:1px solid #1a202c;border-top:1px solid var(--rpv-core__annotation-popup-content-border-top-color);max-height:16rem;overflow:auto;padding:.25rem}.rpv-core__primary-button{background-color:#2566e8;background-color:var(--rpv-core__primary-button-background-color);border:none;border-radius:.25rem;color:#fff;color:var(--rpv-core__primary-button-color);cursor:pointer;height:2rem;padding:0 1rem}.rpv-core__primary-button--rtl{direction:rtl}.rpv-core__progress-bar{background-color:#0000001a;background-color:var(--rpv-core__progress-bar-background-color);border-radius:9999px;padding:.125rem}.rpv-core__progress-bar--rtl{direction:rtl}.rpv-core__progress-bar-progress{align-items:center;background-color:#2566e8;background-color:var(--rpv-core__progress-bar-progress-background-color);border-radius:9999px;color:#fff;color:var(--rpv-core__progress-bar-progress-color);display:flex;font-size:.75rem;height:.75rem;justify-content:center}.rpv-core__separator{border-bottom:1px solid #0000004d;border-bottom:1px solid var(--rpv-core__separator-border-bottom-color)}.rpv-core__spinner{border-bottom:2px solid #0000;border-bottom:2px solid var(--rpv-core__spinner-border-transparent-color);border-left:2px solid #0000;border-left:2px solid var(--rpv-core__spinner-border-transparent-color);border-radius:9999px;border-right:2px solid #0006;border-right:2px solid var(--rpv-core__spinner-border-color);border-top:2px solid #0006;border-top:2px solid var(--rpv-core__spinner-border-color)}.rpv-core__spinner--animating{animation-duration:.4s;animation-iteration-count:infinite;animation-name:rpv-core__spinner-transform;animation-timing-function:linear}@keyframes rpv-core__spinner-transform{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.rpv-core__splitter{background-color:initial;background-color:var(--rpv-core__splitter-background-color);cursor:ew-resize;height:100%;width:.25rem}.rpv-core__splitter--resizing,.rpv-core__splitter:hover{background-color:#0003;background-color:var(--rpv-core__splitter--hover-background-color);cursor:col-resize}.rpv-core__splitter-body--resizing{cursor:col-resize}.rpv-core__splitter-sibling--resizing{pointer-events:none;-webkit-user-select:none;user-select:none}.rpv-core__textbox{background-color:#fff;background-color:var(--rpv-core__textbox-background-color);border:1px solid #0003;border:1px solid var(--rpv-core__textbox-border-color);border-radius:.25rem;box-sizing:border-box;color:#000;color:var(--rpv-core__textbox-color);height:2rem;padding:0 .5rem;width:100%}.rpv-core__textbox--rtl{direction:rtl}.rpv-core__text-layer{height:100%;left:0;line-height:1;opacity:.2;position:absolute;top:0;width:100%;z-index:1}.rpv-core__text-layer span::selection{background-color:#00f;background-color:var(--rpv-core__text-layer-text--selection-background-color);color:#0000;color:var(--rpv-core__text-layer-text--selection-color)}.rpv-core__text-layer br::selection{color:#0000}.rpv-core__text-layer-text{color:#0000;cursor:text;position:absolute;transform-origin:0 0;white-space:pre}.rpv-core__tooltip-body{background-color:#000;background-color:var(--rpv-core__tooltip-body-background-color);border-radius:.25rem;color:#fff;color:var(--rpv-core__tooltip-body-color);left:0;max-width:20rem;position:absolute;text-align:center;top:-9999px;z-index:9999}.rpv-core__tooltip-body--rtl{direction:rtl}.rpv-core__tooltip-body-arrow{background-color:#000;background-color:var(--rpv-core__tooltip-body-background-color)}.rpv-core__tooltip-body-content{padding:.5rem}.rpv-core__display--block{display:block}.rpv-core__display--hidden{display:none}@media(min-width:640px){.rpv-core__display--hidden-small{display:none}.rpv-core__display--block-small{display:block}}@media(min-width:768px){.rpv-core__display--hidden-medium{display:none}.rpv-core__display--block-medium{display:block}}@media(min-width:1024px){.rpv-core__display--hidden-large{display:none}.rpv-core__display--block-large{display:block}}.rpv-core__viewer{min-height:inherit}:root{--rpv-drop__area-background-color:#fff;--rpv-drop__area-body-border-color:#0000004d;--rpv-drop__area-body-color:#000}.rpv-core__viewer--dark{--rpv-drop__area-background-color:#191919;--rpv-drop__area-body-border-color:#fff;--rpv-drop__area-body-color:#fff}.rpv-drop__area{background-color:#fff;background-color:var(--rpv-drop__area-background-color);bottom:0;left:0;padding:.5rem;position:absolute;right:0;top:0;z-index:9999}.rpv-drop__area-body{align-items:center;border:2px dashed #0000004d;border:2px dashed var(--rpv-drop__area-body-border-color);color:#000;color:var(--rpv-drop__area-body-color);display:flex;font-size:1.5rem;height:100%;justify-content:center}.rpv-drop__area-body--rtl{direction:rtl}:root{--rpv-full-screen__overlay-background-color:#fff}.rpv-core__viewer--dark{--rpv-full-screen__overlay-background-color:#1a1a1a}.rpv-full-screen__exit-button{bottom:0;padding:.5rem;position:fixed;z-index:2}.rpv-full-screen__exit-button--ltr{right:0}.rpv-full-screen__exit-button--rtl{left:0}.rpv-full-screen__overlay{align-items:center;background-color:#fff;background-color:var(--rpv-full-screen__overlay-background-color);display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1}.rpv-open__input-wrapper{position:relative}.rpv-open__input{bottom:0;cursor:pointer;display:none;height:100%;left:0;opacity:0;position:absolute;right:0;top:0;width:100%}.rpv-open__input::-webkit-file-upload-button{width:0}.rpv-page-navigation__current-page-input{margin:0 .25rem;text-align:right;width:3rem}:root{--rpv-print__progress-body-background-color:#fff;--rpv-print__progress-body-border-color:#0000004d;--rpv-print__progress-body-color:#000}.rpv-core__viewer--dark{--rpv-print__progress-body-background-color:#363636;--rpv-print__progress-body-border-color:#0000;--rpv-print__progress-body-color:#fff}.rpv-print__permission-body{padding:1rem}.rpv-print__permission-footer{display:flex;justify-content:center;padding:0 1rem 1rem 0}.rpv-print__progress{align-items:center;display:flex;height:100%;justify-content:center;left:0;position:absolute;top:0;width:100%;z-index:9999}.rpv-print__progress-body{background-color:#fff;background-color:var(--rpv-print__progress-body-background-color);border:1px solid #0000004d;border:1px solid var(--rpv-print__progress-body-border-color);border-radius:.25rem;color:#000;color:var(--rpv-print__progress-body-color);padding:1.5rem;text-align:center;width:15rem}.rpv-print__progress-body--rtl{direction:rtl}.rpv-print__progress-bar{margin-bottom:1rem}.rpv-print__progress-message{margin-bottom:.5rem}.rpv-print__zone{display:none}@media print{@page{margin:0}.rpv-print__html-printing{height:100%}.rpv-print__body-printing{height:100%;margin:0}.rpv-print__body-printing *{display:none}.rpv-print__zone{display:block;height:100%}.rpv-print__page{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;page-break-after:always;page-break-inside:avoid;width:100%}.rpv-print__page img{display:block;max-height:100%;max-width:100%}}.rpv-properties__loader{text-align:center}.rpv-properties__modal{min-height:20rem;padding:.5rem 0}.rpv-properties__modal-section{padding:0 .5rem}.rpv-properties__modal-footer{display:flex;justify-content:center;margin-top:.5rem}.rpv-properties__item{align-items:flex-start;display:flex;margin:.5rem 0}.rpv-properties__item--rtl{direction:rtl}.rpv-properties__item-label{padding-right:.5rem;width:25%}.rpv-properties__item-value{flex:1 1}.rpv-search__highlights{height:100%;left:0;position:absolute;top:0;width:100%}.rpv-search__highlight{background-color:#ff06;background-color:var(--rpv-search__highlight-background-color);border-radius:.25rem;position:absolute;z-index:1}.rpv-search__highlight--current{background-color:#00800066;background-color:var(--rpv-search__highlight--current-background-color)}.rpv-search__popover{padding:0 .5rem}.rpv-search__popover-input-counter{align-items:center;display:flex;margin-bottom:.5rem;position:relative;width:12rem}.rpv-search__popover-counter{align-items:center;bottom:0;display:flex;position:absolute;top:0}.rpv-search__popover-counter--ltr{padding-right:.25rem;right:0}.rpv-search__popover-counter--rtl{left:0;padding-left:.25rem}.rpv-search__popover-label{align-items:center;cursor:pointer;display:flex;margin-bottom:.5rem}.rpv-search__popover-label-checkbox{cursor:pointer;margin-right:.25rem}.rpv-search__popover-footer{align-items:center;display:flex}.rpv-search__popover-footer-item{padding:0 .25rem}.rpv-search__popover-footer-button--ltr{margin-left:auto}.rpv-search__popover-footer-button--rtl{margin-right:auto}:root{--rpv-search__highlight-background-color:#ff06;--rpv-search__highlight--current-background-color:#00800066}.rpv-selection-mode__grab{cursor:grab}.rpv-selection-mode__grab :not(input),.rpv-selection-mode__grab :not(select),.rpv-selection-mode__grab :not(textarea){cursor:grab!important}.rpv-selection-mode__grabbing{cursor:grabbing}.rpv-selection-mode__grabbing :not(input),.rpv-selection-mode__grabbing :not(select),.rpv-selection-mode__grabbing :not(textarea){cursor:grabbing!important}:root{--rpv-zoom__popover-target-arrow-border-color:#0009}.rpv-core__viewer--dark{--rpv-zoom__popover-target-arrow-border-color:#fff}.rpv-zoom__popover-target{align-items:center;color:var(--rpv-zoom__popover-target-color);display:flex}.rpv-zoom__popover-target-scale--ltr{margin-right:.25rem}.rpv-zoom__popover-target-scale--rtl{margin-left:.25rem}.rpv-zoom__popover-target-arrow{border-color:#0009 #0000 #0000;border-color:var(--rpv-zoom__popover-target-arrow-border-color) #0000 #0000;border-style:solid;border-width:.5rem .25rem 0;height:0;width:0}:root{--rpv-toolbar__label--color:#000}.rpv-core__viewer--dark{--rpv-toolbar__label--color:#fff}.rpv-toolbar{align-items:center;display:flex;width:100%}.rpv-toolbar--rtl{direction:rtl}.rpv-toolbar__center,.rpv-toolbar__left{align-items:center;display:flex}.rpv-toolbar__center{flex-grow:1;flex-shrink:1;justify-content:center}.rpv-toolbar__right{align-items:center;display:flex;margin-left:auto}.rpv-toolbar__item{align-items:center;display:flex;padding:0 .125rem}.rpv-toolbar__label{color:#000;color:var(--rpv-toolbar__label--color)}.text-button-variant{border-radius:10px!important;box-shadow:none!important;color:#2932e5!important;cursor:pointer;font-family:Roboto,sans-serif!important;font-size:14px;font-weight:600!important;margin:0;outline:0;padding:5px 15px!important;text-decoration:none;&:hover{--variant-containedBg:#1c23a0!important;--variant-textBg:#2932e50a!important;--variant-outlinedBorder:#2932e5!important;--variant-outlinedBg:#2932e50a!important}&:disabled{--variant-containedBg:#9ca3af!important;--variant-textBg:#2932e50a!important;--variant-outlinedBorder:#9ca3af!important;--variant-outlinedBg:#2932e50a!important;color:#9ca3af!important;cursor:not-allowed}}.contained-button-variant{background-color:#2932e5!important;border-radius:10px!important;box-shadow:none!important;color:#fff!important;font-family:Roboto,sans-serif!important;font-size:14px;font-weight:600!important;padding:5px 15px!important;&:hover{background-color:#1f28b8!important}&:disabled,&:hover{box-shadow:none!important}&:disabled{background-color:#9ca3af!important}}:root{--ura-accent:#2932e5;--ura-accent-hover:#1f28b8;--ura-error:#c62828;--ura-muted:#f5f5f5;--ura-border:#e0e0e0;--ura-text:#212121;--ura-text-secondary:#616161;--ura-space-4:16px;--color-accent:var(--ura-accent);--color-error:var(--ura-error);--color-surface-muted:var(--ura-muted)}.ds-text-secondary{color:#616161;color:var(--ura-text-secondary)}.ds-body{color:#212121;color:var(--ura-text);font-size:14px}.ds-error-inline{color:#c62828;color:var(--ura-error);font-size:13px}.ds-stack{display:flex;flex-direction:column;gap:8px}.ds-stack--loose{gap:16px;gap:var(--ura-space-4)}.ds-field{display:flex;flex-direction:column;gap:6px}.ds-field__label{color:#616161;color:var(--ura-text-secondary);font-size:12px;font-weight:500}.ds-field__error{color:#c62828;color:var(--ura-error);font-size:12px}.ds-input,.ds-tp__search{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--ura-border);border-radius:6px;box-sizing:border-box;color:#212121;color:var(--ura-text);font:inherit;font-size:14px;padding:8px 12px}.ds-input:focus,.ds-tp__search:focus{border-color:#2932e5;border-color:var(--ura-accent);outline:2px solid #2932e540}.ds-btn{background:#e0e0e0;border:1px solid #0000;border-radius:6px;color:#212121;color:var(--ura-text);cursor:pointer;font:inherit;font-size:14px;font-weight:500;padding:8px 16px}.ds-btn:disabled{cursor:not-allowed;opacity:.55}.ds-btn--ghost{background:#0000;border-color:#e0e0e0;border-color:var(--ura-border)}.ds-btn--primary{background:#2932e5;background:var(--ura-accent);color:#fff}.ds-btn--primary:hover:not(:disabled){background:#1f28b8;background:var(--ura-accent-hover)}.ds-btn--danger{background:#c62828;background:var(--ura-error);color:#fff}.ds-pill{background:#eee;border-radius:999px;color:#616161;color:var(--ura-text-secondary);display:inline-block;font-size:12px;font-weight:500;padding:2px 10px}.ds-pill--accent{background:#2932e51f;color:#2932e5;color:var(--ura-accent)}.ds-card{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--ura-border);border-radius:8px;padding:16px;padding:var(--ura-space-4)}.ds-tp{display:flex;flex-direction:column;gap:12px;min-height:0}.ds-tp--fill{flex:1 1;min-height:360px}.ds-tp__toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-start}.ds-tp__title{flex:0 0 auto;font-size:20px;font-weight:600;margin:0;min-width:0}.ds-tp__search-wrap{flex:0 1 320px;max-width:320px;min-width:200px}.ds-tp__search{width:100%}.ds-tp__filter-btn{font:inherit;font-size:13px;padding:8px 12px}.ds-tp__filter-btn,.ds-tp__icon-btn{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--ura-border);border-radius:6px;cursor:pointer}.ds-tp__icon-btn{align-items:center;display:inline-flex;height:36px;justify-content:center;padding:0;width:36px}.ds-tp__icon-btn[aria-pressed=true]{background:#2932e514;border-color:#2932e5;border-color:var(--ura-accent)}.ds-tp__body{background:#fafafa;border:1px solid #e0e0e0;border:1px solid var(--ura-border);border-radius:8px;flex:1 1;min-height:0;overflow:auto}.ds-tp__footer{color:#616161;color:var(--ura-text-secondary);flex-wrap:wrap;font-size:13px;gap:10px;justify-content:space-between}.ds-tp__footer,.ds-tp__pager{align-items:center;display:flex}.ds-tp__pager{gap:8px}.ds-dt{background:#fff;border-collapse:collapse;font-size:14px;width:100%}.ds-dt td,.ds-dt th{border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--ura-border);padding:10px 12px;text-align:left;vertical-align:middle}.ds-dt th{background:#fafafa;font-weight:600;-webkit-user-select:none;user-select:none}.ds-dt__sortable{cursor:pointer}.ds-dt__sortable:hover{background:#f0f0f0}.ds-dt__th-inner{align-items:center;display:inline-flex;gap:6px}.ds-dt__row-menu{text-align:right;width:48px}.dashboard-layout{background-color:#fff;display:flex;min-height:100vh}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:240px;transition:margin-left .3s ease}.main-content.sidebar-collapsed{margin-left:60px}.content-area{background:#fafafa;flex:1 1}.header{align-content:center;background:#212121;border-radius:8px;height:80px;justify-content:space-between;margin:.5rem .5rem 0;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:50}.header,.header-left{align-items:center;display:flex}.header-left{gap:1rem}.mobile-menu-btn{background:none;border:none;border-radius:.375rem;color:#374151;cursor:pointer;display:none;font-size:1.25rem;padding:.5rem}.mobile-menu-btn:hover{background:#f3f4f6}.page-title{color:#2932e5}.header-title,.page-title{font-size:30px;font-weight:400;letter-spacing:0;line-height:45px;margin:0}.header-title{color:#fff}.page-subtitle{leading-trim:NONE;color:#4a5565;font-size:14px;font-style:Regular;font-weight:400;letter-spacing:0;line-height:21px}.logo-time{color:#2932e5}.current-page,.logo-machine{color:#1f2937}.header-actions,.header-right{align-items:center;display:flex}.header-actions{gap:1rem}.notification-btn{align-items:center;background:none;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:flex;font-size:1.25rem;justify-content:center;padding:.5rem;transition:background-color .2s ease}.notification-btn:hover{background:#ffffff1a;color:#fff}.user-menu{position:relative}.user-menu-btn{align-items:center;background:none;border:none;border-radius:.5rem;cursor:pointer;display:flex;gap:.75rem;padding:.5rem 1rem;transition:background-color .2s ease}.user-menu-btn:hover{background:#f3f4f6}.user-avatar{align-items:center;background:#2932e5;border:2px solid #e5e7eb;border-radius:50%;color:#fff;display:flex;font-size:.875rem;font-weight:600;height:40px;justify-content:center;width:40px}.user-name{color:#374151;font-size:.875rem;font-weight:500}.dropdown-arrow{color:#9ca3af;font-size:.75rem;transition:transform .2s ease}.user-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;margin-top:.5rem;min-width:200px;position:absolute;right:0;top:100%;z-index:100}.dropdown-header{padding:1rem}.dropdown-user-info{text-align:left}.dropdown-user-name{color:#1f2937;font-size:.875rem;font-weight:600}.dropdown-user-email{color:#6b7280;font-size:.75rem;margin-top:.25rem}.dropdown-divider{border-top:1px solid #e5e7eb}.dropdown-menu{padding:.5rem 0}.dropdown-item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:background-color .2s ease;width:100%}.dropdown-item:hover{background:#f3f4f6}.dropdown-overlay{bottom:0;right:0;z-index:10}.dropdown-overlay,.sidebar{left:0;position:fixed;top:0}.sidebar{background:#212121;border-radius:20px 20px 0 0;box-shadow:2px 0 10px #0000001a;color:#fff;display:flex;flex-direction:column;height:100vh;transition:width .3s ease;width:280px;z-index:1000}.sidebar.collapsed{width:80px}.sidebar-header{justify-content:center;min-height:80px}.logo,.sidebar-header{align-items:center;display:flex}.logo{gap:.75rem;height:48px;width:120px}.logo-icon{font-size:1.5rem;text-align:center;width:32px}.logo-text{color:#2932e5;font-size:1.5rem;font-weight:700;letter-spacing:-.025em}.sidebar-nav{flex:1 1;padding:1rem 0}.nav-list{list-style:none;margin:0;padding:0}.nav-link{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.75rem 1rem;text-align:left;text-decoration:none;transition:all .2s ease;width:100%}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{background:#ff855533;border-right:3.2px solid #ff8555;color:#fff;font-weight:500;position:relative}.nav-link.active:after{border-bottom:8px solid #0000;border-left:8px solid #2932e5;border-top:8px solid #0000;height:0;position:absolute;right:1.5rem;top:50%;transform:translateY(-50%);width:0}.nav-link.has-submenu{position:relative}.submenu-arrow{font-size:12px;margin-left:auto;transition:transform .2s ease}.submenu-arrow.expanded{transform:rotate(180deg)}.submenu{background-color:#f3f4f6;border-radius:8px;list-style:none;margin:8px 0 0;overflow:hidden;padding:0}.submenu-item{margin:0}.submenu-link{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;font-size:.8rem;gap:.5rem;padding:.5rem 1rem .5rem 3rem;text-align:left;text-decoration:none;transition:all .2s ease;width:100%}.submenu-link:hover{background-color:#e5e7eb;color:#374151;transform:translateX(4px)}.submenu-link.active{color:#2932e5;font-weight:500}.submenu-icon{font-size:14px}.submenu-label{white-space:nowrap}.nav-icon{color:#fff;flex-shrink:0;font-size:1.125rem;text-align:center;width:20px}.nav-icon svg{stroke:#fff;color:#fff}.nav-label{flex:1 1;overflow:hidden;white-space:nowrap}.sidebar-footer{border-top:1px solid #e5e7eb;padding:1rem 1.5rem}.footer{background-color:#fafafa;border-top:1px solid #f3f4f6;bottom:0;margin-top:auto;position:-webkit-sticky;position:sticky;z-index:100}.footer,.footer-content{align-items:center;display:flex;justify-content:space-between;padding:0 1rem;width:100%}.footer-left{flex:1 1;text-align:left}.footer-center{flex:1 1;text-align:center}.footer-right{flex:1 1;text-align:right}.ready-text{font-weight:500}.copyright-text,.ready-text{color:#6b7280;font-size:.875rem}.allcad-logo,.copyright-text,.ready-text{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.allcad-logo{align-items:center;display:inline-flex;font-size:1rem;font-weight:600}.logo-image{max-width:14rem;width:auto}.logo-text-fallback{align-items:center;display:inline-flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1rem;font-weight:600}.logo-a{color:#3b82f6;position:relative}.logo-a:before{border-bottom:4px solid #ef4444;border-left:3px solid #0000;border-right:3px solid #0000;content:"";height:0;left:-3px;position:absolute;top:-2px;width:0}.logo-ll{color:#10b981}.logo-cad{color:#1e40af}@media (max-width:768px){.main-content,.main-content.sidebar-collapsed{margin-left:0}.header{padding:0 1rem}.mobile-menu-btn{display:block}.page-title{font-size:1.25rem}.footer-content{flex-direction:column;gap:.5rem;text-align:center}.footer-center,.footer-left,.footer-right{flex:none;text-align:center}.copyright-text,.ready-text{font-size:.75rem}.allcad-logo{font-size:.875rem}.user-name{display:none}.sidebar{transform:translateX(-100%);transition:transform .3s ease}.sidebar.open{transform:translateX(0)}.sidebar.collapsed{transform:translateX(-100%);width:280px}}body{font-family:Roboto,sans-serif;font-size:14px;font-style:Regular;font-weight:400;line-height:1.5}.login-container{background:#fff;height:100vh;width:100vw}.login-container,.login-left-panel{display:flex;overflow:hidden;position:relative}.login-left-panel{align-items:center;color:#fff;height:100%;width:60%}.login-left-panel,.login-left-panel:before{background:url(/static/media/login-background.7fda610271c5e5e69e1d.png) 50%/cover no-repeat}.login-left-panel:before{content:"";inset:0;opacity:.8;position:absolute;z-index:-1}.login-branding{margin-left:3rem;max-width:550px}.logo-image{height:48px;object-fit:contain;position:relative;width:120px}.logo-footer{max-width:10rem;object-fit:contain;padding:.5rem}.login-copyright{color:#6b7280;font-size:1rem;margin-top:2rem;text-align:center}.brand-title{color:#f26a56;font-family:Inter,sans-serif;font-size:72px;font-weight:900;line-height:1.2;margin-bottom:8vh;text-align:start}.brand-subtitle{bottom:4rem;font-size:4rem;font-style:italic;font-weight:500;position:absolute}.brand-features{font-size:18px;line-height:1.8;margin-bottom:10vh}.feature-item{margin-bottom:6px;margin-left:16px}.feature-item-bullet{margin-right:8px}.brand-tagline{color:#f26a56;font-size:28px}.login-right-panel{align-items:center;background:#fff;display:flex;justify-content:center;width:40%}.login-form-container{text-align:left;width:360px}.form-title{color:#333;display:flex;font-family:Inter,sans-serif;font-size:28px;font-weight:700;justify-content:center;margin-bottom:8vh;text-align:start}.form-subtitle{margin-bottom:10px}.form-description{margin-bottom:20px}.title-orange{color:#f26a56}.login-form{display:flex;flex-direction:column;gap:20px;margin-top:1.5rem}.form-group input{border:1px solid #ccc;border-radius:6px;font-family:Inter,sans-serif;font-size:15px;padding:12px 14px;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#5055f5;outline:none}.form-group input.error{border-color:#ef4444}.form-group-checkbox{margin-top:-8px}.remember-me-label{align-items:center;color:#374151;cursor:pointer;display:inline-flex;font-size:14px;gap:8px}.remember-me-label input[type=checkbox]{cursor:pointer;width:auto}.error-message{color:#ef4444;font-size:12px;margin-top:4px}.otp-sent-message{animation:fadeIn .3s ease-in-out;background-color:#e6ffed;border:1px solid #a7f3d0;border-radius:8px;color:#057a55;font-size:.95rem;padding:10px 14px;text-align:center}.login-button{background-color:#5055f5;border:none;border-radius:6px;box-shadow:1px 10px 20px #00000024;color:#fff;cursor:pointer;font-weight:700;padding:14px;transition:all .3s ease}.login-button:hover:not(:disabled){background-color:#3d4af0;transform:translateY(-1px)}.login-button:disabled{cursor:not-allowed;opacity:.6}.error-alert{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#f87171;font-size:14px;padding:10px 15px;text-align:center}.login-footer{align-items:center;display:flex;font-size:14px;gap:8px;margin-top:20px}.forgot-text{color:#333;font-weight:400}.forgot-link{color:#333;font-weight:700;text-decoration:underline;transition:color .3s ease}.forgot-link:hover{color:#5055f5}.permissions-page,.roles-page,.users-page{margin:0 auto}.breadcrumbs{color:#6b7280;display:flex;flex-direction:column;font-size:.875rem;gap:1px;min-height:49px;min-width:322.85px;opacity:1;padding:1rem 1.5rem}.breadcrumb-item{color:#ff8555;font-size:20px;font-size:16px;line-height:24px}.breadcrumb-Desc,.breadcrumb-item{font-style:normal;font-weight:400;letter-spacing:0;overflow:visible;white-space:nowrap}.breadcrumb-Desc{color:#4a5565;font-family:Roboto,sans-serif;font-size:14px;line-height:21px;margin-top:-7px;min-height:21px;opacity:1;position:relative;top:.13px}.breadcrumb-item:hover{color:#374151}.breadcrumb-separator{color:#9ca3af}.page-header{align-items:center;background:#f2f2f2;border:1.07px solid #f3f4f6;border-radius:10px;box-shadow:0 1px 2px -1px #0000001a,0 1px 3px 0 #0000001a;display:flex;justify-content:space-between;margin-bottom:1rem;opacity:1;padding:10px;width:100%}.header-left h1.page-title{color:#1f2937;font-size:2rem;font-weight:700}.page-subtitle{color:#6b7280;font-size:1rem;margin:0}.header-right .btn{border:1.07px solid #d1d5dc;border-radius:8px;box-shadow:none!important;font-style:Medium;gap:.5rem;padding:.3rem 1rem}.btn-primary,.header-right .btn{align-items:center;cursor:pointer;display:flex;font-size:14px;font-weight:500;letter-spacing:0;line-height:20px;text-transform:none;transition:all .2s ease}.btn-primary{background:#fafafa;border:1.07px solid #d1d5dc;border-radius:10px;color:#404040;font-family:Roboto,sans-serif;font-style:normal;gap:5px;justify-content:center;min-width:95px;opacity:1;padding:.75rem!important}.btn-primary:hover{background-color:#2932e5}.btn-secondary{align-items:center;background-color:initial;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:14px;font-style:normal;font-weight:500;gap:5px;justify-content:center;letter-spacing:0;line-height:20px;padding:.75rem 1.5rem;text-transform:none;transition:all .2s ease}.btn-secondary:hover{background-color:#ffebee;border-color:#f26a56}.btn-filters{background-color:#fafafa;border:2px solid #d1d5dc;border-radius:8px;cursor:pointer;font-weight:500;gap:.5rem;max-width:-webkit-fit-content;max-width:fit-content;padding:.75rem;transition:all .2s ease;white-space:nowrap}.btn-filters,.page-filters{align-items:center;display:flex}.page-filters{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.search-filters-container{align-items:center;display:flex;gap:7rem;justify-content:flex-start}.search-container{max-width:400px;min-width:200px;position:relative}.search-input{background:#fff;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;padding:.75rem 1rem .75rem 2.5rem;width:25rem}.search-input:focus{border-color:#2932e5;box-shadow:0 0 0 3px #f45b491a;outline:none}.search-icon{color:#9ca3af;left:1rem;position:absolute;top:50%;transform:translateY(-50%)}.active-filters,.filter-actions{display:flex;gap:.5rem}.active-filters{flex-direction:column;margin-right:1rem}.filter-count{align-self:flex-start;background-color:#dbeafe;border-radius:12px;color:#1e40af;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.filter-tags{display:flex;flex-wrap:wrap;gap:.5rem}.filter-tag{background-color:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;color:#374151;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.filter-select{background:#fff;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;padding:.75rem}.permissions-table-container,.roles-table-container,.users-table-container{background:#f2f2f2;border-radius:12px;border-top:1.07px solid #f3f4f6;box-shadow:0 1px 2px -1px #0000001a,0 1px 3px 0 #0000001a;overflow:hidden}.roles-cards-container{width:100%}.roles-cards-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,365.47px);justify-content:start;padding:1rem 0}.role-card{background:#f2f2f2;border:1.07px solid #e5e7eb;border-radius:14px;box-shadow:0 1px 2px -1px #0000001a,0 1px 3px 0 #0000001a;display:flex;flex-direction:column;gap:.75rem;height:373.27px;justify-content:space-between;opacity:1;padding:1.5rem;transition:all .3s ease;width:365.47px}.role-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.role-card-top{justify-content:space-between;margin-bottom:.5rem}.role-card-top,.role-icon{align-items:center;display:flex}.role-icon{border-radius:10px;height:48px;justify-content:center;opacity:1;padding-right:0;width:48px}.role-shield-icon{height:32px;object-fit:contain;width:32px}.action-dropdown-btn-vertical{background:#0000;border:none;color:#6b7280;cursor:pointer;font-size:1.5rem;line-height:1;padding:.25rem .5rem;transition:color .2s ease}.action-dropdown-btn-vertical:hover{color:#374151}.role-card-name{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0 0 .35rem}.role-card-description{-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;color:#6b7280;display:-webkit-box;flex:1 1;font-size:.875rem;line-height:1.5;margin:0;max-height:4.5em;overflow:hidden;text-overflow:ellipsis}.role-card-field{display:flex;flex-direction:column;gap:.35rem}.permissions-container-full,.role-card-field .permissions-container{display:flex;flex-wrap:wrap;gap:.5rem}.permissions-container-full{align-content:flex-start;margin-top:auto;min-height:60px;padding-top:.5rem;width:100%}.role-card-label{color:#6b7280;font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.role-card-value{color:#4a5565;font-size:.875rem;line-height:1.5;margin:0}.role-users-header{align-items:center;display:flex;justify-content:space-between}.role-users-count{color:#4a5565;font-size:.875rem;font-weight:600}.role-progress-bar{background-color:#e5e7eb;border-radius:10px;height:8px;margin-top:.5rem;overflow:hidden;width:100%}.role-progress-fill{background:linear-gradient(90deg,#2932e5,#4f5bff);border-radius:10px;height:100%;transition:width .3s ease}@media (max-width:1600px){.roles-cards-grid{grid-template-columns:repeat(auto-fit,365.47px);justify-content:center}}@media (max-width:1200px){.roles-cards-grid{grid-template-columns:repeat(auto-fit,minmax(320px,365.47px));justify-content:center}.role-card{max-width:365.47px;width:100%}}@media (max-width:640px){.roles-cards-grid{grid-template-columns:1fr}.role-card{max-width:100%;width:100%}}.permissions-table,.roles-table,.users-table{border-collapse:collapse;width:100%}.permissions-table th,.roles-table th,.users-table th{background-color:#f2f2f2;border-bottom:1px solid #e5e7eb;color:#4a5565;font-size:.875rem;font-weight:400;padding:1rem;text-align:left}.permissions-table td,.roles-table td,.users-table td{background-color:#f2f2f2;border-bottom:1px solid #f3f4f6;color:#4a5565;font-weight:400;padding:1rem;vertical-align:middle}.permissions-table tr:hover td,.roles-table tr:hover td,.users-table tr:hover td{background-color:#f9fafb}.permissions-table tr,.roles-table tr,.users-table tr{border-bottom:2px solid #e5e7eb}.permission-info,.role-info,.user-info{align-items:center;gap:.75rem}.user-info{position:relative}.status-indicator{border-radius:50%;flex-shrink:0;height:16px;margin-right:.5rem;width:16px}.status-indicator.active{size:16px;background-color:#4caf50}.status-indicator.inactive{background-color:#f44336}.permission-avatar,.role-avatar,.user-avatar{align-items:center;background-color:#2932e5;border-radius:50%;color:#fff;display:flex;font-weight:600;height:40px;justify-content:center;width:40px}.role-avatar{background-color:#10b981}.permission-avatar{background-color:#f59e0b}.permission-name,.role-name,.user-name{color:#4a5565;cursor:pointer;font-weight:400;text-decoration:none}.permissions-container,.roles-container{display:flex;flex-wrap:wrap;gap:.25rem}.permission-badge,.role-badge{border:1px solid #e5e7eb;border-radius:5px;color:#4a5565;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.status-badge{color:#fff}.status-badge,.status-badge-role{background-color:#2932e5;border:1px solid #2932e5;border-radius:5px;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.status-badge-role{color:#fff!important}.status-badge.inactive{background-color:#fb2c36;border:1px solid #fb2c36}.permission-badge{background-color:#2932e515;color:#2932e5}.permission-badge.more{background-color:#0a108215;color:#2932e5}.category-badge{background-color:#ffebee;border:1px solid #ffcdd2;border-radius:12px;color:#2932e5}.action-badge,.category-badge{font-size:.75rem;font-weight:500;padding:.25rem .5rem}.action-badge{background-color:#e3f2fd;border:1px solid #bbdefb;border-radius:12px;color:#1976d2}.no-permissions,.no-roles{color:#9ca3af;font-size:.875rem;font-style:italic}.status-toggle{border:none;border-radius:20px;cursor:pointer;font-size:.75rem;font-weight:500;padding:.25rem .75rem;transition:all .2s ease}.status-toggle.active{background-color:#4caf50;color:#fff}.status-toggle.inactive{background-color:#f44336;color:#fff}.action-buttons{display:flex;gap:.5rem}.btn-icon{align-items:center;background:#0000;border:none;display:inline-flex;font-size:16px;height:16px;justify-content:center;line-height:16px;opacity:1;width:16px}.btn-edit:hover{background-color:#dbeafe;transform:scale(1.05)}.btn-delete:hover{background-color:#fef2f2;transform:scale(1.05)}.action-dropdown{display:inline-block;position:relative}.action-dropdown-btn{align-items:center;background-color:initial;border:none;border-radius:.375rem;color:#6b7280;cursor:pointer;display:flex;font-size:1.2rem;height:2rem;justify-content:center;transition:all .2s ease;width:2rem}.action-dropdown-btn:hover{background-color:#f3f4f6;color:#374151}.action-dropdown-menu{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;display:block;margin-top:0;min-width:150px;position:absolute;right:0;top:100%;z-index:1000!important}.action-dropdown-menu:before{background:#0000;content:"";height:.5rem;left:0;position:absolute;right:0;top:-.5rem}.action-dropdown-item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:background-color .2s ease;width:100%}.action-dropdown-item:hover{background:#f3f4f6}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:none;display:flex;justify-content:space-between;padding:2rem 2rem 1rem}.modal-header h2{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0}.modal-close{background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;font-size:1.5rem;padding:.5rem;transition:all .2s ease}.modal-close:hover{background-color:#f3f4f6;color:#374151}.modal-body{padding:1rem 2rem}.camera-form,.permission-form,.role-form,.user-form{display:flex;flex-direction:column;gap:1.5rem}.form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:.75rem}.form-group label{color:#6b7280;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.form-group input,.form-group select,.form-group textarea{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;font-size:.875rem;padding:.75rem 1rem;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background-color:#fff;border-color:#2932e5;outline:none}.form-group textarea{min-height:80px;resize:vertical}.password-input-container{align-items:center;display:flex;position:relative}.password-input-container input{padding-right:3rem;width:100%}.password-toggle{color:#6b7280;cursor:pointer;font-size:1rem;position:absolute;right:1rem}.password-toggle:hover{color:#374151}.toggle-container{margin-top:.5rem}.toggle-label{align-items:center;cursor:pointer;display:flex;gap:1rem}.toggle-text{color:#374151;font-size:.875rem;font-weight:500}.toggle-switch{align-items:center;display:flex;gap:.75rem}.toggle-input{display:none}.toggle-slider{background-color:#e5e7eb;border-radius:16px;cursor:pointer;height:32px;position:relative;transition:all .3s ease;width:60px}.toggle-knob{background-color:#fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;height:28px;left:2px;position:absolute;top:2px;transition:all .3s ease;width:28px}.toggle-input:checked+.toggle-slider{background-color:#4caf50}.toggle-input:checked+.toggle-slider .toggle-knob{transform:translateX(28px)}.toggle-status{color:#374151;font-size:.875rem;font-weight:500;min-width:20px}.permission-builder{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.permission-builder h4{color:#374151;font-size:1rem;font-weight:600;margin:0 0 1rem}.builder-divider{color:#6b7280;font-weight:500;margin:1rem 0;position:relative;text-align:center}.builder-divider:before{background-color:#e5e7eb;content:"";height:1px;left:0;position:absolute;right:0;top:50%;z-index:1}.builder-divider:after{background-color:#f9fafb;content:"OR";padding:0 1rem;position:relative;z-index:2}.permissions-grid{background-color:#f9fafb;border-radius:8px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));max-height:200px;padding:.5rem}.checkbox-label{align-items:flex-start;border-radius:6px;padding:.5rem;transition:background-color .2s ease}.checkbox-label:hover{background-color:#f3f4f6}.checkbox-label input[type=checkbox]{margin:.125rem 0 0}.checkbox-label span{color:#374151;font-size:.875rem;font-weight:500}.permission-description{color:#4a5565;display:block;font-size:14px;font-style:italic;margin-top:.25rem}.status-display{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:.5rem;padding:.75rem 1rem}.form-sections-row{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.form-section{display:flex;flex-direction:column;gap:1.5rem}.form-help,.form-hint{color:#6b7280;font-size:.75rem;margin-top:.25rem}.form-hint{font-style:italic}.field-error{color:#ef4444;font-size:.75rem;margin-top:.25rem}.form-error.submit-error{background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#b91c1c;font-size:.875rem;margin-bottom:1rem;padding:.75rem}.permissions-grid{grid-gap:.75rem;border:1px solid #e5e7eb;border-radius:6px;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));justify-items:start;max-height:300px;overflow-y:auto;padding:1rem}.multi-select{min-height:100px;padding:.5rem}.multi-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.modal-footer{background-color:initial;border-top:none;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem 2rem}.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:3rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#3b82f6;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-message{color:#dc2626;margin-bottom:1rem}.empty-state{color:#6b7280;padding:3rem;text-align:center}.pagination{align-items:center;display:flex;justify-content:space-between;padding:1rem}.pagination-info{color:#6b7280;font-size:.875rem}.pagination-controls{align-items:center;display:flex;gap:.5rem}.pagination button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;border-radius:100%;color:#374151;cursor:pointer;display:flex;height:40px;justify-content:center;min-width:40px;padding:.5rem 1rem;transition:all .2s ease}.pagination button:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.pagination button.active{background-color:#2932e5;border-color:#2932e5;color:#fff}.pagination button:disabled{cursor:not-allowed;opacity:.5}.pagination span{color:#6b7280;font-size:.875rem}.dashboard{margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{color:#1f2937;font-size:2rem;font-weight:700;margin-bottom:.5rem}.dashboard-header p{color:#6b7280;font-size:1rem}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px)}.stat-icon{align-items:center;background:#2932e5;border-radius:12px;display:flex;flex-shrink:0;font-size:2rem;height:60px;justify-content:center;width:60px}.stat-content{flex:1 1}.stat-title{color:#6b7280;font-size:.875rem;font-weight:500;margin:0 0 .5rem}.stat-value{color:#1f2937;display:block;font-size:1.875rem;font-weight:700;margin-bottom:.25rem}.stat-change{font-size:.75rem;font-weight:500}.stat-change.positive{color:#059669}.stat-change.negative{color:#dc2626}.dashboard-content{margin-top:2rem}.content-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:2fr 1fr}.section-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;padding:1.5rem}.section-card h2{color:#1f2937;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem}.chart-placeholder{align-items:center;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;display:flex;flex-direction:column;height:300px;justify-content:center}.chart-bars{align-items:end;display:flex;gap:8px;height:120px;margin-bottom:1rem}.bar{animation:growUp .8s ease-out;background:#2932e5;border-radius:2px 2px 0 0;width:20px}@keyframes growUp{0%{height:0}to{height:100%;height:var(--height,100%)}}.chart-label{color:#6b7280;font-size:.875rem;margin:0}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{align-items:center;background:#f9fafb;border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:background-color .2s ease}.activity-item:hover{background:#f3f4f6}.activity-avatar{align-items:center;background:#2932e5;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;height:40px;justify-content:center;width:40px}.activity-content{flex:1 1}.activity-user{color:#1f2937;font-size:.875rem;font-weight:500}.activity-action{color:#6b7280;font-size:.75rem;margin:.25rem 0}.activity-time{color:#9ca3af;font-size:.75rem}.analytics-page{margin:0 auto}.analytics-content{margin-top:2rem}.settings-page{margin:0 auto}.settings-content{margin-top:2rem}.settings-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.settings-section{margin-bottom:2rem}.settings-form{gap:1rem}.settings-form,.system-info{display:flex;flex-direction:column}.system-info{gap:.75rem}.info-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:.5rem 0}.info-label{color:#374151;font-weight:500}.info-value{color:#6b7280}.status-online{color:#059669;font-weight:500}.form-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;padding:.75rem}.form-select:focus{border-color:#2932e5;box-shadow:0 0 0 3px #f45b491a;outline:none}@media (max-width:768px){.dashboard-header h1{font-size:1.5rem}.content-grid,.stats-grid{gap:1rem;grid-template-columns:1fr}.section-card,.stat-card{padding:1rem}.chart-placeholder{height:200px}}@media (max-width:480px){.login-card{padding:2rem}.login-header h1{font-size:1.5rem}}:root{--font-sans:"Roboto","Helvetica","Arial",sans-serif;--color-text:#212121;--color-text-muted:#616161;--color-border:#e0e0e0;--color-surface:#fff;--color-primary:#2932e5;--space-2:8px;--space-3:12px;--space-4:16px;--radius-md:8px}body{color:#212121;color:var(--color-text);font-family:Roboto,Helvetica,Arial,sans-serif;font-family:var(--font-sans)}
/*# sourceMappingURL=main.4e9aa3c9.css.map*/