@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&family=Geist:wght@300;400;500;600;700&display=swap";:root,[data-theme=dark]{--bg-canvas: #111217;--bg-primary: #181b1f;--bg-secondary: #212327;--bg-elevated: #1c1f26;--bg-hover: rgba(204,204,220,.05);--border-subtle: rgba(204,204,220,.07);--border-muted: rgba(204,204,220,.07);--border-default: rgba(204,204,220,.15);--border-active: rgba(204,204,220,.25);--text-primary: #ccccdc;--text-secondary: rgba(204,204,220,.65);--text-muted: rgba(204,204,220,.4);--text-disabled: rgba(204,204,220,.25);--accent-blue: #3d71d9;--accent-green: #73BF69;--accent-amber: #ff9900;--accent-red: #F2495C;--accent-purple: #a78bfa;--sidebar-w: 224px;--sidebar-w-col: 56px;--topbar-h: 52px;--panel-bg: #181b1f;--panel-border: rgba(204,204,220,.07);--panel-radius: 2px;--radius-sm: 2px;--radius: 2px;--radius-lg: 4px;--radius-xl: 8px;--shadow-sm: 0 2px 4px rgba(0,0,0,.45);--shadow: 0 4px 12px rgba(0,0,0,.45);--shadow-lg: 0 8px 32px rgba(0,0,0,.65);--font-mono: "JetBrains Mono", "Fira Code", monospace;--font-sans: "Geist", "Inter", system-ui, sans-serif;--transition: .15s ease}[data-theme=light]{--bg-canvas: #f4f5f5;--bg-primary: #ffffff;--bg-secondary: #f4f5f5;--bg-elevated: #ffffff;--bg-hover: rgba(36,41,46,.05);--border-subtle: rgba(36,41,46,.12);--border-muted: rgba(36,41,46,.12);--border-default: rgba(36,41,46,.2);--border-active: rgba(36,41,46,.3);--text-primary: #1d1f33;--text-secondary: rgba(29,31,51,.65);--text-muted: rgba(29,31,51,.4);--text-disabled: rgba(29,31,51,.25);--panel-bg: #ffffff;--panel-border: rgba(36,41,46,.12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background:var(--bg-canvas);color:var(--text-primary);line-height:1.5;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}a{color:var(--accent-blue);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-active);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-shell{display:flex;height:100vh;overflow:hidden;position:relative}.sidebar-overlay{position:fixed;inset:0;background:#0009;z-index:149;backdrop-filter:blur(2px)}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;margin-left:0;transition:margin-left var(--transition)}@media (min-width: 768px){.main-area{margin-left:var(--sidebar-w)}.main-area.sidebar-collapsed{margin-left:var(--sidebar-w-col)}}.content-area{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--bg-canvas)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;z-index:150;transform:translate(-100%);transition:transform var(--transition),width var(--transition);overflow:hidden}.sidebar.open{transform:translate(0)}@media (min-width: 768px){.sidebar{transform:translate(0)}.sidebar.collapsed{width:var(--sidebar-w-col)}}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 12px;border-bottom:1px solid var(--border-subtle);min-height:var(--topbar-h);flex-shrink:0}.sidebar-logo{display:flex;align-items:center;gap:9px}.sidebar-brand{font-size:16px;font-weight:700;letter-spacing:-.5px;color:var(--text-primary)}.sidebar-collapse-btn{background:none;border:none;color:var(--text-muted);padding:4px;border-radius:var(--radius-sm);display:none}@media (min-width: 768px){.sidebar-collapse-btn{display:flex;align-items:center}}.sidebar-collapse-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.sidebar.collapsed .sidebar-collapse-btn{transform:rotate(180deg)}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:var(--radius);margin:1px 6px;color:var(--text-secondary);text-decoration:none;transition:all var(--transition);white-space:nowrap;overflow:hidden;font-size:13.5px;font-weight:450}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary);text-decoration:none}.nav-item.active{background:#00c8ff1a;color:var(--accent-blue)}.nav-item.active .nav-icon{color:var(--accent-blue)}.nav-icon{flex-shrink:0;display:flex;align-items:center}.nav-label{overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .nav-item{justify-content:center;padding:8px;margin:1px 8px}.sidebar.collapsed .nav-label{display:none}.sidebar-footer{padding:10px 12px;border-top:1px solid var(--border-subtle);flex-shrink:0}.user-info{display:flex;align-items:center;gap:9px}.user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:#fff;flex-shrink:0}.user-details{overflow:hidden}.user-name{font-size:12.5px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:var(--text-muted)}.org-switcher,.org-switcher-static{padding:8px 10px;border-bottom:1px solid var(--border-subtle);position:relative;flex-shrink:0}.org-switcher-btn{width:100%;display:flex;align-items:center;gap:8px;background:none;border:none;padding:6px 8px;border-radius:var(--radius);cursor:pointer;color:var(--text-secondary);transition:background var(--transition)}.org-switcher-btn:hover{background:var(--bg-hover)}.org-switcher-static{display:flex;align-items:center;gap:8px;padding:14px 12px}.org-badge{width:28px;height:28px;border-radius:6px;background:linear-gradient(135deg,#1e40af,#0ea5e9);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:#fff;flex-shrink:0}.org-badge.sm{width:22px;height:22px;font-size:10px}.org-info{flex:1;min-width:0;text-align:left}.org-name{font-size:12.5px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.org-role{font-size:11px;color:var(--text-muted)}.org-dropdown{position:absolute;left:8px;right:8px;top:calc(100% + 4px);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:6px;z-index:200;overflow:hidden}.org-dropdown-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:4px 8px 6px}.org-dropdown-item{width:100%;display:flex;align-items:center;gap:8px;background:none;border:none;padding:7px 8px;border-radius:var(--radius);cursor:pointer;text-align:left;color:var(--text-secondary);transition:background var(--transition)}.org-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.org-dropdown-item.active{color:var(--text-primary)}.org-dropdown-name{font-size:12.5px;font-weight:500;color:var(--text-primary)}.org-dropdown-role{font-size:11px;color:var(--text-muted)}.topbar{height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;padding:0 12px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:100;flex-shrink:0;gap:8px}.topbar-left{display:flex;align-items:center;gap:10px;min-width:0}.topbar-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.topbar-menu-btn{background:none;border:none;color:var(--text-muted);padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center}.topbar-menu-btn:hover{color:var(--text-primary);background:var(--bg-hover)}@media (min-width: 768px){.topbar-menu-btn{display:none}}.topbar-title{display:flex;align-items:center;gap:6px;overflow:hidden}.topbar-folder{color:var(--text-muted);font-size:13px;white-space:nowrap}.topbar-dash-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unsaved-badge{font-size:10px;background:#f59e0b26;color:var(--accent-amber);padding:1px 6px;border-radius:999px;border:1px solid rgba(245,158,11,.3);flex-shrink:0}.topbar-edit-controls{display:flex;gap:5px;align-items:center}.topbar-time-btn,.topbar-refresh-btn{font-size:12px;display:flex;align-items:center}.time-label{max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 480px){.time-label{max-width:70px}}.topbar-icon-btn{background:none;border:none;color:var(--text-muted);padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center}.topbar-icon-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.topbar-user-btn{background:none;border:none;padding:0;display:flex}.topbar-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:#fff;cursor:pointer}.dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:6px;z-index:200;min-width:160px;animation:dropIn .1s ease}.time-dropdown{min-width:200px}.dropdown-section-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:4px 10px 6px}.dropdown-item{width:100%;text-align:left;background:none;border:none;padding:7px 10px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:background var(--transition);display:block}.dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.dropdown-item.active{color:var(--accent-blue)}.dropdown-item-danger{color:var(--accent-red)!important}.dropdown-divider{height:1px;background:var(--border-subtle);margin:4px 0}.user-dropdown{min-width:220px}.dropdown-user-info{padding:8px 10px}.dropdown-user-name{font-weight:600;color:var(--text-primary);font-size:13.5px}.dropdown-user-email{color:var(--text-muted);font-size:12px;margin-top:1px}.dropdown-user-org{color:var(--text-secondary);font-size:11.5px;margin-top:4px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:7px 13px;border-radius:var(--radius);font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all var(--transition);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-blue);color:#000;border-color:var(--accent-blue)}.btn-primary:hover:not(:disabled){background:#33d4ff}.btn-outline{background:transparent;color:var(--text-secondary);border-color:var(--border-default)}.btn-outline:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-active)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:5px 10px;font-size:12px}.btn-xs{padding:2px 7px;font-size:11px}.btn-full{width:100%}.btn-loading{display:flex;align-items:center;gap:8px}.spinner-sm{width:14px;height:14px;border:2px solid rgba(0,0,0,.3);border-top-color:#000;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes dropIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.loading-fullpage{display:flex;align-items:center;justify-content:center;height:100vh;gap:12px;color:var(--text-muted);flex-direction:column}.spinner{width:28px;height:28px;border:3px solid var(--border-default);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .7s linear infinite}.loading-shimmer{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:400px 100%;animation:shimmer 1.4s infinite}.page-container{padding:20px 16px;max-width:1400px;margin:0 auto}@media (min-width: 768px){.page-container{padding:24px}}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:12px;flex-wrap:wrap}.page-title{font-size:22px;font-weight:700;color:var(--text-primary)}.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:3px}.page-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.panel-wrapper{background:var(--panel-bg);border:1px solid var(--border-subtle);border-radius:var(--panel-radius);overflow:hidden;position:relative;transition:border-color var(--transition)}.panel-wrapper.edit-mode{cursor:pointer}.panel-wrapper.edit-mode:hover{border-color:var(--border-active)}.panel-wrapper.selected{border-color:var(--accent-blue)!important;box-shadow:0 0 0 1px #3d71d980}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;height:34px;border-bottom:1px solid var(--border-subtle)}.panel-title{font-size:12.5px;font-weight:500;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.panel-header-actions{display:flex;align-items:center;gap:4px}.panel-loading-dot{width:6px;height:6px;border-radius:50%;background:#3d71d9;animation:pulse 1.2s ease infinite}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.panel-body{position:relative;overflow:hidden}.panel-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:8px;color:var(--accent-red);font-size:12px;padding:16px;text-align:center}.panel-empty{display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:12px}.panel-edit-overlay{position:absolute;inset:0;pointer-events:none}.panel-edit-badge{position:absolute;top:36px;right:4px;background:#00c8ff26;color:var(--accent-blue);font-size:9px;padding:1px 5px;border-radius:3px;font-family:var(--font-mono)}.panel-drag-handle{position:absolute;top:4px;left:50%;transform:translate(-50%);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:3px;cursor:move;color:var(--text-muted);display:none;align-items:center;z-index:10}.grid-panel:hover .panel-drag-handle{display:flex}.panel-resize-handle{position:absolute;bottom:3px;right:3px;color:var(--text-muted);cursor:se-resize;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:2px;display:none;align-items:center;z-index:10}.grid-panel:hover .panel-resize-handle{display:flex}.panel-edit-actions{position:absolute;top:-1px;right:28px;display:flex;gap:2px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:2px;z-index:20}.panel-action-btn{background:none;border:none;color:var(--text-muted);padding:4px;border-radius:3px;cursor:pointer;display:flex;align-items:center}.panel-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.panel-action-danger:hover{color:var(--accent-red)!important}.grid-panel{user-select:none}.grid-panel.selected{z-index:10}.stat-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:8px;text-align:center}.stat-value{font-weight:700;line-height:1;font-family:var(--font-mono);transition:color .3s}.stat-label{font-size:11px;color:var(--text-muted);margin-top:6px}.stat-skeleton{display:inline-block;width:80px;height:1em;background:var(--border-default);border-radius:4px;animation:shimmer 1.4s infinite;background-size:400px 100%;background-image:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%)}.progress-panel,.table-panel,.markdown-panel{overflow:hidden}.table-row:hover td{background:var(--bg-hover)!important}.dashboard-view{height:100%;display:flex;flex-direction:column}.variables-bar{display:flex;flex-wrap:wrap;gap:6px;padding:8px 16px;border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);flex-shrink:0}.variable-chip{display:flex;align-items:center;gap:6px}.var-label{font-size:12px;color:var(--text-muted)}.var-select{background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-primary);font-size:12px;padding:2px 22px 2px 7px;border-radius:var(--radius-sm);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center}.dashboard-layout{flex:1;display:flex;overflow:hidden}.canvas-area{flex:1;overflow:auto;padding:16px}.canvas-area:has(+.panel-editor-drawer){flex:1}.panel-editor-drawer{width:340px;flex-shrink:0;border-left:1px solid var(--border-subtle);background:var(--bg-secondary);overflow-y:auto}@media (max-width: 900px){.dashboard-layout{flex-direction:column}.panel-editor-drawer{width:100%;height:50%;border-left:none;border-top:1px solid var(--border-subtle)}}.panel-editor{display:flex;flex-direction:column;height:100%}.panel-editor-header{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.panel-title-input{flex:1;background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-primary);font-size:13.5px;font-weight:600;padding:5px 9px;border-radius:var(--radius-sm)}.panel-title-input:focus{outline:none;border-color:var(--accent-blue)}.panel-editor-tabs{display:flex;overflow-x:auto;padding:0 4px;border-bottom:1px solid var(--border-subtle);flex-shrink:0;scrollbar-width:none}.panel-editor-tabs::-webkit-scrollbar{display:none}.editor-tab{background:none;border:none;color:var(--text-muted);padding:8px 11px;font-size:12px;cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:all var(--transition)}.editor-tab:hover{color:var(--text-primary)}.editor-tab.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}.panel-editor-body{flex:1;overflow-y:auto}.editor-section{padding:12px}.editor-label{display:block;font-size:11.5px;font-weight:500;color:var(--text-muted);margin-bottom:5px}.editor-row{margin-bottom:10px}.editor-hint{font-size:12px;color:var(--text-muted);line-height:1.5;margin-bottom:12px}.editor-input,.editor-select,.editor-textarea{width:100%;background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-primary);font-size:12.5px;padding:6px 9px;border-radius:var(--radius-sm);transition:border-color var(--transition)}.editor-input:focus,.editor-select:focus,.editor-textarea:focus{outline:none;border-color:var(--accent-blue)}.editor-select.sm{padding:3px 22px 3px 7px;font-size:12px;width:auto}.editor-textarea{resize:vertical;min-height:72px;font-family:var(--font-mono)}.panel-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}.panel-type-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 4px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius);color:var(--text-secondary);font-size:10px;cursor:pointer;transition:all var(--transition);text-align:center}.panel-type-btn:hover{background:var(--bg-hover);border-color:var(--border-active);color:var(--text-primary)}.panel-type-btn.active{background:#3d71d91f;border-color:var(--accent-blue);color:var(--accent-blue)}.transform-row{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-sm);margin-bottom:4px}.transform-name{font-size:12px;color:var(--text-primary);font-family:var(--font-mono)}.toggle-switch{display:flex;align-items:center;gap:8px}.toggle-switch input{display:none}.toggle-track{width:36px;height:20px;background:var(--border-default);border-radius:999px;position:relative;cursor:pointer;transition:background var(--transition)}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform var(--transition)}.toggle-switch input:checked+.toggle-track{background:var(--accent-blue)}.toggle-switch input:checked+.toggle-track:after{transform:translate(16px)}.dash-list-layout{display:flex;gap:20px}.dash-list-sidebar{width:200px;flex-shrink:0}@media (max-width: 640px){.dash-list-layout{flex-direction:column}.dash-list-sidebar{width:100%}}.dash-list-main{flex:1;min-width:0}.filter-section{margin-bottom:16px}.filter-label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:4px;padding:0 4px}.filter-item{width:100%;text-align:left;background:none;border:none;display:flex;align-items:center;padding:6px 8px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12.5px;cursor:pointer;transition:all var(--transition)}.filter-item:hover{background:var(--bg-hover);color:var(--text-primary)}.filter-item.active{background:#3d71d91a;color:var(--accent-blue)}.folder-count{margin-left:auto;font-size:11px;background:var(--bg-elevated);color:var(--text-muted);padding:0 5px;border-radius:999px}.tag-filter-list{display:flex;flex-wrap:wrap;gap:4px}.dash-search-bar{margin-bottom:12px}.search-input-wrap{position:relative}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-primary);font-size:13px;padding:8px 10px 8px 34px;border-radius:var(--radius);transition:border-color var(--transition)}.search-input:focus{outline:none;border-color:var(--accent-blue)}.search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer;padding:2px 4px}.dash-list{display:flex;flex-direction:column;gap:2px}.dash-folder-group{margin-bottom:8px}.dash-folder-header{display:flex;align-items:center;gap:6px;padding:6px 8px;color:var(--text-muted);font-size:12px;font-weight:600}.dash-row{display:flex;align-items:center;justify-content:space-between;padding:9px 10px;border-radius:var(--radius);cursor:pointer;transition:background var(--transition);border:1px solid transparent;gap:8px}.dash-row:hover{background:var(--bg-hover);border-color:var(--border-subtle)}.dash-row-left{display:flex;align-items:center;gap:8px;min-width:0}.dash-row-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.dash-row-info{min-width:0}.dash-row-title{font-size:13.5px;font-weight:500;color:var(--text-primary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-row-meta{display:flex;gap:8px;margin-top:1px}.dash-row-time,.dash-row-author{font-size:11px;color:var(--text-muted)}.dash-row-version{font-size:11px;color:var(--text-disabled);font-family:var(--font-mono)}.star-btn{background:none;border:none;font-size:14px;padding:2px 4px;cursor:pointer;color:var(--text-muted);transition:color var(--transition)}.star-btn:hover,.star-btn.starred{color:var(--accent-amber)}.dash-delete-btn{opacity:0}.dash-row:hover .dash-delete-btn{opacity:1}.dash-skeleton{height:50px;background:var(--bg-elevated);border-radius:var(--radius);margin-bottom:4px;background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:400px 100%;animation:shimmer 1.4s infinite}.tag-chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:500;background:#3d71d91a;color:var(--accent-blue);border:1px solid rgba(61,113,217,.25);cursor:pointer;white-space:nowrap;transition:background var(--transition)}.tag-chip:hover{background:#3d71d92e}.tag-chip.active{background:#3d71d938}.tag-chip.sm{padding:1px 6px;font-size:10px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}.login-bg{position:fixed;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(61,113,217,.06) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 80%,rgba(61,113,217,.04) 0%,transparent 50%),var(--bg-canvas);pointer-events:none}.login-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:36px 32px;width:100%;max-width:420px;position:relative;z-index:1;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:24px}.login-brand{font-size:22px;font-weight:800;letter-spacing:-1px}.login-title{font-size:20px;font-weight:700;margin-bottom:6px}.login-subtitle{color:var(--text-muted);font-size:13.5px;margin-bottom:22px}.login-error{display:flex;align-items:center;gap:7px;background:#f871711a;border:1px solid rgba(248,113,113,.3);color:var(--accent-red);padding:9px 12px;border-radius:var(--radius);font-size:13px;margin-bottom:16px}.login-form{display:flex;flex-direction:column;gap:14px}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:12.5px;font-weight:500;color:var(--text-secondary)}.form-input{background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-primary);font-size:14px;padding:9px 12px;border-radius:var(--radius);transition:border-color var(--transition)}.form-input:focus{outline:none;border-color:var(--accent-blue)}.demo-accounts{margin-top:20px;padding-top:18px;border-top:1px solid var(--border-subtle)}.demo-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:8px}.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.demo-btn{display:flex;flex-direction:column;gap:2px;text-align:left;background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius-sm);padding:7px 9px;cursor:pointer;transition:all var(--transition)}.demo-btn:hover{background:var(--bg-hover);border-color:var(--border-active)}.demo-email{font-size:10.5px;color:var(--text-muted);font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:3px;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-badge.platform,.role-badge.orgadmin{background:#3d71d91f;color:var(--accent-blue)}.role-badge.admin{background:#3d71d91a;color:var(--accent-blue)}.role-badge.editor{background:#73bf691f;color:var(--accent-green)}.role-badge.viewer{background:#64748b26;color:var(--text-muted)}.home-welcome{margin-bottom:24px}.home-greeting{font-size:24px;font-weight:700}.home-org{display:flex;align-items:center;gap:8px;margin-top:5px}.org-badge-inline{background:#3d71d91f;color:var(--accent-blue);padding:1px 8px;border-radius:999px;font-size:12px;font-weight:500}.role-label{font-size:12px;color:var(--text-muted)}.home-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}@media (min-width: 640px){.home-stats{grid-template-columns:repeat(4,1fr)}}.home-stat-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:4px}.stat-card-icon{font-size:20px}.stat-card-value{font-size:28px;font-weight:700;color:var(--accent-blue);font-family:var(--font-mono);line-height:1}.stat-card-label{font-size:12px;color:var(--text-muted)}.home-grid{display:grid;gap:20px}@media (min-width: 900px){.home-grid{grid-template-columns:1fr 1fr}}.home-section{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:16px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.section-title{font-size:14px;font-weight:600}.section-link{background:none;border:none;color:var(--accent-blue);font-size:12.5px;cursor:pointer}.section-link:hover{text-decoration:underline}.home-empty{text-align:center;padding:20px;color:var(--text-muted);font-size:13px}.dash-shortcut-list{display:flex;flex-direction:column;gap:2px}.dash-shortcut{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition)}.dash-shortcut:hover{background:var(--bg-hover)}.shortcut-icon{color:var(--text-muted);flex-shrink:0}.shortcut-info{flex:1;min-width:0}.shortcut-title{font-size:13px;font-weight:500;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shortcut-folder{font-size:11px;color:var(--text-muted);display:block}.quick-links{display:grid;grid-template-columns:1fr 1fr;gap:6px}.quick-link-btn{display:flex;align-items:center;gap:7px;padding:9px 10px;background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:var(--radius);cursor:pointer;font-size:12.5px;color:var(--text-secondary);transition:all var(--transition);text-align:left}.quick-link-btn:hover{background:var(--bg-hover);border-color:var(--border-medium);color:var(--text-primary)}.tab-bar{display:flex;border-bottom:1px solid var(--border-subtle);margin-bottom:20px;overflow-x:auto}.tab-btn{background:none;border:none;color:var(--text-muted);padding:9px 14px;font-size:13px;cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:all var(--transition);margin-bottom:-1px}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}.data-list{display:flex;flex-direction:column;gap:3px}.list-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius);gap:10px;transition:border-color var(--transition)}.list-row:hover{border-color:var(--border-default)}.list-row-left{display:flex;align-items:center;gap:10px;min-width:0}.list-row-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.list-row-title{font-size:13.5px;font-weight:500;color:var(--text-primary)}.list-row-meta{display:flex;align-items:center;gap:8px;margin-top:3px;font-size:12px;color:var(--text-muted);flex-wrap:wrap}.state-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.state-dot.normal{background:#73bf69}.state-dot.alerting{background:#f2495c}.state-dot.pending{background:#f90}.state-dot.inactive{background:#ccccdc40}.state-dot.error{background:#f2495c}.member-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,#3d71d9,#6ed0e0);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff}.datasource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.datasource-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:14px;transition:border-color var(--transition)}.datasource-card:hover{border-color:var(--border-default)}.ds-card-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px}.ds-type-icon{font-size:22px;flex-shrink:0}.ds-name{font-size:14px;font-weight:600;color:var(--text-primary)}.ds-type-label{font-size:11.5px;color:var(--text-muted)}.ds-default-badge{margin-left:auto;font-size:10px;background:#22d3a01a;color:var(--accent-green);padding:1px 6px;border-radius:999px;flex-shrink:0}.ds-url{font-size:11px;color:var(--text-muted);font-family:var(--font-mono);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ds-card-actions{display:flex;gap:6px}.alert-state-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:3px;font-size:11px;font-weight:600}.alert-state-badge.alerting{background:#f2495c1a;color:var(--accent-red)}.alert-state-badge.normal{background:#73bf691a;color:var(--accent-green)}.alert-state-badge.pending{background:#ff99001a;color:var(--accent-amber)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:300;padding:16px;backdrop-filter:blur(3px);animation:fadeIn .15s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);width:100%;max-width:560px;box-shadow:var(--shadow-lg);animation:slideUp .2s ease;overflow:hidden}.modal-sm{max-width:380px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-subtle)}.modal-header h2{font-size:15px;font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:2px 5px;border-radius:3px}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-body{padding:16px 18px;display:flex;flex-direction:column;gap:4px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px;border-top:1px solid var(--border-subtle)}.toast-container{position:fixed;bottom:20px;right:16px;z-index:500;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:10px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:11px 14px;min-width:260px;max-width:360px;box-shadow:var(--shadow-lg);pointer-events:all;animation:slideUp .2s ease}.toast-icon{flex-shrink:0;margin-top:1px}.toast-content{flex:1;min-width:0}.toast-title{font-size:13px;font-weight:600;color:var(--text-primary)}.toast-message{font-size:12px;color:var(--text-muted);margin-top:2px}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:1px 4px;font-size:12px;flex-shrink:0}.toast-close:hover{color:var(--text-primary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;gap:12px}.empty-icon{color:var(--text-disabled);margin-bottom:4px}.empty-state h3{font-size:16px;font-weight:600}.empty-state p{font-size:13.5px;color:var(--text-muted);max-width:300px}.coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center;gap:10px}.coming-soon-icon{font-size:40px}.coming-soon h2{font-size:18px;font-weight:600}.coming-soon p{color:var(--text-muted);font-size:13.5px}.text-danger{color:var(--accent-red)!important}.text-success{color:var(--accent-green)!important}.text-muted{color:var(--text-muted)!important}.toggle-row{display:flex;align-items:center;justify-content:space-between}.loading-state{display:flex;justify-content:center;padding:40px;color:var(--text-muted)}.panel-loading-placeholder{display:flex;align-items:center;justify-content:center}.query-tab{padding:0}.query-tab>.qb-row{padding:10px 12px 0}.qb-row{display:flex;align-items:center;gap:8px;padding:4px 12px}.qb-label{font-size:11.5px;color:var(--text-muted);font-weight:500;min-width:80px}.query-options-bar{display:flex;align-items:center;gap:8px;padding:7px 12px;border-bottom:1px solid var(--border-subtle);border-top:1px solid var(--border-subtle);margin-top:10px;background:#00000026}.qo-label{font-size:11px;color:var(--text-muted);font-weight:600}.qo-pill{font-size:10.5px;color:var(--text-muted);background:var(--bg-elevated);padding:1px 7px;border-radius:999px;border:1px solid var(--border-muted)}.targets-list{display:flex;flex-direction:column}.target-block{border-bottom:1px solid var(--border-subtle)}.target-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;user-select:none;transition:background var(--transition);gap:8px}.target-header:hover{background:var(--bg-hover)}.target-header-left{display:flex;align-items:center;gap:7px;min-width:0;flex:1}.target-refid{font-size:12px;font-weight:700;font-family:var(--font-mono);color:var(--accent-blue);background:#3d71d91f;padding:1px 6px;border-radius:3px;flex-shrink:0}.target-ds-tag{font-size:10px;color:var(--text-muted);background:var(--bg-elevated);padding:1px 5px;border-radius:3px;border:1px solid var(--border-muted);flex-shrink:0}.target-preview{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-mono)}.target-header-actions{display:flex;align-items:center;gap:1px;flex-shrink:0}.target-icon-btn{background:none;border:none;color:var(--text-muted);padding:4px 5px;border-radius:3px;cursor:pointer;display:flex;align-items:center;transition:all var(--transition)}.target-icon-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.target-icon-danger:hover{color:var(--accent-red)!important}.target-drag-handle{font-size:11px;color:var(--text-disabled);cursor:grab;padding:4px 3px;letter-spacing:-1px}.target-body{padding:0 0 10px;border-top:1px solid var(--border-subtle);background:#0003}.qb-builder{padding:6px 0}.qb-builder-row{display:flex;align-items:flex-start;gap:8px;padding:5px 12px;min-height:34px}.qb-kw{font-size:10.5px;font-weight:700;font-family:var(--font-mono);color:#a78bfa;min-width:88px;padding-top:5px;flex-shrink:0;letter-spacing:.5px}.qb-chips{display:flex;flex-wrap:wrap;align-items:center;gap:4px;flex:1}.qb-chips-wrap{flex-wrap:wrap}.qb-chip{display:inline-flex;align-items:center;gap:3px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:4px;padding:3px 7px;font-size:11.5px;color:var(--text-primary);white-space:nowrap}.qb-chip-fn{color:var(--text-muted);font-family:var(--font-mono);font-size:10.5px}.qb-chip-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;line-height:1;padding:0 1px;margin-left:2px}.qb-chip-remove:hover{color:var(--accent-red)}.qb-chip-add{background:none;border:1px dashed var(--border-active);color:var(--text-muted);cursor:pointer;border-radius:4px;padding:2px 8px;font-size:14px;line-height:1.2;transition:all var(--transition)}.qb-chip-add:hover{background:var(--bg-hover);color:var(--text-primary)}.qb-chip-select{background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-primary);font-size:11.5px;padding:3px 20px 3px 7px;border-radius:4px;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center}.qb-filter-chip{display:inline-flex;align-items:center;gap:3px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:4px;padding:2px 4px}.qb-filter-input{background:transparent;border:none;color:var(--text-primary);font-size:11.5px;outline:none;width:60px;font-family:var(--font-mono)}.qb-filter-op{background:transparent;border:none;color:#f90;font-size:11px;outline:none;cursor:pointer;font-family:var(--font-mono);font-weight:600;padding:0 2px}.raw-query-editor{padding:8px 12px}.raw-query-textarea{font-family:var(--font-mono)!important;font-size:11.5px!important;line-height:1.6!important;background:#00000040!important;min-height:80px}.target-mode-row{display:flex;gap:2px;padding:6px 12px 2px}.mode-toggle-btn{background:none;border:1px solid var(--border-default);color:var(--text-muted);font-size:11px;padding:2px 10px;cursor:pointer;border-radius:3px;transition:all var(--transition)}.mode-toggle-btn:first-child{border-radius:3px 0 0 3px;border-right:none}.mode-toggle-btn:last-child{border-radius:0 3px 3px 0}.mode-toggle-btn.active{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-active)}.target-options-row{display:flex;align-items:center;gap:6px;padding:6px 12px 2px;flex-wrap:wrap}.target-opt-label{font-size:11px;color:var(--text-muted)}.qb-add-btn{margin:10px 12px 12px;display:flex;align-items:center;gap:6px}.vis-section{margin-bottom:4px}.vis-section-header{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:600;color:#ccccdc66;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;padding-bottom:5px;border-bottom:1px solid var(--border-subtle)}.editor-divider{height:1px;background:var(--border-subtle);margin:14px 0}.btn-group{display:inline-flex;border:1px solid var(--border-default);border-radius:var(--radius-sm);overflow:hidden}.btn-group-item{background:none;border:none;border-right:1px solid var(--border-default);color:var(--text-muted);font-size:11.5px;padding:4px 10px;cursor:pointer;transition:all var(--transition);white-space:nowrap}.btn-group-item:last-child{border-right:none}.btn-group-item:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-group-item.active{background:var(--bg-secondary);color:var(--text-primary);font-weight:500;border-color:var(--border-medium)}.editor-color{width:32px;height:24px;padding:1px;border-radius:3px;border:1px solid var(--border-default);cursor:pointer;background:var(--bg-elevated)}.threshold-list{display:flex;flex-direction:column;gap:5px;margin-top:6px}.threshold-row{display:flex;align-items:center;gap:7px}.threshold-base-label{font-size:12px;color:var(--text-muted);font-style:italic}.editor-input.sm{padding:4px 7px;font-size:12px}.topbar-time-btn.time-zoomed{border-color:#f906;color:var(--accent-amber)}.topbar-time-btn.time-zoomed svg{color:var(--accent-amber)}.topbar-zoom-reset-btn{background:#ff99001a;border:1px solid rgba(255,153,0,.35);color:var(--accent-amber);display:flex;align-items:center;gap:4px;font-size:12px;padding:5px 10px;border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.topbar-zoom-reset-btn:hover{background:#ff99002e;border-color:#ff99008c}.time-current-range{padding:5px 10px 7px;font-size:12px;font-weight:500;color:var(--accent-amber);font-family:var(--font-mono)}.chart-drag-hint{position:absolute;bottom:30px;right:20px;font-size:10px;color:#ccccdc33;pointer-events:none;user-select:none;letter-spacing:.3px;opacity:0;transition:opacity .3s}.panel-wrapper:not(.edit-mode):hover .chart-drag-hint{opacity:1}.zr-drag-area{background:#3d71d91f!important;border:1px solid rgba(61,113,217,.55)!important}.ts-panel-wrap{user-select:none}.ts-selection-overlay{position:absolute;pointer-events:none;background:#3d71d924;border-left:1px solid rgba(61,113,217,.7);border-right:1px solid rgba(61,113,217,.7);border-top:none;border-bottom:none;transition:opacity .06s ease;z-index:10}.topbar-dash-name-input{background:transparent;border:1px solid rgba(204,204,220,.25);border-radius:var(--radius);color:var(--text-primary);font-size:14px;font-weight:600;font-family:var(--font-sans);padding:3px 8px;outline:none;min-width:120px;max-width:360px;transition:border-color var(--transition),box-shadow var(--transition)}.topbar-dash-name-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3d71d933;background:#3d71d90f}.topbar-dash-name-input::placeholder{color:var(--text-disabled);font-weight:400}.ds-settings-overlay{position:fixed;inset:0;z-index:200;background:var(--bg-canvas);overflow-y:auto;animation:fadeIn .12s ease}.ds-settings-page{max-width:860px;margin:0 auto;padding:20px 24px 60px}.ds-settings-breadcrumb{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text-muted);margin-bottom:16px}.ds-breadcrumb-link{background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:12.5px;padding:0;transition:color var(--transition)}.ds-breadcrumb-link:hover{color:var(--text-primary);text-decoration:underline}.ds-breadcrumb-sep{color:var(--text-disabled)}.ds-breadcrumb-current{color:var(--text-muted)}.ds-settings-title{font-size:28px;font-weight:500;color:var(--text-primary);margin-bottom:20px;line-height:1.2}.ds-settings-tabs{display:flex;align-items:center;gap:0;position:relative}.ds-settings-tab{background:none;border:none;color:var(--text-secondary);font-size:14px;font-weight:400;padding:10px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--transition),border-color var(--transition);white-space:nowrap}.ds-settings-tab:hover{color:var(--text-primary)}.ds-settings-tab.active{color:var(--text-primary);border-bottom-color:var(--accent-amber);font-weight:500}.ds-settings-close-btn{margin-left:auto;background:none;border:none;color:var(--text-muted);padding:8px;cursor:pointer;border-radius:var(--radius);display:flex;align-items:center;transition:all var(--transition)}.ds-settings-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.ds-settings-tab-divider{height:1px;background:var(--border-subtle);margin-bottom:28px}.ds-settings-body{max-width:620px}.ds-settings-section{display:flex;flex-direction:column;gap:20px}.ds-field{display:flex;flex-direction:column;gap:6px}.ds-label{font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:2px}.ds-hint{font-size:12px;color:var(--text-muted);line-height:1.5;margin-top:-2px;margin-bottom:4px}.ds-input{width:100%;background:var(--bg-secondary);border:1px solid var(--border-medium);color:var(--text-primary);font-size:14px;padding:8px 12px;border-radius:var(--radius);transition:border-color var(--transition);font-family:var(--font-sans)}.ds-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #3d71d92e}.ds-input::placeholder{color:var(--text-disabled)}.ds-textarea{width:100%;background:var(--bg-secondary);border:1px solid var(--border-medium);color:var(--text-primary);font-size:14px;padding:8px 12px;border-radius:var(--radius);resize:vertical;font-family:var(--font-sans);min-height:80px;line-height:1.5;transition:border-color var(--transition)}.ds-textarea:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #3d71d92e}.ds-select-wrap{position:relative;display:flex;align-items:center}.ds-select-icon{position:absolute;left:10px;color:var(--text-muted);pointer-events:none;z-index:1}.ds-select{width:100%;background:var(--bg-secondary);border:1px solid var(--border-medium);color:var(--text-primary);font-size:14px;padding:8px 32px 8px 30px;border-radius:var(--radius);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color var(--transition)}.ds-field>.ds-select{padding-left:12px}.ds-select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #3d71d92e}.ds-tag-row{display:flex;gap:8px;align-items:center}.ds-tag-input{flex:1}.ds-tags-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.ds-tag-chip{display:inline-flex;align-items:center;gap:5px;background:#3d71d91f;border:1px solid rgba(61,113,217,.25);color:var(--accent-blue);font-size:12px;padding:2px 8px;border-radius:var(--radius-pill)}.ds-tag-remove{background:none;border:none;cursor:pointer;color:#3d71d999;font-size:14px;line-height:1;padding:0 1px;transition:color var(--transition)}.ds-tag-remove:hover{color:var(--accent-red)}.ds-section-heading{display:flex;align-items:center;font-size:18px;font-weight:500;color:var(--text-primary);padding-top:8px;border-top:1px solid var(--border-subtle);cursor:pointer;user-select:none}.ds-actions-row{display:flex;align-items:center;gap:12px;padding-top:12px;margin-top:8px;border-top:1px solid var(--border-subtle);flex-wrap:wrap}.ds-delete-btn{margin-left:auto;color:var(--accent-red)!important}.ds-delete-btn:hover{background:#f2495c14!important}.ds-empty-tab{display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding:24px 0}.ds-empty-tab h3{font-size:16px;font-weight:500}.ds-empty-tab p{font-size:13.5px;color:var(--text-muted);line-height:1.5;max-width:500px}.ds-versions-table{width:100%;border-collapse:collapse;font-size:13px}.ds-versions-table th{text-align:left;padding:8px 12px;font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-subtle)}.ds-versions-table td{padding:10px 12px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);vertical-align:middle}.ds-versions-table tr:hover td{background:var(--bg-hover)}.ds-version-current td{color:var(--text-primary)}.ds-version-num{font-family:var(--font-mono);font-weight:600;color:var(--text-primary);margin-right:6px}.ds-version-badge{display:inline-flex;font-size:10px;font-weight:600;background:#3d71d91f;color:var(--accent-blue);padding:1px 6px;border-radius:var(--radius-pill)}.ds-json-section{gap:12px}.ds-json-actions{display:flex;gap:8px;margin-bottom:8px}.ds-json-pre{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:16px;font-family:var(--font-mono);font-size:12px;line-height:1.6;color:var(--text-secondary);overflow-x:auto;white-space:pre;max-height:560px;overflow-y:auto}.topbar-settings-btn{border:1px solid var(--border-medium)!important;background:transparent!important}.topbar-settings-btn:hover{background:var(--bg-hover)!important;color:var(--text-primary)!important}.admin-page{padding:20px 24px 60px;max-width:1200px;margin:0 auto}.admin-breadcrumb{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text-muted);margin-bottom:16px}.admin-bc-item{color:var(--text-secondary);cursor:pointer;transition:color var(--transition)}.admin-bc-item:hover{color:var(--text-primary);text-decoration:underline}.admin-bc-sep{color:var(--text-disabled)}.admin-bc-current{color:var(--text-muted);cursor:default}.admin-bc-current:hover{text-decoration:none}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.admin-title{font-size:28px;font-weight:500;color:var(--text-primary);line-height:1.2}.admin-subtitle{font-size:13px;color:var(--text-muted);margin-top:4px}.admin-tabs{display:flex;gap:0}.admin-tab{background:none;border:none;color:var(--text-secondary);font-size:14px;padding:10px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--transition),border-color var(--transition)}.admin-tab:hover{color:var(--text-primary)}.admin-tab.active{color:var(--text-primary);border-bottom-color:var(--accent-amber);font-weight:500}.admin-tab-divider{height:1px;background:var(--border-subtle);margin-bottom:20px}.admin-search-bar{margin-bottom:16px;max-width:400px}.admin-table{width:100%;border-collapse:collapse;font-size:13.5px}.admin-table th{text-align:left;padding:8px 12px;font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-subtle)}.admin-table td{padding:11px 12px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);vertical-align:middle}.admin-table-row{cursor:pointer;transition:background var(--transition)}.admin-table-row:hover td{background:var(--bg-hover);color:var(--text-primary)}.admin-empty-row{text-align:center;padding:40px!important;color:var(--text-muted)!important;cursor:default!important}.admin-id-cell{font-family:var(--font-mono);font-size:12px;color:var(--text-disabled)!important}.admin-slug-cell{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)!important}.admin-name-cell{font-weight:500;color:var(--text-primary)!important;display:flex;align-items:center;gap:10px}.admin-email-cell{color:var(--text-secondary)!important;font-size:13px}.admin-count-cell{font-family:var(--font-mono);font-size:13px}.admin-date-cell{font-size:12.5px;color:var(--text-muted)!important}.admin-org-avatar{width:26px;height:26px;border-radius:4px;background:linear-gradient(135deg,#3d71d9,#6ed0e0);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;color:#fff;flex-shrink:0}.admin-user-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#3d71d9,#705da0);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;color:#fff;flex-shrink:0}.admin-delete-btn{width:28px;height:28px;background:#d63e6a;border:none;border-radius:var(--radius);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition),background var(--transition)}.admin-table-row:hover .admin-delete-btn{opacity:1}.admin-delete-btn:hover{background:#b02d57}.admin-inactive-badge{display:inline-flex;font-size:10px;font-weight:600;background:#f2495c1f;color:var(--accent-red);padding:1px 6px;border-radius:var(--radius-pill);margin-left:6px}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;max-width:900px}.admin-stat-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:4px;transition:border-color var(--transition)}.admin-stat-card:hover{border-color:var(--border-medium)}.admin-stat-icon{font-size:24px;margin-bottom:4px}.admin-stat-value{font-size:36px;font-weight:700;color:var(--accent-blue);font-family:var(--font-mono);line-height:1}.admin-stat-label{font-size:14px;font-weight:500;color:var(--text-primary);margin-top:4px}.admin-stat-desc{font-size:12px;color:var(--text-muted)}.admin-user-page{padding:20px 24px 60px;max-width:860px;margin:0 auto}.admin-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:20px}.admin-section-title{font-size:16px;font-weight:500;color:var(--text-primary);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border-subtle)}.admin-info-table{width:100%;border-collapse:collapse}.admin-info-row{border-bottom:1px solid var(--border-subtle)}.admin-info-row:last-child{border-bottom:none}.admin-info-label{padding:12px 0;font-size:13.5px;font-weight:500;color:var(--text-secondary);width:180px;vertical-align:middle}.admin-info-value{padding:12px 8px;font-size:13.5px;color:var(--text-primary);vertical-align:middle}.admin-info-value-mono{font-family:var(--font-mono);font-size:12.5px;color:var(--text-muted)}.admin-info-action{padding:12px 0;text-align:right;width:140px;vertical-align:middle}.admin-inline-input{background:var(--bg-primary);border:1px solid var(--accent-blue);box-shadow:0 0 0 2px #3d71d92e;color:var(--text-primary);font-size:13.5px;padding:5px 9px;border-radius:var(--radius);outline:none;width:280px;font-family:var(--font-sans)}.admin-text-btn{background:none;border:none;color:var(--accent-blue);font-size:13px;cursor:pointer;padding:2px 4px;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition)}.admin-text-btn:hover{color:#6e9fff;text-decoration:underline}.admin-text-btn:disabled{opacity:.5;cursor:not-allowed;text-decoration:none}.admin-text-btn-danger{color:var(--accent-red)!important}.admin-text-btn-danger:hover{color:#ff6b7a!important}.admin-text-btn-cancel{color:var(--text-muted)!important}.admin-text-btn-cancel:hover{color:var(--text-primary)!important;text-decoration:none!important}.admin-role-select{background:var(--bg-elevated);border:1px solid var(--border-medium);color:var(--text-primary);font-size:13px;padding:4px 24px 4px 8px;border-radius:var(--radius);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.admin-role-select:focus{outline:none;border-color:var(--accent-blue)}.admin-user-actions{display:flex;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-subtle)}.admin-btn-delete{background:#d63e6a;border:1px solid #d63e6a;color:#fff;font-weight:500}.admin-btn-delete:hover{background:#b02d57;border-color:#b02d57}.admin-sessions-table{width:100%;border-collapse:collapse;font-size:13px}.admin-sessions-table th{padding:7px 10px;text-align:left;font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-subtle)}.admin-sessions-table td{padding:10px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);vertical-align:middle}.admin-sessions-table tr:hover td{background:var(--bg-hover)}.admin-code{font-family:var(--font-mono);font-size:12px;color:var(--text-primary)}.admin-info-section{display:flex;flex-direction:column;gap:0}.alerting-page{padding:20px 24px 60px;max-width:1200px;margin:0 auto}.alerting-header{margin-bottom:20px}.alerting-title{font-size:28px;font-weight:500;color:var(--text-primary);line-height:1.2}.alerting-subtitle{font-size:13px;color:var(--text-muted);margin-top:4px}.alerting-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:24px;background:var(--border-subtle)}.alert-feature-card{background:var(--bg-secondary);padding:18px 20px;display:flex;flex-direction:column;gap:6px}.alert-feature-title{font-size:16px;font-weight:500;color:var(--text-primary)}.alert-feature-desc{font-size:12.5px;color:var(--text-muted);line-height:1.5;flex:1}.alert-feature-link{background:none;border:none;cursor:pointer;color:var(--accent-blue);font-size:13px;padding:0;text-align:left;transition:color var(--transition)}.alert-feature-link:hover{color:#6e9fff;text-decoration:underline}.alerting-tabs{display:flex;gap:0}.alerting-tab{background:none;border:none;color:var(--text-secondary);font-size:14px;padding:10px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--transition),border-color var(--transition)}.alerting-tab:hover{color:var(--text-primary)}.alerting-tab.active{color:var(--text-primary);border-bottom-color:var(--accent-amber);font-weight:500}.alerting-tab-divider{height:1px;background:var(--border-subtle);margin-bottom:24px}.alerting-section-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.alerting-table{width:100%;border-collapse:collapse;font-size:13.5px}.alerting-table th{padding:8px 12px;text-align:left;font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-subtle)}.alerting-table td{padding:11px 12px;border-bottom:1px solid var(--border-subtle);vertical-align:middle}.alerting-table-row{transition:background var(--transition)}.alerting-table-row:hover td{background:var(--bg-hover)}.alerting-rule-name{font-weight:500;color:var(--text-primary)}.alerting-meta-cell{color:var(--text-secondary);font-size:13px}.alerting-row-actions{display:flex;gap:4px;justify-content:flex-end}.alerting-action-btn{background:none;border:none;color:var(--text-muted);padding:5px 6px;border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;transition:all var(--transition)}.alerting-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.alerting-action-danger:hover{color:var(--accent-red)!important;background:#f2495c14!important}.alert-state-badge{display:inline-flex;align-items:center;font-size:11.5px;font-weight:600;padding:2px 7px;border-radius:var(--radius-pill);text-transform:capitalize}.alert-state-badge.alerting{background:#f2495c1f;color:#f2495c}.alert-state-badge.normal{background:#73bf691f;color:#73bf69}.alert-state-badge.pending{background:#ff99001f;color:#f90}.alert-state-badge.paused{background:#ccccdc1a;color:var(--text-muted)}.alert-state-badge.error{background:#f2495c1f;color:#f2495c}.alert-state-badge.inactive{background:#ccccdc14;color:var(--text-disabled)}.cp-list{display:flex;flex-direction:column;gap:8px}.cp-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:14px 16px;transition:border-color var(--transition)}.cp-card:hover{border-color:var(--border-medium)}.cp-card-left{display:flex;align-items:center;gap:14px;min-width:0}.cp-card-actions{display:flex;gap:4px;flex-shrink:0}.cp-icon{width:36px;height:36px;border-radius:var(--radius-lg);background:var(--bg-elevated);border:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}.cp-name{font-size:14px;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:6px}.cp-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.cp-default-badge{font-size:10px;font-weight:600;padding:1px 6px;background:#3d71d91f;color:var(--accent-blue);border-radius:var(--radius-pill)}.policy-list{display:flex;flex-direction:column;gap:12px}.policy-card{display:flex;justify-content:space-between;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:16px 18px;transition:border-color var(--transition)}.policy-card:hover{border-color:var(--border-medium)}.policy-card-left{flex:1;min-width:0}.policy-index{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-disabled);margin-bottom:4px}.policy-name{font-size:15px;font-weight:500;color:var(--text-primary);margin-bottom:6px}.policy-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:12.5px;color:var(--text-secondary)}.policy-meta span{white-space:nowrap}.policy-meta code{font-family:var(--font-mono);font-size:11px;background:var(--bg-elevated);padding:1px 5px;border-radius:3px}.policy-routes{margin-top:10px;display:flex;flex-direction:column;gap:4px}.policy-route{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-secondary)}.policy-route-if{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--text-muted);background:var(--bg-elevated);padding:1px 5px;border-radius:3px}.policy-route-matcher{font-family:var(--font-mono);font-size:11.5px;background:#a78bfa1f;color:#a78bfa;padding:1px 7px;border-radius:var(--radius-pill)}.policy-route-to{color:var(--text-muted)}.policy-route-editor{margin-bottom:10px;padding:12px;background:var(--bg-elevated);border-radius:var(--radius-lg)}.alerting-overview{display:grid;grid-template-columns:1fr 320px;gap:20px}.overview-how-it-works h3,.overview-get-started h3{font-size:18px;font-weight:500;color:var(--text-primary);margin-bottom:12px}.overview-list{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-direction:column;gap:8px}.overview-list li{font-size:13.5px;color:var(--text-secondary);line-height:1.5;display:flex;gap:8px}.overview-list li:before{content:"•";color:var(--text-disabled);flex-shrink:0}.overview-diagram{display:flex;align-items:center;gap:0;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;overflow-x:auto;margin-top:8px}.diag-box{background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-lg);padding:12px 14px;min-width:160px}.diag-box-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.diag-box-body{display:flex;flex-direction:column;gap:5px}.diag-code{font-family:var(--font-mono);font-size:11.5px;color:var(--text-secondary);display:block}.diag-label-chip{display:inline-block;font-family:var(--font-mono);font-size:10.5px;background:#a78bfa;color:#fff;padding:2px 8px;border-radius:3px;font-weight:600;margin-top:4px}.diag-instance{font-size:12.5px;color:var(--text-secondary);padding:2px 0}.diag-cp-icons{display:flex;gap:8px;font-size:16px;margin-top:4px;color:var(--text-muted)}.diag-arrow{font-size:20px;color:var(--text-disabled);padding:0 12px;flex-shrink:0}.overview-get-started{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;height:fit-content}.modal-body-form{display:flex;flex-direction:column;gap:0}.modal-form-section{padding:16px 0;border-bottom:1px solid var(--border-subtle)}.modal-form-section:last-child{border-bottom:none}.modal-form-heading{font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:12px}.rule-condition-row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-start}.alerting-empty{display:flex;flex-direction:column;align-items:center;padding:48px 0;gap:10px;text-align:center}.alerting-empty-icon{font-size:36px;margin-bottom:4px}.alerting-empty h3{font-size:17px;font-weight:500;color:var(--text-primary)}.alerting-empty p{font-size:13.5px;color:var(--text-muted);max-width:400px;line-height:1.5}.modal-lg{width:680px;max-width:96vw}.target-alias-row{display:flex;align-items:center;gap:8px;padding:6px 12px 2px;border-top:1px solid var(--border-subtle);margin-top:4px}.target-alias-row .target-opt-label{min-width:40px}.ts-legend-table{overflow-x:auto;border-top:1px solid var(--border-subtle);margin-top:2px}.ts-legend-table table{width:100%;border-collapse:collapse;font-size:12px}.ts-legend-table th{padding:5px 10px;text-align:right;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border-subtle);white-space:nowrap}.ts-legend-name-col{text-align:left!important}.ts-legend-stat-col{min-width:60px}.ts-legend-row{transition:background var(--transition)}.ts-legend-row:hover{background:var(--bg-hover)}.ts-legend-name-cell{padding:5px 10px;display:flex;align-items:center;gap:7px;color:var(--text-primary);font-weight:500;white-space:nowrap}.ts-legend-stat-cell{padding:5px 10px;text-align:right;color:var(--text-secondary);font-family:var(--font-mono);font-size:11.5px;white-space:nowrap}.ts-legend-swatch{width:10px;height:3px;border-radius:2px;flex-shrink:0;display:inline-block}.legend-values-wrap{margin-top:6px}.legend-chips-row{display:flex;flex-wrap:wrap;gap:5px;align-items:center;min-height:28px}.legend-chip{display:inline-flex;align-items:center;gap:4px;background:#3d71d91f;border:1px solid rgba(61,113,217,.28);color:var(--accent-blue);font-size:11.5px;font-weight:500;padding:2px 7px;border-radius:var(--radius-pill)}.legend-chip-remove{background:none;border:none;cursor:pointer;color:#3d71d98c;font-size:13px;line-height:1;padding:0 1px;transition:color var(--transition)}.legend-chip-remove:hover{color:var(--accent-red)}.legend-chip-add-select{background:var(--bg-elevated);border:1px dashed var(--border-active);color:var(--text-muted);font-size:11.5px;padding:2px 20px 2px 8px;border-radius:var(--radius-pill);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 5px center;transition:all var(--transition)}.legend-chip-add-select:hover{border-color:var(--accent-blue);color:var(--text-primary)}.ts-legend-bottom{flex-shrink:0;border-top:1px solid var(--border-subtle);padding-top:4px;padding-bottom:4px;overflow-x:auto;overflow-y:visible}.ts-legend-right{flex-shrink:0;border-left:1px solid var(--border-subtle);padding-left:6px;overflow-x:hidden;overflow-y:auto;align-self:stretch}.ts-legend-right .ts-legend-name-col{min-width:80px;max-width:120px}.ts-legend-right .ts-legend-name-cell{max-width:120px;overflow:hidden;text-overflow:ellipsis}.ts-legend-right .ts-legend-stat-col{min-width:44px}.ts-legend-right .ts-legend-stat-cell{font-size:11px}.ts-legend-table{border-top:none}.ts-panel-wrap{position:relative}.ts-panel-wrap .ts-selection-overlay{position:absolute;pointer-events:none}.ts-panel-wrap .chart-drag-hint{position:absolute;bottom:32px;right:20px}.ds-edit-page{padding:16px 24px 60px}.ds-edit-layout{display:flex;gap:20px;align-items:flex-start;max-width:1100px;margin:0 auto}.ds-type-sidebar{width:200px;flex-shrink:0;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:12px 0;position:sticky;top:20px}.ds-type-sidebar-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-disabled);padding:0 12px 8px}.ds-type-option{display:flex;align-items:center;gap:9px;width:100%;background:none;border:none;cursor:pointer;padding:8px 12px;font-size:13px;color:var(--text-secondary);text-align:left;transition:all var(--transition);border-left:2px solid transparent}.ds-type-option:hover{background:var(--bg-hover);color:var(--text-primary)}.ds-type-option.active{background:#3d71d91a;color:var(--accent-blue);border-left-color:var(--accent-blue);font-weight:500}.ds-edit-form{flex:1;min-width:0}.ds-edit-header{display:flex;align-items:center;gap:14px;margin-bottom:24px}.ds-edit-type-icon{font-size:32px}.ds-edit-title{font-size:22px;font-weight:500;color:var(--text-primary)}.ds-edit-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}.ds-edit-section{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px 22px;margin-bottom:16px}.ds-edit-section-title{font-size:17px;font-weight:500;color:var(--text-primary);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border-subtle)}.ds-info-box{display:flex;gap:10px;align-items:flex-start;background:#3d71d914;border:1px solid rgba(61,113,217,.2);border-radius:var(--radius-lg);padding:12px 14px;margin-bottom:14px}.ds-info-box svg{color:var(--accent-blue);flex-shrink:0;margin-top:1px}.ds-info-box p{font-size:12.5px;color:var(--text-secondary);line-height:1.5;margin:0;white-space:pre-line}.ds-two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ds-three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.ds-auth-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 20px;margin-bottom:14px}.ds-auth-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border-subtle)}.ds-auth-sub{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:14px;margin-top:10px}.ds-auth-sub-title{font-size:12.5px;font-weight:600;color:var(--text-muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.4px}.ds-header-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}.ds-header-row .ds-input{flex:1}.ds-url-error{font-size:12px;color:var(--accent-red);background:#f2495c14;border:1px solid rgba(242,73,92,.25);border-radius:var(--radius);padding:4px 10px;margin-top:5px;display:inline-block}.ds-input-error{border-color:var(--accent-red)!important}.ds-label-info{color:var(--text-disabled);font-size:11px;cursor:help;margin-left:3px}.ds-test-result{padding:10px 14px;border-radius:var(--radius-lg);margin-bottom:12px;font-size:13.5px;font-weight:500}.ds-test-ok{background:#73bf691f;color:#73bf69;border:1px solid rgba(115,191,105,.25)}.ds-test-fail{background:#f2495c1a;color:#f2495c;border:1px solid rgba(242,73,92,.25)}.ds-actions-row{display:flex;align-items:center;gap:10px;padding-top:8px}.inspector-modal{width:820px;max-width:96vw;max-height:85vh;display:flex;flex-direction:column}.inspector-tabs{display:flex;padding:0 16px;border-bottom:1px solid var(--border-subtle)}.inspector-tab{background:none;border:none;color:var(--text-secondary);font-size:13.5px;padding:9px 14px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition)}.inspector-tab:hover{color:var(--text-primary)}.inspector-tab.active{color:var(--text-primary);border-bottom-color:var(--accent-blue);font-weight:500}.inspector-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.inspector-data-tab{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:12px}.inspector-query-tab{padding:14px 16px;overflow-y:auto}.inspector-frame-meta{font-size:12px;color:var(--text-muted);margin-bottom:8px}.inspector-table-wrap{flex:1;overflow:auto;border:1px solid var(--border-subtle);border-radius:var(--radius)}.inspector-table{width:100%;border-collapse:collapse;font-size:12.5px}.inspector-table th{padding:7px 10px;text-align:left;position:sticky;top:0;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);font-size:12px;font-weight:600;color:var(--text-secondary);white-space:nowrap}.inspector-field-type{font-size:10px;color:var(--text-disabled);font-weight:400;margin-left:5px;font-family:var(--font-mono)}.inspector-table td{padding:6px 10px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);font-family:var(--font-mono);font-size:12px;white-space:nowrap}.inspector-table tr:hover td{background:var(--bg-hover)}.inspector-truncated{padding:8px 12px;font-size:12px;color:var(--text-muted);border-top:1px solid var(--border-subtle);text-align:center}.inspector-pre{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:12px;font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);overflow-x:auto;white-space:pre;line-height:1.6;margin-top:6px}.cp-edit-page{padding:20px 24px 60px;max-width:760px;margin:0 auto}.cp-edit-header{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}.cp-name-input{flex:1;min-width:200px;background:var(--bg-secondary);border:1px solid var(--border-medium);color:var(--text-primary);font-size:18px;font-weight:500;padding:8px 12px;border-radius:var(--radius);transition:border-color var(--transition)}.cp-name-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #3d71d92e}.cp-edit-actions{display:flex;gap:8px;flex-shrink:0}.cp-delete-btn{color:var(--accent-red)!important;border-color:#f2495c59!important}.cp-delete-btn:hover{background:#f2495c14!important}.cp-section{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:18px 20px;margin-bottom:12px}.cp-section-row{margin-bottom:16px}.cp-type-select{min-width:260px;padding-left:12px}.cp-field{margin-bottom:16px}.cp-field:last-child{margin-bottom:0}.cp-field-label{font-size:13px;font-weight:500;color:var(--text-secondary);display:block;margin-bottom:6px}.cp-required{color:var(--accent-red);margin-left:2px}.cp-input{width:100%;max-width:480px;background:var(--bg-primary);border:1px solid var(--border-medium);color:var(--text-primary);font-size:14px;padding:8px 12px;border-radius:var(--radius);transition:border-color var(--transition)}.cp-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #3d71d92e}.cp-textarea{max-width:480px;font-family:var(--font-sans)!important}.cp-edit-message-btn{display:inline-flex;align-items:center;gap:6px;background:var(--bg-elevated);border:1px solid var(--border-medium);color:var(--text-secondary);font-size:13px;padding:6px 12px;border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.cp-edit-message-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.cp-checkbox-row{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-subtle)}.cp-checkbox-row:last-child{border-bottom:none;padding-bottom:0}.cp-checkbox{margin-top:2px;flex-shrink:0;width:14px;height:14px;cursor:pointer;accent-color:var(--accent-blue)}.cp-checkbox-label{cursor:pointer;display:flex;flex-direction:column;gap:3px}.cp-checkbox-label span:first-child{font-size:13.5px;color:var(--text-primary);font-weight:500}.cp-checkbox-hint{font-size:12px;color:var(--text-muted);line-height:1.4}.cp-collapsible{margin-bottom:12px;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.cp-collapsible:last-child{margin-bottom:0}.cp-collapsible-header{display:flex;align-items:center;gap:8px;width:100%;background:var(--bg-elevated);border:none;cursor:pointer;padding:12px 16px;font-size:14px;font-weight:500;color:var(--text-primary);text-align:left;transition:background var(--transition)}.cp-collapsible-header:hover{background:var(--bg-hover)}.cp-collapsible-body{padding:16px 18px;border-top:1px solid var(--border-subtle);background:var(--bg-secondary)}.profile-page{padding:20px 24px 60px;max-width:760px;margin:0 auto}.profile-avatar-lg{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#3d71d9,#705da0);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;flex-shrink:0}.pref-theme-grid{display:flex;gap:16px;margin-top:8px}.pref-theme-btn{display:flex;flex-direction:column;align-items:center;gap:8px;background:none;border:2px solid var(--border-subtle);border-radius:var(--radius-lg);padding:12px;cursor:pointer;transition:all var(--transition);color:var(--text-secondary);font-size:13px}.pref-theme-btn:hover{border-color:var(--border-medium);color:var(--text-primary)}.pref-theme-btn.active{border-color:var(--accent-blue);color:var(--accent-blue)}.pref-theme-preview{width:120px;height:72px;border-radius:4px;display:flex;overflow:hidden;border:1px solid var(--border-subtle)}.pref-theme-dark{background:#111217}.pref-theme-light{background:#f4f5f5}.pref-preview-sidebar{width:24px;height:100%;flex-shrink:0}.pref-theme-dark .pref-preview-sidebar{background:#212327}.pref-theme-light .pref-preview-sidebar{background:#e8e8e8}.pref-preview-content{flex:1;padding:6px;display:flex;flex-direction:column;gap:4px}.pref-preview-bar{height:10px;border-radius:2px}.pref-theme-dark .pref-preview-bar{background:#181b1f}.pref-theme-light .pref-preview-bar{background:#fff;border:1px solid #e8e8e8}.pref-preview-panel{flex:1;border-radius:2px}.pref-theme-dark .pref-preview-panel{background:#181b1f;border:1px solid rgba(204,204,220,.07)}.pref-theme-light .pref-preview-panel{background:#fff;border:1px solid rgba(36,41,46,.12)}.explore-page{padding:16px 24px 60px;display:flex;flex-direction:column;gap:16px}.explore-header{margin-bottom:4px}.explore-query-bar{display:flex;gap:12px;align-items:flex-start;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:14px 16px}.explore-ds-select{width:200px;flex-shrink:0;background:var(--bg-elevated);border:1px solid var(--border-medium);color:var(--text-primary);font-size:13.5px;padding:8px 28px 8px 10px;border-radius:var(--radius);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:border-color var(--transition)}.explore-ds-select:focus{outline:none;border-color:var(--accent-blue)}.explore-query-wrap{flex:1;display:flex;flex-direction:column;gap:8px}.explore-query-input{width:100%;resize:vertical;min-height:72px;background:var(--bg-primary);border:1px solid var(--border-medium);color:var(--text-primary);font-family:var(--font-mono);font-size:13px;padding:10px 12px;border-radius:var(--radius);line-height:1.5;transition:border-color var(--transition)}.explore-query-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #3d71d926}.explore-query-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:10px}.explore-run-btn{display:flex;align-items:center}.explore-history{position:relative}.explore-history-btn{list-style:none;display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--text-muted);cursor:pointer;background:none;border:1px solid var(--border-subtle);border-radius:var(--radius);padding:4px 10px;transition:all var(--transition)}.explore-history-btn::-webkit-details-marker{display:none}.explore-history-btn:hover{border-color:var(--border-medium);color:var(--text-primary)}.explore-history-list{position:absolute;right:0;top:100%;margin-top:4px;background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:320px;max-height:260px;overflow-y:auto;z-index:100}.explore-history-item{display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:8px 14px;font-size:12px;font-family:var(--font-mono);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:all var(--transition)}.explore-history-item:last-child{border-bottom:none}.explore-history-item:hover{background:var(--bg-hover);color:var(--text-primary)}.explore-results{display:flex;flex-direction:column;gap:16px}.explore-chart-wrap,.explore-table-wrap{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.explore-result-label{padding:10px 14px;font-size:12px;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);text-transform:uppercase;letter-spacing:.4px}.explore-chart-wrap .explore-result-label{border-bottom:none}.explore-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;gap:12px;text-align:center;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.explore-empty p{font-size:14px;color:var(--text-muted)}.explore-empty kbd{background:var(--bg-elevated);border:1px solid var(--border-medium);padding:1px 6px;border-radius:3px;font-family:var(--font-mono);font-size:12px}.panel-menu-wrap{position:relative;display:inline-flex;align-items:center}.panel-menu-trigger{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:3px 5px;border-radius:var(--radius);display:flex;align-items:center;opacity:0;transition:opacity var(--transition),background var(--transition)}.panel-wrapper:hover .panel-menu-trigger,.panel-wrapper.edit-mode .panel-menu-trigger{opacity:1}.panel-menu-trigger:hover{background:var(--bg-hover);color:var(--text-primary)}.panel-menu-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:180px;background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000008c;z-index:500;padding:4px 0;animation:dropdownFadeIn .1s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.panel-menu-item{display:flex;align-items:center;gap:9px;width:100%;background:none;border:none;color:var(--text-secondary);font-size:13.5px;padding:7px 14px;cursor:pointer;text-align:left;transition:all var(--transition)}.panel-menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.panel-menu-item-danger{color:var(--accent-red)!important}.panel-menu-item-danger:hover{background:#f2495c14!important}.panel-menu-item-icon{color:var(--text-muted);flex-shrink:0;display:flex}.panel-menu-item:hover .panel-menu-item-icon{color:var(--text-secondary)}.panel-menu-item-label{flex:1}.panel-menu-item-kbd{margin-left:auto;font-size:11px;font-family:var(--font-mono);color:var(--text-disabled);background:var(--bg-secondary);border:1px solid var(--border-subtle);padding:1px 5px;border-radius:3px}.panel-menu-divider{height:1px;background:var(--border-subtle);margin:4px 0}.panel-fullscreen-overlay{position:fixed;inset:0;z-index:300;background:#000000bf;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .12s ease}.panel-fullscreen-wrap{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);display:flex;flex-direction:column;width:calc(100vw - 32px);height:calc(100vh - 32px);overflow:hidden}.panel-fullscreen-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);flex-shrink:0}.panel-fullscreen-title{font-size:16px;font-weight:500;color:var(--text-primary)}.panel-fullscreen-actions{display:flex;gap:4px}.panel-fullscreen-body{flex:1;overflow:hidden;padding:8px}.panel-opts-header{display:flex;align-items:center;gap:7px;width:100%;background:none;border:none;cursor:pointer;font-size:13px;font-weight:600;color:var(--text-secondary);padding:0 0 8px;text-align:left;transition:color var(--transition)}.panel-opts-header:hover{color:var(--text-primary)}.panel-opts-body{padding:4px 0 2px}.panel-wrapper.transparent-bg{background:transparent!important;border-color:transparent!important}.share-modal{width:680px;max-width:95vw}.share-modal-body{padding:16px 20px 8px}.share-theme-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.share-label{font-size:13px;font-weight:500;color:var(--text-secondary)}.share-preview-wrap{width:100%;height:240px;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:4px}.share-preview-dark{background:#111217}.share-preview-light{background:#fff}.share-preview-img{width:100%;height:100%;object-fit:contain}.share-preview-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-disabled);font-size:13px}.ts-legend-row-clickable{cursor:pointer;user-select:none;transition:opacity .15s}.ts-legend-row-clickable:hover{background:var(--bg-hover)}.ts-legend-row-dimmed{opacity:.3}.ts-legend-row-dimmed:hover{opacity:.55}.legend-sizing-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;margin-top:6px}.legend-sizing-field{display:flex;flex-direction:column;gap:4px}.editor-input-sm{padding:5px 8px!important;font-size:12px!important;max-width:100%!important}.ts-legend-list{display:flex;flex-wrap:wrap;align-items:center;gap:4px 12px;padding:4px 4px 0;flex-shrink:0}.ts-legend-list-item{display:flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:3px;color:var(--text-secondary);font-size:11.5px;transition:all .12s;user-select:none}.ts-legend-list-item:hover{background:var(--bg-hover);color:var(--text-primary)}.ts-legend-list-item-dimmed{opacity:.3}.ts-legend-list-item-dimmed:hover{opacity:.6}.ts-legend-list-name{white-space:nowrap}.topbar-icon-btn-active{color:var(--accent-blue)!important;background:#3d71d91f!important;border-color:#3d71d959!important}
