:root{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;color:#1a1a1a;background:#f5f5f5}*{box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}.app-loading,.layout-loading,.page-loading{display:flex;align-items:center;justify-content:center;min-height:60vh;margin:0}.page-error,.form-error{color:#c00;margin:.5rem 0}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;width:100%;max-width:360px}.login-card h1{margin:0 0 .25rem;font-size:1.5rem}.login-subtitle{margin:0 0 1.5rem;color:#666;font-size:.9rem}.login-card .form-group{margin-bottom:1rem}.login-card label{display:block;margin-bottom:.25rem;font-size:.9rem}.login-card input{width:100%;padding:.5rem .75rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.login-card button{width:100%;margin-top:.5rem;padding:.6rem 1rem;background:#2563eb;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.login-card button:disabled{opacity:.7;cursor:not-allowed}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-header{background:#1e293b;color:#fff;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.layout-nav{display:flex;gap:1.5rem}.layout-nav a{color:#e2e8f0;text-decoration:none}.layout-nav a:hover{color:#fff}.layout-user{display:flex;align-items:center;gap:1rem}.layout-username{font-size:.9rem;color:#94a3b8}.layout-user button{padding:.4rem .8rem;background:transparent;border:1px solid #64748b;color:#e2e8f0;border-radius:4px;cursor:pointer;font-size:.9rem}.layout-user button:hover{background:#334155}.layout-main{flex:1;padding:1.5rem;max-width:1200px;margin:0 auto;width:100%}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.25rem;font-size:.9rem}.form-group input,.form-group select{width:100%;max-width:20rem;padding:.5rem .75rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.form-hint{display:block;margin-top:.25rem;font-size:.85rem;color:#64748b}button{padding:.5rem 1rem;border-radius:4px;font-size:.95rem;cursor:pointer;border:1px solid #cbd5e1;background:#fff}button:hover:not(:disabled){background:#f1f5f9}.page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.page-header h1{margin:0}.page-header button{background:#2563eb;color:#fff;border:none}.page-header button:hover{background:#1d4ed8}.dashboard h1{margin:0 0 1rem}.dashboard-rooms{display:flex;flex-direction:column;gap:1.5rem}.dashboard-section{background:#fff;padding:1.25rem;border-radius:8px;box-shadow:0 1px 3px #00000014}.dashboard-section h2{margin:0 0 .5rem;font-size:1.1rem}.dashboard-section-count{margin:0 0 1rem;color:#64748b;font-size:.9rem}.dashboard-devices{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.device-card{display:block;padding:.75rem 1rem;background:#f8fafc;border-radius:6px;text-decoration:none;color:inherit;border:1px solid #e2e8f0}.device-card:hover{background:#f1f5f9;border-color:#cbd5e1}.device-card-name{display:block;font-weight:500}.device-card-type,.device-card-online{display:block;font-size:.85rem;color:#64748b}.device-card-online.online{color:#16a34a}.device-card-online.offline{color:#dc2626}.devices-page h1,.rooms-page h1{margin:0}.devices-total{margin:0 0 1rem;color:#64748b}.devices-list{display:flex;flex-direction:column;gap:.5rem}.device-row{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#fff;border-radius:6px;border:1px solid #e2e8f0}.device-row:hover{background:#f8fafc}.device-row-link{flex:1;display:flex;align-items:center;gap:1rem;text-decoration:none;color:inherit;min-width:0}.device-row-name{font-weight:500;flex:1;min-width:0}.device-row-type{color:#64748b;font-size:.9rem;flex-shrink:0}.device-row-room{color:#64748b;font-size:.9rem;min-width:6rem}.device-row-room-select{min-width:10rem;flex-shrink:0}.device-row-delete{flex-shrink:0;font-size:.85rem;color:#dc2626;border-color:#fecaca}.device-row-delete:hover:not(:disabled){background:#fef2f2}.device-row-online.online{color:#16a34a}.device-row-online.offline{color:#dc2626}.device-detail h1{margin:0 0 .5rem}.breadcrumb{margin-bottom:1rem;font-size:.9rem;color:#64748b}.breadcrumb a{color:#2563eb;text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.device-meta{margin:0 0 1.5rem;color:#64748b}.detail-section{margin-bottom:1.5rem;background:#fff;padding:1.25rem;border-radius:8px;box-shadow:0 1px 3px #00000014}.detail-section h2{margin:0 0 1rem;font-size:1rem}.detail-section-primary{border:1px solid #cbd5e1}.detail-section-primary h2{margin-bottom:.5rem}.device-meta-inline{margin:0 0 1rem;font-size:.95rem}.device-control-block{margin-bottom:1.25rem}.device-control-block:last-child{margin-bottom:0}.device-control-label{display:block;font-size:.9rem;font-weight:500;margin-bottom:.35rem;color:#334155}.device-room-select{max-width:20rem;padding:.5rem .75rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.device-control-block-danger{margin-top:1.25rem;padding-top:1rem;border-top:1px solid #fecaca}.devices-hint{margin:0 0 1rem;font-size:.9rem;color:#64748b}.device-name-display{display:flex;align-items:center;gap:.75rem;margin:0}.device-detail-title{font-size:1.25rem;font-weight:600}.device-rename-btn{font-size:.9rem;padding:.25rem .5rem;color:#2563eb;border-color:#93c5fd;background:transparent}.device-rename-btn:hover{background:#eff6ff}.device-rename-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.device-rename-input{flex:1;min-width:10rem;padding:.5rem .75rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.detail-section-danger{border-color:#fecaca}.device-delete-hint{margin:0 0 .75rem;font-size:.9rem;color:#64748b}.device-delete-confirm{display:flex;align-items:center;gap:.75rem}.btn-danger{color:#dc2626;border-color:#fecaca;background:#fff}.btn-danger:hover:not(:disabled){background:#fef2f2}.command-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.command-buttons button{background:#2563eb;color:#fff;border:none}.command-buttons button:hover{background:#1d4ed8}.status-json{background:#f8fafc;padding:1rem;border-radius:4px;overflow:auto;font-size:.85rem;margin:0}.command-history{margin:0;padding-left:1.25rem}.command-history li{margin-bottom:.25rem}.command-history code{font-size:.9rem;background:#f1f5f9;padding:.1rem .3rem;border-radius:3px}.rooms-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.room-card{background:#fff;padding:1.25rem;border-radius:8px;box-shadow:0 1px 3px #00000014;border:1px solid #e2e8f0}.room-card h3{margin:0 0 .5rem}.room-card p{margin:0 0 .75rem;color:#64748b;font-size:.9rem}.room-delete{font-size:.85rem;color:#dc2626;border-color:#fecaca}.room-delete:hover{background:#fef2f2}.room-card-actions{display:flex;gap:.5rem;flex-wrap:wrap}.room-rename-btn{font-size:.85rem;color:#2563eb;border-color:#93c5fd;background:transparent}.room-rename-btn:hover{background:#eff6ff}.room-rename-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.room-rename-input{flex:1;min-width:8rem;padding:.5rem .75rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:#fff;padding:1.5rem;border-radius:8px;max-width:420px;width:100%;box-shadow:0 4px 20px #00000026}.modal h3{margin:0 0 1rem}.pin-code{font-size:1.5rem;font-weight:600;letter-spacing:.2em;text-align:center;margin:1rem 0}.pin-expiry,.pin-hint{font-size:.9rem;color:#64748b;margin:.5rem 0}.modal-actions{display:flex;gap:.75rem;margin-top:1.25rem}.modal-actions button:last-child{background:#2563eb;color:#fff;border:none}.modal-actions button:last-child:hover:not(:disabled){background:#1d4ed8}.form-textarea{width:100%;max-width:100%;padding:.5rem .75rem;border:1px solid #ccc;border-radius:4px;font-size:.9rem;font-family:ui-monospace,monospace}.admin-page h1{margin:0 0 1rem}.admin-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.admin-tabs button{padding:.5rem 1rem;border-radius:4px;border:1px solid #cbd5e1;background:#fff}.admin-tabs button.active{background:#2563eb;color:#fff;border-color:#2563eb}.admin-section{margin-bottom:2rem}.admin-section h2{margin:0 0 1rem;font-size:1.1rem}.admin-types-list{display:flex;flex-direction:column;gap:.75rem}.admin-type-card{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:6px}.admin-type-desc,.admin-type-meta,.admin-type-commands{margin:.25rem 0 0;font-size:.9rem;color:#64748b}.admin-type-actions{display:flex;gap:.5rem;flex-shrink:0}.admin-type-actions .danger{color:#dc2626;border-color:#fecaca}.admin-type-actions .danger:hover{background:#fef2f2}.admin-pagination-info{margin:0 0 .75rem;font-size:.9rem;color:#64748b}.admin-devices-table-wrap{overflow-x:auto;margin-bottom:1rem}.admin-devices-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-devices-table th,.admin-devices-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid #e2e8f0}.admin-devices-table th{background:#f8fafc;font-weight:600}.admin-cell-mono{font-family:ui-monospace,monospace;font-size:.85rem;max-width:12rem;overflow:hidden;text-overflow:ellipsis}.admin-btn-sm{padding:.25rem .5rem;font-size:.85rem;margin-right:.25rem}.admin-btn-sm.danger{color:#dc2626;border-color:#fecaca}.admin-pagination{display:flex;align-items:center;gap:1rem}.admin-modal .form-group input,.admin-modal .form-group select{max-width:100%}.admin-bulk-form{max-width:28rem}.admin-bulk-form .form-group{margin-bottom:1rem}.admin-bulk-result{margin-top:1.5rem;padding:1rem;background:#f8fafc;border-radius:6px}.admin-bulk-result h3{margin:0 0 .75rem;font-size:1rem}
