:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.app{flex-direction:column;gap:1rem;min-height:100%;padding:1.5rem;display:flex}.header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.header h1{margin:0;font-size:clamp(2rem,4vw,2.7rem)}.backend-status{background:#ffffffd9;border:1px solid #d1d5db;border-radius:999px;align-items:center;gap:.45rem;padding:.3rem .75rem;display:inline-flex}.status-indicator{border-radius:999px;width:10px;height:10px}.status-indicator.online{background:#10b981}.status-indicator.offline{background:#ef4444}.status-indicator.checking{background:#f59e0b}.status-text{text-transform:capitalize;color:#374151;font-weight:600}.container{flex-direction:column;gap:1rem;display:flex}.config-section{background:#ffffffe0;border:1px solid #d1d5db;border-radius:10px;flex-wrap:wrap;align-items:center;gap:.75rem;padding:.75rem;display:flex}.config-section label{color:#374151;font-weight:700}.config-section input{border:1px solid #d1d5db;border-radius:8px;flex:1;min-width:260px;padding:.55rem .7rem;font-size:.95rem}.config-section input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1f}.selected-stream-id{color:#374151;align-items:center;gap:.5rem;font-weight:600;display:inline-flex}.selected-stream-id code{color:#4338ca;background:#eef2ff;border-radius:6px;padding:.2rem .5rem}.tabs{flex-wrap:wrap;gap:.6rem;display:flex}.tab{color:#1f2937;cursor:pointer;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;padding:.5rem .9rem;font-weight:600;transition:all .2s}.tab:hover{border-color:#667eea}.tab.active{color:#3730a3;background:#e0e7ff;border-color:#667eea}.content{background:#ffffffe6;border:1px solid #e5e7eb;border-radius:12px;padding:1rem}.footer{color:#4b5563;margin-top:auto;font-size:.9rem}.footer p{margin:.25rem 0}.endpoints code{color:#4338ca;background:#eef2ff;border-radius:4px;padding:.15rem .4rem}@media (width<=768px){.app{padding:.9rem}.config-section{flex-direction:column;align-items:stretch}.config-section input{width:100%;min-width:0}.selected-stream-id{justify-content:space-between}.content{padding:.75rem}}.camera-capture{width:100%}.camera-capture h2{color:#333;margin-top:0;margin-bottom:1.5rem}.camera-manager{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;margin-bottom:1.5rem;padding:1rem}.camera-manager-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem;display:flex}.camera-manager-header h3{color:#1f2937;margin:0}.add-camera-btn{min-width:130px}.camera-profiles-list{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.camera-profile-chip{cursor:pointer;background:#fff;border:2px solid #cbd5e1;border-radius:999px;align-items:center;gap:.6rem;padding:.45rem .85rem;transition:all .2s;display:inline-flex}.camera-profile-chip:hover{border-color:#667eea}.camera-profile-chip.active{background:#eef2ff;border-color:#667eea}.profile-name{color:#1f2937;font-weight:700}.profile-stream-id{color:#667eea;background:#f8fafc;border-radius:999px;padding:.15rem .45rem;font-family:monospace;font-size:.82rem}.camera-profile-editor{grid-template-columns:1fr 1fr auto;align-items:end;gap:.75rem;display:grid}.editor-field{flex-direction:column;gap:.35rem;display:flex}.editor-field label{color:#374151;font-weight:600}.editor-field input{border:2px solid #d1d5db;border-radius:8px;padding:.65rem .75rem;font-size:.95rem}.editor-field input:focus{border-color:#667eea;outline:none}.remove-camera-btn{min-width:145px}.capture-controls{grid-template-columns:1fr 1fr 1fr;gap:1rem;margin-bottom:2rem;display:grid}.camera-select{flex-direction:column;gap:.5rem;display:flex}.camera-select label{color:#333;font-size:.9rem;font-weight:600}.camera-select select{cursor:pointer;background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:.75rem;font-size:1rem;transition:border-color .3s}.camera-select select:hover{border-color:#667eea}.camera-select select:focus{border-color:#667eea;outline:none}.camera-source-hint{color:#6b7280;font-size:.8rem}.button-group{flex-wrap:wrap;align-items:flex-end;gap:.75rem;display:flex}.btn{cursor:pointer;color:#fff;border:none;border-radius:8px;flex:1;min-width:130px;padding:.75rem 1rem;font-size:1rem;font-weight:600;transition:all .3s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#6b7280}.btn-secondary:hover:not(:disabled){background:#4b5563;transform:translateY(-2px)}.btn-success{background:#10b981}.btn-success:hover:not(:disabled){background:#059669;transform:translateY(-2px)}.btn-danger{background:#ef4444}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-2px)}.preview-section{grid-template-columns:2fr 1fr;gap:2rem;margin-bottom:2rem;display:grid}.video-wrapper{aspect-ratio:16/9;background:#000;border-radius:12px;position:relative;overflow:hidden;box-shadow:0 4px 12px #0003}.preview-video{object-fit:contain;width:100%;height:100%}.stats{background:#f3f4f6;border-radius:12px;flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.stat-item{background:#fff;border-left:4px solid #667eea;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem;display:flex}.stat-item .label{color:#666;font-weight:600}.stat-item .value.active{color:#10b981}.stat-item .value.code{color:#4f46e5;background:#eef2ff;border-radius:6px;padding:.2rem .45rem;font-family:monospace;font-size:.9rem}.info-section{background:#f0f4ff;border:2px solid #667eea;border-radius:12px;padding:1.5rem}.info-section h3{color:#667eea;margin-top:0}.info-section ol{margin:0;padding-left:1.5rem}.info-section li{color:#333;margin-bottom:.5rem;line-height:1.6}.info-section code{color:#667eea;background:#fff;border-radius:4px;padding:.25rem .5rem;font-family:monospace}.capture-links{background:#eff6ff;border:2px solid #93c5fd;border-radius:12px;margin-top:1rem;padding:1rem}.capture-links h3{color:#1d4ed8;margin-top:0;margin-bottom:.75rem}.capture-links-list{gap:.65rem;display:grid}.capture-link-item{background:#fff;border:1px solid #bfdbfe;border-radius:10px;padding:.75rem}.capture-link-meta{color:#1f2937;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.55rem;display:flex}.capture-link-meta code{color:#3730a3;background:#e0e7ff;border-radius:4px;padding:.1rem .35rem}.capture-link-actions{flex-wrap:wrap;align-items:center;gap:.55rem;display:flex}.capture-link-actions code{color:#1d4ed8;word-break:break-all;background:#f8fafc;border:1px solid #dbeafe;border-radius:7px;flex:1;min-width:230px;padding:.45rem .55rem;font-size:.82rem}.capture-link-copy{flex:none;min-width:82px}@media (width<=1024px){.camera-profile-editor{grid-template-columns:1fr}.remove-camera-btn,.add-camera-btn{width:100%}.camera-manager-header{flex-direction:column;align-items:stretch}.capture-controls{grid-template-columns:1fr}.button-group{align-items:center}.preview-section{grid-template-columns:1fr}}@media (width<=768px){.capture-controls{grid-template-columns:1fr}.capture-link-actions{flex-direction:column;align-items:stretch}.capture-link-actions code,.capture-link-copy{width:100%;min-width:0}.button-group,.btn{width:100%}.video-wrapper{aspect-ratio:4/3}}.stream-viewer{width:100%}.stream-viewer h2{color:#333;margin-top:0;margin-bottom:1.25rem}.streams-grid{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stream-card{background:#f8fafc;border:2px solid #e5e7eb;border-radius:12px;flex-direction:column;gap:.9rem;padding:1rem;display:flex}.stream-card-header{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.stream-card-header h3{color:#111827;margin:0;font-size:1.05rem}.stream-card-header p{color:#4b5563;margin:.35rem 0 0;font-size:.9rem}.stream-card-header code{color:#4338ca;background:#e5e7eb;border-radius:4px;padding:.1rem .35rem}.status-pill{color:#fff;white-space:nowrap;border-radius:999px;padding:.3rem .75rem;font-size:.8rem;font-weight:700}.status-pill.connected{background:#10b981}.status-pill.waiting{background:#f59e0b}.status-pill.error{background:#ef4444}.stream-wrapper{aspect-ratio:16/9;background:#000;border-radius:10px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.stream-image{object-fit:contain;background:#111827;width:100%;height:100%}.live-badge{color:#fff;background:#ef4444;border-radius:16px;padding:.3rem .65rem;font-size:.8rem;font-weight:600;animation:2s infinite pulse;position:absolute;top:.75rem;right:.75rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.75}}.stream-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem;display:grid}.stat-item{background:#fff;border:1px solid #e5e7eb;border-left:4px solid #667eea;border-radius:8px;padding:.5rem}.stat-item .label{color:#6b7280;margin-bottom:.2rem;font-size:.78rem;font-weight:600;display:block}.stat-item .value{color:#111827;font-size:1rem;font-weight:700}.feed-error{color:#991b1b;background:#fee2e2;border:1px solid #ef4444;border-radius:8px;padding:.55rem;font-size:.85rem}.stream-url-row{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.stream-url-row code{color:#4338ca;word-break:break-all;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex:1;min-width:220px;padding:.5rem .65rem;font-size:.82rem}.copy-btn{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:6px;padding:.45rem .8rem;font-weight:600;transition:transform .2s,background .2s}.copy-btn:hover{background:#4f46e5;transform:translateY(-1px)}.published-links{background:#eff6ff;border:2px solid #93c5fd;border-radius:12px;margin-bottom:1.2rem;padding:1rem}.published-links-header{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.85rem;display:flex}.published-links-header h3{color:#1d4ed8;margin:0}.published-links-list{gap:.65rem;display:grid}.published-link-item{background:#fff;border:1px solid #bfdbfe;border-radius:10px;padding:.75rem}.published-link-meta{color:#1f2937;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.4rem;margin-bottom:.55rem;display:flex}.published-link-meta code{color:#3730a3;background:#e0e7ff;border-radius:4px;padding:.1rem .35rem}.published-link-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.published-link-actions code{color:#1d4ed8;word-break:break-all;background:#f8fafc;border:1px solid #dbeafe;border-radius:7px;flex:1;min-width:230px;padding:.45rem .55rem;font-size:.82rem}.open-link-btn{color:#2563eb;background:#eff6ff;border:1px solid #2563eb;border-radius:6px;justify-content:center;align-items:center;padding:.45rem .8rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-flex}.open-link-btn:hover{background:#dbeafe}.stream-url.usage-section{background:#fef3c7;border:2px solid #f59e0b;border-radius:12px;padding:1.2rem}.stream-url.usage-section h3{color:#92400e;margin-top:0}.usage-example h4{color:#92400e;margin:1rem 0 .4rem}.usage-example pre{color:#1f2937;background:#fff;border:1px solid #fcd34d;border-radius:8px;margin:0;padding:.7rem;font-size:.8rem;overflow-x:auto}@media (width<=900px){.stream-stats{grid-template-columns:1fr}}@media (width<=768px){.streams-grid{grid-template-columns:1fr}.published-links-header,.published-link-actions{flex-direction:column;align-items:stretch}.published-link-actions code{width:100%;min-width:0}.open-link-btn,.published-link-actions .copy-btn,.published-links-header .copy-btn{width:100%}.stream-url-row{flex-direction:column;align-items:stretch}.stream-url-row code,.copy-btn{width:100%}}.stream-info{width:100%}.stream-info h2{color:#333;margin-top:0;margin-bottom:1.5rem}.stream-selector{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.65rem .75rem;display:flex}.stream-selector label{color:#1f2937;font-weight:700}.stream-selector select{background:#fff;border:1px solid #d1d5db;border-radius:6px;min-width:180px;padding:.45rem .6rem}.error-message{color:#991b1b;background:#fee2e2;border:2px solid #ef4444;border-radius:8px;margin-bottom:1rem;padding:1rem}.loading{text-align:center;color:#667eea;padding:2rem;font-weight:600}.info-card{background:#f0f4ff;border:2px solid #667eea;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.card-header{border-bottom:2px solid #667eea;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.card-header h3{color:#667eea;margin:0}.btn-danger{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:6px;padding:.5rem 1rem;font-weight:600;transition:all .3s}.btn-danger:hover{background:#dc2626;transform:translateY(-2px)}.info-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;display:grid}.info-item{background:#fff;border-left:4px solid #667eea;border-radius:8px;padding:1rem}.info-item .label{color:#666;margin-bottom:.5rem;font-size:.9rem;font-weight:600;display:block}.info-item .value{color:#333;word-break:break-word;font-size:1.1rem;display:block}.info-item .value.active{color:#10b981}.info-item .value.inactive{color:#ef4444}.info-item .value.code{color:#667eea;background:#f3f4f6;border-radius:4px;padding:.5rem;font-family:monospace;font-size:.85rem}.streams-list{background:#fff;border:2px solid #e0e0e0;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.streams-list h3{color:#333;margin-top:0}.empty-message{text-align:center;color:#999;padding:2rem;font-style:italic}.table-wrapper{overflow-x:auto}.streams-table{border-collapse:collapse;width:100%}.streams-table thead{background:#f3f4f6;border-bottom:2px solid #e0e0e0}.streams-table th{text-align:left;color:#333;padding:1rem;font-weight:600}.streams-table td{color:#333;border-bottom:1px solid #e0e0e0;padding:1rem}.streams-table tbody tr:hover{background:#f9f9f9}.streams-table code{color:#667eea;background:#f3f4f6;border-radius:4px;padding:.25rem .5rem;font-size:.9rem}.streams-table .url-code{word-break:break-all;max-width:300px;font-size:.8rem;display:inline-block}.badge{color:#fff;border-radius:12px;padding:.25rem .75rem;font-size:.85rem;font-weight:600;display:inline-block}.badge.active{background:#10b981}.badge.inactive{background:#9ca3af}.api-section{background:#fff5e6;border:2px solid #f59e0b;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.api-section h3{color:#b45309;margin-top:0}.endpoint{background:#fff;border-left:4px solid #f59e0b;border-radius:8px;grid-template-columns:60px 1fr 1fr;align-items:center;gap:1rem;margin-bottom:.75rem;padding:1rem;display:grid}.endpoint .method{color:#fff;text-align:center;background:#f59e0b;border-radius:4px;padding:.5rem;font-size:.9rem;font-weight:700}.endpoint .path{color:#667eea;font-family:monospace;font-weight:600}.endpoint .desc{color:#666;font-size:.9rem}.notes-section{background:#e0f2fe;border:2px solid #0284c7;border-radius:12px;padding:1.5rem}.notes-section h3{color:#0284c7;margin-top:0}.notes-section ul{margin:0;padding-left:1.5rem}.notes-section li{color:#0c4a6e;margin-bottom:.5rem;line-height:1.6}.notes-section code{color:#667eea;background:#fff;border-radius:4px;padding:.25rem .5rem;font-weight:600}@media (width<=768px){.stream-selector{flex-direction:column;align-items:stretch}.stream-selector select{width:100%}.card-header{flex-direction:column;align-items:flex-start;gap:1rem}.btn-danger{width:100%}.info-grid{grid-template-columns:1fr}.endpoint{grid-template-columns:1fr;gap:.5rem}.streams-table .url-code{max-width:100%}}
