:root{color:#1c2430;background:#f4f7f9;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}body.viewer-pseudo-fullscreen{overflow:hidden}a{color:inherit}h1,h2,p{margin:0}h1{font-size:1.55rem;font-weight:700}h2{font-size:.95rem;font-weight:700}h3{margin:0;font-size:1rem}ol,ul{margin:0;padding:0}.surface{width:min(100%,980px);min-height:100vh;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:16px}.surface-narrow{width:min(100%,620px);justify-content:center}.topbar,.grid,.actions,.controls,.metrics div{display:flex;gap:12px}.topbar{align-items:center;justify-content:space-between}.home-page{width:min(100%,1080px);gap:22px}.home-topbar{min-height:48px}.brand-heading{line-height:1}.brand-lockup{display:inline-flex;align-items:center;gap:10px;font-size:1.05rem;font-weight:800}.brand-lockup img{width:36px;height:36px;border-radius:8px}.home-hero{min-height:430px;padding:36px;display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,.42fr);align-items:center;gap:28px;border-radius:8px;background:#263744;color:#fff}.home-hero-content{display:grid;gap:16px}.home-kicker,.home-section-label{color:#64d3ad;font-size:.78rem;font-weight:800;text-transform:uppercase}.home-hero h1{font-size:4.75rem;line-height:.95}.home-lead{max-width:620px;color:#dbe9ef;font-size:1.08rem;line-height:1.75}.home-hero-actions{margin-top:4px}.home-hero .button:not(.primary){border-color:#dbe9ef;background:transparent;color:#fff}.home-hero-visual{min-height:260px;display:grid;place-items:center;gap:16px;align-content:center}.home-hero-visual img{width:min(150px,100%);height:auto;border-radius:8px;box-shadow:0 18px 44px #0000003d}.home-hero-visual div{min-height:40px;padding:8px 12px;display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.25);border-radius:999px;background:#ffffff1a;color:#dbe9ef;font-size:.85rem;font-weight:800}.home-signal-dot{width:9px;height:9px;border-radius:999px;background:#64d3ad;box-shadow:0 0 0 5px #64d3ad2e}.home-warning{padding:18px;display:grid;gap:8px;border:1px solid #f0c778;border-radius:8px;background:#fff7df;color:#4d3700}.home-warning h2{font-size:1rem}.home-warning p,.home-card p,.home-use-list p,.home-steps p{line-height:1.65}.home-section{display:grid;gap:14px}.home-section>div:first-child{display:grid;gap:6px}.home-section h2{font-size:1.35rem}.home-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.home-card{min-height:164px;padding:16px;display:grid;align-content:start;gap:10px;border:1px solid #d7e0e7;border-radius:8px;background:#fff}.home-card p,.home-use-list p,.home-steps p{color:#4c5f6f}.home-use-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.home-use-list>div{min-height:120px;padding:14px;display:grid;align-content:start;gap:8px;border-left:4px solid #13795b;border-radius:8px;background:#fff}.home-use-list span{font-weight:800}.home-steps{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;list-style:none}.home-steps li{min-height:168px;padding:14px;display:grid;align-content:start;gap:12px;border:1px solid #d7e0e7;border-radius:8px;background:#fff}.home-steps span{width:32px;height:32px;display:inline-grid;place-items:center;border-radius:999px;background:#d9f2e8;color:#0f6248;font-weight:900}.app-footer{margin-top:auto;padding:12px 0 4px;display:flex;justify-content:center;text-align:center;color:#5f6d7a;font-size:.9rem}.app-footer a{color:inherit;font-weight:700;text-decoration:underline;text-underline-offset:3px}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.actions,.controls{flex-wrap:wrap}.camera-controls{display:grid;grid-template-columns:minmax(0,3fr) minmax(0,1fr);gap:8px}.camera-controls .button{min-width:0;padding-inline:6px;white-space:nowrap}.viewer-controls{display:grid;grid-template-columns:1fr}.viewer-controls>#connect-viewer{width:min(100%,520px);justify-self:center}.viewer-control-row{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.viewer-control-row .button{min-width:0}.button{min-height:44px;padding:10px 16px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #bec8d2;border-radius:8px;background:#fff;color:#1c2430;text-decoration:none;font-weight:700;cursor:pointer}.button:disabled{cursor:not-allowed;opacity:.55}.button.primary{border-color:#13795b;background:#13795b;color:#fff}.button.active{border-color:#7a4d00;background:#fff1cf;color:#7a4d00}.muted{color:#5f6d7a}.badge{min-width:108px;padding:6px 10px;border-radius:999px;background:#dfe8ef;color:#30404f;text-align:center;font-size:.85rem;font-weight:700}.badge.good{background:#d9f2e8;color:#0f6248}.badge.warn{background:#fff1cf;color:#805400}.badge.bad{background:#fce1df;color:#9c241b}.video-frame{width:100%;aspect-ratio:16 / 9;border-radius:8px;background:#111922;color:#d8e3ea;object-fit:contain}.camera-video-shell{position:relative}.camera-video-shell .video-frame,.viewer-video-shell .video-frame{display:block}.viewer-video-shell{position:relative;width:100%;aspect-ratio:16 / 9;overflow:hidden;background:#111922;border-radius:8px}.viewer-video-shell.pseudo-fullscreen{position:fixed;inset:0;z-index:2000;width:100vw;height:100dvh;aspect-ratio:auto;border-radius:0;background:#000}.viewer-video-shell .video-frame{position:absolute;inset:0;width:100%;height:100%;aspect-ratio:auto;transform-origin:center;transition:transform .12s ease,opacity .12s ease}.viewer-video-shell.pseudo-fullscreen .video-frame{border-radius:0}.viewer-video-shell .filter-canvas{position:absolute;inset:0;display:none;height:100%;pointer-events:none}.viewer-video-shell #remote-video{opacity:1}.viewer-video-shell.filter-active .filter-canvas{display:block}.viewer-video-shell.filter-active #remote-video{opacity:0}.viewer-controls.pseudo-fullscreen{position:fixed;left:10px;right:10px;bottom:max(10px,env(safe-area-inset-bottom));z-index:2001;justify-content:center;padding:8px;border-radius:8px;background:#f4f7f9e0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.viewer-controls.pseudo-fullscreen .button{min-height:40px;padding:8px 12px}.dim-overlay{position:fixed;inset:0;z-index:1000;pointer-events:none;background:#000000e6;opacity:0;transition:opacity .16s ease}.dim-overlay.active{opacity:1}.placeholder{display:grid;place-items:center;text-align:center}.status-panel{padding:14px;border:1px solid #d7e0e7;border-radius:8px;background:#fff}.link{display:block;margin-top:8px;overflow-wrap:anywhere;color:#0f6fbd}.watch-link-panel{display:grid;justify-items:center;gap:14px;text-align:center}.watch-link-panel>div{width:min(100%,620px)}.qr-code{width:144px;height:144px;border:1px solid #d7e0e7;border-radius:8px;background:#fff}.panel-actions{margin-top:12px;display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.metrics{margin:10px 0 0;display:grid;gap:8px}.metrics div{justify-content:space-between}.metrics dt{color:#5f6d7a}.metrics dd{margin:0;font-weight:700}.session-list{margin-top:10px;display:grid;gap:8px;color:#5f6d7a}.session-row{min-height:34px;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-radius:8px;background:#f4f7f9;color:#1c2430}@media(max-width:700px){.surface{padding:14px}.grid,.topbar,.watch-link-panel{grid-template-columns:1fr}.topbar{align-items:flex-start}.home-topbar{align-items:center}.home-topbar .button{min-height:40px;padding:8px 12px}.home-hero{min-height:auto;padding:22px;grid-template-columns:1fr}.home-hero h1{font-size:2.6rem}.home-lead{font-size:1rem}.home-hero-actions .button{width:100%}.home-hero-visual{min-height:170px}.home-hero-visual img{width:112px}.home-card-grid,.home-use-list,.home-steps{grid-template-columns:1fr}.home-card,.home-use-list>div,.home-steps li{min-height:auto}.camera-controls{grid-template-columns:minmax(0,3fr) minmax(0,1fr)}.camera-controls .button{font-size:.9rem}.qr-code{width:min(192px,100%);height:auto}}
