*{margin:0;padding:0;box-sizing:border-box}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:#f8f9fa;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{cursor:pointer;font-family:inherit}input{font-family:inherit}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4361ee,#3a0ca3);padding:1rem}.login-form{width:100%;max-width:400px;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003}.login-title{font-size:1.5rem;font-weight:600;color:#333;margin-bottom:1.5rem;text-align:center}.input-field{margin-bottom:1.5rem}.input-field label{display:block;margin-bottom:.5rem;font-size:.9rem;color:#666}.input-field input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;transition:all .3s ease}.input-field input:focus{outline:none;border-color:#4361ee;box-shadow:0 0 0 3px #4361ee1a}.btn-login{width:100%;padding:.75rem;font-size:1rem;font-weight:500;color:#fff;background:linear-gradient(135deg,#4361ee,#3a0ca3);border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;margin-top:1rem}.btn-login:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4361ee4d}.btn-login:active{transform:translateY(0)}.btn-login:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.error-message{margin-top:1rem;padding:1rem;border-radius:8px;background-color:#ffebee;color:#c62828;font-size:.9rem;text-align:center}@media(max-width:480px){.login-form{padding:1.5rem}.login-title{font-size:1.3rem}.input-field input,.btn-login{padding:.65rem}}.control-container{min-height:100vh;display:flex;flex-direction:column}.header{background:linear-gradient(135deg,#4361ee,#3a0ca3);color:#fff;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:100}.header-title{font-size:1.2rem;font-weight:600;margin:0}.header-actions{display:flex;gap:.5rem;align-items:center}.settings-btn{background-color:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem .75rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.4rem}.settings-btn:hover{background-color:#ffffff40}.logout-btn{background-color:#fff3;color:#fff;border:none;padding:.5rem .75rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.4rem}.logout-btn:hover{background-color:#ffffff4d}.main-content{flex:1;padding:1.5rem;background-color:#f8f9fa}.door-section{margin-bottom:2rem}.section-title{font-size:1.3rem;font-weight:600;color:#333;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e9ecef}.doors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.door-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;transition:all .3s ease}.door-card:hover{transform:translateY(-3px);box-shadow:0 4px 8px #0000001a}.door-name{font-size:1.1rem;font-weight:500;color:#495057;margin-bottom:1rem;word-break:break-word}.btn-open-door{width:100%;padding:1rem;font-size:1rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;margin-bottom:.5rem}.btn-open-door.idle{background-color:#4361ee;color:#fff}.btn-open-door.idle:hover{background-color:#3a0ca3;transform:translateY(-2px);box-shadow:0 4px 12px #4361ee4d}.btn-open-door.loading{background-color:#6c757d;color:#fff;cursor:not-allowed;transform:none;box-shadow:none}.btn-open-door.success{background-color:#4caf50;color:#fff}.btn-open-door.error{background-color:#f44336;color:#fff}.error-message{padding:.75rem;border-radius:6px;background-color:#ffebee;color:#c62828;font-size:.9rem;margin-top:.5rem}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f8f9fa}.loading-spinner{width:50px;height:50px;border:5px solid #f3f3f3;border-top:5px solid #4361ee;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{font-size:1rem;color:#666}@media(max-width:768px){.doors-grid{grid-template-columns:1fr}.header{padding:.75rem 1rem}.header-title{font-size:1.1rem}.main-content{padding:1rem}.door-card{padding:1.25rem}.btn-open-door{padding:.8rem}}@media(max-width:480px){.header{padding:.75rem 1rem;gap:.5rem}.header-title{font-size:1rem;white-space:nowrap}.header-actions{gap:.4rem;flex-shrink:0}.settings-btn,.logout-btn{padding:.4rem .5rem;min-height:36px;font-size:.8rem}.settings-btn .btn-text,.logout-btn .btn-text{display:none}.section-title{font-size:1.2rem}.door-name{font-size:1rem}}.settings-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f8f9fa;padding:1rem}.settings-card{background:#fff;border-radius:16px;padding:2rem;width:100%;max-width:480px;box-shadow:0 4px 12px #0000001a}.settings-title{font-size:1.5rem;font-weight:600;color:#333;margin:0 0 1.5rem;text-align:center}.settings-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:500;color:#495057}.form-group textarea{padding:.75rem;border:2px solid #e9ecef;border-radius:8px;font-size:.9rem;font-family:monospace;resize:vertical;transition:border-color .3s ease}.form-group textarea:focus{outline:none;border-color:#4361ee}.form-hint{font-size:.8rem;color:#6c757d;margin:0}.settings-message{padding:.75rem;border-radius:8px;font-size:.9rem;text-align:center}.settings-message.success{background-color:#e8f5e9;color:#2e7d32}.settings-message.error{background-color:#ffebee;color:#c62828}.btn-save{width:100%;padding:.9rem;font-size:1rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;background-color:#4361ee;color:#fff;transition:all .3s ease}.btn-save:hover:not(:disabled){background-color:#3a0ca3}.btn-save:disabled{background-color:#6c757d;cursor:not-allowed}.btn-back{width:100%;padding:.8rem;font-size:.9rem;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;background:#fff;color:#495057;margin-top:.75rem;transition:all .3s ease}.btn-back:hover{border-color:#4361ee;color:#4361ee}
