:root{--bg: #0c0f0e;--bg-2: #111614;--surface: #151918;--surface-2: #1a1f1d;--line: rgba(255,255,255,.05);--line-2: rgba(255,255,255,.08);--text: #dde3de;--text-dim: #7a877c;--text-mute: #4e5a51;--accent: oklch(.72 .15 220);--accent-soft:oklch(.72 .15 220 / .12);--accent-glow:oklch(.72 .15 220 / .22);--danger: oklch(.62 .2 25);--warn: oklch(.76 .14 55);--mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--sans: "Inter", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh}body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv11";font-variant-numeric:tabular-nums}a{color:var(--accent);cursor:pointer;text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;background:var(--bg-2);color:var(--text);border:1px solid var(--line-2);border-radius:6px;padding:10px 12px;font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.mono-l{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--text-dim);text-transform:uppercase}.app{min-height:100vh;display:flex;flex-direction:column}.hdr{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:14px 28px;border-bottom:1px solid var(--line);background:#0a0d0cd9;-webkit-backdrop-filter:blur(14px) saturate(160%);backdrop-filter:blur(14px) saturate(160%)}.hdr-l,.hdr-r{display:flex;align-items:center;gap:24px}.brand{display:flex;align-items:center;gap:10px;-webkit-user-select:none;user-select:none}.brand-dot{width:8px;height:8px;background:var(--accent);box-shadow:0 0 12px var(--accent-glow);display:inline-block}.brand-logo{height:28px;width:auto;object-fit:contain;border-radius:4px}.brand-dot.lg{width:12px;height:12px}.brand-name{font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.18em}.brand-name.lg{font-size:18px}.brand-thin{font-weight:300;color:var(--text-dim)}.nav{display:flex;gap:4px}.nav-i{background:transparent;border:0;color:var(--text-dim);font-family:var(--mono);font-size:11px;letter-spacing:.12em;padding:8px 14px;text-transform:uppercase;position:relative}.nav-i.on{color:var(--text)}.nav-i.on:after{content:"";position:absolute;bottom:-16px;left:14px;right:14px;height:2px;background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.nav-i:hover{color:var(--text)}.user{display:flex;align-items:center;gap:10px}.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--surface-2),var(--bg-2));border:1px solid var(--line-2);display:grid;place-items:center;font-family:var(--mono);font-size:12px;color:var(--text)}.avatar.sm{width:24px;height:24px;font-size:10px}.user-meta{line-height:1.2}.user-email{font-size:12px}.user-role{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--accent)}.btn-ghost{background:transparent;border:1px solid var(--line-2);color:var(--text-dim);padding:7px 14px;font-size:12px;border-radius:6px;transition:all .15s}.btn-ghost:hover{color:var(--text);border-color:var(--text-mute)}.btn-prime{background:var(--accent);color:#020d1a;border:0;padding:12px 18px;border-radius:6px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:8px;transition:all .15s;box-shadow:0 0 0 1px var(--accent),0 0 16px var(--accent-soft)}.btn-prime.sm{padding:8px 14px;font-size:13px}.btn-prime:hover{filter:brightness(1.1);box-shadow:0 0 0 1px var(--accent),0 0 24px var(--accent-glow)}.btn-prime:disabled{opacity:.6;cursor:not-allowed;filter:none}.btn-prime .arr{transition:transform .15s}.btn-prime:hover .arr{transform:translate(3px)}.btn-danger{background:var(--danger);color:#1a0606;border:0;padding:8px 14px;border-radius:6px;font-weight:600;font-size:13px}.btn-danger-ghost{background:transparent;border:1px solid var(--line-2);color:var(--text-dim);padding:6px 10px;font-size:11px;border-radius:6px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;transition:all .15s}.btn-danger-ghost:hover{color:var(--danger);border-color:var(--danger)}.btn-danger-ghost:disabled{opacity:.4;cursor:not-allowed}.spin{width:14px;height:14px;border:2px solid #020d1a;border-top-color:transparent;border-radius:50%;animation:sp .8s linear infinite}@keyframes sp{to{transform:rotate(360deg)}}.auth{min-height:100vh;position:relative;display:grid;place-items:center;padding:24px;overflow:hidden}.auth-grid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:56px 56px;-webkit-mask-image:radial-gradient(ellipse 700px 500px at 50% 50%,#000 0%,transparent 75%);mask-image:radial-gradient(ellipse 700px 500px at 50% 50%,#000 0%,transparent 75%);pointer-events:none}.auth-card{position:relative;width:100%;max-width:440px;background:var(--surface);border:1px solid var(--line);padding:36px 32px 28px;display:flex;flex-direction:column;gap:14px}.auth-corner{position:absolute;width:14px;height:14px;border-color:var(--accent);border-style:solid}.auth-corner.tl{top:-1px;left:-1px;border-width:1px 0 0 1px}.auth-corner.tr{top:-1px;right:-1px;border-width:1px 1px 0 0}.auth-corner.bl{bottom:-1px;left:-1px;border-width:0 0 1px 1px}.auth-corner.br{bottom:-1px;right:-1px;border-width:0 1px 1px 0}.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:4px}.auth-logo{height:32px;width:auto;object-fit:contain;border-radius:4px}.auth-sub{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--text-dim);text-transform:uppercase;margin-bottom:18px;padding-bottom:18px;border-bottom:1px dashed var(--line-2)}.fld{display:flex;flex-direction:column;gap:6px}.fld-l{font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--text-dim);text-transform:uppercase;display:flex;align-items:center;gap:8px}.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ok-pill{background:var(--accent-soft);color:var(--accent);font-size:9px;padding:1px 6px;border-radius:3px;letter-spacing:.1em}.err{background:#fc44471f;color:var(--danger);border-left:2px solid var(--danger);padding:8px 12px;font-size:13px}.auth-foot{font-size:13px;color:var(--text-dim);text-align:center;padding-top:12px;border-top:1px dashed var(--line-2);margin-top:8px}.home{padding:clamp(8px,1.5vw,28px) clamp(12px,2vw,28px);display:flex;flex-direction:column;gap:12px;flex:1}.hero{position:relative;background:var(--surface);border:1px solid var(--line);padding:28px 32px 24px;overflow:hidden}.hero-corner{position:absolute;width:18px;height:18px;border-color:var(--accent);border-style:solid}.hero-corner.tl{top:-1px;left:-1px;border-width:1px 0 0 1px}.hero-corner.tr{top:-1px;right:-1px;border-width:1px 1px 0 0}.hero-corner.bl{bottom:-1px;left:-1px;border-width:0 0 1px 1px}.hero-corner.br{bottom:-1px;right:-1px;border-width:0 1px 1px 0}.hero-grid{position:absolute;bottom:0;left:0;right:0;height:50%;background-image:linear-gradient(rgba(60,140,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(60,140,255,.06) 1px,transparent 1px);background-size:36px 36px;background-position:bottom center;transform:perspective(800px) rotateX(60deg);transform-origin:bottom;-webkit-mask-image:linear-gradient(to top,#000 30%,transparent 95%);mask-image:linear-gradient(to top,#000 30%,transparent 95%);pointer-events:none}.hero-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;position:relative}.hero-eyebrow{display:flex;align-items:center;gap:12px}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);animation:pulse 1.6s ease-in-out infinite}.live-dot.off{background:var(--text-mute);box-shadow:none;animation:none}@keyframes pulse{0%,to{box-shadow:0 0 0 0 var(--accent-soft)}50%{box-shadow:0 0 0 6px transparent}}.dot-sep{width:3px;height:3px;background:var(--text-mute);border-radius:50%}.full-badge{background:var(--danger);color:#fff;padding:6px 14px;font-family:var(--mono);font-size:11px;letter-spacing:.2em;font-weight:700;animation:blink 1.2s steps(2) infinite}@keyframes blink{50%{opacity:.5}}.hero-body{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center;position:relative;z-index:2;margin-bottom:28px}@media(max-width:880px){.hero-body{grid-template-columns:1fr;gap:24px}}.counter-stage{display:flex;flex-direction:column;gap:12px}.counter-label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--text-dim);text-transform:uppercase}.delta-line{display:flex;gap:12px;align-items:baseline;margin-top:8px}.delta{font-family:var(--mono);font-size:13px;letter-spacing:.06em}.delta.up{color:var(--accent)}.delta.down{color:var(--text-dim)}.delta.flat{color:var(--text-mute)}.delta-sub{font-family:var(--mono);font-size:11px;color:var(--text-mute);letter-spacing:.06em}.odo{display:flex;gap:6px;padding:4px 0}.odo-cell{position:relative;background:linear-gradient(180deg,var(--bg-2) 0%,#0a100d 50%,var(--bg-2) 100%);border:1px solid var(--line-2);border-radius:4px;overflow:hidden;box-shadow:inset 0 1px #ffffff0a,inset 0 -1px #00000080}.odo-strip{display:flex;flex-direction:column;transition:transform .5s cubic-bezier(.34,1.56,.64,1)}.odo-d{display:grid;place-items:center;font-family:var(--mono);font-size:72px;font-weight:500;color:var(--accent);text-shadow:0 0 14px var(--accent-glow);font-variant-numeric:tabular-nums;line-height:1}.odo-seam{position:absolute;left:0;right:0;top:50%;height:1px;background:#0009;pointer-events:none}.mono-num{font-family:var(--mono);font-size:180px;font-weight:300;letter-spacing:-.04em;color:var(--text);font-variant-numeric:tabular-nums;line-height:.9;text-shadow:0 0 32px var(--accent-soft)}@media(max-width:880px){.mono-num{font-size:120px}}.ring-wrap{position:relative;width:clamp(260px,36vw,680px);height:clamp(260px,36vw,680px)}.ring-num{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.ring-big{font-family:var(--mono);font-size:clamp(28px,5vw,72px);color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1}.ring-sub{font-family:var(--mono);font-size:clamp(10px,1vw,14px);color:var(--text-dim);letter-spacing:.1em}.ring-neg-label{font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:var(--warn);background:#f497521f;padding:2px 8px;border:1px solid oklch(.76 .14 55 / .3)}.stats-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;min-width:320px}.stat{background:var(--bg-2);border:1px solid var(--line);padding:14px 16px}.stat-l{font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--text-dim);text-transform:uppercase;margin-bottom:6px}.stat-v{font-family:var(--mono);font-size:28px;color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.01em}.stat-v.dim{color:var(--text-dim)}.stat-v.warn{color:var(--warn)}.stat-v .unit{font-size:14px;color:var(--text-dim);margin-left:2px}.fill-bar{position:relative;z-index:2}.fill-track{position:relative;height:6px;background:var(--bg-2);border:1px solid var(--line);overflow:hidden}.fill-fill{height:100%;background:var(--accent);box-shadow:0 0 12px var(--accent-glow);transition:width .8s cubic-bezier(.2,.7,.1,1),background .3s}.fill-tick{position:absolute;top:0;bottom:0;width:1px;background:var(--bg)}.fill-labels{display:flex;justify-content:space-between;margin-top:8px;font-family:var(--mono);font-size:10px;color:var(--text-mute);letter-spacing:.06em}.below{display:grid;grid-template-columns:2fr 1fr;gap:20px}@media(max-width:880px){.below{grid-template-columns:1fr}}.panel{background:var(--surface);border:1px solid var(--line);padding:20px 22px;display:flex;flex-direction:column;gap:12px}.panel-h{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px dashed var(--line-2);padding-bottom:10px}.panel-t{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--text);text-transform:uppercase}.panel-meta{color:var(--text-dim)}.spark{width:100%;height:80px;display:block}.log{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.log-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;padding:6px 0;border-bottom:1px solid var(--line);font-size:12px;align-items:center}.log-row:last-child{border:0}.log-t{color:var(--text-mute)}.log-kind{font-family:var(--mono);font-size:10px;padding:2px 8px;letter-spacing:.1em;border:1px solid}.log-kind.in{color:var(--accent);border-color:var(--accent-soft);background:var(--accent-soft)}.log-kind.out{color:var(--text-dim);border-color:var(--line-2)}.log-d{color:var(--text)}.log-tot{color:var(--text-mute)}.log-empty{padding:24px 0;text-align:center;color:var(--text-mute)}.admin{padding:28px;display:flex;flex-direction:column;gap:20px;flex:1}.admin-h{display:flex;justify-content:space-between;align-items:end;gap:24px;border-bottom:1px solid var(--line);padding-bottom:18px;flex-wrap:wrap}.admin-eyebrow{color:var(--text-dim);margin-bottom:4px}.admin-title{font-size:32px;margin:0;font-weight:500;letter-spacing:-.02em}.admin-tabs{display:flex;gap:2px}.tab{background:transparent;border:1px solid var(--line);border-bottom:0;color:var(--text-dim);padding:9px 16px;font-size:13px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;position:relative;bottom:-1px}.tab.on{color:var(--text);background:var(--surface);border-color:var(--accent);border-bottom:1px solid var(--surface)}.tab.on:before{content:"";position:absolute;top:-1px;left:-1px;right:-1px;height:2px;background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.tab:hover:not(.on){color:var(--text)}.tab-danger{color:var(--danger)!important}.tab-danger.on{border-color:var(--danger)!important}.tab-danger.on:before{background:var(--danger)!important;box-shadow:0 0 8px #e6434366!important}.tab-pane{background:var(--surface);border:1px solid var(--line);padding:24px;display:flex;flex-direction:column;gap:20px}.toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px}.search{position:relative;flex:1;max-width:360px}.search input{width:100%;padding-left:36px;background:var(--bg-2)}.search-i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-mute);font-family:var(--mono)}.toolbar-r .count{color:var(--text-dim)}.table{border:1px solid var(--line);background:var(--bg-2)}.thead,.trow{display:grid;grid-template-columns:2fr 1.4fr 1fr 1fr .8fr;align-items:center;gap:12px;padding:12px 16px}.thead.inv,.trow.inv{grid-template-columns:1.6fr 1fr 1.2fr .9fr .7fr .7fr}.thead{background:var(--surface-2);border-bottom:1px solid var(--line);font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--text-dim)}.trow{border-bottom:1px solid var(--line);font-size:13px;transition:background .15s}.trow:hover{background:var(--surface)}.trow:last-child{border-bottom:0}.td-email{display:flex;align-items:center;gap:10px}.td-dim{color:var(--text-dim)}.td-actions{text-align:right}.role-tag{font-family:var(--mono);font-size:10px;padding:3px 8px;letter-spacing:.08em;border:1px solid var(--line-2);color:var(--text-dim)}.role-tag.SUPER_ADMIN{color:var(--accent);border-color:var(--accent-soft);background:var(--accent-soft)}.role-tag.ADMIN{color:var(--warn);border-color:#f3b01d4d}.role-tag.USER{color:var(--text-dim)}.role-sel{background:transparent;border:1px solid var(--line-2);font-family:var(--mono);font-size:10px;padding:4px 8px;letter-spacing:.08em;color:var(--text);text-transform:uppercase}.status-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow);margin-right:6px;vertical-align:middle}.empty{padding:40px 16px;text-align:center;color:var(--text-mute);font-family:var(--mono);font-size:12px;letter-spacing:.08em}.invite-form{background:var(--bg-2);border:1px solid var(--line);padding:18px 20px}.invite-form-l{display:flex;flex-direction:column;gap:10px}.invite-row{display:grid;grid-template-columns:1fr 160px auto;gap:10px}.invite-hint{color:var(--text-mute)}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--accent);color:var(--text);padding:10px 18px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;box-shadow:0 0 24px var(--accent-soft);z-index:1000;animation:slideIn .3s}@keyframes slideIn{0%{transform:translate(-50%,20px);opacity:0}}.stats{gap:24px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media(max-width:880px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi{background:var(--bg-2);border:1px solid var(--line);padding:18px 20px}.kpi-l{color:var(--text-dim);margin-bottom:8px}.kpi-v{font-family:var(--mono);font-size:36px;color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.01em}.kpi-v .unit{font-size:16px;color:var(--text-dim)}.bars{display:flex;flex-direction:column;gap:12px}.bar-row{display:grid;grid-template-columns:120px 1fr 60px;gap:16px;align-items:center}.bar-l{color:var(--text-dim)}.bar-track{height:8px;background:var(--bg-2);border:1px solid var(--line)}.bar-fill{height:100%;background:var(--accent);transition:width .8s ease}.bar-fill.warn{background:var(--warn)}.bar-fill.dim{background:var(--text-mute)}.bar-v{font-family:var(--mono);text-align:right;font-variant-numeric:tabular-nums}.setting{background:var(--bg-2);border:1px solid var(--line);padding:20px 22px;display:flex;flex-direction:column;gap:14px}.setting-h{display:flex;justify-content:space-between;gap:24px}.setting-t{font-size:16px;font-weight:500;margin-bottom:4px}.setting-d{color:var(--text-dim);font-size:13px;max-width:540px}.setting-ctl{display:flex;align-items:center;gap:12px}.setting-meta{color:var(--text-mute)}.cap-input{width:100px;font-family:var(--mono);font-variant-numeric:tabular-nums}.cap-range{flex:1;-webkit-appearance:none;appearance:none;background:transparent;border:0;padding:0;height:24px}.cap-range::-webkit-slider-runnable-track{height:4px;background:var(--bg);border:1px solid var(--line-2)}.cap-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--accent);border:0;margin-top:-6px;box-shadow:0 0 8px var(--accent-glow)}.seg{display:flex;border:1px solid var(--line-2);background:var(--bg)}.seg-i{background:transparent;border:0;color:var(--text-dim);padding:8px 16px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;border-right:1px solid var(--line-2)}.seg-i:last-child{border-right:0}.seg-i.on{background:var(--accent-soft);color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}.modal-bg{position:fixed;inset:0;background:#050807b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:1000;animation:fadeIn .15s}@keyframes fadeIn{0%{opacity:0}}.modal{position:relative;background:var(--surface);border:1px solid var(--line);padding:24px 28px;min-width:380px;max-width:480px}.modal-corner{position:absolute;width:12px;height:12px;border-color:var(--accent);border-style:solid}.modal-corner.tl{top:-1px;left:-1px;border-width:1px 0 0 1px}.modal-corner.tr{top:-1px;right:-1px;border-width:1px 1px 0 0}.modal-corner.bl{bottom:-1px;left:-1px;border-width:0 0 1px 1px}.modal-corner.br{bottom:-1px;right:-1px;border-width:0 1px 1px 0}.modal-h{display:flex;justify-content:space-between;align-items:center;font-size:16px;font-weight:500;margin-bottom:12px}.x-btn{background:transparent;border:0;color:var(--text-dim);font-size:24px;line-height:1;padding:0 6px}.x-btn:hover{color:var(--text)}.modal-body{font-size:14px;color:var(--text-dim);line-height:1.6}.modal-body b{color:var(--text)}.modal-body p{margin:0 0 4px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.home-status{background:var(--surface);border:1px solid var(--line);padding:14px 20px}.cameras-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}@media(max-width:1100px){.cameras-grid{grid-template-columns:1fr 1fr}}@media(max-width:720px){.cameras-grid{grid-template-columns:1fr}}.cam-card{background:var(--surface);border:1px solid var(--line);padding:clamp(8px,1.5vw,20px);display:flex;flex-direction:column;gap:10px}.cam-card-hdr{display:flex;justify-content:space-between;align-items:center;border-bottom:1px dashed var(--line-2);padding-bottom:12px}.cam-id{font-size:13px;color:var(--text)}.cam-counter{display:flex;flex-direction:column;align-items:center;gap:6px}.cam-cap{font-size:12px}.cam-stats{display:flex;flex-direction:column;gap:10px;align-items:stretch;width:fit-content}.cam-stat{background:var(--bg-2);border:1px solid var(--line);padding:clamp(8px,1vw,14px) clamp(10px,1.2vw,20px)}.cam-stat .stat-l{font-size:clamp(8px,.7vw,10px)}.cam-stat .stat-v{font-size:clamp(16px,1.8vw,24px)}.cam-fill{margin-top:0}.cam-hist-wrap{display:flex;flex-direction:column;gap:8px;flex:1}.cam-hist-hdr{border-bottom:1px dashed var(--line-2);padding-bottom:8px}.cam-hist{max-height:240px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}.cam-hist::-webkit-scrollbar{width:4px}.cam-hist::-webkit-scrollbar-track{background:transparent}.cam-hist::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:2px}.cam-log{max-height:none}.cam-log-row{grid-template-columns:auto 1fr auto}.reports-form{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.reports-sel{padding:10px 12px;font-size:13px;text-transform:none;color:var(--text)}.reports-date{font-family:var(--mono)}.reports-empty{padding:32px 0;text-align:center;color:var(--text-mute);display:flex;flex-direction:column;gap:10px;align-items:center}.reports-flag{color:var(--warn);background:#f3b01d14;border:1px solid oklch(.8 .16 80 / .3);padding:6px 14px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;max-width:640px;text-align:left}.reports-table-wrap{display:flex;flex-direction:column;gap:10px}.reports-meta{color:var(--text-dim)}.reports-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);background:var(--bg-2)}.reports-scroll::-webkit-scrollbar{height:4px}.reports-scroll::-webkit-scrollbar-track{background:transparent}.reports-scroll::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:2px}.rpt-table{width:100%;min-width:600px;border-collapse:collapse;font-family:var(--mono);font-size:13px;font-variant-numeric:tabular-nums;white-space:nowrap}.rpt-table th{background:var(--surface-2);border-bottom:1px solid var(--line);font-size:10px;letter-spacing:.12em;color:var(--text-dim);padding:10px 14px;text-align:left;font-weight:500}.rpt-table td{padding:10px 14px;border-bottom:1px solid var(--line);color:var(--text)}.rpt-table tbody tr:last-child td{border-bottom:0}.rpt-table tbody tr:hover td{background:var(--surface)}.rpt-total td{background:var(--surface-2);border-top:1px solid var(--line-2);border-bottom:0;font-weight:600}.td-in{color:var(--accent)}.reset-tab-ctl{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.reset-result-ok{background:var(--accent-soft);color:var(--accent);border-left:2px solid var(--accent);padding:8px 12px;font-size:13px}.cam-status-bar{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;padding-top:10px;border-top:1px dashed var(--line-2)}.cam-status-chip{display:flex;align-items:center;gap:6px;background:var(--bg-2);border:1px solid var(--line);padding:4px 10px}.home-pacha-logo{display:flex;justify-content:center;padding:4px 0 8px}.home-pacha-img{height:72px;width:auto;object-fit:contain;border-radius:6px}.home-main-layout{display:flex;flex-direction:row;gap:32px;align-items:center}.home-left{display:flex;flex-direction:column;gap:16px;flex:1;min-width:0}.home-right{display:flex;align-items:center;justify-content:center;flex-shrink:0}.cameras-tab-selector{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.cam-conn-badge{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;padding:4px 10px;border:1px solid var(--line-2)}.cam-conn-badge.on{color:var(--accent);border-color:var(--accent-soft);background:var(--accent-soft)}.cam-conn-badge.off{color:var(--text-mute)}.cam-detail{display:grid;grid-template-columns:auto 660px;gap:24px;align-items:stretch}.cam-detail-left{display:flex;flex-direction:column}.cam-detail-left .cam-card{flex:1;display:flex;flex-direction:column;justify-content:center}.cam-detail-right{display:flex;flex-direction:column}.cam-detail-right .cam-stream-section{flex:1;display:flex;flex-direction:column}.cam-detail-right .cam-stream-wrap{flex:1}.cam-stream-section{display:flex;flex-direction:column}.cam-stream-wrap{background:var(--bg-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;overflow:hidden}.cam-stream-img{width:100%;height:auto;display:block;object-fit:contain}.cam-stream-placeholder{padding:60px 20px;text-align:center;color:var(--text-mute);width:100%}@media(max-width:720px){.cam-detail{grid-template-columns:1fr}.cam-detail-left,.cam-detail-right{align-items:center}.cam-stream-wrap{max-width:480px;width:100%;margin:0 auto}}@media(max-width:720px){.home-main-layout{flex-direction:column-reverse;gap:16px}.home-pacha-img{height:44px}.home-right .cam-counter{width:100%;display:flex;justify-content:center}.home-right .ring-wrap{width:clamp(200px,60vw,280px)!important;height:clamp(200px,60vw,280px)!important}.hdr{padding:12px 16px;flex-wrap:wrap;gap:12px}.hdr-l{gap:14px}.user-meta{display:none}.home,.admin{padding:12px}.hero{padding:20px}.stats-col{min-width:0}.admin-h{align-items:flex-start;gap:12px}.admin-title{font-size:22px}.admin-tabs{overflow-x:auto;padding-bottom:2px}.tab-pane{padding:12px;gap:12px}.thead{display:none}.trow{display:flex;flex-direction:column;padding:12px;gap:6px;position:relative}.td-email{padding-right:72px;min-width:0}.td-email span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.trow>div:nth-child(3),.trow>div:nth-child(4){display:none}.td-actions{position:absolute;top:12px;right:12px}.trow.inv>div:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:72px}.trow.inv>div:nth-child(3),.trow.inv>div:nth-child(4),.trow.inv>div:nth-child(5){display:none}.invite-row{grid-template-columns:1fr}.setting{padding:14px}.setting-ctl{flex-wrap:wrap}.cap-input,.cap-range{width:100%}.reports-form{flex-direction:column;align-items:stretch}.reports-form .fld,.reports-form .btn-prime{width:100%}.odo-d{font-size:56px}.odo-cell{transform:scale(.7);transform-origin:left center}.mono-num{font-size:88px}}
