*{box-sizing:border-box}:root{color-scheme:light dark;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0;padding:0;min-height:100vh}body{margin:0;padding:0;background:radial-gradient(circle at top,#1f2937,#0f172a 60%);color:#f8fafc;width:100%;max-width:100%;overflow-x:hidden}#root{min-height:100vh;width:100%}.app-shell{flex:1;display:flex;flex-direction:column;padding:2.5rem;gap:2rem}.dashboard-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.card{background:#0f172aa6;border:1px solid rgba(148,163,184,.2);border-radius:18px;padding:1.5rem;box-shadow:0 12px 30px #0f172a73;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;flex-direction:column;gap:.75rem}.card h2{margin:0;font-size:1.1rem;font-weight:600;color:#e2e8f0}.card .value{font-size:2.25rem;font-weight:700;letter-spacing:-.03em;color:#38bdf8}.trend{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:#94a3b8}.chart{flex:1;background:#0f172a73;border-radius:16px;padding:1.5rem;border:1px solid rgba(148,163,184,.2);min-height:280px}.chart canvas{width:100%!important;height:100%!important}.table{background:#0f172a73;border-radius:16px;border:1px solid rgba(148,163,184,.2);overflow:hidden}.table table{width:100%;border-collapse:collapse}.table thead{background:#47556933;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem}.table th,.table td{padding:.85rem 1.25rem;text-align:left;border-bottom:1px solid rgba(148,163,184,.12)}.table tbody tr:hover{background:#3b82f614}.status-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .65rem;border-radius:999px;font-size:.78rem;font-weight:600;background:#38bdf829;color:#38bdf8}.status-pill.offline{background:#f871711f;color:#f87171}.loading,.error-state{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;background:#0f172a8c;border-radius:16px;border:1px solid rgba(148,163,184,.2);color:#94a3b8}.error-state{color:#fca5a5}.rooms-dashboard{min-height:100vh;padding:clamp(1.5rem,2vw,2.75rem);background:radial-gradient(circle at top,#111827,#0b1120 60%);color:#e2e8f0;display:flex;flex-direction:column;gap:1.75rem;width:100%;max-width:100%;flex:1;box-sizing:border-box}.rooms-top{width:100%;align-self:stretch;display:flex;flex-direction:column;gap:1.5rem}.rooms-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem}.rooms-pretitle{text-transform:uppercase;letter-spacing:.18em;font-size:.65rem;font-weight:700;color:#38bdf8;margin:0 0 .5rem}.rooms-header h1{margin:0;font-size:clamp(1.8rem,2.2vw + 1rem,2.6rem);letter-spacing:-.03em}.rooms-subtitle{margin:.35rem 0 0;color:#94a3b8;font-size:.95rem}.rooms-actions{display:flex;gap:.75rem;flex-wrap:wrap}.rooms-button{border-radius:999px;padding:.8rem 1.4rem;font-weight:600;display:inline-flex;align-items:center;gap:.6rem;border:none;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.rooms-button.primary{background:linear-gradient(135deg,#38bdf8,#22d3ee);color:#0f172a;box-shadow:0 12px 26px #22d3ee47}.rooms-button.primary:hover{transform:translateY(-1px);box-shadow:0 18px 32px #22d3ee59}.rooms-button.secondary{background:#94a3b81f;color:#e2e8f0;border:1px solid rgba(148,163,184,.25);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.rooms-button.secondary:hover{transform:translateY(-1px)}.rooms-controls{display:flex;flex-direction:column;gap:1.25rem}.rooms-control-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.rooms-tabs{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.5rem}.rooms-tab{border-radius:999px;padding:.7rem 1.4rem;background:#94a3b826;color:#cbd5f5;border:none;cursor:pointer;font-weight:600;transition:background .2s ease,transform .2s ease;white-space:nowrap}.rooms-tab.active{background:linear-gradient(135deg,#8b5cf6,#3b82f6);color:#f8fafc;box-shadow:0 12px 24px #3b82f659;transform:translateY(-2px)}.rooms-time-range{display:flex;flex-wrap:wrap;gap:.65rem}.time-range-button{border-radius:12px;padding:.65rem 1.1rem;background:#94a3b81f;color:#cbd5f5;border:1px solid transparent;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s ease}.time-range-button.active{background:#3b82f629;border-color:#3b82f666;color:#f8fafc;box-shadow:0 12px 24px #3b82f633}.rooms-refresh{display:inline-flex;flex-wrap:wrap;align-items:center;gap:.6rem}.refresh-button{border-radius:12px;padding:.65rem 1rem;background:#94a3b81a;color:#cbd5f5;border:1px solid transparent;cursor:pointer;font-size:.8rem;font-weight:600;transition:all .2s ease}.refresh-button.active{background:#38bdf82e;border-color:#38bdf873;color:#f8fafc;box-shadow:0 10px 20px #38bdf838}.refresh-button:hover{transform:translateY(-1px)}.rooms-content{display:flex;flex-direction:column;gap:1.6rem;width:100%;align-self:stretch}.rooms-overview,.rooms-stats,.rooms-charts,.rooms-summary,.rooms-recent{background:#0f172a8c;border-radius:24px;padding:clamp(1.4rem,2vw,1.8rem);border:1px solid rgba(148,163,184,.2);box-shadow:0 18px 40px #0f172a73;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);width:100%}.rooms-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem}.overview-tile{display:flex;flex-direction:column;gap:.35rem}.overview-tile p{margin:0;text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;color:#94a3b8}.overview-tile strong{font-size:clamp(1.6rem,1.1vw + 1.2rem,2rem);font-weight:700;color:#38bdf8}.overview-tile span{font-size:.85rem;color:#94a3b8}.rooms-stats{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.stat-card{background:#111827a6;border:1px solid rgba(148,163,184,.18);border-radius:18px;padding:1.25rem;display:flex;flex-direction:column;gap:.4rem}.stat-card p{margin:0;color:#94a3b8;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}.stat-card strong{font-size:1.4rem;color:#f8fafc}.stat-card.trend{flex-direction:column;gap:.8rem}.stat-card.trend div{display:inline-flex;align-items:center;gap:.5rem;color:#fbbf24}.stat-card.trend span{font-size:.8rem;text-transform:uppercase;color:#fde68a}.rooms-charts{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.panel header{margin-bottom:1rem;display:flex;align-items:baseline;justify-content:space-between;gap:.75rem}.panel h2{margin:0;font-size:1rem;color:#f8fafc}.panel header span{font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em}.panel-body{height:100%}.rooms-summary header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;color:#c4b5fd}.rooms-summary h2{margin:0;font-size:1rem}.summary-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-tile{background:#11182799;border-radius:16px;padding:1.1rem;border:1px solid rgba(148,163,184,.18);display:flex;flex-direction:column;gap:.3rem}.summary-tile p{margin:0;color:#94a3b8;font-size:.8rem}.summary-tile strong{font-size:1.2rem;color:#f8fafc}.rooms-recent header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem;gap:1rem}.rooms-recent h2{margin:0;font-size:1rem}.rooms-recent p{margin:0;color:#94a3b8;font-size:.85rem}.table-wrapper{max-width:100%;overflow-x:auto}.rooms-recent table{width:100%;border-collapse:collapse}.rooms-recent th,.rooms-recent td{padding:.8rem 1rem;text-align:left;border-bottom:1px solid rgba(148,163,184,.14);white-space:nowrap}.rooms-recent tbody tr:hover{background:#3b82f61a}.rooms-state{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.75rem;background:#0f172a99;border-radius:18px;border:1px solid rgba(148,163,184,.25);color:#94a3b8}.rooms-state.error{color:#fca5a5}.rooms-state.empty{color:#cbd5f5}.pulse-dot{width:10px;height:10px;border-radius:999px;background:#38bdf8;box-shadow:0 0 #38bdf8b3;animation:pulse 1.6s infinite}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #38bdf899}70%{transform:scale(1);box-shadow:0 0 0 12px #38bdf800}to{transform:scale(.95);box-shadow:0 0 #38bdf800}}.rooms-footer{margin-top:auto;text-align:center;color:#64748b;font-size:.85rem}@media (max-width: 960px){.rooms-dashboard{padding:2.2rem 1.4rem 2.6rem}.rooms-header{flex-direction:column;align-items:flex-start}.rooms-actions{width:100%}.rooms-button{flex:1 1 auto;justify-content:center}.rooms-control-row{flex-direction:column;align-items:stretch}.rooms-refresh{justify-content:flex-start}}@media (max-width: 640px){.rooms-dashboard{padding:1.6rem .9rem 1.9rem}.rooms-controls{gap:.9rem}.rooms-tabs{gap:.5rem}.rooms-tab{padding:.6rem 1.1rem}.time-range-button{width:100%;text-align:center}.rooms-refresh{width:100%;gap:.5rem}.refresh-button{flex:1;text-align:center}.rooms-overview,.rooms-stats,.rooms-charts,.rooms-summary,.rooms-recent{border-radius:18px}}.device-manager-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.device-manager{background:linear-gradient(to bottom,#1e293b,#0f172a);border:1px solid rgba(148,163,184,.2);border-radius:20px;width:100%;max-width:1200px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080}.device-manager-header{padding:2rem;border-bottom:1px solid rgba(148,163,184,.15);display:flex;justify-content:space-between;align-items:flex-start}.device-manager-header h2{margin:0 0 .5rem;font-size:1.75rem;font-weight:700;display:flex;align-items:center;gap:.75rem;color:#f1f5f9}.device-manager-header p{margin:0;font-size:.95rem;color:#94a3b8}.close-button{background:#94a3b81a;border:1px solid rgba(148,163,184,.2);color:#cbd5e1;border-radius:8px;padding:.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#ef444433;border-color:#ef444466;color:#fca5a5}.device-manager-content{padding:2rem;overflow-y:auto;flex:1}.manager-section{margin-bottom:2.5rem}.manager-section:last-child{margin-bottom:0}.manager-section h3{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#e2e8f0}.create-room-form{display:flex;gap:.75rem;margin-bottom:1.5rem}.room-input{flex:1;background:#0f172a99;border:1px solid rgba(148,163,184,.25);border-radius:10px;padding:.75rem 1rem;color:#f1f5f9;font-size:.95rem;transition:all .2s}.room-input:focus{outline:none;border-color:#3b82f6;background:#0f172acc}.room-input::placeholder{color:#64748b}.create-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff;border-radius:10px;padding:.75rem 1.5rem;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.create-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #3b82f64d}.create-button:disabled{opacity:.5;cursor:not-allowed}.rooms-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.room-item{background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:10px;padding:1rem;display:flex;justify-content:space-between;align-items:center}.room-name{font-weight:500;color:#e2e8f0}.delete-room-button{background:transparent;border:none;color:#94a3b8;cursor:pointer;padding:.25rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.delete-room-button:hover{background:#ef444433;color:#fca5a5}.devices-section{margin-bottom:0}.devices-table{background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:12px;overflow:hidden}.devices-table table{width:100%;border-collapse:collapse}.devices-table thead{background:#0f172acc;border-bottom:1px solid rgba(148,163,184,.2)}.devices-table th{text-align:left;padding:1rem;font-weight:600;font-size:.85rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.devices-table tbody tr{border-bottom:1px solid rgba(148,163,184,.1);transition:background .2s}.devices-table tbody tr:last-child{border-bottom:none}.devices-table tbody tr:hover{background:#3b82f60d}.devices-table td{padding:1rem;color:#cbd5e1;font-size:.95rem}.device-id{font-family:Fira Code,Courier New,monospace;background:#3b82f626;padding:.25rem .5rem;border-radius:6px;font-size:.85rem;color:#93c5fd}.device-name{color:#e2e8f0;font-weight:500}.device-name-input{background:#0f172acc;border:1px solid rgba(148,163,184,.3);border-radius:6px;padding:.5rem .75rem;color:#f1f5f9;font-size:.95rem;width:100%;max-width:200px}.device-name-input:focus{outline:none;border-color:#3b82f6}.room-select{background:#0f172acc;border:1px solid rgba(148,163,184,.3);border-radius:6px;padding:.5rem .75rem;color:#f1f5f9;font-size:.95rem;cursor:pointer}.room-select:focus{outline:none;border-color:#3b82f6}.room-badge{background:#3b82f633;color:#93c5fd;padding:.35rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;display:inline-block}.last-seen{color:#94a3b8;font-size:.85rem}.device-actions{display:flex;gap:.5rem}.action-button{background:#94a3b81a;border:1px solid rgba(148,163,184,.2);color:#cbd5e1;border-radius:6px;padding:.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.action-button.edit:hover{background:#3b82f633;border-color:#3b82f666;color:#93c5fd}.action-button.save:hover{background:#22c55e33;border-color:#22c55e66;color:#86efac}.action-button.cancel:hover{background:#ef444433;border-color:#ef444466;color:#fca5a5}.empty-state{padding:3rem 2rem;text-align:center;color:#94a3b8}.empty-state p{margin:0;font-size:.95rem}.view-switcher{position:fixed;bottom:2rem;right:2rem;z-index:100;display:flex;gap:.5rem;background:#0f172acc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(148,163,184,.2);border-radius:12px;padding:.5rem;box-shadow:0 8px 24px #0000004d}.view-switcher-button{background:transparent;border:none;color:#94a3b8;border-radius:8px;padding:.6rem 1rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.view-switcher-button:hover{background:#94a3b81a;color:#cbd5e1}.view-switcher-button.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f64d}.device-filter{display:flex;align-items:center;gap:.75rem;padding:1rem 0;flex-wrap:wrap}.filter-label{font-size:.9rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.device-filter-button{background:#0f172a99;border:2px solid rgba(148,163,184,.2);color:#cbd5e1;border-radius:10px;padding:.6rem 1rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.device-filter-button:hover{background:#0f172acc;transform:translateY(-1px)}.device-filter-button.active{background:#3b82f626;color:#f1f5f9}.device-badge{background:#3b82f633;color:#93c5fd;padding:.25rem .6rem;border-radius:6px;font-size:.85rem;font-weight:500;display:inline-block}.log-filters{display:flex;gap:1.5rem;padding:1.5rem 0;flex-wrap:wrap}.log-filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.log-filter-group label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.log-filter-select{background:#0f172a99;border:1px solid rgba(148,163,184,.25);border-radius:10px;padding:.75rem 1rem;color:#f1f5f9;font-size:.95rem;cursor:pointer;transition:all .2s}.log-filter-select:focus{outline:none;border-color:#3b82f6;background:#0f172acc}.logs-table-section{display:flex;flex-direction:column;gap:1.5rem}.logs-table{width:100%;border-collapse:collapse}.logs-table thead{background:#0f172acc;border-bottom:2px solid rgba(148,163,184,.2)}.logs-table th{text-align:left;padding:1rem;font-weight:600;font-size:.85rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.logs-table tbody tr{border-bottom:1px solid rgba(148,163,184,.1);transition:background .2s}.logs-table tbody tr:last-child{border-bottom:none}.logs-table tbody tr:hover{background:#3b82f60d}.logs-table td{padding:.875rem 1rem;color:#cbd5e1;font-size:.95rem}.timestamp-cell{color:#94a3b8;font-size:.9rem;white-space:nowrap}.numeric-cell{font-family:Fira Code,Courier New,monospace;color:#e2e8f0;font-weight:500}.room-label{color:#cbd5e1;font-size:.9rem}.proximity-badge{background:#94a3b833;color:#cbd5e1;padding:.25rem .6rem;border-radius:6px;font-size:.85rem;display:inline-block}.load-more-container{display:flex;justify-content:center;padding:1.5rem 0}.load-more-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff;border-radius:10px;padding:.875rem 2rem;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.load-more-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #3b82f64d}.load-more-button:disabled{opacity:.7;cursor:not-allowed}@media (max-width: 768px){.device-manager{max-width:100%;max-height:100vh;border-radius:0}.devices-table{overflow-x:auto}.rooms-list{grid-template-columns:1fr}.device-filter{padding:.75rem 0}.device-filter-button{font-size:.85rem;padding:.5rem .85rem}.log-filters{flex-direction:column;gap:1rem}.log-filter-group{width:100%}.logs-table{font-size:.85rem}.logs-table th,.logs-table td{padding:.75rem .5rem}}
