@charset "UTF-8";@tailwind base;@tailwind components;@tailwind utilities;:root{--color-terracotta: 175, 110, 80;--color-olive: 146, 153, 93;--color-ochre: 226, 180, 107;--color-forest: 63, 110, 76;--color-clay: 118, 77, 61;--dust-sage: 170, 193, 181;--dust-sand: 221, 203, 186;--dust-taupe: 191, 182, 170;--hp-warning: 226, 180, 107;--hp-alert: 175, 110, 80;--hp-terracotta-dark: color-mix(in srgb, rgb(var(--color-terracotta)) 72%, rgba(0,0,0,1) 28%);--hp-forest-dark: color-mix(in srgb, rgb(var(--color-forest)) 72%, rgba(0,0,0,1) 28%);--hp-radius-lg: 18px;--hp-radius-md: 14px;--hp-radius-sm: 10px;--hp-pad-card: 12px;--hp-gap-card: 8px;--hp-pad-topline: 10px;--hp-topline-gap: 10px;--hp-font-family: Sora, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans";--page: rgb(242, 240, 238);--page-soft: rgb(var(--dust-taupe));--surface: rgb(255,255,255);--surface-soft: rgb(247, 245, 242);--surface-clay: rgb(250, 249, 248);--card: rgb(250, 249, 248);--ink: rgb(var(--color-clay));--muted: rgb(123, 111, 104);--subtle: rgb(160, 150, 140);--stroke: rgba(var(--color-clay), .15);--stroke-2: rgba(var(--color-clay), .25);--shadow-outer: 0 18px 40px rgba(60, 40, 30, .08);--shadow-tile: 0 12px 26px rgba(60, 40, 30, .06);--grid-dot: rgba(var(--color-clay), .2);--brand: rgb(var(--color-terracotta));--accent: rgb(var(--color-olive));--warn: rgb(var(--color-ochre));--danger: rgb(180, 80, 80);--hp-tab-ink: var(--hp-forest-dark);--bg: var(--page);--bg2: var(--page-soft);--tile: var(--surface)}html[data-hp-surface=glass]{--page: color-mix(in srgb, rgb(var(--dust-sand)) 10%, rgb(255,255,255) 90%);--page-soft: color-mix(in srgb, rgb(var(--dust-taupe)) 22%, rgb(255,255,255) 78%);--surface: rgba(255,255,255,.72);--surface-soft: rgba(255,255,255,.58);--surface-clay: rgba(255,255,255,.78);--card: rgba(255,255,255,.82);--ink: rgba(20,20,22,.92);--muted: rgba(20,20,22,.62);--subtle: rgba(20,20,22,.5);--stroke: rgba(var(--color-clay), .18);--stroke-2: rgba(var(--color-clay), .28);--shadow-outer: 0 18px 40px rgba(0,0,0,.14);--shadow-tile: 0 12px 26px rgba(0,0,0,.1)}html[data-hp-surface=clay]{--page: color-mix(in srgb, rgb(var(--dust-sand)) 18%, rgb(255,255,255) 82%);--page-soft: color-mix(in srgb, rgb(var(--dust-taupe)) 40%, rgb(255,255,255) 60%);--surface: color-mix(in srgb, rgba(var(--dust-sand), .3) 70%, rgba(255,255,255,1));--surface-soft: color-mix(in srgb, rgba(var(--dust-taupe), .22) 65%, rgba(255,255,255,1));--surface-clay: color-mix(in srgb, rgba(var(--dust-sand), .35) 70%, rgba(255,255,255,1));--card: color-mix(in srgb, rgba(var(--dust-sand), .3) 60%, rgba(255,255,255,1));--ink: rgba(28,24,22,.92);--muted: rgba(28,24,22,.64);--subtle: rgba(28,24,22,.52);--stroke: rgba(var(--color-clay), .18);--stroke-2: rgba(var(--color-clay), .28);--shadow-outer: 0 18px 44px rgba(60, 40, 30, .1);--shadow-tile: 0 12px 28px rgba(60, 40, 30, .08)}.dark{color-scheme:dark;--page: #161412;--page-soft: #1c1917;--surface: #201c18;--surface-soft: #282420;--surface-clay: #201c18;--card: #201c18;--ink: #e7e2da;--muted: #a8a29d;--subtle: #78716c;--stroke: rgba(255, 255, 255, .12);--stroke-2: rgba(255, 255, 255, .2);--shadow-outer: 10px 12px 24px rgba(0, 0, 0, .7);--shadow-tile: 6px 8px 18px rgba(0, 0, 0, .55);--grid-dot: #2e3345;--hp-tab-ink: color-mix(in srgb, rgb(var(--color-forest)) 78%, rgba(255,255,255,1) 22%)}html[data-hp-radius=rounded]{--hp-radius-lg: 20px;--hp-radius-md: 16px;--hp-radius-sm: 12px}html[data-hp-radius=strict]{--hp-radius-lg: 12px;--hp-radius-md: 10px;--hp-radius-sm: 8px}html[data-hp-density=comfortable]{--hp-pad-card: 12px;--hp-gap-card: 8px}html[data-hp-density=compact]{--hp-pad-card: 10px;--hp-gap-card: 7px}html[data-hp-density=close]{--hp-pad-card: 8px;--hp-gap-card: 6px}html[data-hp-font=sans]{--hp-font-family: Sora, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial}html[data-hp-font=serif]{--hp-font-family: Fraunces, ui-serif, Georgia, Cambria, "Times New Roman", Times, serif}html,body,#root{height:100%}body{margin:0;color:var(--ink);font-family:var(--hp-font-family);-webkit-font-smoothing:antialiased;background:var(--page)}body.builder-page{overflow:hidden;display:flex;flex-direction:column;background:var(--page)}h1,h2,h3,h4{font-family:Fraunces,ui-serif,Georgia,serif}.crumbs{color:var(--muted);font-size:12px;opacity:.9}.wrap{max-width:1100px;margin:0 auto;padding:0 clamp(14px,3vw,28px) 64px}.bar{display:flex;align-items:center;justify-content:space-between;margin:4px 0 16px}.bar h1{margin:0;font-size:20px;letter-spacing:.2px}.grid{display:grid;gap:14px;grid-template-columns:repeat(12,1fr)}.search{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;border:1px solid var(--stroke);background:var(--surface);color:var(--ink);width:260px}.search input{background:transparent;border:none;outline:none;color:inherit;width:100%}.grid[aria-label=Applications]>*{grid-column:span 3}@media(max-width:1100px){.grid[aria-label=Applications]>*{grid-column:span 6}}@media(max-width:640px){.grid[aria-label=Applications]>*{grid-column:span 12}}.grid[aria-label="Dashboard Metrics"]>*{grid-column:span 3}@media(max-width:1100px){.grid[aria-label="Dashboard Metrics"]>*{grid-column:span 6}}@media(max-width:640px){.grid[aria-label="Dashboard Metrics"]>*{grid-column:span 12}}.tile{display:flex;gap:12px;align-items:center;justify-content:space-between;text-decoration:none;color:inherit;background:var(--surface-clay);border:1px solid var(--stroke);border-radius:var(--hp-radius-lg);padding:14px;box-shadow:var(--shadow-tile);transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease;outline:none;min-height:112px;flex-direction:column}.tile:hover{transform:translateY(-2px);border-color:var(--stroke-2);box-shadow:0 16px 32px #3c281e1f}.tile:focus-visible{box-shadow:0 0 0 3px rgba(var(--color-terracotta),.28)}.grid[aria-label=Applications] .tile{flex-direction:row;min-height:auto}.logo{width:40px;height:40px;border-radius:999px;display:grid;place-items:center;font-size:18px;background:#fff;border:1px solid var(--stroke);flex:0 0 auto}.meta{flex:1 1 auto;min-width:0}.name{font-size:15px;font-weight:600;line-height:1.15}.hint{font-size:12px;color:var(--muted);margin-top:2px}.badge{flex:0 0 auto;font-size:11px;padding:4px 10px;border-radius:999px;border:1px solid var(--stroke);color:var(--subtle);background:var(--surface-soft);align-self:flex-start}.badge.ok{border-color:rgba(var(--color-olive),.3);color:var(--accent);background:rgba(var(--dust-sage),.15)}.badge.err{border-color:rgba(var(--color-clay),.3);color:var(--danger);background:rgba(var(--color-clay),.08)}.kpi{background:var(--surface);border:1px solid var(--stroke);border-radius:var(--hp-radius-lg);box-shadow:var(--shadow-tile);padding:var(--hp-pad-card);display:flex;flex-direction:column;gap:var(--hp-gap-card);position:relative;overflow:visible;min-height:100px;min-width:0}.kpi-content-wrap{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;gap:var(--hp-gap-card)}.kpi-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.kpi-label{font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.delta{font-size:11px;padding:3px 8px;border-radius:999px;border:1px solid var(--stroke);background:var(--card);color:var(--subtle)}.delta.positive{border-color:rgba(var(--color-olive),.4);background:rgba(var(--dust-sage),.2);color:rgb(var(--color-forest))}.delta.negative{border-color:rgba(var(--color-clay),.3);background:rgba(var(--color-clay),.08);color:rgb(var(--color-clay))}.delta.warn{border-color:rgba(var(--color-ochre),.4);background:rgba(var(--dust-sand),.3);color:#a06e28}.kpi-meta-row{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.kpi-value{font-size:20px;line-height:1.1;font-weight:900;letter-spacing:-.02em;color:var(--ink)}.kpi-sub{font-size:11px;color:var(--subtle);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kpi-edit-input{width:100%;border-radius:var(--hp-radius-sm);padding:6px 8px;font-size:11px;outline:none;color:var(--ink);border:1px solid var(--stroke-2);background:var(--surface-soft)}.chart{width:100%;flex:1 1 auto;min-height:56px;display:flex;align-items:stretch;justify-content:stretch;position:relative;overflow:hidden}.kpi>*{min-height:0}.chart svg,.chart>svg{width:100%!important;height:100%!important;display:block;overflow:hidden}.bars{display:flex;align-items:flex-end;gap:6px;height:100%;width:100%;min-height:0}.bars .bar{flex:1;border-radius:6px 6px 0 0;background:linear-gradient(180deg,rgb(var(--color-terracotta)),rgb(var(--color-ochre)));border:1px solid rgba(var(--color-terracotta),.3);height:10px}.chart-donut{width:100%;height:100%;border-radius:50%;background:conic-gradient(var(--color) 0% calc(var(--value) * 1%),var(--card) calc(var(--value) * 1%) 100%);position:relative;display:grid;place-items:center;min-height:0}.chart-donut:before{content:"";position:absolute;width:75%;height:75%;background:var(--surface);border-radius:50%;z-index:1}.kpi-value-in-chart{font-size:20px;font-weight:700;color:var(--ink);position:absolute;z-index:2;top:50%;left:50%;transform:translate(-50%,-50%)}.kpi-tooltip{position:absolute;z-index:80;pointer-events:none;padding:8px 10px;border-radius:var(--hp-radius-md);background:#141416e6;border:1px solid rgba(255,255,255,.16);color:#ffffffeb;font-size:11px;font-weight:800;box-shadow:0 12px 40px #00000059;transform:translate(-50%,-110%);white-space:nowrap}.kpi-tooltip .kpi-tooltip-sub{display:block;margin-top:2px;font-size:10px;font-weight:800;opacity:.75}.kpi-legend{position:absolute;z-index:20;top:6px;right:6px;width:44%;max-width:220px;padding:8px;border-radius:var(--hp-radius-md);background:#141416ad;border:1px solid rgba(255,255,255,.14);pointer-events:none}.kpi-legend-row{display:grid;grid-template-columns:10px 1fr auto;align-items:center;gap:8px;padding:3px 2px;font-size:10px;color:#ffffffd6}.kpi-legend-dot{width:10px;height:10px;border-radius:999px}.kpi-legend-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-legend-val{color:#fffffff0;font-weight:900}.kpi-edit-controls-top{position:absolute;top:-10px;right:-10px;background:var(--card);border:1px solid var(--stroke);border-radius:var(--hp-radius-md);display:flex;align-items:center;gap:4px;padding:4px;z-index:70;box-shadow:0 14px 40px #0000001f;opacity:0;transform:scale(.92);transition:all .18s ease;pointer-events:none}.kpi:hover .kpi-edit-controls-top.visible{opacity:1;transform:scale(1);pointer-events:all}.kpi-move-handle{width:28px;height:28px;display:grid;place-items:center;background:rgba(var(--hp-warning),.14);color:rgb(var(--hp-alert));border-radius:10px;cursor:grab;user-select:none;touch-action:none;border:1px solid rgba(var(--hp-warning),.3)}.kpi-move-handle:active{cursor:grabbing}.kpi-resize-btn{width:24px;height:24px;display:grid;place-items:center;cursor:pointer;color:var(--muted);border-radius:8px;border:1px solid transparent}.kpi-resize-btn:hover{background:#0000000f;border-color:#0000000f;color:var(--ink)}.kpi-divider{width:1px;height:16px;background:#0000001a;margin:0 2px}.kpi-chart-container{position:relative;flex:1 1 auto;min-height:0;overflow:hidden;border-radius:calc(var(--hp-radius-lg) - 6px)}.kpi-chart-container .kpi-chart-host{width:100%;height:100%;min-height:0}.kpi-context-pill{position:absolute;z-index:60;background:var(--card);border:1px solid rgba(var(--color-forest),.3);box-shadow:0 2px 10px #0000001a;padding:4px 10px;border-radius:999px;font-size:10px;font-weight:950;letter-spacing:.06em;color:rgb(var(--color-forest));cursor:pointer;transition:all .2s;opacity:0;transform:translateY(4px);pointer-events:none;display:flex;align-items:center;gap:6px}.kpi:hover .kpi-context-pill{opacity:1;transform:translateY(0);pointer-events:all}.kpi-context-pill:hover,.kpi-context-pill.active{background:rgb(var(--color-forest));color:#fff;border-color:rgba(var(--color-forest),.95);box-shadow:0 10px 28px #0000002e}.kpi-context-pill--type{top:10px;left:10px}.kpi-context-pill--data{top:10px;right:10px}.kpi-context-popover{position:absolute;z-index:200;background:#141416f0;border:1px solid rgba(255,255,255,.15);border-radius:var(--hp-radius-md);padding:8px;width:210px;box-shadow:0 18px 70px #0000008c;display:flex;flex-direction:column;gap:8px}.kpi-context-popover h4{margin:0 0 2px;font-size:10px;text-transform:uppercase;color:#ffffff8c;letter-spacing:.06em}.kpi-pop-row{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:#fff;gap:10px}.kpi-pop-select{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:10px;padding:5px 8px;font-size:11px;outline:none;width:112px}.kpi-pop-select option{background:#333}.kpi-pop-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:30px;height:28px;border-radius:12px;display:grid;place-items:center;cursor:pointer;user-select:none}.kpi-pop-btn:hover{background:#ffffff2e}.kpi-pop-input{flex:1;min-width:0;background:#ffffff14;border:1px solid rgba(255,255,255,.18);color:#ffffffeb;border-radius:12px;padding:8px 10px;font-size:11px;outline:none}.kpi-type-search,.kpi-type-group-title,.kpi-type-item-kind{display:none!important}.kpi-type-list{max-height:168px;overflow-y:auto;padding:10px 4px;border-radius:var(--hp-radius-md);background:#ffffff08;border:1px solid rgba(255,255,255,.1);overscroll-behavior:contain;scrollbar-width:none;-ms-overflow-style:none}.kpi-type-list::-webkit-scrollbar{width:0;height:0}.kpi-edit-controls-top{z-index:220}.kpi-type-item{width:100%;display:flex;justify-content:space-between;align-items:center;gap:10px;margin:0;border:1px solid transparent;background:transparent;padding:8px;border-radius:12px;text-align:left;cursor:pointer}.kpi-type-item:hover{background:#ffffff0f;border-color:#ffffff1a}.kpi-type-item.active{background:#ffffff1a;border:1px solid rgba(var(--hp-warning),.6)}.kpi-type-item-name{font-size:12px;font-weight:950;line-height:1.1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-type-item-action{opacity:.7;font-size:12px}.empty{display:grid;place-items:center;min-height:120px;border:1px dashed var(--stroke);background:var(--surface);border-radius:var(--hp-radius-lg);color:var(--muted)}.hp-content>.grid{display:grid;grid-template-columns:repeat(10,1fr);grid-auto-rows:60px;gap:12px;width:100%;margin:0 auto;padding-bottom:60px;grid-auto-flow:row;position:relative;isolation:isolate}.hp-content>.grid:not(.grid--editable) .grid-background,.hp-content>.grid:not(.grid--editable) .grid-preview-layer{display:none}.grid-background,.grid-preview-layer{position:absolute;inset:0;pointer-events:none;display:grid;grid-template-columns:repeat(10,1fr);grid-auto-rows:60px;gap:12px;padding-bottom:60px}.grid-background{z-index:0}.grid-preview-layer{z-index:3}.grid-cell{border-radius:var(--hp-radius-md);border:1px dashed rgba(var(--dust-taupe),.28);background:#00000003}.grid-preview-rect,.grid-draw-rect{border-radius:var(--hp-radius-lg);display:grid;align-items:start;justify-items:end;overflow:hidden;position:relative}.grid-preview-rect.valid,.grid-draw-rect.valid{background:rgba(var(--color-forest),.1);border:2px dashed rgba(var(--color-forest),.78);box-shadow:0 12px 45px #0000001f}.grid-preview-rect.invalid,.grid-draw-rect.invalid{background:rgba(var(--hp-alert),.1);border:2px dashed rgba(var(--hp-alert),.85);box-shadow:0 12px 45px #0000001f}.grid-preview-rect.adjusted.valid{background:rgba(var(--hp-warning),.12);border-color:rgba(var(--hp-warning),.85)}.grid-preview-rect.swap.valid{background:rgba(var(--color-olive),.14);border-color:rgba(var(--color-olive),.95)}.grid-preview-rect.push.valid{background:rgba(var(--color-forest),.12);border-color:rgba(var(--color-forest),.78)}.grid-preview-label{margin:10px;font-size:11px;font-weight:850;letter-spacing:.08em;padding:6px 10px;border-radius:999px;background:#141416bf;color:#ffffffeb;border:1px solid rgba(255,255,255,.14)}.hp-content>.grid>.kpi{z-index:2}.kpi.kpi--swap-target,.kpi.kpi--push-target{z-index:18;transform:scale(1.01)}.kpi.kpi--swap-target{box-shadow:0 0 0 3px rgba(var(--color-olive),.55),0 20px 60px #00000026}.kpi.kpi--push-target{box-shadow:0 0 0 3px rgba(var(--color-forest),.55),0 20px 60px #00000026}body.hp-drag-active{cursor:grabbing}body.hp-draw-active{cursor:crosshair}.btn{font-size:13px;font-weight:700;padding:8px 14px;border:1px solid transparent;border-radius:999px;cursor:pointer;transition:background .12s ease,box-shadow .12s ease,transform .12s ease;background:var(--surface-soft);color:var(--ink)}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background:var(--brand);color:#fff;border-color:rgba(var(--color-terracotta),.35);box-shadow:0 10px 24px #af6e5047}.btn-secondary{background:rgba(var(--dust-sage),.22);color:rgb(var(--color-forest));border-color:rgba(var(--color-olive),.3)}.hp-compact-btn{padding:6px 12px;font-size:11px}.fab{position:fixed;right:22px;bottom:22px;width:56px;height:56px;border-radius:50%;border:1px solid var(--stroke);background:var(--surface);color:var(--ink);font-size:28px;line-height:56px;text-align:center;cursor:pointer;box-shadow:var(--shadow-outer)}.fab:hover{transform:translateY(-1px)}#addDialog{width:min(560px,92vw);border:1px solid var(--stroke);border-radius:var(--hp-radius-lg);padding:0;background:var(--surface);color:var(--ink);box-shadow:var(--shadow-outer)}#addDialog::backdrop{background:#0006}#addDialog .modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--stroke)}#addDialog .modal-body{padding:14px 16px}#addDialog .list{display:grid;grid-template-columns:1fr;gap:10px}#addDialog .opt{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--stroke);border-radius:12px;background:var(--surface-soft);cursor:pointer}#addDialog .opt .logo{width:28px;height:28px;border-radius:6px;font-size:14px}.hartprism-app{height:100vh;width:100%;background:var(--page);overflow:hidden}.builder-layout{--hp-sidebar-w: 260px;height:100%;width:100%;display:flex;min-height:0;min-width:0}.builder-layout.is-nav-collapsed{--hp-sidebar-w: 0px}.hp-sidebar{flex:0 0 var(--hp-sidebar-w);width:var(--hp-sidebar-w);min-width:var(--hp-sidebar-w);max-width:var(--hp-sidebar-w);border-right:1px solid var(--stroke);background:var(--surface);padding:16px 12px;display:flex;flex-direction:column;gap:18px;height:100%;overflow-y:auto;overflow-x:hidden;transition:flex-basis .3s cubic-bezier(.25,.1,.25,1),width .3s cubic-bezier(.25,.1,.25,1),min-width .3s cubic-bezier(.25,.1,.25,1),max-width .3s cubic-bezier(.25,.1,.25,1),padding .2s ease,opacity .2s ease,border-color .2s ease}.hp-sidebar.is-collapsed{padding:0;border-right-color:transparent;opacity:0;pointer-events:none}.hp-main{flex:1 1 auto;min-width:0;min-height:0;display:flex;flex-direction:column;background:var(--page)}.hp-main-shell{display:flex;flex-direction:column;height:100%;min-height:0}.account-switcher-wrapper{position:relative;border-radius:12px}.sidebar-banner-img{border-radius:12px;border:1px solid var(--stroke);display:block}.account-switch-icon{position:absolute;top:6px;right:6px;background:transparent;border:none;padding:4px;border-radius:50%;color:var(--muted);cursor:pointer;transition:all .1s ease-out}.account-switch-icon:hover{background:#00000014;color:var(--ink)}.account-switch-icon svg{display:block}.account-switcher-dropdown{position:absolute;top:calc(100% + 4px);left:0;width:100%;background:var(--surface);border:1px solid var(--stroke);border-radius:12px;box-shadow:var(--shadow-outer);padding:8px;z-index:100;display:flex;flex-direction:column;gap:4px}.account-choice-label{font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);padding:4px 8px 6px}.account-choice{display:flex;align-items:center;width:100%;padding:6px;border-radius:8px;border:1px solid transparent;background:transparent;text-align:left;cursor:pointer}.account-choice:hover{background:var(--card);border-color:var(--stroke)}.account-choice.active{background:var(--brand);border-color:var(--brand);color:#fff}.account-choice.active span{color:#fff;font-weight:700}.account-choice-logo{width:40px;height:40px;border-radius:6px;border:1px solid var(--stroke);object-fit:cover;margin-right:10px;flex-shrink:0}.account-choice.active .account-choice-logo{border-color:#ffffff80}.account-choice span{font-size:13px;font-weight:600;color:var(--ink)}.hp-sidebar-label{font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);padding:0 6px}.hp-nav{display:flex;flex-direction:column;gap:4px}.hp-nav-item{display:flex;align-items:center;gap:10px;width:100%;border-radius:999px;border:1px solid transparent;padding:8px 10px;background:transparent;color:var(--muted);font-size:11px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease,transform .12s ease}.hp-nav-item:hover{background:var(--card);border-color:var(--stroke);transform:translate(1px)}.hp-nav-item-active{color:rgb(var(--color-clay));border-color:rgba(var(--color-terracotta),.4);background:var(--surface-soft);box-shadow:0 10px 24px #3c281e14}.hp-nav-pill{width:9px;height:9px;border-radius:999px;border:1px solid rgba(var(--color-clay),.3);background:var(--surface-soft);flex-shrink:0}.hp-nav-item-active .hp-nav-pill{background:var(--brand);border-color:var(--brand);box-shadow:0 0 0 4px rgba(var(--color-terracotta),.2)}.hp-nav-text{white-space:nowrap}.hp-sidebar-footer{margin-top:auto;padding:10px 6px 4px;border-top:1px solid var(--stroke)}.hp-sidebar-caption{font-size:11px;color:var(--muted);margin-bottom:6px}.hp-sidebar-chip{font-size:11px;padding:6px 10px;border-radius:999px;border:1px solid var(--stroke);display:inline-flex;align-items:center;gap:6px;background:var(--card)}.hp-sidebar-chip-ok{border-color:rgba(var(--color-olive),.3);background:rgba(var(--dust-sage),.15);color:var(--accent)}.hp-sidebar-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(var(--color-olive),.2)}.hp-topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 10px;border-bottom:1px solid var(--stroke);background:var(--surface);z-index:5}.hp-topbar-left{display:flex;flex-direction:column;gap:4px}.hp-topbar-right{display:flex;gap:8px}.hp-page-tabs{display:flex;align-items:center;gap:6px;padding:6px 20px;border-bottom:1px solid var(--stroke);background:var(--surface);z-index:4}.hp-page-tab{border-radius:999px;border:1px solid transparent;padding:6px 12px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;background:transparent;color:var(--hp-tab-ink);cursor:pointer;display:inline-flex;align-items:center;gap:6px}.hp-page-tab:hover{border-color:var(--stroke);background:var(--card)}.hp-page-tab-active,.hp-page-tab.active,.hp-page-tab[aria-selected=true]{color:rgb(var(--color-clay));border-color:rgba(var(--color-terracotta),.3);background:var(--surface-soft);box-shadow:0 0 0 1px rgba(var(--color-terracotta),.1)}.hp-content{flex:1 1 auto;min-height:0;padding:18px 20px 24px;overflow:auto}.hp-toggle-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.hp-panel{border-radius:var(--hp-radius-lg);border:1px solid var(--stroke);background:var(--surface-clay);box-shadow:var(--shadow-tile);padding:14px}.hp-panel-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.hp-panel-head h3{margin:0;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.hp-list-meta{font-size:11px;color:var(--muted)}.hp-soul-topline{display:flex;align-items:center;gap:var(--hp-topline-gap);padding:var(--hp-pad-topline) 8px 0;position:relative;z-index:50}.hp-topline-icon{width:34px;height:34px;border-radius:var(--hp-radius-md);border:1px solid var(--stroke);background:var(--surface);color:var(--ink);display:grid;place-items:center;cursor:pointer;user-select:none;box-shadow:var(--shadow-tile);transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.hp-topline-icon:hover{transform:translateY(-1px);border-color:var(--stroke-2);background:var(--surface-soft);box-shadow:var(--shadow-outer)}.hp-topline-icon:active{transform:translateY(0) scale(.98)}.hp-topline-icon.is-active{background:rgba(var(--color-forest),.22);border-color:rgba(var(--color-forest),.5);color:#ffffffeb}.hp-topline-icon.is-warn{background:rgba(var(--hp-warning),.22);border-color:rgba(var(--hp-warning),.48);color:#fffffff2}.hp-topline-tabs{flex:1 1 auto;min-width:0;display:flex;align-items:center;overflow:hidden}.hp-topline-tabs.hp-page-tabs{margin:0!important;padding:0!important;min-width:0;flex:1 1 auto;display:flex;align-items:center;gap:6px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.hp-topline-tabs.hp-page-tabs::-webkit-scrollbar{width:0;height:0}.hp-topline-tabs.hp-page-tabs .hp-page-tab:not(.hp-page-tab-active):not(.active):not([aria-selected=true]){color:var(--hp-forest-dark)}.hp-filter-summary{padding:6px 8px 0;display:flex;gap:6px;flex-wrap:wrap;align-items:center}.hp-filter-summary-pill{display:inline-flex;align-items:center;gap:6px;margin:1px;padding:3px 8px;border-radius:999px;border:1px solid rgba(var(--color-forest),.55);background:rgba(var(--color-forest),.12);color:var(--hp-terracotta-dark);font-size:11px;font-weight:900;letter-spacing:.01em}.hp-filter-summary-pill .k{opacity:.82;font-weight:950}.hp-filter-summary-pill button{width:18px;height:18px;border-radius:999px;border:1px solid rgba(0,0,0,.1);background:#0000000f;color:#141416cc;display:grid;place-items:center;cursor:pointer;padding:0}.hp-overlay-root{position:fixed;inset:0;z-index:10000;pointer-events:none}.hp-popover{position:fixed;width:min(620px,calc(100vw - 24px));z-index:10001;pointer-events:auto;border-radius:var(--hp-radius-lg);background:#141416eb;border:1px solid rgba(255,255,255,.16);box-shadow:0 34px 140px #0000008c;padding:10px;color:#ffffffeb}.hp-popover-title{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 6px 10px}.hp-popover-title .hp-popover-h{font-size:11px;font-weight:950;letter-spacing:.08em;text-transform:uppercase;color:#ffffffb8}.hp-mini-icon-btn{width:34px;height:34px;border-radius:var(--hp-radius-md);border:1px solid rgba(255,255,255,.14);background:#ffffff0f;color:#ffffffeb;box-shadow:0 18px 60px #00000038;display:grid;place-items:center;cursor:pointer;user-select:none}.hp-mini-icon-btn:hover{background:#ffffff1a;border-color:#fff3}.hp-mini-icon-btn:active{transform:scale(.98)}.hp-theme-wheel{border-radius:999px;border:1px solid rgba(255,255,255,.2);flex-shrink:0;background-color:var(--surface-soft);box-shadow:0 0 0 1px #00000014;transition:transform .1s ease}.hp-theme-row{width:100%;display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;border-radius:14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);cursor:pointer;text-align:left;color:#ffffffeb}.hp-theme-row:hover{background:#ffffff1a;border-color:#ffffff40}.hp-theme-row.active{background:rgba(var(--color-terracotta),.2);border-color:rgba(var(--color-terracotta),.6);box-shadow:0 8px 30px #ffffff14}.hp-theme-row-left{display:flex;align-items:center;gap:12px}.hp-theme-row-name{font-size:13px;font-weight:900}.hp-theme-row-desc{font-size:11px;opacity:.75}.hp-theme-row-wheels{display:flex;align-items:center;gap:8px}.hp-theme-row-preview{display:flex;align-items:center;gap:6px}.hp-pill-mini{font-size:9px;font-weight:950;padding:3px 6px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d}.hp-pill-mini.warn{border-color:rgba(var(--hp-warning),.4);background:rgba(var(--hp-warning),.1);color:rgb(var(--hp-warning))}.hp-pill-mini.alert{border-color:rgba(var(--hp-alert),.4);background:rgba(var(--hp-alert),.1);color:rgb(var(--hp-alert))}.hp-mini-surface{width:14px;height:14px;border-radius:4px;border:1px solid rgba(255,255,255,.2)}.hp-mini-surface.light{background:#fff}.hp-theme-controls{padding:10px 6px;margin-top:10px;display:flex;flex-wrap:wrap;gap:16px;border-top:1px solid rgba(255,255,255,.12)}.hp-theme-controls>div{display:flex;flex-direction:column;gap:4px}.hp-theme-controls .label{font-size:10px;text-transform:uppercase;opacity:.7;font-weight:800}.hp-toggle{padding:5px 10px;border-radius:999px;font-size:11px;font-weight:800;cursor:pointer;transition:all .2s ease;border:1px solid rgba(255,255,255,.18);background:#ffffff0d;color:#ffffffdb;text-transform:capitalize}.hp-toggle:hover{background:#ffffff1a;border-color:#ffffff42;color:#fffffffa}.hp-toggle.active{background:rgba(var(--color-terracotta),.4);border-color:rgba(var(--color-terracotta),.78);color:#fffffff5}.hp-filter-gutter{display:flex;align-items:center;gap:16px;padding:8px;flex-wrap:wrap}.hp-filter-group{display:flex;flex-direction:column;gap:6px}.hp-filter-label{font-size:10px;text-transform:uppercase;opacity:.7;font-weight:800}.hp-date-inputs{display:flex;align-items:center;gap:6px;background:#ffffff0f;border:1px solid rgba(255,255,255,.14);padding:4px 6px;border-radius:var(--hp-radius-sm)}.hp-filter-input{background:transparent;border:none;font-family:inherit;font-size:12px;outline:none;color:#ffffffeb;color-scheme:dark}.hp-filter-pills{display:flex;gap:6px;flex-wrap:wrap}.hp-filter-pill{appearance:none;border-radius:999px;padding:6px 10px;font-size:11px;font-weight:850;cursor:pointer;transition:all .2s ease;border:1px solid rgba(255,255,255,.18);background:#ffffff0d;color:#ffffffdb}.hp-filter-pill:hover{background:#ffffff1a;border-color:#ffffff42;color:#fffffffa}.hp-filter-pill.active{background:rgba(var(--color-forest),.4);border-color:rgba(var(--color-forest),.78);color:#fffffff5}@media(max-width:780px){.hartprism-app{height:auto;overflow:visible}.builder-layout{flex-direction:column;height:auto}.hp-sidebar{width:100%;min-width:100%;max-width:100%;flex-basis:auto;height:auto;overflow:visible;border-right:none;border-bottom:1px solid var(--stroke);opacity:1!important;pointer-events:auto!important;padding:16px 12px!important}.hp-main{min-height:60vh}.hp-topbar,.hp-content{padding-inline:14px}}.kpi-config-overlay{position:absolute;inset:8px;z-index:120;border-radius:var(--hp-radius-lg);background:#141416f0;border:1px solid rgba(255,255,255,.16);box-shadow:0 18px 70px #00000073;display:flex;flex-direction:column;overflow:hidden}.kpi-config-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 10px 8px;border-bottom:1px solid rgba(255,255,255,.12)}.kpi-config-title{font-size:11px;font-weight:950;letter-spacing:.08em;text-transform:uppercase;color:#ffffffc7;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-config-close{width:32px;height:32px;display:grid;place-items:center;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:#ffffff14;color:#ffffffeb;cursor:pointer}.kpi-config-close:hover{background:#ffffff1f;border-color:#ffffff38}.kpi-config-close:active{transform:scale(.98)}.kpi-config-body{flex:1 1 auto;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding:10px;display:flex;flex-direction:column;gap:10px;scrollbar-width:none;-ms-overflow-style:none}.kpi-config-body::-webkit-scrollbar{width:0;height:0}.kpi-config-row{display:grid;grid-template-columns:minmax(110px,1fr) minmax(140px,1.2fr);gap:10px;align-items:center;padding:8px;border-radius:14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.12)}.kpi-config-name{font-size:11px;font-weight:900;color:#ffffffd6;letter-spacing:.02em;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-config-control{min-width:0}.kpi-config-overlay .kpi-pop-select,.kpi-config-overlay .kpi-pop-input{width:100%!important;max-width:100%;height:34px;border-radius:12px}@media(max-width:420px){.kpi-config-row{grid-template-columns:1fr}}.hp-popover,.grid-preview-label,.kpi-config-overlay,.hp-modal{background:#141416eb;border:1px solid rgba(255,255,255,.16);color:#ffffffeb}@layer components{.tile{background:var(--surface-clay);border:1px solid var(--stroke);border-radius:var(--hp-radius-lg);box-shadow:var(--shadow-tile);transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}.tile:hover{transform:translateY(-2px);border-color:var(--stroke-2)}.tile{display:flex;gap:12px;align-items:center;justify-content:space-between;padding:14px;min-height:112px;flex-direction:column;color:inherit;text-decoration:none;outline:none}.tile:hover{box-shadow:0 16px 32px #3c281e1f}.tile:focus-visible{box-shadow:0 0 0 3px rgba(var(--color-terracotta),.28)}.grid[aria-label=Applications] .tile{flex-direction:row;min-height:auto}.logo{width:40px;height:40px;display:grid;place-items:center;border-radius:999px;border:1px solid var(--stroke);background:#fff;color:var(--ink);font-size:18px;flex:0 0 auto}.meta{flex:1 1 auto;min-width:0}.name{font-size:15px;font-weight:600;line-height:1.15}.hint{font-size:12px;color:var(--muted);margin-top:2px}.badge{border-radius:999px;border:1px solid var(--stroke);background:var(--surface-soft);align-self:flex-start;flex:0 0 auto;font-size:11px;padding:4px 10px;color:var(--subtle)}.badge.ok{border-color:rgba(var(--color-olive),.3);color:var(--accent);background:rgba(var(--dust-sage),.15)}.badge.err{border-color:rgba(var(--color-clay),.3);color:var(--danger);background:rgba(var(--color-clay),.08)}.kpi{background:var(--surface);border:1px solid var(--stroke);border-radius:var(--hp-radius-lg);box-shadow:var(--shadow-tile);backdrop-filter:var(--kpi-backdrop-filter);-webkit-backdrop-filter:var(--kpi-backdrop-filter);padding:var(--hp-pad-card);display:flex;flex-direction:column;gap:var(--hp-gap-card);position:relative;overflow:visible;min-height:100px;min-width:0}.kpi>*{min-height:0}.kpi-content-wrap{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;gap:var(--hp-gap-card)}.kpi-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.kpi-label{font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.delta{border-radius:999px;border:1px solid var(--stroke);background:var(--card);font-size:11px;padding:3px 8px;color:var(--subtle)}.delta.positive{border-color:rgba(var(--color-olive),.4);background:rgba(var(--dust-sage),.2);color:rgb(var(--color-forest))}.delta.negative{border-color:rgba(var(--color-clay),.3);background:rgba(var(--color-clay),.08);color:rgb(var(--color-clay))}.delta.warn{border-color:rgba(var(--color-ochre),.4);background:rgba(var(--dust-sand),.3);color:#a06e28}.kpi-meta-row{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.kpi-value{font-size:20px;line-height:1.1;font-weight:900;letter-spacing:-.02em;color:var(--ink)}.kpi-sub{font-size:11px;color:var(--subtle);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-edit-input{width:100%;border-radius:var(--hp-radius-sm);padding:6px 8px;font-size:11px;outline:none;color:var(--ink);border:1px solid var(--stroke-2);background:var(--surface-soft)}.chart,.kpi-chart{width:100%;flex:1 1 auto;min-height:56px;min-width:0;display:flex;align-items:stretch;justify-content:stretch;position:relative;overflow:hidden}.chart>svg,.kpi-chart>svg{position:absolute;inset:0;width:100%!important;height:100%!important;display:block;overflow:hidden}.kpi-chart-controls{position:absolute;inset:0;z-index:50;pointer-events:none}.kpi-chart-controls>*{pointer-events:auto}.bars{display:flex;align-items:flex-end;gap:6px;height:100%;width:100%;min-height:0}.bars .bar{flex:1;border-radius:6px 6px 0 0;border:1px solid rgba(var(--color-terracotta),.3);height:10px;background:linear-gradient(180deg,rgb(var(--color-terracotta)),rgb(var(--color-ochre)))}.chart-donut{width:100%;height:100%;border-radius:50%;background:conic-gradient(var(--color) 0% calc(var(--value) * 1%),var(--card) calc(var(--value) * 1%) 100%);position:relative;display:grid;place-items:center;min-height:0}.chart-donut:before{content:"";position:absolute;width:75%;height:75%;background:var(--surface);border-radius:50%;z-index:1}.kpi-value-in-chart{font-size:20px;font-weight:700;color:var(--ink);position:absolute;z-index:2;top:50%;left:50%;transform:translate(-50%,-50%)}.kpi-tooltip{position:absolute;z-index:80;pointer-events:none;padding:8px 10px;border-radius:var(--hp-radius-md);background:#141416e6;border:1px solid rgba(255,255,255,.16);color:#ffffffeb;font-size:11px;font-weight:800;box-shadow:0 12px 40px #00000059;transform:translate(-50%,-110%);white-space:nowrap}.kpi-tooltip .kpi-tooltip-sub{display:block;margin-top:2px;font-size:10px;font-weight:800;opacity:.75}.kpi-legend{position:absolute;z-index:20;top:6px;right:6px;width:44%;max-width:220px;padding:8px;border-radius:var(--hp-radius-md);background:#141416ad;border:1px solid rgba(255,255,255,.14);pointer-events:none}.kpi-legend-row{display:grid;grid-template-columns:10px 1fr auto;align-items:center;gap:8px;padding:3px 2px;font-size:10px;color:#ffffffd6}.kpi-legend-dot{width:10px;height:10px;border-radius:999px}.kpi-legend-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-legend-val{color:#fffffff0;font-weight:900}.kpi-edit-controls-top{position:absolute;top:-10px;right:-10px;background:var(--card);border:1px solid var(--stroke);border-radius:var(--hp-radius-md);box-shadow:0 14px 40px #0000001f;display:flex;align-items:center;gap:4px;padding:4px;z-index:220;opacity:0;transform:scale(.92);transition:all .18s ease;pointer-events:none}.kpi:hover .kpi-edit-controls-top.visible{opacity:1;transform:scale(1);pointer-events:all}.kpi-move-handle{width:28px;height:28px;display:grid;place-items:center;border-radius:10px;border:1px solid rgba(var(--hp-warning),.3);background:rgba(var(--hp-warning),.14);color:rgb(var(--hp-alert));cursor:grab;user-select:none;touch-action:none}.kpi-move-handle:active{cursor:grabbing}.kpi-resize-btn{width:24px;height:24px;display:grid;place-items:center;cursor:pointer;color:var(--muted);border-radius:8px;border:1px solid transparent}.kpi-resize-btn:hover{background:#0000000f;border-color:#0000000f;color:var(--ink)}.kpi-divider{width:1px;height:16px;background:#0000001a;margin:0 2px}.kpi-chart-container{position:relative;flex:1 1 auto;min-height:0;overflow:hidden;border-radius:calc(var(--hp-radius-lg) - 6px)}.kpi-chart-container .kpi-chart-host{width:100%;height:100%;min-height:0}.kpi-context-pill{position:absolute;z-index:60;border-radius:999px;border:1px solid rgba(var(--color-forest),.3);background:var(--card);box-shadow:0 2px 10px #0000001a;padding:4px 10px;font-size:10px;font-weight:950;letter-spacing:.06em;color:rgb(var(--color-forest));cursor:pointer;transition:all .2s;opacity:0;transform:translateY(4px);pointer-events:none;display:flex;align-items:center;gap:6px}.kpi-context-pill:hover,.kpi-context-pill.active{background:rgb(var(--color-forest));color:#fff;border-color:rgba(var(--color-forest),.95);box-shadow:0 10px 28px #0000002e}.kpi-context-pill--type{top:calc(var(--plot-top) + var(--plot-pill-inset));left:calc(var(--plot-left) + var(--plot-pill-inset))}.kpi-context-pill--data{top:calc(var(--plot-top) + var(--plot-pill-inset));left:calc(var(--plot-right) - var(--plot-pill-inset));transform:translate(-100%)}.kpi-context-pill--edit{top:calc(var(--plot-bottom) - var(--plot-pill-inset));left:calc(var(--plot-left) + var(--plot-pill-inset));transform:translateY(-100%)}.kpi-context-pill--settings{top:calc(var(--plot-bottom) - var(--plot-pill-inset));left:calc(var(--plot-right) - var(--plot-pill-inset));transform:translate(-100%,-100%)}.kpi:hover .kpi-context-pill{opacity:1;transform:translateY(0);pointer-events:all}.kpi:hover .kpi-context-pill--data{transform:translate(-100%) translateY(0)}.kpi:hover .kpi-context-pill--edit{transform:translateY(-100%) translateY(0)}.kpi:hover .kpi-context-pill--settings{transform:translate(-100%) translateY(-100%) translateY(0)}.kpi-pop-row{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:#fff;gap:10px}.kpi-pop-select{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:10px;padding:5px 8px;font-size:11px;outline:none;width:112px}.kpi-pop-select option{background:#333}.kpi-pop-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:30px;height:28px;border-radius:12px;display:grid;place-items:center;cursor:pointer;user-select:none}.kpi-pop-btn:hover{background:#ffffff2e}.kpi-pop-input{flex:1;min-width:0;background:#ffffff14;border:1px solid rgba(255,255,255,.18);color:#ffffffeb;border-radius:12px;padding:8px 10px;font-size:11px;outline:none}.kpi-type-search,.kpi-type-group-title,.kpi-type-item-kind{display:none!important}.kpi-type-list{max-height:168px;overflow-y:auto;padding:10px 4px;border-radius:var(--hp-radius-md);background:#ffffff08;border:1px solid rgba(255,255,255,.1);overscroll-behavior:contain;scrollbar-width:none;-ms-overflow-style:none}.kpi-type-list::-webkit-scrollbar{width:0;height:0}.kpi-type-item{width:100%;display:flex;justify-content:space-between;align-items:center;gap:10px;margin:0;border:1px solid transparent;background:transparent;padding:8px;border-radius:12px;text-align:left;cursor:pointer}.kpi-type-item:hover{background:#ffffff0f;border-color:#ffffff1a}.kpi-type-item.active{background:#ffffff1a;border-color:rgba(var(--hp-warning),.6)}.kpi-type-item-name{font-size:12px;font-weight:950;line-height:1.1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-type-item-action{opacity:.7;font-size:12px}.empty{display:grid;place-items:center;min-height:120px;border:1px dashed var(--stroke);background:var(--surface);border-radius:var(--hp-radius-lg);color:var(--muted)}.hp-content>.grid{display:grid;grid-template-columns:repeat(10,1fr);grid-auto-rows:60px;gap:12px;width:100%;margin:0 auto;padding-bottom:60px;grid-auto-flow:row;position:relative;isolation:isolate}.hp-content>.grid:not(.grid--editable) .grid-background,.hp-content>.grid:not(.grid--editable) .grid-preview-layer{display:none}.hp-content>.grid>.kpi{z-index:2}.grid-background,.grid-preview-layer{position:absolute;inset:0;pointer-events:none;display:grid;grid-template-columns:repeat(10,1fr);grid-auto-rows:60px;gap:12px;padding-bottom:60px}.grid-background{z-index:0}.grid-preview-layer{z-index:3}.grid-cell{border-radius:var(--hp-radius-md);border:1px dashed rgba(var(--dust-taupe),.28);background:#00000003}.grid-preview-rect,.grid-draw-rect{border-radius:var(--hp-radius-lg);display:grid;align-items:start;justify-items:end;overflow:hidden;position:relative}.grid-preview-rect.valid,.grid-draw-rect.valid{background:rgba(var(--color-forest),.1);border:2px dashed rgba(var(--color-forest),.78);box-shadow:0 12px 45px #0000001f}.grid-preview-rect.invalid,.grid-draw-rect.invalid{background:rgba(var(--hp-alert),.1);border:2px dashed rgba(var(--hp-alert),.85);box-shadow:0 12px 45px #0000001f}.grid-preview-rect.adjusted.valid{background:rgba(var(--hp-warning),.12);border-color:rgba(var(--hp-warning),.85)}.grid-preview-rect.swap.valid{background:rgba(var(--color-olive),.14);border-color:rgba(var(--color-olive),.95)}.grid-preview-rect.push.valid{background:rgba(var(--color-forest),.12);border-color:rgba(var(--color-forest),.78)}.grid-preview-label{margin:10px;font-size:11px;font-weight:850;letter-spacing:.08em;padding:6px 10px;border-radius:999px;border-color:#ffffff24;background:#141416bf}.kpi.kpi--swap-target,.kpi.kpi--push-target{z-index:18;transform:scale(1.01)}.kpi.kpi--swap-target{box-shadow:0 0 0 3px rgba(var(--color-olive),.55),0 20px 60px #00000026}.kpi.kpi--push-target{box-shadow:0 0 0 3px rgba(var(--color-forest),.55),0 20px 60px #00000026}body.hp-drag-active{cursor:grabbing}body.hp-draw-active{cursor:crosshair}.kpi-config-overlay{position:absolute;inset:8px;z-index:120;border-radius:var(--hp-radius-lg);box-shadow:0 18px 70px #00000073;display:flex;flex-direction:column;overflow:hidden}.kpi-config-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 10px 8px;border-bottom:1px solid rgba(255,255,255,.12)}.kpi-config-title{font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:#ffffffc7;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-config-close{width:32px;height:32px;display:grid;place-items:center;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:#ffffff14;color:#ffffffeb;cursor:pointer}.kpi-config-close:hover{background:#ffffff1f;border-color:#ffffff38}.kpi-config-close:active{transform:scale(.98)}.kpi-config-body{flex:1 1 auto;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding:10px;display:flex;flex-direction:column;gap:10px;scrollbar-width:none;-ms-overflow-style:none}.kpi-config-body::-webkit-scrollbar{width:0;height:0}.kpi-config-row{display:grid;grid-template-columns:minmax(110px,1fr) minmax(140px,1.2fr);gap:10px;align-items:center;padding:8px;border-radius:14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.12)}.kpi-config-name{font-size:11px;font-weight:900;color:#ffffffd6;letter-spacing:.02em;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-config-control{min-width:0}.kpi-config-overlay .kpi-pop-select,.kpi-config-overlay .kpi-pop-input{width:100%!important;max-width:100%;height:34px;border-radius:12px}@media(max-width:420px){.kpi-config-row{grid-template-columns:1fr}}.hp-overlay-root{position:fixed;inset:0;z-index:9999;pointer-events:none}.hp-overlay-root>*{pointer-events:auto}.hp-modal-backdrop{position:fixed;inset:0;background:#0000006b;backdrop-filter:blur(4px);z-index:9999}.hp-modal{position:fixed;z-index:10000;left:50%;top:10vh;transform:translate(-50%);width:min(860px,100vw - 24px);max-height:min(78vh,860px);border-radius:var(--hp-radius-lg);overflow:hidden;border-color:#ffffff26;box-shadow:0 18px 70px #0009;display:flex;flex-direction:column}.hp-modal--sm{width:min(520px,100vw - 24px)}.hp-modal--lg{width:min(980px,100vw - 24px)}.hp-modal__head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 12px 10px;border-bottom:1px solid rgba(255,255,255,.12);background:#1414168c;backdrop-filter:blur(8px)}.hp-modal__title{font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:#ffffffd1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hp-modal__body{flex:1 1 auto;min-height:0;overflow:auto;padding:12px;overscroll-behavior:contain}@media(max-width:420px){.hp-modal{top:8px;width:calc(100vw - 16px);max-height:calc(100vh - 16px)}}}@layer components{.hp-toggle-row,.search{display:flex;align-items:center;gap:8px}.search input{background:transparent;border:none;outline:none;color:inherit}.wrap{max-width:1100px;margin:0 auto;padding:0 clamp(14px,3vw,28px) 64px}.bar{display:flex;align-items:center;justify-content:space-between;margin:4px 0 16px}.bar h1{margin:0;font-size:20px;letter-spacing:.2px}.grid{display:grid;gap:14px;grid-template-columns:repeat(12,1fr)}.search{background:var(--surface);border:1px solid var(--stroke);border-radius:12px;box-shadow:none;padding:10px 12px;width:260px;color:var(--ink)}.search input{width:100%}.grid[aria-label=Applications]>*{grid-column:span 3}@media(max-width:1100px){.grid[aria-label=Applications]>*{grid-column:span 6}}@media(max-width:640px){.grid[aria-label=Applications]>*{grid-column:span 12}}.grid[aria-label="Dashboard Metrics"]>*{grid-column:span 3}@media(max-width:1100px){.grid[aria-label="Dashboard Metrics"]>*{grid-column:span 6}}@media(max-width:640px){.grid[aria-label="Dashboard Metrics"]>*{grid-column:span 12}}.btn{border-radius:999px;border:1px solid transparent;background:var(--surface-soft);font-size:13px;font-weight:700;padding:8px 14px;cursor:pointer;transition:background .12s ease,box-shadow .12s ease,transform .12s ease;color:var(--ink)}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background:var(--brand);color:#fff;border-color:rgba(var(--color-terracotta),.35);box-shadow:0 10px 24px #af6e5047}.btn-secondary{background:rgba(var(--dust-sage),.22);color:rgb(var(--color-forest));border-color:rgba(var(--color-olive),.3)}.hp-compact-btn{padding:6px 12px;font-size:11px}.fab{position:fixed;right:22px;bottom:22px;width:56px;height:56px;background:var(--surface);border:1px solid var(--stroke);border-radius:50%;box-shadow:var(--shadow-outer);color:var(--ink);font-size:28px;line-height:56px;text-align:center;cursor:pointer}.fab:hover{transform:translateY(-1px)}#addDialog{width:min(560px,92vw);background:var(--surface);border:1px solid var(--stroke);border-radius:var(--hp-radius-lg);box-shadow:var(--shadow-outer);padding:0;color:var(--ink)}#addDialog::backdrop{background:#0006}#addDialog .modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--stroke)}#addDialog .modal-body{padding:14px 16px}#addDialog .list{display:grid;grid-template-columns:1fr;gap:10px}#addDialog .opt{background:var(--surface-soft);border:1px solid var(--stroke);border-radius:12px;box-shadow:none;display:flex;align-items:center;gap:12px;padding:12px;cursor:pointer}#addDialog .opt .logo{width:28px;height:28px;border-radius:6px;font-size:14px}.hartprism-app{height:100vh;width:100%;background:var(--page);overflow:hidden}.builder-layout{--hp-sidebar-w: 260px;height:100%;width:100%;display:flex;min-height:0;min-width:0}.builder-layout.is-nav-collapsed{--hp-sidebar-w: 0px}.hp-sidebar{flex:0 0 var(--hp-sidebar-w);width:var(--hp-sidebar-w);min-width:var(--hp-sidebar-w);max-width:var(--hp-sidebar-w);border-right:1px solid var(--stroke);background:var(--surface);padding:16px 12px;display:flex;flex-direction:column;gap:18px;height:100%;overflow-y:auto;overflow-x:hidden;transition:flex-basis .3s cubic-bezier(.25,.1,.25,1),width .3s cubic-bezier(.25,.1,.25,1),min-width .3s cubic-bezier(.25,.1,.25,1),max-width .3s cubic-bezier(.25,.1,.25,1),padding .2s ease,opacity .2s ease,border-color .2s ease}.hp-sidebar.is-collapsed{padding:0;border-right-color:transparent;opacity:0;pointer-events:none}.hp-main{flex:1 1 auto;min-width:0;min-height:0;display:flex;flex-direction:column;background:var(--page)}.hp-main-shell{display:flex;flex-direction:column;height:100%;min-height:0}.account-switcher-wrapper{position:relative;border-radius:12px}.sidebar-banner-img{border-radius:12px;border:1px solid var(--stroke);display:block}.account-switch-icon{position:absolute;top:6px;right:6px;background:transparent;border:none;padding:4px;border-radius:50%;color:var(--muted);cursor:pointer;transition:all .1s ease-out}.account-switch-icon:hover{background:#00000014;color:var(--ink)}.account-switch-icon svg{display:block}.account-switcher-dropdown{position:absolute;top:calc(100% + 4px);left:0;width:100%;background:var(--surface);border:1px solid var(--stroke);border-radius:12px;box-shadow:var(--shadow-outer);padding:8px;z-index:100;display:flex;flex-direction:column;gap:4px}.account-choice-label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:4px 8px 6px}.account-choice{display:flex;align-items:center;width:100%;padding:6px;border-radius:8px;border:1px solid transparent;background:transparent;text-align:left;cursor:pointer}.account-choice:hover{background:var(--card);border-color:var(--stroke)}.account-choice.active{background:var(--brand);border-color:var(--brand);color:#fff}.account-choice.active span{color:#fff;font-weight:700}.account-choice span{font-size:13px;font-weight:600;color:var(--ink)}.account-choice-logo{width:40px;height:40px;border-radius:6px;border:1px solid var(--stroke);object-fit:cover;margin-right:10px;flex-shrink:0}.account-choice.active .account-choice-logo{border-color:#ffffff80}.hp-sidebar-label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:0 6px}.hp-nav{display:flex;flex-direction:column;gap:4px}.hp-nav-item{display:flex;align-items:center;gap:10px;width:100%;border-radius:999px;border:1px solid transparent;padding:8px 10px;background:transparent;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease,transform .12s ease}.hp-nav-item:hover{background:var(--card);border-color:var(--stroke);transform:translate(1px)}.hp-nav-item-active{color:rgb(var(--color-clay));border-color:rgba(var(--color-terracotta),.4);background:var(--surface-soft);box-shadow:0 10px 24px #3c281e14}.hp-nav-item-active .hp-nav-pill{background:var(--brand);border-color:var(--brand);box-shadow:0 0 0 4px rgba(var(--color-terracotta),.2)}.hp-nav-pill{width:9px;height:9px;border-radius:999px;border:1px solid rgba(var(--color-clay),.3);background:var(--surface-soft);flex-shrink:0}.hp-nav-text{white-space:nowrap}.hp-sidebar-footer{margin-top:auto;padding:10px 6px 4px;border-top:1px solid var(--stroke)}.hp-sidebar-caption{font-size:11px;color:var(--muted);margin-bottom:6px}.hp-sidebar-chip{border-radius:999px;border:1px solid var(--stroke);background:var(--card);font-size:11px;padding:6px 10px;display:inline-flex;align-items:center;gap:6px}.hp-sidebar-chip-ok{border-color:rgba(var(--color-olive),.3);background:rgba(var(--dust-sage),.15);color:var(--accent)}.hp-sidebar-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(var(--color-olive),.2)}.hp-topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 10px;border-bottom:1px solid var(--stroke);background:var(--surface);z-index:5}.hp-topbar-left{display:flex;flex-direction:column;gap:4px}.hp-topbar-right{display:flex;gap:8px}.hp-page-tabs{display:flex;align-items:center;gap:6px;padding:6px 20px;border-bottom:1px solid var(--stroke);background:var(--surface);z-index:4}.hp-page-tab{border-radius:999px;border:1px solid transparent;padding:6px 12px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;background:transparent;color:var(--hp-tab-ink);cursor:pointer;display:inline-flex;align-items:center;gap:6px}.hp-page-tab:hover{border-color:var(--stroke);background:var(--card)}.hp-page-tab-active,.hp-page-tab.active,.hp-page-tab[aria-selected=true]{color:rgb(var(--color-clay));border-color:rgba(var(--color-terracotta),.3);background:var(--surface-soft);box-shadow:0 0 0 1px rgba(var(--color-terracotta),.1)}.hp-content{flex:1 1 auto;min-height:0;padding:18px 20px 24px;overflow:auto}.hp-toggle-row{flex-wrap:wrap}.hp-panel{background:var(--surface-clay);border:1px solid var(--stroke);border-radius:var(--hp-radius-lg);box-shadow:var(--shadow-tile);padding:14px}.hp-panel-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.hp-panel-head h3{margin:0;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.hp-list-meta{font-size:11px;color:var(--muted)}.hp-soul-topline{display:flex;align-items:center;gap:var(--hp-topline-gap);padding:var(--hp-pad-topline) 8px 0;position:relative;z-index:50}.hp-topline-icon{width:34px;height:34px;border-radius:var(--hp-radius-md);border:1px solid var(--stroke);background:var(--surface);color:var(--ink);display:grid;place-items:center;cursor:pointer;user-select:none;box-shadow:var(--shadow-tile);transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.hp-topline-icon:hover{transform:translateY(-1px);border-color:var(--stroke-2);background:var(--surface-soft);box-shadow:var(--shadow-outer)}.hp-topline-icon:active{transform:translateY(0) scale(.98)}.hp-topline-icon.is-active{background:rgba(var(--color-forest),.22);border-color:rgba(var(--color-forest),.5);color:#ffffffeb}.hp-topline-icon.is-warn{background:rgba(var(--hp-warning),.22);border-color:rgba(var(--hp-warning),.48);color:#fffffff2}.hp-topline-tabs{flex:1 1 auto;min-width:0;display:flex;align-items:center;overflow:hidden}.hp-topline-tabs.hp-page-tabs{margin:0!important;padding:0!important;min-width:0;flex:1 1 auto;gap:6px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.hp-topline-tabs.hp-page-tabs::-webkit-scrollbar{width:0;height:0}.hp-topline-tabs.hp-page-tabs .hp-page-tab:not(.hp-page-tab-active):not(.active):not([aria-selected=true]){color:var(--hp-forest-dark)}.hp-filter-summary{padding:6px 8px 0;display:flex;gap:6px;flex-wrap:wrap;align-items:center}.hp-filter-summary-pill{display:inline-flex;align-items:center;gap:6px;margin:1px;padding:3px 8px;border-radius:999px;border:1px solid rgba(var(--color-forest),.55);background:rgba(var(--color-forest),.12);color:var(--hp-terracotta-dark);font-size:11px;font-weight:900;letter-spacing:.01em}.hp-filter-summary-pill .k{opacity:.82;font-weight:950}.hp-filter-summary-pill button{width:18px;height:18px;border-radius:999px;border:1px solid rgba(0,0,0,.1);background:#0000000f;color:#141416cc;display:grid;place-items:center;cursor:pointer;padding:0}.hp-overlay-root{position:fixed;inset:0;z-index:10000;pointer-events:none}.hp-popover{position:fixed;width:min(620px,100vw - 24px);z-index:10001;pointer-events:auto;border-radius:var(--hp-radius-lg);box-shadow:0 34px 140px #0000008c;padding:10px}.hp-popover-title{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 6px 10px}.hp-popover-title .hp-popover-h{font-size:11px;font-weight:950;letter-spacing:.08em;text-transform:uppercase;color:#ffffffb8}.hp-mini-icon-btn{width:34px;height:34px;display:grid;place-items:center;border-radius:var(--hp-radius-md);border:1px solid rgba(255,255,255,.14);background:#ffffff0f;color:#ffffffeb;box-shadow:0 18px 60px #00000038;cursor:pointer;user-select:none}.hp-mini-icon-btn:hover{background:#ffffff1a;border-color:#fff3}.hp-mini-icon-btn:active{transform:scale(.98)}.hp-theme-wheel{border-radius:999px;border:1px solid rgba(255,255,255,.2);flex-shrink:0;background-color:var(--surface-soft);box-shadow:0 0 0 1px #00000014;transition:transform .1s ease}.hp-theme-row{width:100%;display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;border-radius:14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);cursor:pointer;text-align:left;color:#ffffffeb}.hp-theme-row:hover{background:#ffffff1a;border-color:#ffffff40}.hp-theme-row.active{background:rgba(var(--color-terracotta),.2);border-color:rgba(var(--color-terracotta),.6);box-shadow:0 8px 30px #ffffff14}.hp-theme-row-left{display:flex;align-items:center;gap:12px}.hp-theme-row-name{font-size:13px;font-weight:900}.hp-theme-row-desc{font-size:11px;opacity:.75}.hp-theme-row-wheels,.hp-theme-row-preview{display:flex;align-items:center;gap:8px}.hp-theme-row-preview{gap:6px}.hp-pill-mini{font-size:9px;font-weight:950;padding:3px 6px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d}.hp-pill-mini.warn{border-color:rgba(var(--hp-warning),.4);background:rgba(var(--hp-warning),.1);color:rgb(var(--hp-warning))}.hp-pill-mini.alert{border-color:rgba(var(--hp-alert),.4);background:rgba(var(--hp-alert),.1);color:rgb(var(--hp-alert))}.hp-mini-surface{width:14px;height:14px;border-radius:4px;border:1px solid rgba(255,255,255,.2)}.hp-mini-surface.light{background:#fff}.hp-theme-controls{padding:10px 6px;margin-top:10px;display:flex;flex-wrap:wrap;gap:16px;border-top:1px solid rgba(255,255,255,.12)}.hp-theme-controls>div{display:flex;flex-direction:column;gap:4px}.hp-theme-controls .label{font-size:10px;text-transform:uppercase;opacity:.7;font-weight:800}.hp-toggle{padding:5px 10px;border-radius:999px;font-size:11px;font-weight:800;cursor:pointer;transition:all .2s ease;border:1px solid rgba(255,255,255,.18);background:#ffffff0d;color:#ffffffdb;text-transform:capitalize}.hp-toggle:hover{background:#ffffff1a;border-color:#ffffff42;color:#fffffffa}.hp-toggle.active{background:rgba(var(--color-terracotta),.4);border-color:rgba(var(--color-terracotta),.78);color:#fffffff5}.hp-filter-gutter{display:flex;align-items:center;gap:16px;padding:8px;flex-wrap:wrap}.hp-filter-group{display:flex;flex-direction:column;gap:6px}.hp-filter-label{font-size:10px;text-transform:uppercase;opacity:.7;font-weight:800}.hp-date-inputs{display:flex;align-items:center;gap:6px;background:#ffffff0f;border:1px solid rgba(255,255,255,.14);padding:4px 6px;border-radius:var(--hp-radius-sm)}.hp-filter-input{background:transparent;border:none;font-family:inherit;font-size:12px;outline:none;color:#ffffffeb;color-scheme:dark}.hp-filter-pills{display:flex;gap:6px;flex-wrap:wrap}.hp-filter-pill{appearance:none;border-radius:999px;padding:6px 10px;font-size:11px;font-weight:850;cursor:pointer;transition:all .2s ease;border:1px solid rgba(255,255,255,.18);background:#ffffff0d;color:#ffffffdb}.hp-filter-pill:hover{background:#ffffff1a;border-color:#ffffff42;color:#fffffffa}.hp-filter-pill.active{background:rgba(var(--color-forest),.4);border-color:rgba(var(--color-forest),.78);color:#fffffff5}@media(max-width:780px){.hartprism-app{height:auto;overflow:visible}.builder-layout{flex-direction:column;height:auto}.hp-sidebar{width:100%;min-width:100%;max-width:100%;flex-basis:auto;height:auto;overflow:visible;border-right:none;border-bottom:1px solid var(--stroke);opacity:1!important;pointer-events:auto!important;padding:16px 12px!important}.hp-main{min-height:60vh}.hp-topbar,.hp-content{padding-inline:14px}}}
