*{box-sizing:border-box;padding:0;margin:0}body,html{max-width:100vw;overflow-x:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:#f8f9fa;min-height:100vh;display:flex;align-items:center;justify-content:center}.app-wrapper{flex-direction:column;gap:2rem}.app-wrapper,.logo-container{display:flex;align-items:center;width:100%;max-width:600px}.logo-container{justify-content:center;margin-bottom:0;background:#f8f9fa;border-radius:30px;padding:2rem 3rem;box-shadow:0 8px 25px rgba(248,249,250,.2);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid hsla(0,0%,100%,.1)}.logo{max-width:600px;height:auto;max-height:240px;object-fit:contain;filter:drop-shadow(0 12px 24px rgba(0,0,0,.5))}.container{background:linear-gradient(135deg,#1e3a8a,#3b82f6);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:30px;padding:2rem;box-shadow:0 8px 25px rgba(30,58,138,.3);text-align:center;max-width:500px;width:90%;border:1px solid rgba(30,64,175,.3)}.title{color:#fff;font-size:2.5rem;font-weight:700;margin-bottom:1rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.subtitle{color:hsla(0,0%,100%,.9);font-size:1.1rem;margin-bottom:2rem}.qr-container{background:hsla(0,0%,100%,.1);border-radius:15px;padding:2rem;margin:2rem 0;box-shadow:0 10px 30px rgba(0,0,0,.2);border:2px solid hsla(0,0%,100%,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.qr-image{max-width:100%;height:auto;border-radius:10px;box-shadow:0 5px 15px rgba(0,0,0,.1)}.loading{display:flex;flex-direction:column;align-items:center;gap:1rem;color:hsla(0,0%,100%,.9)}.spinner{width:40px;height:40px;border:4px solid hsla(0,0%,100%,.3);border-top-color:hsla(0,0%,100%,.9);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.button{background:hsla(0,0%,100%,.2);color:#fff;border:2px solid hsla(0,0%,100%,.3);padding:12px 24px;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 5px 15px rgba(0,0,0,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.button:hover{transform:translateY(-2px);background:hsla(0,0%,100%,.3);box-shadow:0 8px 25px rgba(0,0,0,.3)}.button:active{transform:translateY(0)}.error{color:hsla(0,0%,100%,.9);background:rgba(239,68,68,.2);border:1px solid rgba(239,68,68,.4);padding:1rem}.error,.session-input{border-radius:10px;margin:1rem 0}.session-input{background:hsla(0,0%,100%,.1);padding:1.5rem;border-left:4px solid hsla(0,0%,100%,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.input-group{display:flex;flex-direction:column;gap:1rem}.input-group label{color:hsla(0,0%,100%,.9);font-weight:600;font-size:1rem}.input-group input{padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:all .3s ease;background:#fff}.input-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.placeholder{color:hsla(0,0%,100%,.9);font-style:italic;padding:2rem}.session-working{text-align:center;padding:2rem;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border-radius:15px;box-shadow:0 10px 30px rgba(76,175,80,.3)}.status-icon{font-size:3rem;margin-bottom:1rem}.session-working h3{color:#fff;margin-bottom:1rem;font-size:1.5rem}.session-working p{color:hsla(0,0%,100%,.9);margin-bottom:1rem}.user-info{background:hsla(0,0%,100%,.1);border-radius:10px;padding:1rem;margin-top:1rem}.user-info p{margin:.5rem 0;font-size:.9rem}.session-stopped{background:linear-gradient(135deg,#ff9800,#f57c00);box-shadow:0 10px 30px rgba(255,152,0,.3)}.session-starting,.session-stopped{text-align:center;padding:2rem;color:#fff;border-radius:15px}.session-starting{background:linear-gradient(135deg,#2196f3,#1976d2);box-shadow:0 10px 30px rgba(33,150,243,.3)}.session-failed{background:linear-gradient(135deg,#f44336,#d32f2f);box-shadow:0 10px 30px rgba(244,67,54,.3)}.session-failed,.session-unknown{text-align:center;padding:2rem;color:#fff;border-radius:15px}.session-unknown{background:linear-gradient(135deg,#9e9e9e,#757575);box-shadow:0 10px 30px hsla(0,0%,62%,.3)}.action-buttons{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.button-start{background:rgba(76,175,80,.3)!important;border-color:rgba(76,175,80,.5)!important}.button-restart{background:rgba(255,152,0,.3)!important;border-color:rgba(255,152,0,.5)!important}.button-stop{background:rgba(239,68,68,.3)!important;border-color:rgba(239,68,68,.5)!important}.button-logout{background:rgba(6,182,212,.3)!important;border-color:rgba(6,182,212,.5)!important}.spinning{animation:spin 2s linear infinite}.loading-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}.loading-dots span{width:8px;height:8px;background:hsla(0,0%,100%,.7);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f8f9fa;padding:1rem}.login-card{background:#fff;border-radius:20px;padding:2.5rem;box-shadow:0 10px 30px rgba(0,0,0,.1);width:100%;max-width:400px;text-align:center}.login-title{font-size:2rem;font-weight:700;color:#1e3a8a;margin-bottom:.5rem}.login-subtitle{color:#6b7280;margin-bottom:2rem;font-size:1rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{text-align:left}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151}.form-group input{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:10px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#3b82f6}.error-message{background:#fef2f2;color:#dc2626;padding:.75rem;border-radius:10px;border:1px solid #fecaca;font-size:.9rem}.login-button{background:linear-gradient(135deg,#3b82f6,#1e3a8a);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px rgba(59,130,246,.4)}.login-button:disabled{opacity:.7;cursor:not-allowed}.spinner-small{width:16px;height:16px;border:2px solid transparent;border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.login-footer{margin-top:1.5rem;color:#6b7280;font-size:.9rem}.toggle-button{background:none;border:none;color:#3b82f6;cursor:pointer;text-decoration:underline;font-size:inherit;margin-left:.25rem}.toggle-button:hover{color:#1e3a8a}.navbar{justify-content:flex-end;width:100%;max-width:600px;padding:1rem;background:linear-gradient(135deg,rgba(30,58,138,.8),rgba(59,130,246,.6));-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:15px;border:2px solid rgba(59,130,246,.3);margin-bottom:1rem;position:relative;box-shadow:0 8px 25px rgba(30,58,138,.2)}.navbar,.navbar-menu,.navbar-user{display:flex;align-items:center}.navbar-user{gap:1rem;color:#fff}.logout-button,.welcome-text{color:#fff;font-size:.9rem}.logout-button{background:linear-gradient(135deg,#ef4444,#dc2626);border:2px solid #b91c1c;padding:.75rem 1.5rem;border-radius:12px;cursor:pointer;font-weight:600;transition:all .3s ease;box-shadow:0 4px 12px rgba(239,68,68,.3);text-shadow:0 1px 2px rgba(0,0,0,.2)}.logout-button:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 6px 20px rgba(239,68,68,.4);border-color:#991b1b}.logout-button:active{transform:translateY(0);box-shadow:0 2px 8px rgba(239,68,68,.3)}.mobile-menu{display:none}.mobile-user-info{display:flex;flex-direction:column;gap:.75rem;align-items:center}.mobile-user-info .welcome-text{color:#fff;text-align:center;font-size:.85rem;line-height:1.2}.mobile-logout{width:100%;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:2px solid #b91c1c;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.2);box-shadow:0 4px 12px rgba(239,68,68,.3)}.mobile-logout:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 6px 20px rgba(239,68,68,.4);border-color:#991b1b}@media (max-width:768px){.desktop-menu{display:none}.mobile-menu{display:flex}.navbar{padding:1rem;justify-content:center}}@media (min-width:769px){.mobile-menu{display:none}.desktop-menu{display:flex}}@media (max-width:480px){.navbar{padding:.75rem}.mobile-user-info{gap:.5rem}.mobile-user-info .welcome-text{font-size:.8rem}.mobile-logout{padding:.5rem 1rem;font-size:.85rem}}.session-info{background:hsla(0,0%,100%,.1);border-radius:10px;padding:1.5rem;margin:1rem 0;border-left:4px solid rgba(76,175,80,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.session-display{display:flex;flex-direction:column;gap:.5rem}.session-display label{color:hsla(0,0%,100%,.9);font-weight:600;font-size:1rem}.session-value{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.session-value strong{color:#fff;font-size:1.1rem;background:rgba(76,175,80,.2);padding:.5rem 1rem;border-radius:8px;border:1px solid rgba(76,175,80,.3)}