:root{--bg-0: #f4f6fa;--bg-1: #ffffff;--bg-2: #f7f9fc;--border: #e0e6ee;--border-soft: #eef1f6;--text: #1e2936;--text-dim: #4d5970;--text-mute: #8893a8;--accent: #ff960b;--accent-dim: #c46e00;--warn: #ff960b;--crit: #d63450;--good: #0f9d6e;--shadow: 0 1px 2px rgba(30, 41, 54, .04), 0 8px 24px rgba(30, 41, 54, .06)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{background:radial-gradient(1200px 800px at 20% -10%,#ffffff 0%,var(--bg-0) 55%) fixed;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;line-height:1.4}@keyframes piper-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}@keyframes piper-blink{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-2px)}}.piper-root{display:flex;flex-direction:column;height:100vh;overflow:hidden}.piper-root-center{align-items:center;justify-content:center}.piper-loading-hint{color:var(--text-mute);font-size:14px}.piper-login-page{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.piper-login-card{width:100%;max-width:400px;padding:32px 28px;background:var(--bg-1);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}.piper-login-title{margin:0 0 4px;font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--accent-dim)}.piper-login-sub{margin:0 0 24px;font-size:13px;color:var(--text-dim);line-height:1.45}.piper-login-form{display:flex;flex-direction:column;gap:14px}.piper-login-form label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:500;color:var(--text-dim)}.piper-login-form input{padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px}.piper-login-primary{margin-top:4px;padding:10px 16px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer}.piper-login-primary:hover:not(:disabled){background:var(--accent-dim)}.piper-login-primary:disabled{opacity:.6;cursor:wait}.piper-login-reset{font-size:12px;color:var(--accent);text-decoration:none}.piper-login-reset:hover{text-decoration:underline}.piper-login-secondary{width:100%;margin-top:12px;padding:10px 16px;border:1px solid var(--border);border-radius:8px;background:var(--bg-1);font-size:14px;cursor:pointer}.piper-login-secondary:hover{border-color:var(--accent)}.piper-login-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}.piper-login-actions .piper-login-primary,.piper-login-actions .piper-login-secondary{flex:1;min-width:120px;margin-top:0}.piper-login-sms{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-soft)}.piper-recaptcha{display:flex;justify-content:center;margin:12px 0 0;min-height:78px}.piper-login-error{margin:0;font-size:12px;color:var(--crit)}.piper-login-dev{margin-top:20px;padding-top:16px;border-top:1px dashed var(--border);font-size:11px;color:var(--text-mute)}.piper-login-dev input{width:100%;margin:8px 0;padding:6px 8px;border:1px solid var(--border);border-radius:4px}.piper-top-bar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 22px;border-bottom:1px solid var(--border);background:#fff}.piper-top-bar-user{margin-left:auto;display:flex;align-items:flex-start;gap:12px;flex-shrink:0}.piper-top-bar-user-main{display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:0;max-width:min(420px,50vw)}.piper-top-bar-user-meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:8px 12px;font-size:11px;color:var(--text-dim)}.piper-top-bar-datetime{white-space:nowrap}.piper-top-bar-live{font-size:11px}.piper-top-bar-name{font-size:12px;font-weight:500;color:var(--text);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.piper-top-bar-view-link{padding:0;border:none;background:none;font-size:11px;font-weight:600;color:var(--accent);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.piper-top-bar-view-link:hover,.piper-top-bar-view-link.active{color:var(--accent-dim)}.piper-top-bar-signout{padding:6px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg-2);font-size:12px;cursor:pointer;white-space:nowrap}.piper-top-bar-signout:hover{border-color:var(--crit);color:var(--crit)}.piper-company-switcher{position:relative;display:flex;flex-direction:column;gap:6px;min-width:0;max-width:480px}.piper-company-switcher-label{font-size:10px;font-weight:600;color:var(--text-mute);text-transform:uppercase;letter-spacing:.04em}.piper-company-combobox-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--bg-1);font-size:13px;color:var(--text);text-align:left;cursor:pointer}.piper-company-combobox-trigger:hover:not(:disabled){border-color:var(--accent)}.piper-company-combobox-trigger:disabled{opacity:.6;cursor:not-allowed}.piper-company-combobox-trigger-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.piper-company-combobox-chevron{flex-shrink:0;font-size:10px;color:var(--text-mute)}.piper-company-combobox-menu{position:absolute;z-index:50;top:calc(100% + 4px);left:0;right:0;display:flex;flex-direction:column;border:1px solid var(--border);border-radius:8px;background:var(--bg-1);box-shadow:var(--shadow);overflow:hidden}.piper-company-combobox-search-wrap{padding:8px;border-bottom:1px solid var(--border-soft);background:var(--bg-2)}.piper-company-combobox-search{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:6px;font-size:13px;background:#fff;color:var(--text)}.piper-company-combobox-search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #ff960b33}.piper-company-combobox-list{list-style:none;margin:0;padding:4px 0;max-height:240px;overflow-y:auto}.piper-company-combobox-option{display:block;width:100%;padding:8px 12px;border:none;background:transparent;font-size:12px;text-align:left;color:var(--text);cursor:pointer}.piper-company-combobox-option:hover,.piper-company-combobox-option.selected{background:#ff960b1f}.piper-company-combobox-option.selected{font-weight:600}.piper-company-combobox-empty{padding:12px;font-size:12px;color:var(--text-mute);text-align:center}.piper-company-combobox-foot{margin:0;padding:6px 10px;font-size:10px;color:var(--text-mute);border-top:1px solid var(--border-soft);background:var(--bg-2)}.piper-company-switcher-hint{font-size:10px;color:var(--text-mute)}.piper-company-switcher-error{color:var(--crit)}@media(max-width:900px){.piper-app-header{flex-wrap:wrap}.piper-company-switcher{max-width:100%;order:3;width:100%}}.piper-app{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.piper-header{display:flex;align-items:center;justify-content:space-between;padding:10px 22px;border-bottom:1px solid var(--border);background:#fff;flex-shrink:0}.piper-brand{display:flex;align-items:center;gap:14px}.piper-logo{width:32px;height:32px;border-radius:7px;background:linear-gradient(135deg,#ffb347 0%,var(--accent) 60%,#c46e00 100%);display:grid;place-items:center;font-weight:800;color:#fff;font-size:15px;box-shadow:0 4px 12px #ff960b59}.piper-brand-text{line-height:1.1}.piper-name{font-weight:700;letter-spacing:.5px}.piper-sub{font-size:11px;color:var(--text-dim);margin-top:2px}.piper-header-meta{display:flex;align-items:center;gap:18px;font-size:12px;color:var(--text-dim)}.piper-region-pill{background:#fff;border:1px solid var(--border);padding:6px 12px;border-radius:999px;color:var(--text);font-weight:500;display:flex;align-items:center;gap:8px;box-shadow:0 1px 2px #1e29360a}.piper-region-pill:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--good);box-shadow:0 0 8px var(--good)}.piper-ts-block{text-align:right}.piper-live{color:var(--good);font-size:11px;display:flex;align-items:center;gap:6px;justify-content:flex-end}.piper-live:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--good);animation:piper-pulse 1.6s infinite}.piper-main{flex:1;display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:12px;padding:10px 22px 14px;min-height:0;overflow:auto}.piper-banner-error{padding:8px 12px;background:#d6345014;border:1px solid rgba(214,52,80,.25);border-radius:8px;color:var(--crit);font-size:12px}.piper-dashboard-sync-error{flex-shrink:0;margin:8px 22px 0}.piper-auth-error{margin:12px 22px;max-width:720px}.piper-auth-hint{margin-top:8px;color:var(--text-2, #64748b);font-size:11px}.piper-card{background:var(--bg-1);border:1px solid var(--border);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow);display:flex;flex-direction:column;min-height:0;overflow:hidden;position:relative}.piper-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.7}.piper-card-wide{grid-column:span 2}.piper-main-empty{display:flex;align-items:center;justify-content:center}.piper-dashboard-empty{grid-column:1 / -1;margin:0;max-width:420px;text-align:center;color:var(--text-mute);font-size:13px;line-height:1.5}.piper-dashboard-empty strong{color:var(--accent-dim);font-weight:600}.piper-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.piper-card-title{font-size:11px;text-transform:uppercase;letter-spacing:1.4px;color:var(--text-dim);font-weight:600;display:flex;align-items:center;gap:8px}.piper-card-title .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent)}.piper-card-title.warn .dot{background:var(--warn);box-shadow:0 0 6px var(--warn)}.piper-card-title.crit .dot{background:var(--crit);box-shadow:0 0 6px var(--crit)}.piper-card-title.good .dot{background:var(--good);box-shadow:0 0 6px var(--good)}.piper-status-tag{font-size:10px;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.tag-ok{background:#0f9d6e1a;color:var(--good);border:1px solid rgba(15,157,110,.3)}.tag-warn{background:#ff960b1a;color:var(--accent-dim);border:1px solid rgba(255,150,11,.35)}.tag-crit{background:#d634501a;color:var(--crit);border:1px solid rgba(214,52,80,.35)}.piper-horizon-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:10px}.piper-card-wide .piper-horizon-row{grid-template-columns:repeat(5,1fr)}.piper-horizon-cell{background:var(--bg-2);border:1px solid var(--border-soft);border-radius:8px;padding:8px 10px}.piper-horizon-label{font-size:10px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}.piper-horizon-value{font-size:20px;font-weight:700;color:var(--text);line-height:1.1}.piper-horizon-value.warn{color:var(--accent-dim)}.piper-horizon-value.crit{color:var(--crit)}.piper-horizon-value.good{color:var(--good)}.piper-horizon-sub{font-size:10px;color:var(--text-dim);margin-top:2px}.piper-chart-wrap{flex:1;min-height:60px;display:flex;align-items:stretch;gap:12px}.piper-card-plot{min-height:280px}.piper-plot-wrap{flex:1;min-height:220px;width:100%;margin-top:4px}.piper-card-wide .piper-plot-wrap{min-height:280px}.piper-drivers-below{margin-top:8px;flex-direction:row;flex-wrap:wrap;gap:8px 16px}.piper-spark{flex:1;min-height:48px}.piper-spark svg{width:100%;height:100%;display:block}.piper-drivers{list-style:none;margin:0;padding:0;font-size:11px;display:flex;flex-direction:column;gap:4px;min-width:120px}.piper-drivers li{display:flex;justify-content:space-between;color:var(--text-dim);padding:2px 0}.piper-drivers li span:last-child{color:var(--text);font-weight:500}.piper-drivers .row-warn span:last-child{color:var(--accent-dim);font-weight:600}.piper-drivers .row-crit span:last-child{color:var(--crit);font-weight:600}.piper-drivers .row-good span:last-child{color:var(--good);font-weight:600}.piper-mono{font-family:ui-monospace,monospace;font-size:10px}.piper-data-table{width:100%;border-collapse:collapse;font-size:11px;flex:1}.piper-data-table thead th{text-align:left;color:var(--text-mute);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600;border-bottom:1px solid var(--border);padding:6px 8px}.piper-data-table tbody td{padding:7px 8px;border-bottom:1px solid var(--border-soft);color:var(--text)}.piper-card-table{min-height:160px}.piper-tile-unsupported{padding:12px 4px;font-size:12px;color:var(--text-dim);line-height:1.45}.piper-tile-unsupported-hint{margin-top:8px}.piper-tile-unsupported-id{margin-top:10px;font-size:10px}.piper-spec-debug{margin-top:10px;max-height:140px;overflow:auto;font-size:9px;background:var(--surface-2, #f4f6f9);padding:8px;border-radius:6px;border:1px solid var(--border-soft)}.piper-gauge-wrap{display:flex;align-items:center;gap:14px;flex:1}.piper-gauge{position:relative;width:90px;height:90px;flex-shrink:0}.piper-gauge svg{width:100%;height:100%;transform:rotate(-90deg)}.piper-gauge-center{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;text-align:center}.piper-gauge-value{font-size:22px;font-weight:700;color:var(--accent-dim);line-height:1}.piper-gauge-label{font-size:9px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}.piper-footer{flex-shrink:0;padding:6px 22px;border-top:1px solid var(--border);display:flex;justify-content:space-between;color:var(--text-mute);font-size:10px;background:#fff}.piper-footer span b{color:var(--text-dim);font-weight:600}.piper-chat-dock{--piper-chat-tab-width: 42px;--piper-chat-panel-width: 400px;position:fixed;top:0;right:0;height:100vh;z-index:200;display:flex;flex-direction:row;align-items:stretch;transform:translate(calc(100% - var(--piper-chat-tab-width)));transition:transform .28s cubic-bezier(.2,.8,.2,1);pointer-events:none}.piper-chat-dock.open{transform:translate(0)}.piper-chat-dock .piper-chat-toggle,.piper-chat-dock .piper-chat-panel{pointer-events:auto}.piper-chat-toggle{flex-shrink:0;align-self:center;width:var(--piper-chat-tab-width);background:linear-gradient(135deg,#ffb347 0%,var(--accent) 100%);color:#fff;border:none;padding:14px 6px;border-radius:8px 0 0 8px;cursor:pointer;font-size:10px;font-weight:700;letter-spacing:1px;writing-mode:vertical-rl;text-orientation:mixed;box-shadow:-4px 4px 14px #ff960b59;display:flex;align-items:center;justify-content:center;gap:8px}.piper-chat-dock.open .piper-chat-toggle{background:linear-gradient(135deg,var(--accent-dim) 0%,#c46e00 100%)}.piper-chat-toggle:hover{filter:brightness(1.05)}.piper-chat-toggle .pulse{width:6px;height:6px;background:#fff;border-radius:50%;animation:piper-pulse 1.6s infinite}.piper-chat-panel{flex-shrink:0;width:var(--piper-chat-panel-width);height:100vh;background:#fff;border-left:1px solid var(--border);box-shadow:-12px 0 32px #1e29361a;display:flex;flex-direction:column}.piper-chat-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;background:linear-gradient(180deg,rgba(255,150,11,.06) 0%,transparent 100%);flex-shrink:0}.piper-chat-title{display:flex;align-items:center;gap:10px}.piper-chat-logo{width:30px;height:30px;border-radius:6px;background:linear-gradient(135deg,#ffb347 0%,var(--accent) 60%,#c46e00 100%);display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px}.piper-chat-name{font-weight:700;font-size:13px;color:var(--text);line-height:1.1}.piper-chat-sub{font-size:10px;color:var(--text-dim);margin-top:2px}.piper-chat-close{background:transparent;border:1px solid var(--border);color:var(--text-dim);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:16px;line-height:1;display:grid;place-items:center}.piper-chat-close:hover{background:var(--bg-2);color:var(--text)}.piper-chat-error{padding:8px 16px;font-size:11px;color:var(--crit);background:#d634500f;border-bottom:1px solid rgba(214,52,80,.15)}.piper-chat-status{padding:6px 16px;font-size:11px;color:var(--text-2, #64748b);background:#ff960b14;border-bottom:1px solid rgba(255,150,11,.2)}.piper-chat-reconnect{display:block;margin-top:6px;padding:4px 10px;font-size:11px;font-weight:600;border:1px solid var(--accent);border-radius:6px;background:#fff;color:var(--accent);cursor:pointer}.piper-chat-reconnect:hover{background:#ff960b1a}.piper-chat-messages{flex:1;overflow-y:auto;padding:14px 16px;background:var(--bg-0);display:flex;flex-direction:column;gap:10px}.piper-msg{max-width:88%;display:flex;flex-direction:column;gap:3px}.piper-msg-bot{align-self:flex-start}.piper-msg-user{align-self:flex-end;align-items:flex-end}.piper-msg-bubble{padding:9px 12px;border-radius:12px;font-size:12px;line-height:1.45;white-space:pre-wrap}.piper-msg-bot .piper-msg-bubble{background:#fff;border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}.piper-msg-user .piper-msg-bubble{background:linear-gradient(135deg,#ffb347 0%,var(--accent) 100%);color:#fff;border-bottom-right-radius:4px}.piper-msg-time{font-size:9px;color:var(--text-mute);padding:0 4px}.piper-msg-typing{display:inline-flex;gap:4px;align-items:center;background:#fff!important;border:1px solid var(--border)!important}.piper-msg-typing span{width:5px;height:5px;background:var(--text-mute);border-radius:50%;animation:piper-blink 1.2s infinite}.piper-msg-typing span:nth-child(2){animation-delay:.2s}.piper-msg-typing span:nth-child(3){animation-delay:.4s}.piper-chat-suggestions{padding:8px 16px;border-top:1px solid var(--border);background:#fff;display:flex;gap:6px;flex-wrap:wrap;flex-shrink:0}.piper-chip-suggest{font-size:11px;padding:5px 10px;border-radius:999px;border:1px solid var(--border);background:var(--bg-2);color:var(--text-dim);cursor:pointer;transition:all .15s}.piper-chip-suggest:hover:not(:disabled){border-color:var(--accent);color:var(--accent-dim);background:#ff960b0f}.piper-chip-suggest:disabled{opacity:.5;cursor:not-allowed}.piper-chat-input{display:flex;gap:8px;padding:12px 14px 14px;border-top:1px solid var(--border);background:#fff;flex-shrink:0}.piper-chat-input input{flex:1;border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:12px;color:var(--text);background:var(--bg-2);outline:none;font-family:inherit}.piper-chat-input input:focus{border-color:var(--accent);background:#fff}.piper-chat-send{width:36px;height:36px;border-radius:8px;border:none;background:linear-gradient(135deg,#ffb347 0%,var(--accent) 100%);color:#fff;font-size:16px;cursor:pointer;display:grid;place-items:center;box-shadow:0 2px 8px #ff960b4d}.piper-chat-send:hover:not(:disabled){transform:translateY(-1px)}.piper-chat-send:disabled{opacity:.45;cursor:not-allowed}.internal-section{margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid var(--border-soft)}.internal-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.internal-section h3{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--text)}.internal-console,.vorto-console{flex:1;overflow:auto;padding:1rem 22px;background:var(--bg-0)}.vorto-console h2{color:var(--text);font-size:14px}.vorto-console pre{background:var(--bg-1);border:1px solid var(--border);border-radius:8px;padding:12px;color:var(--text)}.vorto-console label{color:var(--text-dim);font-size:12px}.vorto-console input,.vorto-console select{border:1px solid var(--border);border-radius:6px;padding:6px 8px;background:#fff;color:var(--text)}.vorto-console button{border:1px solid var(--border);background:#fff;border-radius:6px;padding:6px 12px;cursor:pointer;color:var(--text)}.vorto-console button:hover{border-color:var(--accent)}.vorto-console .error{color:var(--crit)}.vorto-console .vorto{max-width:900px}.vorto-console label{display:block;margin:10px 0;font-size:12px;color:var(--text-dim)}.vorto-console label select,.vorto-console label input{display:block;width:100%;max-width:520px;margin-top:4px;border:1px solid var(--border);border-radius:6px;padding:6px 8px;background:#fff;color:var(--text)}.vorto-agent-table-wrap{max-height:320px;overflow:auto;margin:12px 0;border:1px solid var(--border);border-radius:8px;background:#fff}.vorto-agent-table{width:100%;border-collapse:collapse;font-size:12px}.vorto-agent-table thead th{position:sticky;top:0;background:var(--bg-2);text-align:left;padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text-dim);font-weight:600}.vorto-agent-table tbody td{padding:7px 10px;border-bottom:1px solid var(--border-soft);cursor:pointer}.vorto-agent-table tbody tr:hover{background:#ff960b0f}.vorto-agent-table tbody tr.selected{background:#ff960b1f}.vorto-agent-table .mono{font-family:ui-monospace,monospace;font-size:10px;color:var(--text-mute)}.vorto-status{color:var(--text-dim);font-size:12px}
