:root{color:#1c2430;font-synthesis:none;text-rendering:optimizelegibility;background:#f4f7f9;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}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{flex-direction:column;gap:16px;width:min(100%,980px);min-height:100vh;margin:0 auto;padding:20px;display:flex}.surface-narrow{justify-content:center;width:min(100%,620px)}.topbar,.grid,.actions,.controls,.metrics div{gap:12px;display:flex}.topbar{justify-content:space-between;align-items:center}.brand-heading{line-height:1}.brand-lockup{align-items:center;gap:10px;font-size:1.05rem;font-weight:800;display:inline-flex}.brand-lockup img{border-radius:8px;width:36px;height:36px}.app-footer{text-align:center;color:#5f6d7a;justify-content:center;margin-top:auto;padding:12px 0 4px;font-size:.9rem;display:flex}.app-footer a{color:inherit;text-underline-offset:3px;font-weight:700;text-decoration:underline}.app-footer .app-footer-link{color:var(--rp-fg);justify-content:center;text-decoration:none}.lp-page{--lp-bg:oklch(99.7% .004 95);--lp-surface:oklch(100% 0 0);--lp-fg:oklch(20.6% .015 108);--lp-muted:oklch(54.5% 0 0);--lp-border:oklch(93.1% 0 0);--lp-accent:oklch(69.6% .187 48);--lp-accent-strong:oklch(64% .205 45);--lp-blue:oklch(56.7% .199 259);--lp-green:oklch(56.4% .108 154);--lp-brown:oklch(34.2% .065 62);--lp-warm:oklch(95.9% .014 67);--lp-warn:oklch(78% .12 78);--lp-shadow:0 18px 50px color-mix(in oklch, var(--lp-brown) 14%, transparent);background:radial-gradient(circle at 88% 4%, color-mix(in oklch, var(--lp-warm) 80%, transparent) 0 230px, transparent 420px), linear-gradient(180deg, var(--lp-bg), var(--lp-surface) 34%, var(--lp-bg));min-height:100vh;color:var(--lp-fg);font-family:Noto Sans JP,-apple-system,BlinkMacSystemFont,Hiragino Sans,Yu Gothic,Segoe UI,system-ui,sans-serif;line-height:1.75}.lp-page svg{width:20px;height:20px;display:block}.lp-page img{max-width:100%;display:block}.lp-container{width:min(1180px,100% - 40px);margin:0 auto}.lp-site-header{z-index:20;border-bottom:1px solid color-mix(in oklch, var(--lp-border), transparent 25%);background:color-mix(in oklch, var(--lp-surface) 86%, transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);position:sticky;top:0}.lp-nav{justify-content:space-between;align-items:center;gap:20px;min-height:76px;display:flex}.lp-brand{min-width:0;color:var(--lp-fg);align-items:center;gap:12px;font-size:28px;font-weight:900;line-height:1;text-decoration:none;display:inline-flex}.lp-brand img{border-radius:10px;flex:none;width:36px;height:36px}.lp-nav-links{color:var(--lp-muted);align-items:center;gap:22px;font-size:14px;font-weight:800;display:flex}.lp-nav-links a{color:inherit;text-decoration:none}.lp-nav-links a:hover{color:var(--lp-fg)}.lp-cta,.lp-secondary-link{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;gap:10px;min-height:50px;font-weight:900;text-decoration:none;display:inline-flex}.lp-cta{background:linear-gradient(180deg, var(--lp-accent), var(--lp-accent-strong));color:#fff;box-shadow:0 12px 28px color-mix(in oklch, var(--lp-accent) 28%, transparent);border:0;padding:0 24px;transition:transform .18s,box-shadow .18s}.lp-cta:hover{box-shadow:0 16px 34px color-mix(in oklch, var(--lp-accent) 34%, transparent);transform:translateY(-1px)}.lp-cta:active{transform:translateY(0)}.lp-secondary-link{border:1px solid color-mix(in oklch, var(--lp-accent) 22%, var(--lp-border));background:linear-gradient(180deg, color-mix(in oklch, var(--lp-warm) 82%, white), color-mix(in oklch, var(--lp-accent) 12%, white));color:var(--lp-brown);box-shadow:0 10px 24px color-mix(in oklch, var(--lp-brown) 8%, transparent);padding:0 18px;transition:background .18s,border-color .18s,box-shadow .18s,transform .18s}.lp-secondary-link:hover{border-color:color-mix(in oklch, var(--lp-accent) 34%, var(--lp-border));background:linear-gradient(180deg, color-mix(in oklch, var(--lp-warm) 70%, white), color-mix(in oklch, var(--lp-accent) 18%, white));box-shadow:0 14px 30px color-mix(in oklch, var(--lp-brown) 12%, transparent);transform:translateY(-1px)}.lp-secondary-link:active{transform:translateY(0)}.lp-hero{isolation:isolate;background:linear-gradient(90deg, var(--lp-bg) 0%, var(--lp-bg) 26%, color-mix(in oklch, var(--lp-bg) 90%, transparent) 38%, color-mix(in oklch, var(--lp-bg) 56%, transparent) 54%, transparent 74%), url(/lp/hero-roompeek.png) 62% center / auto 100% no-repeat;min-height:min(700px,100vh - 140px);position:relative;overflow:clip}.lp-hero:after{content:"";z-index:-1;background:linear-gradient(180deg, transparent, var(--lp-surface));height:22%;position:absolute;inset:auto 0 0}.lp-hero-inner{min-height:inherit;align-items:center;padding:54px 0 74px;display:grid}.lp-hero-content{justify-items:start;max-width:560px;display:grid}.lp-eyebrow{border:1px solid color-mix(in oklch, var(--lp-brown) 12%, transparent);background:color-mix(in oklch, var(--lp-warm) 78%, white);min-height:38px;color:var(--lp-brown);border-radius:999px;align-items:center;gap:9px;padding:8px 14px;font-size:13px;font-weight:900;display:inline-flex}.lp-hero h1{color:var(--lp-fg);letter-spacing:0;margin-top:28px;font-size:68px;font-weight:900;line-height:1.16}.lp-hero-copy{max-width:520px;color:var(--lp-fg);margin-top:26px;font-size:20px;font-weight:700;line-height:1.75}.lp-hero-actions{flex-wrap:wrap;align-items:center;gap:14px;margin-top:30px;display:flex}.lp-microcopy{color:var(--lp-muted);margin-top:16px;padding-left:52px;font-size:14px;font-weight:800}.lp-section{background:var(--lp-surface);padding:78px 0}.lp-section-soft{background:color-mix(in oklch, var(--lp-warm) 26%, var(--lp-surface))}.lp-section-head{text-align:center;justify-items:center;gap:10px;margin-bottom:34px;display:grid}.lp-section-head p{color:var(--lp-blue);letter-spacing:0;text-transform:uppercase;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;font-weight:900}.lp-section-head h2{color:var(--lp-fg);letter-spacing:0;font-size:38px;font-weight:900;line-height:1.25}.lp-section-head span{background:var(--lp-blue);border-radius:999px;width:58px;height:4px}.lp-features-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;display:grid}.lp-feature-card{border:1px solid var(--lp-border);background:linear-gradient(180deg, var(--lp-surface), color-mix(in oklch, var(--lp-warm) 30%, white));text-align:center;border-radius:8px;flex-direction:column;align-items:center;gap:18px;min-height:270px;padding:30px 24px;display:flex}.lp-feature-icon{width:82px;height:82px;color:var(--lp-brown);place-items:center;display:grid}.lp-feature-card:nth-child(2) .lp-feature-icon{color:oklch(50% .055 230)}.lp-feature-card:nth-child(3) .lp-feature-icon{color:var(--lp-green)}.lp-feature-card:nth-child(4) .lp-feature-icon{color:oklch(76% .13 78)}.lp-feature-icon svg{stroke-width:1.65px;width:64px;height:64px}.lp-feature-card h3{color:var(--lp-fg);letter-spacing:0;font-size:18px;font-weight:900;line-height:1.45}.lp-feature-card p{color:var(--lp-muted);text-align:left;font-size:14px;font-weight:700}.lp-use-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;display:grid}.lp-use-card{border:1px solid var(--lp-border);background:var(--lp-surface);box-shadow:0 10px 28px color-mix(in oklch, var(--lp-brown) 8%, transparent);border-radius:8px;overflow:hidden}.lp-use-image{background:var(--lp-warm);height:315px;position:relative;overflow:hidden}.lp-use-image img{object-fit:cover;object-position:center;width:100%;height:100%}.lp-use-badge{border:1px solid color-mix(in oklch, var(--lp-border) 78%, white);min-height:52px;color:var(--lp-fg);box-shadow:0 12px 28px color-mix(in oklch, var(--lp-brown) 18%, transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:oklch(100% 5.96046e-8 none/.94);border-radius:999px;align-items:center;gap:10px;padding:9px 18px 9px 10px;font-size:18px;font-weight:900;line-height:1;display:inline-flex;position:absolute;top:18px;left:18px}.lp-use-badge span{background:var(--lp-blue);color:#fff;border-radius:50%;place-items:center;width:34px;height:34px;display:grid}.lp-use-badge.is-green span{background:var(--lp-green)}.lp-use-badge.is-green svg{transform:rotate(-22deg)}.lp-use-badge svg{width:19px;height:19px}.lp-use-card p{color:var(--lp-fg);text-align:center;padding:22px 24px 26px;font-weight:800}.lp-steps{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;list-style:none;display:grid}.lp-step-card{border:1px solid var(--lp-border);background:var(--lp-surface);min-height:380px;box-shadow:0 8px 24px color-mix(in oklch, var(--lp-brown) 5%, transparent);border-radius:8px;padding:22px}.lp-step-no{background:var(--lp-blue);color:#fff;border-radius:50%;place-items:center;width:34px;height:34px;margin-bottom:12px;font-weight:900;display:grid}.lp-step-card p{min-height:100px;color:var(--lp-fg);font-size:14px;font-weight:800}.lp-mini-phone{background:linear-gradient(#fff,oklch(98% .004 240));border:4px solid oklch(78% .01 260);border-bottom:0;border-radius:8px 8px 0 0;width:min(190px,100%);min-height:190px;margin:18px auto 0;padding:16px;overflow:hidden}.lp-mini-phone img{object-fit:cover;object-position:center 52%;border-radius:8px;width:100%;height:98px}.lp-mini-bar{background:oklch(86% .006 260);border-radius:999px;width:54px;height:6px;margin:0 auto 26px}.lp-mini-content{min-height:72px;color:var(--lp-muted);text-align:center;place-items:center;font-weight:900;display:grid}.lp-mini-content svg{width:52px;height:52px}.lp-mini-action{background:var(--lp-accent);color:#fff;border-radius:8px;place-items:center;width:100%;min-height:42px;margin-top:18px;font-size:12px;font-weight:900;display:grid}.lp-mini-action.is-blue{background:var(--lp-blue)}.lp-mini-qr{aspect-ratio:1;outline:1px solid color-mix(in oklch, var(--lp-border) 70%, var(--lp-blue));width:96px;color:var(--lp-fg);box-shadow:0 8px 18px color-mix(in oklch, var(--lp-brown) 10%, transparent);background:#fff;border:10px solid #fff;border-radius:6px;place-items:center;margin:10px auto 0;display:grid}.lp-mini-qr svg{stroke-width:2.6px;width:72px;height:72px}.lp-notice-section{padding-top:44px}.lp-notice{border:1px solid color-mix(in oklch, var(--lp-warn), white 42%);background:linear-gradient(90deg, color-mix(in oklch, var(--lp-warm) 72%, white), var(--lp-surface));border-radius:8px;grid-template-columns:1fr minmax(260px,360px);align-items:center;gap:28px;padding:34px;display:grid}.lp-notice h2{color:var(--lp-fg);letter-spacing:0;align-items:center;gap:10px;font-size:24px;font-weight:900;display:flex}.lp-notice h2 svg{color:var(--lp-warn)}.lp-notice p{color:color-mix(in oklch, var(--lp-fg) 80%, var(--lp-muted));margin-top:6px;font-weight:750}.lp-lan-map{color:var(--lp-brown);grid-template-columns:54px 1fr 80px 1fr 74px;align-items:center;gap:10px;display:grid}.lp-lan-map span{border:1px solid color-mix(in oklch, var(--lp-brown) 18%, transparent);background:var(--lp-surface);height:54px;box-shadow:0 8px 22px color-mix(in oklch, var(--lp-brown) 10%, transparent);border-radius:8px;place-items:center;display:grid}.lp-lan-map i{border-top:3px dotted var(--lp-accent);height:1px}.lp-faq-list{gap:12px;max-width:860px;margin:0 auto;display:grid}.lp-faq-item{border:1px solid var(--lp-border);background:var(--lp-surface);border-radius:8px;overflow:hidden}.lp-faq-item summary{min-height:66px;color:var(--lp-fg);cursor:pointer;justify-content:space-between;align-items:center;gap:16px;padding:0 22px;font-weight:900;list-style:none;display:flex}.lp-faq-item summary::-webkit-details-marker{display:none}.lp-faq-item summary svg{background:color-mix(in oklch, var(--lp-blue) 12%, white);width:28px;height:28px;color:var(--lp-blue);border-radius:50%;flex:none;padding:6px;transition:transform .2s}.lp-faq-item[open] summary svg{transform:rotate(45deg)}.lp-faq-item p{color:var(--lp-muted);padding:0 22px 20px;font-weight:750}.lp-final-cta{background:linear-gradient(135deg, color-mix(in oklch, var(--lp-accent) 10%, white), color-mix(in oklch, var(--lp-blue) 7%, white)), var(--lp-surface);text-align:center;padding:64px 0}.lp-final-cta h2{max-width:1000px;color:var(--lp-fg);letter-spacing:0;margin:0 auto;font-size:42px;font-weight:900;line-height:1.28}.lp-final-cta p{max-width:620px;color:var(--lp-muted);margin:14px auto 26px;font-weight:800}.lp-footer{border-top:1px solid var(--lp-border);background:var(--lp-bg);color:var(--lp-muted);padding:34px 0 42px;font-size:13px;font-weight:800}.lp-footer-row,.lp-footer nav{flex-wrap:wrap;align-items:center;gap:18px;display:flex}.lp-footer-row{justify-content:space-between}.lp-footer a{color:inherit;text-decoration:none}@media (width>=1025px){.lp-nav{min-height:88px}.lp-brand{font-size:34px}.lp-brand img{width:40px;height:40px}}@media (width<=1100px){.lp-nav-links{display:none}.lp-hero{background:linear-gradient(90deg, var(--lp-bg) 0%, var(--lp-bg) 32%, color-mix(in oklch, var(--lp-bg) 88%, transparent) 48%, color-mix(in oklch, var(--lp-bg) 54%, transparent) 64%, transparent 84%), url(/lp/hero-roompeek.png) 58% center / auto 100% no-repeat;min-height:min(640px,100vh - 118px)}.lp-hero h1{font-size:58px}.lp-features-grid,.lp-steps{grid-template-columns:repeat(2,minmax(0,1fr))}.lp-notice{grid-template-columns:1fr}}@media (width<=720px){.lp-container{width:min(100% - 28px,1180px)}.lp-nav{gap:12px;min-height:68px}.lp-brand{gap:9px;font-size:24px}.lp-brand img{width:38px;height:38px}.lp-nav-cta{min-height:42px;padding:0 14px;font-size:13px}.lp-nav-cta svg{width:18px;height:18px}.lp-hero{background:linear-gradient(90deg, color-mix(in oklch, var(--lp-bg) 92%, transparent) 0%, color-mix(in oklch, var(--lp-bg) 82%, transparent) 42%, color-mix(in oklch, var(--lp-bg) 34%, transparent) 62%, transparent 76%), linear-gradient(180deg, color-mix(in oklch, var(--lp-bg) 18%, transparent) 0%, color-mix(in oklch, var(--lp-bg) 24%, transparent) 44%, color-mix(in oklch, var(--lp-bg) 62%, transparent) 74%, var(--lp-surface) 100%), url(/lp/hero-roompeek.png) center 99px / min(430px, 100%) auto no-repeat;min-height:auto}.lp-hero-inner{padding:28px 0 34px}.lp-hero-content{max-width:100%}.lp-eyebrow{max-width:100%;min-height:36px;padding:7px 12px;font-size:12px}.lp-hero h1{max-width:340px;margin-top:48px;font-size:42px;line-height:1.18}.lp-hero-copy{max-width:340px;margin-top:22px;font-size:16px;line-height:1.65}.lp-hero-actions{order:2;width:100%;margin-top:28px}.lp-hero-actions .lp-cta,.lp-hero-actions .lp-secondary-link{width:100%}.lp-hero-actions .lp-cta{background:var(--lp-accent-strong);box-shadow:none}.lp-hero-actions .lp-cta:hover{box-shadow:none}.lp-microcopy{border:1px solid color-mix(in oklch, var(--lp-brown) 12%, transparent);background:color-mix(in oklch, var(--lp-warm) 74%, white);color:var(--lp-brown);text-align:center;border-radius:999px;order:1;justify-self:center;margin-top:26px;padding:4px 10px;font-size:12px;line-height:1.4}.lp-section{padding:58px 0}.lp-section-head{margin-bottom:28px}.lp-section-head h2{font-size:30px}.lp-features-grid,.lp-use-grid,.lp-steps{grid-template-columns:1fr}.lp-feature-card,.lp-step-card{min-height:auto}.lp-use-image{height:230px}.lp-use-badge{min-height:44px;padding:7px 15px 7px 8px;font-size:15px;top:14px;left:14px}.lp-use-badge span{width:30px;height:30px}.lp-step-card p{min-height:auto}.lp-notice{padding:22px}.lp-notice h2{font-size:21px}.lp-lan-map{grid-template-columns:48px 1fr 60px 1fr 58px;gap:6px}.lp-lan-map span{height:48px}.lp-final-cta{padding:52px 0}.lp-final-cta h2{font-size:30px}.lp-footer-row{flex-direction:column;align-items:flex-start}}@media (width<=380px){.lp-brand{font-size:22px}.lp-nav-cta{padding:0 12px}.lp-nav-cta span{text-overflow:ellipsis;max-width:6.5em;overflow:hidden}.lp-hero h1{margin-top:44px;font-size:40px}.lp-hero-inner{padding-bottom:26px}}.grid{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.actions,.controls{flex-wrap:wrap}.camera-controls{grid-template-columns:minmax(0,3fr) minmax(0,1fr);gap:8px;display:grid}.camera-controls .button{white-space:nowrap;min-width:0;padding-inline:6px}.viewer-controls{grid-template-columns:1fr;display:grid}.viewer-controls>#connect-viewer{justify-self:center;width:min(100%,520px)}.viewer-control-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%;display:grid}.viewer-control-row .button{min-width:0}.button{color:#1c2430;cursor:pointer;background:#fff;border:1px solid #bec8d2;border-radius:8px;justify-content:center;align-items:center;min-height:44px;padding:10px 16px;font-weight:700;text-decoration:none;display:inline-flex}.button:disabled{cursor:not-allowed;opacity:.55}.button.primary{color:#fff;background:#13795b;border-color:#13795b}.button.active{color:#7a4d00;background:#fff1cf;border-color:#7a4d00}.muted{color:#5f6d7a}.badge{color:#30404f;text-align:center;background:#dfe8ef;border-radius:999px;min-width:108px;padding:6px 10px;font-size:.85rem;font-weight:700}.badge.good{color:#0f6248;background:#d9f2e8}.badge.warn{color:#805400;background:#fff1cf}.badge.bad{color:#9c241b;background:#fce1df}.video-frame{aspect-ratio:16/9;color:#d8e3ea;object-fit:contain;background:#111922;border-radius:8px;width:100%}.camera-video-shell{position:relative}.camera-video-shell .video-frame,.viewer-video-shell .video-frame{display:block}.viewer-video-shell{aspect-ratio:16/9;background:#111922;border-radius:8px;width:100%;position:relative;overflow:hidden}.viewer-video-shell.pseudo-fullscreen{z-index:2000;aspect-ratio:auto;background:#000;border-radius:0;width:100vw;height:100dvh;position:fixed;inset:0}.viewer-video-shell .video-frame{aspect-ratio:auto;transform-origin:50%;width:100%;height:100%;transition:transform .12s,opacity .12s;position:absolute;inset:0}.viewer-video-shell.pseudo-fullscreen .video-frame{border-radius:0}.viewer-video-shell .filter-canvas{pointer-events:none;height:100%;display:none;position:absolute;inset:0}.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{left:10px;right:10px;bottom:max(10px, env(safe-area-inset-bottom));z-index:2001;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f4f7f99e;border-radius:8px;justify-content:center;padding:8px;transition:opacity .16s,transform .16s;position:fixed}.viewer-controls.pseudo-fullscreen.controls-hidden{opacity:0;pointer-events:none;transform:translateY(calc(100% + 16px))}.viewer-controls.pseudo-fullscreen .button{min-height:40px;padding:8px 12px}.viewer-controls.pseudo-fullscreen .saved-camera-control-row{display:none}.dim-overlay{z-index:1000;pointer-events:none;opacity:0;background:#000000e6;transition:opacity .16s;position:fixed;inset:0}.dim-overlay.active{opacity:1}.placeholder{text-align:center;place-items:center;display:grid}.status-panel{background:#fff;border:1px solid #d7e0e7;border-radius:8px;padding:14px}.link{overflow-wrap:anywhere;color:#0f6fbd;margin-top:8px;display:block}.watch-link-panel{text-align:center;justify-items:center;gap:14px;display:grid}.watch-link-panel>div{width:min(100%,620px)}.view-empty-panel{text-align:center;gap:12px;display:grid}.view-empty-panel p{color:#4c5f6f;line-height:1.7}.qr-code{background:#fff;border:1px solid #d7e0e7;border-radius:8px;width:144px;height:144px}.panel-actions{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:12px;display:flex}.metrics{gap:8px;margin:10px 0 0;display:grid}.metrics div{justify-content:space-between}.metrics dt{color:#5f6d7a}.metrics dd{margin:0;font-weight:700}.session-list{color:#5f6d7a;gap:8px;margin-top:10px;display:grid}.session-row{color:#1c2430;background:#f4f7f9;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;min-height:34px;padding:8px 10px;display:flex}.modal-backdrop{z-index:3000;background:#1119228f;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal{background:#fff;border:1px solid #d7e0e7;border-radius:8px;width:min(100%,560px);max-height:min(82dvh,640px);overflow:auto;box-shadow:0 18px 48px #1119223d}.modal-header{border-bottom:1px solid #d7e0e7;justify-content:space-between;align-items:center;gap:12px;padding:14px;display:flex}.modal-close{min-height:36px;padding:6px 12px}.modal-content{padding:14px}.saved-camera-form{gap:10px;display:grid}.field-label{color:#30404f;font-weight:700}.text-input{color:#1c2430;width:100%;min-height:44px;font:inherit;background:#fff;border:1px solid #bec8d2;border-radius:8px;padding:10px 12px}.modal-actions{flex-wrap:wrap;gap:8px;display:flex}.modal-empty{color:#5f6d7a;line-height:1.65}.saved-camera-list{gap:8px;list-style:none;display:grid}.saved-camera-row{background:#f4f7f9;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;min-height:44px;padding:8px;display:grid}.saved-camera-details{gap:4px;min-width:0;display:grid}.saved-camera-actions{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.saved-camera-row .button,.modal-actions .button{min-height:36px;padding:6px 10px}.saved-camera-link{overflow-wrap:anywhere;color:#0f6fbd;font-weight:700}.saved-camera-id{overflow-wrap:anywhere;color:#5f6d7a;font-size:.82rem}@media (width<=700px){.surface{padding:14px}.grid,.topbar,.watch-link-panel{grid-template-columns:1fr}.topbar{align-items:flex-start}.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}.saved-camera-row{grid-template-columns:1fr}.saved-camera-actions{justify-content:stretch}.saved-camera-actions .button{flex:120px}}@media (width>=900px){.viewer-controls{grid-template-columns:repeat(7,minmax(0,1fr));align-items:stretch}.viewer-controls>#connect-viewer{justify-self:stretch;width:auto}.viewer-control-row{display:contents}.viewer-controls.pseudo-fullscreen{grid-template-columns:repeat(5,minmax(0,1fr))}}:root{--rp-bg:oklch(98.5% .004 240);--rp-surface:oklch(100% 0 0);--rp-surface-soft:oklch(96.5% .006 250);--rp-fg:oklch(18% .012 250);--rp-muted:oklch(48% .014 250);--rp-border:oklch(90% .006 250);--rp-accent:oklch(62% .18 255);--rp-accent-soft:oklch(94% .035 255);--rp-success:oklch(61% .16 151);--rp-success-soft:oklch(95% .04 151);--rp-warning:oklch(72% .15 75);--rp-danger:oklch(58% .18 28);--rp-shadow:0 24px 70px oklch(18% .012 250/.08);--rp-radius:12px;--rp-radius-sm:8px;font-family:Noto Sans JP Local,Noto Sans JP,Hiragino Sans,Yu Gothic,Meiryo,-apple-system,BlinkMacSystemFont,system-ui,sans-serif}body.is-camera-drawer-open{overflow:hidden}.viewer-app{background:radial-gradient(circle at 74% 14%, oklch(88% .06 255/.24), transparent 28rem), linear-gradient(180deg, var(--rp-surface) 0%, var(--rp-bg) 46%, oklch(96.8% .008 240) 100%);width:100%;min-width:0;max-width:100%;min-height:100vh;color:var(--rp-fg);grid-template-rows:auto minmax(0,1fr) auto;font-family:Noto Sans JP Local,Noto Sans JP,Hiragino Sans,Yu Gothic,Meiryo,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;display:grid}.viewer-topbar{z-index:20;border-bottom:1px solid var(--rp-border);background:color-mix(in oklch, var(--rp-surface) 88%, transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);justify-content:space-between;align-items:center;gap:18px;width:100%;min-width:0;max-width:100%;height:72px;padding:0 clamp(18px,3vw,48px);display:flex;position:sticky;top:0}.viewer-brand{min-width:0;color:var(--rp-fg);align-items:center;gap:12px;text-decoration:none;display:inline-flex}.viewer-brand img{border-radius:10px;flex:none;width:36px;height:36px}.viewer-brand span{text-overflow:ellipsis;white-space:nowrap;letter-spacing:0;font-size:clamp(22px,2vw,28px);font-weight:700;overflow:hidden}.viewer-app.view-index-app{height:auto;min-height:100vh;overflow:hidden auto}.viewer-app.view-index-app .app-footer{width:min(860px,100%);color:var(--rp-muted);margin:0 auto;padding:0 clamp(18px,3vw,48px) 24px}.view-index-content{align-items:start;width:100%;min-width:0;max-width:960px;margin:0 auto;padding:clamp(22px,4vw,44px) clamp(18px,3vw,48px) 34px;display:grid}.view-index-content-narrow{align-items:center;max-width:620px;min-height:calc(100svh - 120px)}.view-index-panel{min-width:0;box-shadow:var(--rp-shadow);gap:18px;padding:clamp(18px,3vw,24px);display:grid}.view-index-header{justify-content:space-between;align-items:center;gap:16px;min-width:0;display:flex}.view-index-header>div{gap:6px;min-width:0;display:grid}.view-index-header h1{min-width:0;color:var(--rp-fg);letter-spacing:0;font-size:clamp(26px,3vw,34px);line-height:1.12}.view-index-header p{color:var(--rp-muted);font-weight:700}.view-index-camera-list{gap:12px}.view-index-camera-list .viewer-camera-card{min-height:64px}.view-index-feedback-link{border-top:1px solid var(--rp-border);border-radius:0;justify-content:center;width:100%;margin-top:4px;padding-top:14px}.view-empty-card{text-align:center;width:100%;min-width:0;box-shadow:var(--rp-shadow);justify-items:center;gap:18px;padding:clamp(22px,4vw,34px);display:grid}.view-empty-icon{border:1px solid color-mix(in oklch, var(--rp-accent) 22%, var(--rp-border));background:var(--rp-accent-soft);width:72px;height:72px;color:var(--rp-accent);border-radius:50%;place-items:center;display:grid}.view-empty-icon svg{width:34px;height:34px;display:block}.view-empty-copy{gap:8px;max-width:460px;display:grid}.view-empty-copy h1{color:var(--rp-fg);letter-spacing:0;font-size:clamp(26px,4vw,34px);line-height:1.16}.view-empty-copy p{color:var(--rp-muted);font-weight:700;line-height:1.7}.view-index-primary{min-width:min(100%,180px)}.app-home-content{max-width:860px}.app-home-panel{gap:26px;width:100%;min-width:0;max-width:100%}.app-home-section{border:1px solid var(--rp-border);background:color-mix(in oklch, var(--rp-surface) 92%, #fff);border-radius:16px;gap:16px;width:100%;min-width:0;max-width:100%;padding:24px;display:grid}.app-home-section-heading{justify-content:space-between;align-items:baseline;gap:12px;min-width:0;display:flex}.app-home-section-heading h1,.app-home-section-heading h2{color:var(--rp-fg);letter-spacing:0;font-size:21px;line-height:1.25}.app-home-section-heading p{color:var(--rp-muted);font-size:13px;font-weight:700}.app-home-section-copy{color:var(--rp-muted);overflow-wrap:anywhere;font-size:14px;font-weight:700;line-height:1.7}.app-home-section .button{justify-content:center;width:100%;min-width:0}.app-home-section .button span{white-space:normal;text-align:center;overflow-wrap:anywhere;min-width:0;line-height:1.35}.app-home-primary.button.primary{color:#fff;background:linear-gradient(oklch(69.6% .187 48),oklch(64% .205 45));border-color:#0000;border-radius:999px;gap:12px;max-width:100%;min-height:68px;font-size:18px;transition:transform .18s,box-shadow .18s;box-shadow:0 12px 28px oklch(69.6% .187 48/.28)}.app-home-primary.button.primary:hover{transform:translateY(-1px);box-shadow:0 16px 34px oklch(69.6% .187 48/.34)}.app-home-primary.button.primary:active{transform:translateY(0)}.app-home-section svg{flex:none;width:20px;height:20px}.app-home-primary svg{width:24px;height:24px}.viewer-entry-tools{gap:10px;min-width:0;max-width:100%;display:grid}.viewer-entry-scan-button{background:var(--rp-accent);color:#fff;border-color:#0000;justify-content:center;gap:10px;width:100%;min-height:58px;box-shadow:0 10px 24px oklch(62% .18 255/.2)}.viewer-entry-scan-button:hover:not(:disabled){background:color-mix(in oklch, var(--rp-accent) 92%, #fff);border-color:#0000}.viewer-entry-url-toggle{min-height:38px;color:var(--rp-muted);font:inherit;cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;gap:8px;padding:0;font-size:13px;font-weight:800;display:inline-flex}.viewer-entry-url-toggle:hover,.viewer-entry-url-toggle.is-open{color:var(--rp-accent)}.viewer-entry-url-toggle svg{width:18px;height:18px;transition:transform .18s}.viewer-entry-url-toggle.is-open svg{transform:rotate(180deg)}.viewer-entry-form{gap:8px;min-width:0;display:grid}.viewer-entry-form[hidden]{display:none}.viewer-entry-label{color:var(--rp-fg);font-size:13px}.viewer-entry-input-row{grid-template-columns:minmax(0,1fr) auto;gap:8px;min-width:0;display:grid}.viewer-entry-input{border-color:var(--rp-border);color:var(--rp-fg)}.viewer-entry-input[aria-invalid=true]{border-color:color-mix(in oklch, var(--rp-danger) 72%, var(--rp-border));box-shadow:0 0 0 3px oklch(58% .18 28/.12)}.viewer-entry-submit{justify-content:center;min-width:72px}.viewer-entry-status{min-height:18px;color:var(--rp-danger);font-size:13px;font-weight:700;line-height:1.4}.viewer-qr-scanner{gap:12px;display:grid}.viewer-qr-video{aspect-ratio:3/4;object-fit:cover;border:1px solid var(--rp-border);background:#05070a;border-radius:8px;width:100%;max-height:min(58dvh,480px);overflow:hidden}.viewer-qr-status{min-height:24px}.app-home-camera-list-heading{border-top:1px solid var(--rp-border);gap:5px;min-width:0;margin-top:10px;padding-top:18px;display:grid}.app-home-camera-list-title{justify-content:space-between;align-items:baseline;gap:10px;min-width:0;display:flex}.app-home-camera-list-heading h2,.app-home-camera-list-heading h3{color:var(--rp-fg);letter-spacing:0;font-size:16px;line-height:1.3}.app-home-saved-count{color:var(--rp-muted);flex:none;font-size:12px;font-weight:800}.app-home-camera-list-heading p{color:var(--rp-muted);overflow-wrap:anywhere;font-size:13px;font-weight:700;line-height:1.55}.app-home-saved{gap:16px;min-width:0;display:grid}.app-home-empty{max-width:100%;color:var(--rp-muted);overflow-wrap:anywhere;padding:2px 0;font-size:14px;font-weight:700;line-height:1.55}.camera-app{background:radial-gradient(circle at 74% 14%, oklch(88% .06 255/.24), transparent 28rem), linear-gradient(180deg, var(--rp-surface) 0%, var(--rp-bg) 46%, oklch(96.8% .008 240) 100%);width:100%;min-width:0;max-width:100%;min-height:100vh;color:var(--rp-fg);grid-template-rows:auto minmax(0,1fr);font-family:Noto Sans JP Local,Noto Sans JP,Hiragino Sans,Yu Gothic,Meiryo,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;display:grid}.camera-topbar{z-index:20;border-bottom:1px solid var(--rp-border);background:color-mix(in oklch, var(--rp-surface) 88%, transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);justify-content:space-between;align-items:center;gap:18px;width:100%;min-width:0;max-width:100%;height:72px;padding:0 clamp(18px,3vw,48px);display:flex;position:sticky;top:0}.camera-content{grid-template-columns:minmax(260px,340px) minmax(0,1fr);align-items:start;gap:26px;width:100%;min-width:0;max-width:100%;padding:28px clamp(18px,3vw,48px) 34px;display:grid}.camera-panel{border:1px solid var(--rp-border);border-radius:var(--rp-radius);background:color-mix(in oklch, var(--rp-surface) 94%, transparent);min-width:0;box-shadow:0 1px oklch(100% 0 0/.8)}.camera-main{grid-area:1/2;gap:18px;min-width:0;display:grid}.camera-live-card{min-width:0;box-shadow:var(--rp-shadow);gap:16px;padding:clamp(14px,2vw,20px);display:grid}.camera-feed{aspect-ratio:16/9;border:1px solid color-mix(in oklch, var(--rp-border) 75%, transparent);border-radius:var(--rp-radius-sm);background:#05070a;min-height:380px;position:relative;overflow:hidden}.camera-feed:after{content:"";pointer-events:none;background:linear-gradient(oklch(0% 0 0/.04),#0000 35%,oklch(0% 0 0/.12));position:absolute;inset:0}.camera-feed .video-frame{aspect-ratio:auto;object-fit:contain;border-radius:0;width:100%;height:100%;position:absolute;inset:0}.camera-action-row{grid-template-columns:repeat(2,minmax(120px,1fr));gap:clamp(10px,2vw,18px);width:100%;display:grid}.camera-action{border-radius:var(--rp-radius-sm);min-width:0;min-height:86px;color:var(--rp-fg);text-align:center;background:0 0;border:0;justify-items:center;gap:8px;padding:0;display:grid}.camera-action.button.primary,.camera-action.button.active{color:var(--rp-fg);background:0 0;border:0}.camera-action:hover:not(:disabled) .viewer-control-icon{border-color:color-mix(in oklch, var(--rp-accent) 25%, transparent);background:var(--rp-accent-soft);transform:translateY(-1px)}.camera-action:disabled{opacity:.42}.camera-action.is-primary .viewer-control-icon,.camera-action.is-active .viewer-control-icon,.camera-action.active .viewer-control-icon{background:var(--rp-accent);color:#fff;box-shadow:0 10px 24px oklch(62% .18 255/.24)}.camera-action.is-danger .viewer-control-icon{background:var(--rp-danger);color:#fff;box-shadow:0 10px 24px oklch(58% .18 28/.24)}.camera-action.is-danger:hover:not(:disabled) .viewer-control-icon{border-color:color-mix(in oklch, var(--rp-danger) 38%, transparent);background:color-mix(in oklch, var(--rp-danger) 92%, #fff)}.camera-side-panel{flex-direction:column;grid-area:1/1;gap:16px;min-width:0;padding:18px;display:flex}.camera-side-heading{justify-content:space-between;align-items:center;gap:12px;display:flex}.camera-side-heading h2{color:var(--rp-fg);letter-spacing:0;font-size:20px;line-height:1.2}.camera-qr-link-wrap{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:end;column-gap:8px;width:100%;display:grid}.camera-qr-code{border-color:var(--rp-border);border-radius:var(--rp-radius-sm);grid-column:2;justify-self:center;width:192px;max-width:100%;height:auto}.camera-watch-url{border:1px solid var(--rp-border);background:var(--rp-surface);min-height:28px;color:var(--rp-accent);white-space:nowrap;border-radius:999px;grid-column:3;justify-content:center;justify-self:start;align-items:center;margin-bottom:4px;padding:4px 8px;font-size:12px;font-weight:700;line-height:1;text-decoration:none;display:inline-flex}.camera-watch-url:hover{border-color:color-mix(in oklch, var(--rp-accent) 35%, var(--rp-border));background:var(--rp-accent-soft)}.camera-link-button{border-color:color-mix(in oklch, var(--rp-accent) 22%, var(--rp-border));width:100%;min-width:0;color:var(--rp-fg);justify-content:center;gap:10px}.camera-link-button:hover:not(:disabled){border-color:color-mix(in oklch, var(--rp-accent) 45%, var(--rp-border));background:var(--rp-accent-soft)}.camera-link-button-icon{flex:none;place-items:center;width:22px;height:22px;display:grid}.camera-link-button-icon svg{width:22px;height:22px;display:block}.camera-side-footer{border-top:1px solid var(--rp-border);margin-top:auto;padding-top:18px;display:grid}.camera-loading-app{grid-template-rows:auto 1fr}.camera-loading-card{gap:10px;width:min(100% - 32px,520px);margin:auto;padding:22px;display:grid}.camera-loading-card h1{color:var(--rp-fg);letter-spacing:0;font-size:28px}.camera-loading-card p{color:var(--rp-muted);font-weight:700}.viewer-top-actions{justify-content:flex-end;align-items:center;gap:12px;min-width:0;display:flex}.viewer-app .badge{white-space:nowrap;border-radius:999px;min-width:0;padding:6px 10px;font-size:.8rem;font-weight:700}.viewer-app .badge.good{background:var(--rp-success-soft);color:oklch(39% .13 151)}.viewer-app .badge.warn{color:oklch(42% .11 75);background:oklch(96.5% .045 75)}.viewer-app .badge.bad{color:var(--rp-danger);background:oklch(95% .04 28)}.viewer-icon-button{border:1px solid var(--rp-border);background:color-mix(in oklch, var(--rp-surface) 90%, transparent);width:44px;height:44px;min-height:44px;color:var(--rp-fg);border-radius:50%;place-items:center;padding:0;transition:background .18s,border-color .18s,transform .18s;display:grid}.viewer-icon-button:hover{border-color:color-mix(in oklch, var(--rp-accent) 45%, var(--rp-border));background:var(--rp-surface);transform:translateY(-1px)}.viewer-icon-button:focus-visible,.viewer-camera-name-link:focus-visible,.viewer-camera-action:focus-visible,.viewer-side-link:focus-visible,.viewer-control:focus-visible{outline:3px solid color-mix(in oklch, var(--rp-accent) 32%, transparent);outline-offset:2px}.viewer-icon-button svg{width:22px;height:22px;display:block}.camera-drawer-trigger,.camera-drawer-close{display:none}.viewer-content{grid-template-columns:minmax(230px,280px) minmax(0,1fr);align-items:start;gap:26px;width:100%;min-width:0;max-width:100%;padding:28px clamp(18px,3vw,48px) 34px;display:grid}.viewer-panel{border:1px solid var(--rp-border);border-radius:var(--rp-radius);background:color-mix(in oklch, var(--rp-surface) 94%, transparent);min-width:0;box-shadow:0 1px oklch(100% 0 0/.8)}.viewer-sidebar{flex-direction:column;gap:18px;min-width:0;min-height:calc(100vh - 142px);padding:18px;display:flex}.viewer-section-heading{justify-content:space-between;align-items:center;gap:12px;display:flex}.viewer-section-actions{justify-content:flex-end;align-items:center;gap:8px;display:inline-flex}.viewer-section-heading h2{color:var(--rp-fg);letter-spacing:0;font-size:20px;line-height:1.2}.add-camera-button{display:grid}.viewer-icon-button.is-active{border-color:color-mix(in oklch, var(--rp-accent) 36%, var(--rp-border));background:var(--rp-accent-soft);color:var(--rp-accent)}.viewer-camera-list{gap:10px;min-width:0;display:grid}.viewer-camera-card{border:1px solid var(--rp-border);border-radius:var(--rp-radius-sm);background:var(--rp-surface);min-width:0;min-height:58px;color:var(--rp-fg);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:6px;padding:6px;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;display:grid;position:relative;overflow:hidden}.viewer-camera-card:hover{border-color:color-mix(in oklch, var(--rp-accent) 35%, var(--rp-border));transform:translateY(-1px);box-shadow:0 14px 26px oklch(18% .012 250/.06)}.viewer-camera-card.is-active{border-color:color-mix(in oklch, var(--rp-accent) 58%, var(--rp-border));background:linear-gradient(180deg, var(--rp-surface), var(--rp-accent-soft))}.viewer-camera-card.is-active:before{content:"";background:var(--rp-accent);border-radius:999px;width:3px;position:absolute;top:12px;bottom:12px;left:0}.viewer-camera-name-link{border-radius:var(--rp-radius-sm);min-width:0;min-height:46px;color:var(--rp-fg);align-items:center;gap:9px;padding:0 10px;text-decoration:none;display:flex}.viewer-camera-name-link:hover{background:color-mix(in oklch, var(--rp-accent) 8%, transparent)}.viewer-camera-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:15px;font-weight:700;line-height:1.2;overflow:hidden}.viewer-camera-status-dot{background:oklch(64% .01 245);border-radius:50%;flex:none;width:9px;height:9px;box-shadow:0 0 0 4px oklch(64% .01 245/.14)}.viewer-camera-status-dot.is-online{background:var(--rp-success);box-shadow:0 0 0 4px oklch(61% .16 151/.12)}.viewer-camera-status-dot.is-offline{background:oklch(64% .01 245);box-shadow:0 0 0 4px oklch(64% .01 245/.14)}.viewer-camera-actions{justify-self:end;align-items:center;gap:2px;display:inline-flex}.viewer-camera-action{width:40px;height:40px;color:var(--rp-muted);background:0 0;border:0;border-radius:50%;place-items:center;padding:0;transition:background .18s,color .18s,transform .18s;display:grid}.viewer-camera-action:hover:not(:disabled){background:color-mix(in oklch, var(--rp-accent) 10%, var(--rp-surface));color:var(--rp-accent);transform:translateY(-1px)}.viewer-camera-action[data-camera-action=remove]:hover:not(:disabled){background:color-mix(in oklch, var(--rp-danger) 10%, var(--rp-surface));color:var(--rp-danger)}.viewer-camera-action:disabled{cursor:not-allowed;opacity:.34}.viewer-camera-action svg{width:20px;height:20px;display:block}.viewer-dot{background:var(--rp-success);border-radius:50%;flex:none;width:8px;height:8px;box-shadow:0 0 0 4px oklch(61% .16 151/.1)}.viewer-sidebar-footer{border-top:1px solid var(--rp-border);margin-top:auto;padding-top:18px;display:grid}.viewer-side-link{border-radius:var(--rp-radius-sm);min-height:44px;color:var(--rp-fg);text-align:left;font:inherit;background:0 0;border:0;align-items:center;gap:10px;padding:8px 4px;font-weight:700;display:flex}.viewer-side-link:hover,.viewer-side-link.is-active{background:var(--rp-surface-soft)}.viewer-side-link svg{flex:none;width:22px;height:22px}.viewer-side-link span{text-overflow:ellipsis;white-space:normal;min-width:0;line-height:1.35;overflow:hidden}.viewer-main{gap:18px;min-width:0;display:grid}.viewer-live-card{min-width:0;box-shadow:var(--rp-shadow);gap:16px;padding:clamp(14px,2vw,20px);display:grid}.viewer-live-header{justify-content:space-between;align-items:flex-start;gap:16px;min-width:0;display:flex}.viewer-live-title{flex-wrap:wrap;align-items:center;gap:11px;min-width:0;display:flex}.viewer-live-title h1{text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:min(100%,12em);color:var(--rp-fg);letter-spacing:0;font-size:clamp(24px,3vw,34px);line-height:1.12;overflow:hidden}.viewer-camera-status{border:1px solid var(--rp-border);background:var(--rp-surface);min-height:32px;color:var(--rp-fg);white-space:nowrap;border-radius:999px;align-items:center;gap:8px;padding:6px 10px;font-size:13px;font-weight:700;display:inline-flex}.viewer-camera-status.is-offline{color:var(--rp-muted)}.viewer-camera-status.is-offline .viewer-dot{background:oklch(64% .01 245);box-shadow:0 0 0 4px oklch(64% .01 245/.14)}.viewer-feed{aspect-ratio:16/9;border:1px solid color-mix(in oklch, var(--rp-border) 75%, transparent);border-radius:var(--rp-radius-sm);background:#05070a;min-height:380px;position:relative;overflow:hidden}.viewer-feed:after{content:"";pointer-events:none;background:linear-gradient(oklch(0% 0 0/.04),#0000 35%,oklch(0% 0 0/.12));position:absolute;inset:0}.viewer-feed .video-frame{object-fit:contain;border-radius:0}.viewer-feed .filter-canvas{z-index:1}.viewer-video-actions{z-index:3;color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:oklch(0% 0 0/.46);border:1px solid oklch(100% 0 0/.16);border-radius:999px;align-items:center;gap:8px;padding:6px;display:inline-flex;position:absolute;bottom:14px;right:14px}.viewer-video-action{width:38px;height:38px;color:inherit;cursor:pointer;background:0 0;border:0;border-radius:999px;place-items:center;transition:background .14s,color .14s,opacity .14s,transform .14s;display:grid}.viewer-video-action:hover:not(:disabled),.viewer-video-action:focus-visible{background:oklch(100% 0 0/.16)}.viewer-video-action:focus-visible{outline-offset:2px;outline:2px solid oklch(100% 0 0/.7)}.viewer-video-action:active:not(:disabled){transform:translateY(1px)}.viewer-video-action.is-active{background:oklch(100% 0 0/.22)}.viewer-video-action.is-danger{background:var(--rp-danger);color:#fff}.viewer-video-action.is-danger:hover:not(:disabled),.viewer-video-action.is-danger:focus-visible{background:color-mix(in oklch, var(--rp-danger) 88%, #fff)}.viewer-video-action:disabled{cursor:not-allowed;opacity:.42}.viewer-video-action svg,.viewer-video-action-icon{width:20px;height:20px;display:block}.viewer-video-action-icon svg{width:100%;height:100%;display:block}.viewer-video-shell.pseudo-fullscreen .viewer-video-actions{display:none}.viewer-app .viewer-control-row{grid-template-columns:repeat(5,minmax(78px,1fr));gap:clamp(10px,2vw,18px);width:100%;display:grid}.viewer-app .viewer-control{border-radius:var(--rp-radius-sm);min-width:0;min-height:86px;color:var(--rp-fg);text-align:center;background:0 0;border:0;justify-items:center;gap:8px;padding:0;display:grid}.viewer-app .viewer-control:hover:not(:disabled) .viewer-control-icon{border-color:color-mix(in oklch, var(--rp-accent) 25%, transparent);background:var(--rp-accent-soft);transform:translateY(-1px)}.viewer-app .viewer-control:disabled{opacity:.42}.viewer-app .viewer-control.button.primary,.viewer-app .viewer-control.button.active{color:var(--rp-fg);background:0 0;border:0}.viewer-control-icon{background:var(--rp-surface-soft);width:58px;height:58px;color:var(--rp-fg);border:1px solid #0000;border-radius:50%;place-items:center;transition:background .18s,color .18s,transform .18s,border-color .18s,box-shadow .18s;display:grid}.viewer-control-icon svg{width:24px;height:24px;display:block}.viewer-control-label{max-width:100%;color:var(--rp-fg);overflow-wrap:anywhere;font-size:13px;font-weight:700;line-height:1.25}.viewer-control.is-primary .viewer-control-icon,.viewer-control.is-active .viewer-control-icon,.viewer-control.active .viewer-control-icon{background:var(--rp-accent);color:#fff;box-shadow:0 10px 24px oklch(62% .18 255/.24)}.viewer-control.is-danger .viewer-control-icon{background:var(--rp-danger);color:#fff;box-shadow:0 10px 24px oklch(58% .18 28/.24)}.viewer-control.is-danger:hover:not(:disabled) .viewer-control-icon{border-color:color-mix(in oklch, var(--rp-danger) 38%, transparent);background:color-mix(in oklch, var(--rp-danger) 92%, #fff)}.drawer-backdrop{display:none}.viewer-controls.pseudo-fullscreen{-webkit-backdrop-filter:blur(14px)saturate(118%);backdrop-filter:blur(14px)saturate(118%);background:oklch(100% 0 0/.62);border:1px solid oklch(100% 0 0/.18);border-radius:14px;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;width:auto;box-shadow:0 18px 42px oklch(0% 0 0/.18)}.viewer-controls.pseudo-fullscreen .viewer-control{min-height:66px}.viewer-controls.pseudo-fullscreen .viewer-control-icon{background:oklch(100% 0 0/.56);border-color:oklch(100% 0 0/.18);width:46px;height:46px}.viewer-controls.pseudo-fullscreen .viewer-control:hover:not(:disabled) .viewer-control-icon{background:oklch(100% 0 0/.72)}.viewer-controls.pseudo-fullscreen .viewer-control.is-primary .viewer-control-icon,.viewer-controls.pseudo-fullscreen .viewer-control.is-active .viewer-control-icon,.viewer-controls.pseudo-fullscreen .viewer-control.active .viewer-control-icon{background:color-mix(in oklch, var(--rp-accent) 82%, transparent)}.viewer-controls.pseudo-fullscreen .viewer-control.is-danger .viewer-control-icon{background:color-mix(in oklch, var(--rp-danger) 82%, transparent)}.viewer-controls.pseudo-fullscreen .viewer-control-label{font-size:11px}.viewer-video-shell.pseudo-fullscreen{border:0;border-radius:0}@media (width>=1025px){.camera-app{height:100vh;min-height:0;overflow:hidden}.camera-topbar{height:64px}.camera-content{height:calc(100vh - 64px);padding-top:16px;padding-bottom:18px}.camera-main{height:100%;min-height:0}.camera-live-card{grid-template-rows:minmax(0,1fr) auto;gap:12px;height:100%;min-height:0;padding:16px}.camera-feed{aspect-ratio:auto;height:100%;min-height:0}.camera-action{min-height:72px}.camera-action .viewer-control-icon{width:50px;height:50px}.camera-side-panel{height:100%;min-height:0;padding:16px}.viewer-app{height:100vh;min-height:0;overflow:hidden}.viewer-app .app-footer{display:none}.viewer-app.view-index-app .app-footer{display:flex}.viewer-topbar{height:64px}.viewer-brand img{border-radius:9px;width:32px;height:32px}.viewer-brand span{font-size:24px}.viewer-content{height:calc(100vh - 64px);padding-top:16px;padding-bottom:18px}.viewer-sidebar{gap:14px;height:100%;min-height:0;padding:14px;overflow:hidden}.viewer-camera-list{gap:8px}.viewer-camera-card{min-height:54px}.viewer-sidebar-footer{padding-top:12px}.viewer-main{height:100%;min-height:0}.viewer-live-card{grid-template-rows:auto minmax(0,1fr) auto auto;gap:12px;height:100%;min-height:0;padding:16px}.viewer-live-header{align-items:center}.viewer-feed{aspect-ratio:auto;height:100%;min-height:0}.viewer-app .viewer-control-row{grid-template-columns:repeat(5,minmax(78px,1fr));gap:10px;display:grid}.viewer-app .viewer-control{min-height:72px}.viewer-control-icon{width:50px;height:50px}}@media (width>=1025px) and (height<=720px){.viewer-sidebar-footer{display:none}}@media (width<=1180px){.viewer-content{grid-template-columns:minmax(220px,260px) minmax(0,1fr)}}@media (width<=1024px){.camera-topbar{height:auto;min-height:72px;padding-top:14px;padding-bottom:14px}.camera-content{grid-template-columns:1fr;padding-top:18px}.camera-main,.camera-side-panel{grid-area:auto}.camera-feed{aspect-ratio:auto;height:clamp(300px,46svh,520px);min-height:0}.viewer-topbar{height:auto;min-height:72px;padding-top:14px;padding-bottom:14px}.viewer-content{grid-template-columns:1fr;padding-top:18px}.viewer-sidebar{z-index:45;overscroll-behavior:contain;background:var(--rp-surface);border-radius:0 18px 18px 0;width:min(86vw,380px);height:100dvh;min-height:0;padding:18px;transition:transform .24s;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(calc(-100% - 28px));box-shadow:24px 0 70px oklch(18% .012 250/.22)}body.is-camera-drawer-open .viewer-sidebar{transform:translate(0)}.camera-drawer-trigger,.camera-drawer-close{display:grid}.drawer-backdrop{z-index:40;opacity:0;pointer-events:none;background:oklch(10% .02 250/.38);transition:opacity .24s;display:block;position:fixed;inset:0}body.is-camera-drawer-open .drawer-backdrop{opacity:1;pointer-events:auto}}@media (width<=620px){.app-home-section-heading h1,.app-home-section-heading h2{font-size:18px}.app-home-section-copy{font-size:clamp(11px,3vw,12px);line-height:1.55}.view-index-content{padding-left:12px;padding-right:12px}.view-index-panel{padding:14px}.app-home-section{padding:18px}.app-home-primary.button.primary{min-height:58px;font-size:16px}.app-home-primary svg{width:22px;height:22px}.viewer-entry-input-row{grid-template-columns:1fr}.viewer-entry-submit{width:100%;min-height:44px}.camera-topbar{gap:10px;padding-left:14px;padding-right:14px}.camera-content{padding:12px 12px max(18px, env(safe-area-inset-bottom));gap:14px}.camera-main,.camera-side-panel{grid-area:auto}.camera-panel,.camera-live-card{border-radius:10px}.camera-live-card,.camera-side-panel{gap:13px;padding:14px}.camera-feed{height:clamp(250px,38svh,330px)}.camera-action-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.camera-action{gap:6px;min-height:68px}.camera-action .viewer-control-icon{width:clamp(40px,11vw,46px);height:clamp(40px,11vw,46px)}.camera-action .viewer-control-label{font-size:11px}.viewer-topbar{gap:10px;padding-left:14px;padding-right:14px}.viewer-brand span{font-size:22px}.viewer-top-actions{gap:8px}.viewer-content{padding:12px 12px max(18px, env(safe-area-inset-bottom));align-items:start;gap:14px}.viewer-panel,.viewer-live-card{border-radius:10px}.viewer-live-card{align-content:start;gap:13px;padding:14px}.viewer-live-header{grid-template-columns:minmax(0,1fr) auto;align-items:center;display:grid}.viewer-live-title{align-items:center}.viewer-live-title h1{font-size:24px}.viewer-sidebar{padding:14px}.viewer-feed{aspect-ratio:auto;height:clamp(250px,36svh,310px);min-height:0}.viewer-video-actions{gap:4px;padding:4px;bottom:10px;right:10px}.viewer-video-action{width:34px;height:34px}.viewer-video-action svg,.viewer-video-action-icon{width:18px;height:18px}.viewer-app .viewer-control-row{grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.viewer-app .viewer-control{gap:6px;min-height:68px}.viewer-control-icon{width:clamp(40px,11vw,46px);height:clamp(40px,11vw,46px)}.viewer-control-icon svg{width:22px;height:22px}.viewer-control-label{font-size:clamp(10px,2.8vw,11px);line-height:1.15}}
