:root{--bg:#f7f4ee;--bg-elevated:#fff;--text:#0f172a;--muted:#475569;--border:#0f172a1f;--card-shadow:0 16px 40px #0f172a14;--accent:#0f766e;--accent-contrast:#fff;--surface:#fff;--surface-soft:#e7f5f2;--danger:#b91c1c;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--font-sans:"Inter"}:root[data-theme=dark]{--bg:#0b1220;--bg-elevated:#101a2d;--text:#e5e7eb;--muted:#94a3b8;--border:#94a3b82e;--card-shadow:0 20px 50px #00000059;--accent:#34d399;--accent-contrast:#06241d;--surface:#101a2d;--surface-soft:#18253c;--danger:#f87171;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box}html,body{background:var(--bg);min-height:100%;color:var(--text);font-family:var(--font-sans), system-ui, sans-serif;margin:0}a{color:inherit}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-shell{background:radial-gradient(circle at 0 0,#0f766e1f,#0000 28%),radial-gradient(circle at 100% 0,#f59e0b1a,#0000 24%),linear-gradient(135deg,#f7f4ee 0%,#eef3f7 100%);min-height:100vh;display:flex}.app-sidebar{background:var(--surface);width:280px;color:var(--text);flex-direction:column;gap:20px;padding:24px 18px;transition:width .18s,padding .18s;display:flex;overflow:hidden;box-shadow:2px 0 20px #0f172a2e}.app-shell.sidebar-collapsed .app-sidebar{width:96px;padding-inline:12px}.sidebar-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.sidebar-brand{margin-bottom:6px;font-size:18px;font-weight:700}.sidebar-brand-subtitle{color:var(--muted);font-size:12px}.sidebar-toggle{justify-content:center;align-items:center;min-width:42px;padding:8px 12px;display:inline-flex}.sidebar-action{justify-content:flex-start;align-items:center;gap:10px;display:inline-flex}.sidebar-action-icon{justify-content:center;width:18px;display:inline-flex}.sidebar-nav{gap:8px;display:grid}.sidebar-nav-item{color:var(--text);background:var(--surface-soft);box-shadow:none;border:1px solid #0000;border-radius:10px;padding:10px 12px;font-weight:600;text-decoration:none}.sidebar-nav-item.active{background:#2563eb24;border-color:#2563eb59;font-weight:700;box-shadow:0 10px 20px #2563eb24}.sidebar-nav-item-content{align-items:center;gap:10px;display:inline-flex}.sidebar-summary{gap:14px;margin-top:auto;display:grid}.sidebar-summary-card{background:#ffffff0f;border-radius:12px;gap:4px;padding:14px;display:grid}.sidebar-summary-title{color:#94a3b8;margin-bottom:6px;font-size:12px}.sidebar-summary-main{font-weight:700}.sidebar-summary-sub{color:var(--muted);font-size:13px}.sidebar-summary-meta{color:var(--muted);margin-top:6px;font-size:12px}.sidebar-tenant-switcher{gap:8px;margin-top:10px;display:grid}.sidebar-select{background:var(--surface);width:100%;color:var(--text);border:1px solid #94a3b859;border-radius:10px;padding:8px 10px}.app-main{flex:1;padding:24px;overflow:auto}.blueprint-canvas{border:1px dashed var(--border);background:linear-gradient(135deg,#2563eb0d,#0f172a05);border-radius:18px;place-items:center;width:100%;height:clamp(320px,65vh,560px);min-height:320px;margin-top:12px;display:grid;position:relative;overflow:hidden}.blueprint-image{object-fit:contain;width:100%;height:100%;display:block}.blueprint-stage{position:absolute}.blueprint-empty{color:var(--muted);text-align:center;padding:20px}.blueprint-marker{color:#fff;text-align:center;cursor:grab;background:#2563ebeb;border:none;border-radius:999px;gap:2px;padding:8px 12px;display:grid;position:absolute;transform:translate(-50%,-50%);box-shadow:0 12px 24px #2563eb47}.blueprint-marker.alert{background:var(--danger);box-shadow:0 12px 24px #b91c1c47}.blueprint-sensor-chip{border:1px solid var(--border);background:var(--surface);cursor:grab;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.blueprint-sensor-chip.alert{color:var(--danger);background:#b91c1c14;border-color:#b91c1c59}.app-shell.sidebar-collapsed .sidebar-brand,.app-shell.sidebar-collapsed .sidebar-brand-subtitle,.app-shell.sidebar-collapsed .sidebar-action-label,.app-shell.sidebar-collapsed .sidebar-nav-label,.app-shell.sidebar-collapsed .sidebar-summary-title,.app-shell.sidebar-collapsed .sidebar-summary-main,.app-shell.sidebar-collapsed .sidebar-summary-sub,.app-shell.sidebar-collapsed .sidebar-summary-meta,.app-shell.sidebar-collapsed .sidebar-tenant-switcher{display:none}.app-shell.sidebar-collapsed .sidebar-header{justify-content:center}.app-shell.sidebar-collapsed .sidebar-nav-item{padding-inline:10px}.app-shell.sidebar-collapsed .sidebar-nav-item-content{justify-content:center;width:100%}.app-shell.sidebar-collapsed .sidebar-action{justify-content:center}@media (max-width:1100px){.app-main{padding:18px}}@media (max-width:820px){.app-shell{flex-direction:column}.app-sidebar,.app-shell.sidebar-collapsed .app-sidebar{width:100%}.app-shell.sidebar-collapsed .sidebar-brand,.app-shell.sidebar-collapsed .sidebar-brand-subtitle,.app-shell.sidebar-collapsed .sidebar-action-label,.app-shell.sidebar-collapsed .sidebar-nav-label,.app-shell.sidebar-collapsed .sidebar-summary-title,.app-shell.sidebar-collapsed .sidebar-summary-main,.app-shell.sidebar-collapsed .sidebar-summary-sub,.app-shell.sidebar-collapsed .sidebar-summary-meta,.app-shell.sidebar-collapsed .sidebar-tenant-switcher{display:block}.app-shell.sidebar-collapsed .sidebar-header,.app-shell.sidebar-collapsed .sidebar-action,.app-shell.sidebar-collapsed .sidebar-nav-item-content{justify-content:flex-start}}button,input,select,textarea{font:inherit}.card{background:var(--bg-elevated);border:1px solid var(--border);box-shadow:var(--card-shadow);border-radius:20px;padding:24px;overflow-x:auto}.auth-page{place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{width:min(420px,100%)}.grid{gap:16px;display:grid}.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width:1100px){.cols-2,.cols-3{grid-template-columns:1fr}}.row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.muted{color:var(--muted)}.inline-note{color:var(--accent);font-size:.95rem}.toast-stack{z-index:80;gap:10px;width:min(360px,100vw - 32px);display:grid;position:fixed;bottom:24px;right:24px}.toast{border:1px solid var(--border);border-left:4px solid var(--accent);background:var(--surface);color:var(--text);border-radius:14px;padding:12px 14px;font-weight:650;box-shadow:0 18px 44px #0f172a2e}.toast-error{border-left-color:var(--danger)}.toast-info{border-left-color:#2563eb}@media (max-width:640px){.toast-stack{bottom:16px;right:16px}}.btn{background:var(--accent);color:var(--accent-contrast);cursor:pointer;border:none;border-radius:999px;padding:10px 16px;font-weight:600}.btn.secondary{background:var(--surface-soft);color:var(--text)}.btn:disabled{opacity:.5;cursor:not-allowed}.field{gap:8px;margin-bottom:16px;display:grid}.field label{font-size:.95rem;font-weight:600}.field input,.field select,.field textarea{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:14px;padding:12px 14px}.table{border-collapse:collapse;border-radius:16px;width:100%;min-width:720px;overflow:hidden}.table-scroll{border:1px solid var(--border);border-radius:16px;width:100%;max-height:min(620px,70vh);overflow:auto}.table-scroll .table{border-radius:0}.content-scroll{max-height:min(680px,72vh);overflow:auto}.table th,.table td{text-align:left;border-bottom:1px solid var(--border);padding:12px 14px}.table thead th{background:var(--surface-soft);letter-spacing:.03em;text-transform:uppercase;font-size:.85rem}.table tbody tr:hover{background:#2563eb0f}.code-block{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:16px;margin:0;padding:16px;overflow-x:auto}.pill{background:var(--surface-soft);border-radius:999px;align-items:center;gap:8px;padding:8px 12px;display:inline-flex}.modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:40;background:#0f172a94;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-shell{background:var(--surface);width:min(960px,100%);max-height:calc(100vh - 48px);color:var(--text);border:1px solid #2563eb29;border-radius:24px;padding:24px;overflow:auto;box-shadow:0 28px 80px #0f172a38}:root[data-theme=dark] .modal-shell{background:var(--bg-elevated);border-color:var(--border);box-shadow:0 28px 80px #0000006b}.modal-header{justify-content:space-between;align-items:start;gap:12px;margin-bottom:18px;display:flex}.modal-title{margin:0;font-size:1.4rem}.modal-subtitle{color:var(--muted);margin:6px 0 0}.modal-body{gap:16px;display:grid}.modal-footer{margin-top:18px}
