.notification-container{position:fixed;top:20px;right:20px;z-index:9999;max-width:400px;display:flex;flex-direction:column;gap:10px}.notification{display:flex;align-items:center;padding:16px;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}.notification-success{background-color:#d4edda;border-left:4px solid #28a745;color:#155724}.notification-error{background-color:#f8d7da;border-left:4px solid #dc3545;color:#721c24}.notification-warning{background-color:#fff3cd;border-left:4px solid #ffc107;color:#856404}.notification-info{background-color:#d1ecf1;border-left:4px solid #17a2b8;color:#0c5460}.notification-content{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px}.notification-message{flex:1;font-size:14px;font-weight:500;line-height:1.4}.notification-close{background:none;border:none;font-size:24px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:.6;transition:opacity .2s}.notification-close:hover{opacity:1}@media(max-width:480px){.notification-container{max-width:calc(100% - 40px);top:10px;right:10px;left:10px}.notification{padding:12px;font-size:13px}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:var(--spacing-lg)}.login-card{background-color:var(--background-secondary);padding:var(--spacing-xl);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;text-align:center;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{margin-bottom:var(--spacing-lg)}.login-header h1{font-size:var(--font-size-xxl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.login-header p{font-size:var(--font-size-lg);color:var(--text-secondary)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{text-align:left}.form-group label{display:block;font-size:var(--font-size-md);font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.form-group input{width:100%;padding:14px;border:1px solid #e0e0e0;border-radius:var(--border-radius-md);font-size:var(--font-size-lg);transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #007aff33}.btn-login{background-color:var(--primary);color:var(--white);padding:16px;border-radius:var(--border-radius-md);font-size:var(--font-size-lg);font-weight:600;transition:transform .2s,background-color .2s;margin-top:var(--spacing-md)}.btn-login:hover{background-color:#005bb5}.btn-login:active{transform:scale(.98)}.btn-login:disabled{background-color:var(--gray);cursor:not-allowed}.login-footer{margin-top:var(--spacing-xl);font-size:var(--font-size-sm);color:var(--text-secondary)}.home-container{display:flex;flex-direction:column;min-height:100vh;background-color:var(--background-primary)}.home-header{background-color:var(--background-secondary);padding:var(--spacing-lg);text-align:center;border-bottom:1px solid #e0e0e0}.home-header h1{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.home-header p{font-size:var(--font-size-md);color:var(--text-secondary)}.home-content{flex:1;padding:var(--spacing-lg);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.home-card{background-color:var(--background-secondary);padding:var(--spacing-xl);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:500px;text-align:center}.home-card h2{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--spacing-sm)}.home-card p{font-size:var(--font-size-md);color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.qrcode-button{background-color:var(--primary);color:var(--white);padding:var(--spacing-lg);border-radius:var(--border-radius-lg);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);width:100%;transition:transform .2s,background-color .2s}.qrcode-button:hover{background-color:#005bb5}.qrcode-button:active{transform:scale(.98)}.qrcode-icon{font-size:48px}.qrcode-text{font-size:var(--font-size-lg);font-weight:600}.active-cleanings{width:100%;max-width:500px}.active-cleanings h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-md);text-align:center}.cleaning-item{background-color:var(--background-secondary);padding:var(--spacing-md);border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);box-shadow:var(--shadow-sm)}.cleaning-item-info{display:flex;flex-direction:column}.cleaning-room{font-size:var(--font-size-md);font-weight:600}.cleaning-duration{font-size:var(--font-size-sm);color:var(--text-secondary)}.btn-resume{background-color:var(--secondary);color:var(--white);padding:8px 16px;border-radius:var(--border-radius-sm);font-weight:600}.home-footer{background-color:var(--background-secondary);padding:var(--spacing-md);border-top:1px solid #e0e0e0}.nav-icons{display:flex;justify-content:space-around}.nav-icon{font-size:24px;color:var(--gray);transition:color .2s}.nav-icon.active,.nav-icon:hover{color:var(--primary)}.qrcode-scanner-container{position:relative;width:100%;height:100%;background:#000;overflow:hidden;display:flex;align-items:center;justify-content:center}.qrcode-video{width:100%;height:100%;object-fit:cover}.qrcode-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;background:#0000004d}.qrcode-frame{position:relative;width:250px;height:250px;border:2px solid #0066cc;border-radius:12px;background:#0066cc1a}.qrcode-corner{position:absolute;width:30px;height:30px;border:3px solid #0066cc}.qrcode-corner-tl{top:-5px;left:-5px;border-right:none;border-bottom:none;border-radius:8px 0 0}.qrcode-corner-tr{top:-5px;right:-5px;border-left:none;border-bottom:none;border-radius:0 8px 0 0}.qrcode-corner-bl{bottom:-5px;left:-5px;border-right:none;border-top:none;border-radius:0 0 0 8px}.qrcode-corner-br{bottom:-5px;right:-5px;border-left:none;border-top:none;border-radius:0 0 8px}.qrcode-instruction{position:absolute;bottom:40px;color:#fff;font-size:16px;font-weight:600;text-align:center;background:#0009;padding:12px 24px;border-radius:8px;margin:0}.qrcode-error{position:absolute;top:0;left:0;width:100%;height:100%;background:#dc3545f2;display:flex;align-items:center;justify-content:center;flex-direction:column;color:#fff;padding:20px;text-align:center;z-index:100}.qrcode-error p{margin:0 0 10px;font-size:18px;font-weight:600}.qrcode-error small{font-size:12px;opacity:.9;line-height:1.5}.qrcode-success{position:absolute;top:0;left:0;width:100%;height:100%;background:#28a745f2;display:flex;align-items:center;justify-content:center;flex-direction:column;color:#fff;padding:20px;text-align:center;z-index:100}.qrcode-success-title{font-size:24px;font-weight:700;margin:0 0 20px}.qrcode-success-code{font-size:14px;background:#fff3;padding:12px 16px;border-radius:8px;margin:0 0 20px;word-break:break-all;font-family:Courier New,monospace}.qrcode-retry-btn{background:#fff;color:#28a745;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.qrcode-retry-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #0003}.qrcode-retry-btn:active{transform:scale(.98)}.qrcode-loading{position:absolute;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;flex-direction:column;color:#fff;z-index:100}.qrcode-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(360deg)}}.qrcode-loading p{font-size:16px;margin:0}@media(max-width:768px){.qrcode-frame{width:200px;height:200px}.qrcode-instruction{font-size:14px;padding:10px 20px;bottom:30px}.qrcode-success-title{font-size:20px}.qrcode-success-code{font-size:12px;padding:10px 14px}}.camera-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.camera-modal{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000004d;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.camera-modal-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#06c,#0c6);color:#fff;border-radius:16px 16px 0 0}.camera-modal-header h2{margin:0;font-size:20px;font-weight:700}.camera-modal-close{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease}.camera-modal-close:hover{background:#fff3}.xiaomi-badge{background:#ffffff4d;color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;margin-left:auto}.camera-modal-content{flex:1;padding:40px 30px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}.camera-modal-icon{font-size:80px;margin-bottom:20px;display:block}.camera-modal-title{font-size:24px;font-weight:700;color:#06c;margin:0 0 16px}.camera-modal-description{font-size:16px;color:#555;line-height:1.6;margin:0 0 16px;white-space:pre-wrap;text-align:left}.camera-modal-instruction{font-size:14px;color:#06c;font-weight:600;margin:0;padding:12px 16px;background:#e6f2ff;border-radius:8px;border-left:4px solid #0066cc}.camera-modal-progress{padding:20px 30px;border-top:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between;gap:16px}.progress-dots{display:flex;gap:8px;flex:1}.progress-dot{width:10px;height:10px;border-radius:50%;background:#e0e0e0;transition:all .3s ease;cursor:pointer}.progress-dot.active{background:#06c;width:30px;border-radius:5px}.progress-dot.completed{background:#0c6}.progress-text{font-size:12px;color:#999;white-space:nowrap}.camera-modal-buttons{padding:20px 30px;border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end}.camera-modal-btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;flex:1}.camera-modal-btn-primary{background:#06c;color:#fff}.camera-modal-btn-primary:hover{background:#0052a3;transform:translateY(-2px);box-shadow:0 4px 12px #0066cc4d}.camera-modal-btn-primary:active{transform:translateY(0)}.camera-modal-btn-secondary{background:#f0f0f0;color:#333}.camera-modal-btn-secondary:hover{background:#e0e0e0}.camera-modal-btn-success{background:#0c6;color:#fff;flex:1}.camera-modal-btn-success:hover{background:#00a852;transform:translateY(-2px);box-shadow:0 4px 12px #00cc664d}.camera-modal-btn-success:active{transform:translateY(0)}.camera-modal-skip{background:none;border:none;color:#999;font-size:12px;cursor:pointer;padding:10px;text-decoration:underline;transition:color .2s ease}.camera-modal-skip:hover{color:#666}@media(max-width:480px){.camera-modal{max-width:100%;border-radius:16px 16px 0 0}.camera-modal-content{padding:30px 20px}.camera-modal-icon{font-size:60px;margin-bottom:16px}.camera-modal-title{font-size:20px}.camera-modal-description{font-size:14px}.camera-modal-buttons{padding:16px 20px;flex-direction:column}.camera-modal-btn{width:100%}.progress-text{display:none}}.scanner-container{display:flex;flex-direction:column;min-height:100vh;background-color:var(--dark);color:var(--white)}.scanner-header{display:flex;align-items:center;padding:var(--spacing-lg);background-color:#0003}.scanner-header h1{font-size:var(--font-size-lg);font-weight:600;margin-left:var(--spacing-md)}.scanner-content{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--spacing-lg);gap:var(--spacing-lg)}.scanner-box{width:100%;max-width:400px;aspect-ratio:1 / 1;background-color:#00000080;border-radius:var(--border-radius-lg);overflow:hidden;position:relative}.scanner-info{text-align:center}.scanner-info h2{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--spacing-sm)}.scanner-info p{font-size:var(--font-size-md);color:var(--gray)}.scanner-footer{background-color:#0003;padding:var(--spacing-md)}.room-container{display:flex;flex-direction:column;min-height:100vh;background-color:var(--background-primary)}.room-header{display:flex;align-items:center;padding:var(--spacing-lg);background-color:var(--background-secondary);border-bottom:1px solid #e0e0e0}.btn-back{font-size:24px;color:var(--primary);margin-right:var(--spacing-md)}.room-header h1{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.room-content{flex:1;padding:var(--spacing-lg);display:flex;justify-content:center;align-items:center}.room-card{background-color:var(--background-secondary);padding:var(--spacing-xl);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:400px;text-align:center}.room-info{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.info-group{text-align:left}.info-group label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600}.info-value{font-size:var(--font-size-lg);font-weight:500}.room-number{font-size:var(--font-size-xxl);font-weight:700;color:var(--primary)}.warning-message{color:var(--warning);background-color:#ff95001a;padding:var(--spacing-md);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-lg);font-weight:500}.btn-play{background-color:var(--secondary);color:var(--white);width:80px;height:80px;border-radius:50%;font-size:48px;display:flex;align-items:center;justify-content:center;margin:0 auto;transition:transform .2s,background-color .2s}.btn-play:hover{background-color:#2ca048}.btn-play:active{transform:scale(.95)}.btn-play:disabled{background-color:var(--gray);cursor:not-allowed}.room-footer{padding:var(--spacing-lg);text-align:center;color:var(--text-secondary)}.cleaning-container{display:flex;flex-direction:column;min-height:100vh;background-color:var(--background-primary)}.cleaning-header{padding:var(--spacing-lg);background-color:var(--background-secondary);border-bottom:1px solid #e0e0e0;text-align:center}.cleaning-header h1{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.cleaning-content{flex:1;padding:var(--spacing-lg);display:flex;justify-content:center;align-items:center}.cleaning-card{background-color:var(--background-secondary);padding:var(--spacing-xl);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:400px;text-align:center}.cleaning-info{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.timer-section{margin-bottom:var(--spacing-lg)}.timer-display{font-size:64px;font-weight:700;color:var(--primary)}.timer-label{font-size:var(--font-size-md);color:var(--text-secondary)}.btn-stop{background-color:var(--danger);color:var(--white);padding:16px;border-radius:var(--border-radius-md);font-size:var(--font-size-lg);font-weight:600;width:100%;transition:transform .2s,background-color .2s}.btn-stop:hover{background-color:#d93025}.btn-stop:active{transform:scale(.98)}.btn-stop:disabled{background-color:var(--gray);cursor:not-allowed}.profile-container{display:flex;flex-direction:column;min-height:100vh;background-color:var(--background-primary)}.profile-header{display:flex;align-items:center;padding:var(--spacing-lg);background-color:var(--background-secondary);border-bottom:1px solid #e0e0e0}.profile-header h1{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin-left:var(--spacing-md)}.profile-content{flex:1;padding:var(--spacing-lg);display:flex;justify-content:center;align-items:center}.profile-card{background-color:var(--background-secondary);padding:var(--spacing-xl);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:400px;text-align:center}.profile-avatar{font-size:64px;margin-bottom:var(--spacing-lg)}.profile-info{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);text-align:left}.btn-logout{background-color:var(--danger);color:var(--white);padding:16px;border-radius:var(--border-radius-md);font-size:var(--font-size-lg);font-weight:600;width:100%;transition:transform .2s,background-color .2s}.btn-logout:hover{background-color:#d93025}.btn-logout:active{transform:scale(.98)}.profile-footer{background-color:var(--background-secondary);padding:var(--spacing-md);border-top:1px solid #e0e0e0}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary: #007aff;--secondary: #34c759;--danger: #ff3b30;--warning: #ff9500;--dark: #1c1c1e;--light: #f2f2f7;--gray: #8e8e93;--white: #ffffff;--text-primary: #1c1c1e;--text-secondary: #636366;--text-light: #ffffff;--background-primary: #f2f2f7;--background-secondary: #ffffff;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-size-sm: 13px;--font-size-md: 15px;--font-size-lg: 17px;--font-size-xl: 22px;--font-size-xxl: 28px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .1);--border-radius-sm: 8px;--border-radius-md: 12px;--border-radius-lg: 16px}body{font-family:var(--font-family);background-color:var(--background-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:var(--font-family);cursor:pointer;border:none;background:none}input{font-family:var(--font-family)}.container{max-width:800px;margin:0 auto;padding:var(--spacing-lg)}.btn-primary{background-color:var(--primary);color:var(--white);padding:12px 24px;border-radius:var(--border-radius-md);font-size:var(--font-size-lg);font-weight:600;transition:transform .2s,background-color .2s}.btn-primary:hover{background-color:#005bb5}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{background-color:var(--gray);cursor:not-allowed}.error-message{color:var(--danger);background-color:#ff3b301a;padding:var(--spacing-md);border-radius:var(--border-radius-md);text-align:center;margin-bottom:var(--spacing-md);font-weight:500}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;color:var(--white);font-size:var(--font-size-xl)}
