:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}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:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:0;background:#f5f5f5}.login-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center;max-width:100%;width:100%;margin:0 auto}@media(min-width:768px){.login-card{padding:3rem 4rem;max-width:600px}}@media(min-width:1024px){.login-card{padding:3rem 4rem;max-width:700px}}@media(min-width:1440px){.login-card{padding:4rem 5rem;max-width:800px}}.login-card h1{margin-bottom:.5rem;color:#333;font-size:1.5rem}@media(min-width:768px){.login-card h1{font-size:2rem}}@media(min-width:1024px){.login-card h1{font-size:2.5rem;margin-bottom:1rem}}.login-card p{color:#666;margin-bottom:2rem;font-size:.9rem}@media(min-width:768px){.login-card p{font-size:1rem}}@media(min-width:1024px){.login-card p{font-size:1.125rem;margin-bottom:2rem}}@media(min-width:1440px){.login-card p{font-size:1.25rem;margin-bottom:2.5rem}}.login-buttons{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.login-button{color:#fff;border:none;padding:1rem 1.5rem;font-size:1rem;border-radius:8px;cursor:pointer;width:100%;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.25rem;font-weight:600}.login-button-woff{background:#1976d2}.login-button-woff:hover:not(:disabled){background:#1565c0;transform:translateY(-2px);box-shadow:0 4px 12px #1976d24d}.login-button-line{background:#06c755}.login-button-line:hover:not(:disabled){background:#05b34a;transform:translateY(-2px);box-shadow:0 4px 12px #06c7554d}.login-button:disabled{background:#ccc;cursor:not-allowed}.login-button-sub{font-size:.75rem;font-weight:400;opacity:.9}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:1rem;border-radius:6px;margin-bottom:1rem}.form-group{margin-bottom:1.5rem;text-align:left}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500;font-size:.9rem}@media(min-width:768px){.form-group label{font-size:1rem}}.backend-url-input{width:100%;padding:.75rem;font-size:.9rem;border:1px solid #ddd;border-radius:6px;box-sizing:border-box;transition:border-color .3s ease}.backend-url-input:focus{outline:none;border-color:#06c755}.backend-url-input:disabled{background:#f5f5f5;cursor:not-allowed}@media(min-width:768px){.backend-url-input{padding:.875rem;font-size:1rem}}.help-text{font-size:.75rem;color:#999;margin-top:.25rem;margin-bottom:0}@media(min-width:768px){.help-text{font-size:.875rem}}.info-text{font-size:.875rem;color:#999;margin-top:1rem}.management-container{min-height:100vh;background:#f5f5f5}.management-nav{background:#fff;box-shadow:0 1px 3px #0000001a;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.nav-brand h2{margin:0;color:#333;font-size:1.5rem}.nav-user{display:flex;align-items:center;gap:1rem}.user-name{color:#666;font-size:.9rem}.nav-logout-button{background:#f44336;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background .3s}.nav-logout-button:hover{background:#d32f2f}.nav-actions{display:flex;align-items:center;gap:1rem}.video-call-button{position:relative;background:transparent;border:none;width:50px;height:50px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.video-call-button:hover{transform:scale(1.1)}.video-call-button .video-call-icon{font-size:1.5rem}.video-call-button.has-participants .video-call-icon{animation:pulse 2s ease-in-out infinite}.video-call-button .online-badge{position:absolute;top:-5px;right:-5px;background:#f44;color:#fff;border-radius:12px;padding:.2rem .5rem;font-size:.7rem;font-weight:700;animation:badge-pulse 2s ease-in-out infinite}.enable-audio-button{background:#ff9800;border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;font-size:1.2rem;animation:attention-pulse 1.5s ease-in-out infinite}.enable-audio-button:hover{transform:scale(1.1);background:#f57c00}@keyframes attention-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.mute-button{background:transparent;border:none;width:40px;height:40px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.mute-button:hover{transform:scale(1.1)}.recording-control{display:flex;align-items:center;gap:.5rem}.recording-label{font-size:.9rem;color:#333;font-weight:500}.recording-toggle{position:relative;width:50px;height:26px;border-radius:13px;border:none;cursor:pointer;transition:all .3s ease}.recording-toggle.enabled{background:#4caf50}.recording-toggle.disabled{background:#ccc}.recording-toggle:hover{opacity:.8}.recording-toggle:before{content:"";position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;top:2px;transition:all .3s ease;box-shadow:0 2px 4px #0003}.recording-toggle.enabled:before{left:26px}.recording-toggle.disabled:before{left:2px}.hamburger-button{background:none;border:none;font-size:1.8rem;cursor:pointer;color:#333;padding:.5rem;transition:color .3s}.hamburger-button:hover{color:#06c755}.dropdown-menu{position:fixed;inset:0;z-index:1000}.dropdown-overlay{position:absolute;inset:0;background:#00000080}.dropdown-content{position:absolute;top:4rem;right:1rem;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;overflow:hidden}.dropdown-item{width:100%;background:none;border:none;padding:1rem 1.5rem;display:flex;align-items:center;gap:1rem;cursor:pointer;color:#666;font-size:1rem;transition:all .2s;text-align:left}.dropdown-item:hover{background:#f5f5f5;color:#333}.dropdown-item.active{background:#e3f2fd;color:#1976d2}.dropdown-divider{height:1px;background:#e0e0e0;margin:.5rem 0}.menu-icon{font-size:1.2rem}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes badge-pulse{0%,to{box-shadow:0 0 #ff4444b3}50%{box-shadow:0 0 0 6px #f440}}.management-content{min-height:calc(100vh - 4rem)}.management-main{padding:2rem}.profile-section{margin-bottom:2rem}.profile-card-large{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center;max-width:600px;margin:0 auto}.profile-image-large{width:120px;height:120px;border-radius:50%;object-fit:cover;margin-bottom:1rem}.profile-card-large h2{margin:0 0 .5rem;color:#333;font-size:1.75rem}.profile-email{color:#666;margin:0 0 2rem;font-size:1rem}.profile-details{border-top:1px solid #f0f0f0;padding-top:1.5rem;text-align:left}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #f5f5f5}.detail-row:last-child{border-bottom:none}.detail-label{font-weight:500;color:#666;font-size:.9rem}.detail-value{color:#333;font-size:.95rem;display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{margin:0;color:#333;font-size:2rem}.primary-button{background:#06c755;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:1rem;transition:background .3s}.primary-button:hover{background:#05b34a}.user-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem}.stat-icon{font-size:1.5rem}.stat-info{display:flex;flex-direction:column;gap:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:#333}.stat-label{font-size:.7rem;color:#666;line-height:1.2}.user-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto;overflow-y:visible}.table-header{padding:1.5rem;border-bottom:1px solid #e0e0e0;display:flex;gap:1rem}.search-input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem}.search-input:focus{outline:none;border-color:#06c755}.filter-select{padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;cursor:pointer}.user-table{width:100%;border-collapse:collapse}.user-table thead{background:#f5f5f5}.user-table th{padding:1rem 1.5rem;text-align:left;font-weight:600;color:#666;font-size:.9rem}.user-table td{padding:1rem 1.5rem;border-top:1px solid #f0f0f0;white-space:nowrap;vertical-align:middle;color:#333}.user-table td>div{white-space:normal}.user-cell{display:flex;align-items:center;gap:1rem}.user-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.user-avatar-placeholder{width:40px;height:40px;border-radius:50%;background:#06c755;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem}.user-display-name{font-weight:500;color:#333}.user-username{font-size:.85rem;color:#999}.roles-cell{display:flex;gap:.5rem;flex-wrap:wrap;white-space:normal}.role-badge-small{background:#e3f2fd;color:#1976d2;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.text-muted{color:#999;font-size:.9rem}.status-badge{padding:.375rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500}.status-active{background:#e8f5e9;color:#2e7d32}.status-inactive{background:#ffebee;color:#c62828}.provider-prefix{display:inline-block;width:1.2rem;height:1.2rem;line-height:1.2rem;text-align:center;border-radius:3px;font-size:.7rem;font-weight:700;margin-right:.5rem;vertical-align:middle}.provider-prefix.provider-woff{background:#1976d2;color:#fff}.provider-prefix.provider-line{background:#06c755;color:#fff}.video-call-section{padding:2rem 0}.section-description{margin-bottom:2rem;color:#666;font-size:1rem}.user-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.user-call-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:1rem;transition:all .3s ease}.user-call-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.user-call-info{flex:1}.user-call-name{font-size:1.1rem;font-weight:600;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.user-call-username{color:#666;font-size:.9rem;margin-bottom:.75rem}.user-call-roles{display:flex;gap:.5rem;flex-wrap:wrap}.call-button{background:#06c755;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .3s ease}.call-button:hover{background:#05b34a;transform:scale(1.02)}.call-icon{font-size:1.2rem}.no-users{text-align:center;padding:3rem;color:#999;font-size:1.1rem}.action-buttons{display:flex;gap:.5rem}.action-button{background:none;border:1px solid #ddd;padding:.5rem;border-radius:6px;cursor:pointer;font-size:1rem;transition:all .3s}.action-button:hover{background:#f5f5f5;border-color:#999}.roles-edit{padding:.5rem;background:#f9f9f9;border-radius:6px;min-width:150px;white-space:normal}.roles-edit label{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;cursor:pointer;color:#333;font-size:.9rem}.roles-edit input[type=checkbox]{cursor:pointer;width:16px;height:16px}.qr-section{margin-bottom:2rem}.qr-card-inline{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-width:600px;margin:0 auto;text-align:center}.qr-description{color:#666;margin:0 0 2rem;font-size:1rem}.qr-code-wrapper{display:flex;justify-content:center;padding:2rem;background:#fff;border-radius:8px;margin-bottom:1.5rem}.qr-code{border:8px solid #fff;box-shadow:0 2px 12px #00000026;border-radius:8px}.qr-url{text-align:center;padding:1rem;background:#f5f5f5;border-radius:8px;margin-bottom:1.5rem;word-break:break-all;font-size:.9rem;color:#555}.qr-url strong{color:#333}.qr-info{padding:1.5rem;background:#e3f2fd;border-radius:8px;border-left:4px solid #1976d2;text-align:left}.qr-info h3{margin:0 0 1rem;color:#1976d2;font-size:1.1rem}.qr-info ol{margin:0;padding-left:1.5rem;color:#555}.qr-info li{margin-bottom:.5rem}.nfc-section{margin-bottom:2rem}.nfc-warning{background:#fff3cd;color:#856404;padding:1rem 1.5rem;border-radius:8px;border-left:4px solid #ffc107;margin-bottom:1.5rem;font-size:.95rem}.nfc-error{background:#f8d7da;color:#721c24;padding:1rem 1.5rem;border-radius:8px;border-left:4px solid #f44336;margin-bottom:1.5rem;font-size:.95rem}.nfc-controls{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-width:600px;margin:0 auto 2rem;text-align:center}.nfc-button{padding:1rem 2rem;border:none;border-radius:8px;font-size:1.1rem;cursor:pointer;transition:all .3s;font-weight:500}.nfc-button-start{background:#06c755;color:#fff}.nfc-button-start:hover:not(:disabled){background:#05b34a;transform:translateY(-2px);box-shadow:0 4px 12px #06c7554d}.nfc-button-start:disabled{background:#ccc;cursor:not-allowed}.nfc-button-stop{background:#f44336;color:#fff;margin-top:1rem}.nfc-button-stop:hover{background:#d32f2f}.nfc-scanning{display:flex;flex-direction:column;align-items:center;gap:1rem}.nfc-scanning p{color:#666;font-size:1rem;margin:0}.nfc-pulse{width:80px;height:80px;border-radius:50%;background:#06c755;position:relative;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #06c755b3}70%{transform:scale(1);box-shadow:0 0 0 20px #06c75500}to{transform:scale(.95);box-shadow:0 0 #06c75500}}.nfc-history{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-width:600px;margin:0 auto 2rem}.nfc-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.nfc-history-header h2{margin:0;color:#333;font-size:1.3rem}.nfc-clear-button{background:#f44336;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background .3s}.nfc-clear-button:hover{background:#d32f2f}.nfc-list{display:flex;flex-direction:column;gap:.75rem}.nfc-item{padding:1rem;background:#f5f5f5;border-radius:8px;border-left:4px solid #06c755;font-family:Courier New,monospace;font-size:.9rem;color:#333}.nfc-info{padding:1.5rem;background:#e3f2fd;border-radius:8px;border-left:4px solid #1976d2;text-align:left;max-width:600px;margin:0 auto}.nfc-info h3{margin:0 0 1rem;color:#1976d2;font-size:1.1rem}.nfc-info ol{margin:0;padding-left:1.5rem;color:#555}.nfc-info li{margin-bottom:.5rem}@media(max-width:768px){.management-nav{padding:1rem}.nav-brand h2{font-size:1.2rem}.user-name{display:none}.management-main{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.user-stats{grid-template-columns:repeat(4,1fr);gap:.5rem}.stat-card{padding:.75rem .5rem}.stat-icon,.stat-value{font-size:1.25rem}.stat-label{font-size:.65rem}.table-header{flex-direction:column}.user-table{font-size:.85rem}.user-table th,.user-table td{padding:.75rem .5rem}.action-buttons{flex-direction:column;gap:.5rem}.action-button{width:100%;padding:.75rem}.user-avatar,.user-avatar-placeholder{width:32px;height:32px;font-size:1rem}}.video-call-container{height:100vh;height:100dvh;width:100vw;background:#1a1a1a;color:#fff;position:fixed;top:0;left:0;overflow:hidden;overscroll-behavior:none;touch-action:none}.video-call-header{position:absolute;top:1rem;left:1rem;right:1rem;z-index:10;display:flex;justify-content:space-between;align-items:center}.video-call-header h2{margin:0;font-size:1.5rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.status-disconnected{background:#dc3545;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem}.status-waiting{background:#ffc107;color:#1a1a1a;padding:.5rem 1rem;border-radius:20px;font-size:.9rem}.status-connected{background:#28a745;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem}.status-container{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.status-recording{background:#dc3545;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;animation:pulse 1.5s ease-in-out infinite}.error-message{position:absolute;top:5rem;left:1rem;right:1rem;z-index:10;background:#dc3545;color:#fff;padding:1rem;border-radius:8px}.video-grid{position:absolute;top:0;left:0;width:100vw;height:100vh;height:100dvh}.video-grid.full-screen-mode{display:block}.video-grid.waiting-mode{display:grid;grid-template-columns:50% 50%;gap:0;padding:0;align-items:stretch;justify-items:stretch}.video-box.remote{position:absolute;top:0;left:0;width:100%;height:100%;background:#000;border-radius:0;overflow:hidden}.video-box.local{position:absolute;bottom:5rem;right:1rem;width:240px;height:135px;background:#000;border-radius:12px;overflow:hidden;border:2px solid #fff;box-shadow:0 4px 12px #00000080;z-index:10;transition:all .3s ease}.video-box.local:hover{transform:scale(1.05)}.video-box.waiting-local,.video-box.waiting-remote{position:relative;background:#000;border-radius:0;overflow:hidden;width:100%;height:100%;border:none;box-shadow:none}.video-box.waiting-remote{background:#1a1a1a;display:flex;align-items:center;justify-content:center;border-left:2px solid #333}.video-box video{width:100%;height:100%;object-fit:contain;background:#000}.video-label{position:absolute;bottom:.5rem;left:.5rem;background:#000000b3;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.8rem}.call-controls{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);z-index:10;display:flex;justify-content:center;gap:1rem}.end-call-button{background:#dc3545;color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #00000080;touch-action:auto}.end-call-button:hover{background:#c82333;transform:scale(1.05)}@media(max-width:768px){.video-box.local{width:120px;height:68px;bottom:4rem;right:.5rem}.video-grid.waiting-mode{grid-template-columns:1fr;grid-template-rows:50% 50%;padding:0;gap:0}.video-box.waiting-remote{border-left:none;border-top:2px solid #333}.video-call-header h2{font-size:1.2rem}.end-call-button{padding:.75rem 1.5rem;font-size:1rem}}#root{width:100%;height:100%}.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)}.logo.cloudflare:hover{filter:drop-shadow(0 0 2em #f6821faa)}@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}
