:root{font-family:Aptos,Segoe UI,Trebuchet MS,sans-serif;color:#162033;background:radial-gradient(circle at top center,rgba(179,227,255,.58),transparent 36%),linear-gradient(180deg,#f6fbff,#eef6fb 44%,#edf5f8);color-scheme:light;--bg-soft: rgba(255, 255, 255, .82);--bg-strong: rgba(255, 255, 255, .94);--line: rgba(87, 121, 152, .14);--shadow: 0 20px 45px rgba(69, 112, 147, .12);--text-soft: #60748d;--blue: #2f93d1;--teal: #46c7b2;--orange: #f4a259;--red: #e26b6b}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}button,input,select{font:inherit}button{border:0}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px minmax(0,1fr)}.app-sidebar{padding:22px 18px;background:linear-gradient(180deg,#ffffffe6,#f6fbffd6);border-right:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;flex-direction:column;gap:20px}.brand-lockup{display:flex;align-items:center;gap:14px}.brand-mark{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;font-size:24px;font-weight:700;color:#fff;background:linear-gradient(135deg,#2f93d1,#46c7b2);box-shadow:0 10px 20px #46adc93d}.company-logo{width:44px;height:44px;object-fit:contain;border-radius:12px;background:#ffffffe6;border:1px solid var(--line);padding:4px}.brand-title{margin:0;font-size:1.05rem;font-weight:700}.brand-subtitle,.sidebar-heading,.section-copy,.card-note,.updated-at,.detail-footer,.activity-item span,.activity-item small,.table-empty,.empty-state,.primary-cell small,.detail-section-header span{color:var(--text-soft)}.brand-subtitle{margin:4px 0 0;font-size:.88rem}.side-nav{display:flex;flex-direction:column;gap:8px}.nav-link{border-radius:16px;padding:14px 16px;background:transparent;color:inherit;text-align:left;display:flex;flex-direction:column;gap:2px;cursor:pointer}.nav-link span{font-weight:700}.nav-link small{color:var(--text-soft)}.nav-link.active{background:linear-gradient(180deg,#c9e7ffd6,#eaf7fff5);box-shadow:inset 0 0 0 1px #4a91c02e}.sidebar-section{display:flex;flex-direction:column;gap:12px}.sidebar-heading,.section-kicker,.card-title,.metric-card p,.detail-item span{text-transform:uppercase;letter-spacing:.08em;font-size:.76rem;font-weight:700}.mini-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.mini-stat{background:var(--bg-soft);border:1px solid var(--line);border-radius:16px;padding:12px 14px;display:flex;flex-direction:column;gap:6px}.mini-stat strong{font-size:1.45rem}.mini-stat.online strong{color:#229b76}.mini-stat.stale strong{color:#cb8a1b}.mini-stat.offline strong{color:#d45858}.mini-stat.neutral strong{color:#265e90}.topology-panel{min-height:0;flex:1}.topology-building,.topology-group{display:flex;flex-direction:column;gap:8px}.topology-row,.topology-room,.topology-filter,.room-filter{border-radius:14px;border:1px solid transparent;background:#ffffffb3;color:inherit;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;text-align:left}.topology-row.active,.topology-room.active,.topology-filter.active,.room-filter.active{background:linear-gradient(180deg,#cdecffeb,#ecf8fff5);border-color:#4a91c02e}.topology-rooms,.topology-list{display:flex;flex-direction:column;gap:8px}.room-filter{margin-left:14px;font-size:.94rem}.app-main{padding:20px 24px 28px;display:flex;flex-direction:column;gap:18px}.topbar{display:flex;justify-content:space-between;align-items:center;gap:18px}.searchbox{width:min(420px,100%);display:flex;flex-direction:column;gap:8px}.searchbox span{position:absolute;left:-9999px}.searchbox input,.filter-row select{width:100%;border-radius:16px;border:1px solid rgba(109,148,181,.16);background:#ffffffbd;padding:14px 16px;color:inherit;box-shadow:inset 0 1px #ffffffb3}.topbar-actions{display:flex;align-items:center;gap:12px}.current-user-pill{border-radius:999px;padding:8px 12px;background:#f0f8ffe6;border:1px solid rgba(89,127,156,.16);color:#2f587d;font-weight:700}.health-pill{border-radius:999px;padding:10px 14px;font-weight:700}.health-pill.good{background:#46c7b226;color:#15806a}.health-pill.bad{background:#e26b6b24;color:#b33f3f}.avatar-badge{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-weight:700;color:#295886;background:linear-gradient(135deg,#d8edfff2,#fffffff5);border:1px solid var(--line)}.page-heading{display:flex;justify-content:space-between;gap:24px;align-items:flex-end}.page-heading-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.page-heading-meta{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap}.page-heading h1,.detail-hero h3{margin:0}.section-kicker{margin:0 0 6px;color:#6e8ca8}.section-copy{margin:8px 0 0;max-width:720px}.error-banner{border-radius:18px;padding:14px 16px;background:#ed7e7e24;border:1px solid rgba(226,107,107,.22);color:#aa3e3e}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(440px,100%);background:linear-gradient(180deg,#ffffffeb,#fcfeffdb);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:24px;display:flex;flex-direction:column;gap:18px}.login-form{display:flex;flex-direction:column;gap:12px}.login-form label{display:flex;flex-direction:column;gap:6px}.login-form input{border-radius:12px;border:1px solid rgba(109,148,181,.16);background:#ffffffbd;padding:10px 12px}.notice-banner{border-radius:18px;padding:12px 16px;background:#4797d31a;border:1px solid rgba(47,147,209,.18);color:#245f93}.dashboard-layout,.single-card-layout{display:flex;flex-direction:column;gap:18px}.hero-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.compact-hero{grid-template-columns:repeat(3,minmax(0,1fr))}.metric-card,.card{background:linear-gradient(180deg,#ffffffeb,#fcfeffdb);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow)}.metric-card{padding:20px 22px;display:flex;flex-direction:column;gap:10px}.metric-card strong{font-size:clamp(2rem,3vw,3rem);line-height:1}.metric-card span{color:var(--text-soft)}.metric-card.tone-online strong{color:#229b76}.metric-card.tone-stale strong{color:#d1901f}.metric-card.tone-offline strong{color:#d45858}.metric-card.tone-neutral strong{color:#286fa7}.dashboard-grid{display:grid;grid-template-columns:1.45fr .85fr;gap:18px}.card{padding:20px 22px}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:16px}.split-header{align-items:center}.ghost-button,.secondary-button,.primary-button{border-radius:14px;padding:10px 14px;cursor:pointer}.ghost-button,.secondary-button{background:#f0f8ffe6;color:#2f587d;border:1px solid rgba(89,127,156,.16)}.primary-button{color:#fff;background:linear-gradient(135deg,#2f93d1,#46c7b2);box-shadow:0 12px 20px #40afc43d}.primary-button:disabled,.secondary-button:disabled,.ghost-button:disabled{opacity:.5;cursor:not-allowed}.summary-table{display:flex;flex-direction:column;gap:10px}.summary-head,.summary-row{display:grid;grid-template-columns:1.05fr 1.15fr 1.15fr .65fr;gap:14px;align-items:center;line-height:1.4}.summary-head{padding:0 0 8px;color:var(--text-soft);border-bottom:1px solid rgba(108,144,177,.16)}.summary-row{padding:12px 0;border-bottom:1px solid rgba(108,144,177,.1)}.summary-head span,.summary-row span{min-width:0}.activity-list{display:flex;flex-direction:column;gap:12px}.compact-list{gap:10px}.activity-item{display:flex;flex-direction:column;gap:4px;padding-bottom:12px;border-bottom:1px solid rgba(108,144,177,.12)}.compact-item{padding-bottom:10px}.footer-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.footer-metric{border-radius:20px;border:1px solid var(--line);background:#ffffffb8;padding:16px 18px;display:flex;justify-content:space-between;align-items:center}.monitor-layout{display:grid;grid-template-columns:290px minmax(0,1.15fr) minmax(360px,.9fr);gap:18px}.monitor-layout-devices{grid-template-columns:290px minmax(0,1fr);align-items:start;width:100%}.topology-card,.table-card,.detail-card{min-height:0}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:14px 12px;text-align:left;border-bottom:1px solid rgba(108,144,177,.12)}.data-table th{color:#4f6781;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}.data-table tbody tr{cursor:pointer}.data-table tbody tr:focus-visible{outline:2px solid rgba(47,147,209,.45);outline-offset:-2px;background:#d5f0ff6b}.data-table tbody tr.is-selected,.data-table tbody tr:hover{background:#d5f0ff85}.compact-table tbody tr{cursor:default}.table-empty{text-align:center;padding:28px 12px}.primary-cell{display:flex;flex-direction:column;gap:4px}.status-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.status-online,.status-chip.online,.status-chip.executed{background:#46c7b226;color:#147966}.status-stale,.status-chip.stale,.status-chip.acknowledged,.status-chip.queued,.status-chip.sent{background:#f4a25929;color:#b06c19}.status-offline,.status-chip.offline,.status-chip.failed{background:#e26b6b24;color:#b64444}.detail-actions{display:flex;gap:10px}.command-devices-table th,.command-devices-table td{padding-top:8px;padding-bottom:8px}.command-devices-table td{line-height:1.3}.command-devices-table .detail-actions{gap:8px}.detail-hero{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:18px}.detail-hero p{margin:6px 0 0;color:var(--text-soft)}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.detail-item{border-radius:16px;border:1px solid rgba(108,144,177,.12);background:#f8fcffdb;padding:14px;display:flex;flex-direction:column;gap:8px}.detail-item strong{font-size:.98rem}.detail-item.wide{grid-column:1 / -1}.detail-section{margin-top:18px;padding-top:18px;border-top:1px solid rgba(108,144,177,.12)}.detail-section-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.detail-footer{margin-top:18px;padding-top:14px;border-top:1px solid rgba(108,144,177,.12);font-size:.92rem}.device-table-card{width:100%;min-width:0;justify-self:stretch;overflow:hidden}.monitor-layout-devices .table-card{width:100%;min-width:0;justify-self:stretch}.devices-table th,.devices-table td{padding:6px 7px;vertical-align:middle;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.devices-table td{line-height:1.15}.device-name-cell{max-width:160px;font-weight:700}.devices-table td:nth-child(2){max-width:140px}.devices-table td:nth-child(7){max-width:140px}.device-note-cell{max-width:170px;color:var(--text-soft)}.devices-table td:last-child{max-width:170px}.status-detail-button{padding:4px 8px;gap:6px;font-size:.68rem;line-height:1;cursor:pointer;border:0;text-transform:uppercase}.detail-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#11213266;display:flex;align-items:flex-start;justify-content:center;padding:36px 20px;overflow-y:auto}.detail-modal{width:min(1080px,100%);max-height:calc(100vh - 120px);overflow-y:auto}.detail-modal .detail-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.detail-modal .detail-item{padding:10px 12px;gap:4px}.detail-modal .detail-item.compact{min-height:0}.detail-modal .detail-item strong{font-size:.88rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-modal .detail-item.wide strong{white-space:normal;overflow:visible;text-overflow:clip;word-break:break-word}.detail-modal .detail-item.multiline strong{white-space:pre-line;overflow:visible;text-overflow:clip}.detail-modal-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:18px}.detail-close-button{flex-shrink:0}@media (max-width: 1280px){.hero-grid,.compact-hero,.footer-strip,.dashboard-grid,.monitor-layout,.app-shell{grid-template-columns:1fr}}@media (max-width: 900px){.app-main,.app-sidebar{padding:18px}.page-heading,.topbar{flex-direction:column;align-items:stretch}.summary-head,.summary-row{grid-template-columns:1.2fr repeat(4,.6fr);font-size:.88rem}.detail-grid{grid-template-columns:1fr}}.card-span-two{grid-column:span 1}.sidebar-overview-list{gap:10px}.sidebar-building-chip,.building-summary-card{border-radius:18px;border:1px solid var(--line);background:#ffffffd1;color:inherit;text-align:left;padding:14px 16px;display:flex;flex-direction:column;gap:6px;cursor:pointer}.sidebar-building-chip span,.building-summary-card span{font-weight:700}.sidebar-building-chip small,.building-summary-card small,.building-summary-card strong{color:var(--text-soft)}.building-summary-card strong{font-size:1.8rem;color:#286fa7}.building-layout,.command-layout{display:flex;flex-direction:column;gap:18px}.compact-button{min-height:34px;padding:8px 12px;border-radius:12px;font-size:12px}.building-grid{display:grid;grid-template-columns:1.4fr .6fr;gap:18px}.floor-stack{display:flex;flex-direction:column;gap:18px}.floor-group{border-radius:20px;border:1px solid rgba(44,112,166,.38);background:linear-gradient(180deg,#87c6ecfa,#bce7f0f5),#9ad6ebf0;padding:16px;box-shadow:inset 0 1px #ffffff9e,0 12px 28px #2f78ac1f}.floor-group-header,.room-overview-head,.scope-summary{display:flex;justify-content:space-between;align-items:center;gap:12px}.room-overview-head>div,.floor-title-block{display:flex;flex-direction:column;gap:6px}.floor-group-header{margin-bottom:14px}.floor-group-header span,.status-inline{color:var(--text-soft)}.building-room-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.room-overview-card{border-radius:18px;border:1px solid rgba(108,144,177,.12);background:#ffffffd1;padding:14px;display:flex;flex-direction:column;gap:12px}.room-overview-head small{color:var(--text-soft);line-height:1.35}.room-device-list{display:flex;flex-direction:column;gap:8px}.room-device-row{border-radius:14px;border:1px solid rgba(108,144,177,.12);background:#f5faffe6;color:inherit;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;text-align:left}.command-toolbar{display:flex;gap:10px;flex-wrap:wrap}.command-toolbar select{border-radius:14px;border:1px solid rgba(109,148,181,.16);background:#ffffffbd;padding:10px 12px}.toggle-chip{display:inline-flex;align-items:center;gap:8px;border-radius:14px;border:1px solid rgba(109,148,181,.16);background:#ffffffc7;padding:10px 12px;color:#2f587d}.toggle-chip input{margin:0}.scope-summary{padding:16px 0 18px;border-top:1px solid rgba(108,144,177,.12);border-bottom:1px solid rgba(108,144,177,.12);margin-bottom:16px;flex-wrap:wrap}.scope-chip{min-width:120px;border-radius:16px;border:1px solid rgba(108,144,177,.12);background:#f8fcffdb;padding:12px 14px;display:flex;flex-direction:column;gap:6px}.scope-chip span{color:var(--text-soft);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}.scope-chip strong{font-size:1.3rem}@media (min-width: 1281px){.card-span-two{grid-column:span 1}}@media (max-width: 1280px){.building-grid,.building-room-grid{grid-template-columns:1fr}}.app-main{padding:14px 16px 18px;gap:12px;font-size:13px}.topbar{gap:12px}.searchbox{width:min(360px,100%)}.searchbox input,.filter-row select,.command-toolbar select{border-radius:12px;padding:10px 12px;font-size:13px}.topbar-actions{gap:8px}.health-pill{padding:8px 12px;font-size:12px}.avatar-badge{width:36px;height:36px;font-size:12px}.page-heading{gap:14px;align-items:center}.page-heading h1{font-size:1.8rem;line-height:1.05}.section-kicker{margin:0 0 4px;font-size:.68rem}.section-copy{margin:4px 0 0;max-width:860px;font-size:.88rem;line-height:1.35}.updated-at{font-size:12px}.error-banner{border-radius:14px;padding:10px 12px;font-size:12px}.notice-banner{border-radius:14px;padding:9px 12px;font-size:12px}.dashboard-layout,.single-card-layout,.building-layout,.command-layout,.hero-grid,.dashboard-grid,.monitor-layout,.building-grid,.footer-strip{gap:12px}.monitor-layout{grid-template-columns:250px minmax(0,1.1fr) minmax(320px,.82fr)}.monitor-layout.monitor-layout-devices{grid-template-columns:250px minmax(0,1fr)}.metric-card,.card{border-radius:18px}.metric-card{padding:14px 16px;gap:6px}.metric-card p{font-size:.68rem}.metric-card strong{font-size:clamp(1.55rem,2vw,2.1rem)}.metric-card span{font-size:.82rem;line-height:1.3}.card{padding:14px 16px}.card-header{gap:10px;margin-bottom:10px}.card-title,.detail-item span,.sidebar-heading,.section-kicker{font-size:.68rem;letter-spacing:.07em}.card-note{font-size:.8rem;line-height:1.3}.ghost-button,.secondary-button,.primary-button{border-radius:12px;padding:8px 12px;font-size:12px}.summary-table{gap:4px}.summary-head,.summary-row{gap:10px;font-size:12px}.summary-head{padding:0 0 6px}.summary-row{padding:8px 0}.activity-list{gap:8px}.activity-item{gap:2px;padding-bottom:8px}.activity-item strong,.primary-cell strong,.room-device-row span,.room-overview-head strong{font-size:13px}.activity-item span,.activity-item small,.primary-cell small,.detail-section-header span,.room-overview-head small{font-size:11px}.footer-metric{border-radius:14px;padding:10px 12px;font-size:12px}.topology-row,.topology-room,.topology-filter,.room-filter,.sidebar-building-chip,.building-summary-card,.room-device-row{border-radius:12px}.topology-row,.topology-room,.topology-filter,.room-filter{padding:8px 10px;font-size:12px}.topology-list,.topology-rooms,.topology-group,.topology-building,.room-device-list{gap:6px}.data-table th,.data-table td{padding:9px 8px;font-size:12px}.data-table th{font-size:.72rem}.table-empty{padding:18px 10px;font-size:12px}.status-chip{padding:4px 8px;font-size:.66rem}.detail-actions{gap:8px}.detail-hero{gap:8px;margin-bottom:10px}.detail-hero h3{font-size:1.1rem}.detail-hero p{margin:3px 0 0;font-size:12px}.detail-grid{gap:8px}.detail-item{border-radius:12px;padding:10px;gap:4px}.detail-item strong{font-size:.84rem;line-height:1.3}.detail-section{margin-top:10px;padding-top:10px}.detail-section-header{margin-bottom:8px}.detail-footer{margin-top:10px;padding-top:8px;font-size:11px}.scope-summary{padding:10px 0 12px;margin-bottom:10px;gap:8px}.scope-chip{min-width:96px;border-radius:12px;padding:8px 10px;gap:4px}.scope-chip span{font-size:.66rem}.scope-chip strong{font-size:1rem}.floor-stack{gap:12px}.floor-group{border-radius:14px;padding:12px}.floor-group-header{margin-bottom:10px}.building-room-grid{gap:10px}.room-overview-card{border-radius:14px;padding:10px;gap:8px}.logs-hero-grid{grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width: 1280px){.logs-hero-grid,.hero-grid,.compact-hero,.footer-strip,.dashboard-grid,.monitor-layout,.building-grid,.building-room-grid{grid-template-columns:1fr}}.nav-link-main,.summary-title,.sidebar-building-main,.room-device-main,.floor-badge,.log-meta-row,.stage-pill{display:inline-flex;align-items:center;gap:8px}.nav-link-main{font-weight:700}.nav-icon,.metric-icon,.searchbox-icon,.inline-icon,.log-detail-icon,.building-roof-icon{flex:0 0 auto}.nav-icon{width:15px;height:15px;color:#4d7296}.inline-icon{width:13px;height:13px}.metric-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.metric-icon{width:28px;height:28px;padding:7px;border-radius:12px;color:#fff;background:#6a91b5;box-shadow:inset 0 1px #ffffff40}.metric-card.tone-online .metric-icon{background:linear-gradient(180deg,#2ea97f,#1f8865)}.metric-card.tone-stale .metric-icon{background:linear-gradient(180deg,#d69b31,#b97810)}.metric-card.tone-neutral .metric-icon{background:linear-gradient(180deg,#4283c4,#2e659f)}.metric-card.tone-offline .metric-icon{background:linear-gradient(180deg,#d46969,#b54747)}.metric-card-top p{margin:0;line-height:1.25}.searchbox-field{display:flex;align-items:center;gap:10px;border-radius:12px;border:1px solid rgba(109,148,181,.16);background:#ffffffbd;padding:0 12px;box-shadow:inset 0 1px #ffffffb3}.searchbox-field input{border:0;background:transparent;box-shadow:none;padding:10px 0;min-width:0}.searchbox-field input:focus{outline:none}.searchbox-icon{width:14px;height:14px;color:#7892aa}.status-dot{width:7px;height:7px;border-radius:999px;background:currentColor}.sidebar-building-main{font-weight:700}.building-grid-enhanced{grid-template-columns:minmax(0,1.45fr) 320px;align-items:start}.building-stage-card{overflow:hidden}.building-stage-meta{display:flex;flex-wrap:wrap;gap:8px}.mapping-toolbar{align-items:center;justify-content:flex-end}.hidden-file-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.stage-pill{padding:6px 10px;border-radius:999px;background:#eef7ffe6;border:1px solid rgba(109,148,181,.16);color:#41637f;font-size:11px}.building-stage{display:grid;grid-template-columns:minmax(250px,.78fr) minmax(0,1.22fr);gap:14px;align-items:start}.building-facade{position:sticky;top:12px;border-radius:18px;padding:12px;background:linear-gradient(180deg,#25587e0f,#fff0),linear-gradient(180deg,#eef8fff5,#e2eff8eb);border:1px solid rgba(95,132,163,.14);box-shadow:inset 0 1px #fffc}.building-roof{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:14px 14px 8px 8px;background:linear-gradient(180deg,#eaf6ff,#dbeefd);border:1px solid rgba(88,128,164,.16)}.building-roof-copy{display:flex;flex-direction:column;gap:4px;min-width:0}.building-roof strong,.log-detail-hero h3{margin:0;font-size:15px}.building-roof span,.log-detail-hero p{display:block;margin-top:2px;color:var(--text-soft);font-size:11px}.building-roof-icon{width:18px;height:18px;color:#4679a4}.building-floors{display:flex;flex-direction:column;gap:8px;padding-top:10px}.building-floor-band{display:grid;grid-template-columns:72px minmax(0,1fr);gap:8px;padding:8px;border-radius:12px;background:#ffffffbd;border:1px solid rgba(103,139,169,.12)}.building-floor-label{display:flex;flex-direction:column;justify-content:center;gap:2px;padding-right:6px;border-right:1px dashed rgba(103,139,169,.18)}.building-floor-label strong{font-size:11px}.building-floor-label small,.room-window-card small{font-size:10px;color:var(--text-soft)}.building-floor-windows{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.room-window-card{border-radius:10px;padding:8px;background:linear-gradient(180deg,#dcf1ffeb,#f8fcfff2);border:1px solid rgba(108,144,177,.12);box-shadow:inset 0 1px #ffffffb8;display:flex;flex-direction:column;gap:6px}.room-window-card.online{border-color:#41be8d3d}.room-window-card.stale{border-color:#eba44f47}.room-window-card.offline{border-color:#dd6c6c47}.room-window-top{display:flex;flex-direction:column;align-items:flex-start;gap:6px;margin-bottom:0}.room-window-top span{font-size:11px;font-weight:700}.status-mini-bar{display:flex;width:100%;max-width:84px;height:6px;overflow:hidden;border-radius:999px;background:#cfdee9cc}.status-mini{height:100%}.status-mini.online{background:#41be8d}.status-mini.stale{background:#eba44f}.status-mini.offline{background:#dd6c6c}.building-floor-detail-stack{display:flex;flex-direction:column;gap:10px}.floor-group-rich{background:#f8fcffe6}.floor-title-block{display:flex;flex-direction:column;gap:3px}.floor-status-cluster{display:flex;gap:10px;flex-wrap:wrap}.floor-badge{width:fit-content;padding:4px 8px;border-radius:999px;background:#e1f1ffe6;color:#446a8c;font-size:10px;text-transform:uppercase;letter-spacing:.05em}.room-overview-building{background:linear-gradient(180deg,#ffffffeb,#f6fbffeb)}.device-note-editor{display:flex;flex-direction:column;gap:10px}.device-note-editor textarea{width:100%;min-height:96px;resize:vertical;border-radius:14px;border:1px solid rgba(109,148,181,.16);background:#ffffffe0;padding:10px 12px;font:inherit;color:var(--text-strong)}.room-device-main{font-weight:600}.building-side-card{position:sticky;top:12px}.logs-layout{display:grid;grid-template-columns:minmax(0,1.2fr) 340px;gap:12px;align-items:start}.logs-table-card,.logs-detail-card{min-height:0}.filter-row-inline{min-width:150px}.log-type-strip{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.log-type-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 9px;border-radius:999px;font-size:11px;border:1px solid rgba(108,144,177,.12)}.log-type-chip strong{font-size:11px}.log-type-chip.info{background:#e7f4ffe6;color:#3f6f96}.log-type-chip.warning{background:#fff3e2f5;color:#ad6d1f}.log-type-chip.critical{background:#ffeaeaf0;color:#b55050}.log-type-chip.heartbeat,.log-type-pill.heartbeat,.log-detail-hero.heartbeat{background:#eaf6ffeb;color:#245f9a}.log-type-chip.inventory,.log-type-pill.inventory,.log-detail-hero.inventory{background:#e8faf2f0;color:#1b8a65}.log-type-chip.command,.log-type-pill.command,.log-detail-hero.command{background:#fff3e2f5;color:#ad6d1f}.log-type-chip.presence,.log-type-pill.presence,.log-detail-hero.presence{background:#ffebebf0;color:#b44444}.log-type-chip.audit,.log-type-pill.audit,.log-detail-hero.audit{background:#f1eefff0;color:#6f5ab8}.log-type-pill{display:inline-flex;align-items:center;justify-content:center;min-width:92px;padding:5px 10px;border-radius:999px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.log-message-cell{line-height:1.35;color:#2f4f6c}.logs-table tbody tr td:first-child{min-width:118px}.logs-detail-card{position:sticky;top:12px}.log-detail-stack{display:flex;flex-direction:column;gap:10px}.log-detail-hero{display:grid;grid-template-columns:42px minmax(0,1fr);gap:10px;align-items:start;padding:10px;border-radius:14px;border:1px solid rgba(108,144,177,.12)}.log-detail-hero.info{background:#eaf6ffe0}.log-detail-hero.warning{background:#fff4e4f0}.log-detail-hero.critical{background:#ffebebf0}.log-detail-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.log-detail-summary-row{border-radius:14px;padding:10px 12px;background:#f7fbffeb;border:1px solid rgba(108,144,177,.12);display:flex;flex-direction:column;gap:6px}.log-detail-summary-row span{color:var(--text-soft);font-size:11px;text-transform:uppercase;letter-spacing:.05em}.log-detail-summary-row strong{font-size:13px;line-height:1.35}.log-detail-message{border-radius:16px;padding:14px 16px;background:#f7fbfff5;border:1px solid rgba(108,144,177,.12);color:#23445f;line-height:1.5;white-space:pre-wrap}.log-detail-icon-wrap{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:#ffffffb8;border:1px solid rgba(108,144,177,.12)}.log-detail-icon{width:18px;height:18px}.log-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:10px;padding:10px 12px;background:#f7fbffd1}.log-detail-grid .detail-item span{text-transform:none;letter-spacing:0;font-size:12px;font-weight:500}.log-detail-grid .detail-item strong{font-size:1rem;font-weight:700}.log-detail-section{margin-top:14px;padding:0;border-top:0}.log-detail-grid .detail-item{background:transparent;border:0;border-radius:0;padding:8px 6px}.log-meta-list{display:flex;flex-direction:column;gap:8px}.log-meta-row{padding:8px 10px;border-radius:12px;background:#f7fbffe6;border:1px solid rgba(108,144,177,.12);color:#44627e;font-size:12px}@media (max-width: 1280px){.building-grid-enhanced,.building-stage,.logs-layout{grid-template-columns:1fr}.building-facade,.building-side-card,.logs-detail-card{position:static}}.nav-icon{width:18px;height:18px;color:#245f9a}.inline-icon{width:14px;height:14px;color:#2b6aa8}.metric-icon{width:18px;height:18px;color:#1d5e94}.nav-link.active .nav-icon,.nav-link.active .inline-icon,.building-summary-card .inline-icon,.sidebar-building-chip .inline-icon,.stage-pill .inline-icon,.floor-badge .inline-icon,.room-device-main .inline-icon,.log-type-chip .inline-icon,.log-meta-row .inline-icon{color:inherit}.summary-title,.sidebar-building-main,.room-device-main{font-weight:700}.metric-card-top{align-items:center}.metric-card .metric-icon{padding:4px;border-radius:10px;background:#d2e8f8e6}.building-filter-strip{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.floor-chip{border-radius:999px;padding:6px 10px;background:#f4f9ffeb;border:1px solid rgba(106,143,174,.16);color:#40617e;cursor:pointer}.floor-chip.active{background:linear-gradient(180deg,#2f93d1,#2676af);color:#fff;border-color:transparent;box-shadow:0 8px 18px #2f93d138}.room-window-card{cursor:pointer}.room-window-card.active,.room-overview-card.active{border-color:#2f93d159;box-shadow:0 8px 20px #2f93d124}.compact-ghost{padding:6px 9px;font-size:11px}.building-focus-stack{display:flex;flex-direction:column;gap:10px}.focus-hero{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:10px;border-radius:14px;background:linear-gradient(180deg,#eaf6fff2,#f8fcfff5);border:1px solid rgba(108,144,177,.12)}.focus-hero strong{display:block;font-size:14px}.focus-hero small{color:var(--text-soft);font-size:11px}.compact-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.logs-filter-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-bottom:10px}.severity-pill{display:inline-flex;align-items:center;justify-content:center;min-width:72px;padding:4px 8px;border-radius:999px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.severity-pill.info{background:#e2f1fff2;color:#245f9a}.severity-pill.warning{background:#fff1dffa;color:#b26d1f}.severity-pill.critical{background:#ffe6e6fa;color:#b44444}.logs-table td,.logs-table th{vertical-align:top}.log-detail-icon-wrap{background:#ffffffe0}.log-detail-icon{width:20px;height:20px;color:#245f9a}.log-detail-hero.warning .log-detail-icon{color:#b26d1f}.log-detail-hero.critical .log-detail-icon{color:#b44444}@media (max-width: 1280px){.logs-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 900px){.logs-filter-grid,.compact-detail-grid,.log-detail-summary{grid-template-columns:1fr}}.dashboard-layout-rich{gap:12px}.dashboard-kpi-row{grid-template-columns:repeat(3,minmax(0,1fr))}.dashboard-main-grid{display:flex;flex-direction:column;gap:12px}.dashboard-timeline-card{min-height:0;width:100%}.dashboard-scope-strip{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 12px}.dashboard-scope-chip{min-width:140px;border-radius:16px;border:1px solid rgba(108,144,177,.14);background:#f7fbffeb;color:inherit;padding:10px 12px;display:flex;flex-direction:column;gap:4px;text-align:left;cursor:pointer}.dashboard-scope-chip strong{font-size:13px;line-height:1.2}.dashboard-scope-chip span{color:var(--text-soft);font-size:11px}.dashboard-scope-chip.active{background:linear-gradient(180deg,#d1ebfffa,#ebf6fffa);border-color:#4f96d147}.dashboard-stack{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;width:100%}.dashboard-timeline-meta{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.timeline-pill{border-radius:999px;border:1px solid rgba(108,144,177,.16);background:#f3f9fff5;color:#436781;padding:6px 10px;font-size:11px;font-weight:700}.dashboard-selector-row{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1.1fr) minmax(0,.8fr);gap:10px;align-items:end;margin-bottom:12px}.dashboard-select{display:flex;flex-direction:column;gap:6px}.dashboard-select span{color:var(--text-soft);font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}.dashboard-select select,.dashboard-select input{width:100%;border-radius:14px;border:1px solid rgba(109,148,181,.16);background:#ffffffc7;padding:10px 12px;color:inherit}.timeline-status-row{min-height:24px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.timeline-scope-label,.timeline-loading-label{color:var(--text-soft);font-size:12px}.timeline-loading-label{white-space:nowrap}.dashboard-room-chip-strip{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.dashboard-room-chip{border-radius:16px;border:1px solid rgba(108,144,177,.14);background:#f7fbffe0;color:inherit;padding:10px 12px;display:flex;flex-direction:column;gap:4px;min-width:140px;text-align:left;cursor:pointer}.dashboard-room-chip strong{font-size:13px}.dashboard-room-chip span{color:var(--text-soft);font-size:11px}.dashboard-room-chip.active{background:linear-gradient(180deg,#cae9fffa,#e9f6fff5);border-color:#4f96d147}.timeline-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:12px}.timeline-summary-card{padding:10px 12px;border-radius:14px;border:1px solid rgba(108,144,177,.12);background:#f8fcffeb;display:flex;flex-direction:column;gap:4px}.timeline-summary-card span{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft)}.timeline-summary-card strong{font-size:15px;line-height:1.2}.timeline-summary-card small{color:var(--text-soft);font-size:11px}.timeline-plot-shell{border-radius:18px;border:1px solid rgba(108,144,177,.12);background:#f8fcffe6;padding:12px;display:grid;grid-template-columns:48px minmax(0,1fr);gap:10px;align-items:stretch;overflow:hidden}.timeline-y-axis{display:flex;flex-direction:column;justify-content:space-between;padding:4px 0 28px;color:var(--text-soft);font-size:11px}.timeline-plot{position:relative;min-width:0;display:flex;flex-direction:column;gap:8px}.timeline-grid-lines{position:absolute;top:0;right:0;bottom:28px;left:0;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}.timeline-grid-lines span{display:block;border-top:1px solid rgba(108,144,177,.12)}.timeline-vertical-guides{position:absolute;top:0;right:0;bottom:28px;left:0;pointer-events:none}.timeline-vertical-guides span{position:absolute;top:0;bottom:0;width:0;border-left:1px dashed rgba(108,144,177,.18)}.timeline-bars{height:180px;display:flex;gap:1px;position:relative;z-index:1}.timeline-column{position:relative;height:100%;flex:1 1 0;min-width:0}.timeline-bar-blue{position:absolute;left:0;right:0;bottom:0;width:100%;border-radius:999px 999px 0 0;background:linear-gradient(180deg,#6fb5ff,#2f93d1);box-shadow:inset 0 1px #ffffff52}.timeline-axis{display:flex;justify-content:space-between;align-items:center;margin-top:2px;color:var(--text-soft);font-size:11px}.timeline-axis span:first-child{text-align:left}.timeline-axis span:last-child{text-align:right}@media (max-width: 1280px){.timeline-plot-shell{grid-template-columns:40px minmax(0,1fr)}.timeline-bars{height:160px}}.attention-room-list{display:flex;flex-direction:column;gap:10px}.attention-room-item{border-radius:16px;border:1px solid rgba(108,144,177,.12);background:#f8fcffe6;color:inherit;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;gap:12px;text-align:left;cursor:pointer}.attention-room-item strong{display:block;line-height:1.2}.attention-room-item small{display:block;color:var(--text-soft);margin-top:4px;font-size:11px}.attention-room-item span{border-radius:999px;border:1px solid rgba(108,144,177,.14);background:#ffffffe6;color:#355f7f;padding:4px 8px;font-size:11px;font-weight:700;white-space:nowrap}.timeline-summary-list{display:flex;flex-direction:column;gap:8px}.timeline-summary-row{display:flex;justify-content:space-between;gap:12px;align-items:baseline;padding:8px 10px;border-radius:12px;background:#f7fbffeb;border:1px solid rgba(108,144,177,.1)}.timeline-summary-row span{color:var(--text-soft);font-size:12px}.timeline-summary-row strong{font-size:13px}.dashboard-kpi-row .metric-card strong{letter-spacing:-.02em}.dashboard-kpi-row .metric-card span{font-size:.8rem}.dashboard-grid-rich{align-items:start}.hotspot-item{border-radius:12px;padding:8px 10px;background:#f7fbffe6;border:1px solid rgba(108,144,177,.1);display:flex;flex-direction:column;gap:4px}.pipeline-item{border-radius:12px;padding:8px 10px;background:#f8fcffeb;border:1px solid rgba(108,144,177,.1);display:flex;flex-direction:column;gap:4px}.hotspot-item strong,.pipeline-item strong,.activity-item strong{line-height:1.25}.hotspot-item span,.hotspot-item small,.pipeline-item span,.pipeline-item small,.activity-item span,.activity-item small{line-height:1.45}@media (max-width: 1280px){.dashboard-kpi-row,.dashboard-stack{grid-template-columns:1fr}}
