body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-card{background:#fff;border-radius:10px;box-shadow:0 10px 25px #0003;max-width:400px;padding:2rem 3rem;width:100%}.login-card h2{color:#333;margin:0 0 1.5rem;text-align:center}.auth-method-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.auth-method-tabs button{background:#fff;border:2px solid #e0e0e0;border-radius:5px;cursor:pointer;flex:1 1;font-weight:500;padding:.75rem;transition:all .3s}.auth-method-tabs button.active{background:#667eea;border-color:#667eea;color:#fff}.form-group{margin-bottom:1.25rem}.form-group label{color:#555;display:block;font-weight:500;margin-bottom:.5rem}.form-group input{border:2px solid #e0e0e0;border-radius:5px;box-sizing:border-box;font-size:1rem;padding:.75rem;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.error-message{background:#fdf2f2;color:#e74c3c;text-align:center}.submit-btn{border:none;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem;transition:transform .2s;width:100%}.submit-btn:hover:not(:disabled){transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.6}.register-link{color:#666;margin-top:1.5rem;text-align:center}.register-link a{color:#667eea;font-weight:500;text-decoration:none}.register-link a:hover{text-decoration:underline}.dashboard-container{background:#f5f5f5;min-height:100vh}.dashboard-nav{align-items:center;background:#fff;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;padding:1rem 2rem}.dashboard-nav h1{color:#333;margin:0}.nav-left{gap:1rem}.nav-actions,.nav-left{align-items:center;display:flex}.nav-actions{gap:1.5rem}.dashboard-content{margin:2rem auto;max-width:1200px;padding:0 2rem}.dashboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.dashboard-header h2{color:#333;margin:0}.add-device-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:transform .2s}.add-device-btn:hover{transform:translateY(-2px)}.loading,.no-devices{color:#666;padding:3rem;text-align:center}.devices-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.device-card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;color:inherit;cursor:pointer;padding:1.5rem;text-decoration:none;transition:transform .2s,box-shadow .2s}.device-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-5px)}.device-card h3{color:#333;margin:0 0 .5rem}.device-id,.device-type{color:#666;font-size:.9rem;margin:.25rem 0}.device-status{font-weight:600;margin:.5rem 0}.device-status.online{color:#27ae60}.device-status.offline{color:#e74c3c}.device-status.unknown{color:#95a5a6}.device-line{color:#555;font-size:.82rem;margin:.2rem 0}.device-line-label{color:#666;font-weight:600}.line-badge{font-weight:600}.line-badge.on{color:#1e8449}.line-badge.off{color:#c0392b}.line-badge.na{color:#95a5a6;font-weight:500}.control-btn{background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;margin-top:1rem;padding:.75rem;transition:background .3s;width:100%}.control-btn:hover{background:#5568d3}.device-list-container{background:#f5f5f5;min-height:100vh}.device-list-container .dashboard-nav{margin-bottom:0}.device-list-container .devices-grid{margin:2rem auto;max-width:1200px;padding:0 2rem}.device-list-container h1{color:#333;margin-bottom:2rem}.modal-content{background:#fff;border-radius:10px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:500px;overflow-y:auto;padding:0;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h3{color:#333;margin:0}.close-btn{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;font-size:2rem;height:30px;justify-content:center;line-height:1;padding:0;transition:color .3s;width:30px}.close-btn:hover{color:#333}.device-form{padding:1.5rem}.device-form .form-group{margin-bottom:1.5rem}.device-form label{color:#333;display:block;font-weight:500;margin-bottom:.5rem}.device-form input,.device-form select{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:1rem;padding:.75rem;transition:border-color .3s;width:100%}.device-form input:focus,.device-form select:focus{border-color:#667eea;outline:none}.device-form select{background:#fff;cursor:pointer}.error-message{background:#fee;border:1px solid #fcc;border-radius:5px;color:#c33;margin-bottom:1rem;padding:.75rem}.modal-actions{justify-content:flex-end;margin-top:2rem}.cancel-btn,.submit-btn{border:none;border-radius:5px;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s}.cancel-btn{background:#e0e0e0;color:#333}.cancel-btn:hover{background:#d0d0d0}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.submit-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.device-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem}.device-card-header h3{flex:1 1;margin:0}.device-actions{display:flex;gap:.5rem}.delete-btn-small,.edit-btn{background:none;border:none;border-radius:5px;cursor:pointer;font-size:1.2rem;opacity:.7;padding:.25rem .5rem;transition:all .3s}.edit-btn:hover{background:#e3f2fd;opacity:1;transform:scale(1.1)}.delete-btn-small:hover{background:#ffebee;opacity:1;transform:scale(1.1)}.delete-modal{max-width:400px}.delete-content{padding:1.5rem}.delete-content p{color:#333;margin:0 0 1rem}.device-info-box{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;line-height:1.8;margin:1rem 0;padding:1rem}.device-info-box strong{color:#667eea}.delete-btn{background:#e74c3c;color:#fff}.delete-btn:hover{background:#c0392b;box-shadow:0 4px 12px #e74c3c66;transform:translateY(-2px)}.device-control-container{margin:0 auto;max-width:1200px;padding:2rem}.control-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.header-actions{align-items:center;display:flex;gap:1.5rem}.user-name{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;color:#333;font-size:.95rem;font-weight:600;padding:.25rem .75rem}.back-btn{background:#95a5a6;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:background .3s}.back-btn:hover{background:#7f8c8d}.control-header h1{color:#333;margin:0}.device-info{grid-gap:1rem;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem;padding:1.5rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item label{color:#666;font-size:.9rem;font-weight:600}.info-item span{color:#333;font-size:1rem}.status.online{color:#27ae60}.status.offline{color:#e74c3c}.status.unknown{color:#95a5a6}.line-state{border-radius:6px;display:inline-block;font-size:.95rem;font-weight:600;padding:.25rem .6rem}.line-state.run{background:#e8f8ef;color:#1e8449}.line-state.not-run{background:#fdecea;color:#c0392b}.line-state.na{color:#95a5a6;font-weight:500}.led-saved-state{font-weight:600}.led-saved-state.on{color:#1e8449}.led-saved-state.off{color:#7f8c8d}.led-saved-time{color:#888;font-size:.9em;font-weight:400}.command-section,.messages-section{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:1.5rem}.command-section h2,.messages-section h2{color:#333;margin:0 0 1rem}.command-examples{border-top:none;margin-top:0;padding-top:0}.command-examples h3{color:#333;font-size:1.1rem;margin:0 0 1rem}.example-buttons{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.example-btn{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:5px;color:#333;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1rem;transition:all .3s}.example-btn:hover{background:#667eea;border-color:#667eea;color:#fff}.example-btn-led-toggle.led-is-on{background:#e8f5e9;border-color:#2e7d32}.messages-list{border:1px solid #e0e0e0;border-radius:5px;max-height:400px;overflow-y:auto;padding:.5rem}.no-messages{color:#666;padding:2rem;text-align:center}.message-item{grid-gap:1rem;border-bottom:1px solid #f0f0f0;display:grid;font-size:.9rem;gap:1rem;grid-template-columns:100px 200px 1fr;padding:.75rem}.message-item:last-child{border-bottom:none}.message-time{color:#666}.message-topic{color:#667eea;font-weight:500}.message-content{color:#333}.admin-dashboard{background:#f5f5f5;min-height:100vh}.admin-nav{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:1.5rem 2rem}.admin-nav h1{font-size:1.8rem;margin:0}.admin-tabs{background:#fff;box-shadow:0 2px 4px #0000001a;display:flex;gap:.5rem;padding:1rem 2rem}.admin-tabs button{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .3s}.admin-tabs button:hover{background:#f0f0f0;color:#667eea}.admin-tabs button.active{border-bottom-color:#667eea;color:#667eea}.admin-content{margin:2rem auto;max-width:1400px;padding:0 2rem}.admin-content h2{color:#333;margin-bottom:1.5rem}.admin-table{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;overflow:hidden;width:100%}.admin-table th{background:#667eea;color:#fff;font-weight:600;padding:1rem;text-align:left}.admin-table td{border-bottom:1px solid #f0f0f0;padding:.75rem 1rem}.admin-table tr:hover{background:#f9f9f9}.btn-delete,.btn-edit,.btn-password{border:none;border-radius:5px;cursor:pointer;font-size:.9rem;margin-right:.5rem;padding:.5rem 1rem;transition:all .3s}.btn-edit{background:#4caf50;color:#fff}.btn-password{background:#ff9800;color:#fff}.btn-delete{background:#f44336;color:#fff}.btn-delete:hover,.btn-edit:hover,.btn-password:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.status.online{color:#4caf50;font-weight:600}.status.offline{color:#f44336;font-weight:600}.status.unknown{color:#999;font-weight:600}.mqtt-topic{color:#666;font-family:monospace;font-size:.85rem}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:10px;box-shadow:0 10px 30px #0000004d;min-width:400px;padding:2rem}.modal h3{color:#333;margin-top:0}.modal label{color:#666;display:block;font-weight:500;margin:1rem 0 .5rem}.modal input{border:2px solid #e0e0e0;border-radius:5px;box-sizing:border-box;font-size:1rem;padding:.75rem;width:100%}.modal input:focus{border-color:#667eea;outline:none}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn-save{background:#4caf50}.btn-cancel,.btn-save{border:none;border-radius:5px;color:#fff;cursor:pointer;flex:1 1;font-weight:600;padding:.75rem}.btn-cancel{background:#999}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;text-align:center}.stat-card h3{color:#666;font-size:.9rem;margin:0 0 1rem}.stat-value{color:#667eea;font-size:2.5rem;font-weight:700;margin:0}.devices-by-type,.recent-users{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:1.5rem}.devices-by-type h3,.recent-users h3{color:#333;margin-top:0}.loading{color:#666;padding:3rem;text-align:center}.logout-btn{background:#e74c3c!important;border:2px solid #c0392b!important;border-radius:6px!important;box-shadow:0 2px 4px #e74c3c4d!important;color:#fff!important;cursor:pointer!important;font-size:.95rem!important;font-weight:600!important;letter-spacing:.5px!important;opacity:1!important;padding:.5rem 1.25rem!important;text-transform:uppercase!important;transition:all .3s!important;visibility:visible!important}.logout-btn:hover{background:#c0392b!important;border-color:#a93226!important;box-shadow:0 4px 8px #e74c3c66!important;transform:translateY(-1px)!important}.logout-btn:active{box-shadow:0 1px 2px #e74c3c4d!important;transform:translateY(0)!important}.logout-btn:focus{outline:2px solid #e74c3c!important;outline-offset:2px!important}.qr-page{display:flex;font-family:Segoe UI,Sarabun,Kanit,sans-serif;min-height:100vh;overflow-x:hidden;position:relative}.qr-page-bg{inset:0;position:fixed;transition:background .4s ease;z-index:0}.qr-page-bg.theme-purple-blue{background:linear-gradient(135deg,#1a0a2e,#2d1b4e 40%,#16213e)}.qr-page-bg.theme-ocean{background:linear-gradient(135deg,#0c1445,#1a5f7a 50%,#0d7377)}.qr-page-bg.theme-sunset{background:linear-gradient(135deg,#2d1f3d,#7b2869 50%,#c94b4b)}.qr-page-bg.theme-dark{background:#121218}.qr-page-bg.has-image{background-position:50%;background-repeat:no-repeat;background-size:cover}.qr-page-bg.has-image:after{background:#0000008c;content:"";inset:0;position:absolute}.qr-sidebar{background:#fffffff7;box-shadow:4px 0 24px #0000001f;display:flex;flex-direction:column;flex-shrink:0;min-height:100vh;padding:1.25rem 1rem;width:260px;z-index:2}.qr-sidebar h2{color:#333;font-size:1.1rem;font-weight:700;margin-bottom:1rem}.qr-lang-btns{display:flex;gap:.5rem;margin-bottom:1.25rem}.qr-lang-btns button{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;flex:1 1;font-size:.85rem;font-weight:600;padding:.45rem}.qr-lang-btns button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff}.qr-nav{list-style:none;margin:0 0 1.5rem;padding:0}.qr-nav li{margin-bottom:.35rem}.qr-nav button{align-items:center;background:#0000;border:none;border-radius:10px;color:#444;cursor:pointer;display:flex;font-size:.95rem;gap:.5rem;padding:.65rem .75rem;text-align:left;transition:background .2s;width:100%}.qr-nav button:hover{background:#f0f0f8}.qr-nav button.active{background:linear-gradient(90deg,#667eea33,#764ba226);color:#5a4fcf;font-weight:600}.qr-nav a.qr-nav-link{align-items:center;border-radius:10px;color:#444;display:flex;font-size:.95rem;gap:.5rem;padding:.65rem .75rem;text-align:left;text-decoration:none;transition:background .2s;width:100%}.qr-nav a.qr-nav-link:hover{background:#f0f0f8}.qr-sidebar-section{border-top:1px solid #eee;margin-top:auto;padding-top:1rem}.qr-sidebar-section h3{color:#555;font-size:.9rem;margin-bottom:.75rem}.qr-sidebar-section label{color:#666;display:block;font-size:.8rem;margin-bottom:.35rem}.qr-sidebar-section input[type=text],.qr-sidebar-section select{border:1px solid #ddd;border-radius:8px;font-size:.85rem;margin-bottom:.75rem;padding:.5rem;width:100%}.qr-bg-actions{display:flex;gap:.5rem}.qr-bg-actions button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:.8rem;font-weight:600;padding:.5rem}.qr-bg-actions .btn-use{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.qr-bg-actions .btn-clear{background:#e8e8e8;color:#444}.qr-main{align-items:flex-start;display:flex;flex:1 1;justify-content:center;overflow-y:auto;padding:2rem 1.5rem;z-index:1}.qr-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #00000040;max-width:720px;padding:2rem 2.25rem;width:100%}.qr-card h1{color:#222;font-size:1.65rem;margin:0 0 .35rem}.qr-card .subtitle{color:#666;font-size:.95rem;margin-bottom:1.25rem}.qr-url-row{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.qr-url-row input{border:2px solid #e0e0e0;border-radius:12px;flex:1 1;font-size:1rem;min-width:200px;padding:.85rem 1rem}.qr-url-row input:focus{border-color:#667eea;outline:none}.qr-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.85rem 1.5rem;white-space:nowrap}.qr-btn-primary:hover{filter:brightness(1.05)}.qr-panel{background:#f5f6fa;border-radius:14px;margin-bottom:1.5rem;padding:1.25rem}.qr-panel-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.qr-field label{color:#555;display:block;font-size:.8rem;font-weight:500;margin-bottom:.35rem}.qr-field input[type=text],.qr-field select{border:1px solid #ddd;border-radius:8px;font-size:.9rem;padding:.55rem .65rem;width:100%}.qr-field input[type=color]{border:1px solid #ddd;border-radius:8px;cursor:pointer;height:38px;padding:2px;width:100%}.qr-field input[type=range]{width:100%}.qr-panel-footer{display:flex;justify-content:flex-end;margin-top:1rem}.qr-btn-secondary{background:#e8e9ed;border:none;border-radius:10px;color:#333;cursor:pointer;font-size:.9rem;font-weight:600;padding:.55rem 1.1rem}.qr-btn-secondary:hover{background:#ddd}.qr-preview-wrap{align-items:center;background:#fafafa;border:1px dashed #ddd;border-radius:14px;display:flex;flex-direction:column;gap:1rem;padding:1rem}.qr-preview-wrap #qr-canvas-container{align-items:center;display:flex;justify-content:center;min-height:120px}.qr-download-row{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.qr-download-row button{background:#fff;border:1px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;font-size:.85rem;font-weight:600;padding:.5rem 1rem}.qr-download-row button:hover{background:#f0f0ff}.qr-static-page{color:#444;line-height:1.7}.qr-static-page h2{color:#333;margin-top:0}@media (max-width:900px){.qr-page{flex-direction:column}.qr-sidebar{min-height:auto;width:100%}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.3bf9111d.css.map*/