*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100dvh;background:#1a1a1a;color:#e0e0e0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}.screen{display:flex;flex-direction:column;height:100dvh;padding:16px;gap:12px}.screen-header{flex-shrink:0}.screen-header h1{font-size:20px;font-weight:600;color:#fff}.screen-header p{font-size:13px;color:#888;margin-top:4px}label{display:block;font-size:13px;color:#aaa;margin-bottom:4px}input[type=password],input[type=text],textarea,select{width:100%;padding:12px;background:#2a2a2a;border:1px solid #444;border-radius:8px;color:#e0e0e0;font-size:16px;font-family:inherit;outline:none;transition:border-color .2s}input:focus,textarea:focus,select:focus{border-color:#4a9eff}textarea{resize:vertical;min-height:80px}.form-group{display:flex;flex-direction:column;gap:4px}.form-stack{display:flex;flex-direction:column;gap:16px;flex:1}button{width:100%;height:48px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s;flex-shrink:0}button:active{opacity:.8}button:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:#4a9eff;color:#fff}.btn-danger{background:#e74c3c;color:#fff}.btn-secondary{background:#444;color:#e0e0e0}.status-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#222;border-radius:8px;font-size:13px;flex-shrink:0}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.connected{background:#2ecc71}.status-dot.connecting,.status-dot.processing{background:#f39c12;animation:pulse 1s infinite}.status-dot.disconnected{background:#e74c3c}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.camera-container{flex-shrink:0;height:30%;min-height:120px;background:#000;border-radius:8px;overflow:hidden;position:relative}.camera-preview{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.response-log{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding:8px 0;min-height:0}.response-entry{padding:8px 12px;background:#222;border-radius:8px;font-size:14px;line-height:1.5}.response-entry.incomplete{border-left:2px solid #4a9eff}.response-timestamp{font-size:11px;color:#666;margin-bottom:4px}.response-text{white-space:pre-wrap;word-break:break-word}.response-empty{display:flex;align-items:center;justify-content:center;flex:1;color:#555;font-size:14px}.error-message{padding:12px;background:#e74c3c26;border:1px solid rgba(231,76,60,.3);border-radius:8px;color:#e74c3c;font-size:14px;flex-shrink:0}.stopped-content{flex:1;display:flex;flex-direction:column;gap:12px;min-height:0}
