.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#06c,#0c6);padding:var(--spacing-md)}.login-card{background:var(--white);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-header h1{color:var(--primary);font-size:var(--font-size-xxl);margin-bottom:var(--spacing-sm)}.login-header p{color:var(--gray);font-size:var(--font-size-md);margin:0}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group label{font-weight:600;color:var(--dark);font-size:var(--font-size-md)}.form-group input{padding:var(--spacing-md);border:2px solid var(--light);border-radius:var(--border-radius-md);font-size:var(--font-size-md);transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0066cc1a}.form-group input::placeholder{color:var(--gray)}.form-group input:disabled{background-color:var(--light);cursor:not-allowed}.btn-login{background-color:var(--primary);color:var(--white);padding:var(--spacing-lg) var(--spacing-md);font-size:var(--font-size-lg);font-weight:700;border-radius:var(--border-radius-lg);border:none;cursor:pointer;transition:all .3s ease;margin-top:var(--spacing-md)}.btn-login:hover:not(:disabled){background-color:#0052a3;transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--light)}.login-footer p{color:var(--gray);font-size:var(--font-size-sm);margin:0}@media(max-width:480px){.login-card{padding:var(--spacing-lg)}.login-header h1{font-size:var(--font-size-xl)}.btn-login{padding:var(--spacing-md) var(--spacing-md);font-size:var(--font-size-md)}}.home-container{display:flex;flex-direction:column;height:100vh;background-color:var(--light);overflow:hidden}.home-header{padding:var(--spacing-lg);background:linear-gradient(135deg,#06c,#0c6);color:var(--white);text-align:center}.home-header h1{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-xxl);color:var(--white)}.home-header p{margin:0;font-size:var(--font-size-md);opacity:.9}.home-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-lg);overflow-y:auto}.success-message{background-color:#e6ffe6;color:#060;padding:var(--spacing-md);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);border-left:4px solid var(--secondary);animation:slideUp .3s ease}.home-card{background:var(--white);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-md);text-align:center}.home-card h2{margin-top:0;color:var(--primary)}.home-card p{color:var(--gray);margin-bottom:var(--spacing-lg)}.qrcode-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);width:200px;height:200px;margin:0 auto;background:linear-gradient(135deg,#06c,#0052a3);color:var(--white);border:none;border-radius:var(--border-radius-xl);cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md)}.qrcode-button:hover{transform:scale(1.05);box-shadow:var(--shadow-lg)}.qrcode-button:active{transform:scale(.98)}.qrcode-icon{font-size:64px;display:block}.qrcode-text{font-size:var(--font-size-md);font-weight:600;text-align:center}.active-cleanings{background:var(--white);border-radius:var(--border-radius-xl);padding:var(--spacing-lg);box-shadow:var(--shadow-md)}.active-cleanings h3{margin-top:0;color:var(--primary);margin-bottom:var(--spacing-lg)}.cleaning-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background-color:var(--light);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-md);gap:var(--spacing-md)}.cleaning-item:last-child{margin-bottom:0}.cleaning-item-info{flex:1}.cleaning-room{font-weight:600;color:var(--dark);margin:0 0 var(--spacing-xs) 0}.cleaning-duration{font-size:var(--font-size-sm);color:var(--gray);margin:0}.btn-resume{background-color:var(--secondary);color:var(--white);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-md);border:none;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-resume:hover{background-color:#0a5;transform:translateY(-2px)}.home-footer{padding:var(--spacing-md);border-top:1px solid var(--light);background-color:var(--white)}@media(max-width:480px){.home-content{padding:var(--spacing-md)}.qrcode-button{width:160px;height:160px}.qrcode-icon{font-size:48px}.home-header h1{font-size:var(--font-size-xl)}}.scanner-container{display:flex;flex-direction:column;height:100vh;background-color:var(--white);overflow:hidden}.scanner-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--white);border-bottom:1px solid var(--light)}.scanner-header h1{flex:1;margin:0;font-size:var(--font-size-lg);color:var(--dark)}.scanner-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-lg);gap:var(--spacing-lg);overflow-y:auto}.scanner-box{width:100%;max-width:400px;aspect-ratio:1;border-radius:var(--border-radius-xl);overflow:hidden;border:3px solid var(--primary);box-shadow:var(--shadow-md);background-color:var(--light)}.scanner-box canvas,.scanner-box video{width:100%;height:100%;object-fit:cover}.scanner-info{text-align:center;margin-bottom:var(--spacing-lg)}.scanner-info h2{color:var(--dark);margin-bottom:var(--spacing-sm)}.scanner-info p{color:var(--gray);margin:0;font-size:var(--font-size-md)}.error-message{background-color:#ffe6e6;color:var(--danger);padding:var(--spacing-md);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);border-left:4px solid var(--danger);width:100%;max-width:400px}.loading-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:var(--font-size-lg);font-weight:600;z-index:1000}.scanner-footer{padding:var(--spacing-md);border-top:1px solid var(--light);background-color:var(--white)}@media(max-width:480px){.scanner-content{padding:var(--spacing-md)}.scanner-box{max-width:100%}.scanner-header h1{font-size:var(--font-size-md)}}.room-container{display:flex;flex-direction:column;height:100vh;background-color:var(--light);overflow:hidden}.room-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--white);border-bottom:1px solid var(--light)}.room-header h1{flex:1;margin:0;font-size:var(--font-size-lg);color:var(--dark)}.room-content{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);overflow-y:auto}.room-card{background:var(--white);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);width:100%;max-width:400px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:var(--spacing-lg)}.room-info{display:flex;flex-direction:column;gap:var(--spacing-lg)}.warning-message{background-color:#fff3cd;color:#856404;padding:var(--spacing-md);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);border-left:4px solid var(--warning)}.btn-play{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#0c6,#0a5);color:var(--white);font-size:var(--font-size-xxxl);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;margin:var(--spacing-lg) auto 0;box-shadow:var(--shadow-lg);transition:all .3s ease}.btn-play:hover:not(:disabled){transform:scale(1.1);box-shadow:0 12px 24px #0c66}.btn-play:active:not(:disabled){transform:scale(.95)}.btn-play:disabled{opacity:.6;cursor:not-allowed}.room-footer{padding:var(--spacing-md);text-align:center;color:var(--gray);font-size:var(--font-size-sm);background-color:var(--white);border-top:1px solid var(--light)}.room-footer p{margin:0}@media(max-width:480px){.room-card{padding:var(--spacing-lg)}.room-number{font-size:var(--font-size-xxl)}.btn-play{width:100px;height:100px;font-size:var(--font-size-xxl)}}.cleaning-container{display:flex;flex-direction:column;height:100vh;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);overflow:hidden}.cleaning-header{padding:var(--spacing-lg);background-color:var(--white);border-bottom:1px solid var(--light);text-align:center}.cleaning-header h1{margin:0;font-size:var(--font-size-lg);color:var(--primary)}.cleaning-content{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);overflow-y:auto}.cleaning-card{background:var(--white);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:var(--spacing-xl)}.cleaning-info{display:flex;flex-direction:column;gap:var(--spacing-lg)}.info-value{font-size:var(--font-size-lg);color:var(--dark);margin:0;font-weight:500}.room-number{font-size:var(--font-size-xxxl);color:var(--primary);margin:0;font-weight:700;text-align:center}.timer-section{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);background:linear-gradient(135deg,#fff5e6,#fff9f0);border-radius:var(--border-radius-lg);border:2px solid var(--warning)}.timer-display{font-size:64px;font-weight:700;color:var(--warning);font-family:Courier New,monospace;letter-spacing:2px;line-height:1}.timer-label{font-size:var(--font-size-md);color:var(--gray);margin:0;font-weight:600}.error-message{background-color:#ffe6e6;color:var(--danger);padding:var(--spacing-md);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);border-left:4px solid var(--danger)}.btn-stop{background:linear-gradient(135deg,#f33,#c00);color:var(--white);padding:var(--spacing-lg) var(--spacing-md);border-radius:var(--border-radius-lg);border:none;font-size:var(--font-size-lg);font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md)}.btn-stop:hover:not(:disabled){background:linear-gradient(135deg,#f55,#d11);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-stop:active:not(:disabled){transform:translateY(0)}.btn-stop:disabled{opacity:.7;cursor:not-allowed}.btn-primary{background-color:var(--primary);color:var(--white);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--border-radius-lg);border:none;font-size:var(--font-size-md);font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary:hover{background-color:#0052a3;transform:translateY(-2px);box-shadow:var(--shadow-md)}@media(max-width:480px){.cleaning-card{padding:var(--spacing-lg)}.timer-display{font-size:48px}.room-number{font-size:var(--font-size-xxl)}.btn-stop{padding:var(--spacing-md) var(--spacing-md);font-size:var(--font-size-md)}}.profile-container{display:flex;flex-direction:column;height:100vh;background-color:var(--light);overflow:hidden}.profile-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--white);border-bottom:1px solid var(--light)}.profile-header h1{flex:1;margin:0;font-size:var(--font-size-lg);color:var(--dark)}.btn-back{background:none;border:none;font-size:var(--font-size-xxl);cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--primary);transition:transform .2s ease}.btn-back:hover{transform:scale(1.1)}.profile-content{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);overflow-y:auto}.profile-card{background:var(--white);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);width:100%;max-width:400px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:var(--spacing-xl);align-items:center}.profile-avatar{font-size:80px;display:flex;align-items:center;justify-content:center;width:120px;height:120px;background-color:var(--light);border-radius:50%}.profile-info{width:100%;display:flex;flex-direction:column;gap:var(--spacing-lg)}.info-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.info-group label{font-size:var(--font-size-sm);color:var(--gray);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:var(--font-size-md);color:var(--dark);margin:0;font-weight:500;padding:var(--spacing-sm);background-color:var(--light);border-radius:var(--border-radius-md)}.btn-logout{background-color:var(--danger);color:var(--white);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--border-radius-lg);border:none;font-size:var(--font-size-md);font-weight:600;cursor:pointer;transition:all .3s ease;width:100%}.btn-logout:hover{background-color:#c00;transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-logout:active{transform:translateY(0)}.profile-footer{padding:var(--spacing-md);border-top:1px solid var(--light);background-color:var(--white)}.nav-icons{display:flex;justify-content:space-around;align-items:center}.nav-icon{background:none;border:none;font-size:var(--font-size-xxl);cursor:pointer;padding:var(--spacing-md);opacity:.6;transition:opacity .3s ease}.nav-icon:hover{opacity:1}.nav-icon.active{opacity:1;color:var(--primary)}@media(max-width:480px){.profile-card{padding:var(--spacing-lg)}.profile-avatar{font-size:60px;width:100px;height:100px}.btn-logout{padding:var(--spacing-md) var(--spacing-md)}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #0066cc;--secondary: #00cc66;--danger: #ff3333;--warning: #ffaa00;--dark: #1a1a1a;--light: #f5f5f5;--gray: #999999;--white: #ffffff;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-size-sm: 12px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-xxl: 28px;--font-size-xxxl: 48px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 8px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .2);--border-radius-sm: 4px;--border-radius-md: 8px;--border-radius-lg: 16px;--border-radius-xl: 20px}body{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;background-color:var(--white);color:var(--dark);font-size:var(--font-size-md);line-height:1.5}html,body,#root{width:100%;height:100%}h1{font-size:var(--font-size-xxxl);font-weight:700;margin-bottom:var(--spacing-lg)}h2{font-size:var(--font-size-xxl);font-weight:700;margin-bottom:var(--spacing-md)}h3{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--spacing-md)}p{margin-bottom:var(--spacing-md)}button{font-family:inherit;cursor:pointer;border:none;border-radius:var(--border-radius-lg);padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-lg);font-weight:600;transition:all .3s ease}button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}button:active{transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed}input,textarea{font-family:inherit;font-size:var(--font-size-md);padding:var(--spacing-md);border:2px solid var(--light);border-radius:var(--border-radius-md);transition:border-color .3s ease}input:focus,textarea:focus{outline:none;border-color:var(--primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--light)}::-webkit-scrollbar-thumb{background:var(--gray);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--dark)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.fade-in{animation:fadeIn .3s ease}.slide-up{animation:slideUp .3s ease}.pulse{animation:pulse 2s ease-in-out infinite}@media(max-width:768px){:root{--font-size-xxxl: 32px;--font-size-xxl: 24px}h1{font-size:var(--font-size-xxl)}button{padding:var(--spacing-md) var(--spacing-md);font-size:var(--font-size-md)}}
