@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;700&family=IBM+Plex+Sans:wght@400;500;600&display=swap";:root{color:#f5f2e8;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg:#0f1114c7;--bg-soft:#15181be0;--border:#ffffff1a;--border-strong:#ffc8803d;--text:#f5f2e8;--text-dim:#bcb7ae;--accent:#ef9b52;--accent-strong:#ffb76b;--accent-soft:#ef9b5224;--success:#57c79a;--warning:#f5c56d;--danger:#ef7869;--shadow:0 24px 60px #00000052;background:radial-gradient(circle at 0 0,#ffb05e38,#0000 28%),radial-gradient(circle at 100% 0,#4abb9a29,#0000 30%),linear-gradient(#151414 0%,#0d0e10 48%,#10191a 100%);font-family:IBM Plex Sans,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}button,input,select{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;padding:24px;position:relative;overflow:hidden}.app-shell--camera-route{padding-top:18px}.app-shell__glow{filter:blur(88px);opacity:.26;pointer-events:none;border-radius:999px;width:360px;height:360px;position:absolute}.app-shell__glow--one{background:#ff9f5b;top:-120px;left:-80px}.app-shell__glow--two{background:#2eb798;bottom:15%;right:-80px}.app-shell__grid{pointer-events:none;background-image:linear-gradient(#ffffff05 1px,#0000 1px),linear-gradient(90deg,#ffffff05 1px,#0000 1px);background-size:44px 44px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#000000b3,#0000 95%);mask-image:linear-gradient(#000000b3,#0000 95%)}.topbar,.status-banner,.workspace{z-index:1;position:relative}.topbar{justify-content:space-between;align-items:center;gap:20px;max-width:1600px;margin:0 auto 20px;display:flex}.app-shell--camera-route .topbar{margin-bottom:12px}.status-banner{grid-template-columns:minmax(280px,1.15fr) minmax(0,2fr);gap:14px;max-width:1600px;margin:0 auto 20px;display:grid}.status-banner__intro,.banner-metric{background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px}.status-banner__intro{background:linear-gradient(140deg, #ffb76b24, transparent 48%), linear-gradient(225deg, #49bb9a1f, transparent 38%), var(--bg-soft);padding:20px 22px}.status-banner__intro p{color:var(--text-dim);margin:0}.status-banner__metrics{grid-template-columns:repeat(6,minmax(0,1fr));gap:14px;display:grid}.banner-metric{gap:6px;padding:16px 18px;display:grid}.banner-metric__label{color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase;font-size:.78rem}.banner-metric strong{font-family:Space Grotesk,sans-serif;font-size:1.3rem}.banner-metric small{color:var(--text-dim)}.brand{align-items:center;gap:14px;display:flex}.brand__mark{color:#0f1114;letter-spacing:.08em;background:linear-gradient(135deg,#ffb76beb,#49bb9ac7);border-radius:18px;place-items:center;width:48px;height:48px;font-family:Space Grotesk,sans-serif;font-weight:700;display:grid}.brand strong,.panel__title span,.tile-card strong,.runtime-card strong,.metric-card strong,.camera-row strong,.list-button span,.section-header h2,.empty-state strong{font-family:Space Grotesk,sans-serif}.brand small,.panel p,.tile-card small,.metric-card span,.camera-row small,.runtime-card small,.message,.field label,.checkbox,.list-button small{color:var(--text-dim)}.tabs{flex-wrap:wrap;gap:10px;display:flex}.topbar__auth{align-items:center;gap:12px;display:flex}.topbar__user{justify-items:end;display:grid}.topbar__user small{color:var(--text-dim)}.tabs__button,.button,.list-button,.camera-row,.segmented__option,.chip-button,.day-chip,.icon-button{border:1px solid var(--border);color:var(--text);background:#ffffff08;transition:transform .12s,border-color .12s,background .12s}.tabs__button:hover,.button:hover,.list-button:hover,.camera-row:hover,.segmented__option:hover,.chip-button:hover,.day-chip:hover,.icon-button:hover{border-color:#ffc27c61;transform:translateY(-1px)}.tabs__button{border-radius:999px;align-items:center;gap:8px;padding:12px 16px;display:inline-flex}.tabs__button.is-active{background:var(--accent-soft);border-color:var(--border-strong)}.workspace{grid-template-columns:340px minmax(0,1fr);gap:20px;max-width:1600px;margin:0 auto;display:grid}.workspace--single{grid-template-columns:minmax(0,1fr)}.sidebar,.content{min-width:0}.sidebar{align-content:start;gap:16px;display:grid}.content{gap:18px;display:grid}.content--centered{place-items:center;min-height:calc(100vh - 120px)}.content--camera-route{gap:12px;min-height:calc(100vh - 122px)}.panel,.live-canvas{background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:26px}.panel{padding:20px}.panel--hero{background:linear-gradient(140deg, #ffb76b29, transparent 45%), linear-gradient(225deg, #49bb9a24, transparent 42%), var(--bg-soft);padding:24px}.panel--focus-hint{gap:8px;display:grid}.auth-shell{place-items:center;min-height:100vh;padding:24px;display:grid;position:relative;overflow:hidden}.auth-card{z-index:1;grid-template-columns:minmax(280px,420px) minmax(320px,420px);gap:18px;width:min(980px,100%);display:grid;position:relative}.auth-card__intro,.auth-form{background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:26px}.auth-card__intro{background:linear-gradient(140deg, #ffb76b29, transparent 45%), linear-gradient(225deg, #49bb9a24, transparent 42%), var(--bg-soft);padding:28px}.auth-form{gap:16px;padding:24px;display:grid}.auth-callouts{gap:12px;margin-top:18px;display:grid}.auth-callout{background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;align-items:center;gap:10px;padding:12px 14px;display:flex}.wall-panel{gap:16px;display:grid}.eyebrow{color:var(--accent-strong);letter-spacing:.09em;text-transform:uppercase;background:#ffffff0f;border-radius:999px;margin-bottom:10px;padding:6px 10px;font-size:.78rem;display:inline-flex}h1,h2,.spotlight-panel h3{letter-spacing:-.04em;margin:0;font-weight:700}h1{font-size:clamp(2rem,3.6vw,3.2rem);line-height:1.02}h2{font-size:clamp(1.7rem,2.4vw,2.3rem)}.spotlight-panel h3{font-size:clamp(1.35rem,2vw,1.8rem)}.panel__title,.section-header,.tile-card__header,.section-actions,.tile-card__footer,.camera-row,.list-button,.runtime-card,.recording-summary,.metrics,.segmented,.tabs,.button,.chip-button,.day-chip,.availability-list,.brand{display:flex}.panel__title,.section-header,.tile-card__header,.tile-card__footer,.camera-row,.list-button,.runtime-card{justify-content:space-between;align-items:center}.panel__title{margin-bottom:14px}.metrics,.stack,.status-stack,.availability-list{gap:12px;display:grid}.metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.metric-card,.runtime-card,.user-card{background:#ffffff08;border:1px solid #ffffff0f;border-radius:18px;padding:14px 16px}.metric-card strong,.runtime-card span{font-size:1.4rem}.runtime-card{gap:2px;display:grid}.access-panel,.user-card{gap:12px;display:grid}.user-card__header,.user-card__actions,.user-card__meta{gap:12px;display:flex}.user-card__header,.user-card__actions{justify-content:space-between;align-items:center}.user-card__actions{flex-wrap:wrap;justify-content:flex-end}.user-card__meta{color:var(--text-dim);flex-wrap:wrap;font-size:.88rem}.list-button,.camera-row{text-align:left;border-radius:18px;width:100%;padding:14px 16px}.list-button.is-active,.camera-row.is-active{border-color:var(--border-strong);background:#ef9b521f}.button{border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:12px 16px}.button:disabled{cursor:not-allowed;opacity:.5;transform:none}.button--accent{color:#111;background:linear-gradient(135deg,#ef9b52f0,#ffb76bb8);border-color:#ffd1a19e}.button--danger{background:#ef78691f;border-color:#ef786947}.button--full{width:100%;margin-bottom:14px}.section-header{gap:16px}.section-actions{flex-wrap:wrap;gap:10px}.section-actions--left{justify-content:flex-start}.layout-shell,.camera-layout,.playback-layout,.access-layout{gap:18px;display:grid}.layout-shell{grid-template-columns:360px minmax(0,1fr)}.camera-layout{grid-template-columns:minmax(0,1.25fr) 360px}.playback-layout{grid-template-columns:420px minmax(0,1fr)}.access-layout{grid-template-columns:minmax(0,1fr) minmax(360px,.95fr)}.panel--editor,.panel--playback,.panel--status,.live-canvas,.spotlight-panel{min-height:0}.spotlight-panel{background:linear-gradient(135deg, #ef9b521a, transparent 42%), linear-gradient(225deg, #49bb9a1a, transparent 38%), var(--bg);gap:16px;display:grid}.spotlight-panel--route{gap:14px;min-height:calc(100vh - 122px)}.spotlight-panel__header,.spotlight-panel__actions{justify-content:space-between;align-items:center;gap:16px;display:flex}.spotlight-panel__header p{color:var(--text-dim)}.spotlight-panel__actions{flex-wrap:wrap;justify-content:flex-end}.spotlight-panel__mode-toggle{min-width:220px}.camera-route__toolbar,.camera-route__heading{justify-content:space-between;align-items:center;gap:16px;display:flex}.camera-route__toolbar{flex-wrap:wrap}.camera-route__heading{flex-wrap:wrap;justify-content:flex-start}.camera-route__heading p{color:var(--text-dim);margin:0}.camera-route__content{grid-template-columns:minmax(0,1fr) 190px;align-items:stretch;gap:14px;min-height:0;display:grid}.camera-route__player{min-height:0}.video-frame--camera-route{border-radius:20px;height:min(70vh,100vh - 240px);min-height:0}.motion-review-panel{background:#06080947;border:1px solid #ffffff14;border-radius:22px;gap:14px;padding:16px 18px;display:grid}.motion-review-panel--side{flex-direction:column;height:min(70vh,100vh - 240px);min-height:0;display:flex;overflow:hidden}.motion-review-panel__body{flex-direction:column;flex:1;gap:12px;min-height:0;display:flex;position:relative}.motion-review-panel__timeline-shell{flex-direction:column;flex:1;gap:12px;min-height:0;display:flex}.motion-review-panel__header,.motion-timeline__labels{justify-content:space-between;align-items:center;gap:14px;display:flex}.motion-review-panel__header{flex-wrap:wrap}.motion-review-panel__header--side{align-items:flex-start}.motion-review-panel__header strong,.motion-timeline__labels span{font-family:Space Grotesk,sans-serif}.motion-review-preview{background:#ffffff08;border:1px solid #ffffff14;border-radius:18px;gap:10px;padding:10px;display:grid}.motion-review-preview--floating{z-index:3;pointer-events:none;width:min(208px,100% - 16px);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:absolute;top:6px;right:8px}.motion-review-preview__frame{aspect-ratio:16/9;background:radial-gradient(circle at 100% 0,#49bb9a1a,#0000 30%),linear-gradient(#0b0e10eb,#050708);border-radius:14px;min-height:88px;position:relative;overflow:hidden}.motion-review-preview__image{object-fit:cover;width:100%;height:100%;display:block}.motion-review-preview__placeholder,.motion-review-preview__loading{text-align:center;color:var(--text-dim);place-items:center;padding:12px;font-size:.82rem;display:grid;position:absolute;inset:0}.motion-review-preview__loading{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a0c0e85}.motion-review-preview__meta{gap:4px;display:grid}.motion-review-preview__meta strong{font-family:Space Grotesk,sans-serif;font-size:.78rem}.motion-review-preview__meta small{color:var(--text-dim);font-size:.72rem}.motion-review-panel__header small,.motion-timeline__labels{color:var(--text-dim)}.motion-timeline{z-index:1;flex:1;gap:10px;min-height:0;display:grid;position:relative}.motion-timeline--vertical{grid-template-rows:minmax(0,1fr) auto;grid-template-columns:minmax(0,1fr)}.motion-timeline__track{cursor:ew-resize;touch-action:none;padding:12px 0 6px;position:relative}.motion-timeline__track--vertical{cursor:ns-resize;overscroll-behavior:contain;background:linear-gradient(90deg,#49bb9a0f,#0000 45%),#090c0ed1;border:1px solid #ffffff14;border-radius:18px;height:100%;min-height:0;padding:6px;display:block;position:relative;overflow-y:auto}.motion-timeline__bars{background:linear-gradient(#49bb9a0f,#0000 45%),#090c0ed1;border:1px solid #ffffff14;border-radius:18px;grid-auto-columns:minmax(2px,1fr);grid-auto-flow:column;align-items:end;gap:1px;height:88px;padding:0 2px;display:grid;overflow:hidden}.motion-timeline__content--vertical{min-height:100%;position:relative}.motion-timeline__hover{pointer-events:none;z-index:2;position:absolute;left:0;right:0;transform:translateY(-50%)}.motion-timeline__hover-line{background:#ef9b52eb;height:2px;box-shadow:0 0 0 4px #ef9b521a}.motion-timeline__hover-label{color:var(--text);white-space:nowrap;box-shadow:var(--shadow);background:#0c0e10f5;border:1px solid #ffb76b47;border-radius:10px;padding:6px 8px;font-size:.74rem;line-height:1.2;position:absolute;top:0;right:calc(100% + 10px);transform:translateY(-50%)}.motion-timeline__bars--vertical-scroll{grid-auto-rows:minmax(5px,1fr);grid-auto-flow:row;grid-auto-columns:unset;background:0 0;border:0;align-content:stretch;place-items:stretch end;gap:1px;width:100%;height:100%;padding:0}.motion-timeline__bar{min-height:10%;height:calc(var(--motion-level) * 100%);opacity:calc(.18 + (var(--motion-level) * .82));background:linear-gradient(#ffb76bf0,#49bb9ae0);border-radius:999px 999px 0 0;align-self:end;transition:opacity .12s,filter .12s}.motion-timeline--vertical .motion-timeline__bar{min-width:12%;min-height:2px;width:calc(var(--motion-level) * 100%);border-radius:999px 0 0 999px;place-self:stretch end;height:auto}.motion-timeline__bar.is-active{filter:brightness(1.24);opacity:1}.motion-timeline__playhead{pointer-events:none;background:#fffffff5;border-radius:999px;width:2px;position:absolute;top:4px;bottom:0;transform:translate(-50%);box-shadow:0 0 0 4px #ffffff1f}.motion-timeline__playhead--vertical{width:auto;height:2px;inset:auto 0;transform:translateY(-50%)}.motion-timeline__labels--vertical{text-align:center;justify-items:center;gap:6px;display:grid}.form-panel{gap:16px;display:grid}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.form-grid--compact{grid-template-columns:minmax(0,1fr) auto}.field{gap:8px;display:grid}.field--full{grid-column:1/-1}.input{border:1px solid var(--border);width:100%;color:var(--text);background:#06080975;border-radius:16px;padding:13px 14px}.input:focus{border-color:#ffc27c85;outline:none;box-shadow:0 0 0 4px #ef9b521a}.checkbox{align-items:center;gap:10px;display:flex}.checkbox input{width:18px;height:18px}.segmented{gap:10px}.dashboard-mode-toggle{min-width:260px}.segmented__option{border-radius:16px;flex:1;padding:12px 14px}.segmented__option.is-active{background:#49bb9a1f;border-color:#49bb9a4d}.message{margin:0}.message--danger{color:#ffb0a8}.add-tile-list,.recording-summary{gap:12px;display:grid}.chip-button,.day-chip{border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:10px 12px}.availability-list{max-height:360px;margin-top:12px;overflow:auto}.day-chip{justify-content:space-between}.day-chip span,.day-chip small{display:block}.live-canvas{min-height:720px;padding:12px}.wall-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;display:grid}.wall-tile{background:#090b0d;border:1px solid #ffffff14;border-radius:20px;position:relative;overflow:hidden}.wall-tile.is-selected{border-color:#ffc27c75;box-shadow:inset 0 0 0 1px #ffc27c4d}.wall-tile__overlay,.wall-tile__overlay-right{align-items:center;gap:10px;display:flex}.wall-tile__overlay{background:linear-gradient(#0000,#060809d6);justify-content:space-between;padding:12px 14px;position:absolute;inset:auto 0 0}.wall-tile__overlay strong{display:block}.wall-tile__overlay small{color:#ffffffbf}.wall-tile__overlay-right{flex-wrap:wrap;justify-content:flex-end}.dashboard-grid{min-height:680px}.dashboard-grid .react-grid-item{transition:transform .16s}.dashboard-grid .react-grid-placeholder{background:#ef9b5229;border:1px dashed #ffc27c66;border-radius:22px}.tile-card{background:linear-gradient(#0d1114f0,#090c0efa);border:1px solid #ffffff14;border-radius:22px;grid-template-rows:auto 1fr auto;height:100%;display:grid;overflow:hidden}.tile-card.is-selected{border-color:#ffc27c75;box-shadow:inset 0 0 0 1px #ffc27c4d}.tile-card__header,.tile-card__footer{background:#ffffff08;padding:12px 14px}.tile-card__header{cursor:grab}.tile-card__actions{align-items:center;gap:8px;display:flex}.tile-card__badge{color:var(--accent-strong);text-transform:uppercase;letter-spacing:.08em;background:#ef9b5224;border-radius:999px;align-items:center;padding:6px 9px;font-size:.74rem;display:inline-flex}.tile-card__footer{color:var(--text-dim);font-size:.82rem}.icon-button{border-radius:10px;place-items:center;width:30px;height:30px;display:inline-grid}.status-pill{text-transform:capitalize;border-radius:999px;justify-content:center;align-items:center;min-width:90px;padding:6px 10px;font-size:.78rem;display:inline-flex}.status-pill--online{color:#111;background:#57c79af0}.status-pill--degraded{color:#111;background:#f5c56df0}.status-pill--offline{color:#111;background:#ef7869f0}.video-frame{--video-zoom-scale:1;--video-pan-x:0px;--video-pan-y:0px;background:radial-gradient(circle at 100% 0,#49bb9a1f,#0000 30%),linear-gradient(#0b0e10eb,#050708);height:100%;min-height:220px;position:relative;overflow:hidden}.video-frame--zoomable{cursor:default;overscroll-behavior:none}.video-frame--zoomed{touch-action:none}.video-frame--dragging{-webkit-user-select:none;user-select:none}.video-frame__media{object-fit:cover;width:100%;height:100%;transform:translate3d(var(--video-pan-x), var(--video-pan-y), 0) scale(var(--video-zoom-scale));transform-origin:50%;will-change:transform;transition:transform .14s ease-out;display:block}.video-frame__live-root,.video-frame__live-root>video-stream,.video-frame__live-root video{width:100%;height:100%}.video-frame__live-root,.video-frame__live-root>video-stream{display:block}.video-frame__live-root video{object-fit:cover;transform:translate3d(var(--video-pan-x), var(--video-pan-y), 0) scale(var(--video-zoom-scale));transform-origin:50%;will-change:transform;transition:transform .14s ease-out}.video-frame--dragging .video-frame__media,.video-frame--dragging .video-frame__live-root video{transition:none}.video-frame__overlay{text-align:center;color:var(--text-dim);background:linear-gradient(#0a0d0f38,#0a0d0fa8);place-items:center;padding:18px;display:grid;position:absolute;inset:0}.video-frame__badge{z-index:2;color:var(--text);letter-spacing:.04em;pointer-events:none;background:#060809b8;border:1px solid #ffffff1f;border-radius:999px;padding:6px 10px;font-size:.78rem;position:absolute;top:12px;right:12px}.video-frame--spotlight{min-height:460px}.video-frame--wall{aspect-ratio:16/9;min-height:220px}.empty-state{text-align:center;min-height:320px;color:var(--text-dim);border:1px dashed #ffffff1f;border-radius:24px;place-items:center;gap:10px;padding:24px;display:grid}.empty-state--slim{min-height:220px}.react-resizable-handle{opacity:.8}@media (width<=1320px){.status-banner,.status-banner__metrics,.workspace,.layout-shell,.camera-layout,.playback-layout,.access-layout,.camera-route__content{grid-template-columns:1fr}.video-frame--camera-route{height:min(62vh,100vh - 250px)}.motion-review-panel--side{height:min(46vh,420px)}.sidebar{order:2}.auth-card{grid-template-columns:1fr}}@media (width<=900px){.app-shell{padding:16px}.topbar,.status-banner,.section-header,.spotlight-panel__header,.camera-route__toolbar,.camera-route__heading,.topbar__auth{flex-direction:column;align-items:flex-start}.topbar__user{justify-items:start}.form-grid,.metrics,.form-grid--compact,.status-banner__metrics{grid-template-columns:1fr}.live-canvas{min-height:560px}.content--camera-route,.spotlight-panel--route{min-height:auto}.video-frame--camera-route{height:min(50vh,100vh - 280px)}.motion-review-panel--side{height:min(38vh,360px)}}
