.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))}:root{--primary: #2b5597;--primary-dark: #1f4070;--primary-light: #3c6cb5;--accent: #c62032;--accent-dark: #a3192a;--bg: #f5f6fa;--surface: #ffffff;--text: #1f2937;--text-muted: #6b7280;--border: #e5e7eb;--success: #16a34a;--danger: #dc2626;--sidebar-width: 260px;--radius: 12px;--shadow: 0 4px 20px rgba(0, 0, 0, .06)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}button{font-family:inherit;cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1.2rem;border:none;border-radius:var(--radius);font-size:.95rem;font-weight:600;transition:all .15s ease}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover{background:#f3f4f6}.btn-block{width:100%}.field{margin-bottom:1.1rem}.field label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.4rem;color:var(--text)}.field input:not([type=checkbox]):not([type=radio]),.field select,.field textarea{width:100%;padding:.7rem .9rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;font-family:inherit;outline:none;background:#fff;transition:border .15s ease,box-shadow .15s ease}.field input:not([type=checkbox]):not([type=radio]):focus,.field select:focus,.field textarea:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #2b559726}.alert{padding:.7rem 1rem;border-radius:var(--radius);font-size:.9rem;margin-bottom:1rem}.alert-error{background:#fef2f2;color:var(--danger);border:1px solid #fecaca}.alert-success{background:#f0fdf4;color:var(--success);border:1px solid #bbf7d0}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}.auth-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2b5597,#1f4070);padding:1rem}.auth-card{background:var(--surface);width:100%;max-width:400px;border-radius:20px;box-shadow:0 20px 60px #00000040;padding:2.5rem}.auth-logo{text-align:center;margin-bottom:1.8rem}.auth-logo img{width:130px;height:auto;margin-bottom:.6rem}.auth-icon{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;margin:0 auto .4rem;border-radius:50%;background:#2b55971a;color:var(--primary)}.auth-logo h1{font-size:1.4rem;margin-top:.4rem}.auth-logo p{color:var(--text-muted);font-size:.9rem;margin-top:.2rem}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border);color:var(--text);display:flex;flex-direction:column;position:fixed;height:100vh}.sidebar-brand{padding:1.6rem 1.5rem 1.2rem;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border)}.sidebar-brand img{width:150px;height:auto}.sidebar-brand-name{font-size:1.45rem;font-weight:800;letter-spacing:-.02em;color:var(--primary)}.logo-sr{font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:700;letter-spacing:-.01em;display:flex;align-items:flex-end;line-height:1;color:#2c589b;-webkit-user-select:none;user-select:none;white-space:nowrap;font-size:26px}.logo-sr .sr-routeS{height:.78em;width:.6em;display:block;margin-bottom:.02em;overflow:visible}.logo-sr .sr-word{display:inline-flex;align-items:flex-end}.logo-sr .sr-word .ch{display:inline-block;will-change:transform,opacity}.logo-sr .sr-word .ch.pin{position:relative;color:transparent;width:.58em}.logo-sr .pinmark{position:absolute;left:50%;bottom:.02em;width:.62em;height:.86em;transform:translate(-50%);overflow:visible}.perfil-head{display:flex;align-items:center;gap:1.1rem;margin-bottom:1.5rem}.perfil-avatar{width:64px;height:64px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:700;font-size:1.4rem;flex-shrink:0}.perfil-head h2{margin:0 0 .25rem;font-size:1.3rem}.perfil-head .perfil-correo{color:var(--text-muted);font-size:.9rem;margin-bottom:.4rem}.barchart{display:flex;align-items:flex-end;gap:6px;height:190px;padding-top:8px}.barchart .col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:5px}.barchart .val{font-size:.7rem;font-weight:700;color:var(--text)}.barchart .bar{width:72%;max-width:32px;min-height:3px;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--primary-light),var(--primary));transition:height .3s ease}.barchart .bar.cero{background:#e5e7eb}.barchart .col small{font-size:.66rem;color:var(--text-muted)}.sidebar-nav{flex:1;padding:1rem .7rem;display:flex;flex-direction:column;gap:.15rem}.sidebar-link{display:flex;align-items:center;gap:.7rem;padding:.65rem .9rem;border-radius:8px;color:var(--text-muted);font-weight:500;font-size:.92rem;transition:background .15s ease,color .15s ease}.sidebar-link:hover{background:#f3f4f6;color:var(--text)}.sidebar-link.active{background:#2b55971a;color:var(--primary);font-weight:600}.sidebar-icon{font-size:1.1rem;width:1.2rem;text-align:center}.sidebar-group{width:100%;background:none;border:none;font-family:inherit;cursor:pointer;text-align:left}.sidebar-caret{margin-left:auto;transition:transform .15s ease;font-size:1.1rem}.sidebar-caret.open{transform:rotate(90deg)}.sidebar-subnav{display:flex;flex-direction:column;gap:.1rem;margin:.1rem 0 .2rem;padding-left:1.7rem}.sidebar-subnav .sidebar-link{padding:.5rem .9rem;font-size:.88rem}.sidebar-footer{padding:1rem;border-top:1px solid var(--border)}.sidebar-user{display:flex;align-items:center;gap:.7rem;margin-bottom:.8rem;padding:.5rem;border-radius:10px;color:inherit;text-decoration:none;cursor:pointer;transition:background .15s ease}.sidebar-user:hover{background:#f3f4f6}.sidebar-user.active{background:#2b55971a}.sidebar-avatar{width:38px;height:38px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.sidebar-user-info strong{font-size:.9rem}.sidebar-user-info small{display:block;color:var(--text-muted);font-size:.75rem;text-transform:capitalize}.btn-logout{width:100%;background:#f3f4f6;color:var(--text);border:1px solid var(--border);padding:.55rem;border-radius:8px;font-weight:600;font-size:.88rem;transition:background .15s ease,color .15s ease}.btn-logout:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.content{margin-left:var(--sidebar-width);flex:1;padding:2rem}.page-header{margin-bottom:1.5rem}.page-header h1{font-size:1.6rem}.page-header p{color:var(--text-muted);margin-top:.3rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.2rem}.stat-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.3rem}.stat-card .stat-icon{color:var(--primary);line-height:0}.stat-card .stat-value{font-size:1.8rem;font-weight:700;margin-top:.5rem}.stat-card .stat-label{color:var(--text-muted);font-size:.9rem}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:.8rem 1rem;border-bottom:1px solid var(--border);font-size:.9rem}.table th{color:var(--text-muted);font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.03em}.table .th-grupo{text-align:center;font-size:.72rem;color:var(--primary);background:#2b55970f;padding:.45rem 1rem}.table .col-sep{border-left:2px solid var(--border)}.celda-asesor{display:flex;flex-direction:column;gap:.18rem}.celda-asesor strong{font-size:.88rem}.celda-sub{font-size:.78rem;color:var(--text-muted);display:inline-flex;align-items:center;gap:.25rem;white-space:nowrap}.badge-asig{align-self:flex-start;background:#2b55971a;color:var(--primary);padding:.1rem .5rem;border-radius:999px;font-size:.72rem;font-weight:600}.badge-reasig{align-self:flex-start;background:#fef3c7;color:#b45309;padding:.1rem .5rem;border-radius:999px;font-size:.72rem;font-weight:600;white-space:nowrap}.celda-badges{display:flex;gap:.3rem;flex-wrap:wrap}.copy-mini{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:.15rem;border-radius:4px;display:inline-flex;vertical-align:middle}.copy-mini:hover{color:var(--primary);background:#2b55971a}.celda-copy{display:inline-flex;align-items:center;gap:.25rem}.evento-toggle{display:flex;align-items:center;gap:.65rem;padding:.6rem .75rem;border:1px solid var(--border);border-radius:10px;background:#fff;cursor:pointer;font-size:.86rem;margin-bottom:.9rem;transition:border-color .12s ease,background .12s ease}.evento-toggle:hover{border-color:var(--primary-light)}.evento-toggle.activo{border-color:#ff7a59;background:#ff7a590f;font-weight:600}.evento-toggle input{accent-color:#ff7a59;width:16px;height:16px;flex-shrink:0}.multi-combo{position:relative}.multi-combo-btn{display:inline-flex;align-items:center;gap:.45rem;min-width:200px;padding:.45rem .7rem;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:.85rem;font-family:inherit;color:var(--text);cursor:pointer;transition:border-color .12s ease}.multi-combo-btn:hover{border-color:var(--primary-light)}.multi-combo-btn.activo{border-color:var(--primary);color:var(--primary);font-weight:600;background:#2b55970d}.multi-combo-btn .rot{transform:rotate(180deg)}.multi-combo-label{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.multi-combo-panel{position:absolute;top:calc(100% + 4px);left:0;z-index:30;min-width:250px;max-height:280px;overflow-y:auto;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #0f172a24;padding:.35rem}.multi-combo-head{display:flex;justify-content:space-between;align-items:center;padding:.3rem .55rem .4rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:.25rem}.multi-combo-clear{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.74rem;font-weight:600;padding:0;text-transform:none;letter-spacing:normal}.multi-combo-clear:hover{text-decoration:underline}.multi-combo-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.42rem .55rem;border-radius:6px;cursor:pointer;font-size:.85rem;background:none;border:none;font-family:inherit;text-align:left;color:var(--text)}.multi-combo-item:hover{background:#2b559714}.multi-combo-item input{accent-color:var(--primary)}.multi-combo-item.sel{color:var(--primary);font-weight:600}.multi-combo-item .check{margin-left:auto;flex-shrink:0}.multi-combo-item span:first-child{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.multi-combo-empty{color:var(--text-muted);font-size:.82rem;padding:.6rem .55rem}.multi-combo-grupo+.multi-combo-grupo{margin-top:.45rem}.rango-icono{display:inline-flex;align-items:center;color:var(--primary)}.dot-error{position:absolute;top:-3px;right:-3px;width:10px;height:10px;border-radius:50%;background:var(--accent);animation:pulso-error 1.2s ease-in-out infinite}@keyframes pulso-error{0%,to{box-shadow:0 0 #c6203280}50%{box-shadow:0 0 0 6px #c6203200}}.table tr.fila-nueva td{background:#fef2f2}.badge-nuevo{background:var(--accent);color:#fff;padding:.05rem .45rem;border-radius:999px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.asesor-row{display:grid;grid-template-columns:minmax(140px,200px) 1fr auto;gap:.7rem;align-items:center;margin-bottom:.45rem}.asesor-nombre{font-size:.88rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asesor-barra{background:#2b559714;border-radius:999px;height:14px;overflow:hidden}.asesor-barra-fill{height:100%;background:linear-gradient(90deg,var(--primary-light),var(--primary));border-radius:999px;min-width:6px}.asesor-total{font-size:.85rem;white-space:nowrap}.asesor-total small{color:var(--text-muted)}.badge{padding:.25rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge-activo{background:#dcfce7;color:var(--success)}.badge-pendiente{background:#fef9c3;color:#ca8a04}.badge-inactivo{background:#f3f4f6;color:var(--text-muted)}.pw-checklist{list-style:none;margin:.5rem 0 1rem;font-size:.82rem}.pw-checklist li{display:flex;align-items:center;gap:.55rem;color:var(--text-muted);padding:.15rem 0}.pw-checklist li.ok{color:var(--success)}.btn-link{background:none;border:none;color:var(--primary);font-weight:600;font-size:.85rem;padding:.2rem .4rem;border-radius:6px}.btn-link:hover{background:#2b55971a}.btn-link.danger{color:var(--danger)}.btn-link.danger:hover{background:#fef2f2}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:.4rem;border:1px solid var(--border);border-radius:var(--radius);padding:.8rem}.checkbox-item{display:flex;align-items:center;gap:.7rem;font-size:.85rem;cursor:pointer}.checkbox-item input{width:auto;accent-color:var(--primary)}.wh-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;align-items:start}@media (max-width: 760px){.wh-grid{grid-template-columns:1fr}}.capture-panel{border:1px solid var(--border);border-radius:var(--radius);padding:.9rem;background:#f9fafb}.props-chips{display:flex;flex-wrap:wrap;gap:.35rem;margin:.5rem 0}.props-chips .chip{cursor:pointer;border:none;font-family:inherit}.props-chips .chip:hover{background:#2b559733}.flujo-canvas{display:flex;align-items:stretch;gap:.4rem;flex-wrap:wrap;padding:1.6rem;background:radial-gradient(circle,rgba(43,85,151,.12) 1px,transparent 1px) 0 0 / 22px 22px,#f9fafb;border:1px solid var(--border);border-radius:var(--radius)}.flujo-node{flex:1 1 230px;min-width:220px;display:flex;gap:.85rem;align-items:flex-start;text-align:left;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1rem;cursor:pointer;font-family:inherit;box-shadow:0 1px 2px #0000000d;transition:box-shadow .15s,transform .15s,border-color .15s}.flujo-node:hover{border-color:var(--primary);box-shadow:0 6px 18px #2b559729;transform:translateY(-2px)}.flujo-node-icon{flex-shrink:0;width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.flujo-node-title{font-weight:700;font-size:1.02rem;color:var(--text)}.flujo-node-sub{font-size:.8rem;color:var(--text-muted);margin-bottom:.4rem}.flujo-node-resumen{font-size:.82rem;color:var(--primary);word-break:break-word}.flujo-connector{display:flex;align-items:center;color:var(--text-muted);flex:0 0 auto}@media (max-width: 760px){.flujo-canvas{flex-direction:column}.flujo-connector{transform:rotate(90deg);align-self:center}}.flujo-editor{display:flex;flex-direction:column}.flujo-topbar{display:flex;align-items:center;gap:.8rem;padding:.6rem .2rem .9rem}.flujo-nombre{font-size:1.05rem;font-weight:600;border:1px solid var(--border);border-radius:var(--radius);padding:.45rem .7rem;min-width:280px}.flujo-cuerpo{display:flex;gap:.8rem;height:calc(100vh - 190px);min-height:460px}.flujo-lienzo{flex:1;min-width:0;background:#fff;position:relative;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.flujo-add-btn{position:absolute;top:12px;left:12px;z-index:10;width:38px;height:38px;border-radius:50%;border:none;background:var(--primary);color:#fff;display:grid;place-items:center;box-shadow:0 4px 12px #2b559759;cursor:pointer;transition:background .15s ease,transform .15s ease}.flujo-add-btn:hover{background:var(--primary-dark);transform:scale(1.06)}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1500}.menu-flotante{position:fixed;z-index:1600;min-width:215px;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 30px #00000029;padding:.35rem;animation:toast-in .12s ease}.menu-flotante-tit{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding:.35rem .5rem}.menu-item{display:flex;align-items:center;gap:.5rem;width:100%;text-align:left;background:transparent;border:none;border-radius:6px;padding:.45rem .5rem;font-family:inherit;font-size:.85rem;color:var(--text);cursor:pointer}.menu-item:hover{background:#f3f4f6}.menu-item.danger{color:var(--danger)}.menu-item.danger:hover{background:#dc262614}.menu-item span{display:flex;flex-direction:column;line-height:1.25}.menu-item small{color:var(--text-muted);font-size:.7rem}.menu-flotante-hint{font-size:.7rem;color:var(--text-muted);padding:.45rem .5rem .2rem;border-top:1px solid var(--border);margin-top:.3rem;line-height:1.45;max-width:230px}.menu-renombrar{display:flex;gap:.35rem;padding:.3rem .4rem}.menu-renombrar input{flex:1;padding:.4rem .5rem;border:1px solid var(--border);border-radius:6px;font-size:.84rem;min-width:140px}.flujo-panel{width:320px;flex-shrink:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow-y:auto}.flujo-panel-in{padding:0}.flujo-panel-acento{height:4px;border-radius:4px;margin-bottom:.9rem}.flujo-salida{font-size:.76rem;color:var(--text-muted);background:#f9fafb;border-radius:8px;padding:.5rem .6rem;margin-top:.7rem;line-height:1.6}.nodo-modal{display:grid;grid-template-columns:320px 1fr;gap:1.2rem;align-items:start}.nodo-modal.sin-refs{grid-template-columns:1fr}.nodo-modal-refs{background:#f9fafb;border:1px solid var(--border);border-radius:var(--radius);padding:.8rem;position:sticky;top:0;max-height:76vh;overflow-y:auto}.nodo-modal-cfg{min-width:0}@media (max-width: 720px){.nodo-modal{grid-template-columns:1fr}.nodo-modal-refs{position:static;max-height:none}}.ref-nodo{border:1px solid var(--border);border-radius:8px;padding:.5rem .6rem;margin-bottom:.5rem;background:#fff}.ref-nodo-tit{font-size:.82rem;margin-bottom:.35rem}.ref-nodo-tit code{background:#2b55971a;color:var(--primary);padding:0 .3rem;border-radius:4px}.chip-pay{display:inline-flex;align-items:center;gap:.4rem}.chip-pay .chip-key{font-weight:600}.chip-pay .chip-val{color:var(--text-muted);font-weight:400;font-size:.74rem;background:#fff;border-radius:4px;padding:0 .3rem}.cond-row{display:flex;gap:.35rem;align-items:center;margin-bottom:.4rem}.cond-row input,.cond-row select{padding:.4rem .5rem;border:1px solid var(--border);border-radius:6px;font-size:.82rem;min-width:0;flex:1}.hs-combo{position:relative;flex:1.35;min-width:0}.hs-combo-btn{width:100%;display:flex;align-items:center;gap:.45rem;padding:.42rem .55rem;border:1px solid var(--border);border-radius:6px;background:#fff;font-size:.82rem;text-align:left;font-family:inherit;min-width:0}.hs-combo-btn:hover{border-color:var(--primary-light)}.hs-combo-btn.placeholder{color:var(--text-muted)}.hs-combo-btn .hs-combo-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hs-combo-btn code{color:var(--text-muted);font-size:.72rem;background:#f3f4f6;padding:0 .3rem;border-radius:4px;flex-shrink:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hs-combo-btn svg{margin-left:auto;flex-shrink:0;color:var(--text-muted)}.hs-combo-panel{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:300px;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 30px #00000024;z-index:60;padding:.45rem}.hs-combo-buscar{width:100%;margin-bottom:.4rem}.hs-combo-lista{max-height:250px;overflow-y:auto;display:flex;flex-direction:column;gap:1px}.hs-combo-item{display:flex;flex-direction:column;align-items:flex-start;gap:.12rem;width:100%;text-align:left;border:none;background:transparent;padding:.4rem .5rem;border-radius:6px;font-family:inherit;cursor:pointer}.hs-combo-item:hover{background:#2b559714}.hs-combo-item.sel{background:#2b559721}.hs-combo-label{font-weight:600;font-size:.82rem;color:var(--text)}.hs-combo-meta{display:flex;gap:.4rem;align-items:center;font-size:.72rem;color:var(--text-muted);min-width:0}.hs-combo-meta code{background:#f3f4f6;padding:0 .3rem;border-radius:4px}.hs-combo-tipo{background:#2b55971a;color:var(--primary);border-radius:999px;padding:0 .45rem;font-weight:600}.hs-combo-vacio{padding:.5rem;font-size:.78rem;color:var(--text-muted);display:flex;flex-direction:column;gap:.4rem;align-items:flex-start}.nodo{position:relative;background:#fff;border:2px solid var(--c, var(--primary));border-radius:10px;padding:.6rem .9rem;min-width:150px;box-shadow:0 1px 3px #00000014}.nodo.sel{box-shadow:0 0 0 3px #2b559740}.nodo-cab{font-weight:700;font-size:.9rem;color:var(--c, var(--primary));display:flex;align-items:center;gap:.4rem}.nodo-icono{display:inline-flex;line-height:0}.nodo-sub{font-size:.72rem;color:var(--text-muted);margin-top:.1rem}.nodo-port{position:absolute;right:14px;font-size:.68rem;font-weight:700;color:var(--text-muted)}.nodo-port.si{top:30%;color:#16a34a}.nodo-port.no{top:64%;color:var(--danger)}.react-flow__handle{width:11px;height:11px;background:var(--primary);border:2px solid #fff}.react-flow__edge-path{stroke-width:2}.react-flow__edge.selected .react-flow__edge-path{stroke:var(--primary);stroke-width:3}.edge-del{position:absolute;pointer-events:all;width:20px;height:20px;line-height:1;border-radius:50%;border:1px solid var(--border);background:#fff;color:var(--danger);font-size:15px;font-weight:700;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0003;opacity:.75;transition:opacity .12s,background .12s}.edge-del:hover{opacity:1;background:var(--danger);color:#fff}@media (max-width: 900px){.flujo-cuerpo{flex-direction:column;height:auto}.flujo-lienzo{height:60vh}.flujo-panel{width:100%}}.form-section{border-top:1px solid var(--border);margin:1.2rem 0 .9rem;padding-top:1rem}.form-section:first-of-type{border-top:none;margin-top:0;padding-top:0}.form-section-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--primary);margin-bottom:.2rem}.form-section-hint{color:var(--text-muted);font-size:.82rem;margin-bottom:.8rem}.campo-row.encabezado{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);margin-bottom:.3rem}.log-item{border:1px solid var(--border);border-radius:var(--radius);padding:.7rem .8rem;margin-bottom:.7rem}.log-head{display:flex;align-items:center;gap:.7rem;margin-bottom:.5rem;font-size:.82rem;color:var(--text-muted)}.log-cols{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.log-cols>div>strong{font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted)}pre.json{background:#0f172a;color:#e2e8f0;padding:.6rem .7rem;border-radius:8px;font-size:.76rem;overflow-x:auto;max-height:220px;margin-top:.25rem;white-space:pre-wrap;word-break:break-word}@media (max-width: 560px){.log-cols{grid-template-columns:1fr}}.input-group{display:flex;align-items:stretch;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff}.input-group:focus-within{border-color:var(--primary-light);box-shadow:0 0 0 3px #2b559726}.input-prefix{display:flex;align-items:center;padding:0 .7rem;background:#f3f4f6;color:var(--text-muted);font-size:.82rem;white-space:nowrap;border-right:1px solid var(--border)}.input-group input{flex:1;border:none!important;border-radius:0!important;box-shadow:none!important;outline:none}.metodo-selector{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff}.metodo-opcion{border:none;background:transparent;padding:.55rem 1.3rem;font-weight:700;font-size:.85rem;letter-spacing:.04em;color:var(--text-muted);border-right:1px solid var(--border);transition:background .15s ease,color .15s ease}.metodo-opcion:last-child{border-right:none}.metodo-opcion:hover{background:#f3f4f6}.metodo-opcion.activa.post{background:var(--primary);color:#fff}.metodo-opcion.activa.get{background:var(--success);color:#fff}.metodo-opcion.activa.put{background:#d97706;color:#fff}.campo-row{display:grid;grid-template-columns:1fr 130px 1.2fr auto;gap:.5rem;align-items:center;margin-bottom:.5rem}.campo-row input,.campo-row select{width:100%;padding:.45rem .6rem;border:1px solid var(--border);border-radius:8px;font-size:.85rem;font-family:inherit;background:#fff}.campo-row .btn-icon,.cond-row .btn-icon{background:none;border:none;color:var(--danger);cursor:pointer;padding:.35rem;border-radius:6px;display:flex;align-items:center;flex-shrink:0}.campo-row .btn-icon:hover,.cond-row .btn-icon:hover{background:#fef2f2}.copy-row{display:flex;align-items:center;gap:.5rem}.copy-row code{flex:1;overflow-x:auto;white-space:nowrap;padding:.5rem .6rem}@media (max-width: 560px){.campo-row{grid-template-columns:1fr}}.transfer{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}.transfer-col{border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden}.transfer-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.55rem .7rem;background:#f9fafb;border-bottom:1px solid var(--border);font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted)}.transfer-head .conteo{background:#eef2f7;color:var(--text-muted);border-radius:999px;padding:.05rem .45rem;font-size:.72rem}.transfer-head-action{background:none;border:none;color:var(--primary);font-size:.7rem;font-weight:700;text-transform:none;letter-spacing:0;cursor:pointer}.transfer-head-action:hover{text-decoration:underline}.transfer-search{padding:.5rem;border-bottom:1px solid var(--border)}.transfer-search input{width:100%;padding:.4rem .6rem;border:1px solid var(--border);border-radius:8px;font-size:.84rem;outline:none}.transfer-list{padding:.3rem;overflow-y:auto;max-height:280px;min-height:130px;display:flex;flex-direction:column;gap:.12rem}.transfer-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;text-align:left;background:none;border:none;padding:.5rem .6rem;border-radius:8px;cursor:pointer;font-size:.86rem;color:var(--text);font-family:inherit;transition:background .12s ease}.transfer-item:hover{background:#2b559714}.transfer-item .accion{display:flex;color:var(--text-muted);flex-shrink:0}.transfer-item:hover .accion{color:var(--primary)}.transfer-item .turno-btn{background:none;border:none;cursor:pointer;color:inherit;padding:.2rem;border-radius:6px;display:flex}.transfer-item .turno-btn:hover:not(:disabled){background:#2b55971f;color:var(--primary)}.transfer-item .turno-btn:disabled{opacity:.35;cursor:default}.transfer-empty{color:var(--text-muted);font-size:.84rem;padding:.8rem .6rem;text-align:center}@media (max-width: 560px){.transfer{grid-template-columns:1fr}}.dropdown-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.65rem .85rem;border:1px solid var(--border);border-radius:var(--radius);background:#fff;font-size:.92rem;font-family:inherit;color:var(--text);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.dropdown-trigger:hover{border-color:var(--primary-light)}.dropdown-trigger.open{border-color:var(--primary-light);box-shadow:0 0 0 3px #2b559726}.dropdown-trigger.placeholder{color:var(--text-muted)}.dropdown-trigger .caret{color:var(--text-muted);transition:transform .15s ease;flex-shrink:0}.dropdown-trigger.open .caret{transform:rotate(180deg)}.paginacion{display:flex;align-items:center;justify-content:flex-end;gap:.8rem;margin-top:1rem;font-size:.85rem;color:var(--text-muted)}.combo{position:relative}.combo-list{margin-top:.3rem;border:1px solid var(--border);border-radius:var(--radius);max-height:220px;overflow-y:auto;background:#fff}.combo-option{display:flex;flex-direction:column;align-items:flex-start;width:100%;text-align:left;background:none;border:none;padding:.5rem .75rem;cursor:pointer;border-bottom:1px solid #f1f3f5}.combo-option:last-child{border-bottom:none}.combo-option:hover{background:#2b559714}.combo-option small{color:var(--text-muted);font-size:.78rem}.combo-empty{padding:.6rem .75rem;color:var(--text-muted);font-size:.85rem}.splash-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;background:radial-gradient(1200px 600px at 80% -10%,#f7f9fb,transparent),#eef1f4;animation:modal-fade .25s ease}.splash-icon{width:230px;height:230px}.splash-overlay h2{font-size:1.55rem;font-weight:800;letter-spacing:-.02em;color:var(--primary);margin:.4rem 0 0}.splash-overlay p{color:var(--text-muted);font-size:.9rem;margin:0}.toasts{position:fixed;top:1.2rem;left:50%;transform:translate(-50%);z-index:3000;display:flex;flex-direction:column;gap:.5rem;width:max-content;max-width:min(540px,90vw);pointer-events:none}.toasts .alert{margin:0;box-shadow:0 8px 24px #0000002e;animation:toast-in .18s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1118278c;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000;animation:modal-fade .15s ease}.modal{background:var(--surface);border-radius:16px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 70px #0000004d;animation:modal-in .18s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem;border-bottom:1px solid var(--border)}.modal-header h3{font-size:1.15rem}.modal-close{background:none;border:none;color:var(--text-muted);width:32px;height:32px;border-radius:8px;display:grid;place-items:center;font-size:1rem;transition:background .15s ease,color .15s ease}.modal-close:hover{background:#f3f4f6;color:var(--text)}.modal-body{padding:1.5rem;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1.4rem;padding-top:1.2rem;border-top:1px solid var(--border)}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}.btn-sm{display:inline-flex;align-items:center;gap:.3rem;padding:.38rem .75rem;font-size:.8rem;font-weight:600;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text);margin-right:.4rem;transition:background .15s ease,border-color .15s ease,color .15s ease}.btn-sm:hover{background:#f3f4f6}.btn-sm.primary{color:var(--primary);border-color:var(--primary)}.btn-sm.primary:hover{background:#2b55971a}.btn-sm.danger{color:var(--danger);border-color:#fecaca}.btn-sm.danger:hover{background:#fef2f2}.btn-sm.success{color:var(--success);border-color:#bbf7d0}.btn-sm.success:hover{background:#f0fdf4}.btn-sm:disabled{opacity:.5;cursor:not-allowed}.chip{display:inline-block;padding:.22rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;margin:0 .3rem .3rem 0;background:#2b55971a;color:var(--primary)}.table-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.filtros{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:1rem}.filtros>input,.filtros>select{padding:.55rem .8rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;font-family:inherit;outline:none;background:#fff}.filtros>input{flex:1;min-width:220px}.filtros>input:focus,.filtros>select:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #2b559726}.permisos-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.9rem}.permiso-card{border:1px solid var(--border);border-radius:12px;overflow:hidden}.permiso-card-head{display:flex;align-items:center;justify-content:space-between;padding:.55rem .75rem;background:#f9fafb;border-bottom:1px solid var(--border)}.permiso-card-head .titulo{display:flex;align-items:center;gap:.4rem;font-weight:700;font-size:.9rem}.permiso-card-head .conteo{font-size:.72rem;font-weight:600;color:var(--text-muted);background:#eef2f7;padding:.05rem .4rem;border-radius:999px}.permiso-card-todos{display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;color:var(--primary);cursor:pointer}.permiso-card-todos input{accent-color:var(--primary)}.permiso-card-body{padding:.35rem;display:flex;flex-direction:column;gap:.1rem}.permiso-opcion{display:flex;align-items:center;gap:.75rem;padding:.5rem .6rem;border-radius:8px;cursor:pointer;font-size:.88rem;color:var(--text);transition:background .12s ease,color .12s ease}.permiso-opcion:hover{background:#f3f4f6}.permiso-opcion.activo{background:#2b55971a;color:var(--primary);font-weight:600}.permiso-opcion input{accent-color:var(--primary)}code{background:#f3f4f6;padding:.1rem .4rem;border-radius:5px;font-size:.82rem;color:var(--primary-dark)}input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;margin:0;padding:0;border:1.5px solid #cbd5e1;border-radius:5px;background:#fff;display:inline-grid;place-content:center;cursor:pointer;flex-shrink:0;vertical-align:middle;transition:background .15s ease,border-color .15s ease}input[type=checkbox]:before{content:"";width:11px;height:11px;background:#fff;transform:scale(0);transition:transform .12s ease-in-out;clip-path:polygon(14% 44%,0 65%,50% 100%,100% 16%,80% 0%,43% 62%)}input[type=checkbox]:hover{border-color:var(--primary-light)}input[type=checkbox]:checked{background:var(--primary);border-color:var(--primary)}input[type=checkbox]:checked:before{transform:scale(1)}input[type=checkbox]:focus-visible{outline:none;box-shadow:0 0 0 3px #2b559740}
