*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#eee;overflow:hidden;display:flex;flex-direction:column;height:100vh}#header{display:flex;align-items:center;gap:20px;padding:10px 20px;background:#fff;border-bottom:3px solid #e94560;flex-shrink:0}#header .header-logo{height:40px;width:auto}#header h1{font-size:1.2rem;font-weight:600;color:#09357a;margin:0}#app{display:flex;width:100vw;flex:1;overflow:hidden}#canvas{flex:1;display:block}#panel{position:relative;width:320px;background:#16213e;padding:20px;overflow-y:auto;overflow-x:hidden;border-left:1px solid #0f3460;transition:width .3s ease}#panel.collapsed{width:70px;padding:8px}#panel-toggle{position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:24px;height:48px;background:#0f3460;border:1px solid #1a4a7a;border-radius:6px 0 0 6px;color:#888;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}#panel-toggle:hover{background:#1a4a7a;color:#eee}#panel-toggle .toggle-icon{font-size:12px;transition:transform .3s ease}#panel.collapsed #panel-toggle .toggle-icon{transform:rotate(180deg)}#panel-compact{display:flex;flex-direction:column;gap:12px}.compact-group{display:flex;flex-direction:column;gap:6px}.compact-row{display:flex;gap:4px}.compact-btn{flex:1;padding:8px 10px;border:none;border-radius:6px;background:#0f3460;color:#aaa;cursor:pointer;transition:all .2s;font-size:.8rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:40px}.compact-btn:hover{background:#1a4a7a;color:#eee}.compact-btn.active{background:#e94560;color:#fff}.compact-btn .btn-icon-char{font-size:1rem;line-height:1}.compact-btn .btn-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.5px;transition:opacity .3s ease}#panel.collapsed .compact-btn .btn-label{display:none}#panel.collapsed .compact-btn{min-height:32px;min-width:32px;padding:4px}#panel.collapsed .compact-row{flex-direction:column;align-items:stretch}#panel.collapsed #panel-compact{gap:6px}#panel.collapsed .compact-group{gap:3px}.site-selector-group{margin-bottom:8px}.site-selector{width:100%;padding:8px 10px;border:none;border-radius:6px;background:#0f3460;color:#eee;font-size:.85rem;cursor:pointer;transition:all .2s}.site-selector:hover{background:#1a4a7a}.site-selector:focus{outline:none;background:#1a4a7a;box-shadow:0 0 0 2px #e94560}.site-selector option{background:#16213e;color:#eee}#panel.collapsed .site-selector-group{margin-bottom:4px}#panel.collapsed .site-selector-group .compact-label{display:none}#panel.collapsed .site-selector{padding:4px 6px;font-size:.7rem}.view-selector-group{margin-bottom:8px}.view-selector-row{display:flex;gap:4px;align-items:center}.view-selector{flex:1;padding:6px 8px;border:none;border-radius:6px;background:#0f3460;color:#eee;font-size:.8rem;cursor:pointer;transition:all .2s}.view-selector:hover{background:#1a4a7a}.view-selector:focus{outline:none;background:#1a4a7a;box-shadow:0 0 0 2px #e94560}.view-selector option{background:#16213e;color:#eee}.view-selector option.is-default{font-weight:700}.view-btn{width:28px;height:28px;padding:0;border:none;border-radius:4px;background:#0f3460;color:#888;cursor:pointer;transition:all .2s;font-size:.85rem;display:flex;align-items:center;justify-content:center}.view-btn:hover:not(:disabled){background:#1a4a7a;color:#eee}.view-btn:disabled{opacity:.4;cursor:not-allowed}.view-btn.active{background:#f59e0b;color:#fff}#btn-delete-view:hover:not(:disabled){background:#dc2626;color:#fff}#btn-default-view.is-default{background:#f59e0b;color:#fff}#panel.collapsed .view-selector-group{margin-bottom:4px}#panel.collapsed .view-selector-group .compact-label{display:none}#panel.collapsed .view-selector-row{flex-direction:column}#panel.collapsed .view-selector{width:100%;padding:4px 6px;font-size:.65rem}#panel.collapsed .view-btn{width:100%;height:24px;font-size:.75rem}.view-dialog-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000}.view-dialog{background:#16213e;border-radius:8px;padding:20px;min-width:300px;max-width:400px;box-shadow:0 4px 20px #00000080;border:1px solid #0f3460}.view-dialog h3{margin:0 0 16px;color:#eee;font-size:1.1rem}.view-dialog-field{margin-bottom:12px}.view-dialog-field label{display:block;font-size:.8rem;color:#888;margin-bottom:4px}.view-dialog-field input{width:100%;padding:8px 10px;border:none;border-radius:4px;background:#0f3460;color:#eee;font-size:.9rem}.view-dialog-field input:focus{outline:1px solid #e94560}.view-dialog-actions{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}.view-dialog-actions button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.view-dialog-actions .btn-cancel{background:#0f3460;color:#aaa}.view-dialog-actions .btn-cancel:hover{background:#1a4a7a;color:#eee}.view-dialog-actions .btn-save{background:#e94560;color:#fff}.view-dialog-actions .btn-save:hover{background:#f05e78}#panel-compact .btn-live{width:100%;padding:8px 10px;margin-top:0;flex-direction:column;gap:2px}#panel-compact .btn-live .live-dot{font-size:1rem}#panel.collapsed #panel-compact .btn-live .btn-label{display:none}.compact-btn.btn-secondary{background:#0f3460;color:#aaa}.compact-btn.btn-secondary:hover{background:#1a4a7a;color:#eee}.compact-btn.btn-secondary.active{background:#1a4a7a;color:#4ade80}.explode-compact{background:#0f3460;padding:8px;border-radius:6px}.explode-compact .compact-label{font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;display:block}#panel.collapsed .explode-compact .compact-label{display:none}#panel.collapsed .explode-compact{padding:4px;display:flex;align-items:center;justify-content:center}#panel.collapsed .explode-compact input[type=range]{width:100%;height:4px}#panel.collapsed #explode-value{display:none}#ifc-rotation-control{background:#0f3460;padding:8px;border-radius:6px}#ifc-rotation-control .compact-label{font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;display:block}.slider-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.slider-row input[type=range]{flex:1}.slider-row span{min-width:40px;text-align:right;font-size:.8rem;color:#e94560}#btn-save-rotation{width:100%;padding:4px 8px;font-size:.75rem}#panel.collapsed #ifc-rotation-control{display:none!important}.floors-compact{display:none}#panel.collapsed .floors-compact{display:block}#panel.collapsed .floors-compact .compact-label{display:none}#floor-list-compact{display:flex;flex-direction:column;gap:2px;max-height:280px;overflow-y:auto}#floor-list-compact .floor-btn{width:100%;padding:6px 4px;border:none;border-radius:4px;background:#0f3460;color:#aaa;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}#floor-list-compact .floor-btn:hover{background:#1a4a7a;color:#eee}#floor-list-compact .floor-btn.selected{background:#e94560;color:#fff}#floor-list-compact .floor-btn.isolated{background:#f59e0b;color:#fff;box-shadow:0 0 8px #f59e0b80}#floor-list-compact .floor-btn.disabled{opacity:.3;cursor:not-allowed}#panel-extended{margin-top:16px;padding-top:16px;border-top:1px solid #0f3460;transition:opacity .3s ease}#panel.collapsed #panel-extended{display:none}.control-group{margin-bottom:20px}.control-group>label{display:block;font-size:.85rem;color:#888;margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}.btn-group{display:flex;gap:8px}.btn-group button{flex:1;padding:10px 16px;border:none;border-radius:6px;background:#0f3460;color:#eee;cursor:pointer;transition:all .2s;font-size:.9rem}.btn-group button:hover{background:#1a4a7a}.btn-group button.active{background:#e94560;color:#fff}.btn-secondary{flex:1;padding:8px 12px;border:none;border-radius:6px;background:#0f3460;color:#aaa;cursor:pointer;transition:all .2s;font-size:.85rem}.btn-secondary:hover{background:#1a4a7a;color:#eee}.btn-secondary.active{background:#1a4a7a;color:#4ade80}.btn-live{width:100%;margin-top:10px;padding:10px 16px;border:2px solid #374151;border-radius:8px;background:#1f2937;color:#9ca3af;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-live:hover{background:#374151;border-color:#4b5563;color:#e5e7eb}.btn-live .live-dot{font-size:.8rem;color:#6b7280;transition:all .3s}.btn-live.active{background:#dc2626;border-color:#dc2626;color:#fff;box-shadow:0 0 20px #dc262666}.btn-live.active .live-dot{color:#fff;animation:pulse-live 1.5s ease-in-out infinite}@keyframes pulse-live{0%,to{opacity:1}50%{opacity:.4}}.btn-row{display:flex;gap:8px;margin-top:8px}input[type=range]{width:100%;height:6px;border-radius:3px;background:#0f3460;outline:none;-webkit-appearance:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#e94560;cursor:pointer}#explode-value{display:inline-block;margin-top:5px;font-size:.85rem;color:#888}#floor-list{list-style:none;max-height:200px;overflow-y:auto}#floor-list li{padding:10px 12px;margin-bottom:4px;background:#0f3460;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;justify-content:space-between;align-items:center}#floor-list li:hover{background:#1a4a7a}#floor-list li.selected{background:#e94560;color:#fff}#floor-list li .count{font-size:.8rem;background:#0000004d;padding:2px 8px;border-radius:10px}#floor-list li .floor-name{flex:1}#floor-list li .btn-isolate{width:24px;height:24px;padding:0;margin-left:8px;border:none;border-radius:4px;background:transparent;color:#6b7280;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}#floor-list li .btn-isolate:hover{background:#ffffff1a;color:#e94560}#floor-list li .btn-isolate.active{background:#e94560;color:#fff}#floor-list li.isolated{border:2px solid #e94560;background:#1a4a7a}#floor-list li.floor-disabled{opacity:.4;cursor:not-allowed}#floor-list li.floor-disabled:hover{background:#0f3460}.legend{display:grid;grid-template-columns:1fr 1fr;gap:8px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.85rem}.dot{width:12px;height:12px;border-radius:50%}.dot.present{background:#4ade80}.dot.absent{background:#f87171}.dot.meeting{background:#60a5fa}.dot.moving{background:#fb923c}#stats{background:#0f3460;padding:12px;border-radius:6px;font-size:.9rem}#stats p{margin-bottom:4px}#stats .stat-number{font-size:1.5rem;font-weight:700;color:#e94560}#tooltip{position:fixed;background:#16213ef2;border:1px solid #e94560;padding:8px 12px;border-radius:6px;font-size:.85rem;pointer-events:none;z-index:1000;box-shadow:0 4px 12px #0000004d}#tooltip.hidden{display:none}#tooltip .name{font-weight:700;margin-bottom:4px}#tooltip .status{color:#888}.hidden{display:none!important}#edit-panel{border-top:1px solid #0f3460;padding-top:15px;margin-top:10px}.location-editor{background:#0f3460;padding:12px;border-radius:6px}.location-editor .hint{color:#888;font-size:.85rem;font-style:italic}.location-editor .location-info{display:flex;flex-direction:column;gap:10px}.location-editor .location-name{display:flex;align-items:center;gap:8px}.location-editor .location-name input{flex:1;padding:8px 10px;border:none;border-radius:4px;background:#16213e;color:#eee;font-size:.9rem}.location-editor .location-coords{font-size:.8rem;color:#888}.location-editor .location-occupants{font-size:.85rem;color:#4ade80}.edit-actions{display:flex;flex-direction:column;gap:8px}.edit-actions button{padding:10px 16px;border:none;border-radius:6px;cursor:pointer;transition:all .2s;font-size:.9rem}.btn-primary{width:100%;padding:12px 16px;border:none;border-radius:6px;background:#e94560;color:#fff;cursor:pointer;transition:all .2s;font-size:.95rem;font-weight:600}.btn-primary:hover{background:#f05e78}.btn-primary.placement-mode{background:#f59e0b;animation:pulse-placement 1.5s ease-in-out infinite}@keyframes pulse-placement{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 8px #f59e0b00}}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background:#ef4444}.btn-danger:disabled{background:#4a1515;color:#888;cursor:not-allowed}.instructions{background:#0f3460;padding:12px;border-radius:6px;font-size:.8rem}.instructions p{margin-bottom:6px;color:#aaa}.instructions strong{color:#e94560}body.edit-mode #panel{border-left:3px solid #f59e0b}body.edit-mode #panel-toggle{background:#f59e0b;color:#fff}body.edit-mode .people-section{display:none!important}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0f3460}::-webkit-scrollbar-thumb{background:#e94560;border-radius:3px}.panel-header{display:flex;justify-content:space-between;align-items:center}.btn-icon{background:transparent;border:1px solid #0f3460;border-radius:4px;color:#888;cursor:pointer;padding:4px 8px;font-size:1rem;transition:all .2s}.btn-icon:hover{background:#0f3460;color:#eee}.btn-icon.active{background:#e94560;border-color:#e94560;color:#fff}#people-panel{border-top:1px solid #0f3460;margin-top:10px;padding-top:15px}#people-search-input{width:100%;padding:8px 12px;border:none;border-radius:6px;background:#0f3460;color:#eee;margin-bottom:8px;font-size:.9rem}#people-search-input::placeholder{color:#666}#people-search-input:focus{outline:1px solid #e94560}#people-list{list-style:none;max-height:300px;overflow-y:auto}#people-list li{padding:8px 12px;margin-bottom:4px;background:#0f3460;border-radius:6px;display:flex;flex-direction:column;gap:2px;cursor:pointer;transition:background .2s}#people-list li:hover{background:#1a4a7a}#people-list li .badge-code{font-weight:700;color:#e94560;font-family:monospace;font-size:.95rem}#people-list li .person-name{font-size:.85rem;color:#ccc}#people-list li .person-location{font-size:.8rem;color:#888}#people-list li .person-floor{font-size:.75rem;color:#666}@keyframes position-flash{0%{background:#0f3460}25%{background:#f59e0b}50%{background:#f59e0b}to{background:#0f3460}}#people-list li.position-changed{animation:position-flash .8s ease-in-out}#people-list li.is-moving{border-left:3px solid #fb923c}#people-list li.is-moving .badge-code:after{content:" ↔";color:#fb923c}#people-list li.is-tracked{background:#1a4a7a;border:2px solid #e94560;box-shadow:0 0 8px #e9456066}#people-list li.is-tracked .badge-code:before{content:"📍 "}@keyframes tracking-pulse{0%{box-shadow:0 0 4px #e9456066}50%{box-shadow:0 0 12px #e94560b3}to{box-shadow:0 0 4px #e9456066}}#people-list li.is-tracked{animation:tracking-pulse 2s ease-in-out infinite}.wall-editor{background:#0f3460;padding:12px;border-radius:6px}.wall-editor .hint{color:#888;font-size:.85rem;font-style:italic}.wall-editor .wall-info{display:flex;flex-direction:column;gap:10px}.wall-editor .wall-field{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.wall-editor .wall-field label{width:70px;font-size:.85rem;color:#aaa}.wall-editor .wall-field .color-palette,.wall-editor .wall-field .texture-selector{width:100%;flex-basis:100%}.wall-editor .wall-field input{flex:1;padding:6px 8px;border:none;border-radius:4px;background:#16213e;color:#eee;font-size:.85rem;width:60px}.wall-editor .wall-field input[type=number]{-moz-appearance:textfield}.wall-editor .wall-field input::-webkit-outer-spin-button,.wall-editor .wall-field input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.wall-editor .wall-coords{font-size:.8rem;color:#888}.color-palette{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;width:100%}.color-swatch{width:100%;aspect-ratio:1;border-radius:4px;cursor:pointer;border:2px solid transparent;transition:all .2s}.color-swatch:hover{transform:scale(1.1);border-color:#fff}.color-swatch.selected{border-color:#e94560;box-shadow:0 0 8px #e9456099}.texture-selector{display:flex;gap:6px;flex:1}.texture-btn{flex:1;padding:6px 8px;border:none;border-radius:4px;background:#16213e;color:#aaa;cursor:pointer;transition:all .2s;font-size:.8rem}.texture-btn:hover{background:#1a4a7a;color:#eee}.texture-btn.active{background:#e94560;color:#fff}.location-editor .location-field{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.location-editor .location-field label{width:60px;font-size:.85rem;color:#aaa}.location-editor .location-field input{flex:1;padding:6px 8px;border:none;border-radius:4px;background:#16213e;color:#eee;font-size:.85rem}.location-editor .location-field input[type=number]{width:70px;-moz-appearance:textfield}.location-editor .location-field input.code-input{font-family:monospace;font-size:.75rem;color:#888;background:#0f172a}.location-editor .location-field input::-webkit-outer-spin-button,.location-editor .location-field input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.location-editor .location-field .color-palette,.location-editor .location-field .type-selector{width:100%;flex-basis:100%}.location-editor .color-palette{grid-template-columns:repeat(6,1fr)}.type-selector{display:flex;flex-direction:column;gap:4px;width:100%}.type-btn{width:100%;padding:8px 10px;border:none;border-radius:4px;background:#16213e;color:#aaa;cursor:pointer;transition:all .2s;font-size:.8rem;text-align:left}.type-btn:hover{background:#1a4a7a;color:#eee}.type-btn.active{background:#e94560;color:#fff}.slider-with-input{display:flex;align-items:center;gap:8px;flex:1}.slider-with-input input[type=range]{flex:1;min-width:80px}.slider-with-input input[type=number]{width:55px;padding:4px 6px;border:none;border-radius:4px;background:#16213e;color:#4ade80;font-size:.85rem;text-align:right}.slider-with-input input[type=number]:focus{outline:1px solid #4ade80}.slider-with-input .unit{color:#666;font-size:.8rem;min-width:12px}.slider-with-input input[type=number]::-webkit-outer-spin-button,.slider-with-input input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.slider-with-input input[type=number]{-moz-appearance:textfield}.height-control{display:flex;align-items:center;gap:10px;flex:1}.height-control input[type=range]{flex:1}.height-control span{min-width:45px;text-align:right;font-size:.85rem;color:#4ade80;font-weight:500}.tb-sync{color:#64748b;font-size:10px;margin-left:6px;vertical-align:middle}.tb-sync.synced{color:#4ade80}.tb-info{font-size:.7rem;color:#4ade80;padding:2px 8px;background:#4ade801a;border-radius:4px;margin-bottom:8px}#people-list li .tb-sync{margin-left:0;margin-right:6px}.path-editor{font-size:.85rem}.path-info{display:flex;flex-direction:column;gap:8px}.path-coords{background:#0003;padding:8px;border-radius:4px;font-family:monospace;font-size:.8rem}.path-coords p{margin:2px 0}.path-field{display:flex;flex-direction:column;gap:4px}.path-field label{font-size:.75rem;color:#999}.path-field input[type=number]{padding:6px 8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;font-size:.85rem}.path-transition-field label{display:flex;align-items:center;gap:8px;cursor:pointer}.path-transition-field input[type=checkbox]{width:16px;height:16px;cursor:pointer}.type-selector{display:flex;gap:4px;flex-wrap:wrap}.type-btn{padding:4px 8px;border:2px solid;border-radius:4px;background:transparent;color:#fff;cursor:pointer;font-size:.75rem;transition:all .15s ease}.type-btn:hover{background:#ffffff1a}.type-btn.active{background:#fff3}#path-graph-stats{background:#0003;padding:8px;border-radius:4px}.graph-stat{display:flex;justify-content:space-between;padding:2px 0;font-size:.8rem}.stat-label{color:#999}.stat-value{color:#fff}.graph-stat.connectivity{margin-top:4px;padding-top:4px;border-top:1px solid rgba(255,255,255,.1)}.graph-stat.connected .stat-value{color:#4ade80}.graph-stat.disconnected .stat-value{color:#fbbf24}.graph-stat.has-isolated .stat-value{color:#e94560}#btn-show-segment-list{width:100%;margin-top:8px;font-size:.75rem;padding:6px 8px}.segment-list-container{margin-top:8px;max-height:300px;overflow-y:auto;background:#0000004d;border-radius:4px}.segment-floor-group{border-bottom:1px solid rgba(255,255,255,.1)}.segment-floor-group:last-child{border-bottom:none}.segment-floor-header{padding:6px 8px;font-size:.75rem;font-weight:700;color:#60a5fa;background:#60a5fa1a;position:sticky;top:0}.segment-floor-list{list-style:none;margin:0;padding:0}.segment-list-item{padding:6px 8px 6px 16px;font-size:.7rem;color:#ccc;cursor:pointer;transition:background .15s}.segment-list-item:hover{background:#ffffff1a;color:#fff}.segment-list-item:active{background:#60a5fa4d}.routing-panel{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.routing-controls{display:flex;flex-direction:column;gap:10px}.routing-field{display:flex;flex-direction:column;gap:4px}.routing-field label{font-size:.75rem;color:#999}.route-selector{padding:8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;font-size:.85rem;cursor:pointer}.route-selector option{background:#1a1a2e;color:#fff}.routing-actions{display:flex;gap:8px}.routing-actions button{flex:1}.route-info{background:#0003;padding:10px;border-radius:4px;margin-top:8px}.route-detail{display:flex;justify-content:space-between;padding:3px 0;font-size:.8rem}.route-label{color:#999}.route-value{color:#fff;font-weight:500}.route-floors .route-value{font-size:.75rem;text-align:right}.route-error{color:#e94560;font-size:.85rem;text-align:center;padding:8px}.placement-mode{animation:pulse 1.5s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #4ade8066}50%{box-shadow:0 0 0 8px #4ade8000}}#btn-toggle-battery{color:#666}#btn-toggle-battery .btn-icon-char{filter:grayscale(100%);opacity:.5}#btn-toggle-battery:hover{background:#1a4a7a}#btn-toggle-battery:hover .btn-icon-char{filter:grayscale(50%);opacity:.8}#btn-toggle-battery.active{background:#166534;color:#4ade80}#btn-toggle-battery.active .btn-icon-char{filter:none;opacity:1}.compact-btn.btn-warning{color:#666}.compact-btn.btn-warning:hover{background:#78350f;color:#fbbf24}.compact-btn.btn-warning.active{background:#f59e0b;color:#fff}.compact-btn.btn-danger{color:#666}.compact-btn.btn-danger:hover{background:#7f1d1d;color:#fca5a5}.compact-btn.btn-danger.active{background:#ef4444;color:#fff}.battery-excellent{color:#4ade80}.battery-good{color:#fbbf24}.battery-low{color:#fb923c}.battery-critical{color:#ef4444;animation:battery-pulse 1.5s infinite}@keyframes battery-pulse{0%,to{opacity:1}50%{opacity:.5}}.online-indicator{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}.online-indicator.online{background:#4ade80;box-shadow:0 0 4px #4ade8080}.online-indicator.offline{background:#ef4444;box-shadow:0 0 4px #ef444480}.battery-info{font-size:.85rem}.luxnavix-sync{color:#64748b;font-size:10px;margin-left:6px;vertical-align:middle}.luxnavix-sync.synced{color:#60a5fa}#btn-toggle-topology{color:#666}#btn-toggle-topology.active{background:#1e40af;color:#60a5fa}#btn-toggle-topology.active .btn-icon-char{filter:none}#topology-controls{background:#0f3460;padding:10px;border-radius:6px;border-left:3px solid #1e40af}#topology-controls .compact-label{font-size:.7rem;color:#60a5fa;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;display:block}.rssi-slider-container{display:flex;flex-direction:column;gap:4px}#rssi-filter-slider{width:100%;height:8px;border-radius:4px;background:linear-gradient(to right,#ef4444,#fb923c,#fbbf24 50%,#4ade80);outline:none;-webkit-appearance:none;--rssi-color: #ef4444}#rssi-filter-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--rssi-color, #ef4444);cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px #0000004d;transition:background .2s}#rssi-filter-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--rssi-color, #ef4444);cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px #0000004d}.rssi-labels{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;color:#888}.rssi-min{color:#ef4444}.rssi-max{color:#4ade80}.rssi-current{font-weight:700;font-size:.85rem;transition:color .2s}#optimal-paths-control{margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1)}#optimal-paths-control .compact-label{margin-bottom:6px}.paths-selector{display:flex;gap:4px}.path-count-btn{flex:1;padding:6px 12px;border:none;border-radius:4px;background:#16213e;color:#888;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s}.path-count-btn:hover{background:#1a4a7a;color:#eee}.path-count-btn.active{background:#e94560;color:#fff}.topology-stats{margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1);text-align:center}#topology-link-count{font-size:.8rem;color:#60a5fa;font-weight:500}#panel.collapsed #topology-controls{display:none}#loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center;z-index:10000;transition:opacity .5s ease,visibility .5s ease}#loading-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}.loading-content{text-align:center;max-width:400px;padding:40px}.loading-spinner{width:60px;height:60px;border:4px solid rgba(233,69,96,.2);border-top-color:#e94560;border-radius:50%;margin:0 auto 24px;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-title{color:#fff;font-size:1.5rem;font-weight:600;margin-bottom:24px}.loading-steps{text-align:left;background:#0f346080;border-radius:8px;padding:16px 20px;margin-bottom:20px}.loading-step{display:flex;align-items:center;gap:12px;padding:8px 0;color:#666;font-size:.9rem;transition:color .3s}.loading-step .step-icon{font-size:1rem;width:20px;text-align:center;transition:color .3s}.loading-step.active{color:#fbbf24}.loading-step.active .step-icon{color:#fbbf24;animation:pulse-icon 1s ease-in-out infinite}@keyframes pulse-icon{0%,to{opacity:1}50%{opacity:.5}}.loading-step.completed,.loading-step.completed .step-icon{color:#4ade80}.loading-step.error,.loading-step.error .step-icon{color:#ef4444}.loading-status{color:#888;font-size:.85rem;font-style:italic}.header-spacer{flex:1}.user-info{display:flex;align-items:center;gap:12px;padding:6px 12px;background:#09357a4d;border-radius:6px;margin-right:12px}.user-info.hidden{display:none}#user-name{color:#333;font-weight:500;font-size:.9rem}.user-badge{padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.user-badge.player{background:#3b82f6;color:#fff}.user-badge.tools{background:#f59e0b;color:#fff}.user-badge.admin{background:#e94560;color:#fff}.btn-logout{padding:5px 12px;border:none;border-radius:4px;background:#0000001a;color:#666;cursor:pointer;font-size:.8rem;transition:all .2s}.btn-logout:hover{background:#e94560;color:#fff}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10001}.modal.hidden{display:none}.modal-content{background:#16213e;border-radius:12px;padding:32px;box-shadow:0 8px 32px #00000080;border:1px solid #0f3460}.login-modal{min-width:320px;max-width:400px}.login-modal h3{color:#fff;font-size:1.5rem;margin:0 0 24px;text-align:center}.login-field{margin-bottom:16px}.login-field label{display:block;font-size:.85rem;color:#888;margin-bottom:6px}.login-field input{width:100%;padding:12px 14px;border:1px solid #0f3460;border-radius:6px;background:#0f3460;color:#fff;font-size:1rem;transition:border-color .2s,box-shadow .2s}.login-field input:focus{outline:none;border-color:#e94560;box-shadow:0 0 0 3px #e9456033}.login-field input::placeholder{color:#666}.login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;padding:10px 14px;margin-bottom:16px;color:#ef4444;font-size:.9rem;text-align:center}.login-error.hidden{display:none}.login-btn{width:100%;padding:12px 20px;border:none;border-radius:6px;background:#e94560;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.login-btn:hover{background:#f05e78}.login-btn:active{transform:scale(.98)}.login-btn:disabled{background:#666;cursor:not-allowed}.btn-disabled-auth{opacity:.5;cursor:not-allowed!important;pointer-events:none}.player-hidden,.tools-hidden{display:none!important}.btn-admin{padding:6px 14px;background:#0f3460;border:1px solid #1a4a80;border-radius:4px;font-size:13px;color:#a0c0e0;cursor:pointer;transition:background .2s;margin-right:8px}.btn-admin:hover{background:#1a4a80}#admin-panel{position:fixed;right:0;bottom:0;left:0;top:60px;background:#1a1a2e;z-index:500;display:flex;flex-direction:column;overflow:hidden}.admin-page__tabs{display:flex;gap:4px;padding:16px 16px 0;background:#1a1a2e}.admin-page__tab{padding:8px 16px;background:#0f3460;border:none;border-radius:4px 4px 0 0;font-size:13px;color:#a0a0b0;cursor:pointer;transition:background .15s}.admin-page__tab:hover{background:#1a4a80}.admin-page__tab--active{background:#16213e;color:#e0e0e0;font-weight:600}.admin-page__content{flex:1;background:#16213e;margin:0 16px 16px;border-radius:0 4px 4px;padding:16px;overflow-y:auto}.admin-back{padding:6px 14px;background:#0f3460;border:none;border-radius:4px;font-size:13px;color:#a0c0e0;cursor:pointer;margin:16px 16px 0;align-self:flex-start;transition:background .15s}.admin-back:hover{background:#1a4a80}.admin-section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.admin-section__header h3{font-size:16px;font-weight:600;color:#e0e0e0;margin:0}.admin-section__header--sub{margin-top:20px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #2a3a5e}.admin-section__header--sub h4{font-size:14px;font-weight:600;color:#a0c0e0;margin:0}.admin-client-users-section{margin-bottom:16px}.admin-client-users-section .admin-loading{font-size:13px;color:#666;padding:8px 0}.admin-section__actions{display:flex;align-items:center;gap:12px}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{text-align:left;padding:8px 10px;background:#0f3460;color:#a0c0e0;font-weight:600;font-size:12px}.admin-table td{padding:8px 10px;border-bottom:1px solid #0f3460;color:#e0e0e0}.admin-table code{font-size:11px;background:#1a1a2e;padding:2px 6px;border-radius:3px}.admin-table__actions{display:flex;gap:4px}.admin-table__empty{text-align:center;color:#606080;padding:20px!important}.admin-client-id{font-family:monospace;font-size:10px;background:#0e0e1a;border:1px solid #2a3a5e;border-radius:3px;color:#6090c0;padding:2px 5px;width:220px;cursor:text;-webkit-user-select:all;user-select:all}.admin-btn{padding:6px 12px;background:#0f3460;border:none;border-radius:4px;font-size:12px;color:#e0e0e0;cursor:pointer;transition:background .15s}.admin-btn:hover{background:#1a4a80}.admin-btn--create{background:#4ade80;color:#000;font-weight:600}.admin-btn--create:hover{background:#22c55e}.admin-btn--danger{background:#ef4444;color:#fff}.admin-btn--danger:hover{background:#dc2626}.admin-btn--small{padding:4px 8px;font-size:11px}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.admin-badge--green{background:#4ade8033;color:#4ade80}.admin-badge--red{background:#ef444433;color:#ef4444}.admin-badge--blue{background:#60a5fa33;color:#60a5fa}.admin-filter{display:flex;align-items:center;gap:6px;font-size:12px;color:#a0a0b0;cursor:pointer}.admin-filter input[type=checkbox]{accent-color:#e94560}.admin-select-filter{padding:5px 10px;background:#1a1a2e;color:#e0e0e0;border:1px solid #0f3460;border-radius:4px;font-size:12px;outline:none}.admin-select-filter:focus{border-color:#e94560}.admin-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.admin-modal{background:#16213e;border:1px solid #0f3460;border-radius:8px;padding:20px;min-width:400px;max-width:500px;max-height:80vh;overflow-y:auto}.admin-modal h3{font-size:16px;margin:0 0 16px;color:#e0e0e0}.admin-form{display:flex;flex-direction:column;gap:10px}.admin-form__field{display:flex;flex-direction:column;gap:4px}.admin-form__field label{font-size:11px;color:#808098}.admin-form__field input[type=text],.admin-form__field input[type=email],.admin-form__field input[type=number],.admin-form__field select,.admin-form__field textarea{padding:6px 10px;background:#1a1a2e;color:#e0e0e0;border:1px solid #0f3460;border-radius:4px;font-size:13px;outline:none}.admin-form__field input:focus,.admin-form__field select:focus,.admin-form__field textarea:focus{border-color:#e94560}.admin-form__field input[type=checkbox]{accent-color:#e94560}.admin-form__checkbox{flex-direction:row;align-items:center;gap:8px}.admin-form__checkbox label{font-size:13px;color:#e0e0e0}.admin-form__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.admin-json-editor{font-family:monospace;font-size:12px;resize:vertical;min-height:80px}.admin-error{padding:6px 10px;background:#ef444426;border:1px solid #ef4444;border-radius:4px;font-size:12px;color:#ef4444}.admin-success{padding:6px 10px;background:#4ade8026;border:1px solid #4ade80;border-radius:4px;font-size:12px;color:#4ade80;margin-top:8px}.admin-loading{color:#606080;font-size:13px;padding:20px;text-align:center}.admin-iot-status{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.admin-iot-status__row{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#1a1a2e;border-radius:4px;font-size:13px;color:#e0e0e0}.admin-groups{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.admin-groups label{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 10px;background:#1a1a2e;border-radius:4px;cursor:pointer;color:#e0e0e0}.admin-groups input[type=checkbox]{accent-color:#e94560}.admin-floorplan-row{display:flex;align-items:center;gap:8px}.admin-floorplan-preview{max-width:100%;max-height:300px;border-radius:4px;margin-top:8px}.admin-import-progress{font-size:12px;color:#a0a0b0;margin-top:4px}.admin-iot-subtabs{display:flex;gap:0;border-bottom:2px solid #0f3460;margin-bottom:0}.admin-iot-subtab{padding:8px 18px;font-size:13px;color:#6090c0;cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.admin-iot-subtab:hover{color:#a0c0e0}.admin-iot-subtab--active{color:#a0c0e0;border-bottom-color:#e94560}.admin-iot-frame-wrap{flex:1;min-height:0}.admin-iot-iframe{width:100%;height:calc(100vh - 160px);border:none;background:#1a1a2e}.sv-panel-right{width:400px;height:100%;background:#0f1219;border-left:2px solid #1e2636;display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.sv-panel-header{display:flex;align-items:center;padding:12px 16px;background:#0b0e14;border-bottom:1px solid #1e2636;flex-shrink:0}.sv-panel-header h3{margin:0;font-size:15px;font-weight:700;color:#f1f5f9}.sv-header-badges{display:flex;align-items:center;gap:8px;margin-left:auto;margin-right:12px}.sv-ws-dot{width:8px;height:8px;border-radius:50%;background:#4a5568}.sv-ws-dot.connected{background:#4ade80;box-shadow:0 0 6px #4ade8066}.sv-ws-dot.disconnected{background:#ef4444}.sv-panel-close{background:none;border:none;color:#4a5568;font-size:22px;cursor:pointer;padding:0 4px;transition:color .2s}.sv-panel-close:hover{color:#e94560}.sv-section{padding:10px 14px;flex-shrink:0;overflow-y:auto}.sv-section h4{margin:0 0 8px;font-size:12px;font-weight:700;color:#7a8da0;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:8px}.sv-section-alerts{max-height:40%}.sv-section-history{max-height:25%}.sv-divider{height:1px;background:#1e2636;flex-shrink:0}.sv-mini-tabs{display:flex;background:#0b0e14;border-top:1px solid #1e2636;border-bottom:1px solid #1e2636;flex-shrink:0}.sv-mini-tab{flex:1;padding:8px 0;color:#6b7a8d;cursor:pointer;border:none;border-bottom:2px solid transparent;background:none;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;text-align:center;transition:color .2s,border-bottom-color .2s,background .2s}.sv-mini-tab.active{color:#fff;border-bottom-color:#e94560;background:#e9456014}.sv-mini-tab:hover:not(.active){color:#a0b0c0;background:#ffffff08}.sv-mini-content{flex:1;overflow:hidden}.sv-mini-panel{display:none;flex-direction:column;height:100%;overflow:hidden;padding:10px 14px}.sv-mini-panel.active{display:flex}.sv-alerts-list{flex:1;overflow-y:auto;gap:8px;display:flex;flex-direction:column}.sv-alert-card{background:#161c28;border-radius:8px;padding:10px 12px;border:1px solid #1e2636;border-left:4px solid;display:flex;flex-direction:column;gap:6px;box-shadow:0 2px 8px #0000004d;cursor:pointer;transition:background .2s}.sv-alert-card:hover{background:#1c2538}.sv-alert-card.fall{border-left-color:#ef4444;background:linear-gradient(135deg,#161c28,#1a1520)}.sv-alert-card.help{border-left-color:#f59e0b;background:linear-gradient(135deg,#161c28,#1a1a15)}.sv-alert-card.sv-alert-resolved{opacity:.4;transition:opacity 1s}.sv-alert-card .sv-alert-header{display:flex;justify-content:space-between;align-items:center}.sv-alert-card .sv-alert-type{font-weight:800;font-size:12px;color:#f87171}.sv-alert-card .sv-alert-badge-code{font-weight:700;color:#f1f5f9;font-size:13px}.sv-alert-card .sv-alert-status{font-size:10px;padding:2px 8px;border-radius:4px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.sv-status-pending{background:#f59e0b30;color:#fbbf24;border:1px solid #f59e0b44}.sv-status-confirmed{background:#ef444430;color:#f87171;border:1px solid #ef444444}.sv-status-escalated{background:#dc262630;color:#f87171;border:1px solid #dc262644;animation:sv-blink 1s infinite}.sv-alert-progress{height:3px;background:#1e2636;border-radius:2px}.sv-alert-progress-bar{height:100%;border-radius:2px;width:0%;transition:width .5s linear}.sv-alert-card .sv-alert-actions{display:flex;gap:6px}.sv-alert-card .sv-alert-actions button{font-size:10px;padding:3px 10px;border-radius:4px;border:none;cursor:pointer;font-weight:600;transition:filter .2s}.sv-alert-card .sv-alert-actions button:hover{filter:brightness(1.15)}.sv-alert-audio{background:#3b82f6;color:#fff}.sv-alert-resolve{background:#22c55e;color:#fff}.sv-alert-focus{background:#1e2636;color:#a0b0c0;border:1px solid #2a3a52!important}.sv-badge{background:#ef4444;color:#fff;font-size:10px;border-radius:8px;padding:1px 6px;font-weight:700}.sv-empty{color:#4a5568;text-align:center;padding:20px;font-style:italic;font-size:12px}.sv-history-list{overflow-y:auto}.sv-history-item{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid #141a24;font-size:12px}.sv-history-time{color:#4a5568;font-family:Consolas,Monaco,monospace;font-size:11px;flex-shrink:0}.sv-history-type{font-weight:700;font-size:10px;padding:1px 6px;border-radius:3px;text-transform:uppercase;flex-shrink:0}.sv-history-type.fall{background:#ef444430;color:#f87171}.sv-history-type.help{background:#f59e0b30;color:#fbbf24}.sv-history-badge{color:#c0cad8;font-weight:600}.sv-history-status{color:#4a5568;font-size:10px;margin-left:auto;text-transform:uppercase}.sv-events-toolbar{display:flex;gap:6px;align-items:center;margin-bottom:8px;flex-shrink:0;flex-wrap:wrap}.sv-events-toolbar select,.sv-events-toolbar input{background:#0b0e14;border:1px solid #1e2636;color:#d0d8e4;padding:4px 8px;border-radius:4px;font-size:11px;transition:border-color .2s}.sv-events-toolbar select:focus,.sv-events-toolbar input:focus{border-color:#3b82f6;outline:none}.sv-events-table-wrap{flex:1;overflow-y:auto;font-size:11px;border-radius:6px;border:1px solid #1e2636}.sv-events-table{width:100%;border-collapse:collapse}.sv-events-table th{position:sticky;top:0;background:#0b0e14;color:#7a8da0;font-weight:700;text-align:left;padding:5px 8px;font-size:10px;text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid #1e2636}.sv-events-table td{padding:3px 8px;color:#c0cad8;border-bottom:1px solid #141a24;white-space:nowrap;font-family:Consolas,Monaco,monospace;font-size:11px}.sv-events-table tr:nth-child(2n){background:#0b0e14}.sv-events-table tr:hover{background:#1a2030}td.type-heartbeat{color:#4ade80;font-weight:600}td.type-button_event{color:#fbbf24;font-weight:600}td.type-movement_status{color:#60a5fa;font-weight:600}td.type-battery_update{color:#c084fc;font-weight:600}td.type-position_update{color:#22d3ee;font-weight:600}td.type-fall_alert{color:#f87171;font-weight:600}td.type-ble_beacon{color:#2dd4bf;font-weight:600}td.type-access_control{color:#f472b6;font-weight:600}.sv-badges-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:8px;flex-shrink:0}.sv-badges-toolbar select,.sv-badges-toolbar input{background:#0b0e14;border:1px solid #1e2636;color:#d0d8e4;padding:4px 8px;border-radius:4px;font-size:11px}.sv-badges-toolbar input:focus{border-color:#3b82f6;outline:none}.sv-badges-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.sv-badge-card{background:#161c28;border-radius:6px;padding:10px 12px;cursor:pointer;transition:background .2s,border-color .2s;border:1px solid #1e2636}.sv-badge-card:hover{background:#1c2538;border-color:#2a3a52}.sv-badge-card .sv-badge-name{font-weight:700;color:#f1f5f9;font-size:13px}.sv-badge-card .sv-badge-info{display:flex;gap:10px;margin-top:4px;font-size:11px;color:#7a8da0}.sv-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:10px}.sv-stat-card{background:#161c28;border-radius:6px;padding:12px;text-align:center;border:1px solid #1e2636}.sv-stat-value{font-size:24px;font-weight:800;color:#fff}.sv-stat-label{font-size:10px;color:#6b7a8d;margin-top:2px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.sv-ws-ok{color:#4ade80!important}.sv-ws-off{color:#ef4444!important}.sv-recent-events{flex:1;overflow-y:auto;font-size:11px;color:#7a8da0}.sv-recent-row{padding:3px 0;border-bottom:1px solid #141a24}.sv-btn-sm{background:#1e2636;border:1px solid #2a3a52;color:#a0b0c0;padding:4px 10px;border-radius:4px;cursor:pointer;font-size:10px;font-weight:600;transition:background .2s,border-color .2s}.sv-btn-sm:hover{background:#2a3a52;border-color:#3a4e6a}.sv-stat-chip{background:#161c28;color:#7a8da0;padding:3px 8px;border-radius:10px;font-size:10px;font-weight:600;border:1px solid #1e2636}@keyframes sv-blink{0%,to{opacity:1}50%{opacity:.4}}.supervision-toggle-group{display:inline-flex;align-items:center}.btn-supervision{padding:6px 14px;background:#fb923c;border:none;border-radius:4px;font-size:13px;color:#fff;cursor:pointer;font-weight:600;transition:background .2s}.btn-supervision:hover{background:#f97316}.btn-supervision.active{background:#f97316;box-shadow:0 0 0 2px #f9731644}.btn-supervision.hidden{display:none}.btn-supervision.sv-off{background:#4a5568;cursor:default}.btn-supervision.sv-off:hover{background:#4a5568}.sv-switch{position:relative;display:inline-block;width:36px;height:20px;margin-left:6px;margin-right:8px;flex-shrink:0}.sv-switch input{opacity:0;width:0;height:0}.sv-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:#4a5568;border-radius:20px;transition:.3s}.sv-slider:before{content:"";position:absolute;height:14px;width:14px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}.sv-switch input:checked+.sv-slider{background:#fb923c}.sv-switch input:checked+.sv-slider:before{transform:translate(16px)}.fullscreen-alert{position:fixed;top:0;right:0;bottom:0;left:0;z-index:5000;display:flex;align-items:center;justify-content:center}.fullscreen-alert-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000e0}.fullscreen-alert-content{position:relative;z-index:1;background:#0f1219;border-radius:12px;width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0009;border:1px solid #1e2636}.fsa-header{padding:22px 24px;border-radius:12px 12px 0 0;text-align:center}.fsa-timer-bar{height:6px;background:#1e2636;overflow:hidden}.fsa-timer-fill{height:100%;width:0%;background:#4ade80;transition:width 1s linear,background .5s}.fsa-timer-fill.warning{background:#fbbf24}.fsa-timer-fill.critical{background:#ef4444;animation:sv-blink .5s infinite}.fsa-timer-label{text-align:center;font-size:28px;font-weight:800;font-family:Consolas,Monaco,monospace;color:#4ade80;padding:8px 0 4px}.fsa-timer-label.warning{color:#fbbf24}.fsa-timer-label.critical{color:#ef4444;animation:sv-blink .5s infinite}.fsa-header.fall{background:linear-gradient(135deg,#dc2626,#991b1b)}.fsa-header.help{background:linear-gradient(135deg,#d97706,#92400e)}.fsa-title{color:#fff;font-size:22px;margin:0;font-weight:800}.fsa-info{padding:18px 24px}.fsa-info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #1e2636}.fsa-info-row label{color:#6b7a8d;font-size:13px;font-weight:600}.fsa-info-row span{color:#f1f5f9;font-size:13px;font-weight:600}.fsa-audio-section{padding:18px 24px}.fsa-audio-section h3{color:#f1f5f9;font-size:15px;margin:0 0 12px}.fsa-quick-messages{display:flex;flex-direction:column;gap:6px}.fsa-radio{display:flex;align-items:center;padding:10px 14px;background:#161c28;border-radius:6px;cursor:pointer;border:2px solid #1e2636;transition:all .2s}.fsa-radio:hover{border-color:#3b82f644;background:#1a2232}.fsa-radio.selected{border-color:#3b82f6;background:#152040}.fsa-radio input{display:none}.fsa-radio-label{color:#c0cad8;font-size:13px}.fsa-catalog-expand{margin-top:10px}.fsa-catalog-expand summary{color:#60a5fa;cursor:pointer;font-size:13px}.fsa-catalog-select{width:100%;margin-top:6px;background:#0b0e14;border:1px solid #1e2636;color:#d0d8e4;padding:6px 8px;border-radius:4px}.fsa-actions{display:flex;gap:10px;margin-top:16px}.fsa-btn{padding:12px 22px;border:none;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:filter .2s}.fsa-btn:hover{filter:brightness(1.1)}.fsa-btn-send{background:#3b82f6;color:#fff;flex:1}.fsa-btn-send:hover{background:#2563eb}.fsa-btn-cancel{background:#dc2626;color:#fff}.fsa-btn-cancel:hover{background:#b91c1c}.fsa-btn-secondary{background:#2a3a52;color:#d0d8e4}.fsa-btn-secondary:hover{background:#3a4e6a}.fsa-feedback{padding:10px 14px;border-radius:6px;font-size:13px;margin-top:10px;font-weight:600}.fsa-feedback.success{background:#22c55e22;color:#4ade80;border:1px solid #22c55e33}.fsa-feedback.error{background:#ef444422;color:#f87171;border:1px solid #ef444433}.sv-toast-container{position:fixed;top:80px;right:20px;z-index:4000;display:flex;flex-direction:column;gap:8px}.sv-toast{background:#161c28;border:1px solid #1e2636;border-left:4px solid #3b82f6;border-radius:6px;padding:12px 16px;color:#f1f5f9;font-size:13px;animation:sv-toast-in .3s ease-out;max-width:360px;box-shadow:0 4px 16px #0006}.sv-toast-alert{border-left-color:#ef4444}.sv-toast-success{border-left-color:#22c55e}.sv-toast-error{border-left-color:#ef4444}@keyframes sv-toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}
