@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;600&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0f7fc;--bg2:#fff;--bg3:#e6f4fb;--border:#dde9f2;--t1:#1a2e3f;--t2:#4a7a95;--t3:#8ab0c5;--blue:#19a7ce;--green:#34d399;--red:#f87171;--yellow:#fbbf24;--r:12px;--rx:20px;--tr:.22s ease}html,body,#root{background:var(--bg);height:100%;color:var(--t1);font-family:Inter,sans-serif;overflow:hidden}button{cursor:pointer;border:none;outline:none;font-family:inherit}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:#b8d4e3;border-radius:99px}.sidebar,.sidebar .nav-item{color:#afd3e2}.sidebar .logo-sub{color:#afd3e280}.alert-log{background:#ffffff0a;border:1px solid #ffffff12}.log-header{color:#afd3e2}.log-empty{color:#5a8aa8}.log-time,.log-room{color:#4a7a9a}.log-item{background:#ffffff08}.dashboard{grid-template-columns:300px 1fr;height:100vh;display:grid;overflow:hidden}.sidebar{color:#ddf2fd;background:#146c94;border-right:none;flex-direction:column;gap:0;padding:0;display:flex;overflow-y:auto}.sidebar .nav-item{color:#ddf2fdbf;border:1px solid #0000}.sidebar .nav-item:hover:not(:disabled){color:#ddf2fd;background:#ffffff1f}.sidebar .nav-item-active{border:1px solid #ffffff4d;box-shadow:inset 3px 0 #fff;color:#fff!important;background:#fff3!important}.sidebar .nav-item:disabled{opacity:.4;cursor:not-allowed}.logo{border-bottom:1px solid #ffffff26;flex-direction:column;margin-bottom:0;padding:20px 20px 16px;display:flex}.logo-sub{color:#ddf2fd8c;text-transform:uppercase;letter-spacing:2px;margin-top:4px;font-size:9px;font-weight:600}.sidebar-body{flex-direction:column;flex:1;gap:12px;padding:0 16px 16px;display:flex}.conn-badge{color:#ddf2fd;background:#ffffff1a;border:1px solid #fff3;border-radius:99px;align-items:center;gap:6px;width:fit-content;padding:6px 12px;font-size:11px;font-weight:600;display:flex}.conn-on{color:#a7f3d0;background:#34d39926;border:1px solid #34d39959}.conn-off{color:#fecaca;background:#f8717126;border:1px solid #f871714d}.conn-dot{background:#444;border-radius:50%;width:7px;height:7px}.conn-dot-on{background:#34d399;box-shadow:0 0 6px #34d399}.sidebar-alert-banner{color:#fca5a5;background:#f871711f;border:1px solid #f871714d;border-radius:8px;padding:8px 12px;font-size:12px;font-weight:600;animation:1.4s ease-in-out infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.6}}.sidebar-nav{flex-direction:column;gap:4px;margin-top:8px;display:flex}.nav-item{color:var(--t2);text-align:left;transition:all var(--tr);background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.nav-item:hover:not(:disabled){color:var(--t1);background:#ffffff08}.nav-item-active{border:1px solid #19a7ce59;box-shadow:inset 2px 0 #19a7ce;color:#ddf2fd!important;background:linear-gradient(90deg,#19a7ce40,#19a7ce0d)!important}.nav-item:disabled{opacity:.4;cursor:not-allowed}.alert-log{border-radius:var(--r);background:#0000001f;border:1px solid #ffffff1f;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.log-header{color:#ddf2fdb3;cursor:pointer;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:9px 12px;font-size:12px;font-weight:600;display:flex}.log-header:hover{background:#ffffff0d}.log-badge{background:var(--red);color:#fff;border-radius:99px;margin-left:4px;padding:1px 6px;font-size:10px;font-weight:700}.log-list{flex-direction:column;gap:3px;max-height:200px;padding:6px;display:flex;overflow-y:auto}.log-empty{color:#ddf2fd73;text-align:center;padding:14px 0;font-size:11px}.log-item{background:#ffffff0f;border-left:3px solid;border-radius:0 6px 6px 0;padding:7px 9px}.log-top{justify-content:space-between;align-items:center;display:flex}.log-time{color:#ddf2fd80;font-family:JetBrains Mono,monospace;font-size:10px}.log-room{color:#ddf2fd80;margin-top:2px;font-size:10px}.main-content{flex-direction:column;display:flex;overflow:hidden}.page-header{border-bottom:1px solid #19a7ce33;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:18px 24px 14px;display:flex}.page-title{letter-spacing:-.3px;font-size:18px;font-weight:700}.page-desc{color:var(--t2);margin-top:2px;font-size:12px}.header-stats{flex-wrap:wrap;gap:8px;display:flex}.stat-pill{color:var(--t2);background:#19a7ce14;border:1px solid #19a7ce33;border-radius:99px;align-items:center;gap:5px;padding:4px 10px;font-size:11px;display:flex}.stat-pill-danger{color:#fca5a5;background:#ef444414;border-color:#ef44444d}.stat-dot{border-radius:50%;width:6px;height:6px}.stat-green{background:#4ade80;box-shadow:0 0 5px #4ade80}.stat-blue{background:var(--blue);box-shadow:0 0 5px var(--blue)}.stat-red{background:var(--red);animation:1s infinite blink}.dashboard-danger{animation:.5s ease-in-out screen-shake}.dashboard-danger:after{content:"";pointer-events:none;z-index:9999;animation:1s ease-in-out infinite glow-pulse;position:fixed;inset:0;box-shadow:inset 0 0 120px #ef444466}@keyframes glow-pulse{0%,to{opacity:.6}50%{opacity:1}}@keyframes screen-shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-4px)}40%,80%{transform:translate(4px)}}.floor-plan{flex:1;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));align-content:start;gap:24px;padding:28px 32px;display:grid;overflow-y:auto}.room-card{text-align:left;cursor:pointer;background:#fff;border:1px solid #19a7ce33;border-radius:20px;flex-direction:column;min-height:165px;padding:0;transition:transform .3s cubic-bezier(.34,1.56,.64,1),border-color .3s,box-shadow .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 16px #146c9414,0 0 0 1px #19a7ce0f}.room-card:hover{border-color:var(--ra,var(--blue));box-shadow:0 12px 32px #146c942e, 0 0 0 1.5px var(--ra,var(--blue));transform:translateY(-4px)}.room-card-alert{animation:1.4s ease-in-out infinite pulse-card}@keyframes pulse-card{0%,to{transform:scale(1)}50%{transform:scale(1.018)}}.rc-accent-bar{background:linear-gradient(90deg,var(--ra,var(--blue)),var(--ra,var(--blue))44,transparent);opacity:.7;flex-shrink:0;width:100%;height:4px;transition:opacity .3s}.room-card:hover .rc-accent-bar{opacity:1}.rc-body{flex-direction:column;flex:1;gap:0;padding:18px 20px 16px;display:flex}.rc-gradient{display:none}.rc-mini-feed{opacity:0;border-radius:inherit;z-index:0;pointer-events:none;background:#071f33;transition:opacity .35s;position:absolute;inset:0;overflow:hidden}.room-card:hover .rc-mini-feed,.room-card.room-card-alert .rc-mini-feed{opacity:1}.rc-mf-grid{background-image:linear-gradient(#ffffff06 1px,#0000 1px),linear-gradient(90deg,#ffffff06 1px,#0000 1px);background-size:22px 22px;position:absolute;inset:0}.rc-mf-scanline{background:linear-gradient(#0000,#ffffff0f,#0000);height:60px;animation:2.8s linear infinite mf-scan;position:absolute;left:0;right:0}@keyframes mf-scan{0%{top:-60px}to{top:100%}}.rc-mf-rec{color:#ffffffa6;letter-spacing:1px;z-index:2;align-items:center;gap:4px;font-size:8px;font-weight:800;display:flex;position:absolute;top:10px;right:10px}.rc-mf-rec-dot{background:#ef4444;border-radius:50%;width:5px;height:5px;animation:1.2s ease-in-out infinite rec-blink}@keyframes rec-blink{0%,to{opacity:1}50%{opacity:.2}}.rc-mf-bbox{z-index:2;transition:all .45s cubic-bezier(.4,0,.2,1);position:absolute}.rc-mini-feed-fade{z-index:3;background:linear-gradient(#050a1233 0%,#050a128c 55%,#050a12f2 100%);position:absolute;inset:0}.rc-pulse-ring{border-radius:calc(var(--rx) + 2px);pointer-events:none;z-index:4;border:2px solid;animation:1.4s ease-out infinite ring-pulse;position:absolute;inset:-2px}@keyframes ring-pulse{0%{opacity:.9;transform:scale(1)}to{opacity:0;transform:scale(1.06)}}.rc-content{z-index:5;flex-direction:column;flex:1;gap:0;display:flex;position:relative}.rc-header{justify-content:space-between;align-items:flex-start;margin-bottom:10px;display:flex}.rc-icon-box{background:#19a7ce1a;border:1px solid #19a7ce33;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;transition:all .3s;display:flex}.room-card:hover .rc-icon-box{background:#19a7ce2e;transform:scale(1.05)}.rc-icon-box svg{opacity:1}.rc-alert-tag{letter-spacing:.5px;text-transform:uppercase;border-radius:99px;padding:4px 8px;font-size:10px;font-weight:800}.rc-name{color:#0d2035;margin-top:2px;font-size:16px;font-weight:700;line-height:1.3}.rc-en{color:var(--t3);text-transform:uppercase;letter-spacing:1px;margin-top:2px;margin-bottom:12px;font-size:11px}.rc-status-row{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.rc-alert-info{align-items:center;gap:6px;font-size:11px;font-weight:700;display:flex}.rc-alert-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:.8s ease-in-out infinite blink}.rc-status-ok{color:var(--t3);align-items:center;gap:6px;font-size:11px;font-weight:500;display:flex}.rc-ok-dot{background:#4ade80;border-radius:50%;flex-shrink:0;width:7px;height:7px;box-shadow:0 0 5px #4ade8066}.rc-click-hint{color:color-mix(in srgb,var(--ra,var(--blue)) 80%,transparent);letter-spacing:.5px;text-transform:uppercase;opacity:0;margin-top:6px;font-size:9px;font-weight:600;transition:opacity .2s}.room-card:hover .rc-click-hint{opacity:1}.room-detail-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#000000bf;justify-content:center;align-items:center;padding:20px;animation:.2s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.room-detail-panel{background:#fff;border:1px solid #19a7ce4d;border-radius:24px;width:100%;max-width:900px;max-height:90vh;padding:28px;animation:.25s slide-up;position:relative;overflow-y:auto;box-shadow:0 8px 40px #146c9426,0 0 0 1px #19a7ce1a}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.rdp-nav{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.rdp-counter{color:var(--t3);border:1px solid var(--border);background:#19a7ce0f;border-radius:6px;padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:12px}.rdp-close{border:1px solid var(--border);color:var(--t2);width:30px;height:30px;transition:background var(--tr);background:#146c9414;border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex}.rdp-close:hover{border-color:var(--red);color:#f87171;background:#ef444426}.rdp-bg-number{color:#19a7ce0d;pointer-events:none;font-family:JetBrains Mono,monospace;font-size:100px;font-weight:900;line-height:1;position:absolute;top:16px;right:28px}.rdp-content{grid-template-columns:1fr 1fr;gap:28px;display:grid}@media (width<=700px){.rdp-content{grid-template-columns:1fr}}.rdp-left,.rdp-right{flex-direction:column;gap:16px;display:flex}.rdp-title-row{align-items:flex-start;gap:12px;display:flex}.rdp-emoji{flex-shrink:0;font-size:36px}.rdp-title{color:var(--ra,var(--t1));font-size:22px;font-weight:800}.rdp-desc{color:var(--t2);margin-top:4px;font-size:12px;line-height:1.5}.rdp-section-title{color:var(--t1);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border);padding-bottom:8px;font-size:13px;font-weight:700}.camera-feed{flex-direction:column;gap:10px;width:100%;display:flex}.cam-inner{border:1.5px solid var(--cam-color,#818cf8);background:radial-gradient(at 60% 40%,#0d2540,#071520);border-radius:14px;justify-content:center;align-items:center;width:100%;height:180px;display:flex;position:relative;overflow:hidden}.cam-inner:after{content:"";pointer-events:none;opacity:.4;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");position:absolute;inset:0}.cam-grid{background-image:linear-gradient(#ffffff08 1px,#0000 1px),linear-gradient(90deg,#ffffff08 1px,#0000 1px);background-size:24px 24px;position:absolute;inset:0}.cam-actions-overlay{z-index:10;opacity:0;align-items:center;gap:6px;transition:opacity .25s;display:flex;position:absolute;top:8px;right:8px}.cam-inner:hover .cam-actions-overlay{opacity:1}.cam-overlay-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;background:#00000080;border:1px solid #ffffff26;border-radius:6px;align-items:center;gap:5px;padding:5px 8px;font-size:10px;font-weight:600;transition:all .2s;display:flex}.cam-overlay-btn:hover{color:#7dd3fc;background:#38bdf840;border-color:#38bdf866}.cam-save-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0a0f1ef2;border:1px solid #ffffff26;border-radius:10px;flex-direction:column;width:230px;animation:.15s fade-in;display:flex;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 10px 30px #000c,0 0 0 1px #00000080}.cam-save-menu-title{color:var(--t3);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #ffffff0d;padding:10px 12px 6px;font-size:10px;font-weight:700}.cam-save-item{color:var(--t2);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:10px 12px;font-size:12px;transition:all .2s;display:flex}.cam-save-item:hover{color:#fff;background:#38bdf826}.cam-save-item:last-child{color:#9ca3af;border-top:1px solid #ffffff0d;font-size:11px}.cam-zoomed-backdrop{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:99999;background:#02060fe6;animation:.25s fade-in;position:fixed;inset:0}.cam-zoomed{z-index:100000;max-width:1400px;max-height:900px;box-shadow:0 20px 80px #000c, 0 0 40px color-mix(in srgb, var(--cam-color) 30%, transparent);border-width:2px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:85vw!important;height:75vh!important}.cam-timestamp{z-index:5;color:var(--cam-color,#818cf8);opacity:.7;letter-spacing:.5px;font-family:JetBrains Mono,monospace;font-size:9px;position:absolute;bottom:8px;left:10px}.cam-rec{z-index:5;color:#ef4444;letter-spacing:.5px;align-items:center;gap:5px;font-size:9px;font-weight:700;display:flex;position:absolute;top:8px;left:10px}.cam-rec-dot{background:#ef4444;border-radius:50%;width:5px;height:5px;animation:.9s ease-in-out infinite blink}.cam-id{z-index:5;color:var(--cam-color,#818cf8);opacity:.6;font-family:JetBrains Mono,monospace;font-size:8px;position:absolute;top:8px;right:10px}.cam-scanline{background:linear-gradient(90deg,transparent,var(--cam-color,#818cf8)88,transparent);filter:blur(1px);z-index:3;height:2px;transition:top 25ms linear;position:absolute;left:0;right:0}.cam-detect-area{z-index:4;justify-content:center;align-items:center;width:90px;height:90px;display:flex;position:relative}.cam-face-box{border:2px solid var(--cam-color,#818cf8);border-radius:4px;transition:border-color .3s,box-shadow .3s;position:absolute;inset:0}.cam-face-box-alert{animation:.8s ease-in-out infinite box-pulse;box-shadow:0 0 16px #ef444466;border-color:#ef4444!important}.cam-face-box-match{box-shadow:0 0 16px #22c55e66;border-color:#22c55e!important}@keyframes box-pulse{0%,to{opacity:1}50%{opacity:.6}}.cam-corner{border-color:var(--cam-color,#818cf8);border-style:solid;width:14px;height:14px;transition:border-color .3s;position:absolute}.cam-tl{border-width:2px 0 0 2px;border-radius:2px 0 0;top:-2px;left:-2px}.cam-tr{border-width:2px 2px 0 0;border-radius:0 2px 0 0;top:-2px;right:-2px}.cam-bl{border-width:0 0 2px 2px;border-radius:0 0 0 2px;bottom:-2px;left:-2px}.cam-br{border-width:0 2px 2px 0;border-radius:0 0 2px;bottom:-2px;right:-2px}.cam-person-icon{opacity:.5;transition:opacity .3s}.cam-detect-area:hover .cam-person-icon{opacity:.7}.cam-flash{border-radius:inherit;pointer-events:none;z-index:6;animation:.4s forwards cam-flash-in;position:absolute;inset:0}@keyframes cam-flash-in{0%{opacity:.5}to{opacity:0}}.cam-name-badge{color:#fff;white-space:nowrap;letter-spacing:.3px;z-index:5;background:#22c55ee6;border-radius:4px 4px 0 0;padding:2px 8px;font-size:9px;font-weight:800;position:absolute;bottom:-1px;left:50%;transform:translate(-50%)}.cam-name-badge-alert{background:#ef4444e6}.cam-confidence{color:var(--t3);align-items:center;gap:8px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex}.cam-conf-bar{background:#ffffff14;border-radius:99px;flex:1;height:3px;overflow:hidden}.cam-conf-fill{background:linear-gradient(90deg,var(--cam-color,#818cf8),var(--cam-color,#818cf8)aa);border-radius:99px;height:100%;transition:width 1s}.cam-meta-row{color:var(--t3);text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;font-family:JetBrains Mono,monospace;font-size:9px;display:flex}.rdp-live-alert{border:1px solid;border-radius:12px;flex-direction:column;gap:10px;padding:14px 16px;display:flex;position:relative;overflow:hidden}.rdp-live-alert-glow{opacity:.06;pointer-events:none;position:absolute;inset:0}.rdp-live-top{align-items:center;gap:10px;display:flex}.rdp-live-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:.7s infinite blink}.rdp-live-label{flex:1;font-size:14px;font-weight:800}.rdp-live-time{opacity:.6;font-family:JetBrains Mono,monospace;font-size:10px}.rdp-live-msg{color:var(--t2);padding-left:18px;font-size:12px;line-height:1.5}.rdp-live-person{background:#ffffff0a;border:1px solid #ffffff0f;border-radius:8px;align-items:center;gap:8px;padding:8px 12px 8px 18px;display:flex}.rdp-live-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:10px;font-weight:800;display:flex}.rdp-live-pname{color:var(--t1);font-size:12px;font-weight:700}.rdp-live-prole{color:var(--t3);font-size:10px}.rdp-live-conf{margin-left:auto;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700}.rdp-live-ok{color:var(--t3);border:1px solid var(--border);background:#ffffff08;border-radius:10px;align-items:center;gap:8px;padding:12px 14px;font-size:12px;display:flex}.rdp-ok-dot{background:#4ade80;border-radius:50%;flex-shrink:0;width:7px;height:7px;box-shadow:0 0 6px #4ade8066}.rdp-stat{border:1px solid var(--border);background:#ffffff08;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.rdp-stat-label{color:var(--t3);font-size:11px}.rdp-stat-value{font-family:JetBrains Mono,monospace;font-size:18px;font-weight:800}.toast-container{z-index:1000;pointer-events:none;flex-direction:column;align-items:flex-end;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:all;border:1px solid;border-radius:14px;align-items:flex-start;gap:12px;width:340px;padding:14px 16px;animation:.3s cubic-bezier(.34,1.56,.64,1) forwards toast-in;display:flex;box-shadow:0 8px 32px #0006}@keyframes toast-in{0%{opacity:0;transform:translateY(16px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.toast-leaving{animation:.25s forwards toast-out}@keyframes toast-out{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(8px)scale(.96)}}.toast-icon-box{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.toast-content{flex:1;min-width:0}.toast-title{color:var(--t1);font-size:13px;font-weight:800}.toast-room{color:var(--t2);margin-top:2px;font-size:11px}.toast-msg{color:var(--t3);margin-top:4px;font-size:11px;line-height:1.4}.toast-time{color:var(--t3);flex-shrink:0;margin-top:2px;font-family:JetBrains Mono,monospace;font-size:9px}.rdp-workflow{flex-direction:column;gap:6px;display:flex}.rdp-workflow-step{border:1px solid var(--border);background:#ffffff08;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex}.rdp-step-num{background:var(--ra,var(--blue));color:#000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:800;display:flex}.rdp-step-label{color:var(--t1);font-size:12px}.rdp-arrow-down{text-align:center;color:var(--t3);margin:-2px 0;font-size:18px}.rdp-outcomes{flex-direction:column;gap:6px;display:flex}.rdp-outcome{border:1px solid;border-radius:8px;align-items:center;gap:10px;padding:10px 14px;font-size:12px;font-weight:600;display:flex}.rdp-outcome-success{color:#4ade80;background:#22c55e14;border-color:#22c55e4d}.rdp-outcome-danger{color:#f87171;background:#ef444414;border-color:#ef44444d}.rdp-outcome-warning{color:#fbbf24;background:#f59e0b14;border-color:#f59e0b4d}.rdp-outcome-icon{font-size:16px}.rdp-face-list{flex-direction:column;gap:8px;display:flex}.rdp-face-title{color:var(--t1);align-items:center;gap:8px;margin-bottom:4px;font-size:12px;font-weight:700;display:flex}.rdp-face-count{color:var(--blue);background:#38bdf826;border:1px solid #38bdf84d;border-radius:99px;padding:2px 7px;font-size:10px}.rdp-face-item{border:1px solid var(--border);background:#ffffff08;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;display:flex}.rdp-face-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.rdp-face-name{color:var(--t1);font-size:12px;font-weight:600}.rdp-face-role{color:var(--t3);margin-top:1px;font-size:10px}.rdp-face-access{color:var(--blue);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.rdp-add-face-btn{color:var(--blue);width:100%;transition:background var(--tr);background:#38bdf80f;border:1px dashed #38bdf840;border-radius:8px;padding:8px;font-size:12px}.rdp-add-face-btn:hover{background:#38bdf81f}.rdp-features-title{color:var(--t3);margin-bottom:6px;font-size:11px}.rdp-features-chips{flex-wrap:wrap;gap:6px;display:flex}.rdp-chip{border:1px solid var(--border);color:var(--t2);background:#ffffff0d;border-radius:99px;padding:4px 10px;font-size:10px}.face-page{background:var(--bg);flex-direction:column;gap:24px;height:100vh;padding:24px 32px;display:flex;overflow-y:auto}.face-page-header{align-items:flex-start;gap:16px;display:flex}.back-btn{border:1px solid var(--border);color:var(--t2);white-space:nowrap;transition:background var(--tr);background:#ffffff0d;border-radius:8px;padding:8px 14px;font-size:12px}.back-btn:hover{color:var(--t1);background:#ffffff14}.fp-title{font-size:22px;font-weight:800}.fp-desc{color:var(--t2);margin-top:4px;font-size:13px}.fp-section-title{text-transform:uppercase;letter-spacing:.8px;color:var(--t1);margin-bottom:12px;font-size:13px;font-weight:700}.fp-steps{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.fp-step{background:var(--bg3);border:1px solid var(--border);text-align:center;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:18px;display:flex}.fp-step-num{color:var(--blue);background:#38bdf81a;border:1px solid #38bdf833;border-radius:99px;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700}.fp-step-icon{font-size:28px}.fp-step-label{color:var(--t1);font-size:13px;font-weight:600}.fp-step-desc{color:var(--t3);font-size:11px;line-height:1.5}.fp-list-section{flex-direction:column;gap:12px;display:flex}.fp-list-header{justify-content:space-between;align-items:center;display:flex}.fp-add-btn{color:var(--blue);transition:background var(--tr);background:linear-gradient(135deg,#38bdf826,#38bdf80d);border:1px solid #38bdf84d;border-radius:8px;padding:8px 16px;font-size:12px;font-weight:600}.fp-add-btn:hover{background:#38bdf833}.fp-cards{flex-direction:column;gap:8px;display:flex}.fp-card{background:var(--bg3);border:1px solid var(--border);transition:border-color var(--tr);border-radius:14px;align-items:center;gap:14px;padding:16px 18px;display:flex}.fp-card:hover{border-color:#38bdf84d}.fp-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;display:flex}.fp-name{color:var(--t1);font-size:14px;font-weight:700}.fp-role{color:var(--blue);margin-top:2px;font-size:12px;font-weight:500}.fp-meta{color:var(--t3);margin-top:4px;font-size:10px}.fp-right{flex-direction:column;align-items:flex-end;gap:4px;margin-left:auto;display:flex}.fp-access-count{color:var(--t1);font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700}.fp-status{color:#4ade80;font-size:10px}.fp-card-add{cursor:pointer;text-align:center;background:#ffffff05;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px;transition:background var(--tr)!important;border:1px dashed #38bdf833!important}.fp-card-add:hover{background:#38bdf80d!important}.fp-add-circle{width:42px;height:42px;color:var(--blue);border:2px dashed #38bdf866;border-radius:50%;justify-content:center;align-items:center;font-size:22px;display:flex}.fp-add-label{color:var(--blue);font-size:13px;font-weight:600}.fp-add-sub{color:var(--t3);font-size:11px}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:20px;flex-direction:column;gap:14px;width:100%;max-width:460px;padding:28px;animation:.2s slide-up;display:flex}.modal-title{font-size:18px;font-weight:800}.modal-desc{color:var(--t2);font-size:13px;line-height:1.5}.modal-steps{border:1px solid var(--border);background:#ffffff08;border-radius:10px;flex-direction:column;gap:6px;padding:14px;display:flex}.modal-steps p{color:var(--t2);font-size:12px}.modal-inputs{flex-direction:column;gap:8px;display:flex}.modal-input{border:1px solid var(--border);color:var(--t1);transition:border-color var(--tr);background:#ffffff0a;border-radius:8px;padding:10px 14px;font-family:inherit;font-size:13px}.modal-input:focus{border-color:var(--blue);outline:none}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.modal-cancel{border:1px solid var(--border);color:var(--t2);background:#ffffff0d;border-radius:8px;padding:8px 18px;font-size:12px}.modal-confirm{color:#fff;background:linear-gradient(135deg,#1d4ed8,#0284c7);border:none;border-radius:8px;padding:8px 18px;font-size:12px;font-weight:700}.demo-panel{border-radius:var(--r);background:linear-gradient(135deg,#0e1f10,#0a1a28);border:1px solid #facc1533;flex-shrink:0;overflow:hidden}.demo-header{color:#facc15;cursor:pointer;align-items:center;gap:8px;padding:9px 12px;font-size:12px;font-weight:600;display:flex}.demo-header:hover{background:#facc150a}.demo-body{flex-direction:column;gap:6px;padding:10px;display:flex}.demo-hint{color:var(--t3);font-size:10px;line-height:1.5}.demo-random-btn{color:#facc15;transition:background var(--tr);background:#facc151f;border:1px solid #facc154d;border-radius:6px;justify-content:center;align-items:center;gap:6px;padding:8px;font-size:11px;font-weight:700;display:flex}.demo-random-btn:hover:not(:disabled){background:#facc1533}.demo-random-btn:disabled{opacity:.4}.demo-scenarios{flex-direction:column;gap:3px;display:flex}.demo-scenario-btn{border:1px solid var(--border);color:var(--t2);text-align:left;transition:background var(--tr),color var(--tr);background:#ffffff08;border-radius:6px;padding:6px 10px;font-size:10px}.demo-scenario-btn:hover:not(:disabled){color:var(--t1);background:#ffffff0f}.demo-last{color:var(--t3);font-size:10px}.demo-last code{color:var(--blue);font-family:JetBrains Mono,monospace;font-size:10px}.settings-page{background:var(--bg);flex:1;min-height:100vh;padding:32px;overflow-y:auto}.settings-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:20px;display:flex}.settings-header-left{align-items:flex-start;gap:16px;display:flex}.settings-back-btn{color:var(--t2);transition:all var(--tr);white-space:nowrap;background:#146c9414;border:1px solid #19a7ce40;border-radius:8px;align-items:center;gap:6px;margin-top:4px;padding:8px 14px;font-size:13px;display:flex}.settings-back-btn:hover{color:var(--t1);background:#146c9426}.settings-title{color:#fff;align-items:center;gap:10px;margin-bottom:4px;font-size:22px;font-weight:800;display:flex}.settings-subtitle{color:var(--t2);font-size:13px;line-height:1.5}.settings-saved-badge{color:#4ade80;background:#4ade801a;border:1px solid #4ade8040;border-radius:99px;padding:6px 12px;font-size:12px;font-weight:600;animation:.3s fade-in}.settings-reset-btn{color:#f87171;transition:all var(--tr);background:#ef444414;border:1px solid #ef444433;border-radius:8px;padding:8px 16px;font-size:12px}.settings-reset-btn:hover{background:#ef444429;border-color:#ef444466}.settings-info-banner{background:#19a7ce14;border:1px solid #19a7ce33;border-radius:12px;align-items:flex-start;gap:12px;margin-bottom:28px;padding:14px 18px;display:flex}.settings-info-banner p{color:var(--t2);font-size:13px;line-height:1.6}.settings-rooms-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.settings-room-card{background:#fff;border:1px solid #19a7ce33;border-radius:18px;padding:0;transition:border-color .25s,box-shadow .25s;position:relative;overflow:hidden;box-shadow:0 2px 12px #146c940f}.settings-room-card:hover{border-color:#19a7ce80;box-shadow:0 4px 20px #146c941f}.settings-room-disabled{opacity:.55}.src-top-bar{width:100%;height:3px}.src-header{align-items:center;gap:12px;padding:16px 18px 10px;display:flex}.src-icon-box{background:color-mix(in srgb,var(--ra,#38bdf8) 12%,transparent);border:1px solid color-mix(in srgb,var(--ra,#38bdf8) 25%,transparent);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.src-room-name{font-size:15px;font-weight:700;line-height:1.3}.src-room-en{color:var(--t3);text-transform:uppercase;letter-spacing:1px;margin-top:1px;font-size:10px}.src-toggle{cursor:pointer;border:none;border-radius:99px;flex-shrink:0;width:44px;height:24px;padding:0;transition:background .25s;position:relative}.src-toggle-on{background:color-mix(in srgb,var(--tc,#38bdf8) 80%,transparent)}.src-toggle-off{background:#ffffff1a}.src-toggle-thumb{pointer-events:none;background:#fff;border-radius:50%;width:18px;height:18px;transition:left .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s;position:absolute;top:3px}.src-toggle-on .src-toggle-thumb{box-shadow:0 0 8px var(--tc,#38bdf8);left:23px}.src-toggle-off .src-toggle-thumb{left:3px}.src-section{padding:12px 18px}.src-section-label{color:var(--t3);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:10px;font-weight:700}.src-divider{background:var(--border);height:1px;margin:0}.src-cam-name-row{justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;display:flex}.src-cam-name-text{color:var(--t1);font-size:13px;font-weight:600}.src-link-btn{color:var(--blue);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0;font-size:11px;font-weight:600;transition:opacity .2s}.src-link-btn:hover{opacity:.7}.src-connected-status{background:#22c55e0f;border:1px solid #22c55e33;border-radius:7px;align-items:center;gap:6px;padding:6px 10px;display:flex}.src-connected-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:7px;height:7px;box-shadow:0 0 5px #22c55e88}.src-connected-url{color:#16a34a;white-space:nowrap;text-overflow:ellipsis;flex:1;font-family:JetBrains Mono,monospace;font-size:10px;overflow:hidden}.src-connect-cta{text-align:center;width:100%;color:var(--blue);cursor:pointer;background:#19a7ce14;border:1.5px dashed #19a7ce59;border-radius:8px;margin-top:4px;padding:8px;font-size:12px;font-weight:600;transition:all .2s;display:block}.src-connect-cta:hover{border-color:var(--blue);background:#19a7ce26}.src-inline-edit{align-items:center;gap:5px;display:flex}.src-cam-input{color:var(--t1);background:#f8fbfd;border:1px solid #19a7ce66;border-radius:7px;outline:none;flex:1;min-width:0;padding:5px 9px;font-size:12px;transition:border-color .2s}.src-cam-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #19a7ce1f}.src-action-btn{cursor:pointer;white-space:nowrap;border:1px solid;border-radius:6px;padding:5px 10px;font-size:11px;font-weight:600;transition:all .2s}.src-action-save{color:#0369a1;background:#19a7ce1a;border-color:#19a7ce4d}.src-action-save:hover{background:#19a7ce33}.src-action-cancel{color:#dc2626;background:#ef444412;border-color:#ef444433}.src-action-cancel:hover{background:#ef444426}.src-action-scan{color:#d97706;background:#f59e0b14;border-color:#f59e0b40}.src-action-scan:hover{background:#f59e0b2e}.src-features{flex-wrap:wrap;gap:5px;display:flex}.src-feature-chip{letter-spacing:.3px;border-radius:99px;padding:3px 8px;font-size:10px;font-weight:600}.src-card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:auto;padding:10px 18px 12px;display:flex}.src-perm-status{color:var(--t3);font-size:11px}.src-disabled-overlay{color:var(--t3);text-align:center;padding:6px 18px 12px;font-size:11px;font-style:italic;position:absolute;bottom:0;left:0;right:0}.settings-modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background:#000000bf;justify-content:center;align-items:center;padding:20px;animation:.2s fade-in;display:flex;position:fixed;inset:0}.settings-modal-content{background:#fff;border:1px solid #19a7ce33;border-radius:16px;width:100%;max-width:440px;animation:.25s cubic-bezier(.16,1,.3,1) slide-up;overflow:hidden;box-shadow:0 8px 40px #146c9426}.settings-modal-header{background:#ffffff05;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.settings-modal-header h3{color:#fff;margin:0;font-size:16px;font-weight:700}.settings-modal-close{color:var(--t3);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;transition:color .2s;display:flex}.settings-modal-close:hover{color:#fff;background:#ffffff1a}.settings-modal-body{padding:24px}.share-input-group{gap:8px;margin-bottom:28px;display:flex}.share-input{color:#fff;background:#ffffff0a;border:1px solid #ffffff26;border-radius:10px;outline:none;flex:1;padding:10px 14px;font-size:13px;transition:border-color .2s}.share-input:focus{border-color:var(--blue)}.share-role-select{color:var(--t1);cursor:pointer;background:#ffffff0a;border:1px solid #ffffff26;border-radius:10px;outline:none;padding:10px 12px;font-size:13px;transition:border-color .2s}.share-role-select option{color:#ddf2fd;background:#071520}.share-role-select:focus{border-color:var(--blue)}.share-send-btn{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:10px 20px;font-size:13px;font-weight:700;transition:all .2s}.share-send-btn:hover{background:#2ba1d8;transform:translateY(-1px)}.share-send-btn:active{transform:translateY(1px)}.share-list h4{color:var(--t3);text-transform:uppercase;letter-spacing:1px;margin:0 0 12px 4px;font-size:11px}.share-user{background:#ffffff08;border:1px solid #ffffff08;border-radius:12px;align-items:center;gap:12px;padding:12px;display:flex}.share-avatar{background:color-mix(in srgb,var(--blue) 20%,transparent);width:36px;height:36px;color:var(--blue);border-radius:50%;justify-content:center;align-items:center;font-size:15px;font-weight:800;display:flex}.share-info{flex:1}.share-name{color:#fff;margin-bottom:3px;font-size:13px;font-weight:600}.share-email{color:var(--t3);font-size:11px}.share-role-badge{color:var(--t2);background:#ffffff14;border-radius:6px;padding:5px 10px;font-size:10px;font-weight:600}.share-role-badge.owner{background:color-mix(in srgb,var(--blue) 15%,transparent);color:var(--blue);border:1px solid color-mix(in srgb,var(--blue) 30%,transparent)}.fp-delete-btn{color:#ef4444;cursor:pointer;background:#fee2e2;border:1px solid #fca5a5;border-radius:6px;margin-left:10px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .2s}.fp-delete-btn:hover{color:#b91c1c;background:#fca5a5}.cp-panel{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1f;border:1px solid #fff3;border-radius:14px;overflow:hidden}.cp-header{color:#ddf2fd;cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:11px 14px;font-size:13px;font-weight:600;transition:background .2s;display:flex}.cp-header:hover{background:#ffffff14}.cp-header-left{align-items:center;gap:8px;display:flex}.cp-header-icon{color:#ddf2fd;background:#ffffff2e;border-radius:7px;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.cp-chevron{color:#ddf2fd99;transition:transform .2s}.cp-body{flex-direction:column;gap:6px;padding:0 10px 12px;display:flex}.cp-power-btn{letter-spacing:.3px;border:1.5px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px 14px;font-size:12px;font-weight:700;transition:all .2s;display:flex}.cp-power-btn:disabled{opacity:.55;cursor:not-allowed}.cp-power-off{color:#ddf2fd;background:#ffffff26;border-color:#ffffff40}.cp-power-off:hover:not(:disabled){background:#ffffff38;border-color:#fff6}.cp-power-on{color:#fca5a5;background:#f8717140;border-color:#f8717180}.cp-power-on:hover:not(:disabled){background:#f8717159}.cp-divider{letter-spacing:.8px;text-transform:uppercase;color:#ddf2fd73;align-items:center;gap:8px;padding:2px;font-size:10px;font-weight:600;display:flex}.cp-divider:before,.cp-divider:after{content:"";background:#ffffff1f;flex:1;height:1px}.cp-engines{flex-direction:column;gap:4px;display:flex}.cp-engine-btn{color:#ddf2fdcc;text-align:left;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:9px;align-items:center;gap:9px;width:100%;padding:8px 10px;font-size:12px;font-weight:500;transition:all .2s;display:flex}.cp-engine-btn:disabled{opacity:.5;cursor:not-allowed}.cp-engine-btn:hover:not(:disabled){color:#ddf2fd;background:#ffffff1f;border-color:#fff3}.cp-engine-btn.cp-engine-on{background:color-mix(in srgb, var(--eng-accent,#19a7ce) 18%, transparent);border-color:color-mix(in srgb, var(--eng-accent,#19a7ce) 50%, transparent);color:#fff}.cp-engine-icon{flex-shrink:0;font-size:15px;line-height:1}.cp-engine-label{flex:1}.cp-engine-badge{letter-spacing:.5px;border-radius:99px;flex-shrink:0;align-items:center;padding:2px 7px;font-size:9px;font-weight:700;display:flex}.cp-badge-off{color:#ddf2fd66;background:#ffffff1a}.cp-badge-on{color:#fff;background:#ffffff40}.cp-spin{animation:.7s linear infinite cp-rotate;display:inline-flex}@keyframes cp-rotate{to{transform:rotate(360deg)}}
