@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;0,6..72,700;1,6..72,400&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--teal:#0d9488;--teal-light:#14b8a6;--teal-dark:#0f766e;--teal-wash:#f0fdfa;--teal-glow:#0d94881f;--stone-50:#fafaf9;--stone-100:#f5f5f4;--stone-200:#e7e5e4;--stone-300:#d6d3d1;--stone-400:#a8a29e;--stone-500:#78716c;--stone-600:#57534e;--stone-700:#44403c;--stone-800:#292524;--stone-900:#1c1917;--bg:#f7f6f4;--card:#fff;--border:var(--stone-200);--text:var(--stone-900);--text-secondary:var(--stone-600);--text-muted:var(--stone-400);--success:#059669;--warning:#d97706;--danger:#dc2626;--font-display:"Newsreader", Georgia, serif;--font-body:"DM Sans", -apple-system, sans-serif;--radius:14px;--radius-sm:10px;--radius-lg:20px;--shadow:0 1px 2px #1c19170a, 0 1px 3px #1c19170f;--shadow-md:0 4px 12px #1c19170f, 0 1px 3px #1c19170a;--shadow-lg:0 8px 24px #1c191714, 0 2px 6px #1c19170a;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{background:var(--bg);flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}.app:before{content:"";z-index:-1;background:radial-gradient(ellipse 80% 50% at 50% -20%, var(--teal-glow), transparent), var(--bg);pointer-events:none;position:fixed;inset:0}.main{-webkit-overflow-scrolling:touch;flex:1;width:100%;max-width:540px;margin:0 auto;padding:20px 16px 96px;overflow-y:auto}.topbar{z-index:50;padding:env(safe-area-inset-top) 16px 0;background:var(--stone-800);color:#fff;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);justify-content:center;align-items:center;min-height:0;display:flex;position:sticky;top:0}.topbar h1{font-family:var(--font-display);letter-spacing:.04em;opacity:.5;margin:0;padding:2px 0;font-size:10px;font-weight:500;line-height:1}.topbar-user{color:var(--stone-400);font-size:11px;font-weight:400}.topbar-btn{color:var(--stone-300);font-family:var(--font-body);cursor:pointer;transition:all .15s var(--ease-out);background:#ffffff14;border:1px solid #ffffff1a;border-radius:8px;padding:5px 12px;font-size:11px;font-weight:500}.topbar-btn:hover{background:#ffffff24}.bottom-nav{z-index:50;-webkit-backdrop-filter:blur(20px)saturate(1.5);padding:8px 0 calc(8px + env(safe-area-inset-bottom));background:#ffffffeb;border-top:1px solid #0000000f;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--stone-400);letter-spacing:.02em;transition:color .2s var(--ease-out), transform .15s var(--ease-out);border-radius:10px;flex-direction:column;align-items:center;gap:3px;padding:4px 16px;font-size:10px;font-weight:500;text-decoration:none;display:flex}.nav-item:active{transform:scale(.92)}.nav-item.active{color:var(--teal)}.nav-item svg{stroke-width:1.8px;width:21px;height:21px}.page-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--stone-800);margin-bottom:4px;font-size:24px;font-weight:600}.page-subtitle{color:var(--text-muted);margin-bottom:20px;font-size:13px}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow .2s var(--ease-out);border:1px solid #00000008;margin-bottom:12px;padding:16px}.card-header{font-family:var(--font-body);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;font-size:11px;font-weight:600}.metrics{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px;display:grid}.metric{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);text-align:left;border:1px solid #00000008;padding:16px 14px;position:relative;overflow:hidden}.metric:after{content:"";background:var(--stone-200);border-radius:0 2px 2px 0;width:3px;height:100%;position:absolute;top:0;left:0}.metric-value{font-family:var(--font-display);letter-spacing:-.02em;font-size:26px;font-weight:700;line-height:1.1}.metric-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:6px;font-size:10px;font-weight:600}.metric.highlight{background:linear-gradient(135deg, var(--teal), var(--teal-dark));border-color:#0000}.metric.highlight:after{background:#fff3}.metric.highlight .metric-value{color:#fff}.metric.highlight .metric-label{color:#ffffffb3}.cal-header{justify-content:space-between;align-items:center;margin-bottom:14px;padding:0 2px;display:flex}.cal-header h2{font-family:var(--font-display);letter-spacing:-.01em;font-size:17px;font-weight:600}.cal-nav{cursor:pointer;color:var(--text-secondary);transition:all .15s var(--ease-out);background:0 0;border:none;border-radius:8px;padding:6px}.cal-nav:hover{background:var(--stone-100)}.cal-nav:active{transform:scale(.9)}.cal-grid{text-align:center;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:16px;display:grid}.cal-dow{color:var(--stone-400);text-transform:uppercase;letter-spacing:.06em;padding:6px 0;font-size:10px;font-weight:600}.cal-day{aspect-ratio:1;cursor:pointer;transition:all .15s var(--ease-out);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;font-size:14px;font-weight:400;display:flex;position:relative}.cal-day:hover{background:var(--stone-100)}.cal-day:active{transform:scale(.9)}.cal-day.today{color:var(--teal);font-weight:700}.cal-day.selected{background:var(--teal);color:#fff;font-weight:600;box-shadow:0 2px 8px #0d94884d}.cal-day.selected:hover{background:var(--teal-dark)}.cal-day.other-month{color:var(--stone-300)}.cal-dot{background:var(--teal);border-radius:50%;width:4px;height:4px;transition:background .15s;position:absolute;bottom:5px}.cal-day.selected .cal-dot{background:#ffffffb3}.appt-list{flex-direction:column;gap:8px;display:flex}.appt-item{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;color:inherit;transition:all .15s var(--ease-out);border:1px solid #00000008;gap:14px;padding:14px;text-decoration:none;display:flex}.appt-item:hover{box-shadow:var(--shadow-md)}.appt-item:active{box-shadow:var(--shadow-md);transform:scale(.98)}.appt-time{font-family:var(--font-display);color:var(--teal);min-width:48px;padding-top:1px;font-size:15px;font-weight:600}.appt-info{flex:1;min-width:0}.appt-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.appt-chinese{color:var(--text-secondary);margin-top:1px;font-size:12px}.appt-doctor{color:var(--text-muted);margin-top:3px;font-size:11px}.appt-remarks{color:var(--stone-500);white-space:nowrap;text-overflow:ellipsis;margin-top:5px;font-size:11px;font-style:italic;overflow:hidden}.appt-badge{letter-spacing:.02em;border-radius:99px;padding:2px 9px;font-size:10px;font-weight:600;display:inline-block}.badge-scheduled{background:var(--teal-wash);color:var(--teal-dark)}.badge-done{color:#065f46;background:#ecfdf5}.badge-cancelled{color:#991b1b;background:#fef2f2}.search-input{border:1.5px solid var(--stone-200);border-radius:var(--radius);width:100%;font-family:var(--font-body);background:var(--card);color:var(--text);transition:all .2s var(--ease-out);outline:none;padding:11px 16px;font-size:14px}.search-input::placeholder{color:var(--stone-400)}.search-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-glow)}.patient-item{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;color:inherit;transition:all .15s var(--ease-out);border:1px solid #00000008;align-items:center;gap:14px;margin-bottom:8px;padding:14px;text-decoration:none;display:flex}.patient-item:hover{box-shadow:var(--shadow-md)}.patient-item:active{transform:scale(.98)}.avatar{background:linear-gradient(135deg, var(--teal), var(--teal-dark));color:#fff;width:42px;height:42px;font-size:14px;font-weight:700;font-family:var(--font-body);letter-spacing:.02em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.avatar.lg{width:68px;height:68px;font-size:24px}.patient-info{flex:1;min-width:0}.patient-name{font-size:14px;font-weight:600}.patient-sub{color:var(--text-muted);margin-top:2px;font-size:12px}.tabs{background:var(--stone-100);border-radius:var(--radius-sm);-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:3px;margin-bottom:18px;padding:3px;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{text-align:center;cursor:pointer;min-width:0;color:var(--text-muted);white-space:nowrap;transition:all .2s var(--ease-out);font-size:11px;font-weight:600;font-family:var(--font-body);letter-spacing:.01em;background:0 0;border:none;border-radius:8px;flex:1;padding:9px 4px}.tab.active{background:var(--card);color:var(--text);box-shadow:0 1px 3px #0000000f}.rev-row{border-bottom:1px solid var(--stone-100);align-items:center;gap:10px;padding:10px 0;display:flex}.rev-date{color:var(--text-muted);min-width:52px;font-size:12px;font-weight:500}.rev-amount{font-family:var(--font-display);text-align:right;min-width:72px;font-size:14px;font-weight:600}.rev-bar-wrap{flex:1}.rev-bar{background:linear-gradient(90deg, var(--teal), var(--teal-light));min-width:4px;height:16px;transition:width .4s var(--ease-out);border-radius:4px}.img-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.img-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;transition:all .15s var(--ease-out);border:1px solid #00000008;overflow:hidden}.img-card:active{transform:scale(.97)}.img-card-body{padding:10px}.img-card-title{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.img-card-sub{color:var(--text-muted);margin-top:2px;font-size:10px}.img-preview{aspect-ratio:4/3;object-fit:cover;background:var(--stone-100);width:100%;color:var(--stone-400);justify-content:center;align-items:center;font-size:12px;font-weight:500;display:flex}.login-page{background:var(--stone-900);flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(60% 40% at 30% 20%,#0d948826,#0000),radial-gradient(50% 30% at 70% 80%,#0d948814,#0000);position:absolute;inset:0}.login-card{border-radius:var(--radius-lg);width:100%;max-width:360px;box-shadow:var(--shadow-lg);z-index:1;animation:loginSlide .5s var(--ease-out);background:#fff;padding:36px 28px;position:relative}@keyframes loginSlide{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-title{font-family:var(--font-display);letter-spacing:-.02em;text-align:center;color:var(--text);margin-bottom:2px;font-size:26px;font-weight:600}.login-subtitle{color:var(--text-muted);text-align:center;margin-bottom:28px;font-size:13px;font-weight:400}.form-group{margin-bottom:18px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:11px;font-weight:600;display:block}.form-input{border:1.5px solid var(--stone-200);border-radius:var(--radius-sm);width:100%;font-family:var(--font-body);color:var(--text);transition:all .2s var(--ease-out);background:var(--stone-50);outline:none;padding:11px 14px;font-size:14px}.form-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-glow);background:#fff}.form-error{color:var(--danger);text-align:center;margin-bottom:14px;font-size:12px;font-weight:500}.btn-primary{width:100%;font-family:var(--font-body);background:linear-gradient(135deg, var(--teal), var(--teal-dark));color:#fff;border-radius:var(--radius-sm);letter-spacing:.01em;cursor:pointer;transition:all .2s var(--ease-out);border:none;padding:13px;font-size:14px;font-weight:600;box-shadow:0 2px 8px #0d94884d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px #0d948859}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.back-btn-wrap{z-index:40;margin-bottom:12px;padding-top:4px;position:sticky;top:0}.back-btn{color:var(--teal-dark);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:13px;font-weight:600;font-family:var(--font-body);transition:all .15s var(--ease-out);letter-spacing:.01em;background:#f0fdfaf2;border:1px solid #0d948826;border-radius:20px;align-items:center;gap:4px;padding:7px 14px 7px 8px;text-decoration:none;display:inline-flex}.back-btn svg{flex-shrink:0}.back-btn:hover{background:#0d94881f}.back-btn:active{transform:scale(.95)}.quick-link{color:inherit;border-bottom:1px solid var(--stone-100);align-items:center;gap:10px;padding:12px 0;font-size:14px;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.quick-link:last-child{border-bottom:none}.quick-link:active{color:var(--teal)}.quick-link-icon{background:var(--teal-wash);width:32px;height:32px;color:var(--teal);border-radius:8px;justify-content:center;align-items:center;display:flex}.quick-link-icon svg{width:16px;height:16px}.date-input{border:1.5px solid var(--stone-200);border-radius:var(--radius-sm);font-family:var(--font-body);color:var(--text);background:var(--card);outline:none;flex:1;padding:9px 12px;font-size:13px;transition:border-color .2s}.date-input:focus{border-color:var(--teal)}.loading{text-align:center;color:var(--text-muted);padding:48px 20px;font-size:14px}.empty{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:13px;font-style:italic}.info-row{border-bottom:1px solid var(--stone-100);padding:10px 0;font-size:13px;display:flex}.info-row:last-child{border-bottom:none}.info-label{width:90px;color:var(--text-muted);flex-shrink:0;font-size:12px;font-weight:500}.info-value{color:var(--text);word-break:break-word;font-weight:500}.section-between{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title{color:var(--text);font-size:14px;font-weight:600}.section-count{color:var(--text-muted);font-size:12px;font-weight:400}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.card,.metric,.patient-item,.appt-item{animation:fadeUp .35s var(--ease-out) both}.metrics .metric:nth-child(2){animation-delay:40ms}.metrics .metric:nth-child(3){animation-delay:80ms}.metrics .metric:nth-child(4){animation-delay:.12s}.settings-row{border-bottom:1px solid var(--stone-100);align-items:flex-start;gap:12px;padding:12px 0;display:flex}.settings-row:last-child{border-bottom:none}.settings-row svg{flex-shrink:0;margin-top:2px}.settings-info{flex:1}.settings-label{color:var(--text-muted);font-size:11px;font-weight:500}.settings-value{margin-top:2px;font-size:14px;font-weight:500}.signout-btn{border:1.5px solid var(--danger);width:100%;color:var(--danger);border-radius:var(--radius);font-family:var(--font-body);cursor:pointer;transition:all .15s var(--ease-out);background:0 0;justify-content:center;align-items:center;gap:8px;margin-top:24px;padding:14px;font-size:14px;font-weight:600;display:flex}.signout-btn:active{background:#dc26260d;transform:scale(.98)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}@media (width>=768px){.main{max-width:640px;padding:28px 20px 96px}.metrics{grid-template-columns:repeat(4,1fr)}.img-grid{grid-template-columns:repeat(3,1fr)}}.cctv-page{--cctv-off:var(--stone-500);--cctv-quiet:var(--stone-300);--cctv-low:#d4a85a;--cctv-medium:#dc7a3a;--cctv-high:#b84a3a;--cctv-empty-outline:var(--stone-200)}.cctv-viewer{--cctv-quiet:#4a4642;--cctv-empty-outline:#ffffff14}.cctv-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.cctv-header .page-title,.cctv-header .page-subtitle{margin-bottom:2px}.cctv-help-btn{border:1px solid var(--stone-200);background:var(--card);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:all .15s var(--ease-out);border-radius:50%;place-items:center;display:grid}.cctv-help-btn:hover{border-color:var(--teal);color:var(--teal);box-shadow:0 0 0 3px var(--teal-glow)}.cctv-layout{flex-direction:column;gap:12px;display:flex}@media (width>=900px){.main:has(.cctv-page){max-width:min(100%,1440px);padding:28px 28px 96px}.cctv-layout{grid-template-columns:340px minmax(0,1fr);align-items:start;gap:20px;display:grid}.cctv-sidebar{position:sticky;top:28px}}@media (orientation:landscape) and (width>=700px) and (width<=899px){.main:has(.cctv-page){max-width:100%;padding:16px 18px 80px}.cctv-layout{grid-template-columns:260px minmax(0,1fr);align-items:start;gap:14px;display:grid}}@media (width>=1400px){.main:has(.cctv-page){max-width:1640px;padding:32px 40px 96px}.cctv-layout{grid-template-columns:360px minmax(0,1fr);gap:28px}}.cctv-mini-cal{font-family:var(--font-body);font-variant-numeric:tabular-nums;grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cctv-mini-cal__dow{color:var(--stone-400);text-align:center;text-transform:uppercase;letter-spacing:.08em;padding:4px 0 6px;font-size:9px;font-weight:700}.cctv-mini-cal__day{aspect-ratio:1;color:var(--stone-300);cursor:pointer;transition:all .12s var(--ease-out);background:0 0;border:none;border-radius:6px;place-items:center;font-size:12px;font-weight:500;display:grid;position:relative}.cctv-mini-cal__day[data-in-month]{color:var(--stone-700)}.cctv-mini-cal__day[data-today]{box-shadow:inset 0 0 0 1px var(--stone-400)}.cctv-mini-cal__day[data-has-data]{color:var(--teal);font-weight:700}.cctv-mini-cal__day[data-has-data]:after{content:"";background:var(--teal);border-radius:50%;width:3px;height:3px;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.cctv-mini-cal__day[data-emoji]:after{content:attr(data-emoji);width:auto;min-width:0;height:auto;min-height:0;box-shadow:none;background:0 0;border:none;border-radius:0;padding:0;font-size:8px;line-height:1}.cctv-mini-cal__day:hover:not([data-selected]){background:var(--stone-100)}.cctv-mini-cal__day[data-selected]{background:var(--teal);font-weight:700;box-shadow:0 4px 10px -4px #0d94888c;color:#fff!important}.cctv-mini-cal__day[data-selected]:after{background:#ffffffe6}.cctv-channel-switcher{background:var(--stone-100);border-radius:10px;gap:3px;margin-top:14px;padding:3px;display:flex}.cctv-channel-btn{font-family:var(--font-body);color:var(--stone-500);cursor:pointer;transition:all .15s var(--ease-out);letter-spacing:.01em;background:0 0;border:none;border-radius:7px;flex:1;padding:7px 4px;font-size:11px;font-weight:600}.cctv-channel-btn:hover{color:var(--stone-700)}.cctv-channel-btn[data-active]{background:var(--card);color:var(--teal-dark);box-shadow:var(--shadow)}.cctv-moments-card .card-header.cctv-moments-header{color:var(--teal-dark);align-items:center;gap:6px;margin-bottom:10px;display:flex}.cctv-moments{flex-direction:column;gap:6px;display:flex}.cctv-moments__card{text-align:left;background:var(--stone-50);border:1px solid var(--stone-200);border-left:3px solid var(--teal);transition:all .15s var(--ease-out);border-radius:8px;align-items:center;gap:8px;padding:6px 10px;display:flex}.cctv-moments__card--motion_dark{border-left-color:var(--cctv-high);background:#fef2f2}.cctv-moments__card--active_clinic{border-left-color:var(--cctv-medium)}.cctv-moments__card--light_on{border-left-color:var(--cctv-low)}.cctv-moments__card--light_off{border-left-color:var(--stone-400)}.cctv-moments__head{align-items:center;gap:6px;display:flex}.cctv-moments__emoji{font-size:16px;line-height:1}.cctv-moments__time{font-family:var(--font-body);color:var(--stone-500);letter-spacing:.06em;text-transform:uppercase;font-variant-numeric:tabular-nums;font-size:10px;font-weight:700}.cctv-moments__label{font-family:var(--font-display);color:var(--stone-800);letter-spacing:-.005em;font-size:14px;font-style:italic;font-weight:500}.cctv-moments__patients{font-family:var(--font-body);color:var(--teal-dark);flex-wrap:wrap;margin-top:2px;font-size:10px;font-weight:600;line-height:1.4;display:flex}.cctv-moments__patient{white-space:nowrap;align-items:center;gap:2px;display:inline-flex}.cctv-moments__body{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.cctv-moments__replay{flex-direction:row;flex:none;align-self:center;gap:3px;display:flex}.cctv-moments__replay button{border:1px solid var(--stone-200);background:var(--card);cursor:pointer;width:26px;height:26px;font-family:var(--font-body);color:var(--stone-500);transition:all .12s var(--ease-out);border-radius:6px;place-items:center;font-size:11px;font-weight:700;display:grid}.cctv-moments__replay button:hover{border-color:var(--teal);background:var(--teal-wash);color:var(--teal-dark)}.cctv-intensity{align-items:center;gap:4px;margin-top:2px;display:inline-flex}.cctv-intensity__bar{background:var(--stone-200);border-radius:2px;width:8px;height:8px;transition:background .15s;display:inline-block}.cctv-intensity__bar--filled{background:var(--cctv-low)}.cctv-intensity--medium .cctv-intensity__bar--filled{background:var(--cctv-medium)}.cctv-intensity--high .cctv-intensity__bar--filled{background:var(--cctv-high)}.cctv-intensity__label{font-family:var(--font-body);color:var(--text-muted);text-transform:capitalize;letter-spacing:.03em;font-size:9px;font-weight:600}.cctv-timeline-card{padding:18px 16px 14px}.cctv-timeline-header{margin-bottom:12px}.cctv-timeline-header .section-title{font-family:var(--font-display);letter-spacing:-.01em;color:var(--stone-800);font-size:16px;font-weight:500}.cctv-histogram{align-items:stretch;gap:6px;height:84px;margin-bottom:4px;display:flex;position:relative}.cctv-histogram__label{font-family:var(--font-body);letter-spacing:.1em;color:var(--stone-400);font-variant-numeric:tabular-nums;flex:0 0 32px;align-items:flex-end;padding-bottom:4px;font-size:9px;font-weight:700;display:flex}.cctv-histogram__bars{background: linear-gradient(90deg, transparent calc(25% - 1px), #1c191714 25%, transparent calc(25% + 1px), transparent calc(50% - 1px), #1c191714 50%, transparent calc(50% + 1px), transparent calc(75% - 1px), #1c191714 75%, transparent calc(75% + 1px)),  repeating-linear-gradient(90deg, transparent 0, transparent calc((100% / 24) - 1px), #1c191706 calc((100% / 24) - 1px), #1c191706 calc(100% / 24)), linear-gradient(180deg, var(--stone-50), var(--stone-100));border:1px solid var(--stone-200);border-radius:8px;flex:1;height:100%;position:relative;overflow:hidden}.cctv-histogram__bar{height:var(--bar-height,0%);background:var(--cctv-quiet);cursor:pointer;transition:opacity .15s, filter .15s, transform .12s var(--ease-spring);border:none;padding:0;position:absolute;bottom:0}.cctv-histogram__bar:disabled{cursor:default}.cctv-histogram__bar[data-level=off]{background:var(--cctv-off);opacity:.55}.cctv-histogram__bar[data-level=quiet]{background:var(--cctv-quiet)}.cctv-histogram__bar[data-level=low]{background:var(--cctv-low)}.cctv-histogram__bar[data-level=medium]{background:var(--cctv-medium)}.cctv-histogram__bar[data-level=high]{background:var(--cctv-high);background-image:repeating-linear-gradient(45deg,#0000 0 3px,#0000001f 3px 5px)}.cctv-histogram__bar[data-level=empty]{border-top:1px dashed var(--cctv-empty-outline);background:0 0;height:14%}.cctv-histogram__bar:not(:disabled):hover{filter:brightness(1.15);transform-origin:bottom;transform:scaleY(1.05)}.cctv-histogram__bar[data-selected]{box-shadow:0 0 0 2px var(--teal), 0 -4px 14px -2px #0d948859;z-index:2}.cctv-histogram__bar[data-selected]:after{content:"";border-left:5px solid #0000;border-right:5px solid #0000;border-top:6px solid var(--teal);width:0;height:0;position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%)}.cctv-histogram__playhead{pointer-events:none;z-index:3;background:#ef4444;width:1px;transition:left .25s linear;position:absolute;top:0;bottom:0;box-shadow:0 0 8px #ef444480}.cctv-histogram[data-loading] .cctv-histogram__bars{background:linear-gradient(90deg, transparent calc(25% - 1px), #1c191714 25%, transparent calc(25% + 1px), transparent calc(50% - 1px), #1c191714 50%, transparent calc(50% + 1px), transparent calc(75% - 1px), #1c191714 75%, transparent calc(75% + 1px)), repeating-linear-gradient(90deg, transparent 0, transparent calc((100% / 24) - 1px), #1c191706 calc((100% / 24) - 1px), #1c191706 calc(100% / 24)), linear-gradient(90deg, var(--stone-100) 0%, var(--stone-50) 50%, var(--stone-100) 100%);background-size:100% 100%,100% 100%,200% 100%;animation:1.6s ease-in-out infinite cctv-shimmer}@keyframes cctv-shimmer{0%,to{background-position:0 0,0 0,200% 0}50%{background-position:0 0,0 0,-200% 0}}.cctv-ruler{height:16px;font-family:var(--font-body);color:var(--stone-500);font-variant-numeric:tabular-nums;margin:6px 0 0 38px;font-size:9px;font-weight:700;position:relative}.cctv-ruler__tick{position:absolute;top:0;transform:translate(-50%)}.cctv-ruler__tick:first-child{transform:translate(0)}.cctv-ruler__tick:last-child{transform:translate(-100%)}.cctv-timeline-card .cctv-legend{border-top:1px solid var(--stone-200);color:var(--stone-500);font-size:10px;font-family:var(--font-body);letter-spacing:.02em;flex-wrap:wrap;gap:14px;margin-top:14px;padding-top:10px;display:flex}.cctv-legend-item{align-items:center;gap:5px;display:inline-flex}.cctv-legend-swatch{border-radius:2px;width:18px;height:8px;display:inline-block}.cctv-legend-swatch[data-level=off]{background:var(--cctv-off);opacity:.6}.cctv-legend-swatch[data-level=quiet]{background:var(--cctv-quiet)}.cctv-legend-swatch[data-level=low]{background:var(--cctv-low)}.cctv-legend-swatch[data-level=medium]{background:var(--cctv-medium)}.cctv-legend-swatch[data-level=high]{background:var(--cctv-high);background-image:repeating-linear-gradient(45deg,#0000 0 2px,#0000001f 2px 4px)}.cctv-legend-swatch[data-level=empty]{border:1px dashed var(--stone-300);background:0 0}.cctv-viewer{background:var(--stone-900);color:var(--stone-50);border-radius:var(--radius);background-image:radial-gradient(at 0 0,#0d94880f,#0000 50%),radial-gradient(at 100% 100%,#d4a85a0a,#0000 60%);margin-bottom:12px;padding:22px 22px 18px;position:relative;box-shadow:0 20px 50px -20px #1c191773,inset 0 0 0 1px #ffffff0a}.cctv-viewer__head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.cctv-viewer__head-actions{align-items:center;gap:8px;display:flex}.cctv-viewer__cam-select{background:#ffffff0d;border:1px solid #ffffff14;border-radius:999px;gap:3px;padding:3px;display:flex}.cctv-viewer__cam-btn{width:28px;height:28px;color:var(--stone-400);font-family:var(--font-body);cursor:pointer;transition:all .12s var(--ease-out);background:0 0;border:none;border-radius:50%;place-items:center;font-size:12px;font-weight:700;display:grid}.cctv-viewer__cam-btn:hover{color:var(--stone-100)}.cctv-viewer__cam-btn.active{background:var(--teal);color:#fff;box-shadow:0 2px 8px -2px #0d948899}.cctv-viewer__fs-toggle{width:32px;height:32px;color:var(--stone-300);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:50%;place-items:center;transition:all .15s;display:grid}.cctv-viewer__fs-toggle:hover{border-color:var(--teal);color:var(--teal-light);background:#0d948833}.cctv-viewer__eyebrow{font-family:var(--font-body);letter-spacing:.14em;text-transform:uppercase;color:var(--teal-light);align-items:center;gap:8px;margin-bottom:4px;font-size:10px;font-weight:700;display:flex}.cctv-viewer__title{font-family:var(--font-display);letter-spacing:-.015em;color:var(--stone-50);font-size:22px;font-weight:500;line-height:1.2}.cctv-viewer__title em{color:var(--stone-300);font-style:italic;font-weight:400}.cctv-viewer__share{color:var(--stone-200);font-family:var(--font-body);letter-spacing:.04em;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:999px;align-items:center;gap:5px;padding:6px 10px;font-size:10px;font-weight:600;transition:all .15s;display:inline-flex}.cctv-viewer__share:hover{border-color:var(--teal);color:var(--teal-light);background:#0d94882e}.cctv-live-dot{background:#ef4444;border-radius:50%;width:8px;height:8px;animation:1.6s ease-in-out infinite cctv-live-pulse;display:inline-block;box-shadow:0 0 10px #ef4444b3}@keyframes cctv-live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.8)}}.cctv-videos{flex-direction:column;gap:10px;margin-bottom:14px;display:flex}.cctv-videos--stacked{flex-direction:column;gap:10px;display:flex}.cctv-videos--focused{display:block;position:relative}.cctv-videos--focused .cctv-video-block{width:100%}.cctv-videos--side{gap:8px;flex-direction:row!important}.cctv-videos--side .cctv-video-block{flex:1;min-width:0}.cctv-videos--pip{position:relative}.cctv-videos--pip>.cctv-video-block--pip{aspect-ratio:16/9;border:2px solid var(--teal);cursor:pointer;z-index:3;border-radius:8px;width:160px;position:absolute;overflow:hidden;box-shadow:0 8px 24px #00000080}.cctv-video-block--pip[data-corner=tr]{top:12px;right:12px}.cctv-video-block--pip[data-corner=br]{bottom:12px;right:12px}.cctv-video-block--pip[data-corner=bl]{bottom:12px;left:12px}.cctv-video-block--pip[data-corner=tl]{top:12px;left:12px}.cctv-video-block--pip:hover{transition:transform .15s var(--ease-out);transform:scale(1.05)}.cctv-pip-move{z-index:4;color:#fff;cursor:pointer;background:#0009;border:1px solid #ffffff4d;border-radius:50%;place-items:center;width:28px;height:28px;font-size:14px;transition:background .15s;display:grid;position:absolute;bottom:12px;left:12px}.cctv-pip-move:hover{background:#0d9488cc}.cctv-video-block{aspect-ratio:16/9;border-radius:var(--radius-sm);background:#000;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0f}.cctv-video-block--compact{aspect-ratio:16/9;border-radius:6px}.cctv-video-label{z-index:2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#ffffffd9;font-family:var(--font-body);letter-spacing:.14em;background:#00000047;border:1px solid #ffffff0d;border-radius:4px;padding:3px 8px;font-size:9px;font-weight:800;position:absolute;bottom:10px;right:12px}.cctv-sync-badge{z-index:2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:var(--font-body);letter-spacing:.14em;color:#fff;background:#0d9488e6;border:1px solid #ffffff26;border-radius:999px;align-items:center;gap:4px;padding:3px 8px;font-size:8px;font-weight:800;display:inline-flex;position:absolute;top:10px;right:12px}.cctv-sync-badge__dot{background:#10b981;border-radius:50%;width:5px;height:5px;display:inline-block}.cctv-sync-badge__dot--live{animation:1.6s ease-in-out infinite cctv-sync-pulse}@keyframes cctv-sync-pulse{0%,to{opacity:1}50%{opacity:.3}}.cctv-video-fs{z-index:2;color:#fffc;cursor:pointer;opacity:0;background:#0000008c;border:1px solid #ffffff1f;border-radius:6px;place-items:center;width:26px;height:26px;transition:opacity .2s,background .15s;display:grid;position:absolute;bottom:10px;right:12px}.cctv-video-block:hover .cctv-video-fs{opacity:1}.cctv-video-fs:hover{color:#fff;background:#0d9488d9}.cctv-video{object-fit:contain;background:#000;width:100%;height:100%;display:block}.cctv-sprite-player{image-rendering:auto;background-color:#000;background-repeat:no-repeat;position:absolute;inset:0}.cctv-sprite-badge{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-family:var(--font-body);letter-spacing:.08em;text-transform:uppercase;color:#fff;pointer-events:none;z-index:2;background:#0d9488d9;border:1px solid #ffffff26;border-radius:999px;padding:3px 10px;font-size:9px;font-weight:700;position:absolute;bottom:10px;right:12px;box-shadow:0 4px 12px -4px #0d948873}.cctv-media-missing{background:linear-gradient(135deg, #ffffff05, transparent 60%), var(--stone-900);color:var(--stone-500);font-family:var(--font-body);letter-spacing:.05em;text-transform:uppercase;grid-auto-flow:row;place-items:center;gap:8px;font-size:11px;font-weight:500;display:grid;position:absolute;inset:0}.cctv-media-missing__bars{gap:4px;display:flex}.cctv-media-missing__bars span{background:var(--stone-600);border-radius:1px;width:3px;height:18px;animation:1.2s ease-in-out infinite cctv-missing-bars;display:inline-block}.cctv-media-missing__bars span:nth-child(2){animation-delay:.15s}.cctv-media-missing__bars span:nth-child(3){animation-delay:.3s}.cctv-media-missing__bars span:nth-child(4){animation-delay:.45s}@keyframes cctv-missing-bars{0%,to{opacity:.4;transform:scaleY(.3)}50%{opacity:1;transform:scaleY(1)}}.cctv-pip{z-index:3;aspect-ratio:16/9;border:2px solid var(--teal);cursor:pointer;width:160px;transition:transform .15s var(--ease-spring), border-color .15s;background:0 0;border-radius:8px;padding:0;position:absolute;bottom:16px;right:16px;overflow:hidden;box-shadow:0 10px 24px -10px #000000b3}.cctv-pip:hover{border-color:var(--teal-light);transform:scale(1.05)}.cctv-pip .cctv-video-block{border-radius:0}.cctv-strip-v2{border-radius:var(--radius-sm);background:#0b0a09;border:1px solid #ffffff0d;margin-bottom:12px;padding:8px 4px 18px;position:relative;overflow:visible}.cctv-strip-v2__inner{scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;-webkit-overflow-scrolling:touch;gap:1px;padding-bottom:2px;display:flex;overflow:auto visible}.cctv-strip-v2__inner::-webkit-scrollbar{height:4px}.cctv-strip-v2__inner::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.cctv-strip-v2__cell{cursor:pointer;opacity:.55;background-repeat:no-repeat;border:none;border-radius:2px;flex:none;padding:0;transition:opacity .15s,box-shadow .15s,transform .15s;position:relative}.cctv-strip-v2__cell:hover{opacity:1;transform:translateY(-1px)}.cctv-strip-v2__cell[data-time]:after{content:attr(data-time);color:var(--stone-400);font-size:7px;font-weight:700;font-family:var(--font-body);font-variant-numeric:tabular-nums;white-space:nowrap;pointer-events:none;position:absolute;bottom:-13px;left:50%;transform:translate(-50%)}.cctv-strip-v2__cell[data-current]{opacity:1;box-shadow:inset 0 0 0 2px var(--teal), 0 0 14px #0d948866;transform:translateY(-2px)}.cctv-strip-v2__selected-preview{border:2px solid var(--teal);pointer-events:none;z-index:5;background-color:#000;background-repeat:no-repeat;border-radius:6px;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 12px 32px -8px #0009}.cctv-strip-v2__selected-preview .cctv-strip-v2__preview-time{position:absolute;bottom:-20px;left:50%;transform:translate(-50%)}.cctv-strip-v2__preview{border:2px solid var(--teal);pointer-events:none;z-index:10;background-color:#000;background-repeat:no-repeat;border-radius:6px;position:absolute;bottom:calc(100% + 10px);transform:translate(-50%);box-shadow:0 20px 40px -12px #000000b3}.cctv-strip-v2__preview:after{content:"";border-right:2px solid var(--teal);border-bottom:2px solid var(--teal);background:#000;width:10px;height:10px;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)rotate(45deg)}.cctv-strip-v2__preview-time{font-family:var(--font-body);letter-spacing:.1em;color:var(--teal-light);font-variant-numeric:tabular-nums;white-space:nowrap;background:#000000d9;border:1px solid #0d948866;border-radius:4px;margin-top:12px;padding:2px 8px;font-size:10px;font-weight:700;position:absolute;top:100%;left:50%;transform:translate(-50%)}.cctv-transport{border-top:1px solid #ffffff0f;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;padding-top:12px;display:grid}.cctv-transport__controls{align-items:center;gap:6px;display:flex}.cctv-transport__step{width:30px;height:30px;color:var(--stone-300);cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:50%;place-items:center;transition:all .15s;display:grid}.cctv-transport__step:hover{border-color:var(--teal);color:var(--teal-light);background:#0d94881f}.cctv-transport__play{background:var(--teal);color:#fff;cursor:pointer;width:44px;height:44px;transition:transform .15s var(--ease-spring), box-shadow .15s;border:2px solid #ffffff1a;border-radius:50%;place-items:center;display:grid;box-shadow:0 6px 20px -6px #0d948899}.cctv-transport__play:hover{transform:scale(1.06);box-shadow:0 8px 24px -6px #0d9488cc}.cctv-transport__play:active{transform:scale(.95)}.cctv-transport__timecode{font-family:var(--font-body);font-variant-numeric:tabular-nums;flex-direction:column;align-items:center;gap:2px;display:flex}.cctv-transport__wallclock{letter-spacing:-.02em;color:var(--stone-50);font-size:22px;font-weight:300;line-height:1}.cctv-transport__offset{color:var(--stone-500);letter-spacing:.04em;font-size:10px;font-weight:600}.cctv-transport__speed{background:#ffffff0d;border:1px solid #ffffff14;border-radius:999px;align-items:center;padding:3px;display:flex}.cctv-speed-btn{font-family:var(--font-body);font-variant-numeric:tabular-nums;color:var(--stone-400);cursor:pointer;transition:all .12s var(--ease-out);background:0 0;border:none;border-radius:999px;padding:5px 10px;font-size:11px;font-weight:700}.cctv-speed-btn:hover{color:var(--stone-100)}.cctv-speed-btn[data-active]{background:var(--teal);color:#fff;box-shadow:0 2px 8px -2px #0d9488b3}.cctv-help-popover{z-index:100;background:var(--stone-900);width:280px;color:var(--stone-100);border-radius:var(--radius);box-shadow:var(--shadow-lg);animation:cctv-popover-in .18s var(--ease-out);border:1px solid #ffffff14;padding:14px 16px;position:fixed;top:80px;right:20px}@keyframes cctv-popover-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.cctv-help-popover__header{font-family:var(--font-body);letter-spacing:.1em;text-transform:uppercase;color:var(--teal-light);border-bottom:1px solid #ffffff14;align-items:center;gap:6px;margin-bottom:10px;padding-bottom:8px;font-size:11px;font-weight:700;display:flex}.cctv-help-popover__header button{color:var(--stone-400);cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0 4px;font-size:18px;line-height:1}.cctv-help-popover__grid{font-family:var(--font-body);grid-template-columns:1fr auto;gap:8px 12px;margin:0;font-size:11px;display:grid}.cctv-help-popover__grid dt{color:var(--stone-300);align-items:center;gap:3px;font-weight:500;display:flex}.cctv-help-popover__grid dd{color:var(--stone-400);text-align:right;margin:0}.cctv-help-popover__grid kbd{min-width:18px;font-family:var(--font-body);color:var(--stone-100);text-align:center;background:#ffffff14;border:1px solid #ffffff24;border-bottom-width:2px;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:700;line-height:1.3;display:inline-block}.cctv-help-or{color:var(--stone-500);padding:0 2px;font-size:9px}.cctv-empty{text-align:center;padding:40px 24px}.cctv-empty__mark{font-family:var(--font-display);color:var(--stone-300);margin-bottom:6px;font-size:40px;font-weight:400;line-height:1}.cctv-empty__title{font-family:var(--font-display);color:var(--stone-600);margin-bottom:4px;font-size:17px;font-style:italic;font-weight:500}.cctv-empty__hint{color:var(--text-muted);font-size:12px}.cctv-prompt{background:var(--teal-wash);border:1px dashed var(--teal);border-radius:var(--radius-sm);color:var(--teal-dark);font-size:12px;font-family:var(--font-body);text-align:center;padding:14px 18px}.cctv-viewer--fullscreen{z-index:9999;max-width:none;box-shadow:none;animation:cctv-fs-in .2s var(--ease-out);background:#000;border-radius:0;margin:0;padding:0;position:fixed;inset:0;overflow:hidden}@keyframes cctv-fs-in{0%{opacity:.6;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.cctv-viewer--fullscreen .cctv-viewer__head{z-index:10;background:linear-gradient(#000000b3 0%,#0000 100%);margin:0;padding:12px 16px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.cctv-viewer--fullscreen .cctv-viewer__title{font-size:18px}.cctv-viewer--fullscreen .cctv-videos{z-index:1;justify-content:center;align-items:center;margin:0;display:flex;position:absolute;inset:0}.cctv-viewer--fullscreen .cctv-video-block{max-width:100%;max-height:100%;margin:0 auto}.cctv-viewer--fullscreen .cctv-videos--stacked{flex-direction:column;gap:4px;height:100%}.cctv-viewer--fullscreen .cctv-videos--stacked .cctv-video-block{aspect-ratio:auto;flex:1 1 0;min-width:0;min-height:0}.cctv-viewer--fullscreen .cctv-videos--side{flex-direction:row;gap:4px;width:100%;height:100%}.cctv-viewer--fullscreen .cctv-videos--side .cctv-video-block{aspect-ratio:auto;flex:1 1 0;min-width:0;min-height:0}.cctv-viewer--fullscreen .cctv-videos--pip{width:100%;height:100%}.cctv-viewer--fullscreen .cctv-videos--pip>.cctv-video-block:not(.cctv-video-block--pip){aspect-ratio:auto;width:100%;height:100%}.cctv-viewer--fullscreen .cctv-videos--pip>.cctv-video-block--pip{width:200px}.cctv-viewer--fullscreen .cctv-transport{z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:auto;width:auto;transition:opacity .3s, bottom .3s var(--ease-out);background:#000000a6;border:1px solid #ffffff1a;border-radius:999px;margin:0;padding:8px 20px;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.cctv-viewer--fullscreen.cctv-viewer--strip-open .cctv-transport{bottom:210px}.cctv-viewer--fullscreen .cctv-strip-v2{z-index:9;max-height:200px;transition:transform .3s var(--ease-out), opacity .3s;margin:0;padding:10px 4px 6px;position:absolute;bottom:0;left:0;right:0;transform:translateY(0)}.cctv-viewer--fullscreen .cctv-strip-v2--fs-hidden{opacity:0;pointer-events:none;transform:translateY(100%)}.cctv-viewer--fullscreen .cctv-strip-v2__inner{gap:2px;padding-bottom:4px}.cctv-fs-strip-toggle{z-index:11;color:#ffffffb3;cursor:pointer;background:#0009;border:1px solid #fff3;border-radius:14px;place-items:center;width:44px;height:28px;transition:opacity .3s,background .15s;display:grid;position:fixed;bottom:8px;left:50%;transform:translate(-50%)}.cctv-fs-strip-toggle:hover{color:#fff;background:#0d9488cc}.cctv-viewer--fs-idle .cctv-viewer__head,.cctv-viewer--fs-idle .cctv-transport,.cctv-viewer--fs-idle .cctv-fs-strip-toggle{opacity:0;pointer-events:none}@media (orientation:portrait) and (width<=500px){.cctv-viewer--fullscreen:after{content:"↻ Rotate for full screen";z-index:20;color:var(--stone-200);font-family:var(--font-body);pointer-events:none;background:#000c;border:1px solid #ffffff26;border-radius:999px;padding:10px 20px;font-size:13px;font-weight:600;animation:3s ease-out forwards cctv-rotate-hint;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}}@keyframes cctv-rotate-hint{0%,60%{opacity:.9}to{opacity:0}}
