: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)}}#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}body{margin:0}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%}:root{--bg:#f3f3f5;--card-bg:#fff;--border:#e5e5ea;--text:#111114;--text-muted:#6e6e74;--accent:#2563eb;--accent-bg:#eef4ff;--danger:#dc2626;--success:#10b981;--radius:12px;--shadow:0 1px 2px #0000000a}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px}button{font-family:inherit;font-size:inherit;cursor:pointer}input,textarea,select{font-family:inherit;font-size:inherit}.app{flex-direction:column;min-height:100vh;display:flex}.topbar{border-bottom:1px solid var(--border);background:var(--card-bg);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.brand{letter-spacing:-.01em;font-size:18px;font-weight:600}.dashboard{flex:1;grid-template-columns:320px 1fr 360px;gap:1rem;width:100%;max-width:1600px;margin:0 auto;padding:1rem;display:grid}.panel{flex-direction:column;gap:1rem;display:flex}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem}.card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px}.card-value{margin-top:.25rem;font-size:15px;font-weight:500}.row{justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.row+.row{border-top:1px solid var(--border)}.subheading{text-align:center;color:var(--text-muted);margin-bottom:.75rem;font-size:13px;font-weight:500}.muted{color:var(--text-muted);margin:.5rem 0;font-size:13px}.btn-primary{border:1px solid var(--accent);background:var(--accent-bg);width:100%;color:var(--accent);border-radius:var(--radius);padding:.6rem 1rem;font-weight:500;transition:background .15s}.btn-primary:hover{background:#e0ebff}.btn-secondary{border:1px solid var(--border);width:100%;color:var(--text);border-radius:var(--radius);background:0 0;margin-top:.5rem;padding:.5rem 1rem}.btn-secondary:hover{background:var(--bg)}.btn-icon{border:1px solid var(--border);background:var(--card-bg);border-radius:8px;justify-content:center;align-items:center;min-width:36px;height:36px;padding:.5rem;display:inline-flex}.btn-icon:hover{background:var(--bg)}.btn-link{color:var(--accent);background:0 0;border:none;padding:.25rem 0;font-size:13px}.btn-link:hover{text-decoration:underline}.num-input{border:1px solid var(--border);background:var(--card-bg);text-align:right;border-radius:8px;width:60px;padding:.4rem .5rem}.msg-input,.notes-input{border:1px solid var(--border);background:var(--bg);resize:vertical;border-radius:8px;width:100%;min-height:80px;padding:.6rem .75rem;font-family:inherit}.search-input,.device-select{border:1px solid var(--border);background:var(--card-bg);border-radius:8px;width:100%;margin-bottom:.5rem;padding:.5rem .75rem}.control-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.dpad{grid-template-columns:repeat(3,1fr);justify-items:center;gap:.4rem;display:grid}.ctrl-btn{border:1px solid var(--border);background:var(--card-bg);border-radius:8px;justify-content:center;align-items:center;width:44px;height:44px;font-size:16px;display:inline-flex}.ctrl-btn:hover{background:var(--bg)}.gesture-list{flex-direction:column;gap:.4rem;display:flex}.gesture-btn{border:1px solid var(--border);background:var(--card-bg);border-radius:999px;padding:.45rem .75rem;font-size:13px;transition:all .15s}.gesture-btn:hover{background:var(--bg)}.gesture-btn.active{border-color:var(--accent);background:var(--accent-bg);color:var(--accent)}.msg-actions{align-items:center;gap:.5rem;margin-top:.5rem;display:flex}.msg-actions .btn-primary{flex:1}.device-nav .nav-arrows{justify-content:flex-end;gap:.5rem;display:flex}.tab-row{grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem;display:grid}.tab{border:1px solid var(--border);background:var(--card-bg);text-align:left;border-radius:8px;flex-direction:column;align-items:flex-start;gap:.15rem;padding:.6rem .5rem;display:flex}.tab span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.tab strong{font-size:14px;font-weight:500}.tab.active{border-color:var(--accent);background:var(--accent-bg)}.tab.active strong{color:var(--accent)}.tab-content{flex-direction:column;gap:.25rem;display:flex}.phone-mirror{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;touch-action:none;flex-direction:column;justify-content:flex-start;align-items:center;gap:.5rem;display:flex}.phone-frame{background:#1a1a1f;border-radius:40px;flex-direction:column;flex-shrink:0;width:320px;height:660px;padding:14px;display:flex;position:relative;box-shadow:0 6px 24px #0000001f}.phone-screen{color:#fff;background:#000;border-radius:28px;flex:1;justify-content:center;align-items:center;display:flex;overflow:hidden}.phone-home-indicator{background:#444;border-radius:2px;width:80px;height:4px;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.placeholder{text-align:center;color:#aaa;padding:1rem}.placeholder strong{color:#fff;margin:.5rem 0;font-size:16px;display:block}.placeholder small{color:#777;font-size:12px}.placeholder.offline{color:#b66}.phone-stream{object-fit:contain;cursor:crosshair;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;touch-action:none;background:#000;width:100%;height:100%;display:block}.stream-container{width:100%;height:100%;display:flex;position:relative}.tap-marker{pointer-events:none;background:#2563eb4d;border:2px solid #ffffffe6;border-radius:50%;width:20px;height:20px;animation:.6s ease-out forwards tap-ripple;position:absolute;transform:translate(-50%,-50%)}.tap-marker.swipe-end{background:#f59e0b4d}.tap-marker.hold{background:#8b5cf64d;border-color:#c4b5fde6;animation-duration:.8s}.tap-marker.shutter{background:#ffffffb3;border-color:#fffffff2;animation-duration:.3s}.gesture-modes{flex-wrap:wrap;justify-content:center;gap:.4rem;max-width:360px;margin-bottom:.75rem;display:flex}.gesture-mode{border:1px solid var(--border);background:var(--card-bg);cursor:pointer;border-radius:999px;padding:.35rem .7rem;font-size:12px;transition:all .15s}.gesture-mode:hover:not(:disabled){background:var(--bg)}.gesture-mode.active{border-color:var(--accent);background:var(--accent-bg);color:var(--accent);font-weight:500}.gesture-mode:disabled{opacity:.4;cursor:not-allowed}@keyframes tap-ripple{0%{opacity:1;width:12px;height:12px}to{opacity:0;width:40px;height:40px}}.tap-feedback{border-radius:6px;max-width:360px;margin:.75rem 0 0;padding:.4rem .7rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.tap-feedback.success{color:var(--success);background:#d1fae5}.tap-feedback.error{color:var(--danger);background:#fee2e2}.login-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{flex-direction:column;gap:1rem;width:100%;max-width:360px;padding:2rem;display:flex}.login-title{letter-spacing:-.01em;margin:0;font-size:22px;font-weight:600}.login-field{flex-direction:column;gap:.4rem;display:flex}.login-field input{border:1px solid var(--border);background:var(--card-bg);border-radius:8px;padding:.6rem .75rem}.login-field input:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:#0000}.login-error{color:var(--danger);background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;padding:.6rem .75rem;font-size:13px}.topbar-actions{align-items:center;gap:1rem;display:flex}.banner{border-bottom:1px solid var(--border);padding:.75rem 1.5rem;font-size:13px}.banner.error{color:var(--danger);background:#fee2e2}.banner.success{color:var(--success);background:#d1fae5}.banner.muted{background:var(--bg);color:var(--text-muted)}.topbar-nav{flex:1;align-items:center;gap:.25rem;margin-left:2rem;display:flex}.nav-link{color:var(--text-muted);border-radius:8px;padding:.4rem .8rem;font-size:14px;font-weight:500;text-decoration:none}.nav-link:hover{background:var(--bg);color:var(--text)}.nav-link.active{background:var(--accent-bg);color:var(--accent)}.app-main{flex-direction:column;flex:1;display:flex}.page-actions{justify-content:flex-end;align-items:center;gap:.75rem;padding:.75rem 1.5rem 0;display:flex}.kbd-toggle.active{background:var(--accent-bg);color:var(--accent);border-radius:6px;padding:.25rem .5rem}kbd{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px}.admin-page{flex-direction:column;gap:1rem;width:100%;max-width:1100px;margin:0 auto;padding:1.5rem;display:flex}.page-header{justify-content:space-between;align-items:center;display:flex}.page-header h2{margin:0;font-size:22px;font-weight:600}.admin-form h3,.admin-page .card h3{margin:0 0 1rem;font-size:16px;font-weight:600}.form-grid{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.form-field{flex-direction:column;gap:.4rem;display:flex}.form-field-wide{border:1px solid var(--border);border-radius:8px;grid-column:1/-1;padding:.75rem}.form-field input,.form-field select{border:1px solid var(--border);background:var(--card-bg);font-family:inherit;font-size:inherit;border-radius:8px;padding:.5rem .75rem}.form-field input:focus,.form-field select:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:#0000}.checkbox-row{align-items:center;gap:.5rem;padding:.25rem 0;font-size:13px;display:flex}.form-actions{grid-column:1/-1;justify-content:flex-end;display:flex}.form-actions .btn-primary{width:auto;min-width:160px}.admin-table{border-collapse:collapse;width:100%}.admin-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);padding:.5rem .75rem;font-size:12px;font-weight:500}.admin-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:.6rem .75rem}.admin-table tr:last-child td{border-bottom:none}.role-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:.15rem .5rem;font-size:11px;font-weight:500;display:inline-block}.role-admin{background:var(--accent-bg);color:var(--accent)}.role-user{color:#475569;background:#f1f5f9}.btn-link.danger{color:var(--danger)}.btn-link.danger:disabled{color:var(--text-muted);cursor:not-allowed;text-decoration:none}.confirm-row{color:var(--text-muted);align-items:center;gap:.5rem;font-size:13px;display:inline-flex}.small{font-size:12px}.devices-page{flex-direction:column;gap:1rem;width:100%;max-width:1300px;margin:0 auto;padding:1.5rem;display:flex}.devices-page .page-header p{margin:.25rem 0 0}.devices-toolbar{flex-direction:column;gap:.75rem;padding:1rem;display:flex}.devices-toolbar .search-input{margin-bottom:0}.status-tabs{flex-wrap:wrap;gap:.4rem;display:flex}.status-tab{border:1px solid var(--border);background:var(--card-bg);border-radius:999px;padding:.4rem .75rem;font-size:13px}.status-tab:hover{background:var(--bg)}.status-tab.active{border-color:var(--accent);background:var(--accent-bg);color:var(--accent)}.empty-state{text-align:center;color:var(--text-muted);padding:2rem 1rem}.device-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.device-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:.75rem;padding:1rem;display:flex}.device-card.status-online{border-left:3px solid var(--success)}.device-card.status-in-use{border-left:3px solid #f59e0b}.device-card.status-offline{opacity:.85;border-left:3px solid #94a3b8}.device-card-head{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.device-card-head h3{margin:0;font-size:16px;font-weight:600}.device-card-head .udid{color:var(--text-muted);background:var(--bg);border-radius:4px;margin-top:.25rem;padding:.1rem .4rem;font-size:11px;display:inline-block}.device-status{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-radius:999px;padding:.2rem .55rem;font-size:11px;font-weight:500}.device-status.status-online{color:var(--success);background:#d1fae5}.device-status.status-in-use{color:#b45309;background:#fef3c7}.device-status.status-offline{color:#64748b;background:#f1f5f9}.device-status.status-unknown{color:var(--text-muted);background:#f1f5f9}.device-attrs{grid-template-columns:1fr 1fr;gap:.4rem 1rem;margin:0;display:grid}.device-attrs>div{flex-direction:column;gap:.1rem;display:flex}.device-attrs dt{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.device-attrs dd{margin:0;font-size:13px}.device-in-use{background:var(--bg);border-radius:6px;margin:0;padding:.4rem .6rem}.device-actions{gap:.5rem;display:flex}.device-actions .btn-primary{width:100%;min-width:0}.placeholder-card{background:var(--bg);border-style:dashed}.placeholder-card .card-label{margin-bottom:.5rem}.placeholder-card code{background:var(--card-bg);border-radius:3px;padding:1px 4px;font-size:11px}.panel.left code.udid{background:var(--bg);border-radius:4px;margin-top:.25rem;padding:2px 6px;font-size:11px;display:inline-block}.device-gestures .gesture-actions,.system-controls .system-row{grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.5rem;display:grid}.system-controls .system-row .btn-secondary{width:100%;margin:0;font-size:13px}.system-dpad{grid-template-columns:1fr 1fr 1fr;justify-items:center;gap:.4rem;margin-top:.5rem;display:grid}.system-dpad .btn-secondary{width:44px;height:44px;margin:0;padding:0;font-size:18px}.device-gestures .gesture-actions .btn-secondary{width:100%;margin:0;font-size:13px}.device-gestures .msg-input{min-height:60px;margin-top:.5rem}.gesture-feedback{border-radius:6px;margin:.75rem 0 0;padding:.5rem .75rem;font-size:12px}.gesture-feedback.success{color:var(--success);background:#d1fae5}.gesture-feedback.error{color:var(--danger);background:#fee2e2}.live-type-input{border:1px solid var(--border);background:var(--card-bg);border-radius:8px;width:100%;margin-top:.5rem;padding:.5rem .75rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px}.live-type-input:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:#0000}.live-type-input:disabled{background:var(--bg);cursor:not-allowed}.live-type-meta{justify-content:space-between;align-items:center;margin-top:.4rem;display:flex}
