:root{--c-bg: #f7f8fa;--c-surface: #ffffff;--c-surface-2: #f1f3f6;--c-border: #e3e6ea;--c-border-strong: #cdd2da;--c-text: #0f1729;--c-text-secondary: #44506a;--c-text-muted: #79839b;--c-accent: #4f46e5;--c-accent-hover: #4338ca;--c-accent-soft: #eef0fe;--c-on-accent: #ffffff;--c-positive: #15803d;--c-warn: #b45309;--c-danger: #c0303a;--c-focus: #6366f1;--c-scrim: rgba(15, 23, 41, .45);--chart-1: #6366f1;--chart-2: #10b981;--chart-3: #f59e0b;--chart-4: #ec4899;--chart-5: #06b6d4;--chart-6: #8b5cf6;--chart-7: #f43f5e;--chart-8: #14b8a6;--chart-grid: #e7e9ee;--chart-axis: #79839b;--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--fs-xs: .75rem;--fs-sm: .8125rem;--fs-md: .875rem;--fs-lg: 1rem;--fs-xl: 1.375rem;--fs-2xl: 1.75rem;--fw-normal: 450;--fw-medium: 550;--fw-bold: 650;--lh: 1.5;--tracking-tight: -.011em;--tracking-wide: .04em;--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.5rem;--sp-6: 2rem;--sp-7: 3rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(15, 23, 41, .04), 0 1px 3px rgba(15, 23, 41, .06);--shadow-md: 0 2px 4px rgba(15, 23, 41, .05), 0 6px 16px rgba(15, 23, 41, .08);--ring: 0 0 0 3px rgba(99, 102, 241, .35);--dur: .14s;--ease: cubic-bezier(.4, 0, .2, 1);--control-h: 2rem;--control-pad-x: .6rem}[data-theme=dark]{--c-bg: #0b1020;--c-surface: #131a2c;--c-surface-2: #1b2338;--c-border: #2a3450;--c-border-strong: #3b486b;--c-text: #e7ecf5;--c-text-secondary: #b3bdd1;--c-text-muted: #8290ad;--c-accent: #818cf8;--c-accent-hover: #6f7bef;--c-accent-soft: #21294a;--c-on-accent: #0b1020;--c-positive: #4ade80;--c-warn: #fbbf24;--c-danger: #f87171;--c-focus: #a5b4fc;--c-scrim: rgba(0, 0, 0, .65);--chart-1: #818cf8;--chart-2: #34d399;--chart-3: #fbbf24;--chart-4: #f472b6;--chart-5: #22d3ee;--chart-6: #c084fc;--chart-7: #fb7185;--chart-8: #5eead4;--chart-grid: #2a3450;--chart-axis: #8290ad;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .02);--shadow-md: 0 4px 8px rgba(0, 0, 0, .45), 0 0 0 1px rgba(255, 255, 255, .03);--ring: 0 0 0 3px rgba(129, 140, 248, .45);color-scheme:dark}@media(prefers-color-scheme:dark){[data-theme=auto]{--c-bg: #0b1020;--c-surface: #131a2c;--c-surface-2: #1b2338;--c-border: #2a3450;--c-border-strong: #3b486b;--c-text: #e7ecf5;--c-text-secondary: #b3bdd1;--c-text-muted: #8290ad;--c-accent: #818cf8;--c-accent-hover: #6f7bef;--c-accent-soft: #21294a;--c-on-accent: #0b1020;--c-positive: #4ade80;--c-warn: #fbbf24;--c-danger: #f87171;--c-focus: #a5b4fc;--c-scrim: rgba(0, 0, 0, .65);--chart-1: #818cf8;--chart-2: #34d399;--chart-3: #fbbf24;--chart-4: #f472b6;--chart-5: #22d3ee;--chart-7: #fb7185;--chart-8: #5eead4;--chart-6: #c084fc;--chart-grid: #2a3450;--chart-axis: #8290ad;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .02);--shadow-md: 0 4px 8px rgba(0, 0, 0, .45), 0 0 0 1px rgba(255, 255, 255, .03);--ring: 0 0 0 3px rgba(129, 140, 248, .45);color-scheme:dark}}.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px;opacity:0}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}*{box-sizing:border-box}html{color-scheme:light}body{margin:0;font-family:var(--font-sans);font-size:var(--fs-md);font-weight:var(--fw-normal);line-height:var(--lh);color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3{letter-spacing:var(--tracking-tight);font-weight:var(--fw-bold)}a{color:var(--c-accent);text-decoration:none}a:hover{text-decoration:underline}button,select,input{font:inherit;color:var(--c-text)}button{cursor:pointer}select,input[type=text],input[type=search],input[type=date],input[type=datetime-local]{height:var(--control-h);padding:0 var(--control-pad-x);background:var(--c-surface);color:var(--c-text);border:1px solid var(--c-border-strong);border-radius:var(--radius-sm);transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}select option{color:var(--c-text);background:var(--c-surface)}:where(button,select,input,a,[tabindex]):focus-visible{outline:none;box-shadow:var(--ring);border-color:var(--c-focus)}.layout{display:grid;grid-template-columns:var(--sidebar-w, 240px) 1fr;transition:grid-template-columns .48s cubic-bezier(.32,.72,0,1);min-height:100vh}.layout-main{min-width:0;display:flex;flex-direction:column}.content-header{display:flex;align-items:center;justify-content:flex-end;gap:var(--sp-2);padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--c-border);background:var(--c-bg);position:sticky;top:0;z-index:5}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--c-border-strong, var(--c-border));border-radius:var(--radius-pill);background:transparent;color:var(--c-text-secondary);cursor:pointer}.theme-toggle:hover{color:var(--c-accent);border-color:var(--c-accent)}.app{margin:0 auto;padding:var(--sp-5) var(--sp-5) var(--sp-7);width:100%}.app--narrow{max-width:1240px}.sidebar{position:sticky;top:0;height:100vh;width:100%;overflow-x:hidden;overflow-y:auto;background:var(--c-surface);border-right:1px solid var(--c-border);display:flex;flex-direction:column;z-index:50}.sidebar-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);color:var(--c-text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium, 550);text-decoration:none;cursor:pointer;background:none;border:none;border-left:3px solid transparent;text-align:left;width:100%;min-height:32px;white-space:nowrap}.sidebar-item:hover{background:var(--c-surface-2);color:var(--c-text)}.sidebar-item--active,.sidebar-item--active:hover{background:color-mix(in srgb,var(--c-accent) 12%,transparent);color:var(--c-accent);border-left-color:var(--c-accent)}.sidebar-item--soon{opacity:.45;cursor:default}.sidebar-item--soon:hover{background:none;color:var(--c-text-secondary)}.sidebar-soon-badge{margin-left:auto;font-size:.65rem;font-weight:var(--fw-bold, 650);letter-spacing:.06em;text-transform:uppercase;color:var(--c-text-muted);background:var(--c-surface-2);padding:1px 6px;border-radius:999px;white-space:nowrap}.sidebar-chevron{margin-left:auto;display:inline-flex;transition:transform .15s ease;color:var(--c-text-muted)}.sidebar-chevron--open{transform:rotate(90deg)}.sidebar-children{padding-left:var(--sp-4);display:flex;flex-direction:column;gap:2px}.sidebar-section{display:flex;flex-direction:column;gap:2px;padding:var(--sp-2)}.sidebar-section-header{font-size:var(--fs-xs, .75rem);font-weight:var(--fw-bold, 650);letter-spacing:.08em;text-transform:uppercase;color:var(--c-text-muted);padding:var(--sp-2) var(--sp-2) var(--sp-1);white-space:nowrap}.sidebar-divider{height:1px;background:var(--c-border);margin:var(--sp-1) 0}.sidebar-brand{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-3);border-bottom:1px solid var(--c-border);min-height:56px}.sidebar-brand-name{font-weight:var(--fw-bold, 650);font-size:var(--fs-base, 1rem);letter-spacing:-.01em;color:var(--c-text);white-space:nowrap}.sidebar-toggle{border:1px solid var(--c-border);background:var(--c-surface-2);color:var(--c-text-secondary);width:28px;height:28px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.sidebar-toggle:hover{color:var(--c-accent);border-color:var(--c-accent)}.sidebar--collapsed .sidebar-item{justify-content:center;padding:var(--sp-2);gap:0}.sidebar--collapsed .sidebar-item>span,.sidebar--collapsed .sidebar-chevron,.sidebar--collapsed .sidebar-soon-badge,.sidebar--collapsed .sidebar-section-header,.sidebar--collapsed .sidebar-brand-name,.sidebar--collapsed .sidebar-children{display:none}.sidebar-project{position:relative;padding:var(--sp-2)}.sidebar-project-button{display:flex;align-items:center;gap:var(--sp-2);width:100%;padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--c-text);font-weight:var(--fw-bold, 650);font-size:var(--fs-sm);cursor:pointer;text-align:left}.sidebar-project-button:hover:not(:disabled){border-color:var(--c-accent)}.sidebar-project-button:disabled{cursor:default}.sidebar-project-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-project-menu{position:absolute;top:100%;left:var(--sp-2);right:var(--sp-2);margin-top:4px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md, 0 4px 12px rgba(0, 0, 0, .1));z-index:7;display:flex;flex-direction:column;padding:var(--sp-1)}.sidebar-project-menu-item{display:block;padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);background:none;border:none;color:var(--c-text);font-size:var(--fs-sm);cursor:pointer;text-align:left;text-decoration:none;width:100%}.sidebar-project-menu-item:hover{background:var(--c-surface-2);color:var(--c-accent)}.sidebar-project-menu-divider{height:1px;background:var(--c-border);margin:var(--sp-1) 0}.sidebar--collapsed .sidebar-project-button>span,.sidebar--collapsed .sidebar-project-button>svg:last-child{opacity:0;pointer-events:none}.sidebar-footer{margin-top:auto;padding:var(--sp-2);border-top:1px solid var(--c-border);display:flex;flex-direction:column;gap:2px}.sidebar-identity{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3)}.sidebar-identity-avatar{width:28px;height:28px;border-radius:50%;background:var(--c-accent);color:var(--c-on-accent, white);display:inline-flex;align-items:center;justify-content:center;font-weight:var(--fw-bold, 650);font-size:var(--fs-sm);flex-shrink:0}.sidebar-identity-text{flex:1;min-width:0}.sidebar-identity-name{font-size:var(--fs-sm);font-weight:var(--fw-medium, 550);color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-identity-tenant{font-size:var(--fs-xs, .75rem);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.04em}.sidebar--collapsed .sidebar-identity-text{opacity:0;pointer-events:none}.controls{display:flex;flex-wrap:wrap;gap:var(--sp-5);align-items:flex-end;margin-bottom:var(--sp-5);padding:var(--sp-4);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.control{display:flex;flex-direction:column;gap:var(--sp-2)}.control>label{font-size:var(--fs-xs);font-weight:var(--fw-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--c-text-muted)}.control select,.control input{min-width:168px}.range-buttons{display:inline-flex;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:2px;gap:2px}.range-buttons button{border:none;background:transparent;color:var(--c-text-secondary);padding:0 var(--sp-3);height:calc(var(--control-h) - 4px);border-radius:var(--radius-sm);font-size:var(--fs-sm);font-weight:var(--fw-medium);transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.range-buttons button:hover{background:var(--c-surface);color:var(--c-text)}.range-buttons button.active{background:var(--c-accent);color:var(--c-on-accent)}.date-range{display:inline-flex;align-items:center;gap:var(--sp-2)}.date-range-sep{color:var(--c-text-muted)}.edit-toggle{height:var(--control-h);padding:0 var(--sp-4);border:1px solid var(--c-border-strong);border-radius:var(--radius-sm);background:var(--c-surface);color:var(--c-text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease)}.edit-toggle:hover{border-color:var(--c-accent);color:var(--c-accent)}.edit-toggle--on{background:var(--c-accent);border-color:var(--c-accent);color:var(--c-on-accent)}.edit-toggle--on:hover{background:var(--c-accent-hover);color:var(--c-on-accent)}.dash-panel-title--static{border-color:transparent;background:none;cursor:default}.dash-panel-title--static:hover{border-color:transparent;background:none}.live-controls{display:flex;align-items:center;gap:var(--sp-3)}.live-toggle{display:inline-flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);color:var(--c-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.live-toggle input{accent-color:var(--c-accent);cursor:pointer}.live-controls select{min-width:4.5rem}.live-controls select:disabled{opacity:.45;cursor:not-allowed}.chart-container{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:var(--sp-4);min-height:380px;box-shadow:var(--shadow-sm)}.chart-drag{position:relative}.chart-meta{margin-top:var(--sp-2);font-size:var(--fs-xs);color:var(--c-text-muted);font-variant-numeric:tabular-nums}.live-dot{color:var(--c-positive)}.live-dot--err{color:var(--c-warn)}.empty-state{color:var(--c-text-muted);text-align:center;padding:var(--sp-7) var(--sp-4);font-style:italic}.error-state{color:var(--c-danger);text-align:center;padding:var(--sp-7) var(--sp-4)}.controls .error-state{padding:var(--sp-2) 0;text-align:left;font-size:var(--fs-sm);font-style:normal}.dash-tabs{display:flex;flex-wrap:wrap;gap:var(--sp-1);margin-bottom:var(--sp-5);border-bottom:1px solid var(--c-border)}.dash-tab{display:flex;align-items:center;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.dash-tab--active{box-shadow:inset 0 -2px 0 var(--c-accent)}.dash-tab-label{border:none;background:none;padding:var(--sp-3) var(--sp-3);color:var(--c-text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium)}.dash-tab--active .dash-tab-label,.dash-tab-label:hover{color:var(--c-text)}.dash-tab-x{border:none;background:none;color:var(--c-text-muted);padding:0 var(--sp-2) 0 0;font-size:var(--fs-lg)}.dash-tab-x:hover{color:var(--c-danger)}.dash-tab-add{border:1px dashed var(--c-border-strong);background:none;border-radius:var(--radius-sm);padding:var(--sp-2) var(--sp-3);color:var(--c-text-muted);font-size:var(--fs-sm);align-self:center}.dash-tab-add:hover{color:var(--c-accent);border-color:var(--c-accent)}.dash-section{border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:var(--sp-5);margin-bottom:var(--sp-5);background:var(--c-surface);box-shadow:var(--shadow-sm)}.dash-section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-4)}.dash-section-head h2{margin:0;font-size:var(--fs-lg);display:flex;align-items:center;gap:var(--sp-3)}.dash-kind{font-size:var(--fs-xs);font-weight:var(--fw-bold);letter-spacing:var(--tracking-wide);color:var(--c-text-muted);border:1px solid var(--c-border);border-radius:var(--radius-pill);padding:1px var(--sp-2);text-transform:uppercase}.dash-section-actions{display:flex;gap:var(--sp-2)}.dash-section-actions button,.dash-add-section{font-size:var(--fs-sm);font-weight:var(--fw-medium);padding:var(--sp-2) var(--sp-3);border:1px solid var(--c-border-strong);border-radius:var(--radius-sm);background:var(--c-surface);color:var(--c-text-secondary);transition:border-color var(--dur) var(--ease),color var(--dur) var(--ease)}.dash-section-actions button:hover{border-color:var(--c-accent);color:var(--c-accent)}.dash-add-section{border-style:dashed;color:var(--c-text-muted)}.dash-add-section:hover{color:var(--c-accent);border-color:var(--c-accent)}.dash-grid{position:relative;width:100%}.dash-grid .react-grid-item{transition:all .18s var(--ease)}.dash-grid--edit .dash-panel-head{cursor:grab;border-radius:var(--radius-sm);padding:var(--sp-1) var(--sp-2);margin:calc(-1 * var(--sp-1)) calc(-1 * var(--sp-2)) var(--sp-2);transition:background var(--dur) var(--ease)}.dash-grid--edit .dash-panel-head:hover{background:var(--c-surface-2)}.dash-grid--edit .dash-panel-head:active{cursor:grabbing}.dash-panel-grip{display:inline-flex;align-items:center;color:var(--c-text-muted);cursor:grab;flex-shrink:0;margin-right:var(--sp-1);opacity:.6;transition:opacity var(--dur) var(--ease)}.dash-panel-head:hover .dash-panel-grip{opacity:1;color:var(--c-accent)}.dash-panel-grip:active{cursor:grabbing}.react-grid-placeholder{background:var(--c-accent-soft)!important;border:1px dashed var(--c-accent)!important;border-radius:var(--radius-md)!important;opacity:.85!important}.dash-panel{display:flex;flex-direction:column;height:100%;border:1px solid var(--c-border);border-radius:var(--radius-md);padding:var(--sp-4);background:var(--c-surface);transition:box-shadow var(--dur) var(--ease);overflow:hidden}.dash-panel-body{flex:1;min-height:0;display:flex;flex-direction:column}.dash-panel-body .chart-drag{flex:1;min-height:0}.dash-panel:hover{box-shadow:var(--shadow-md)}.dash-panel-head{display:flex;justify-content:space-between;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-3)}.dash-panel-title{flex:1;border:1px solid transparent;background:none;font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--c-text);padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-sm);height:auto}.dash-panel-title:hover{border-color:var(--c-border);background:var(--c-surface-2)}.dash-panel-actions{display:flex;gap:var(--sp-1)}.dash-panel-actions button{border:1px solid var(--c-border-strong);background:var(--c-surface);border-radius:var(--radius-sm);padding:var(--sp-1) var(--sp-2);color:var(--c-text-secondary);font-size:var(--fs-xs);font-weight:var(--fw-medium)}.dash-panel-actions button:hover{border-color:var(--c-accent);color:var(--c-accent)}.dash-panel-config{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-bottom:var(--sp-3);padding:var(--sp-3);background:var(--c-surface-2);border-radius:var(--radius-sm)}.dash-panel-config select{min-width:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--c-scrim);display:flex;align-items:center;justify-content:center;padding:var(--sp-4);z-index:50}.modal{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:min(720px,100%);max-height:90vh;display:flex;flex-direction:column}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--c-border)}.modal-head h3{margin:0;font-size:var(--fs-lg)}.modal-x{border:none;background:none;font-size:var(--fs-xl);color:var(--c-text-muted);line-height:1}.modal-x:hover{color:var(--c-danger)}.modal-body{padding:var(--sp-5);overflow:auto;display:flex;flex-direction:column;gap:var(--sp-4)}.modal-body>*{flex-shrink:0}.field{display:flex;flex-direction:column;gap:var(--sp-2)}.field>span{font-size:var(--fs-xs);font-weight:var(--fw-bold);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--c-text-muted)}.field-row{display:flex;gap:var(--sp-4)}.field-row .field{flex:1}.modal-hint{margin:0;font-size:var(--fs-sm);color:var(--c-text-muted)}.modal-foot{padding:var(--sp-3) var(--sp-5);border-top:1px solid var(--c-border);display:flex;justify-content:flex-end}.dash-tag-chips{display:flex;flex-wrap:wrap;gap:var(--sp-2);flex-basis:100%}.dash-chip{display:inline-flex;align-items:center;gap:var(--sp-2);background:var(--c-accent-soft);border:1px solid transparent;color:var(--c-accent);border-radius:var(--radius-pill);padding:2px var(--sp-2);font-size:var(--fs-xs);font-weight:var(--fw-medium)}.dash-chip button{border:none;background:none;color:var(--c-accent);font-size:var(--fs-md);line-height:1;padding:0;opacity:.7}.dash-chip button:hover{opacity:1}.modal-section-label{margin-top:var(--sp-4);margin-bottom:var(--sp-2);font-size:var(--fs-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.04em;color:var(--c-text-muted)}.modal-hint-inline{text-transform:none;letter-spacing:0;font-weight:var(--fw-normal)}.bin-field{display:flex;gap:var(--sp-2);align-items:center}.bin-field select{flex:1}.bin-custom{width:80px}.series-list{display:flex;flex-direction:column;gap:var(--sp-2);margin-top:var(--sp-2)}.series-row{border:1px solid var(--c-border);border-radius:var(--radius-md);background:var(--c-surface)}.series-row-head{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3)}.series-caret{border:none;background:none;color:var(--c-text-muted);font-size:var(--fs-sm);padding:0;width:16px;cursor:pointer}.series-name{flex:1;font-weight:var(--fw-medium);font-size:var(--fs-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.series-type{max-width:190px}.series-badge{font-size:var(--fs-xs);color:var(--c-accent);background:var(--c-accent-soft);border-radius:var(--radius-pill);padding:1px var(--sp-2)}.series-x{border:none;background:none;color:var(--c-text-muted);font-size:var(--fs-md);line-height:1;padding:0 var(--sp-1);cursor:pointer}.series-x:hover{color:var(--c-danger)}.series-detail{display:flex;flex-wrap:wrap;gap:var(--sp-3);padding:0 var(--sp-3) var(--sp-3) calc(16px + var(--sp-2) + var(--sp-3));border-top:1px solid var(--c-border);padding-top:var(--sp-3)}.series-detail .field{flex:1;min-width:180px}.series-reset{align-self:flex-end;border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text-muted);border-radius:var(--radius-md);padding:var(--sp-1) var(--sp-3);font-size:var(--fs-xs);cursor:pointer}.series-reset:hover{color:var(--c-text)}.tag-tree{border:1px solid var(--c-border);border-radius:var(--radius-md);background:var(--c-surface);overflow:hidden}.tag-tree-search{width:100%;border:none;border-bottom:1px solid var(--c-border);border-radius:0;padding:var(--sp-3);font-size:var(--fs-sm)}.tag-tree-search:focus{outline:none;box-shadow:inset 0 -2px 0 var(--c-accent)}.tag-group+.tag-group{border-top:1px solid var(--c-border)}.tag-group-head{display:flex;align-items:center;gap:var(--sp-2);width:100%;border:none;background:var(--c-surface-2);padding:var(--sp-2) var(--sp-3);font-size:var(--fs-sm);font-weight:var(--fw-medium);cursor:pointer}.tag-group-head:hover{background:var(--c-border)}.tag-caret{color:var(--c-text-muted);width:14px}.tag-group-name{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag-group-kind{font-size:var(--fs-xs);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.04em}.tag-group-badge{font-size:var(--fs-xs);background:var(--c-accent);color:var(--c-on-accent);border-radius:var(--radius-pill);padding:0 var(--sp-2);min-width:18px;text-align:center}.tag-group-items{padding:var(--sp-1) 0}.tag-tree-note{padding:var(--sp-2) var(--sp-5);font-size:var(--fs-sm);color:var(--c-text-muted);font-style:italic}.tag-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-1) var(--sp-3) var(--sp-1) var(--sp-5);font-size:var(--fs-sm);cursor:pointer}.tag-item:hover{background:var(--c-surface-2)}.tag-item input{accent-color:var(--c-accent);cursor:pointer}.tag-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag-item-unit{font-size:var(--fs-xs);color:var(--c-text-secondary)}.tag-item-type{font-size:var(--fs-xs);color:var(--c-text-muted);border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:0 var(--sp-1)}.login-shell{min-height:calc(100vh - 2 * var(--sp-5));display:flex;align-items:center;justify-content:center}.login-card{width:100%;max-width:360px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--sp-6) var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-3)}.login-title{margin:0;font-size:var(--fs-2xl);text-align:center}.login-tagline{margin:0 0 var(--sp-2);text-align:center;color:var(--c-text-muted);font-size:var(--fs-sm)}.login-card .field{width:100%}.login-card .field input{width:100%;box-sizing:border-box}.login-error{background:color-mix(in srgb,var(--c-danger) 12%,transparent);color:var(--c-danger);border-radius:var(--radius-sm);padding:var(--sp-2) var(--sp-3);font-size:var(--fs-sm)}.login-submit{width:100%;margin-top:var(--sp-2)}.account-menu{position:relative;margin-left:var(--sp-2)}.account-avatar{width:32px;height:32px;border-radius:999px;border:1px solid var(--c-border-strong);background:var(--c-surface);color:var(--c-text);font-weight:var(--fw-bold);font-size:var(--fs-sm);cursor:pointer}.account-avatar:hover{border-color:var(--c-accent);color:var(--c-accent)}.account-pop{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--sp-2);z-index:10;display:flex;flex-direction:column;gap:var(--sp-1)}.account-meta{padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--c-border);margin-bottom:var(--sp-1)}.account-email{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--c-text);overflow:hidden;text-overflow:ellipsis}.account-role{font-size:var(--fs-xs);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.account-action{border:none;background:none;text-align:left;padding:var(--sp-2) var(--sp-3);color:var(--c-text);font-size:var(--fs-sm);border-radius:var(--radius-sm);cursor:pointer}.account-action:hover{background:var(--c-surface-2);color:var(--c-accent)}.account-theme{padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--c-border);margin-bottom:var(--sp-1);display:flex;flex-direction:column;gap:var(--sp-2)}.account-theme-label{font-size:var(--fs-xs);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.04em}.account-theme-buttons{display:flex;gap:2px;background:var(--c-surface-2);border-radius:var(--radius-sm);padding:2px}.account-theme-btn{flex:1;border:none;background:none;font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--c-text-muted);padding:var(--sp-1) var(--sp-2);border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.account-theme-btn:hover{color:var(--c-text)}.account-theme-btn--on{background:var(--c-surface);color:var(--c-text);box-shadow:var(--shadow-sm)}.login-banner{background:color-mix(in srgb,var(--c-positive, #2ea043) 12%,transparent);color:var(--c-positive, #2ea043);border-radius:var(--radius-sm);padding:var(--sp-2) var(--sp-3);font-size:var(--fs-sm)}.page-title{margin:0 0 var(--sp-4);font-size:var(--fs-lg)}.invite-form{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:var(--sp-4);box-shadow:var(--shadow-sm);margin-bottom:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-2)}.invite-row{display:flex;flex-wrap:wrap;gap:var(--sp-3);align-items:flex-end}.invite-row .field{flex:1;min-width:200px}.invite-success{font-size:var(--fs-sm);color:var(--c-positive, #2ea043)}.users-table-wrap{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.users-table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}.users-table th,.users-table td{text-align:left;padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--c-border)}.users-table th{background:var(--c-surface-2);font-weight:var(--fw-bold);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:var(--fs-xs)}.users-table tr:last-child td{border-bottom:none}.dim{color:var(--c-text-muted)}.row-actions{display:flex;gap:var(--sp-2);align-items:center;flex-wrap:wrap;justify-content:flex-end}.row-action{border:1px solid var(--c-border-strong);background:var(--c-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);padding:var(--sp-1) var(--sp-3);font-size:var(--fs-xs);cursor:pointer;transition:border-color var(--dur) var(--ease),color var(--dur) var(--ease)}.row-action:hover{border-color:var(--c-accent);color:var(--c-accent)}.row-action:disabled{opacity:.55;cursor:not-allowed}.row-action--danger:hover{border-color:var(--c-danger);color:var(--c-danger)}.row-error{flex-basis:100%;color:var(--c-danger);font-size:var(--fs-xs)}.login-back-link{display:block;text-align:center;margin-top:var(--sp-3);font-size:var(--fs-sm);color:var(--c-text-secondary)}.login-back-link:hover{color:var(--c-accent)}.account-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:var(--sp-4)}.account-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:var(--sp-5);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--sp-3)}.account-card-title{margin:0 0 var(--sp-2);font-size:var(--fs-md)}.account-card form{display:flex;flex-direction:column;gap:var(--sp-3)}.account-current-email{font-size:var(--fs-sm);padding:var(--sp-2) var(--sp-3);background:var(--c-surface-2);border-radius:var(--radius-sm)}.project-list{display:flex;flex-direction:column;gap:var(--sp-3)}.project-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.project-card-head{display:flex;align-items:center;gap:var(--sp-3);width:100%;padding:var(--sp-3) var(--sp-4);background:none;border:none;cursor:pointer;text-align:left}.project-card-head:hover{background:var(--c-surface-2)}.project-card-caret{color:var(--c-text-muted);width:14px}.project-card-name{flex:1;font-weight:var(--fw-medium)}.project-card-body{padding:var(--sp-4);border-top:1px solid var(--c-border);display:flex;flex-direction:column;gap:var(--sp-5)}.project-subsection h4{margin:0 0 var(--sp-2);font-size:var(--fs-sm);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.04em}.page-head-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4)}.page-head-row .page-title{margin:0}.sev{display:inline-block;padding:1px var(--sp-2);border-radius:var(--radius-pill);font-size:var(--fs-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.sev--info{color:var(--c-accent);background:color-mix(in srgb,var(--c-accent) 16%,transparent)}.sev--warn{color:var(--c-warn);background:color-mix(in srgb,var(--c-warn) 18%,transparent)}.sev--critical{color:var(--c-danger);background:color-mix(in srgb,var(--c-danger) 18%,transparent)}.sev--warning{color:var(--c-warn);background:color-mix(in srgb,var(--c-warn) 18%,transparent)}.sev--minor{color:color-mix(in srgb,var(--c-warn) 55%,var(--c-danger));background:color-mix(in srgb,var(--c-warn) 12%,transparent)}.sev--major{color:color-mix(in srgb,var(--c-danger) 75%,var(--c-warn));background:color-mix(in srgb,var(--c-danger) 14%,transparent)}.rule-block{display:flex;gap:var(--sp-3);padding:var(--sp-3);border:1px solid var(--c-border);border-radius:var(--radius-md);background:var(--c-surface-2)}.rule-block-tag{flex-shrink:0;width:52px;text-align:center;align-self:flex-start;padding:2px 0;border-radius:var(--radius-sm);font-size:var(--fs-xs);font-weight:var(--fw-bold);letter-spacing:var(--tracking-wide);color:var(--c-on-accent, #fff)}.rule-block-tag--if{background:var(--c-accent)}.rule-block-tag--when{background:var(--c-warn)}.rule-block-tag--then{background:var(--c-danger)}.rule-block-body{flex:1;min-width:0}.rule-cond-row{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2)}.rule-cond-prefix{font-size:var(--fs-sm);color:var(--c-text-muted);min-width:56px}.rule-action-tabs{display:flex;gap:var(--sp-1);border-bottom:1px solid var(--c-border);margin-bottom:var(--sp-2)}.rule-action-tab{padding:var(--sp-2) var(--sp-3);border:none;background:none;color:var(--c-text-muted);font-size:var(--fs-sm);font-weight:var(--fw-medium);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.rule-action-tab--on{color:var(--c-accent);border-bottom-color:var(--c-accent)}.rule-tagref{margin-right:var(--sp-1);cursor:default}.calc-tag-checks{display:flex;flex-wrap:wrap;gap:var(--sp-2) var(--sp-4);max-height:180px;overflow-y:auto;padding:var(--sp-2);border:1px solid var(--c-border);border-radius:var(--radius-md);background:var(--c-surface-2)}.calc-tag-checks--grouped{display:block;max-height:280px}.calc-tag-group+.calc-tag-group{margin-top:var(--sp-3)}.calc-tag-group-head{font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--c-text-muted);padding:4px 6px;border-bottom:1px solid var(--c-border);margin-bottom:6px}.calc-tag-group-body{display:flex;flex-direction:column;gap:2px;padding-left:6px}.calc-tag-group-body .rule-channel{padding:2px 0}.calc-letter-inputs{display:flex;flex-direction:column;gap:var(--sp-2);padding:var(--sp-2);border:1px solid var(--c-border);border-radius:var(--radius-md);background:var(--c-surface-2)}.calc-letter-row{display:flex;align-items:center;gap:var(--sp-2)}.calc-letter-chip{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;font-weight:700;font-family:var(--font-mono, monospace);font-size:var(--fs-sm);background:var(--c-accent-soft);color:var(--c-accent);border-radius:var(--radius-sm);flex-shrink:0}.rule-channels{display:flex;flex-direction:column;gap:var(--sp-2)}.rule-channel{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm)}.rule-channel input{width:auto}.rule-channel-badge{display:inline-block;margin-left:var(--sp-1);padding:0 var(--sp-2);border-radius:var(--radius-pill);background:var(--c-surface-2);border:1px solid var(--c-border);font-size:var(--fs-xs);color:var(--c-text-muted)}.rule-exec{margin-top:var(--sp-3);padding-top:var(--sp-2);border-top:1px solid var(--c-border)}.rule-exec-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px;max-height:280px;overflow-y:auto}.rule-exec-row{display:grid;grid-template-columns:84px 1fr auto;align-items:center;gap:var(--sp-2);padding:var(--sp-1) 0;font-size:var(--fs-sm)}.rule-exec-detail{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rule-exec-time{font-size:var(--fs-xs);color:var(--c-text-muted);white-space:nowrap}.exec-outcome{text-align:center;padding:1px var(--sp-2);border-radius:var(--radius-pill);font-size:var(--fs-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.exec-outcome--ok{color:var(--c-accent);background:color-mix(in srgb,var(--c-accent) 16%,transparent)}.exec-outcome--skipped_cooldown{color:var(--c-text-muted);background:var(--c-surface-2)}.exec-outcome--error{color:var(--c-danger);background:color-mix(in srgb,var(--c-danger) 18%,transparent)}.recip-status{display:inline-block;padding:1px var(--sp-2);border-radius:var(--radius-pill);font-size:var(--fs-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.recip-status--confirmed{color:var(--c-accent);background:color-mix(in srgb,var(--c-accent) 16%,transparent)}.recip-status--pending{color:var(--c-warn);background:color-mix(in srgb,var(--c-warn) 16%,transparent)}.recip-status--unsubscribed{color:var(--c-text-muted);background:var(--c-surface-2)}.rule-preview{padding:var(--sp-3);border-radius:var(--radius-md);background:var(--c-accent-soft);font-size:var(--fs-sm);line-height:1.5}.rule-preview strong{color:var(--c-accent)}.rule-card-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4)}.rule-card-title{display:flex;align-items:center;gap:var(--sp-3);min-width:0}.rule-card-body{padding:0 var(--sp-4) var(--sp-3)}.rule-summary{margin:0 0 var(--sp-2);font-size:var(--fs-sm);line-height:1.5}.rule-meta{margin:0;font-size:var(--fs-xs)}.rule-status{display:inline-block;padding:1px var(--sp-2);border-radius:var(--radius-pill);font-size:var(--fs-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.rule-status--enabled{color:var(--c-accent);background:color-mix(in srgb,var(--c-accent) 16%,transparent)}.rule-status--disabled{color:var(--c-text-muted);background:var(--c-surface-2)}.rule-status--draft{color:var(--c-warn);background:color-mix(in srgb,var(--c-warn) 16%,transparent)}.notif-bell{position:relative;align-self:center}.notif-bell-btn{position:relative;width:32px;height:32px;border-radius:999px;border:1px solid var(--c-border-strong);background:var(--c-surface);font-size:var(--fs-md);line-height:1;cursor:pointer}.notif-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--c-danger);color:#fff;font-size:10px;font-weight:var(--fw-bold);line-height:16px;text-align:center}.notif-pop{position:absolute;top:calc(100% + 6px);right:0;width:340px;max-width:90vw;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:20;display:flex;flex-direction:column}.notif-pop-head{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3);border-bottom:1px solid var(--c-border);font-weight:var(--fw-bold);font-size:var(--fs-sm)}.notif-mark-all{border:none;background:none;color:var(--c-accent);font-size:var(--fs-xs);font-weight:var(--fw-medium);cursor:pointer}.notif-list{max-height:420px;overflow-y:auto}.notif-empty{padding:var(--sp-4);text-align:center;color:var(--c-text-muted);font-size:var(--fs-sm)}.notif-item{display:grid;grid-template-columns:auto 1fr;grid-template-areas:"sev title" "sev time";gap:2px var(--sp-2);width:100%;text-align:left;padding:var(--sp-3);border:none;border-bottom:1px solid var(--c-border);background:none;cursor:pointer}.notif-item:hover{background:var(--c-surface-2)}.notif-item--unread{background:var(--c-accent-soft)}.notif-item .sev{grid-area:sev;align-self:start}.notif-item-title{grid-area:title;font-size:var(--fs-sm);color:var(--c-text)}.notif-item-time{grid-area:time;font-size:var(--fs-xs);color:var(--c-text-muted)}.timeline-slider{position:fixed;bottom:0;left:var(--sidebar-w, 240px);right:0;height:68px;display:grid;grid-template-columns:auto auto 1fr auto auto;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-4);background:var(--c-surface);border-top:1px solid var(--c-border);box-shadow:0 -4px 12px color-mix(in srgb,var(--c-text) 6%,transparent);z-index:40;transition:left .48s cubic-bezier(.32,.72,0,1)}body.has-timeline-slider .app{padding-bottom:calc(var(--sp-7) + 68px)}.timeline-track-wrap{display:flex;flex-direction:column;gap:3px}.timeline-tick-labels{position:relative;height:11px;pointer-events:none}.timeline-tick-label{position:absolute;transform:translate(-50%);font-size:10px;line-height:1;color:var(--c-text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;letter-spacing:.02em}.timeline-shortcuts{display:inline-flex;gap:2px;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:2px}.timeline-shortcut{background:transparent;border:none;border-radius:var(--radius-sm);padding:3px 8px;font-size:var(--fs-xs);font-weight:var(--fw-medium, 550);color:var(--c-text-secondary);cursor:pointer;white-space:nowrap}.timeline-shortcut:hover{background:var(--c-surface);color:var(--c-accent)}.timeline-zoom{display:inline-flex;gap:2px}.timeline-zoom-btn{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--c-border);background:var(--c-surface-2);color:var(--c-text-secondary);border-radius:var(--radius-sm);cursor:pointer}.timeline-zoom-btn:hover{border-color:var(--c-accent);color:var(--c-accent)}.timeline-live{display:inline-flex;align-items:center;gap:var(--sp-1);padding:4px 8px;border:1px solid var(--c-border);border-radius:var(--radius-pill);background:var(--c-surface-2);color:var(--c-text-muted);font-size:var(--fs-xs);font-weight:var(--fw-bold, 650);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;white-space:nowrap}.timeline-live--on{border-color:var(--c-positive, #16a34a);background:color-mix(in srgb,var(--c-positive, #16a34a) 14%,transparent);color:var(--c-positive, #16a34a)}.timeline-live:hover{border-color:var(--c-accent);color:var(--c-accent)}.timeline-track{position:relative;height:24px;border-radius:var(--radius-sm);background:var(--c-surface-2);border:1px solid var(--c-border);cursor:default;-webkit-user-select:none;user-select:none;touch-action:none;overflow:hidden}.timeline-tick{position:absolute;top:0;bottom:0;width:1px;background:color-mix(in srgb,var(--c-text-muted) 22%,transparent);pointer-events:none}.timeline-tick--major{background:color-mix(in srgb,var(--c-text-muted) 45%,transparent)}.timeline-track--dragging{cursor:grabbing}.timeline-window{position:absolute;top:0;bottom:0;background:color-mix(in srgb,var(--c-accent) 28%,transparent);border-left:1px solid var(--c-accent);border-right:1px solid var(--c-accent);cursor:grab;transition:left .35s cubic-bezier(.32,.72,0,1),width .35s cubic-bezier(.32,.72,0,1)}.timeline-track--dragging .timeline-window{cursor:grabbing;transition:none}.timeline-window--at-tail{background:color-mix(in srgb,var(--c-positive, #16a34a) 28%,transparent);border-left-color:var(--c-positive, #16a34a);border-right-color:var(--c-positive, #16a34a)}.timeline-window-handle{position:absolute;top:-4px;bottom:-4px;width:28px;cursor:ew-resize;z-index:2}.timeline-window-handle:after{content:"";position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%);width:12px;background:var(--c-accent);border-radius:3px;box-shadow:0 1px 2px color-mix(in srgb,var(--c-text) 25%,transparent);background-image:linear-gradient(to bottom,transparent 0,transparent calc(50% - 5px),color-mix(in srgb,white 60%,transparent) calc(50% - 5px),color-mix(in srgb,white 60%,transparent) calc(50% - 4px),transparent calc(50% - 4px),transparent calc(50% + 4px),color-mix(in srgb,white 60%,transparent) calc(50% + 4px),color-mix(in srgb,white 60%,transparent) calc(50% + 5px),transparent calc(50% + 5px),transparent 100%);background-color:var(--c-accent)}.timeline-window-handle:hover:after{filter:brightness(1.1)}.timeline-window-handle--left{left:-14px}.timeline-window-handle--right{right:-14px}.timeline-window--at-tail .timeline-window-handle:after{background-color:var(--c-positive, #16a34a)}.timeline-readout{display:inline-flex;align-items:center;gap:var(--sp-2);padding:4px 8px;font-size:var(--fs-xs);color:var(--c-text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer}.timeline-readout:hover{border-color:var(--c-border);background:var(--c-surface-2);color:var(--c-text-secondary)}.daterange-pop{position:fixed;right:16px;bottom:84px;z-index:120;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-md);box-shadow:0 12px 32px #0f17291f,0 2px 6px #0f17290f;font-size:var(--fs-sm);color:var(--c-text);-webkit-user-select:none;user-select:none}.daterange-body{display:flex;padding:var(--sp-3);gap:var(--sp-3)}.daterange-cals{display:flex;gap:var(--sp-3)}.daterange-month{width:240px}.daterange-month-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.daterange-month-label{font-weight:600;color:var(--c-text);font-size:var(--fs-sm)}.daterange-nav{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;color:var(--c-text-secondary);border-radius:var(--radius-sm);cursor:pointer}.daterange-nav:hover:not(:disabled){border-color:var(--c-border);background:var(--c-surface-2)}.daterange-nav:disabled{cursor:default;opacity:0;pointer-events:none}.daterange-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;font-size:var(--fs-xs);color:var(--c-text-muted);text-align:center;margin-bottom:4px}.daterange-weekdays>span{height:24px;display:inline-flex;align-items:center;justify-content:center}.daterange-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.daterange-cell{height:28px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--c-text);font-size:var(--fs-sm);border-radius:var(--radius-sm);cursor:pointer;font-variant-numeric:tabular-nums}.daterange-cell:hover{background:var(--c-surface-2)}.daterange-cell--out{color:var(--c-text-muted);opacity:.55}.daterange-cell--disabled{color:var(--c-text-muted);opacity:.3;cursor:not-allowed}.daterange-cell--disabled:hover{background:transparent}.daterange-cell--today{outline:1px solid var(--c-border-strong);outline-offset:-1px}.daterange-cell--in{background:var(--c-accent-soft);color:var(--c-text);border-radius:0}.daterange-cell--start,.daterange-cell--end{background:var(--c-accent);color:var(--c-on-accent, #ffffff);font-weight:600}.daterange-cell--start.daterange-cell--end{border-radius:var(--radius-sm)}.daterange-cell--start:not(.daterange-cell--end){border-top-left-radius:var(--radius-sm);border-bottom-left-radius:var(--radius-sm);border-top-right-radius:0;border-bottom-right-radius:0}.daterange-cell--end:not(.daterange-cell--start){border-top-right-radius:var(--radius-sm);border-bottom-right-radius:var(--radius-sm);border-top-left-radius:0;border-bottom-left-radius:0}.daterange-presets{display:flex;flex-direction:column;gap:4px;padding-left:var(--sp-3);border-left:1px solid var(--c-border);min-width:130px}.daterange-preset{text-align:left;padding:6px 10px;background:transparent;border:1px solid transparent;color:var(--c-text-secondary);border-radius:var(--radius-sm);font-size:var(--fs-sm);cursor:pointer}.daterange-preset:hover{background:var(--c-surface-2);color:var(--c-text)}.daterange-foot{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-3);border-top:1px solid var(--c-border);gap:var(--sp-3)}.daterange-readout{display:inline-flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);color:var(--c-text-secondary);font-variant-numeric:tabular-nums}.daterange-actions{display:inline-flex;align-items:center;gap:var(--sp-2)}.daterange-cancel,.daterange-apply{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-sm);font-size:var(--fs-sm);cursor:pointer;border:1px solid var(--c-border)}.daterange-cancel{background:transparent;color:var(--c-text-secondary)}.daterange-cancel:hover{background:var(--c-surface-2);color:var(--c-text)}.daterange-apply{background:var(--c-accent);border-color:var(--c-accent);color:var(--c-on-accent, #ffffff);font-weight:600}.daterange-apply:hover:not(:disabled){background:var(--c-accent-hover);border-color:var(--c-accent-hover)}.daterange-apply:disabled{opacity:.5;cursor:not-allowed}.explorer{display:grid;grid-template-columns:280px 1fr;gap:var(--sp-3);height:calc(100vh - 80px - var(--sp-7) - 68px);min-height:360px}.explorer__rail{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--rad-md);overflow:hidden;display:flex;flex-direction:column}.explorer__main{display:flex;flex-direction:column;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--rad-md);overflow:hidden}.explorer__chart{flex:1 1 auto;min-height:200px;padding:var(--sp-3)}.explorer__controls{flex:0 0 auto;display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-top:1px solid var(--c-border);background:var(--c-surface-2)}.explorer__control{display:flex;align-items:center;gap:var(--sp-1)}.explorer__control label{font-size:12px;color:var(--c-text-secondary)}.explorer__control select{background:var(--c-surface);color:var(--c-text);border:1px solid var(--c-border);border-radius:var(--rad-sm);padding:4px 8px;font-size:13px}.explorer__control-spacer{flex:1 1 auto}.explorer__selection-count{font-size:12px}.explorer-tree{display:flex;flex-direction:column;height:100%}.explorer-tree__search{position:relative;padding:var(--sp-2);border-bottom:1px solid var(--c-border)}.explorer-tree__search-icon{position:absolute;left:calc(var(--sp-2) + 6px);top:50%;transform:translateY(-50%);color:var(--c-text-secondary);pointer-events:none}.explorer-tree__search input{width:100%;background:var(--c-surface-2);color:var(--c-text);border:1px solid var(--c-border);border-radius:var(--rad-sm);padding:5px 8px 5px 28px;font-size:13px}.explorer-tree__body{flex:1 1 auto;overflow-y:auto;padding:var(--sp-1) 0}.explorer-tree__source{display:flex;flex-direction:column}.explorer-tree__source-row{display:flex;align-items:center;gap:4px;width:100%;background:none;border:none;color:var(--c-text);padding:5px var(--sp-2);font-size:13px;cursor:pointer;text-align:left}.explorer-tree__source-row:hover{background:var(--c-surface-2)}.explorer-tree__source-name{flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.explorer-tree__source-count{font-size:11px;font-variant-numeric:tabular-nums}.explorer-tree__tags{list-style:none;margin:0;padding:0 0 4px}.explorer-tree__tag{display:flex;align-items:center;gap:6px;width:100%;background:none;border:none;color:var(--c-text);padding:4px var(--sp-2) 4px 28px;font-size:12.5px;cursor:pointer;text-align:left}.explorer-tree__tag:hover{background:var(--c-surface-2)}.explorer-tree__tag--selected{background:var(--c-accent-soft);color:var(--c-accent)}.explorer-tree__tag-dot{width:8px;height:8px;border-radius:50%;border:1px solid var(--c-border);flex:0 0 auto}.explorer-tree__tag-dot--on{background:var(--c-accent);border-color:var(--c-accent)}.explorer-tree__tag-name{flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.explorer-tree__tag-unit{font-size:11px;font-variant-numeric:tabular-nums}.formula-bar{border-bottom:1px solid var(--c-border);background:var(--c-surface-2);padding:var(--sp-2);display:flex;flex-direction:column;gap:var(--sp-2)}.formula-bar__head{display:flex;align-items:center;justify-content:space-between}.formula-bar__title{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--c-text-secondary)}.formula-bar__add{display:inline-flex;align-items:center;gap:4px;background:var(--c-surface);border:1px solid var(--c-border);color:var(--c-text);border-radius:var(--rad-sm);padding:4px 8px;cursor:pointer;font-size:12px}.formula-bar__add:hover{background:var(--c-accent-soft);border-color:var(--c-accent);color:var(--c-accent)}.formula-bar__empty{font-size:12px;padding:var(--sp-1) var(--sp-2)}.formula-row{display:flex;flex-direction:column;gap:var(--sp-1);padding:var(--sp-2);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--rad-sm)}.formula-row__top{display:flex;gap:var(--sp-1);align-items:center}.formula-row__label{flex:0 0 180px;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--rad-sm);color:var(--c-text);padding:4px 8px;font-size:13px}.formula-row__formula{flex:1 1 auto;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--rad-sm);color:var(--c-text);padding:4px 8px;font-size:13px;font-family:ui-monospace,SFMono-Regular,monospace}.formula-row__action,.formula-row__remove{display:inline-flex;align-items:center;gap:4px;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--rad-sm);color:var(--c-text);padding:4px 8px;cursor:pointer;font-size:12px}.formula-row__action:hover:not(:disabled){background:var(--c-accent-soft);border-color:var(--c-accent);color:var(--c-accent)}.formula-row__action:disabled{opacity:.5;cursor:not-allowed}.formula-row__remove:hover{background:var(--c-danger-soft, rgba(255, 0, 0, .1));border-color:var(--c-danger, #e11);color:var(--c-danger, #e11)}.formula-row__bindings{display:flex;flex-wrap:wrap;gap:var(--sp-1)}.formula-binding{display:inline-flex;align-items:center;gap:4px;font-size:12px}.formula-binding__letter{font-weight:700;font-family:ui-monospace,SFMono-Regular,monospace;font-size:13px;color:var(--c-accent);width:14px;text-align:center}.formula-binding select{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--rad-sm);color:var(--c-text);padding:3px 6px;font-size:12px;min-width:160px}.formula-row__status{font-size:11.5px;display:flex;gap:var(--sp-2)}.formula-row__error{color:var(--c-danger, #e11)}.formula-preview{display:inline-block;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--rad-sm);padding:4px 8px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12.5px}.explorer__view-toggle{display:inline-flex;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--rad-sm);overflow:hidden}.explorer__view-toggle button{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--c-text);padding:4px 10px;cursor:pointer;font-size:12px}.explorer__view-toggle button+button{border-left:1px solid var(--c-border)}.explorer__view-toggle button.is-active{background:var(--c-accent-soft);color:var(--c-accent)}.explorer__export{display:inline-flex;align-items:center;gap:4px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--rad-sm);color:var(--c-text);padding:4px 10px;cursor:pointer;font-size:12px}.explorer__export:hover:not(:disabled){background:var(--c-accent-soft);border-color:var(--c-accent);color:var(--c-accent)}.explorer__export:disabled{opacity:.5;cursor:not-allowed}.explorer-table-wrap{width:100%;height:100%;overflow:auto}.explorer-table{width:100%;border-collapse:collapse;font-size:12.5px;font-variant-numeric:tabular-nums}.explorer-table thead th{position:sticky;top:0;background:var(--c-surface-2);border-bottom:1px solid var(--c-border);padding:6px 10px;text-align:left;font-weight:600;z-index:1}.explorer-table tbody td{padding:4px 10px;border-bottom:1px solid var(--c-border)}.explorer-table tbody tr:hover{background:var(--c-surface-2)}.explorer-table__num{text-align:right}.explorer-table__ts-sort{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--c-text);font-weight:600;font-size:12.5px;cursor:pointer;padding:0}.explorer__chart{position:relative}.explorer__loading-pip{position:absolute;top:8px;right:12px;display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--c-text-secondary);background:color-mix(in srgb,var(--c-surface) 92%,transparent);border:1px solid var(--c-border);border-radius:999px;padding:3px 8px;pointer-events:none;z-index:2;-webkit-user-select:none;user-select:none}.explorer__loading-pip:before{content:"";width:8px;height:8px;border-radius:50%;border:1.5px solid var(--c-accent);border-right-color:transparent;animation:explorer-pip-spin .8s linear infinite}@keyframes explorer-pip-spin{to{transform:rotate(360deg)}}.view-toggle{display:inline-flex;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--rad-sm);overflow:hidden}.view-toggle button{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--c-text);padding:4px 12px;cursor:pointer;font-size:12px}.view-toggle button+button{border-left:1px solid var(--c-border)}.view-toggle button.is-active{background:var(--c-accent-soft);color:var(--c-accent)}.alarm-chip{display:inline-flex;align-items:center;gap:6px;align-self:center;padding:4px 12px;border-radius:var(--radius-pill);border:1px solid color-mix(in srgb,var(--c-danger) 45%,transparent);background:color-mix(in srgb,var(--c-danger) 12%,transparent);color:var(--c-danger);font-size:var(--fs-xs);font-weight:var(--fw-bold);text-decoration:none;white-space:nowrap;animation:alarm-chip-pulse 2.4s ease-in-out infinite}.alarm-chip:hover{background:color-mix(in srgb,var(--c-danger) 20%,transparent)}@keyframes alarm-chip-pulse{50%{border-color:var(--c-danger)}}.events-filters{display:flex;gap:var(--sp-3);align-items:center;margin-bottom:var(--sp-3);font-size:var(--fs-sm);color:var(--c-text-secondary)}.events-filters select{margin-left:var(--sp-1)}.events-list{display:flex;flex-direction:column;border:1px solid var(--c-border);border-radius:var(--radius-md);overflow:hidden}.event-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:var(--c-surface)}.event-row+.event-row{border-top:1px solid var(--c-border)}.event-row--open{box-shadow:inset 3px 0 0 var(--c-danger)}.event-row .sev{flex:0 0 64px;text-align:center}.event-row__main{flex:1;min-width:0}.event-row__title{font-size:var(--fs-sm);font-weight:var(--fw-medium);display:flex;align-items:center;gap:var(--sp-2)}.event-row__live-dot{width:7px;height:7px;border-radius:50%;background:var(--c-danger);animation:event-live-pulse 1.6s ease-in-out infinite}@keyframes event-live-pulse{50%{opacity:.35}}.event-row__meta{font-size:var(--fs-xs);color:var(--c-text-muted);display:flex;flex-wrap:wrap;gap:var(--sp-1);margin-top:1px}.event-row__acked{color:var(--c-text-secondary)}.event-row__time{text-align:right;font-size:var(--fs-xs);color:var(--c-text-secondary);white-space:nowrap}.event-row__time .dim{color:var(--c-text-muted)}.tag-tree-divider{padding:8px 8px 4px;font-size:11px;font-weight:var(--fw-bold);letter-spacing:.05em;text-transform:uppercase;color:var(--c-text-muted);border-top:1px solid var(--c-border);margin-top:6px}.tag-tree-divider:first-child{border-top:none;margin-top:0}.explorer-tree__divider{padding:10px 12px 4px;font-size:11px;font-weight:var(--fw-bold);letter-spacing:.05em;text-transform:uppercase;border-top:1px solid var(--c-border);margin-top:6px}.devices-tree__action{background:none;border:1px solid var(--c-border);color:var(--c-text-muted);border-radius:var(--rad-sm);padding:2px 6px;font-size:12px;cursor:pointer;display:inline-flex;align-items:center;gap:3px}.devices-tree__action:hover{background:var(--c-surface-2);color:var(--c-text)}.devices-tree__action--danger:hover{color:var(--c-danger);border-color:var(--c-danger)}.workspace{display:grid;grid-template-columns:minmax(280px,5fr) minmax(320px,6fr);gap:var(--sp-4);align-items:start}@media(max-width:900px){.workspace{grid-template-columns:1fr}}.workspace__tree{display:flex;flex-direction:column;gap:var(--sp-4);min-width:0}.workspace__panel{position:sticky;top:var(--sp-4);min-width:0}.wtree{border:1px solid var(--c-border);border-radius:var(--rad-md);background:var(--c-surface);padding-bottom:var(--sp-2);overflow:hidden}.wtree__project{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:var(--c-surface-2);border-bottom:1px solid var(--c-border);margin-bottom:var(--sp-1)}.wtree__project-name{font-weight:var(--fw-medium);font-size:var(--fs-sm)}.wtree__project-actions{display:inline-flex;gap:var(--sp-1)}.wtree__section{display:block;width:100%;text-align:left;background:none;border:none;border-top:1px solid var(--c-border);margin-top:var(--sp-2);padding:var(--sp-2) var(--sp-3) var(--sp-1);font-size:var(--fs-xs, 12px);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.04em}.wtree__section--toggle{cursor:pointer}.wtree__section--toggle:hover{color:var(--c-text)}.wtree__subsection{display:flex;align-items:center;gap:4px;padding:var(--sp-1) var(--sp-3);font-size:var(--fs-xs, 12px);color:var(--c-text-muted)}.wtree__row{display:flex;align-items:center;gap:6px;width:100%;text-align:left;background:none;border:none;padding:4px var(--sp-3);font-size:var(--fs-sm);color:var(--c-text);cursor:pointer;border-radius:0}.wtree__row:hover{background:var(--c-surface-2)}.wtree__row--selected{background:var(--c-accent-soft, var(--c-surface-2));color:var(--c-accent, var(--c-text))}.wtree__row--disabled{opacity:.55}.wtree__icon{flex:0 0 auto;color:var(--c-text-muted)}.wtree__icon--device{color:var(--c-accent, var(--c-text-muted))}.wtree__row--selected .wtree__icon{color:inherit}.wtree__label{flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wtree__value{flex:0 0 auto;font-size:var(--fs-xs, 12px);color:var(--c-text-muted);font-variant-numeric:tabular-nums}.wpanel{border:1px solid var(--c-border);border-radius:var(--rad-md);background:var(--c-surface);padding:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-3)}.wpanel--empty{border-style:dashed}.wpanel__head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--sp-2)}.wpanel__title{font-weight:var(--fw-medium);font-size:var(--fs-md)}.wpanel__slug{margin-left:var(--sp-2);font-size:var(--fs-xs, 12px);color:var(--c-text-muted)}.wpanel__meta{font-size:var(--fs-sm);color:var(--c-text-muted)}.wpanel__chip{background:var(--c-surface-2);border-radius:var(--rad-sm);padding:1px 6px}.wpanel__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}.wpanel__facts{display:grid;grid-template-columns:auto 1fr;gap:var(--sp-1) var(--sp-3);margin:0;font-size:var(--fs-sm)}.wpanel__facts dt{color:var(--c-text-muted)}.wpanel__facts dd{margin:0}.wpanel__foot{display:flex;justify-content:flex-end;border-top:1px solid var(--c-border);padding-top:var(--sp-3)}
