body{margin:0;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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--theme-color: #162029}.flex{display:flex}.justify-space-between{justify-content:space-between}.sidebar{width:250px;background-color:var(--theme-color);height:100%;display:flex;flex-direction:column;justify-content:space-between}.sidebar ul{list-style-type:none;padding:20px;margin:0}.sidebar li{margin-bottom:10px;width:100%}.sidebar li:last-of-type{margin-bottom:0}.sidebar button{width:100%}.sidebar button.active{background-color:red}button{height:fit-content}.dashboard{display:grid;grid-template-columns:250px 1fr;height:100vh}.dashboard .dashboard-main{height:100%;position:relative}.dashboard .dashboard-content{position:relative;padding:20px;height:100%;box-sizing:border-box}.loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#fff9;z-index:10;pointer-events:none}.loading-overlay .spinner-svg{width:48px;height:48px;animation:spinner-rotate 1.5s linear infinite}.loading-overlay .spinner-svg .path{stroke:var(--theme-color);stroke-linecap:round;stroke-dasharray:90,150;stroke-dashoffset:0;animation:spinner-dash 1.4s ease-in-out infinite}@keyframes spinner-rotate{to{transform:rotate(360deg)}}@keyframes spinner-dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35px}to{stroke-dasharray:90,150;stroke-dashoffset:-125px}}.loading-overlay .visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.MuiTextField-root{margin:10px 0!important;width:-webkit-fill-available!important}.form-actions{position:absolute;bottom:0;left:0;width:100%;box-sizing:border-box;padding:20px}h1{margin-top:0;line-height:1em}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem 1.5rem;margin-top:1rem}.form-grid-col-span-2{grid-column:span 2}.form-field{display:flex;flex-direction:column}.form-field label{margin-bottom:.25rem;font-size:.875rem;font-weight:500}.form-field select{padding:.75rem;border:1px solid #ccc;border-radius:4px}fieldset{border:1px solid #ccc;border-radius:4px;padding:1rem;margin:0}legend{padding:0 .5rem;font-weight:700}form{padding-bottom:calc(3.5rem + 20px)}.room-displays{margin-top:1rem}.room-displays h2{margin:0 0 .5rem;font-size:1.125rem;font-weight:600}.room-displays-list{display:flex;gap:.75rem;flex-wrap:wrap}.display-card{border:1px solid #e8e8e8;border-radius:8px;padding:.75rem;min-width:220px;box-shadow:0 1px 4px #10182808;background:#fff}.display-name{font-weight:600}.display-mac{color:#666;margin-top:.25rem;font-family:monospace}.display-actions{margin-top:.5rem;display:flex;gap:.5rem}@media(max-width:560px){.display-card{min-width:100%}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--theme-color);padding:16px}.login-card{width:360px;max-width:100%;padding:24px;border-radius:10px;box-shadow:0 8px 24px #141e5014;background:#fff;display:flex;flex-direction:column;gap:12px}.login-title{margin:0 0 4px;font-size:20px;text-align:center;color:#10203a}.login-label{display:flex;flex-direction:column;font-size:13px;color:#2a3b56;gap:6px}.login-input{height:40px;padding:8px 10px;border-radius:6px;border:1px solid #d6dbe9;outline:none;font-size:14px;box-sizing:border-box}.login-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.login-button{margin-top:6px;height:42px;border-radius:8px;border:none;background:#2563eb;color:#fff;font-weight:600;cursor:pointer}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#b00020;background:#fff6f6;border-radius:6px;padding:8px 10px;font-size:13px}
