:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;margin:0;padding:0;text-align:center}h1{font-size:2.5em;line-height:1.1;margin-bottom:1.5rem}h2{margin-top:0}.card{padding:1.5rem;border:1px solid #555;border-radius:8px;background-color:#1a1a1a}ul{list-style-type:none;padding:0;margin:0}li{background-color:#2a2a2a;padding:.8rem 1.2rem;margin-bottom:.5rem;border-radius:4px;text-align:left}select{width:100%;padding:.5rem;margin-bottom:1rem;border-radius:4px;border:1px solid #555;background-color:#333;color:#fff}table{width:100%;border-collapse:collapse;margin-top:1rem;font-size:.85em}th,td{border:1px solid #444;padding:.6rem;text-align:center}th{background-color:#2a2a2a;font-weight:700}tbody tr:nth-child(2n){background-color:#1c1c1c}tbody tr:hover{background-color:#3a3a3a}.reset-button{margin-top:1rem;padding:.5rem 1rem;border:none;border-radius:4px;background-color:#8b0000;color:#fff;cursor:pointer;font-weight:700;transition:background-color .2s}.reset-button:hover{background-color:#b22222}.app-header{padding:1rem 2rem;background-color:#1a1a1a;border-bottom:1px solid #333;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center}@font-face{font-family:WDXL Lubrifont JP N;src:url(/fonts/WDXLLubrifontJPN-Regular.ttf) format("truetype");font-weight:400;font-style:normal}.digital-clock{font-family:WDXL Lubrifont JP N,sans-serif;color:#eee;text-align:left;line-height:1;min-width:350px}.clock-date{font-family:WDXL Lubrifont JP N,sans-serif;font-size:1.2rem;color:#888;margin-bottom:4px;letter-spacing:2px}.clock-time{font-size:3.5rem;font-weight:400;text-shadow:0 0 15px rgba(255,255,255,.2);letter-spacing:2px;font-variant-numeric:tabular-nums}.home-link{text-decoration:none;color:inherit}main{padding:0 1.5rem 2rem}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.detail-button{padding:.5rem 1rem;background-color:#007bff;color:#fff;text-decoration:none;border-radius:4px;transition:background-color .2s}.detail-button:hover{background-color:#0056b3}.back-link{display:inline-block;margin-bottom:1rem;color:#0af;text-decoration:none}.back-link:hover{text-decoration:underline}.back-link-button{padding:.6rem 1.2rem;background-color:#555;color:#fff;text-decoration:none;border-radius:4px;font-size:.9em;font-weight:700;transition:background-color .2s;display:inline-flex;align-items:center}.back-link-button:hover{background-color:#666}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.add-device-button{padding:.6rem 1.2rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1em;transition:background-color .2s}.add-device-button:hover{background-color:#0056b3}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#2a2a2a;padding:2rem;border-radius:8px;width:90%;max-width:500px;box-shadow:0 5px 15px #0000004d}.modal-content h2{margin-top:0}.modal-body{margin:1.5rem 0}.serial-id-input{width:100%;padding:.8rem;border-radius:4px;border:1px solid #555;background-color:#1a1a1a;color:#fff;font-size:1.1em;margin-top:1rem;box-sizing:border-box}.modal-footer{display:flex;justify-content:flex-end;gap:1rem}.modal-footer button{padding:.6rem 1.2rem;border:none;border-radius:4px;cursor:pointer;font-weight:700}.modal-footer button:nth-child(1){background-color:#555;color:#fff}.modal-footer button:nth-child(2){background-color:#007bff;color:#fff}.modal-footer button:disabled{background-color:#444;cursor:not-allowed}.modal-error{color:#ff6b6b;margin-bottom:1rem}.settings-button{background-color:#4caf50;color:#fff;padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-weight:700}.settings-button:hover{background-color:#45a049}.form-group{margin-bottom:1rem;text-align:left}.form-group label{display:block;margin-bottom:.3rem;font-size:.9em;color:#ccc}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.save-button{background-color:#4caf50!important}.accum-status-card{background-color:#1e2a1e;border:1px solid #2e4a2e}.accum-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-top:1rem}.accum-item{display:flex;flex-direction:column;align-items:center;padding:1rem;background-color:#0003;border-radius:8px}.accum-item .label{font-size:.8em;color:#aaa;margin-bottom:.5rem}.accum-item .value{font-size:1.4em;font-weight:700;color:#4caf50}.dashboard-control-panel{display:flex;justify-content:space-between;align-items:center;background-color:#1e1e1e;padding:1rem 1.5rem;border-radius:8px;border:1px solid #333;margin-bottom:2rem;flex-wrap:wrap;gap:1.5rem}.panel-left{display:flex;align-items:center;gap:3rem;flex-wrap:wrap}.panel-right{display:flex;align-items:center;gap:2rem}.user-info-group{display:flex;align-items:center;gap:1rem;padding-left:2rem;border-left:1px solid #444}.user-greeting{display:flex;flex-direction:column;text-align:right}.user-greeting .label{font-size:.7rem;color:#666}.user-greeting .username{font-size:1rem;font-weight:700;color:#ddd}.device-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:768px){.device-grid{grid-template-columns:repeat(2,1fr)}}.device-card{display:flex;flex-direction:column;height:100%;margin-top:0!important;border:1px solid #444;transition:transform .2s,box-shadow .2s}.device-card:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0000004d;border-color:#666}.device-card .card-header{margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #333}.device-info h2{margin:0;font-size:1.4rem;color:#fff}.signal-strength{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#aaa;margin-top:.2rem}.chart-container{flex-grow:1;min-height:auto;width:100%;overflow:hidden}.reset-button-small{margin-top:1rem;padding:.4rem .8rem;font-size:.85rem;background-color:transparent;color:#888;border:1px solid #555;border-radius:4px;cursor:pointer;align-self:flex-start}.reset-button-small:hover{background-color:#300;color:#ff6b6b;border-color:#ff6b6b}.header-user-info{display:flex;align-items:center;gap:1rem}.logout-button{background-color:#444;color:#ccc;border:none;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.9em}.logout-button:hover{background-color:#555;color:#fff}.login-container{display:flex;justify-content:center;align-items:center;min-height:60vh}.login-card{width:100%;max-width:400px}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
