body{margin:0;background:radial-gradient(circle at top left,#4c1d95 0,#020817 40%),#020817;color:#e5e7eb;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
.container{max-width:1200px;margin:0 auto;padding:18px 16px}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:#0b1220;border:1px solid #1f2937;border-radius:12px;box-shadow:0 10px 24px rgba(0,0,0,.25)}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.brand .logo{width:28px;height:28px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#22c55e,#2563eb)}
.btn{background:#111827;color:#e5e7eb;border:1px solid #1f2937;border-radius:999px;padding:6px 12px;font-size:12px;cursor:pointer}
.btn:hover{filter:brightness(1.05)}
.panel{margin-top:14px;background:#020617;border:1px solid #1f2937;border-radius:12px;padding:14px;box-shadow:0 10px 24px rgba(0,0,0,.25)}
.tabs{display:flex;gap:8px;align-items:center}
.tab{background:#0b1220;border:1px solid #1f2937;color:#9ca3af;border-radius:999px;padding:6px 12px;font-size:12px;cursor:pointer}
.tab.active{background:linear-gradient(135deg,#2563eb,#22c55e);color:#020617;border-color:transparent}
.fm-root{background:#050b16;border:1px solid #111827;border-radius:12px;padding:8px}
.fm-rooms{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%;height:420px}
.fm-room{position:relative;overflow:hidden;border-radius:10px;border:1px solid rgba(148,163,184,.18);background:linear-gradient(180deg,rgba(2,6,23,.86),rgba(2,6,23,.62));box-shadow:inset 0 1px 0 rgba(226,232,240,.06)}
.fm-room-title{position:absolute;top:10px;left:10px;z-index:6;font-weight:700;font-size:12px;color:rgba(226,232,240,.75);letter-spacing:.2px}
.fm-room-layer{position:absolute;inset:0}
.fm-room-glow{z-index:2;pointer-events:none}
.fm-room-hum{z-index:3;pointer-events:none;opacity:0}
.fm-room-sensors{z-index:5}

.fm-sensor{position:absolute;transform:translate(-50%,-50%);width:26px;height:26px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:12px;color:rgba(226,232,240,.92);background:rgba(15,23,42,.82);border:1px solid rgba(148,163,184,.26);box-shadow:0 6px 16px rgba(0,0,0,.35)}
.fm-sensor::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:calc(var(--glow-r,50px) * 2);height:calc(var(--glow-r,50px) * 2);border-radius:999px;background:radial-gradient(circle, var(--glow-core, rgba(34,197,94,.22)) 0%, var(--glow-mid, rgba(34,197,94,.10)) 40%, rgba(0,0,0,0) 72%);filter:blur(10px);z-index:-1;pointer-events:none}
.fm-sensor[data-focused="1"]{outline:2px solid rgba(226,232,240,.45);outline-offset:2px}
.fm-sensor[data-dim="1"]{opacity:.35}
.fm-sensor .fm-sensor-ring{position:absolute;inset:-6px;border-radius:999px;border:2px solid var(--ring, rgba(34,211,238,.55));opacity:.65;pointer-events:none}
.fm-sensor[data-critical="1"]{box-shadow:0 0 0 1px rgba(239,68,68,.35),0 10px 18px rgba(0,0,0,.45)}

.fm-room[data-hum="1"] .fm-room-hum{opacity:.55;background-image:radial-gradient(circle at 18px 18px, rgba(34,211,238,.18) 0 2px, transparent 3px),radial-gradient(circle at 40px 34px, rgba(20,184,166,.16) 0 2px, transparent 3px);background-size:54px 54px;background-position:0 0}
.fm-hint{color:#9ca3af;font-size:12px}
.hm-wrap{overflow:auto}
.hm-grid{display:grid;gap:8px;min-width:0}
.hm-header{display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:end}
.hm-row{display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:center}
.hm-device{font-size:12px;color:#9ca3af;white-space:nowrap}
.hm-time{display:grid;grid-auto-flow:column;grid-auto-columns:2px;gap:1px;font-size:10px;color:#64748b}
.hm-time div{text-align:center}
.hm-cells{display:grid;grid-auto-flow:column;grid-auto-columns:2px;gap:1px}
.hm-cell{width:2px;height:14px;border-radius:1px;border:1px solid rgba(148,163,184,.18);background:rgba(148,163,184,.08)}
.hm-day-boundary{box-shadow:inset 3px 0 0 rgba(226,232,240,.55)}
.legend{display:flex;flex-wrap:wrap;gap:10px;align-items:center;font-size:11px;color:#9ca3af;margin-top:10px}
.legend-item{display:inline-flex;align-items:center;gap:6px}
.legend-swatch{width:16px;height:10px;border-radius:3px;border:1px solid rgba(148,163,184,.22)}
.tooltip{position:fixed;z-index:80;pointer-events:none;background:#0b1220;border:1px solid #1f2937;border-radius:8px;padding:8px 10px;font-size:11px;color:#e5e7eb;box-shadow:0 10px 24px rgba(0,0,0,.45);display:none;max-width:240px}
.muted{color:#9ca3af;font-size:12px}
.empty{padding:18px 0;text-align:center;color:#9ca3af}

html.hm-embedded body{background:transparent}
html.hm-embedded .panel{margin-top:0;border-radius:0;border-left:0;border-right:0}
