:root{--bg: #000000;--card: #141414;--card-2: #1c1c1c;--line: #262626;--text: #f5f5f5;--muted: #8a8a8a;--accent: #ffd400;--warn: #ff9800;--err: #ff5252;--radius: 14px;--gap: 10px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-optical-sizing:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden;max-width:480px;margin:0 auto;width:100%}.top{display:grid;grid-template-columns:minmax(96px,.55fr) 1fr;gap:var(--gap);padding:var(--gap) var(--gap) 0;flex:0 0 auto}.logo-card{background:transparent;display:flex;align-items:center;justify-content:flex-start;padding:6px 4px 6px 8px;color:#fff;min-height:84px}.logo-svg{width:100%;max-width:120px;height:auto;display:block}.controls-card{background:var(--card);border-radius:var(--radius);padding:8px 12px;display:flex;flex-direction:column;gap:6px;justify-content:center}.ctrl-row{display:flex;align-items:center;gap:10px}.ctrl-label{color:var(--muted);font-size:12px;min-width:56px;text-align:right}.pill{position:relative;flex:1 1 auto;background:#000;border:1.5px solid var(--line);border-radius:999px;padding:6px 30px 6px 16px;min-height:34px;display:flex;align-items:center;transition:border-color .12s ease}.pill:focus-within{border-color:var(--accent)}.pill select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;border:none;outline:none;color:var(--text);font-size:13px;font-weight:700;width:100%;cursor:pointer}.pill select:disabled{color:var(--muted);cursor:not-allowed}.pill-chevron{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text);width:18px;height:18px;display:block}.banner{margin:var(--gap) var(--gap) 0;padding:10px 14px;background:var(--card);border-radius:var(--radius);font-size:13px}.banner.warn{background:#2a1d00;color:var(--warn)}.banner.err{background:#2a0d0d;color:var(--err)}.banner-actions{display:flex;gap:10px;align-items:center;margin-top:6px;flex-wrap:wrap}.banner-btn{background:var(--accent);color:#000;border:none;border-radius:999px;padding:6px 14px;font-size:12px;font-weight:700;cursor:pointer}.banner-hint{color:var(--muted);font-size:12px}.loc-card{display:flex;align-items:center;gap:8px;margin:var(--gap) var(--gap) 0;padding:10px 14px;background:var(--card);border-radius:var(--radius);font-variant-numeric:tabular-nums;font-size:13px}.dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse 1.6s infinite;flex-shrink:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.loc-text{font-weight:500}.loc-muted{color:var(--muted);font-size:12px}.loc-status{margin-left:auto;color:var(--muted);font-size:12px}.gps-btn{background:var(--accent);color:#000;border:none;border-radius:999px;padding:4px 12px;font-size:11px;font-weight:700;cursor:pointer}.pinned-cam{flex:0 0 auto;padding:var(--gap) var(--gap) 0}.placeholder.pinned{flex:0 0 auto;margin:var(--gap) var(--gap) 0}.scroll-area{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:var(--gap);display:flex;flex-direction:column;gap:var(--gap)}.scroll-area>*{flex-shrink:0}.placeholder{background:var(--card);border-radius:var(--radius);padding:24px;color:var(--muted);text-align:center}.cam{background:var(--card);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;cursor:pointer}.cam-frame{position:relative;background:#000;width:100%;padding-top:56.25%;overflow:hidden}.cam-frame>img,.cam-frame>.offline-fill{position:absolute;top:0;right:0;bottom:0;left:0}.cam-frame img{width:100%;height:100%;object-fit:cover;display:block}.cam-frame img.is-hidden,.qi-thumb img.is-hidden{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.cam-frame .offline-fill{position:absolute;top:0;right:0;bottom:0;left:0;background:#555}.cam-info{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--card)}.cam-summary{font-size:14px;min-width:0;flex:1}.cs-muted{color:var(--muted);font-weight:400}.cs-strong{color:var(--text);font-weight:700}.src-tag{color:var(--accent);font-weight:800;font-size:12px;letter-spacing:1px}.manual-tag{position:absolute;top:12px;right:12px;background:var(--accent);color:#000;padding:6px 14px;border-radius:999px;font-size:12px;font-weight:700}.offline-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#c0392b;color:#fff;padding:6px 18px;border-radius:4px;font-size:16px;font-weight:800;letter-spacing:2px}.queue{display:flex;flex-direction:column;gap:var(--gap)}.queue-header{display:flex;justify-content:space-between;align-items:baseline;padding:4px;font-size:12px;letter-spacing:2px;color:var(--accent);font-weight:800}.queue-header .muted{color:var(--muted);letter-spacing:1px;font-weight:600}.queue-list{display:flex;flex-direction:column;gap:var(--gap)}.queue-item{display:flex;gap:12px;align-items:center;padding:10px;background:var(--card);border-radius:var(--radius);border:none;cursor:pointer;text-align:left;color:var(--text)}.queue-item:nth-child(2n){background:var(--card-2)}.qi-thumb{position:relative;width:110px;height:70px;flex-shrink:0;background:#000;border-radius:8px;overflow:hidden;border:2px solid transparent}.queue-item.active .qi-thumb{border-color:var(--accent)}.qi-thumb img{width:100%;height:100%;object-fit:cover;display:block}.qi-offline{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#c0392b;color:#fff;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:800;letter-spacing:.5px}.qi-thumb .offline-fill{position:absolute;top:0;right:0;bottom:0;left:0;background:#555}.qi-meta{flex:1;min-width:0;display:flex;align-items:center;gap:8px}.qi-lines{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px;font-size:13px}.qi-lines .cs-strong{font-size:14px;font-weight:700}.qi-lines>div{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qi-src{font-size:11px;align-self:center;color:var(--accent);font-weight:800;letter-spacing:1px}.queue-pagination{padding:12px;display:flex;flex-direction:column;gap:8px;background:var(--card);border-radius:var(--radius)}.qp-status{font-size:12px;color:var(--muted)}.qp-actions{display:flex;gap:8px;flex-wrap:wrap}.qp-btn{flex:1;min-width:0;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:700;cursor:pointer;background:var(--card-2);color:var(--text);border:1px solid var(--line)}.qp-btn.primary{background:var(--accent);color:#000;border-color:var(--accent)}.qp-btn:disabled{opacity:.35;cursor:not-allowed}.foot{flex:0 0 auto;display:flex;gap:16px;align-items:center;margin:0 var(--gap) var(--gap);padding:12px 14px;background:var(--card);border-radius:var(--radius);font-size:12px}.foot .foot-right{margin-left:auto}.muted{color:var(--muted)}.splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .4s ease}.splash-in,.splash-hold{opacity:1}.splash-out{opacity:0;pointer-events:none}.splash-img{max-width:min(420px,80vw);max-height:80vh;width:auto;height:auto;object-fit:contain;display:block;margin:auto}.splash-copy{position:absolute;left:0;right:0;bottom:30px;text-align:center;color:#999;font-size:12px}@media (min-width: 700px){.app{max-width:600px}}
