:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f9f9f9;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.button{border:none;border-radius:25px;padding:12px 24px;font-size:16px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.button.primary{background-color:#e0e0e0;color:#ff5722}.button.secondary{background-color:#4a4a4a;color:#fff;border:1px solid #e0e0e0}.button:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.button:disabled{cursor:not-allowed;opacity:.6}.dropdown-container{position:relative;width:120px}.dropdown-button{width:100%;padding:8px 12px;border:none;border-radius:20px;background-color:#e0e0e0;color:#4a4a4a;cursor:pointer;text-align:center;font-size:14px}.dropdown-button.speech{background-color:#e0e0e0;color:#4a4a4a}.dropdown-button.nav{background-color:#2196f3;color:#fff}.dropdown-button.cast{background-color:#f44336;color:#fff}.dropdown-menu{position:absolute;top:100%;left:0;width:100%;background-color:#fff;border-radius:8px;margin-top:4px;box-shadow:0 2px 8px #0003;z-index:1000}.dropdown-item{padding:8px 12px;cursor:pointer;transition:background-color .2s}.dropdown-item:hover{background-color:#f5f5f5}.dropdown-item.speech{color:#4a4a4a}.dropdown-item.nav{color:#2196f3}.dropdown-item.cast{color:#f44336}.config-panel{background-color:#fff;padding:20px;display:flex;flex-direction:column;gap:20px;overflow:hidden;flex:1;position:relative}.config-title{padding-bottom:15px;border-bottom:1px solid rgba(0,0,0,.1)}.config-title h2{margin:0;color:#4a4a4a;font-size:1.5rem}.config-switches{display:flex;justify-content:flex-end;gap:20px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.1)}.switch-item{display:flex;align-items:center;gap:8px;color:#fff}.config-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:15px;padding-right:10px;margin-bottom:70px;height:calc(100% - 150px)}.config-list::-webkit-scrollbar{width:8px}.config-list::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}.config-list::-webkit-scrollbar-thumb{background:#0000001a;border-radius:4px}.config-item{display:flex;align-items:center;gap:10px;background:#f5f5f5;padding:10px;border-radius:8px}.config-input{flex:1;background:#fff;border:1px solid #e0e0e0;border-radius:20px;padding:8px 16px;font-size:14px;color:#4a4a4a}.config-input:focus{outline:none;box-shadow:0 0 0 2px #2196f34d}.action-button{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center}.action-button img{width:24px;height:24px}.delete-button{font-size:24px;color:#f44336;font-weight:700;transition:color .2s}.delete-button:hover{color:#d32f2f}.footer-actions{border-top:1px solid rgba(0,0,0,.1);display:flex;justify-content:center;position:absolute;bottom:0;left:0;right:0;background-color:#fff;padding:15px 20px;box-shadow:0 -2px 10px #0000000d;z-index:5}.add-row-button{width:auto}.config-type{padding:6px 12px;border-radius:20px;font-size:14px;min-width:80px;text-align:center}.config-type.speech{background-color:#e0e0e0;color:#4a4a4a}.config-type.nav{background-color:#2196f3;color:#fff}.config-type.cast{background-color:#f44336;color:#fff}.config-text{flex:1;color:#fff}.play-button{background:none;border:none;cursor:pointer;padding:5px}.play-button img{width:24px;height:24px}@media (max-width: 768px){.config-panel{padding:15px;position:relative;height:auto;min-height:200px;max-height:100%;overflow:hidden;z-index:auto;border-radius:0;background-color:#fff;display:flex;flex-direction:column}.config-title{padding-bottom:15px;margin-bottom:15px;flex-shrink:0}.config-list{overflow-y:auto;flex:1;padding-right:5px;margin-bottom:100px;max-height:none}.config-item{padding:8px;margin-bottom:10px;flex-shrink:0}.footer-actions{position:fixed;bottom:70px;left:0;right:0;background-color:#fff;padding:15px;box-shadow:0 -2px 10px #0000000d;z-index:5}.config-input{font-size:14px;padding:6px 12px}.action-button{padding:6px}.action-button img{width:20px;height:20px}.config-header{flex-direction:column}.config-switches{justify-content:center}}.button-pulse{animation:buttonScale .3s ease-in-out}.control-panel{background-color:#4a4a4a;padding:20px 20px 36px;height:100%;display:flex;flex-direction:column;gap:20px;overflow-y:auto}.control-header{display:flex;flex-direction:column;gap:15px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1)}.control-buttons{display:flex;justify-content:space-between;gap:10px}.config-button{flex:1}.control-switches{display:flex;flex-wrap:wrap;gap:15px;padding-top:10px}.switch-item{display:flex;align-items:center;gap:8px;color:#fff;flex-basis:calc(50% - 10px);min-width:80px}.switch-item img{width:40px;height:20px;cursor:pointer}.control-content{display:flex;justify-content:space-around;align-items:center;flex-shrink:0}.directional-controller{position:relative;width:180px;height:180px}.directional-disc{position:relative;width:150px;height:150px;background-color:#e0e0e0;border-radius:50%;box-shadow:inset 0 0 10px #0003,0 2px 4px #0000004d,0 0 0 3px #ffffff1a}.direction{position:absolute;width:40px;height:40px;display:flex;align-items:center;cursor:pointer;z-index:2;padding:0;background-color:#e0e0e0}.direction img{width:20px;height:20px}.direction span{font-size:14px;font-weight:700;color:#000}.direction.up{top:5px;left:50%;transform:translate(-50%);flex-direction:column}.direction.right{right:5px;top:50%;transform:translateY(-50%);flex-direction:row}.direction.down{bottom:5px;left:50%;transform:translate(-50%);flex-direction:column}.direction.left{left:5px;top:50%;transform:translateY(-50%);flex-direction:row}.label-top{margin-bottom:5px}.label-right{margin-left:5px}.label-bottom{margin-top:5px}.label-left{margin-right:5px}.center-button{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:50%;background:radial-gradient(circle at 40% 40%,#a0a0a0,gray);box-shadow:inset 0 0 4px #00000080}.vertical-controller{position:relative;width:60px;height:180px}.vertical-disc{position:relative;width:60px;height:150px;background-color:#e0e0e0;border-radius:30px;box-shadow:inset 0 0 10px #0003,0 2px 4px #0000004d,0 0 0 3px #ffffff1a;display:flex;flex-direction:column;justify-content:space-between;padding:15px 2px}.v-direction{display:flex;flex-direction:column;justify-content:center;align-items:center;cursor:pointer;height:40px;padding:0;background-color:#e0e0e0}.v-direction img{width:20px;height:20px}.v-label-top{margin-bottom:5px;font-size:14px;font-weight:700;color:#000}.v-label-bottom{margin-top:5px;font-size:14px;font-weight:700;color:#000}.direction:hover,.v-direction:hover{opacity:.8}.direction:active,.v-direction:active{opacity:.6}@keyframes buttonScale{0%{transform:scale(1)}50%{transform:scale(.9)}to{transform:scale(1)}}.direction.button-pulse,.v-direction.button-pulse{animation:buttonScale .3s ease-in-out}@media (max-width: 768px){.control-panel{padding:15px 15px 36px;max-height:none;border-radius:0;background-color:#4a4a4a}.control-header{padding-bottom:15px}.control-switches{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:10px 0}.switch-item{margin-bottom:10px}.control-content{padding:10px 0;display:flex;justify-content:space-between}.directional-controller{max-width:180px;margin:0 auto}.directional-disc{width:180px;height:180px}.vertical-controller{max-width:180px;margin:0 auto}.vertical-disc{min-width:10px;min-height:70px}}@media (max-width: 480px){.control-switches{grid-template-columns:1fr;align-items:flex-start}.switch-item{flex-basis:100%}}.switch-button{background:none;border:none;padding:0;cursor:pointer}.obsbot-camera-control{background:#22272e;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#f8fafc;display:flex;flex-direction:column;gap:16px;padding:16px 16px 28px}.obsbot-camera-header{align-items:center;display:flex;justify-content:space-between;gap:12px}.obsbot-camera-header h2{font-size:20px;line-height:1.2;margin:0}.obsbot-camera-header p{color:#b8c2cc;font-size:13px;margin:4px 0 0}.obsbot-icon-button{align-items:center;background:#3b424b;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:22px;height:42px;justify-content:center;width:42px}.obsbot-icon-button:disabled,.obsbot-camera-control button:disabled,.obsbot-camera-control input:disabled{cursor:not-allowed;opacity:.45}.obsbot-status-strip{align-items:center;background:linear-gradient(135deg,#0f766e38,#94a3b814),#111827;border:1px solid rgba(255,255,255,.12);border-radius:8px;display:grid;gap:4px;justify-content:center;min-height:58px;padding:10px 14px}.obsbot-status-strip span{color:#94a3b8;font-size:12px;font-weight:700;text-transform:uppercase}.obsbot-status-strip strong{color:#e2e8f0;font-size:14px;overflow-wrap:anywhere}.obsbot-pad-row{align-items:center;display:grid;gap:14px;grid-template-columns:minmax(76px,.4fr) minmax(170px,1fr)}.obsbot-reset-button{background:#3b424b;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:700;min-height:44px}.obsbot-direction-pad{aspect-ratio:1 / 1;background:#181d23;border-radius:50%;justify-self:center;max-width:210px;min-width:170px;position:relative;width:80%}.obsbot-direction{align-items:center;background:transparent;border:0;cursor:pointer;display:flex;height:42px;justify-content:center;padding:0;position:absolute;width:42px}.obsbot-direction img{height:22px;width:22px}.obsbot-up{left:50%;top:8px;transform:translate(-50%)}.obsbot-right{right:8px;top:50%;transform:translateY(-50%)}.obsbot-down{bottom:8px;left:50%;transform:translate(-50%)}.obsbot-left{left:8px;top:50%;transform:translateY(-50%)}.obsbot-center{background:#eef2f7;border:0;border-radius:50%;cursor:pointer;height:48px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:48px}.obsbot-zoom-row{align-items:center;display:grid;gap:14px;grid-template-columns:1fr 68px}.obsbot-zoom-row input{accent-color:#e11d48;width:100%}.obsbot-zoom-row output{background:#121820;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#fff;font-variant-numeric:tabular-nums;font-weight:700;padding:8px 10px;text-align:center}.obsbot-status-row{align-items:center;color:#cbd5e1;display:flex;gap:12px;justify-content:space-between}.obsbot-status-row span{font-size:13px;overflow-wrap:anywhere}.obsbot-status-row button{background:#3b424b;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:700;padding:8px 12px}@media (max-width: 768px){.obsbot-camera-control{padding:14px 14px 28px}.obsbot-pad-row{grid-template-columns:1fr}.obsbot-reset-button{justify-self:stretch}}.bottom-sheet-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease-in;transition:background-color .3s ease-in-out}.backdrop-hidden{background-color:transparent;pointer-events:none}.backdrop-hidden .bottom-sheet{pointer-events:auto}.bottom-sheet{position:relative;background-color:#4a4a4a;width:100%;border-top-left-radius:16px;border-top-right-radius:16px;box-shadow:0 -2px 16px #00000040;overflow:hidden;display:flex;flex-direction:column;transition:height .3s cubic-bezier(.2,.8,.2,1),transform .2s cubic-bezier(.2,.8,.2,1);cursor:grab;will-change:transform,height}.bottom-sheet.full-screen{border-top-left-radius:0;border-top-right-radius:0;height:100vh!important}.bottom-sheet:active{cursor:grabbing}.bottom-sheet-header{padding:10px 0;display:flex;flex-direction:column;align-items:center;border-bottom:1px solid rgba(255,255,255,.1)}.drag-handle{width:40px;height:4px;background-color:#ffffff80;border-radius:2px}.bottom-sheet-content{flex:1;overflow-y:auto;padding:0;-webkit-overflow-scrolling:touch;color:#fff}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.dashboard-container{height:100vh;display:flex;flex-direction:column;background-color:#fff}.dashboard-header{background-color:#4a4a4a;padding:20px;display:flex;justify-content:space-between;align-items:center;color:#fff;box-shadow:0 2px 4px #0000001a;border-bottom:1px solid rgba(255,255,255,.1)}.dashboard-header h1{margin:0;font-size:24px}.user-info{font-size:16px;display:flex;align-items:center;gap:10px}.logout-button{background-color:transparent;color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:4px;padding:4px 10px;font-size:14px;cursor:pointer;margin-left:10px;transition:all .2s ease}.logout-button:hover{background-color:#ffffff1a;border-color:#fff}.dashboard-content{flex:1;display:flex;overflow:hidden;position:relative}.config-section{width:60%;overflow:hidden;border-right:1px solid rgba(0,0,0,.1);display:flex}.control-section{width:40%;position:sticky;top:0;right:0;height:100%;overflow:hidden;background-color:#4a4a4a}.mobile-config-trigger{position:fixed;bottom:0;left:0;right:0;background-color:#fff;height:55px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:8px 0;box-shadow:0 -2px 10px #0000001a;border-top-left-radius:16px;border-top-right-radius:16px;z-index:50;cursor:pointer;transition:transform .3s ease}.mobile-config-trigger:hover{transform:translateY(-5px)}.mobile-config-trigger span{font-size:14px;color:#666;margin-top:5px}.drag-handle{width:40px;height:4px;background-color:#ddd;border-radius:2px;margin-bottom:8px}.sheet-container{box-shadow:0 -2px 16px #00000026!important;border-top-left-radius:16px!important;border-top-right-radius:16px!important;max-height:90vh!important}.sheet-content{height:100%;overflow:hidden;display:flex;flex-direction:column}.sheet-header{display:flex;flex-direction:column;align-items:center;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.1)}.sheet-header h2{margin:10px 0;font-size:18px;color:#fff}@media (max-width: 768px){.dashboard-content{flex-direction:column;height:calc(100vh - 60px);position:relative}.config-section,.control-section{width:100%}.config-section{display:block;flex:1;overflow:auto;height:calc(100vh - 80px);padding-bottom:130px}.control-section{display:none}.dashboard-container{height:100vh;overflow:hidden}.sheet-header{border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:15px;margin-bottom:10px;background-color:transparent}.sheet-header h2{font-size:18px;font-weight:600;color:#fff}.sheet-content{padding-bottom:env(safe-area-inset-bottom,20px)}}.socket-status,.socket-status[title=Disconnected],.socket-status[title^="Connection error"],.socket-status[title="Initializing..."]{display:none}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:#4a4a4a;margin:0;padding:32px;box-sizing:border-box;position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%}.logo-image{width:250px;margin-bottom:20px}.tagline{color:#fff;font-size:24px;margin-bottom:40px;position:relative;padding:0 20px;text-align:center}.tagline:before,.tagline:after{content:"";position:absolute;top:50%;width:80px;height:1px;background-color:#fff}.tagline:before{right:100%}.tagline:after{left:100%}.title{color:#fff;font-size:36px;margin-bottom:40px;text-align:center}.login-form{width:100%;max-width:320px;display:flex;flex-direction:column;align-items:center}.input-field{width:100%;padding:15px;margin:10px 0;border:none;border-radius:25px;font-size:16px;outline:none;box-sizing:border-box}.input-field::placeholder{color:#666}.sign-in-button{background-color:#e0e0e0;color:#ff5722;border:none;border-radius:25px;padding:15px 40px;font-size:18px;margin-top:20px;cursor:pointer;transition:all .3s ease}.sign-in-button:hover{background-color:#d0d0d0}@media (max-width: 480px){.login-container{padding:20px}.logo-image{width:200px}.tagline{font-size:20px}.tagline:before,.tagline:after{width:50px}.title{font-size:28px}.login-form{max-width:280px}}
