@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;touch-action:none}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.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__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray: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.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.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:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{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:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.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.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@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;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.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-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.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:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.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-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.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:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));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:var(--xy-resize-background-color, var(--xy-resize-background-color-default));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%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}.vp-builder-shell{min-height:100vh;background:#07111f;color:#eef4ff;padding:18px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.vp-builder-topbar{display:flex;justify-content:space-between;gap:18px;align-items:center;margin-bottom:18px}.vp-builder-topbar h1{margin:0;font-size:26px}.vp-builder-topbar p,.vp-phone-stage-header p{margin:4px 0 0;color:#9aa8bf}.vp-builder-controls{display:flex;gap:10px;align-items:center}.vp-builder-controls select,.vp-builder-controls button,.vp-form input,.vp-form select,.vp-page-controls button,.vp-toggle-btn{background:#101b2b;border:1px solid #24324a;color:#eef4ff;border-radius:10px;padding:10px 12px}.vp-builder-controls button{background:linear-gradient(135deg,#2563eb,#7c3aed);cursor:pointer;border:0;font-weight:700}.vp-builder-grid{display:grid;grid-template-columns:285px minmax(720px,1fr) 315px;gap:14px}.vp-actions-panel,.vp-phone-stage-card,.vp-properties-panel{background:#0c1828f5;border:1px solid #20304a;border-radius:16px;box-shadow:0 20px 70px #00000047}.vp-actions-panel,.vp-properties-panel{padding:18px}.vp-actions-panel h2,.vp-properties-panel h2{margin:0 0 4px;font-size:17px}.vp-actions-panel p{color:#9aa8bf;margin:0;font-size:13px}.vp-action-group{margin-top:18px}.vp-action-group h3{color:#9aa8bf;font-size:12px;text-transform:uppercase;letter-spacing:.06em;margin:0 0 8px}.vp-action-chip{width:100%;display:flex;gap:10px;align-items:center;background:#111d2f;border:1px solid #24324a;color:#eef4ff;padding:11px 12px;border-radius:10px;margin-bottom:8px;cursor:grab;text-align:left}.vp-action-chip:hover,.vp-action-chip.active{border-color:#6d5dfc;background:#17243a}.vp-phone-stage-card{padding:16px}.vp-phone-stage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:12px}.vp-phone-stage-header h2{margin:0;font-size:20px}.vp-stage-stats{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.vp-badge{border:1px solid rgba(124,58,237,.45);color:#c7b6ff;background:#7c3aed1f;padding:7px 10px;border-radius:999px;font-size:12px}.vp-badge.configured{border-color:#22c55e59;color:#bbf7d0;background:#22c55e1a}.vp-badge.empty{border-color:#2dd4bf59;color:#99f6e4;background:#2dd4bf14}.vp-toggle-btn{cursor:pointer;font-size:12px;padding:8px 11px}.vp-toggle-btn.is-on{border-color:#38bdf899;color:#bff7ff;background:#082f49b3}.vp-phone-stage{position:relative;width:100%;aspect-ratio:4 / 3;overflow:hidden;background:radial-gradient(circle at 50% 38%,rgba(45,212,191,.12),rgba(37,99,235,.04) 30%,transparent 58%),linear-gradient(180deg,#040b16,#071325);border:1px solid #20304a;border-radius:14px;isolation:isolate}.vp-screen-guide{position:absolute;z-index:2;border:1px dashed rgba(56,189,248,.24);border-radius:10px;box-shadow:inset 0 0 0 1px #38bdf80f}.vp-phone-image-wrap{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;display:grid;place-items:center}.vp-phone-image{width:100%;height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;filter:drop-shadow(0 18px 28px rgba(0,0,0,.42))}.vp-phone-page-indicator{position:absolute;left:50%;top:2.5%;transform:translate(-50%);z-index:8;padding:7px 12px;border-radius:999px;background:#0f172adb;border:1px solid rgba(148,163,184,.35);color:#e5edff;font-size:12px;font-weight:700;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.vp-slot{position:absolute;display:flex;align-items:center;gap:5px;justify-content:flex-start;overflow:hidden;border-radius:8px;padding:2px 7px;font-size:clamp(10px,.78vw,13px);line-height:1.05;cursor:pointer;z-index:12;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease,transform .12s ease}.vp-slot:hover{transform:translateY(-1px)}.vp-slot.line,.vp-slot.touch-dss,.vp-slot.expansion{background:#031826b8;border:1.6px dashed rgba(45,212,191,1);box-shadow:inset 0 0 0 1px #0891b22e,0 0 10px #22d3ee1a}.vp-slot.line:before,.vp-slot.touch-dss:before,.vp-slot.expansion:before{content:"";width:6px;height:6px;border-radius:999px;background:#22c55e;box-shadow:0 0 8px #22c55e8c;flex:0 0 auto}.vp-slot.soft,.vp-slot.page-control{justify-content:center;background:#1f293773;border:1.5px dashed rgba(167,139,250,.78)}.vp-slot.assigned{border-style:solid;border-color:#22c55efa;background:#056046f5;box-shadow:0 0 0 1px #22c55e4d,0 0 18px #22c55e38}.vp-slot.assigned:before{background:#86efac;box-shadow:0 0 9px #86efacbf}.vp-slot.selected{border-color:#facc15;box-shadow:0 0 0 2px #facc1547,0 0 24px #facc1529}.vp-slot-icon{flex:0 0 auto}.vp-slot-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:760;text-shadow:0 1px 2px rgba(0,0,0,.45)}.vp-slot-empty{opacity:1;font-weight:760;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#8be9ff;text-shadow:0 1px 1px rgba(0,0,0,.35)}.vp-page-controls{display:flex;gap:8px;justify-content:center;align-items:center;margin-top:14px}.vp-page-controls button{cursor:pointer}.vp-page-controls button.active{background:linear-gradient(135deg,#2563eb,#7c3aed);border-color:transparent}.vp-page-controls button:disabled{opacity:.45;cursor:not-allowed}.vp-button-map-table{margin-top:14px;background:#091426;border:1px solid #20304a;border-radius:14px;overflow:hidden}.vp-button-map-table h3{margin:0;padding:13px 14px;border-bottom:1px solid #20304a}.vp-button-map-table table{width:100%;border-collapse:collapse;font-size:13px}.vp-button-map-table th,.vp-button-map-table td{padding:10px 12px;border-bottom:1px solid rgba(32,48,74,.7);text-align:left}.vp-button-map-table th{color:#9aa8bf;font-size:12px}.vp-button-map-table button{background:transparent;border:1px solid #334155;color:#fca5a5;border-radius:8px;padding:6px 9px;cursor:pointer}.vp-form{display:grid;gap:13px}.vp-form label{display:grid;gap:6px;color:#9aa8bf;font-size:12px}.vp-form input,.vp-form select{width:100%;box-sizing:border-box}.vp-form .danger{background:#ef44441a;color:#fecaca;border:1px solid rgba(239,68,68,.35);border-radius:10px;padding:11px;cursor:pointer}.vp-empty-state,.vp-tip{color:#9aa8bf;background:#101b2b;border:1px solid #24324a;border-radius:12px;padding:14px;font-size:13px}.vp-tip{margin-top:16px;color:#bfdbfe;border-color:#2563eb73}@media (max-width: 1180px){.vp-builder-grid{grid-template-columns:1fr}}.vp-slot[style]{min-height:16px}.vp-slot.line{min-width:58px}.vp-slot.touch-dss{min-width:72px;min-height:18px;background:#031826c7}.vp-slot.expansion{min-width:78px;min-height:18px}.vp-slot.page-control,.vp-slot.soft{min-height:16px}.vp-slot.empty.line,.vp-slot.empty.touch-dss,.vp-slot.empty.expansion{background:#041f30c2;outline:1px solid rgba(15,23,42,.35)}.vp-slot.empty .vp-slot-empty{letter-spacing:.01em}.vp-phone-image{filter:drop-shadow(0 18px 28px rgba(0,0,0,.42)) drop-shadow(0 0 1px rgba(255,255,255,.1))}.vp-phone-stage{background:radial-gradient(circle at 50% 38%,rgba(45,212,191,.1),rgba(37,99,235,.03) 30%,transparent 58%),linear-gradient(180deg,#030914,#071325)}.vp-slot.line,.vp-slot.touch-dss,.vp-slot.expansion{border-radius:999px;padding:1px 8px;justify-content:flex-start}.vp-slot.line:before,.vp-slot.touch-dss:before,.vp-slot.expansion:before{width:7px;height:7px}.vp-slot.empty.line,.vp-slot.empty.touch-dss,.vp-slot.empty.expansion{background:#062132c7;border-width:1.7px}.vp-slot.assigned.line,.vp-slot.assigned.touch-dss,.vp-slot.assigned.expansion{background:#065d40f5}.vp-slot-text,.vp-slot-empty{font-size:clamp(10px,.75vw,12px)}.vp-slot.line,.vp-slot.touch-dss,.vp-slot.expansion{border-radius:999px;padding:1px 7px;justify-content:flex-start}.vp-slot.empty.line,.vp-slot.empty.touch-dss,.vp-slot.empty.expansion{background:#062132c2}.vp-slot.assigned.line,.vp-slot.assigned.touch-dss,.vp-slot.assigned.expansion{background:#056644f5}.vp-slot-text,.vp-slot-empty{font-size:clamp(9px,.74vw,11.6px)}.vp-screen-guide{z-index:2;border-color:#38bdf82e}.vp-screen-mask{position:absolute;z-index:4;border-radius:8px;overflow:hidden;pointer-events:none;box-shadow:inset 0 0 0 1px #ffffff0a}.vp-screen-mask .vp-screen-statusbar{top:0;height:12%;opacity:.95}.vp-screen-mask .vp-screen-contentwash{top:12%;bottom:15%}.vp-screen-mask .vp-screen-softbar{bottom:0;height:15%;opacity:.98}.vp-screen-mask.mono-light{background:linear-gradient(180deg,#edf2f6,#dfe7ec)}.vp-screen-mask.mono-light .vp-screen-statusbar{background:linear-gradient(180deg,#e4ebf0fa,#d6dfe6fa);border-bottom:1px solid rgba(102,119,136,.18)}.vp-screen-mask.mono-light .vp-screen-contentwash{background:linear-gradient(180deg,#f8fafc2e,#d6e0e81a),repeating-linear-gradient(180deg,transparent 0 22%,rgba(113,128,150,.06) 22% 23%,transparent 23% 46%)}.vp-screen-mask.mono-light .vp-screen-softbar{background:linear-gradient(180deg,#dbe3e8,#cfd8df);border-top:1px solid rgba(102,119,136,.16)}.vp-screen-mask.business-color{background:linear-gradient(180deg,#0f4e86,#0b3053 45%,#0d3e5f)}.vp-screen-mask.business-color .vp-screen-statusbar{background:linear-gradient(180deg,#0a2e4cf2,#0d4061e6)}.vp-screen-mask.business-color .vp-screen-contentwash{background:radial-gradient(circle at 55% 70%,rgba(34,211,238,.18),transparent 28%),linear-gradient(180deg,#12507e47,#05192c14)}.vp-screen-mask.business-color .vp-screen-softbar{background:linear-gradient(180deg,#0a2a46fa,#071e32fa);border-top:1px solid rgba(255,255,255,.05)}.vp-screen-mask.executive-touch{background:linear-gradient(180deg,#0a3b6b,#082846 38%,#0b3652)}.vp-screen-mask.executive-touch .vp-screen-statusbar{background:linear-gradient(180deg,#092746f5,#0a385ceb)}.vp-screen-mask.executive-touch .vp-screen-contentwash{background:radial-gradient(circle at 52% 72%,rgba(34,211,238,.2),transparent 25%),linear-gradient(180deg,#0f568e24,#071d300d)}.vp-screen-mask.executive-touch .vp-screen-softbar{background:linear-gradient(180deg,#08223afa,#05192afa);border-top:1px solid rgba(255,255,255,.06)}.vp-screen-mask.expansion-dark{background:linear-gradient(180deg,#163042,#0b1e2c)}.vp-screen-mask.expansion-dark .vp-screen-statusbar{background:linear-gradient(180deg,#112d40fa,#0d2130fa)}.vp-screen-mask.expansion-dark .vp-screen-contentwash{background:repeating-linear-gradient(180deg,#ffffff05 0,#ffffff05 9%,#fff0 9%,#fff0 10%)}.vp-screen-mask.expansion-dark .vp-screen-softbar{background:linear-gradient(180deg,#0a1924fa,#07121afa)}.vp-screen-mask{z-index:5}.vp-slot.line,.vp-slot.touch-dss,.vp-slot.expansion{border-radius:999px;padding:1px 6px;justify-content:flex-start}.vp-slot-text,.vp-slot-empty{font-size:clamp(9px,.68vw,11px)}.vp-screen-guide{z-index:2;border-color:#38bdf829}.vp-screen-mask{position:absolute;z-index:5;border-radius:8px;overflow:hidden;pointer-events:none;box-shadow:inset 0 0 0 1px #ffffff0a}.vp-key-lane-mask{position:absolute;z-index:8;border-radius:12px;pointer-events:none;background:linear-gradient(180deg,#0e2e49f5,#0a2236f7);box-shadow:inset 0 0 0 1px #ffffff08}.vp-screen-mask .vp-screen-statusbar,.vp-screen-mask .vp-screen-contentwash,.vp-screen-mask .vp-screen-softbar{position:absolute;left:0;right:0}.vp-screen-mask .vp-screen-statusbar{top:0;height:12%;opacity:1}.vp-screen-mask .vp-screen-contentwash{top:12%;bottom:15%;opacity:1}.vp-screen-mask .vp-screen-softbar{bottom:0;height:15%;opacity:1}.vp-screen-mask.mono-light{background:#e8eef3}.vp-screen-mask.mono-light .vp-screen-statusbar{background:#dde5eb;border-bottom:1px solid rgba(102,119,136,.16)}.vp-screen-mask.mono-light .vp-screen-contentwash{background:linear-gradient(180deg,#f1f5f8,#e1e8ee)}.vp-screen-mask.mono-light .vp-screen-softbar{background:#d5dee5;border-top:1px solid rgba(102,119,136,.14)}.vp-screen-mask.business-color{background:#0c3b67}.vp-screen-mask.business-color .vp-screen-statusbar{background:#0d416f}.vp-screen-mask.business-color .vp-screen-contentwash{background:linear-gradient(180deg,#0f4f86,#0d3152)}.vp-screen-mask.business-color .vp-screen-softbar{background:#0a2c49;border-top:1px solid rgba(255,255,255,.05)}.vp-screen-mask.executive-touch{background:#09365f}.vp-screen-mask.executive-touch .vp-screen-statusbar{background:#0a3f6d}.vp-screen-mask.executive-touch .vp-screen-contentwash{background:linear-gradient(180deg,#0d4a80,#0a2c48)}.vp-screen-mask.executive-touch .vp-screen-softbar{background:#082742;border-top:1px solid rgba(255,255,255,.05)}.vp-screen-mask.expansion-dark{background:#102534}.vp-screen-mask.expansion-dark .vp-screen-statusbar{background:#163244}.vp-screen-mask.expansion-dark .vp-screen-contentwash{background:linear-gradient(180deg,#17394f,#102534)}.vp-screen-mask.expansion-dark .vp-screen-softbar{background:#0d1f2c}.vp-slot{z-index:13}.vp-slot.line,.vp-slot.touch-dss,.vp-slot.expansion{border-radius:999px;padding:1px 5px;justify-content:flex-start}.vp-slot.line:before,.vp-slot.touch-dss:before,.vp-slot.expansion:before{width:6px;height:6px;margin-right:2px}.vp-slot-text,.vp-slot-empty{font-size:clamp(8px,.64vw,10.5px)}.vp-key-lane-mask{background:linear-gradient(180deg,#082034fc,#061828fc);box-shadow:inset 0 0 0 1px #ffffff05}.vp-slot.line,.vp-slot.touch-dss,.vp-slot.expansion{border-radius:999px;padding:1px 5px;justify-content:flex-start;min-height:12px}.vp-slot.line:before,.vp-slot.touch-dss:before,.vp-slot.expansion:before{width:5px;height:5px;margin-right:2px}.vp-slot-text,.vp-slot-empty{font-size:clamp(7px,.58vw,9.5px);letter-spacing:-.01em}.vp-slot.empty.line,.vp-slot.empty.touch-dss,.vp-slot.empty.expansion{background:#051826d6}.vp-slot.assigned.line,.vp-slot.assigned.touch-dss,.vp-slot.assigned.expansion{background:#03653ef5}.vp-phone-stage:not(.show-calibration) .vp-screen-guide{opacity:0}.vp-phone-stage.show-calibration .vp-screen-guide{opacity:1}.vp-phone-stage:not(.show-calibration) .vp-key-lane-mask{opacity:1}.vp-phone-stage.show-calibration .vp-key-lane-mask{outline:1px dashed rgba(34,211,238,.45)}.vp-slot.line,.vp-slot.touch-dss,.vp-slot.expansion,.vp-slot.page-control{padding:1px 4px}.vp-slot.page-control{border-radius:999px;justify-content:flex-start;background:#061c2ce6;border:1px dashed rgba(34,211,238,.78);color:#a5f3fc}.vp-slot.page-control:before{width:5px;height:5px;margin-right:2px;border-radius:999px;background:#22c55e;box-shadow:0 0 8px #22c55e7a}.vp-slot.page-control.assigned{background:#061c2cf0}.vp-slot-text,.vp-slot-empty{font-size:clamp(7px,.55vw,9px)}.vp-key-lane-mask{background:linear-gradient(180deg,#071b2cfe,#051422fe)}.vp-slot.line,.vp-slot.touch-dss,.vp-slot.expansion,.vp-slot.page-control{padding:0 4px;min-height:10px}.vp-slot-text,.vp-slot-empty{font-size:clamp(6px,.5vw,8px);line-height:1}.vp-slot.line:before,.vp-slot.touch-dss:before,.vp-slot.expansion:before,.vp-slot.page-control:before{width:4px;height:4px;margin-right:2px}.vp-screen-mask{opacity:.12}.vp-key-lane-mask{background:#04121f94;opacity:.88}.vp-slot.line,.vp-slot.touch-dss,.vp-slot.expansion,.vp-slot.page-control{min-height:10px;padding:0 4px;border-width:1px}.vp-slot-text,.vp-slot-empty{font-size:clamp(6px,.48vw,8px);line-height:1}.vp-slot.line:before,.vp-slot.touch-dss:before,.vp-slot.expansion:before,.vp-slot.page-control:before{width:4px;height:4px}:root{--bg-shell: #080C18;--bg-surface: #0D1526;--bg-card: rgba(13,21,38,.85);--bg-card-hover:rgba(16,26,48,.95);--bg-input: rgba(255,255,255,.05);--bg-input-focus:rgba(255,255,255,.08);--bg-row-hover: rgba(255,255,255,.03);--bg-selected: rgba(99,102,241,.12);--border: rgba(255,255,255,.08);--border-card: rgba(255,255,255,.06);--border-hover: rgba(99,102,241,.4);--border-focus: rgba(99,102,241,.6);--grad-primary: linear-gradient(135deg, #0004FF 0%, #7B61FF 50%, #9B59FF 100%);--grad-btn: linear-gradient(135deg, #4F46E5 0%, #7C3AED 100%);--grad-btn-hover: linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%);--grad-logo: linear-gradient(135deg, #60A5FA, #818CF8, #A78BFA);--cyan: #22D3EE;--cyan-dim: rgba(34,211,238,.12);--blue: #6366F1;--blue-bright: #818CF8;--purple: #8B5CF6;--purple-bright:#A78BFA;--green: #10B981;--green-bright: #34D399;--amber: #F59E0B;--red: #EF4444;--red-bright: #F87171;--text: #E2E8F0;--text-sub: #94A3B8;--text-muted: #64748B;--text-dim: #334155;--status-ok: #10B981;--status-warn: #F59E0B;--status-err: #EF4444;--sidebar-w: 220px;--topbar-h: 56px;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--radius-xl: 18px;--shadow-card: 0 4px 24px rgba(0,0,0,.4), 0 1px 0 rgba(255,255,255,.04) inset;--shadow-glow: 0 0 20px rgba(99,102,241,.15);--shadow-modal: 0 24px 80px rgba(0,0,0,.7)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg-shell);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--blue-bright);text-decoration:none}button{font-family:inherit}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-shell{display:flex;height:100vh;overflow:hidden;background:var(--bg-shell)}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;z-index:50}.sidebar-logo{padding:16px 16px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:flex-start;flex-shrink:0}.sidebar-logo img{width:130px;height:auto;display:block}.logo-v{font-size:22px;font-weight:900;background:var(--grad-logo);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}.logo-brand{font-size:16px;font-weight:800;color:#f1f5f9;letter-spacing:-.3px}.nav-section{padding:6px 8px 2px}.nav-label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);padding:8px 10px 4px}.nav-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius-sm);color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;text-decoration:none;margin-bottom:1px}.nav-item:hover{background:#ffffff0d;color:var(--text)}.nav-item.active{background:#6366f126;color:var(--blue-bright)}.nav-item.active svg{color:var(--blue-bright)}.nav-item svg{width:15px;height:15px;flex-shrink:0;opacity:.8}.nav-item.active svg{opacity:1}.sidebar-bottom{margin-top:auto;padding:12px;border-top:1px solid var(--border)}.platform-plan-card{background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius);padding:10px 12px;margin-bottom:8px}.platform-plan-label{font-size:9.5px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.platform-plan-name{font-size:13px;font-weight:700;color:var(--blue-bright)}.platform-plan-btn{width:100%;margin-top:6px;padding:5px;background:#6366f126;border:1px solid rgba(99,102,241,.3);border-radius:var(--radius-sm);color:var(--blue-bright);font-size:11px;font-weight:600;cursor:pointer;text-align:center}.collapse-btn{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:12px;cursor:pointer;padding:4px 2px}.collapse-btn:hover{color:var(--text)}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:var(--topbar-h);min-height:var(--topbar-h);background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:12px;z-index:40;flex-shrink:0}.topbar-search{flex:1;max-width:360px;position:relative}.topbar-search input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);padding:7px 12px 7px 34px;font-size:13px;color:var(--text);outline:none;transition:border-color .15s,background .15s}.topbar-search input:focus{border-color:var(--border-focus);background:var(--bg-input-focus)}.topbar-search input::placeholder{color:var(--text-dim)}.topbar-search .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-dim);pointer-events:none}.topbar-search .search-shortcut{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:10px;color:var(--text-dim);background:#ffffff0f;border-radius:4px;padding:1px 5px}.topbar-spacer{flex:1}.topbar-badge{display:flex;align-items:center;gap:6px;padding:5px 12px;background:#ffffff0a;border:1px solid var(--border);border-radius:20px;font-size:12px;font-weight:500;color:var(--text-sub);cursor:pointer;transition:border-color .15s}.topbar-badge:hover{border-color:var(--border-hover)}.topbar-badge .dot{width:7px;height:7px;border-radius:50%}.dot-green{background:var(--green);box-shadow:0 0 6px var(--green)}.dot-blue{background:var(--blue);box-shadow:0 0 6px var(--blue)}.topbar-icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0a;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-sub);cursor:pointer;position:relative;transition:all .15s;font-size:0}.topbar-icon-btn:hover{border-color:var(--border-hover);color:var(--text)}.notif-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:9px;font-weight:700;width:15px;height:15px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--bg-surface)}.topbar-user{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:var(--radius);cursor:pointer;transition:background .15s}.topbar-user:hover{background:#ffffff0a}.topbar-avatar{width:30px;height:30px;border-radius:50%;background:var(--grad-btn);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.topbar-user-info{line-height:1.2}.topbar-user-name{font-size:12px;font-weight:600;color:var(--text)}.topbar-user-role{font-size:10px;color:var(--text-muted)}.topbar-caret{color:var(--text-dim)}.page-content{flex:1;overflow-y:auto;padding:24px;background:var(--bg-shell)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}.page-title{font-size:22px;font-weight:800;color:#f1f5f9;letter-spacing:-.4px}.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}.page-actions{display:flex;align-items:center;gap:10px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:14px;margin-bottom:20px}.kpi-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);padding:16px 18px;display:flex;align-items:flex-start;gap:12px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-card);transition:border-color .2s,box-shadow .2s;cursor:pointer}.kpi-card:hover{border-color:#6366f140;box-shadow:var(--shadow-card),var(--shadow-glow)}.kpi-card__icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-card__icon svg{width:18px;height:18px}.kpi-card__icon.blue{background:#6366f126;color:var(--blue-bright)}.kpi-card__icon.purple{background:#8b5cf626;color:var(--purple-bright)}.kpi-card__icon.cyan{background:#22d3ee1f;color:var(--cyan)}.kpi-card__icon.green{background:#10b9811f;color:var(--green-bright)}.kpi-card__icon.amber{background:#f59e0b1f;color:var(--amber)}.kpi-card__icon.red{background:#ef44441f;color:var(--red-bright)}.kpi-card__icon.indigo{background:#6366f126;color:#a5b4fc}.kpi-card__body{min-width:0;flex:1}.kpi-card__value{font-size:22px;font-weight:800;color:#f1f5f9;line-height:1.1}.kpi-card__label{font-size:11.5px;color:var(--text-muted);margin-top:2px;font-weight:500}.kpi-card__trend{display:flex;align-items:center;gap:3px;font-size:11px;font-weight:600;margin-top:4px}.kpi-card__trend.up{color:var(--green-bright)}.kpi-card__trend.down{color:var(--red-bright)}.kpi-card__trend .trend-sub{color:var(--text-muted);font-weight:400;font-size:10px}.card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);padding:18px 20px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-card)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.card-title{font-size:14px;font-weight:700;color:#cbd5e1}.card-link{font-size:12px;color:var(--blue-bright);cursor:pointer}.card-link:hover{text-decoration:underline}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.grid-cols-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.table-wrap{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.table-toolbar{padding:12px 16px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);flex-wrap:wrap}table{width:100%;border-collapse:collapse}thead th{background:#ffffff05;padding:9px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);border-bottom:1px solid var(--border);white-space:nowrap}tbody tr{border-bottom:1px solid rgba(255,255,255,.04);transition:background .1s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg-row-hover)}tbody td{padding:10px 14px;font-size:13px;color:var(--text)}.tabs{display:flex;align-items:center;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px;padding-bottom:0}.tab-item{padding:8px 14px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.tab-item:hover{color:var(--text)}.tab-item.active{color:var(--blue-bright);border-bottom-color:var(--blue)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.badge-green{background:#10b9811f;color:#34d399;border:1px solid rgba(16,185,129,.2)}.badge-red{background:#ef44441f;color:#f87171;border:1px solid rgba(239,68,68,.2)}.badge-amber{background:#f59e0b1f;color:var(--amber);border:1px solid rgba(245,158,11,.2)}.badge-blue{background:#6366f11f;color:var(--blue-bright);border:1px solid rgba(99,102,241,.2)}.badge-purple{background:#8b5cf61f;color:var(--purple-bright);border:1px solid rgba(139,92,246,.2)}.badge-cyan{background:#22d3ee1a;color:var(--cyan);border:1px solid rgba(34,211,238,.2)}.badge-gray{background:#ffffff0f;color:var(--text-muted);border:1px solid var(--border)}.status-dot{width:6px;height:6px;border-radius:50%;display:inline-block;margin-right:4px}.dot-green{background:var(--green);box-shadow:0 0 5px var(--green)}.dot-red{background:var(--red)}.dot-amber{background:var(--amber)}.dot-gray{background:var(--text-dim)}.dot-blue{background:var(--blue);box-shadow:0 0 5px var(--blue)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--grad-btn);color:#fff;box-shadow:0 2px 12px #6366f14d}.btn-primary:hover{background:var(--grad-btn-hover);box-shadow:0 4px 16px #6366f166;transform:translateY(-.5px)}.btn-secondary{background:#ffffff0f;color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:#ffffff1a;border-color:#ffffff26}.btn-danger{background:#ef44441f;color:var(--red-bright);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:#ef444433}.btn-ghost{background:transparent;color:var(--text-sub);border:none}.btn-ghost:hover{color:var(--text);background:#ffffff0d}.btn-sm{padding:4px 10px;font-size:11.5px;border-radius:5px}.btn-xs{padding:2px 8px;font-size:11px;border-radius:4px}.btn-lg{padding:10px 20px;font-size:14px;border-radius:var(--radius)}.btn-icon{padding:6px;border-radius:var(--radius-sm)}.input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 11px;font-size:13px;color:var(--text);outline:none;width:100%;transition:border-color .15s,background .15s;font-family:inherit}.input:focus{border-color:var(--border-focus);background:var(--bg-input-focus)}.input::placeholder{color:var(--text-dim)}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.input-wrap{position:relative}.input-wrap .input-icon{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--text-dim);pointer-events:none}.input-wrap .input{padding-left:30px}.form-group{margin-bottom:14px}.form-label{font-size:12px;font-weight:600;color:var(--text-sub);margin-bottom:5px;display:block}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:300;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.modal{background:#0d1526;border:1px solid var(--border-card);border-radius:var(--radius-xl);padding:28px;width:520px;max-width:96vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-modal)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-size:17px;font-weight:800;color:#f1f5f9}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.side-panel{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:95vw;background:#0d1526;border-left:1px solid var(--border-card);z-index:200;display:flex;flex-direction:column;box-shadow:-12px 0 48px #00000080}.side-panel-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.side-panel-body{flex:1;overflow-y:auto;padding:20px}.metric-bar{height:4px;background:#ffffff0f;border-radius:2px;overflow:hidden;margin-top:4px}.metric-bar-fill{height:100%;border-radius:2px;transition:width .6s ease}.metric-bar-fill.green{background:var(--green)}.metric-bar-fill.amber{background:var(--amber)}.metric-bar-fill.red{background:var(--red)}.metric-bar-fill.blue{background:var(--blue-bright)}.metric-bar-fill.purple{background:var(--purple)}.metric-bar-fill.grad{background:var(--grad-btn)}.health-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}.health-row:last-child{border-bottom:none}.activity-item{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:12.5px}.activity-item:last-child{border-bottom:none}.activity-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.activity-icon.blue{background:#6366f126;color:var(--blue-bright)}.activity-icon.green{background:#10b9811f;color:var(--green-bright)}.activity-icon.amber{background:#f59e0b1f;color:var(--amber)}.activity-icon.red{background:#ef44441f;color:var(--red-bright)}.activity-icon.purple{background:#8b5cf626;color:var(--purple-bright)}.activity-text{flex:1;line-height:1.45}.activity-time{font-size:11px;color:var(--text-muted);margin-top:2px;white-space:nowrap}.date-pill{display:flex;align-items:center;gap:6px;padding:5px 12px;background:#ffffff0d;border:1px solid var(--border);border-radius:20px;font-size:12px;font-weight:500;color:var(--text-sub);cursor:pointer}.date-pill:hover{border-color:var(--border-hover)}.top-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:12.5px}.top-row:last-child{border-bottom:none}.top-row-bar{flex:1;margin:0 10px}.flex{display:flex}.flex-center{display:flex;align-items:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-4{margin-top:16px}.mt-5{margin-top:20px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-5{margin-bottom:20px}.text-muted{color:var(--text-muted)}.text-sub{color:var(--text-sub)}.text-cyan{color:var(--cyan)}.text-green{color:var(--green-bright)}.text-red{color:var(--red-bright)}.text-amber{color:var(--amber)}.text-blue{color:var(--blue-bright)}.text-purple{color:var(--purple-bright)}.font-mono{font-family:SF Mono,Cascadia Code,Fira Code,monospace}.font-bold{font-weight:700}.font-800{font-weight:800}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uppercase{text-transform:uppercase;letter-spacing:.06em}.chart-wrap{width:100%;overflow:hidden}.mobile-only{display:none}.mobile-hide{display:block}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;min-width:40px;background:#ffffff0a;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-sub);cursor:pointer;flex-shrink:0;transition:all .15s}.mobile-menu-btn:hover{border-color:var(--border-hover);color:var(--text)}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:99;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.sidebar-backdrop.open{display:block}@media (max-width: 1024px) and (min-width: 769px){:root{--sidebar-w: 192px;--topbar-h: 54px}.topbar-search{max-width:220px}.topbar-badge{display:none}.page-content{padding:18px 20px}.kpi-grid{grid-template-columns:repeat(3,1fr)!important;gap:12px!important}.grid-3,.grid-cols-3{grid-template-columns:1fr 1fr!important}}@media (max-width: 768px){:root{--topbar-h: 52px;--sidebar-w: 0px}.mobile-only{display:flex!important}.mobile-hide{display:none!important}.mobile-menu-btn{display:flex!important}.collapse-btn{display:none!important}.app-shell{overflow:hidden}.sidebar{position:fixed!important;top:0!important;left:0!important;height:100dvh!important;height:100vh!important;width:272px!important;min-width:272px!important;z-index:100!important;transform:translate(-100%)!important;transition:transform .28s cubic-bezier(.4,0,.2,1)!important;box-shadow:6px 0 40px #000000b3!important;overflow-y:auto!important}.sidebar.mobile-open{transform:translate(0)!important}.reseller-sidebar{position:fixed!important;top:0!important;left:-272px!important;height:100dvh!important;height:100vh!important;width:272px!important;min-width:272px!important;z-index:100!important;transition:left .28s cubic-bezier(.4,0,.2,1)!important;box-shadow:6px 0 40px #000000b3!important}.reseller-sidebar.open{left:0!important}.reseller-sidebar-collapsed{display:none!important}.main-area{width:100%!important;min-width:0!important;overflow-x:hidden}.topbar{padding:0 12px!important;gap:8px!important;height:var(--topbar-h)!important}.topbar-search{max-width:none!important;flex:1!important}.topbar-search .search-shortcut,.topbar-badge,.topbar-user-info,.topbar-caret{display:none!important}.page-content{padding:14px 12px!important}.page-header{flex-direction:column!important;align-items:flex-start!important;gap:10px!important;margin-bottom:14px!important}.page-title{font-size:20px!important;letter-spacing:-.3px!important}.page-actions{width:100%!important;flex-wrap:wrap!important;gap:8px!important}.page-actions .btn{flex:1 1 auto!important;min-width:120px!important;justify-content:center!important}.kpi-grid,.kpi-grid-3,.kpi-grid-4,.kpi-grid-5,.kpi-grid-6{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}.kpi-card{padding:13px 12px!important;gap:10px!important}.kpi-card__icon{width:34px!important;height:34px!important}.kpi-card__icon svg{width:15px!important;height:15px!important}.kpi-card__value{font-size:19px!important}.kpi-card__label{font-size:10.5px!important}.kpi-card__trend{font-size:10px!important}.card{padding:14px 12px!important;border-radius:var(--radius)!important}.card-header{margin-bottom:10px!important}.grid-2,.grid-3,.grid-cols-3,.card-grid-2,.card-grid-3{grid-template-columns:1fr!important;gap:10px!important}.table-wrap{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;border-radius:var(--radius)!important}.table-scroll{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important}table{min-width:580px!important}thead th{padding:8px 10px!important;font-size:10px!important}tbody td{padding:9px 10px!important;font-size:12px!important}.table-toolbar{padding:10px 12px!important;gap:6px!important;flex-wrap:wrap!important}.table-toolbar .input{font-size:12px!important}.tabs{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;flex-wrap:nowrap!important;gap:0!important;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab-item{padding:8px 12px!important;font-size:12px!important;white-space:nowrap!important;flex-shrink:0!important}.tab-bar{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;flex-wrap:nowrap!important;scrollbar-width:none}.tab-bar::-webkit-scrollbar{display:none}.modal-overlay{align-items:flex-end!important;padding:0!important}.modal{width:100%!important;max-width:100%!important;max-height:92dvh!important;max-height:92vh!important;border-radius:16px 16px 0 0!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch}.side-panel{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100%!important;max-width:100%!important;z-index:200!important;border-radius:0!important;border-left:none!important;overflow-y:auto!important}.workspace-panel{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100%!important;max-width:100%!important;border-radius:0!important;z-index:200!important;overflow-y:auto!important}.form-row{flex-direction:column!important;gap:10px!important}.form-group{margin-bottom:12px!important}.form-label{font-size:11.5px!important}.btn-group{flex-wrap:wrap!important;gap:6px!important}.btn-group>*{flex:1 1 auto!important;min-width:100px!important;justify-content:center!important}.dash-page{padding:14px 10px!important}.dash-header{flex-direction:column!important;align-items:flex-start!important;gap:8px!important;margin-bottom:14px!important}.quick-action-row{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:6px!important}.quick-action-row>*{flex:unset!important;min-width:0!important;padding:10px 4px!important;font-size:11px!important;text-align:center!important;flex-direction:column!important;gap:4px!important}.recharts-wrapper,.recharts-responsive-container{max-height:200px!important}.chart-container{height:180px!important}[data-mobile-hide=true],.col-hide-mobile,[data-mobile=hide]{display:none!important}.scope-bar{padding:6px 10px!important;flex-wrap:wrap!important;gap:6px!important;font-size:11px!important}.filter-bar,.toolbar{flex-wrap:wrap!important;gap:6px!important}.filter-bar .input,.toolbar .input{width:100%!important;font-size:12px!important}.filter-bar select.input{font-size:12px!important}.detail-grid-2{grid-template-columns:1fr!important;gap:12px!important}.nav-item{padding:10px 12px!important;font-size:13.5px!important;min-height:44px!important}.nav-label{padding:10px 12px 4px!important}.input,select.input{min-height:40px!important;font-size:14px!important}textarea.input{min-height:80px!important;font-size:14px!important}input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],input[type=search],select,textarea,.topbar-search input{font-size:16px!important}.overflow-x-auto{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important}.btn{min-height:38px!important}.btn-sm{min-height:32px!important}.topbar-icon-btn{width:38px!important;height:38px!important}.ivr-builder-canvas{height:calc(100dvh - 120px)!important;height:calc(100vh - 120px)!important}.ivr-palette-btn{bottom:80px!important;left:12px!important}.ivr-save-btn{bottom:80px!important;right:12px!important}.kamailio-table-wrap{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important}.health-grid{grid-template-columns:1fr 1fr!important;gap:8px!important}.device-grid{grid-template-columns:1fr 1fr!important;gap:10px!important}.login-card{width:100%!important;max-width:100%!important;border-radius:0!important;min-height:100dvh!important;min-height:100vh!important;padding:32px 20px!important;justify-content:center!important}.login-shell{padding:0!important;align-items:stretch!important}}@media (max-width: 480px){.kpi-grid{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}.kpi-card{padding:11px 10px!important;gap:8px!important}.kpi-card__value{font-size:17px!important}.kpi-card__label{font-size:10px!important}.kpi-card__icon{width:30px!important;height:30px!important}.page-title{font-size:18px!important}.page-content{padding:10px 8px!important}.card{padding:12px 10px!important}.card-title{font-size:13px!important}.quick-action-row{grid-template-columns:repeat(2,1fr)!important}.quick-action-row>*{padding:12px 6px!important;font-size:11px!important}.nav-label{font-size:9px!important}.tab-item{padding:8px 10px!important;font-size:11.5px!important}table{min-width:520px!important}thead th{font-size:9.5px!important;padding:7px 8px!important}tbody td{font-size:11.5px!important;padding:8px!important}.modal{max-height:96dvh!important;max-height:96vh!important}.device-grid{grid-template-columns:1fr!important}.health-grid{grid-template-columns:1fr 1fr!important}.topbar{padding:0 8px!important;gap:6px!important}.mobile-menu-btn{width:36px!important;height:36px!important}.topbar-icon-btn{width:34px!important;height:34px!important}.topbar-search{display:none!important}}@media (hover: none) and (pointer: coarse){.kpi-card:hover{border-color:var(--border-card)!important;box-shadow:var(--shadow-card)!important}.btn-primary:hover{transform:none!important}.nav-item{min-height:44px!important}.btn,.nav-item,.tab-item{user-select:none;-webkit-user-select:none}.page-content,.sidebar,.modal,.side-panel{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}}@supports (padding-bottom: env(safe-area-inset-bottom)){@media (max-width: 768px){.sidebar,.modal{padding-bottom:env(safe-area-inset-bottom)!important}.topbar{padding-left:max(12px,env(safe-area-inset-left))!important;padding-right:max(12px,env(safe-area-inset-right))!important}.page-content{padding-bottom:max(14px,env(safe-area-inset-bottom))!important}}}
