.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}:root{--pg-blue: #43b0f1;--pg-blue-ink: #248dcb;--pg-blue-deep: #1976a8;--pg-green: #10B981;--pg-orange: #F59E0B;--pg-red: #EF4444;--pg-purple: #8B5CF6;--pg-dark: #0B0F19;--pg-dark-secondary: #1C1F2E;--pg-border: #313543;--bg: #f9fafb;--panel: #ffffff;--panel-hi: #f3f4f6;--line: #E5E7EB;--line-2: #F3F4F6;--ink: #111827;--ink-2: #1F2937;--ink-3: #374151;--muted: #6B7280;--muted-2: #9CA3AF;--blue-soft: #E8F4FC;--green-soft: #D1FAE5;--orange-soft: #FEF3C7;--red-soft: #FEE2E2;--purple-soft: #EDE9FE;--shadow-sm: 0 1px 2px rgba(17,24,39,.04);--shadow-md: 0 4px 14px -4px rgba(17,24,39,.08), 0 1px 3px rgba(17,24,39,.04)}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,sans-serif;font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;letter-spacing:-.003em}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:10px;border:2px solid var(--bg)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app{display:grid;grid-template-columns:232px 1fr;min-height:100vh}aside.nav{background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{padding:18px 18px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line)}.brand .logo{height:26px;width:auto;display:block}.brand .ver{margin-left:auto;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}.org-box{margin:12px 12px 6px;padding:10px 11px;background:var(--bg);border:1px solid var(--line);border-radius:7px;display:flex;align-items:center;gap:10px}.org-box .org-ic{width:26px;height:26px;border-radius:6px;background:var(--pg-dark);color:#fff;display:grid;place-items:center;font-weight:700;font-size:10.5px}.org-box .org-name{font-size:13px;font-weight:600;color:var(--ink)}.org-box .org-plan{font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:1px 6px;border-radius:3px;background:var(--blue-soft);color:var(--pg-blue-ink);font-family:JetBrains Mono,monospace;display:inline-block;margin-top:2px}.nav-scroll{flex:1;overflow-y:auto;padding:0 12px 10px}.section-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:14px 4px 6px}.subnav{list-style:none;margin:0;padding:0}.subnav li{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:6px;color:var(--ink-2);font-size:13px;cursor:pointer;transition:background .12s,color .12s;margin:1px 0}.subnav li:hover{background:var(--bg);color:var(--ink)}.subnav li.on{background:var(--blue-soft);color:var(--pg-blue-ink);font-weight:600}.subnav li.on svg{color:var(--pg-blue-ink);opacity:1}.subnav li svg{flex-shrink:0;opacity:.7}.subnav li.group-head{justify-content:space-between;-webkit-user-select:none;user-select:none}.subnav li.group-head .group-left{display:flex;align-items:center;gap:10px}.subnav li.group-head.group-active{color:var(--pg-blue-ink);font-weight:600}.subnav li.group-head.group-active svg{color:var(--pg-blue-ink);opacity:1}.subnav li.group-head .chevron{color:var(--muted-2);opacity:1;flex-shrink:0;display:grid;place-items:center;transition:transform .18s ease}.subnav li.group-head .chevron.open{transform:rotate(90deg)}.subnav-children{overflow:hidden;max-height:0;transition:max-height .22s ease}.subnav-children.open{max-height:240px}.subnav-children ul{list-style:none;padding:2px 0 6px 26px;border-left:2px solid var(--line);margin:0 0 0 18px}.subnav-children li{display:flex;align-items:center;padding:5px 10px;border-radius:6px;color:var(--ink-3);font-size:12.5px;cursor:pointer;transition:background .12s,color .12s;margin:1px 0}.subnav-children li:hover{background:var(--bg);color:var(--ink)}.subnav-children li.on{background:var(--blue-soft);color:var(--pg-blue-ink);font-weight:600}.subnav li.nav-locked,.subnav-children li.nav-locked{opacity:.4;cursor:default;pointer-events:none}.upgrade-nudge{margin:12px 4px 0;padding:12px 14px;background:linear-gradient(135deg,var(--blue-soft) 0%,#EDE9FE 100%);border:1px solid #C7D9F5;border-radius:9px}.upgrade-nudge .upgrade-title{font-size:12px;font-weight:700;color:var(--pg-blue-ink);margin-bottom:4px}.upgrade-nudge .upgrade-sub{font-size:11px;color:var(--ink-3);line-height:1.45;margin-bottom:10px}.upgrade-plan-cta{padding:16px;background:linear-gradient(135deg,var(--blue-soft) 0%,#EDE9FE 100%);border:1px solid #C7D9F5;border-radius:9px;margin-top:8px}.upgrade-plan-cta p{font-size:13px;color:var(--ink-2);line-height:1.5;margin:0 0 12px}.app{grid-template-columns:232px 1fr}.shell-right{display:flex;flex-direction:column;min-height:100vh;min-width:0}main.content{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{flex-shrink:0;height:38px;background:var(--panel);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 20px;gap:0;justify-content:space-between}.topbar-left{display:flex;align-items:center;gap:18px}.topbar-right{display:flex;align-items:center;gap:14px}.interval-picker{position:relative;display:inline-flex;align-items:center}.interval-btn{display:flex;align-items:center;gap:6px;background:transparent;border:none;cursor:pointer;color:var(--ink-3);font-size:12.5px;padding:4px 8px;border-radius:5px;transition:background .1s;font-family:JetBrains Mono,monospace}.interval-btn:hover{background:var(--bg)}.interval-btn svg{color:var(--pg-blue-deep)}.interval-label{color:var(--muted);font-size:11px;margin-right:3px;font-family:Inter,sans-serif}.interval-drop{position:absolute;top:calc(100% + 6px);left:0;z-index:40;background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow-md);min-width:140px;padding:4px 0;overflow:hidden}.interval-drop button{width:100%;text-align:left;background:transparent;border:none;cursor:pointer;padding:7px 14px;font-size:12.5px;color:var(--ink-2);font-family:JetBrains Mono,monospace;transition:background .1s}.interval-drop button:hover{background:var(--bg)}.interval-drop button.sel{color:var(--pg-blue-ink);font-weight:600;background:var(--blue-soft)}.user-foot{padding:12px 14px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}.avatar{width:30px;height:30px;border-radius:50%;background:var(--pg-orange);color:#fff;font-weight:700;font-size:11px;display:grid;place-items:center;flex-shrink:0}.user-foot .u-name{font-size:12.5px;font-weight:600;color:var(--ink)}.user-foot .u-email{font-size:10.5px;color:var(--muted);font-family:JetBrains Mono,monospace}.user-foot .logout-btn{margin-left:auto;width:28px;height:28px;border-radius:6px;display:grid;place-items:center;color:var(--muted);cursor:pointer;background:transparent;border:none}.user-foot .logout-btn:hover{background:var(--bg);color:var(--ink)}main.content{display:flex;flex-direction:column;min-width:0}.page-head{padding:16px 28px;background:var(--panel);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;flex-wrap:wrap}.ph-left{min-width:0}.ph-crumb{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--muted);margin-bottom:2px}h1.page-title{margin:0;font-size:22px;font-weight:600;color:var(--ink);letter-spacing:-.02em;display:flex;align-items:center;gap:12px}h1.page-title .live{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--green-soft);color:#047857;font-family:JetBrains Mono,monospace;letter-spacing:.05em;text-transform:uppercase}h1.page-title .live .d{width:6px;height:6px;background:var(--pg-green);border-radius:50%;animation:pulse 2s infinite}h1.page-title .live.off{background:#f3f4f6;color:var(--muted)}h1.page-title .live.off .d{background:var(--muted);animation:none}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.ph-meta{font-size:11.5px;color:var(--muted);display:flex;gap:14px;margin-top:4px;flex-wrap:wrap}.ph-meta b{color:var(--ink-3);font-weight:500}.ph-right{margin-left:auto;display:flex;align-items:center;gap:10px}.refresh{display:inline-flex;align-items:stretch;background:var(--panel);border:1px solid var(--line);border-radius:7px;overflow:hidden;box-shadow:var(--shadow-sm)}.refresh-main{display:inline-flex;align-items:center;gap:7px;padding:6px 11px;font-size:11.5px;color:var(--ink-2)}.refresh-main .d{width:7px;height:7px;background:var(--pg-green);border-radius:50%;box-shadow:0 0 5px var(--pg-green)}.refresh-main.off .d{background:var(--muted);box-shadow:none}.refresh-main b{color:var(--ink);font-weight:600;font-family:JetBrains Mono,monospace}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--panel);border:1px solid var(--line);border-radius:7px;color:var(--ink-2);font-size:12px;font-weight:500;cursor:pointer;box-shadow:var(--shadow-sm);transition:border-color .15s}.btn:hover:not(:disabled){border-color:var(--pg-blue)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.primary{background:var(--pg-blue-ink);color:#fff;border-color:var(--pg-blue-ink);box-shadow:0 2px 6px -1px #248dcb4d}.btn.primary:hover:not(:disabled){background:var(--pg-blue-deep);border-color:var(--pg-blue-deep)}.btn.ghost{background:transparent;border-color:transparent}.btn.ghost:hover:not(:disabled){background:var(--bg);border-color:var(--line)}.body{display:flex;flex-direction:column;gap:14px;padding:18px 28px 40px}.ribbon{background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden;display:grid;grid-template-columns:repeat(6,1fr);box-shadow:var(--shadow-sm)}.ribbon .cell{padding:16px 18px;border-right:1px solid var(--line-2);position:relative}.ribbon .cell:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--pg-green);opacity:0}.ribbon .cell.warn:before{background:var(--pg-orange);opacity:1}.ribbon .cell.bad:before{background:var(--pg-red);opacity:1}.ribbon .cell:last-child{border-right:none}.ribbon .cell .lbl{font-size:10.5px;color:var(--muted);font-weight:600;letter-spacing:.08em;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between;gap:8px}.ribbon .cell .lbl .st{display:inline-flex;align-items:center;gap:3px;font-size:9.5px;font-weight:700;letter-spacing:.08em;font-family:JetBrains Mono,monospace;padding:2px 6px;border-radius:3px;background:var(--green-soft);color:#047857}.ribbon .cell.warn .lbl .st{background:var(--orange-soft);color:#92400e}.ribbon .cell.bad .lbl .st{background:var(--red-soft);color:#991b1b}.ribbon .cell .v{margin-top:10px;font-size:28px;font-weight:600;color:var(--ink);letter-spacing:-.02em;font-feature-settings:"tnum";display:flex;align-items:baseline;gap:3px;line-height:1.1}.ribbon .cell .v span{font-size:13px;color:var(--muted);font-weight:500}.ribbon .cell .bar{height:4px;background:var(--panel-hi);border-radius:2px;overflow:hidden;margin-top:10px}.ribbon .cell .bar>span{display:block;height:100%;background:var(--pg-blue);border-radius:2px}.ribbon .cell .meta{margin-top:8px;font-family:JetBrains Mono,monospace;font-size:10.5px;color:var(--muted);display:flex;justify-content:space-between;gap:6px}.ribbon .cell .delta.up{color:var(--pg-red);font-weight:600}.ribbon .cell .delta.dn{color:#047857;font-weight:600}.ribbon .cell .delta.warn{color:#92400e;font-weight:600}.ribbon .cell .chip-plain{font-family:JetBrains Mono,monospace;font-size:10.5px;background:var(--bg);padding:1px 6px;border-radius:3px}.row{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.panel{background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.panel.wide{grid-column:span 2}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line);gap:14px}.panel-head .title h3{margin:0;font-size:13.5px;font-weight:600;color:var(--ink);letter-spacing:-.005em}.panel-head .title p{margin:2px 0 0;font-size:11.5px;color:var(--muted);line-height:1.4}.panel-head .actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.panel-head .actions .chip{font-family:JetBrains Mono,monospace;font-size:10.5px;padding:2px 8px;border-radius:4px;background:var(--bg);color:var(--muted);border:1px solid var(--line);font-weight:500}.panel-kv{display:flex;gap:26px;align-items:baseline;flex-wrap:wrap;padding:12px 18px 4px}.panel-kv .big{font-size:26px;font-weight:600;color:var(--ink);letter-spacing:-.015em;font-feature-settings:"tnum"}.panel-kv .big span{font-size:13px;color:var(--muted);font-weight:500;margin-left:2px}.panel-kv .kv{display:flex;flex-direction:column;gap:0}.panel-kv .kv .key{font-size:10.5px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-weight:500}.panel-kv .kv .val{font-size:13px;font-weight:500;color:var(--ink);font-family:JetBrains Mono,monospace;font-feature-settings:"tnum";margin-top:1px}.panel-kv .kv .val.up{color:var(--pg-red)}.panel-kv .kv .val.dn{color:#047857}.panel-kv .kv .val.warn{color:#92400e}.chart{height:240px;padding:4px 8px 8px}.panel-empty{padding:48px 18px;text-align:center;color:var(--muted);font-size:12.5px}.panel-empty b{color:var(--ink-3);font-weight:600}@media (max-width: 1100px){.ribbon{grid-template-columns:repeat(3,1fr)}.ribbon .cell:nth-child(3){border-right:none}.row{grid-template-columns:1fr}.panel.wide{grid-column:auto}}@media (max-width: 900px){.app{grid-template-columns:1fr}aside.nav{display:none}}.auth-shell{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:var(--bg)}.auth-hero{background:var(--pg-blue-ink);color:#fff;padding:56px 48px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}.auth-hero:before,.auth-hero:after{content:"";position:absolute;border-radius:50%;background:#ffffff0f}.auth-hero:before{top:-140px;right:-140px;width:420px;height:420px}.auth-hero:after{bottom:-180px;left:-180px;width:520px;height:520px}.auth-hero-inner{position:relative;z-index:1;max-width:440px}.auth-hero .brand-mark{display:inline-flex;align-items:center;margin-bottom:36px}.auth-hero .brand-mark img{height:34px;width:auto;filter:brightness(0) invert(1)}.auth-hero h1{margin:0 0 14px;font-size:34px;line-height:1.2;font-weight:700;letter-spacing:-.02em}.auth-hero p.tagline{margin:0 0 36px;font-size:15px;color:#ffffffe0;line-height:1.55}.auth-hero .feature{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);border-radius:10px;margin-bottom:10px}.auth-hero .feature .ic{width:34px;height:34px;border-radius:8px;background:#ffffff2e;display:grid;place-items:center;flex-shrink:0}.auth-hero .feature h4{margin:0 0 2px;font-size:13.5px;font-weight:600}.auth-hero .feature p{margin:0;font-size:12px;color:#ffffffbf}.auth-form-wrap{display:flex;align-items:center;justify-content:center;padding:48px 32px}.auth-card{width:100%;max-width:420px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:36px 36px 30px;box-shadow:var(--shadow-md)}.auth-card h2{margin:0 0 6px;font-size:22px;font-weight:600;color:var(--ink);letter-spacing:-.015em}.auth-card .sub{margin:0 0 28px;font-size:13px;color:var(--muted)}.auth-form{display:flex;flex-direction:column;gap:14px}.field{display:flex;flex-direction:column;gap:5px}.field label{font-size:11px;font-weight:600;color:var(--ink-3);letter-spacing:.04em;text-transform:uppercase}.field .input-wrap{position:relative;display:flex;align-items:center}.field input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:7px;background:var(--panel);color:var(--ink);font-size:13.5px;transition:border-color .15s,box-shadow .15s}.field input:focus{outline:none;border-color:var(--pg-blue);box-shadow:0 0 0 3px #43b0f12e}.field input.err{border-color:var(--pg-red)}.field input.err:focus{box-shadow:0 0 0 3px #ef444426}.field .hint{font-size:11px;color:var(--muted)}.field .hint.err{color:var(--pg-red)}.field .toggle{position:absolute;right:10px;background:transparent;border:none;cursor:pointer;color:var(--muted);padding:4px;display:grid;place-items:center}.field .toggle:hover{color:var(--ink)}.auth-alert{padding:10px 12px;border-radius:7px;font-size:12.5px;line-height:1.4;display:flex;align-items:flex-start;gap:8px}.auth-alert.err{background:var(--red-soft);color:#991b1b}.auth-alert.ok{background:var(--green-soft);color:#047857}.auth-row-between{display:flex;align-items:center;justify-content:space-between;font-size:12.5px}.auth-row-between a{color:var(--pg-blue-ink);font-weight:500}.auth-row-between a:hover{text-decoration:underline}.auth-submit{width:100%;padding:11px 16px;background:var(--pg-blue-ink);color:#fff;border:1px solid var(--pg-blue-ink);border-radius:7px;font-size:13.5px;font-weight:600;cursor:pointer;box-shadow:0 2px 6px -1px #248dcb4d;transition:background .15s}.auth-submit:hover:not(:disabled){background:var(--pg-blue-deep)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-switch{margin-top:20px;text-align:center;font-size:12.5px;color:var(--muted)}.auth-switch button{background:transparent;border:none;padding:0;color:var(--pg-blue-ink);font-weight:600;cursor:pointer}.auth-switch button:hover{text-decoration:underline}.auth-result-ic{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;margin:0 auto 14px}.auth-result-ic.ok{background:var(--green-soft);color:#047857}.auth-result-ic.err{background:var(--red-soft);color:#991b1b}.auth-result-ic.neutral{background:var(--blue-soft);color:var(--pg-blue-ink)}.auth-legal{margin-top:18px;font-size:11px;color:var(--muted);text-align:center;line-height:1.5}.auth-legal a{color:var(--pg-blue-ink)}.auth-legal a:hover{text-decoration:underline}@media (max-width: 900px){.auth-shell{grid-template-columns:1fr}.auth-hero{display:none}}.onboarding-shell{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:32px 16px}.onboarding-card{width:100%;max-width:1040px;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-md);display:grid;grid-template-columns:300px 1fr;overflow:hidden;min-height:640px}.onb-stepper{background:var(--bg);border-right:1px solid var(--line);padding:28px 22px;display:flex;flex-direction:column}.onb-stepper .brand{border-bottom:none;padding:0 0 24px}.onb-stepper .brand .logo{height:28px}.onb-stepper ol{list-style:none;padding:0;margin:0;flex:1}.onb-stepper ol li{position:relative;padding:12px;display:flex;align-items:center;gap:12px;border-radius:8px}.onb-stepper ol li.on{background:var(--blue-soft)}.onb-stepper ol li+li:before{content:"";position:absolute;left:30px;top:-4px;width:2px;height:12px;background:var(--line)}.onb-stepper ol li.done+li:before,.onb-stepper ol li.on+li:before{background:var(--line)}.onb-stepper ol li.done:before,.onb-stepper ol li.on:before{background:var(--pg-blue-ink)}.onb-circle{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;background:var(--panel);border:2px solid var(--line);font-size:12px;font-weight:700;color:var(--muted)}.onb-stepper li.on .onb-circle,.onb-stepper li.done .onb-circle{background:var(--pg-blue-ink);border-color:var(--pg-blue-ink);color:#fff}.onb-stepper .step-name{font-size:13px;font-weight:600;color:var(--ink-3)}.onb-stepper li.on .step-name{color:var(--pg-blue-ink)}.onb-stepper .step-sub{font-size:11px;color:var(--muted);margin-top:1px}.onb-stepper .foot{margin-top:auto;padding-top:18px;border-top:1px solid var(--line);font-size:11px;color:var(--muted)}.onb-stepper .foot a{color:var(--pg-blue-ink)}.onb-stepper .foot a:hover{text-decoration:underline}.onb-body{padding:44px 48px;display:flex;flex-direction:column;overflow-y:auto}.onb-body h2{margin:0 0 6px;font-size:22px;font-weight:600;color:var(--ink);letter-spacing:-.015em}.onb-body .onb-sub{margin:0 0 28px;font-size:13px;color:var(--muted)}.plan-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.plan-item{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;padding:18px 20px;border:1px solid var(--line);border-radius:10px;background:var(--bg);position:relative}.plan-item.popular{border-color:var(--pg-blue-ink);box-shadow:0 0 0 1px var(--pg-blue-ink);background:#fafcff}.plan-item-head{grid-column:1;grid-row:1;padding-right:24px}.plan-item-title{display:flex;align-items:center;gap:8px;margin-bottom:2px}.plan-item-name{font-size:15px;font-weight:700;color:var(--ink)}.plan-item-pop-badge{font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--pg-blue-ink);border:1px solid var(--pg-blue-ink);padding:1px 7px;border-radius:999px}.plan-item-desc{font-size:12px;color:var(--muted);margin:0}.plan-item-features{grid-column:1;grid-row:2;list-style:none;padding:0;margin:10px 0 0;display:flex;flex-wrap:wrap;gap:3px 22px}.plan-item-features li{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-3)}.plan-item-features li svg{color:var(--pg-green);flex-shrink:0}.plan-item-cta{grid-column:2;grid-row:1 / 3;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:8px;padding-left:24px;border-left:1px solid var(--line);min-width:150px}.plan-item.popular .plan-item-cta{border-left-color:#c7d9f5}.plan-item-price{display:flex;align-items:baseline;gap:3px}.plan-item-price .p{font-size:28px;font-weight:700;color:var(--ink);letter-spacing:-.02em}.plan-item-price .per{font-size:12px;color:var(--muted)}.plan-item-trial{font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;background:var(--green-soft);color:#047857;text-transform:uppercase;letter-spacing:.06em}.plan-card{max-width:440px;margin:0 auto;background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:24px;position:relative;overflow:hidden}.plan-card.popular{border-color:var(--pg-blue-ink);box-shadow:0 0 0 1px var(--pg-blue-ink)}.plan-card .popular-badge{text-align:center;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--pg-blue-ink);background:var(--blue-soft);padding:5px 0;margin:-24px -24px 16px}.plan-card .plan-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.plan-card .plan-name{font-size:16px;font-weight:600;color:var(--ink)}.plan-card .plan-desc{font-size:12px;color:var(--muted);margin-top:2px}.plan-card .trial{font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700;padding:3px 8px;border-radius:999px;background:var(--green-soft);color:#047857;text-transform:uppercase;letter-spacing:.06em}.plan-card .price{display:flex;align-items:baseline;gap:4px;margin:12px 0 18px}.plan-card .price .p{font-size:34px;font-weight:700;color:var(--ink);letter-spacing:-.02em}.plan-card .price .p.strike{font-size:20px;color:var(--muted);text-decoration:line-through;font-weight:500}.plan-card .price .per{font-size:13px;color:var(--muted);font-weight:500}.plan-card ul.features{list-style:none;padding:0;margin:0 0 20px}.plan-card ul.features li{font-size:12.5px;color:var(--ink-2);padding:6px 0;display:flex;align-items:center;gap:10px}.plan-card ul.features li svg{color:var(--pg-green);flex-shrink:0}.coupon-row{display:grid;grid-template-columns:1fr auto;gap:8px;margin-bottom:16px}.coupon-row input{padding:9px 11px;border:1px solid var(--line);border-radius:7px;background:var(--panel);font-size:13px}.coupon-row input:focus{outline:none;border-color:var(--pg-blue);box-shadow:0 0 0 3px #43b0f12e}.coupon-msg{font-size:11.5px;margin-top:6px}.coupon-msg.ok{color:#047857}.coupon-msg.err{color:var(--pg-red)}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--line);margin-bottom:20px}.tabs button{padding:10px 18px;background:transparent;border:none;font-size:13px;font-weight:500;color:var(--muted);border-bottom:2px solid transparent;cursor:pointer;margin-bottom:-1px}.tabs button.on{color:var(--pg-blue-ink);border-bottom-color:var(--pg-blue-ink);font-weight:600}.tabs button:hover{color:var(--ink)}.step-block{margin-bottom:18px}.step-block h3{margin:0 0 6px;font-size:13.5px;font-weight:600;color:var(--ink)}.step-block p{margin:0 0 8px;font-size:12.5px;color:var(--ink-3)}.code-block{background:var(--pg-dark);color:#f9fafb;padding:12px 16px;border-radius:7px;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.55;position:relative;overflow-x:auto;white-space:pre-wrap;word-break:break-all}.code-block .copy-btn{position:absolute;top:8px;right:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);color:#f9fafb;padding:4px 8px;border-radius:5px;font-size:11px;cursor:pointer}.code-block .copy-btn:hover{background:#ffffff29}.code-block .copy-btn.ok{background:var(--pg-green);border-color:var(--pg-green);color:#fff}.sh-cmd{color:#34d399}.sh-kw{color:#60a5fa}.sh-key{color:#c084fc}.sh-str{color:#fb923c}.sh-cmt{color:#6b7280;font-style:italic}.step-note{margin:5px 0 0;font-size:11.5px;color:var(--muted);line-height:1.45}.step-note code{font-family:JetBrains Mono,monospace;font-size:11px;background:var(--panel-hi);border:1px solid var(--line);border-radius:3px;padding:0 4px;color:var(--ink-3)}.inline-code{font-family:JetBrains Mono,monospace;font-size:11.5px;background:var(--panel-hi);border:1px solid var(--line);border-radius:3px;padding:1px 5px;color:var(--ink-2)}.cred-list{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:4px}.cred-list li{font-size:12px;line-height:1.4;padding-left:14px;position:relative}.cred-list li:before{content:"–";position:absolute;left:0;color:#d97706}.step-ol{margin:6px 0 0;padding-left:18px;font-size:12px;line-height:1.5;color:inherit}.step-ol li{margin-bottom:3px}.step-ol code{font-family:JetBrains Mono,monospace;font-size:11px;background:#00000014;border-radius:3px;padding:0 4px}.note{padding:12px 14px;border-radius:8px;font-size:12.5px;line-height:1.5;border:1px solid}.note.info{background:var(--blue-soft);border-color:#bde4f9;color:var(--pg-blue-deep)}.note.warn{background:var(--orange-soft);border-color:#fde68a;color:#92400e}.wait-box{text-align:center;padding:42px 24px;background:var(--bg);border:2px dashed var(--line);border-radius:10px}.wait-box .wait-circle{width:70px;height:70px;border-radius:50%;background:var(--blue-soft);color:var(--pg-blue-ink);display:grid;place-items:center;margin:0 auto 16px}.wait-box .wait-circle.ok{background:var(--green-soft);color:#047857}.wait-box h3{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--ink)}.wait-box p{margin:0;font-size:12.5px;color:var(--muted)}.verify-list{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.verify-item{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border:1px solid var(--line);border-radius:7px;background:var(--panel)}.verify-item .name{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--ink)}.verify-item .status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600}.verify-item .status.verified{color:#047857}.verify-item .status.missing{color:var(--pg-red)}.verify-item .status.pending{color:var(--muted)}.verify-item .status.verifying{color:var(--pg-blue-ink)}.onb-nav{margin-top:auto;padding-top:24px;display:flex;justify-content:space-between;align-items:center;gap:8px}@media (max-width: 880px){.onboarding-card{grid-template-columns:1fr}.onb-stepper{border-right:none;border-bottom:1px solid var(--line)}.onb-body{padding:28px 24px}}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .9s linear infinite}.spinner.dark{border-color:#11182733;border-top-color:var(--pg-blue-ink)}@keyframes spin{to{transform:rotate(360deg)}}.app-loading{min-height:100vh;display:grid;place-items:center;color:var(--muted);font-size:13px}.panel-body-loading{display:grid;place-items:center;min-height:200px;color:var(--muted);font-size:12.5px}.ribbon.cols-3{grid-template-columns:repeat(3,1fr)}.ribbon.cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1100px){.ribbon.cols-4{grid-template-columns:repeat(2,1fr)}.ribbon.cols-4 .cell:nth-child(2){border-right:none}}.settings-section{padding:18px 20px;display:flex;flex-direction:column;gap:14px}.settings-section>h3{margin:0;font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}.info-grid{display:grid;grid-template-columns:1fr;gap:12px}.info-row{display:grid;grid-template-columns:140px 1fr;align-items:center;padding:10px 0;border-bottom:1px dashed var(--line)}.info-row:last-child{border-bottom:none}.info-row .k{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.06em;text-transform:uppercase}.info-row .v{font-size:13px;color:var(--ink);font-weight:500}.info-row .v.mono{font-family:JetBrains Mono,monospace;font-feature-settings:"tnum"}.status-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-family:JetBrains Mono,monospace}.status-pill .d{width:6px;height:6px;border-radius:50%;background:currentColor}.status-pill.ok{background:var(--green-soft);color:#047857}.status-pill.warn{background:var(--orange-soft);color:#92400e}.status-pill.bad{background:var(--red-soft);color:#991b1b}.status-pill.muted{background:var(--panel-hi);color:var(--muted)}.trial-stripe{display:flex;align-items:center;gap:16px;background:linear-gradient(90deg,var(--blue-soft),transparent);border-left:3px solid var(--pg-blue);padding:12px 16px;border-radius:6px}.trial-stripe .big{font-size:28px;font-weight:700;color:var(--pg-blue-deep);line-height:1;font-feature-settings:"tnum";font-family:JetBrains Mono,monospace;letter-spacing:-.01em}.trial-stripe .sub{font-size:11px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-weight:600}.trial-stripe .end{font-size:12.5px;color:var(--ink-3)}.trial-stripe .end b{color:var(--ink);font-weight:600;font-family:JetBrains Mono,monospace}.trial-stripe .sep{width:1px;height:36px;background:#bde4f9}.feature-list{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px 18px}.feature-list li{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-2);padding:4px 0}.feature-list li svg{color:var(--pg-green);flex-shrink:0}@media (max-width: 960px){.feature-list{grid-template-columns:1fr 1fr}}@media (max-width: 600px){.feature-list{grid-template-columns:1fr}}.retention-row{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap}.retention-row .field{flex:1;min-width:180px}.retention-row .actions{display:flex;gap:8px;padding-bottom:2px}.section-actions{display:flex;justify-content:flex-end;gap:10px;padding:12px 20px 16px;border-top:1px solid var(--line);background:var(--bg)}.danger-zone{border-color:#fecaca}.danger-zone .panel-head{background:linear-gradient(180deg,var(--red-soft),transparent);border-bottom:1px solid #FECACA}.danger-zone .panel-head .title h3{color:#991b1b}.danger-zone .panel-head .title p{color:#b91c1c}.danger-row{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:20px}.danger-row .info h4{margin:0 0 2px;font-size:13.5px;font-weight:600;color:var(--ink)}.danger-row .info p{margin:0;font-size:12px;color:var(--ink-3);line-height:1.5}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#1118277a;display:grid;place-items:center;padding:16px}.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-md);width:100%;max-width:520px;display:flex;flex-direction:column}.modal-head{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;justify-content:space-between}.modal-head h3{margin:0;font-size:15px;font-weight:600;color:var(--ink)}.modal-head p{margin:2px 0 0;font-size:12px;color:var(--muted)}.modal-head .close-btn{background:transparent;border:none;cursor:pointer;color:var(--muted);padding:4px;display:grid;place-items:center}.modal-head .close-btn:hover{color:var(--ink)}.modal-body{padding:18px 20px;display:flex;flex-direction:column;gap:12px}.modal-foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}.choice{border:2px solid var(--line);border-radius:10px;padding:14px 16px;cursor:pointer;display:flex;gap:12px;align-items:flex-start;transition:border-color .12s,background .12s}.choice:hover{border-color:#d1d5db}.choice.on.blue{border-color:var(--pg-blue);background:var(--blue-soft)}.choice.on.red{border-color:var(--pg-red);background:var(--red-soft)}.choice .radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;flex-shrink:0;margin-top:2px}.choice.on.blue .radio{border-color:var(--pg-blue)}.choice.on.red .radio{border-color:var(--pg-red)}.choice .radio:after{content:"";width:8px;height:8px;border-radius:50%;background:transparent}.choice.on.blue .radio:after{background:var(--pg-blue)}.choice.on.red .radio:after{background:var(--pg-red)}.choice h4{margin:0 0 3px;font-size:13px;font-weight:600;color:var(--ink)}.choice p{margin:0;font-size:12px;color:var(--ink-3);line-height:1.5}.choice .foot-tag{display:inline-flex;align-items:center;gap:4px;margin-top:6px;font-size:10.5px;font-weight:700;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.06em}.choice .foot-tag.ok{color:#047857}.choice .foot-tag.warn{color:#92400e}.btn.danger{background:var(--pg-red);color:#fff;border-color:var(--pg-red);box-shadow:0 2px 6px -1px #ef44444d}.btn.danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.btn.danger-ghost{background:var(--red-soft);color:#991b1b;border-color:#fecaca}.btn.danger-ghost:hover:not(:disabled){background:#fecaca}.toast{position:fixed;top:20px;right:20px;z-index:60;min-width:280px;max-width:420px;background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--pg-blue-ink);border-radius:8px;padding:12px 14px;font-size:12.5px;color:var(--ink-2);box-shadow:var(--shadow-md);display:flex;align-items:flex-start;gap:10px}.toast.ok{border-left-color:var(--pg-green)}.toast.err{border-left-color:var(--pg-red)}.toast .close-btn{margin-left:auto;background:transparent;border:none;cursor:pointer;color:var(--muted);padding:2px;display:grid;place-items:center}.toast .close-btn:hover{color:var(--ink)}.ribbon.cols-5{grid-template-columns:repeat(5,1fr)}.query-table{width:100%;border-collapse:collapse;font-size:12.5px}.query-table th{padding:9px 14px;text-align:left;color:var(--muted);font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--line);background:var(--panel-hi);white-space:nowrap}.query-table th.r{text-align:right}.query-table td{padding:8px 14px;border-bottom:1px solid var(--line);color:var(--ink-2);vertical-align:middle}.query-table td.r{text-align:right}.query-table td.mono{font-family:JetBrains Mono,monospace;font-feature-settings:"tnum";font-size:11.5px}.query-table tbody tr:last-child td{border-bottom:none}.query-table tbody tr:hover td{background:var(--panel-hi)}.query-txt{display:block;max-width:340px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;color:var(--pg-blue-deep);font-family:JetBrains Mono,monospace;font-size:11.5px}.query-txt:hover{text-decoration:underline}.modal{background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-md);width:100%;display:flex;flex-direction:column}.modal-close{background:transparent;border:none;cursor:pointer;color:var(--muted);padding:4px;display:grid;place-items:center}.modal-close:hover{color:var(--ink)}.query-modal-pre{margin:0;padding:16px;background:var(--panel-hi);border:1px solid var(--line);border-radius:8px;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.6;white-space:pre-wrap;word-break:break-word;color:var(--ink-2);max-height:60vh;overflow-y:auto}.state-pill{display:inline-block;padding:1px 8px;border-radius:20px;font-size:10.5px;font-weight:600;white-space:nowrap}.state-pill.pill-ok{background:#d1fae5;color:#065f46}.state-pill.pill-warn{background:#fef3c7;color:#92400e}.state-pill.pill-info{background:#dbeafe;color:#1e40af}.state-pill.pill-muted{background:var(--panel-hi);color:var(--muted)}.text-warn{color:#92400e;font-weight:600}.text-bad{color:#991b1b;font-weight:600}.pct-warn{color:#92400e;font-weight:600}.pct-bad{color:#991b1b;font-weight:700}.search-input{height:30px;padding:0 10px;border-radius:6px;border:1px solid var(--line);background:var(--panel-hi);font-size:12px;color:var(--ink);font-family:Inter,sans-serif;outline:none;width:180px}.search-input:focus{border-color:var(--pg-blue-ink)}.search-input::placeholder{color:var(--muted)}.chip.warn{background:#fef3c7;color:#92400e;border-color:#f59e0b}.table-scroll{overflow-x:auto;overflow-y:auto;max-height:480px}.table-scroll .query-table thead th{position:sticky;top:0;z-index:1;background:var(--panel-hi)}.sg-warning{display:flex;gap:8px;align-items:flex-start;margin:0 16px 14px;padding:10px 14px;background:#fef3c7;border:1px solid #F59E0B;border-radius:8px;color:#92400e;font-size:12px;line-height:1.45}.suggestion-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;padding:0 16px 16px}.suggestion-card{background:var(--panel-hi);border:1px solid var(--line);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:8px}.sg-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sg-table{font-size:12.5px;font-weight:700;color:var(--pg-orange)}.sg-type{font-size:10px;font-weight:600;padding:1px 7px;border-radius:20px;background:var(--blue-soft);color:var(--pg-blue-ink)}.sg-reason{font-size:11.5px;color:var(--ink-2);line-height:1.45;margin:0}.sg-meta{display:flex;gap:10px;flex-wrap:wrap}.sg-meta span{font-size:10.5px;color:var(--muted)}.sg-code-wrap{position:relative}.sg-code{margin:0;padding:10px 56px 10px 12px;background:#0b0f19;border-radius:7px;font-family:JetBrains Mono,monospace;font-size:11px;line-height:1.55;color:#a5d6ff;white-space:pre-wrap;word-break:break-all}.sg-copy{position:absolute;top:8px;right:8px;padding:3px 9px;border-radius:5px;border:none;cursor:pointer;font-size:11px;font-weight:600;background:var(--pg-blue-ink);color:#fff;display:flex;align-items:center;gap:4px;transition:background .15s}.sg-copy:hover{background:#1a7ab3}.sg-copy.copied{background:#059669}.plan-tree{padding:16px;overflow:auto}.plan-node-wrap{margin:0 0 4px}.plan-node{border:1px solid var(--line);border-radius:6px;background:var(--panel);margin-bottom:4px;overflow:hidden}.plan-node-head{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;padding:7px 12px;cursor:pointer}.plan-node-head:hover{background:var(--panel-hi)}.plan-chevron{font-size:9px;color:var(--muted);flex-shrink:0;display:inline-block;transition:transform .15s;margin-right:2px}.plan-chevron.open{transform:rotate(90deg)}.plan-node-type{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;flex-shrink:0}.plan-node-rel{font-size:11.5px;color:var(--ink-3);font-family:JetBrains Mono,monospace}.plan-node-cost{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--muted);margin-left:auto}.plan-node-filter{padding:4px 12px 8px;font-family:JetBrains Mono,monospace;font-size:11px;color:var(--ink-3);border-top:1px dashed var(--line);background:var(--panel-hi);word-break:break-all}.plan-node-children{padding-left:22px;border-left:2px solid var(--line);margin:0 0 0 18px;padding-top:4px}.plan-summary{display:flex;gap:28px;flex-wrap:wrap;background:var(--blue-soft);border:1px solid #BDE4F9;border-radius:8px;padding:12px 18px;margin:0 0 16px}.plan-summary-item{display:flex;flex-direction:column;gap:2px}.plan-summary-item .sk{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.plan-summary-item .sv{font-family:JetBrains Mono,monospace;font-size:16px;font-weight:700;color:var(--pg-blue-deep)}.plan-blocks{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:12px 18px;background:#fef3c7;border:1px solid #FCD34D;border-radius:8px}.plan-block-item .bk{font-size:10.5px;color:#92400e;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.plan-block-item .bv{font-family:JetBrains Mono,monospace;font-size:15px;font-weight:700;color:#78350f}.cmp-stat{display:flex;justify-content:space-between;align-items:center;padding:7px 12px;border-radius:6px;font-size:12.5px}.cmp-stat .ck{color:var(--ink-3);font-size:11.5px}.cmp-stat .cv{font-family:JetBrains Mono,monospace;font-weight:600;color:var(--ink)}.cmp-stat.good{background:var(--green-soft)}.cmp-stat.bad{background:var(--red-soft)}.cmp-stat.neutral{background:var(--panel-hi)}.plan-user-badge{display:flex;align-items:center;gap:8px}.plan-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--pg-orange);color:#fff;font-weight:700;font-size:11px;display:grid;place-items:center;flex-shrink:0}.plan-user-name{font-size:13px;font-weight:600;color:var(--ink);line-height:1.2}.plan-user-email{font-size:11px;color:var(--muted);font-family:JetBrains Mono,monospace}.plan-cards-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:20px 28px}.plan-cards-row .plan-card{max-width:none;margin:0;overflow:visible;border:1px solid var(--line);border-radius:12px;background:var(--panel);display:flex;flex-direction:column;padding:28px 24px;position:relative;transition:box-shadow .15s}.plan-cards-row .plan-card:hover{box-shadow:0 4px 16px #00000012}.plan-card-highlight{border-color:#43b0f1!important;box-shadow:0 0 0 2px #43b0f126!important}.plan-card-current{border-color:#10b981!important;box-shadow:0 0 0 2px #10b98126!important}.plan-popular-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:#43b0f1;color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 12px;border-radius:20px}.plan-current-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:#10b981;color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 12px;border-radius:20px}.plan-card-head{margin-bottom:20px}.plan-card .plan-name{font-size:18px;font-weight:700;color:var(--ink);margin:0 0 10px}.plan-card .plan-price{display:flex;align-items:baseline;gap:4px;margin-bottom:10px}.plan-price-val{font-size:32px;font-weight:700;color:var(--ink);letter-spacing:-.03em}.plan-price-period{font-size:13px;color:var(--muted);font-weight:400}.plan-card .plan-desc{font-size:12.5px;color:var(--muted);margin:0;line-height:1.5}.plan-feature-list{list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:8px;flex:1}.plan-feature-list li{font-size:12.5px;color:var(--ink-2);display:flex;align-items:center;gap:8px}.plan-check{color:#10b981;display:flex;flex-shrink:0}.plan-card-foot{margin-top:auto}.plan-btn-current{width:100%;justify-content:center;background:var(--panel-hi);color:var(--muted);cursor:default;border:1px solid var(--line)}.plan-btn-upgrade{width:100%;justify-content:center;gap:6px}.plan-card .btn{display:flex;align-items:center;justify-content:center}.user-foot>div:not(.avatar):not(.logout-btn){overflow:hidden;min-width:0}.user-foot .u-name,.user-foot .u-email{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cred-kv-grid{display:grid;grid-template-columns:auto 1fr;gap:8px 12px;align-items:start;margin:12px 0}.cred-kv-key{font-family:var(--font-mono, monospace);font-size:12px;background:var(--panel-hi);padding:4px 8px;border-radius:4px;color:var(--ink-2);white-space:nowrap;align-self:center}.cred-kv-val-row{display:flex;align-items:flex-start;gap:6px;background:var(--panel-hi);border-radius:4px;padding:4px 8px}.cred-mono{font-family:var(--font-mono, monospace);font-size:11.5px;color:var(--ink-1);word-break:break-all;flex:1}.db-picker-list{display:flex;flex-direction:column;gap:6px;margin-bottom:4px}.db-picker-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;border:1px solid var(--line);cursor:pointer;transition:border-color .15s,background .15s}.db-picker-item:hover{border-color:var(--accent);background:var(--panel-hi)}.db-picker-item.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}.db-picker-item input[type=checkbox]{accent-color:var(--accent);width:15px;height:15px}.db-picker-name{font-size:13.5px;font-family:var(--font-mono, monospace);color:var(--ink-1)}.db-schema-list{display:flex;flex-direction:column;gap:8px}.db-schema-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;border:1px solid var(--line);background:var(--panel-bg)}.db-schema-name{font-family:var(--font-mono, monospace);font-size:13px;color:var(--ink-1);min-width:120px}.db-schema-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;padding:2px 8px;border-radius:20px;font-weight:600;background:var(--panel-hi);color:var(--ink-2)}.db-schema-badge.ok{background:#d1fae5;color:#065f46}.db-schema-badge.failed,.db-schema-badge.manual{background:#fee2e2;color:#991b1b}.db-schema-badge.installing{background:#fef3c7;color:#92400e}.agents-list{display:flex;flex-direction:column;gap:16px}.agent-card{border:1px solid var(--line);border-radius:10px;background:var(--panel-bg);overflow:hidden;transition:border-color .2s}.agent-card.connected{border-color:#34d399}.agent-card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;cursor:pointer;border-bottom:1px solid transparent}.agent-card.connected .agent-card-header{border-bottom-color:var(--line)}.agent-card-title,.agent-card-meta{display:flex;align-items:center;gap:10px}.agent-status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);flex-shrink:0}.agent-status-dot.on{background:#10b981;box-shadow:0 0 0 2px #d1fae5}.agent-name{font-weight:600;font-size:14px;color:var(--ink-1)}.agent-type-badge{font-size:10px;padding:2px 7px;border-radius:20px;background:var(--panel-hi);color:var(--ink-2);font-weight:600;text-transform:uppercase}.agent-version{font-size:11px;color:var(--muted);font-family:var(--font-mono, monospace)}.agent-uuid{font-family:var(--font-mono, monospace);font-size:11px;color:var(--muted);margin-bottom:12px;word-break:break-all}.agent-card-body{padding:14px 16px}.agent-dbs{display:flex;flex-direction:column;gap:10px}.agent-offline-msg{color:var(--ink-3);font-size:13px;margin:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box{background:var(--panel-bg);border-radius:12px;border:1px solid var(--line);width:100%;max-width:540px;box-shadow:0 20px 60px #0003;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}.modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--ink-1)}.modal-body{padding:20px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--line);background:var(--panel-hi)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.page-title{font-size:22px;font-weight:700;color:var(--ink-1);margin:0 0 4px}.page-sub{font-size:13px;color:var(--ink-3);margin:0}.empty-state{text-align:center;padding:60px 24px;color:var(--ink-3);display:flex;flex-direction:column;align-items:center;gap:16px}.empty-state p{font-size:15px;margin:0}.step-block .cred-kv-grid{margin-top:6px}.icon-btn{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:6px;background:transparent;border:none;cursor:pointer;color:var(--muted);transition:background .1s,color .1s;flex-shrink:0}.icon-btn:hover{background:var(--bg);color:var(--ink-2)}.icon-btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn.danger:hover{background:#fee2e2;color:#dc2626}.modal-close-btn{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:6px;background:transparent;border:none;cursor:pointer;color:var(--muted);transition:background .1s,color .1s}.modal-close-btn:hover{background:var(--bg);color:var(--ink-2)}.cred-copy-btn{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:5px;background:transparent;border:none;cursor:pointer;color:var(--muted);transition:background .1s,color .1s;flex-shrink:0}.cred-copy-btn:hover{background:var(--bg);color:var(--pg-blue-ink)}.tb-pill{position:relative;display:inline-flex;align-items:center}.tb-pill-btn{display:flex;align-items:center;gap:5px;background:transparent;border:none;cursor:pointer;color:var(--ink-3);font-size:12.5px;padding:4px 8px;border-radius:5px;transition:background .1s;font-family:Inter,sans-serif}.tb-pill-btn:hover{background:var(--bg)}.tb-pill-btn svg{color:var(--pg-blue-deep);flex-shrink:0}.tb-pill-label{color:var(--muted);font-size:11px}.tb-pill-val{color:var(--ink-2);font-weight:600;font-size:12.5px;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tb-pill-drop{position:absolute;top:calc(100% + 6px);left:0;z-index:50;background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow-md);min-width:180px;padding:4px 0;overflow:hidden}.tb-pill-drop button{width:100%;text-align:left;display:flex;align-items:center;gap:8px;background:transparent;border:none;cursor:pointer;padding:7px 14px;font-size:12.5px;color:var(--ink-2);transition:background .1s;font-family:Inter,sans-serif}.tb-pill-drop button:hover{background:var(--bg)}.tb-pill-drop button.sel{color:var(--pg-blue-ink);font-weight:600;background:var(--blue-soft)}.tb-status-dot{width:7px;height:7px;border-radius:50%;background:var(--muted-2);flex-shrink:0}.tb-status-dot.on{background:var(--pg-green)}.ag-list{display:flex;flex-direction:column;gap:14px}.ag-panel{background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--line);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm)}.ag-panel.connected{border-left-color:var(--pg-green)}.ag-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px 12px;border-bottom:1px solid var(--line-2);flex-wrap:wrap}.ag-panel-title{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}.ag-dot{width:9px;height:9px;border-radius:50%;background:var(--muted-2);flex-shrink:0}.ag-dot.on{background:var(--pg-green);box-shadow:0 0 0 3px #d1fae5}.ag-name{font-weight:600;font-size:14.5px;color:var(--ink)}.ag-type-badge{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;background:var(--blue-soft);color:var(--pg-blue-deep);padding:2px 8px;border-radius:20px}.ag-ver{font-size:11px;color:var(--muted);font-family:JetBrains Mono,monospace}.ag-panel-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.ag-conn-label{font-size:12px;color:var(--muted);white-space:nowrap}.ag-conn-label.on{color:var(--pg-green);font-weight:600}.ag-del-btn{display:inline-flex;align-items:center;gap:5px;font-size:12px;padding:4px 10px;height:28px}.ag-uuid-strip{font-size:10.5px;font-family:JetBrains Mono,monospace;color:var(--muted);padding:5px 20px;background:var(--bg);border-bottom:1px solid var(--line-2)}.ag-body{padding:16px 20px 18px}.ag-offline-msg{font-size:13px;color:var(--muted);margin:0}.ag-empty-note{font-size:13px;color:var(--muted);margin:0 0 14px}.ag-db-table{margin-bottom:14px;border:1px solid var(--line-2);border-radius:8px;overflow:hidden}.ag-db-table-head{display:grid;grid-template-columns:1fr 160px 130px;padding:7px 14px;background:var(--bg);border-bottom:1px solid var(--line-2);font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.ag-db-row{display:grid;grid-template-columns:1fr 160px 130px;align-items:center;padding:9px 14px;border-bottom:1px solid var(--line-2)}.ag-db-row:last-child{border-bottom:none}.ag-db-name{font-size:13px;font-weight:500;font-family:JetBrains Mono,monospace;color:var(--ink-2)}.ag-install-btn{font-size:11.5px;padding:3px 10px;justify-self:start}.ag-schema-badge{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:500;padding:2px 9px;border-radius:20px;white-space:nowrap}.ag-schema-badge.ok{background:var(--green-soft);color:#059669}.ag-schema-badge.busy{background:var(--orange-soft);color:#b45309}.ag-schema-badge.pending{background:var(--line-2);color:var(--muted)}.ag-schema-badge.err{background:#fee2e2;color:#dc2626}.ag-picker-wrap{margin-bottom:14px}.ag-picker-title{font-size:12.5px;font-weight:600;color:var(--ink-2);margin:0 0 10px}.ag-picker-loading{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;padding:8px 0}.ag-db-checkboxes{display:flex;flex-direction:column;gap:4px;max-height:260px;overflow-y:auto;margin-bottom:12px}.ag-db-check-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:7px;border:1px solid var(--line-2);cursor:pointer;font-size:13px;font-family:JetBrains Mono,monospace;color:var(--ink-2);transition:border-color .12s,background .12s}.ag-db-check-item:hover{border-color:var(--pg-blue);background:var(--blue-soft)}.ag-db-check-item.sel{border-color:var(--pg-blue);background:var(--blue-soft);color:var(--pg-blue-ink)}.ag-db-check-item input[type=checkbox]{accent-color:var(--pg-blue);width:14px;height:14px;flex-shrink:0}.ag-picker-foot{display:flex;gap:8px}.ag-action-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:14px;border-top:1px solid var(--line-2);margin-top:2px}.ag-action-msg{font-size:12px;color:var(--muted)}.tbl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:14px}.tbl-card{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:14px 16px;cursor:pointer;transition:box-shadow .15s,transform .15s,border-color .15s;display:flex;flex-direction:column;gap:12px}.tbl-card:hover{box-shadow:0 4px 18px #0000001f;transform:translateY(-2px);border-color:var(--pg-blue)}.tbl-card-head{border-bottom:1px solid var(--line-2);padding-bottom:10px}.tbl-card-schema{font-size:11px;font-weight:600;color:var(--pg-blue);font-family:JetBrains Mono,monospace;margin-bottom:3px}.tbl-card-name{font-size:15px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tbl-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}.tbl-stat{background:var(--bg);border-radius:7px;padding:8px 10px}.tbl-stat-val{font-size:13px;font-weight:600;font-family:JetBrains Mono,monospace;color:var(--ink-2)}.tbl-stat-val.bloat-ok{color:#059669}.tbl-stat-val.bloat-warn{color:#b45309}.tbl-stat-val.bloat-bad{color:#dc2626}.tbl-stat-lbl{font-size:10.5px;color:var(--muted);margin-top:1px}.detail-tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin-bottom:20px}.detail-tab{padding:9px 18px;font-size:13px;font-weight:500;color:var(--muted);border-bottom:2px solid transparent;cursor:pointer;background:none;border-top:none;border-left:none;border-right:none;transition:color .12s,border-color .12s}.detail-tab:hover{color:var(--ink-2)}.detail-tab.on{color:var(--pg-blue-ink);border-bottom-color:var(--pg-blue);font-weight:600}.stat-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:9px;padding:14px 16px;display:flex;flex-direction:column;gap:4px}.stat-card-title{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.stat-card-val{font-size:22px;font-weight:700;color:var(--ink);font-family:JetBrains Mono,monospace;line-height:1.2}.stat-card-desc{font-size:11.5px;color:var(--muted)}.stat-card-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;margin-top:2px}.stat-card-badge.good{background:var(--green-soft);color:#059669}.stat-card-badge.bad{background:var(--red-soft);color:#991b1b}@media (max-width: 1100px){.stat-cards{grid-template-columns:repeat(3,1fr)}}@media (max-width: 700px){.stat-cards{grid-template-columns:repeat(2,1fr)}}.kv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0}.kv-row{display:flex;justify-content:space-between;align-items:center;padding:7px 16px;border-bottom:1px solid var(--line-2);font-size:12.5px}.kv-row:last-child{border-bottom:none}.kv-key{color:var(--muted);font-weight:500;text-transform:capitalize}.kv-val{font-family:JetBrains Mono,monospace;color:var(--ink-2);font-weight:500;text-align:right;max-width:60%;word-break:break-all}.pg-bar{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 0 4px}.pg-bar>span{font-size:12.5px;color:var(--muted)}.pg-btn{background:var(--surface);border:1px solid var(--line);border-radius:7px;padding:5px 13px;font-size:12px;font-weight:500;color:var(--ink-2);cursor:pointer;transition:border-color .12s}.pg-btn:hover:not(:disabled){border-color:var(--pg-blue);color:var(--pg-blue-ink)}.pg-btn:disabled{opacity:.45;cursor:not-allowed}.accordion-item{border:1px solid var(--line);border-radius:9px;overflow:hidden;margin-bottom:8px}.accordion-item.dimmed{opacity:.45;pointer-events:none}.accordion-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:13px 18px;background:var(--surface);font-size:13.5px;font-weight:600;color:var(--ink);cursor:pointer;border:none;text-align:left;transition:background .12s}.accordion-trigger:hover,.accordion-trigger.open{background:var(--bg)}.accordion-chevron{transition:transform .25s;color:var(--muted);flex-shrink:0}.accordion-chevron.open{transform:rotate(180deg)}.accordion-body{overflow:hidden;max-height:0;transition:max-height .35s ease}.accordion-body.open{max-height:9999px}.accordion-content{padding:16px 18px;border-top:1px solid var(--line-2);display:flex;flex-direction:column;gap:16px}.accordion-subtitle{font-size:13px;font-weight:600;color:var(--ink-2);padding-top:8px;border-top:1px solid var(--line-2)}.accordion-subtitle:first-child{border-top:none;padding-top:0}.insight-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.insight-card{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:8px;height:170px}.insight-card-title{font-size:14px;font-weight:700;color:var(--ink)}.insight-card-desc{font-size:12.5px;color:var(--muted);line-height:1.5;flex:1}.insight-card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}.insight-tags{display:flex;flex-wrap:wrap;gap:4px}.insight-tag{background:var(--blue-soft);color:var(--pg-blue-ink);font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:20px}.insight-actions{display:flex;gap:6px;flex-shrink:0}.sel-list{max-height:55vh;overflow-y:auto;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.sel-item{display:flex;align-items:center;gap:10px;padding:9px 20px;border-bottom:1px solid var(--line-2);cursor:pointer;font-size:13px;font-family:JetBrains Mono,monospace;color:var(--ink-2)}.sel-item:last-child{border-bottom:none}.sel-item:hover{background:var(--bg)}.reg-wiz-steps{display:flex;align-items:center;gap:0;padding:0 4px}.reg-wiz-step{display:flex;flex-direction:column;align-items:center;gap:5px;flex-shrink:0;font-size:11px;font-weight:600;color:var(--muted)}.reg-wiz-step.active,.reg-wiz-step.done{color:var(--pg-blue-ink)}.reg-wiz-circle{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;background:var(--surface);border:2px solid var(--line);font-size:11px;font-weight:700;color:var(--muted);transition:background .15s,border-color .15s,color .15s}.reg-wiz-step.active .reg-wiz-circle,.reg-wiz-step.done .reg-wiz-circle{background:var(--pg-blue-ink);border-color:var(--pg-blue-ink);color:#fff}.reg-wiz-bar{flex:1;height:2px;background:var(--line);margin:0 4px 18px;transition:background .15s}.reg-wiz-bar.done{background:var(--pg-blue-ink)}.sel-item input[type=checkbox]{accent-color:var(--pg-blue);width:14px;height:14px;flex-shrink:0}.user-mgmt-table{width:100%;border-collapse:collapse;font-size:12.5px}.user-mgmt-table th{padding:9px 16px;text-align:left;font-size:10.5px;font-weight:600;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--line);background:var(--panel-hi);white-space:nowrap}.user-mgmt-table td{padding:10px 16px;border-bottom:1px solid var(--line);color:var(--ink-2);vertical-align:middle}.user-mgmt-table tbody tr:last-child td{border-bottom:none}.user-mgmt-table tbody tr:hover td{background:var(--panel-hi)}.role-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:999px;font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;font-family:JetBrains Mono,monospace}.role-badge.admin{background:var(--blue-soft);color:var(--pg-blue-ink)}.role-badge.user{background:var(--panel-hi);color:var(--muted)}.perm-editor{display:grid;grid-template-columns:220px 1fr;min-height:400px;border-top:1px solid var(--line);overflow:hidden}.perm-db-list{border-right:1px solid var(--line);overflow-y:auto;background:var(--bg);display:flex;flex-direction:column;padding:8px;gap:2px}.perm-db-item{padding:10px 12px;border-radius:7px;cursor:pointer;transition:background .1s,border-color .1s;border:1px solid transparent}.perm-db-item:hover{background:var(--panel);border-color:var(--line)}.perm-db-item.active{background:var(--blue-soft);border-color:#bde4f9}.perm-dashboard-list{display:flex;flex-direction:column;overflow-y:auto}.perm-group{padding:10px 0 6px}.perm-group-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:0 4px 6px}.perm-check-item{display:flex;align-items:center;gap:9px;padding:6px 4px;border-radius:5px;cursor:pointer;font-size:12.5px;color:var(--ink-2);transition:background .1s}.perm-check-item:hover{background:var(--panel-hi)}.perm-check-item input[type=checkbox]{accent-color:var(--pg-blue-ink);width:14px;height:14px;flex-shrink:0;cursor:pointer}.access-denied-wrap{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 120px);padding:40px 24px}.access-denied-card{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;max-width:380px;width:100%;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:48px 40px 40px;box-shadow:var(--shadow-md)}.access-denied-icon{width:80px;height:80px;border-radius:20px;background:var(--red-soft);color:#dc2626;display:grid;place-items:center;flex-shrink:0}.access-denied-title{margin:0;font-size:20px;font-weight:700;color:var(--ink);letter-spacing:-.02em}.access-denied-sub{margin:0;font-size:13px;color:var(--muted);line-height:1.6}.chat-widget-root{position:fixed;bottom:24px;right:24px;z-index:900;display:flex;flex-direction:column;align-items:flex-end;gap:12px}.chat-fab{position:relative;width:52px;height:52px;border-radius:50%;background:var(--pg-blue);color:#fff;border:none;cursor:pointer;display:grid;place-items:center;box-shadow:0 4px 18px -4px #43b0f18c;transition:transform .15s,background .15s,box-shadow .15s}.chat-fab:hover{background:var(--pg-blue-ink);transform:scale(1.08);box-shadow:0 6px 22px -4px #43b0f1a6}.chat-fab-badge{position:absolute;top:-4px;right:-4px;width:20px;height:20px;border-radius:50%;background:#ef4444;color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center;border:2px solid var(--bg);animation:chat-pop .2s ease}@keyframes chat-pop{0%{transform:scale(0)}to{transform:scale(1)}}.chat-window{width:340px;height:480px;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:0 12px 40px -8px #11182729;display:flex;flex-direction:column;overflow:hidden;animation:chat-slide-up .18s ease}@keyframes chat-slide-up{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-header{background:var(--pg-blue);color:#fff;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.chat-header-left{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13.5px}.chat-header-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;box-shadow:0 0 0 2px #4ade8059;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.chat-close-btn{background:transparent;border:none;color:#fffc;cursor:pointer;padding:4px;border-radius:4px;display:grid;place-items:center;transition:background .1s,color .1s}.chat-close-btn:hover{background:#fff3;color:#fff}.chat-messages{flex:1;overflow-y:auto;padding:14px 12px;display:flex;flex-direction:column;gap:8px;background:var(--bg);position:relative}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;height:100%;color:var(--muted);text-align:center;font-size:12.5px}.chat-msg-row{display:flex;flex-direction:column;max-width:82%}.chat-msg-row.user{align-self:flex-end;align-items:flex-end}.chat-msg-row.admin{align-self:flex-start;align-items:flex-start}.chat-bubble{padding:9px 13px;border-radius:14px;font-size:13px;line-height:1.45;word-break:break-word}.chat-msg-row.user .chat-bubble{background:var(--pg-blue);color:#fff;border-bottom-right-radius:4px}.chat-msg-row.admin .chat-bubble{background:var(--panel);border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:4px}.chat-msg-meta{display:flex;align-items:center;gap:4px;margin-top:3px;padding:0 2px}.chat-ts{font-size:10.5px;color:var(--muted-2)}.chat-new-msg-btn{position:sticky;bottom:4px;align-self:center;background:var(--pg-blue);color:#fff;border:none;border-radius:20px;padding:5px 14px;font-size:11.5px;font-weight:600;cursor:pointer;box-shadow:0 3px 10px -2px #43b0f180;animation:chat-pop .15s ease}.chat-input-row{display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid var(--line);background:var(--panel);flex-shrink:0}.chat-input{flex:1;height:36px;padding:0 14px;border-radius:18px;border:1px solid var(--line);background:var(--bg);color:var(--ink);font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s}.chat-input:focus{border-color:var(--pg-blue);box-shadow:0 0 0 3px #43b0f11f}.chat-send-btn{width:36px;height:36px;border-radius:50%;background:var(--pg-blue);color:#fff;border:none;cursor:pointer;display:grid;place-items:center;flex-shrink:0;transition:background .12s,transform .12s}.chat-send-btn:hover:not(:disabled){background:var(--pg-blue-ink);transform:scale(1.06)}.chat-send-btn:disabled{opacity:.4;cursor:default}.adm-chat-layout{display:grid;grid-template-columns:300px 1fr;height:calc(100vh - 38px);overflow:hidden}.adm-chat-sidebar{display:flex;flex-direction:column;background:var(--panel);border-right:1px solid var(--line);overflow:hidden}.adm-chat-sidebar-head{padding:16px 16px 10px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.adm-chat-sidebar-title{margin:0;font-size:17px;font-weight:700;color:var(--ink)}.adm-chat-live-dot{width:10px;height:10px;border-radius:50%;background:#10b981;box-shadow:0 0 0 3px #10b98133;animation:pulse-dot 2s infinite}.adm-chat-search-wrap{display:flex;align-items:center;gap:8px;margin:0 12px 10px;padding:0 12px;height:34px;border:1px solid var(--line);border-radius:8px;background:var(--bg);color:var(--muted);flex-shrink:0}.adm-chat-search{flex:1;background:transparent;border:none;outline:none;font-size:12.5px;color:var(--ink)}.adm-chat-search::placeholder{color:var(--muted-2)}.adm-chat-list{flex:1;overflow-y:auto;padding:4px 8px 12px;display:flex;flex-direction:column;gap:2px}.adm-chat-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 0;color:var(--muted);font-size:12.5px}.adm-chat-list-item{position:relative;display:flex;align-items:center;gap:10px;padding:10px 10px 10px 14px;border-radius:8px;cursor:pointer;transition:background .1s;overflow:hidden}.adm-chat-list-item:hover{background:var(--bg)}.adm-chat-list-item.active{background:var(--blue-soft)}.adm-chat-active-bar{position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:32px;background:var(--pg-blue);border-radius:0 3px 3px 0}.adm-chat-avatar-wrap{position:relative;flex-shrink:0}.adm-chat-avatar{width:38px;height:38px;border-radius:50%;background:var(--panel-hi);border:1px solid var(--line);color:var(--ink-3);font-weight:700;font-size:14px;display:grid;place-items:center;transition:background .1s,color .1s}.adm-chat-avatar.active{background:var(--pg-blue);color:#fff;border-color:var(--pg-blue)}.adm-chat-online-dot{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;background:#10b981;border:2px solid var(--panel)}.adm-chat-item-body{flex:1;min-width:0}.adm-chat-item-top{display:flex;justify-content:space-between;align-items:baseline;gap:6px;margin-bottom:2px}.adm-chat-item-name{font-weight:600;font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.adm-chat-item-time{font-size:10.5px;color:var(--muted-2);white-space:nowrap;flex-shrink:0}.adm-chat-item-preview{font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.adm-chat-unread{flex-shrink:0;background:var(--pg-blue);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:grid;place-items:center;padding:0 4px}.adm-chat-main{display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.adm-chat-main-head{display:flex;align-items:center;gap:12px;padding:10px 20px;background:var(--panel);border-bottom:1px solid var(--line);flex-shrink:0}.adm-chat-back-btn{background:transparent;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:6px;display:grid;place-items:center;transition:background .1s,color .1s}.adm-chat-back-btn:hover{background:var(--bg);color:var(--ink)}.adm-chat-head-avatar{position:relative;width:38px;height:38px;border-radius:50%;background:var(--pg-blue);color:#fff;font-weight:700;font-size:15px;display:grid;place-items:center;flex-shrink:0}.adm-chat-head-online{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;background:#10b981;border:2px solid var(--panel)}.adm-chat-head-name{font-weight:600;font-size:14px;color:var(--ink)}.adm-chat-head-status{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--muted);margin-top:1px}.adm-status-dot{width:6px;height:6px;border-radius:50%;background:var(--muted-2)}.adm-status-dot.online{background:#10b981}.adm-chat-messages{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:6px}.adm-msg-row{display:flex;flex-direction:column;max-width:64%}.adm-msg-row.admin{align-self:flex-end;align-items:flex-end}.adm-msg-row.user{align-self:flex-start;align-items:flex-start}.adm-bubble{padding:10px 16px;border-radius:16px;font-size:13.5px;line-height:1.5;word-break:break-word}.adm-bubble.admin{background:var(--pg-blue);color:#fff;border-bottom-right-radius:4px}.adm-bubble.user{background:var(--panel);border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:4px}.adm-msg-time{font-size:10.5px;color:var(--muted-2);margin-top:3px;padding:0 4px}.adm-chat-input-bar{display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--panel);border-top:1px solid var(--line);flex-shrink:0}.adm-chat-input{flex:1;height:40px;padding:0 16px;border-radius:20px;border:1px solid var(--line);background:var(--bg);color:var(--ink);font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s}.adm-chat-input:focus{border-color:var(--pg-blue);box-shadow:0 0 0 3px #43b0f11f}.adm-chat-send{width:40px;height:40px;border-radius:50%;background:var(--pg-blue);color:#fff;border:none;cursor:pointer;display:grid;place-items:center;flex-shrink:0;transition:background .12s,transform .12s}.adm-chat-send:hover:not(:disabled){background:var(--pg-blue-ink);transform:scale(1.06)}.adm-chat-send:disabled{opacity:.4;cursor:default}.adm-chat-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--muted);text-align:center;padding:40px}.adm-chat-empty-icon{width:72px;height:72px;border-radius:50%;background:var(--blue-soft);color:var(--pg-blue);display:grid;place-items:center;margin-bottom:4px}.adm-chat-empty-state h3{margin:0;font-size:18px;font-weight:700;color:var(--ink)}.adm-chat-empty-state p{margin:0;font-size:13px;color:var(--muted);max-width:280px;line-height:1.6}@media (max-width: 768px){.adm-chat-layout{grid-template-columns:1fr}.adm-chat-sidebar.hidden-mobile,.adm-chat-main.hidden-mobile{display:none}.adm-chat-back-btn{display:grid}}@media (min-width: 769px){.adm-chat-back-btn{display:none}.adm-chat-sidebar.hidden-mobile,.adm-chat-main.hidden-mobile{display:flex}}.adm-page{display:grid;grid-template-columns:300px 1fr;height:100vh;overflow:hidden;background:var(--bg)}.adm-sidebar-brand{display:flex;align-items:center;gap:8px;padding:14px 16px 10px;border-bottom:1px solid var(--line);flex-shrink:0}.adm-sidebar-brand-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-family:JetBrains Mono,monospace}.adm-logout-btn{margin-left:auto;background:transparent;border:none;cursor:pointer;color:var(--muted);padding:5px;border-radius:6px;display:grid;place-items:center;transition:background .1s,color .1s}.adm-logout-btn:hover{background:var(--bg);color:var(--ink)}.adm-chat-head-email{font-size:11px;color:var(--muted);margin-top:1px;font-family:JetBrains Mono,monospace}.admin-loading{display:flex;align-items:center;justify-content:center;gap:10px;height:100vh;color:var(--muted);font-size:13px}.admin-login-root{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:24px}.admin-login-card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:36px 32px;box-shadow:var(--shadow-md)}.admin-login-brand{display:flex;justify-content:center;margin-bottom:20px}.admin-login-title{margin:0 0 4px;font-size:20px;font-weight:700;color:var(--ink);text-align:center}.admin-login-sub{margin:0 0 24px;font-size:13px;color:var(--muted);text-align:center}@media (max-width: 768px){.adm-page{grid-template-columns:1fr}}.adm-layout{display:grid;grid-template-columns:220px 1fr;height:100vh;overflow:hidden}.adm-nav{display:flex;flex-direction:column;background:var(--panel);border-right:1px solid var(--line);overflow:hidden}.adm-nav-brand{display:flex;align-items:center;gap:10px;padding:16px 16px 14px;border-bottom:1px solid var(--line);flex-shrink:0}.adm-nav-badge{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:2px 7px;border-radius:20px;background:var(--blue-soft);color:var(--pg-blue-ink);font-family:JetBrains Mono,monospace}.adm-nav-links{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.adm-nav-section-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:8px 8px 6px}.adm-nav-item{display:flex;align-items:center;gap:9px;width:100%;padding:8px 10px;border-radius:7px;border:none;background:transparent;color:var(--ink-3);font-size:13px;cursor:pointer;text-align:left;transition:background .1s,color .1s}.adm-nav-item:hover{background:var(--bg);color:var(--ink)}.adm-nav-item.active{background:var(--pg-blue);color:#fff;font-weight:600}.adm-nav-item.active svg{opacity:1}.adm-nav-item svg{opacity:.7;flex-shrink:0}.adm-nav-footer{padding:12px;border-top:1px solid var(--line);flex-shrink:0}.adm-nav-user{display:flex;align-items:center;gap:9px;padding:10px 10px 8px;background:var(--bg);border-radius:8px;margin-bottom:8px}.adm-nav-avatar{width:32px;height:32px;border-radius:50%;background:var(--pg-blue);color:#fff;font-size:12px;font-weight:700;display:grid;place-items:center;flex-shrink:0}.adm-nav-user-info{min-width:0}.adm-nav-user-role{font-size:12px;font-weight:600;color:var(--ink)}.adm-nav-user-email{font-size:10.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:JetBrains Mono,monospace}.adm-nav-logout{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:7px;border-radius:7px;border:1px solid var(--line);background:transparent;color:var(--pg-red);font-size:12px;cursor:pointer;transition:background .1s,border-color .1s}.adm-nav-logout:hover{background:var(--red-soft);border-color:#fecaca}.adm-main{overflow:auto;background:var(--bg);height:100vh}.adm-main .adm-page{height:100%}.adm-customers-page{padding:28px 32px;max-width:1200px}.adm-customers-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.adm-customers-title{margin:0 0 4px;font-size:20px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:10px}.adm-customers-count{font-size:12px;font-weight:600;padding:2px 9px;border-radius:20px;background:var(--panel-hi);color:var(--muted);border:1px solid var(--line)}.adm-customers-sub{margin:0;font-size:12.5px;color:var(--muted)}.adm-customers-search-wrap{display:flex;align-items:center;gap:8px;height:34px;padding:0 12px;background:var(--panel);border:1px solid var(--line);border-radius:8px;min-width:220px}.adm-customers-search{flex:1;background:transparent;border:none;outline:none;font-size:12.5px;color:var(--ink)}.adm-customers-search::placeholder{color:var(--muted-2)}.adm-customers-table{width:100%;border-collapse:collapse;font-size:13px}.adm-customers-table th{padding:10px 16px;text-align:left;font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);background:var(--panel-hi);border-bottom:1px solid var(--line);white-space:nowrap}.adm-customers-table td{padding:12px 16px;border-bottom:1px solid var(--line-2);vertical-align:middle}.adm-customers-table tbody tr:last-child td{border-bottom:none}.adm-customers-table tbody tr:hover td{background:var(--bg)}.adm-cust-avatar{width:34px;height:34px;border-radius:50%;background:var(--blue-soft);color:var(--pg-blue-ink);font-weight:700;font-size:14px;display:grid;place-items:center;flex-shrink:0}.adm-status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid}.adm-status-badge.active{background:var(--green-soft);color:#065f46;border-color:#6ee7b7}.adm-status-badge.inactive{background:var(--panel-hi);color:var(--muted);border-color:var(--line)}.adm-status-badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor}@media (max-width: 768px){.adm-layout{grid-template-columns:1fr}.adm-nav{display:none}.adm-customers-page{padding:16px}}
