:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#3b82f6;--accent:#0ea5e9;--bg:#f8fafc;--surface:#fff;--border:#e2e8f0;--text:#64748b;--text-h:#0f172a;--text-muted:#94a3b8;--success:#16a34a;--success-bg:#16a34a1a;--warning:#f59e0b;--warning-bg:#f59e0b1a;--danger:#dc2626;--danger-bg:#dc26261a;--info:#0ea5e9;--info-bg:#0ea5e91a;--shadow-sm:0 1px 2px #0000000d;--shadow:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 20px 50px -12px #00000026;--sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, "Cascadia Code", Consolas, monospace;--radius:8px;--radius-lg:12px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.5}#root{min-height:100vh}.layout{min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:10;flex-direction:column;width:240px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{color:var(--text-h);align-items:center;gap:10px;padding:20px;font-size:18px;font-weight:700;display:flex}.sidebar-brand svg{width:28px;height:28px;color:var(--primary)}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px 12px;display:flex}.nav-item{border-radius:var(--radius);color:var(--text);align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg);color:var(--text-h)}.nav-item.active{background:var(--primary);color:#fff}.nav-item svg{flex-shrink:0;width:20px;height:20px}.sidebar-footer{border-top:1px solid var(--border);align-items:center;gap:8px;padding:16px;display:flex}.sidebar-user{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.user-avatar-sm{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:flex}.user-details{flex-direction:column;min-width:0;display:flex}.user-name-sm{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role-sm{color:var(--text);font-size:11px}.logout-btn-sm{cursor:pointer;color:var(--text);background:0 0;border:none;border-radius:6px;padding:6px;transition:all .15s}.logout-btn-sm:hover{background:var(--danger-bg);color:var(--danger)}.logout-btn-sm svg{width:18px;height:18px}.main-content{background:var(--bg);flex:1;min-height:100vh;margin-left:240px;padding:24px 32px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{color:var(--text-h);margin:0;font-size:24px;font-weight:700}.btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:5px 10px;font-size:13px}.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th{text-align:left;color:var(--text);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--bg);padding:12px 16px;font-size:12px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-h);padding:12px 16px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg)}.table-actions{gap:6px;display:flex}.pagination{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:8px;padding:16px;display:flex}.pagination button{border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text-h);border-radius:6px;padding:6px 12px;font-size:13px}.pagination button:disabled{opacity:.5;cursor:default}.pagination span{color:var(--text);font-size:13px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-h);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-h);background:var(--surface);box-sizing:border-box;padding:8px 12px;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.form-actions .btn-cancel{background:var(--bg);color:var(--text);border:1px solid var(--border)}.alert{border-radius:var(--radius);margin-bottom:16px;padding:10px 14px;font-size:13px}.alert-error{background:var(--danger-bg);color:var(--danger)}.alert-success{background:var(--success-bg);color:var(--success)}.status-badge{border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.empty-state{text-align:center;color:var(--text);padding:48px 24px}.empty-state p{margin-top:8px;font-size:14px}.loading{text-align:center;color:var(--text);padding:48px;font-size:14px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.stat-card .stat-label{color:var(--text);font-size:13px;font-weight:500}.stat-card .stat-value{color:var(--text-h);margin-top:4px;font-size:28px;font-weight:700}.dashboard-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.dashboard-grid .full-width{grid-column:1/-1}.kpi-row{grid-column:1/-1;grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.gauge-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;flex-direction:column;align-items:center;gap:4px;padding:20px 16px 16px;display:flex}.gauge-svg{display:block}.gauge-arc{transition:stroke-dashoffset 1.2s cubic-bezier(.25,.46,.45,.94)}.gauge-value-text{font-family:inherit;font-size:18px;font-weight:700}.gauge-footer{align-items:center;gap:8px;margin-top:2px;display:flex}.gauge-label{color:var(--text);font-size:13px;font-weight:500}.kpi-delta{border-radius:4px;align-items:center;gap:2px;padding:2px 6px;font-size:12px;font-weight:600;display:inline-flex}.kpi-delta.positive{color:var(--success);background:var(--success-bg)}.kpi-delta.negative{color:var(--danger);background:var(--danger-bg)}.kpi-delta.neutral{color:var(--text-muted);background:var(--bg)}.kpi-sparkline{margin-top:4px}.funnel-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.funnel-select{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;border-radius:4px;min-width:140px;padding:5px 10px;font-size:13px}.funnel-select:focus{border-color:var(--primary);outline:none}.funnel-caidas{border-top:1px solid var(--border);flex-wrap:wrap;gap:8px;margin-top:12px;padding-top:12px;display:flex}.funnel-caida-item{align-items:center;gap:6px;font-size:12px;display:flex}.funnel-caida-paso{color:var(--text);font-weight:500}.funnel-caida-badge{color:var(--danger);background:var(--danger-bg);border-radius:4px;padding:2px 6px;font-size:11px;font-weight:600}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:20px}.chart-card-title{color:var(--text-h);margin-bottom:16px;font-size:14px;font-weight:600}.donut-legend{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:12px;display:flex}.donut-legend-item{color:var(--text);align-items:center;gap:6px;font-size:13px;display:flex}.donut-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.donut-legend-count{color:var(--text-h);font-weight:600}.alert-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;overflow:hidden}.alert-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.alert-card-title{color:var(--text-h);font-size:14px;font-weight:600}.alert-count{background:var(--danger-bg);color:var(--danger);border-radius:10px;padding:2px 8px;font-size:12px;font-weight:600}.feed-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;max-height:400px;padding:20px;overflow-y:auto}.feed-title{color:var(--text-h);margin-bottom:16px;font-size:14px;font-weight:600}.feed-item{border-bottom:1px solid var(--border);gap:12px;padding:10px 0;display:flex}.feed-item:last-child{border-bottom:none}.feed-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.feed-icon.aprobacion{background:var(--success-bg);color:var(--success)}.feed-icon.rechazo{background:var(--danger-bg);color:var(--danger)}.feed-icon.otro{background:var(--info-bg);color:var(--info)}.feed-content{flex:1;min-width:0}.feed-desc{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.feed-meta{color:var(--text-muted);margin-top:2px;font-size:12px}.operator-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;overflow:hidden}.operator-card-title{color:var(--text-h);border-bottom:1px solid var(--border);padding:16px 20px;font-size:14px;font-weight:600}.progress-bar-bg{background:var(--bg);border-radius:3px;width:100%;height:6px;margin-top:4px;overflow:hidden}.progress-bar-fill{background:var(--success);border-radius:3px;height:100%;transition:width .3s}.advanced-section{border-top:2px solid var(--border);margin-top:32px;padding-top:24px}.advanced-title{color:var(--text-h);margin:0 0 20px;font-size:18px;font-weight:700}.sankey-container{min-height:300px;overflow-x:auto}.sankey-legend{justify-content:center;gap:16px;margin-top:12px;display:flex}.sankey-legend-item{color:var(--text);align-items:center;gap:6px;font-size:13px;display:flex}.sankey-legend-dot{border-radius:2px;flex-shrink:0;width:12px;height:4px}.custom-tooltip{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:10px 14px;font-size:12px;line-height:1.5;box-shadow:0 4px 12px #0000001a}.custom-tooltip p{margin:0}.heatmap-wrapper{width:100%}.heatmap-grid{grid-template-rows:repeat(7,1fr);gap:3px;width:100%;display:grid}.heatmap-cell{aspect-ratio:1;border-radius:3px;width:100%;max-height:28px}.heatmap-day-label{color:var(--text-muted);justify-content:center;align-items:center;font-size:11px;font-weight:500;display:flex}.heatmap-legend{justify-content:flex-end;align-items:center;gap:4px;margin-top:12px;display:flex}.heatmap-legend .heatmap-cell{aspect-ratio:auto;width:14px;height:14px}.heatmap-legend-label{color:var(--text-muted);margin:0 4px;font-size:11px}@media (width<=1200px){.kpi-row{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.dashboard-grid{grid-template-columns:1fr}.kpi-row{grid-template-columns:1fr 1fr}}@media (width<=600px){.kpi-row{grid-template-columns:1fr}}.modal-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:85vh;box-shadow:var(--shadow-lg);overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h3{color:var(--text-h);margin:0;font-size:16px;font-weight:600}.modal-close{cursor:pointer;color:var(--text);background:0 0;border:none;padding:0 4px;font-size:22px;line-height:1}.modal-close:hover{color:var(--text-h)}.modal-body{padding:20px}.login-wrapper{background:linear-gradient(135deg,#0f172a 0%,#1e293b 50%,#0f172a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-wrapper:before{content:"";background:radial-gradient(circle,#2563eb26 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-40%;right:-20%}.login-wrapper:after{content:"";background:radial-gradient(circle,#0ea5e91a 0%,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;bottom:-30%;left:-10%}.login-card{z-index:1;background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);margin:20px;padding:40px;position:relative}.login-header{text-align:center;margin-bottom:32px}.login-logo{background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);border-radius:var(--radius-lg);justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:20px;display:inline-flex}.login-logo svg{color:#fff;width:28px;height:28px}.login-header h1{color:var(--text-h);letter-spacing:-.5px;margin-bottom:6px;font-size:24px;font-weight:700}.login-header p{color:var(--text-muted);font-size:14px}.login-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-h);letter-spacing:.02em;font-size:13px;font-weight:600}.form-group input{width:100%;font-size:14px;font-family:var(--sans);color:var(--text-h);background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.login-btn{width:100%;font-size:14px;font-weight:600;font-family:var(--sans);color:#fff;background:var(--primary);border-radius:var(--radius);cursor:pointer;letter-spacing:.02em;border:none;padding:11px 20px;transition:background .2s,transform .1s}.login-btn:hover:not(:disabled){background:var(--primary-hover)}.login-btn:active:not(:disabled){transform:scale(.985)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:var(--danger);background:var(--danger-bg);border-radius:var(--radius);text-align:center;border:1px solid #dc262633;padding:10px 14px;font-size:13px}.home-wrapper{flex-direction:column;min-height:100vh;display:flex}.home-topbar{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.topbar-brand{align-items:center;gap:12px;display:flex}.topbar-logo{background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);border-radius:var(--radius);justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.topbar-logo svg{color:#fff;width:18px;height:18px}.topbar-brand span{color:var(--text-h);letter-spacing:-.3px;font-size:16px;font-weight:700}.topbar-right{align-items:center;gap:16px;display:flex}.topbar-user{align-items:center;gap:10px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);color:#fff;letter-spacing:.5px;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:var(--text-h);font-size:13px;font-weight:600;line-height:1.2}.user-role{color:var(--text-muted);font-size:11px}.logout-btn{font-size:13px;font-weight:500;font-family:var(--sans);color:var(--danger);background:var(--danger-bg);border-radius:var(--radius);cursor:pointer;border:1px solid #dc262633;padding:8px 16px;transition:background .2s,border-color .2s}.logout-btn:hover{background:#dc262626;border-color:#dc262659}.home-content{flex:1;justify-content:center;align-items:center;padding:32px;display:flex}.welcome-card{text-align:center;max-width:480px}.welcome-icon{background:var(--info-bg);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:20px;display:inline-flex}.welcome-icon svg{width:28px;height:28px;color:var(--primary)}.welcome-card h2{color:var(--text-h);letter-spacing:-.3px;margin-bottom:8px;font-size:22px;font-weight:700}.welcome-card p{color:var(--text-muted);font-size:14px;line-height:1.6}
