:root{--sidebar-w: 240px;--sidebar-w-col: 68px;--navbar-h: 62px;--transition: .25s cubic-bezier(.4,0,.2,1);--border: #e4e6ed;--border-soft: #edf0f5;--surface: #ffffff;--surface-2: #f8f9fb;--surface-3: #f1f3f7;--background: #f4f5f9;--accent: #16a34a;--accent-dark: #15803d;--accent-light: #dcfce7;--accent-soft: #f0fdf4;--text-primary: #111827;--text-secondary: #6b7280;--text-hint: #9ca3af;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.1);--shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.06);--verde: #16a34a;--verde-oscuro: #15803d;--verde-claro: #dcfce7;--verde-suave: #f0fdf4;--radius: 12px}.layout{min-height:100vh;background:var(--background)}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-w);height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:200;overflow-y:auto;overflow-x:hidden;transition:width var(--transition);box-shadow:var(--shadow-sm);scrollbar-width:thin;scrollbar-color:var(--border) transparent}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.layout.collapsed .sidebar{width:var(--sidebar-w-col)}.sidebar-header{height:var(--navbar-h);display:flex;align-items:center;padding:0 1rem 0 1.1rem;border-bottom:1px solid var(--border);gap:.65rem;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0;transition:background var(--transition)}.sidebar-header:hover{background:var(--surface-3)}.sidebar-brand-icon{font-size:1.4rem;flex-shrink:0;line-height:1;display:flex;align-items:center;justify-content:center}.sidebar-logo-img{width:28px;height:28px;-o-object-fit:contain;object-fit:contain;border-radius:6px}.sidebar-brand-info{flex:1;display:flex;flex-direction:column;gap:1px;overflow:hidden;min-width:0}.sidebar-brand-name{font-size:15px;font-weight:700;color:#3b82f6;letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.sidebar-brand-sub{font-size:10.5px;font-weight:600;color:var(--text-hint);letter-spacing:.4px;text-transform:uppercase;white-space:nowrap}.sidebar-collapse-icon{color:var(--text-hint);flex-shrink:0;transition:transform var(--transition)}.layout.collapsed .sidebar-collapse-icon{transform:rotate(180deg)}.sidebar-empresa{padding:10px 14px 8px;border-bottom:1px solid var(--border-soft)}.sidebar-empresa-nombre{font-size:11px;font-weight:700;color:var(--text-secondary);margin:0 0 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase;letter-spacing:.5px}.plan-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase}.plan-prueba{background:#eab30826;color:#92400e}.plan-básico{background:#3b82f626;color:#1d4ed8}.plan-pro{background:var(--accent-light);color:var(--accent-dark)}.plan-trial{background:#eab30826;color:#92400e}.plan-profesional{background:var(--accent-light);color:var(--accent-dark)}.sidebar-nav{flex:1;padding:.75rem .625rem;display:flex;flex-direction:column;gap:2px}.nav-group{margin-bottom:4px}.nav-group-label{display:block;padding:6px 10px 4px;font-size:9.5px;font-weight:700;letter-spacing:1px;color:var(--text-hint);text-transform:uppercase;white-space:nowrap}.nav-item{display:flex;align-items:center;gap:.625rem;padding:.65rem .875rem;border-radius:10px;font-size:13.5px;font-weight:500;color:var(--text-secondary);text-decoration:none;cursor:pointer;transition:all var(--transition);border:none;background:none;width:100%;white-space:nowrap;overflow:hidden;position:relative;font-family:inherit}.nav-item:hover{color:var(--text-primary);background:var(--surface-3)}.nav-item.active{color:var(--accent);background:var(--accent-soft);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--accent);border-radius:0 3px 3px 0}.nav-icon{flex-shrink:0}.nav-emoji{font-size:15px;line-height:1}.nav-label{overflow:hidden;text-overflow:ellipsis}.layout.collapsed .nav-item{justify-content:center;padding:.75rem 0;gap:0}.layout.collapsed .nav-item.active:before{height:14px}.layout.collapsed .nav-label,.layout.collapsed .nav-group-label{display:none}.layout.collapsed .nav-item{position:relative}.layout.collapsed .nav-item:hover:after{content:attr(title);position:fixed;left:calc(var(--sidebar-w-col) + 8px);background:#1f2937;color:#fff;padding:.4rem .875rem;border-radius:6px;font-size:12.5px;white-space:nowrap;z-index:1000;box-shadow:var(--shadow-md);pointer-events:none;font-family:inherit}.sidebar-footer{border-top:1px solid var(--border);padding:8px .625rem 12px;flex-shrink:0}.sidebar-superadmin{display:flex;align-items:center;gap:10px;padding:8px 12px;margin-bottom:4px;border-radius:10px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0;color:#15803d;font-size:12px;font-weight:600}.layout.collapsed .sidebar-superadmin{justify-content:center;padding:10px 0;background:transparent;border:none}.superadmin-crown{font-size:15px}.superadmin-label{white-space:nowrap;overflow:hidden}.logout-btn{color:var(--text-hint)!important}.logout-btn:hover{color:#ef4444!important;background:#ef444414!important}.navbar{position:fixed;top:0;left:var(--sidebar-w);right:0;height:var(--navbar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 1.5rem 0 1.25rem;z-index:100;box-shadow:var(--shadow-sm);transition:left var(--transition)}.layout.collapsed .navbar{left:var(--sidebar-w-col)}.navbar-hamburger{display:none!important}.navbar-right{margin-left:auto;display:flex;align-items:center;gap:6px;position:relative}.navbar-notif{position:relative;color:var(--text-secondary)!important}.navbar-plan-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:99px;font-size:12px;font-weight:700;letter-spacing:.3px;white-space:nowrap}.plan-badge--ok{background:#22c55e1f;color:#166534;border:1px solid rgba(34,197,94,.25)}.plan-badge--warning{background:#eab3081f;color:#92400e;border:1px solid rgba(234,179,8,.3)}.plan-badge--danger{background:#ef44441f;color:#dc2626;border:1px solid rgba(239,68,68,.25)}.plan-badge--expired{background:#6b72801f;color:#374151;border:1px solid rgba(107,114,128,.25)}.user-chip{display:flex;align-items:center;gap:9px;padding:.3rem .75rem .3rem .3rem;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);cursor:pointer;transition:var(--transition);-webkit-user-select:none;-moz-user-select:none;user-select:none}.user-chip:hover{background:var(--surface-3)}.user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:.5px}.user-info{display:flex;flex-direction:column}.user-name{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.2}.user-plan{font-size:10.5px;color:var(--text-hint)}.user-chevron{color:var(--text-hint);transition:transform var(--transition)}.user-chevron.open{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border-radius:12px;box-shadow:0 8px 40px #00000024;border:1px solid var(--border-soft);min-width:240px;z-index:500;overflow:hidden}.dropdown-header{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(135deg,var(--accent-soft),var(--surface))}.dropdown-name{font-size:13.5px;font-weight:700;color:var(--text-primary);margin:0}.dropdown-email{font-size:12px;color:var(--text-hint);margin:0}.dropdown-sep{height:1px;background:var(--border-soft)}.dropdown-item{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:13.5px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:var(--transition);border:none;background:none;width:100%;font-family:inherit}.dropdown-item:hover{background:var(--surface-2);color:var(--accent)}.dropdown-item.danger{color:#dc2626}.dropdown-item.danger:hover{background:#fee2e2;color:#dc2626}.main-area{margin-left:var(--sidebar-w);margin-top:var(--navbar-h);min-height:calc(100vh - var(--navbar-h));background:var(--background);transition:margin-left var(--transition);display:flex;flex-direction:column}.layout.collapsed .main-area{margin-left:var(--sidebar-w-col)}.page-content{flex:1;padding:24px;overflow-y:auto}.plan-alert{display:flex;align-items:center;gap:7px;padding:6px 10px;border-radius:8px;font-size:12.5px;font-weight:600;animation:slideIn .3s ease}.plan-alert-warn{background:#fef9c3;color:#92400e;border:1px solid #fde68a}.plan-alert-danger{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.plan-alert-btn{margin-left:4px;padding:3px 10px;border-radius:6px;border:none;cursor:pointer;font-size:12px;font-weight:700;background:#fff;transition:all var(--transition)}.plan-alert-warn .plan-alert-btn{color:#92400e}.plan-alert-warn .plan-alert-btn:hover{background:#fde68a}.plan-alert-danger .plan-alert-btn{color:#dc2626}.plan-alert-danger .plan-alert-btn:hover{background:#fecaca}.plan-renew-btn{display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,#16a34a,#15803d);color:#fff!important;font-size:12.5px;font-weight:700;padding:7px 14px;border-radius:8px;animation:pulse 2s ease-in-out infinite}.plan-renew-btn:hover{opacity:.9;transform:translateY(-1px)}@keyframes slideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{box-shadow:0 0 #16a34a66}50%{box-shadow:0 0 0 6px #16a34a00}}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:var(--sidebar-w)!important;transition:transform var(--transition),width var(--transition)}.layout.mobile-open .sidebar{transform:translate(0)}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:150}.navbar{left:0!important}.main-area{margin-left:0!important}.navbar-hamburger{display:flex!important}.navbar-plan-badge{display:none}.page-content{padding:16px}}@media (max-width: 640px){.plan-alert span{display:none}.plan-alert-btn{margin-left:0}}.auth-shell{display:flex;min-height:100vh;background:#f4f6f8}.auth-shell-center{align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f0ff,#e0e7ff,#f4f6f8)}.auth-panel{width:420px;background:linear-gradient(160deg,#4f46e5,#312e81 60%,#1e1b4b);display:flex;align-items:center;justify-content:center;padding:48px 40px;position:relative;overflow:hidden;flex-shrink:0}.auth-panel:before{content:"";position:absolute;top:-80px;right:-80px;width:280px;height:280px;border-radius:50%;background:#6366f126}.auth-panel:after{content:"";position:absolute;bottom:-60px;left:-60px;width:200px;height:200px;border-radius:50%;background:#6366f11a}.auth-panel-content{position:relative;z-index:1;display:flex;flex-direction:column;gap:20px}.auth-panel-logo{width:68px;height:68px;background:#6366f159;border:1.5px solid rgba(99,102,241,.5);border-radius:16px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-panel-title{font-size:24px;font-weight:800;color:#fff;line-height:1.3;margin:0}.auth-panel-sub{font-size:14px;color:#fff9;line-height:1.6;margin:0}.auth-features{display:flex;flex-direction:column;gap:12px;margin-top:4px}.auth-feature-item{display:flex;align-items:center;gap:12px;font-size:13.5px;color:#ffffffbf;font-weight:500}.auth-panel-brand{font-size:13px;color:#fff6;margin:8px 0 0}.brand-tracks-w{color:#4ade80;font-weight:800}.auth-form-side{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;min-height:100vh}.auth-form-box{width:100%;max-width:420px;animation:slideUp .3s ease}.auth-mobile-logo{display:none;align-items:center;gap:8px;margin-bottom:28px}.auth-logo-circle{width:36px;height:36px;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:9px;display:flex;align-items:center;justify-content:center}.auth-title{font-size:26px;font-weight:800;color:#1e2532;margin:0 0 6px}.auth-subtitle{font-size:14px;color:#94a3b8;margin:0 0 24px}.auth-alert-error{display:flex;align-items:center;gap:8px;background:#fee2e2;border:1px solid #fecaca;color:#dc2626;border-radius:8px;padding:10px 14px;font-size:13.5px;margin-bottom:16px}.auth-form{display:flex;flex-direction:column;gap:16px}.form-field{display:flex;flex-direction:column;gap:5px}.form-label{font-size:13px;font-weight:600;color:#374151}.form-label-row{display:flex;align-items:center;justify-content:space-between}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field-error{font-size:12px;color:#ef4444;margin:0}.field-hint{font-size:12px;color:#94a3b8;margin:-8px 0 0}.input-icon-wrap{position:relative}.input-icon-wrap .input{padding-right:42px}.input-icon-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#94a3b8;padding:4px;display:flex;align-items:center;transition:color var(--transition)}.input-icon-btn:hover{color:#6366f1}.auth-forgot{font-size:12.5px;color:#6366f1;text-decoration:none;font-weight:600}.auth-forgot:hover{text-decoration:underline}.auth-link{color:#6366f1;font-weight:700;text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-submit{width:100%;justify-content:center;gap:9px}.auth-switch{text-align:center;font-size:13.5px;color:#64748b;margin:20px 0 0}.auth-footer{margin-top:40px;font-size:12px;color:#cbd5e1;text-align:center}.plan-cards{display:flex;flex-direction:column;gap:10px}.plan-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:10px;border:2px solid #e2e8f0;background:#f8fafc;cursor:pointer;transition:all var(--transition)}.plan-card:hover{border-color:#6366f1;background:#f0f0ff}.plan-card.selected{background:#f0f0ff}.plan-card-check{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;flex-shrink:0;transition:background var(--transition)}.plan-nombre{font-size:14px;font-weight:700;margin:0}.plan-precio{font-size:13px;font-weight:700;color:#1e2532;margin:0 0 0 auto}.plan-desc{font-size:11.5px;color:#94a3b8;margin:0;display:none}.reg-steps{display:flex;flex-direction:column;gap:16px;margin-top:8px}.reg-step{display:flex;align-items:center;gap:12px;font-size:13.5px;color:#ffffff73;font-weight:500}.reg-step.active{color:#fff;font-weight:700}.reg-step.done{color:#fff9}.reg-step-num{width:26px;height:26px;border-radius:50%;background:#ffffff1f;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#ffffff80;flex-shrink:0}.reg-step.active .reg-step-num{background:#6366f1;color:#fff}.reg-step.done .reg-step-num{background:#4ade8033;color:#4ade80}.auth-recover-box{width:100%;max-width:400px;background:#fff;border-radius:20px;box-shadow:0 8px 40px #0000001a;border:1px solid #f1f5f9;padding:40px 36px;text-align:center;animation:slideUp .3s ease}.auth-icon-circle{width:60px;height:60px;border-radius:50%;background:#f0f0ff;border:2px solid #e0e7ff;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.auth-recover-box .auth-form{text-align:left}.auth-back-link{display:inline-flex;align-items:center;gap:6px;margin-top:20px;font-size:13px;color:#64748b;text-decoration:none;transition:color var(--transition)}.auth-back-link:hover{color:#6366f1}.auth-success-state{display:flex;flex-direction:column;align-items:center;gap:12px}.auth-success-icon{font-size:52px}.auth-hint{font-size:12.5px;color:#94a3b8}@media (max-width: 900px){.auth-panel{display:none}.auth-mobile-logo{display:flex}.auth-form-side{background:#fff}}@media (max-width: 480px){.auth-form-side{padding:32px 20px}.auth-form-box{max-width:100%}.form-row-2{grid-template-columns:1fr}.auth-recover-box{padding:32px 24px}.auth-title{font-size:22px}}.dash-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:16px;color:#94a3b8;font-size:14px}.spin-icon{animation:spin .8s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.dash-banner{background:linear-gradient(135deg,#052e16,#14532d 60%,#166534);border-radius:16px;padding:22px 28px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;position:relative;overflow:hidden;box-shadow:0 8px 32px #16a34a59}.dash-banner:before{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(134,239,172,.15) 0%,transparent 70%);border-radius:50%;pointer-events:none}.dash-banner:after{content:"";position:absolute;right:80px;bottom:-60px;width:150px;height:150px;background:radial-gradient(circle,rgba(22,163,74,.12) 0%,transparent 70%);border-radius:50%;pointer-events:none}.dash-banner-title{font-size:22px;font-weight:800;color:#fff;margin:0 0 4px;letter-spacing:-.3px;position:relative;z-index:1}.dash-banner-sub{font-size:13px;color:#86efacd9;margin:0;position:relative;z-index:1;text-transform:capitalize}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}.kpi-card{background:#fff;border-radius:16px;border:1px solid rgba(22,163,74,.08);box-shadow:0 4px 20px #16a34a12;padding:18px 20px;display:flex;align-items:center;gap:14px;transition:box-shadow .2s,transform .2s;position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#16a34a,#22c55e);border-radius:16px 16px 0 0}.kpi-card:hover{box-shadow:0 10px 36px #16a34a24;transform:translateY(-2px)}.kpi-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-body{flex:1;min-width:0}.kpi-titulo{font-size:11.5px;color:#94a3b8;font-weight:600;margin:0 0 4px;white-space:nowrap;text-transform:uppercase;letter-spacing:.4px}.kpi-valor{font-size:21px;font-weight:800;color:#1e2532;margin:0;line-height:1.2}.kpi-sub{font-size:11px;color:#cbd5e1;margin:3px 0 0}.kpi-trend{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:11px;font-weight:700;padding:6px 8px;border-radius:8px}.kpi-trend.up{background:#dcfce7;color:#15803d}.kpi-trend.down{background:#fee2e2;color:#dc2626}.hoy-strip{background:linear-gradient(135deg,#052e16,#14532d);border-radius:14px;padding:16px 22px;display:flex;align-items:center;gap:20px;margin-bottom:16px;flex-wrap:wrap;box-shadow:0 4px 20px #052e164d;position:relative;overflow:hidden}.hoy-strip:before{content:"";position:absolute;right:-20px;top:-20px;width:120px;height:120px;background:radial-gradient(circle,rgba(134,239,172,.1) 0%,transparent 70%);border-radius:50%;pointer-events:none}.hoy-label{font-size:13px;font-weight:700;color:#86efac;white-space:nowrap;position:relative;z-index:1}.hoy-items{display:flex;align-items:center;gap:20px;flex-wrap:wrap;position:relative;z-index:1}.hoy-item{display:flex;align-items:baseline;gap:6px}.hoy-num{font-size:24px;font-weight:800;color:#fff}.hoy-desc{font-size:12px;color:#ffffff8c}.hoy-sep{width:1px;height:32px;background:#ffffff26}.dash-row-main{display:grid;grid-template-columns:1fr 320px;gap:14px;margin-bottom:16px}.dash-page .card{border-radius:16px;border:1px solid rgba(22,163,74,.08);box-shadow:0 4px 20px #16a34a0f}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.card-title{font-size:14px;font-weight:700;color:#1e2532;margin:0}.card-sub{font-size:12px;color:#94a3b8}.dash-chart-card{padding:20px 22px}.dash-side-card{padding:20px 18px;overflow:hidden}.chart-tooltip{background:#fff;border:1px solid rgba(22,163,74,.12);border-radius:10px;padding:10px 14px;box-shadow:0 8px 24px #16a34a1f;font-size:12.5px;color:#374151}.chart-tooltip-label{font-weight:700;color:#1e2532;margin:0 0 6px}.chart-tooltip p{margin:2px 0}.ult-list{display:flex;flex-direction:column;gap:2px}.ult-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid #f8fafc}.ult-item:last-child{border-bottom:none}.ult-avatar{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#16a34a1f,#dcfce7);color:#16a34a;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ult-info{flex:1;min-width:0}.ult-nombre{font-size:13px;font-weight:600;color:#1e2532;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ult-meta{font-size:11px;color:#94a3b8;margin:0}.ult-monto{font-size:13px;font-weight:700;color:#16a34a;white-space:nowrap}.dash-alert-card{padding:20px 22px;margin-bottom:16px;border-left:4px solid #f59e0b;background:linear-gradient(to right,#fffbeb,#fff 40%)}.table-wrap{overflow-x:auto}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl thead th{text-align:left;padding:10px 12px;font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #f1f5f9;white-space:nowrap}.tbl tbody td{padding:11px 12px;border-bottom:1px solid #f8fafc;color:#374151;vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr:hover td{background:#f7fdf9}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.2px;white-space:nowrap}.badge-yellow{background:#fef9c3;color:#92400e}.pred-section{margin-top:20px}.pred-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;gap:16px;flex-wrap:wrap}.pred-title{font-size:18px;font-weight:800;color:#1e2532;margin:0 0 4px;display:flex;align-items:center;gap:8px}.pred-title-badge{font-size:11px;font-weight:700;color:#16a34a;background:#f0fdf4;padding:3px 10px;border-radius:99px;letter-spacing:.3px}.pred-sub{font-size:13px;color:#94a3b8;margin:0}.pred-tabs{display:flex;gap:4px;background:#f4f6f9;border-radius:12px;padding:4px;border:1px solid rgba(22,163,74,.08)}.pred-tab{padding:7px 18px;border-radius:9px;font-size:13px;font-weight:600;color:#64748b;border:none;background:none;cursor:pointer;transition:all .2s;font-family:inherit}.pred-tab.active{background:#fff;color:#16a34a;box-shadow:0 2px 8px #16a34a26}.pred-tab:hover:not(.active){color:#1e2532}.pred-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.pred-empty{grid-column:1 / -1}.pred-card{background:#fff;border-radius:14px;border:1px solid rgba(22,163,74,.08);box-shadow:0 2px 12px #16a34a0f;padding:18px;display:flex;flex-direction:column;gap:12px;transition:box-shadow .2s,transform .2s}.pred-card:hover{box-shadow:0 8px 28px #16a34a1f;transform:translateY(-2px)}.pred-card-top{display:flex;align-items:center;gap:10px}.pred-rank{font-size:11px;font-weight:800;color:#16a34a;background:linear-gradient(135deg,#f0fdf4,#dcfce7);width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pred-prov-info{flex:1;min-width:0}.pred-nombre{font-size:13.5px;font-weight:700;color:#1e2532;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pred-ruc{font-size:11px;color:#94a3b8;margin:0}.pred-score-wrap{display:flex;align-items:center;gap:6px}.pred-score-bar{width:52px;height:5px;background:#f1f5f9;border-radius:99px;overflow:hidden}.pred-score-fill{height:100%;background:linear-gradient(90deg,#16a34a,#86efac);border-radius:99px}.pred-score-num{font-size:11px;font-weight:700;color:#16a34a}.pred-stats{display:flex;gap:0;border:1px solid rgba(22,163,74,.1);border-radius:10px;overflow:hidden;background:#f7fdf9}.pred-stat{flex:1;padding:9px 10px;text-align:center;border-right:1px solid rgba(22,163,74,.08)}.pred-stat:last-child{border-right:none}.pred-stat-label{font-size:10px;color:#94a3b8;display:block;margin-bottom:2px;text-transform:uppercase;letter-spacing:.3px}.pred-stat-val{font-size:12.5px;font-weight:700;color:#1e2532}.pred-recom{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;border-radius:10px;font-size:12px;line-height:1.5}.pred-recom p{margin:0;flex:1}.recom-excelente{background:#f0fdf4;color:#15803d}.recom-bueno{background:#eff6ff;color:#1d4ed8}.recom-normal,.recom-inactivo{background:#f8fafc;color:#64748b}.recom-alerta{background:#fffbeb;color:#92400e}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#94a3b8;gap:10px;text-align:center}.empty-state .icon{font-size:32px;opacity:.7}.empty-state p{font-size:13px;margin:0}@media (max-width: 1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.dash-row-main{grid-template-columns:1fr}}@media (max-width: 640px){.kpi-grid{grid-template-columns:1fr}.hoy-strip{flex-direction:column;align-items:flex-start;gap:10px}.pred-header{flex-direction:column}.pred-tabs{width:100%}.pred-tab{flex:1;text-align:center}.page-header{padding:18px 20px}.page-title{font-size:18px}}.prov-toolbar{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:12px;flex-wrap:wrap}.prov-search{flex:1;min-width:220px}.prov-filters{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.filter-chip{padding:5px 12px;border-radius:20px;font-size:12.5px;font-weight:600;color:#64748b;background:#f4f6f8;border:1.5px solid #e2e8f0;cursor:pointer;transition:all var(--transition);font-family:inherit}.filter-chip:hover{border-color:#6366f1;color:#6366f1}.filter-chip.active{background:#f0f0ff;border-color:#6366f1;color:#6366f1}.prov-nombre-cell{display:flex;align-items:center;gap:10px}.prov-avatar{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.prov-nombre{font-size:13.5px;font-weight:600;color:#1e2532;margin:0}.prov-empresa{font-size:11.5px;color:#94a3b8;margin:0}.row-inactivo td{opacity:.55}.table-actions{display:flex;align-items:center;justify-content:center;gap:2px}.mono-text{font-family:JetBrains Mono,monospace;font-size:12.5px;color:#374151}.skel{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:4px}@keyframes shimmer{to{background-position:-200% 0}}.detalle-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;background:#f8fafc;border-radius:10px;padding:14px 16px}.detalle-kpi{text-align:center}.detalle-kpi-label{font-size:11px;color:#94a3b8;font-weight:600;margin:0 0 4px;text-transform:uppercase;letter-spacing:.4px}.detalle-kpi-val{font-size:17px;font-weight:800;color:#1e2532;margin:0}.detalle-tabs{display:flex;gap:0;border-bottom:2px solid #f1f5f9;margin-bottom:16px}.detalle-tab{padding:8px 18px;font-size:13.5px;font-weight:600;color:#94a3b8;background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition);font-family:inherit}.detalle-tab.active{color:#6366f1;border-bottom-color:#6366f1}.detalle-tab:hover:not(.active){color:#374151}.detalle-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.detalle-info-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:#f8fafc;border-radius:8px}.detalle-info-item svg{color:#94a3b8;margin-top:2px;flex-shrink:0}.info-label{font-size:10.5px;color:#94a3b8;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin:0}.info-val{font-size:13.5px;color:#1e2532;font-weight:500;margin:3px 0 0;word-break:break-all}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.req{color:#ef4444}@media (max-width: 600px){.form-grid-2{grid-template-columns:1fr}.detalle-kpis{grid-template-columns:1fr 1fr}.detalle-info-grid{grid-template-columns:1fr}}.cli-toolbar{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:12px;flex-wrap:wrap}.cli-search{flex:1;min-width:220px}.cli-avatar{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cli-nombre{font-size:13.5px;font-weight:600;color:#1e2532;margin:0}.cli-empresa{font-size:11.5px;color:#94a3b8;margin:0}.cli-nombre-cell{display:flex;align-items:center;gap:10px}.compras-toolbar{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:12px;flex-wrap:wrap}.date-range{display:flex;align-items:center;gap:8px}.input-sm{padding:7px 10px;font-size:13px}.compra-form{display:flex;flex-direction:column;gap:18px}.compra-header-fields{display:grid;grid-template-columns:1fr 180px;gap:14px}.prov-selector{display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.prov-sel-nombre{font-weight:600;color:#1e2532}.prov-dropdown{position:absolute;top:100%;left:0;right:0;z-index:300;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 32px #0000001f;margin-top:4px;overflow:hidden}.prov-search-wrap{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid #f1f5f9}.prov-search-in{border:none;outline:none;font-family:inherit;font-size:13.5px;flex:1;color:#1e2532}.prov-list{max-height:220px;overflow-y:auto}.prov-option{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background var(--transition)}.prov-option:hover{background:#f0f0ff}.prov-opt-avatar{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.prov-opt-nombre{font-size:13.5px;font-weight:600;color:#1e2532;margin:0}.prov-opt-ruc{font-size:11px;color:#94a3b8;margin:0;font-family:monospace}.prov-empty{padding:20px;text-align:center;color:#94a3b8;font-size:13px}.anticipos-box{background:#fffbeb;border:1.5px solid #fde68a;border-radius:10px;padding:14px 16px}.anticipos-titulo{font-size:13px;font-weight:700;color:#92400e;margin:0 0 10px}.anticipos-list{display:flex;flex-wrap:wrap;gap:8px}.anticipo-chip{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:8px;border:1.5px solid #fde68a;background:#fff;cursor:pointer;transition:all var(--transition)}.anticipo-chip:hover{border-color:#f59e0b}.anticipo-chip.selected{border-color:#f59e0b;background:#fffbeb}.ant-monto{font-weight:700;font-size:14px;color:#92400e;margin:0}.ant-fecha{font-size:11px;color:#94a3b8;margin:0}.ant-check{color:#f59e0b;font-weight:800;font-size:14px}.lineas-section{border:1.5px solid #e8edf2;border-radius:10px;overflow:hidden}.lineas-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#f8fafc;border-bottom:1px solid #e8edf2}.lineas-titulo{font-size:13px;font-weight:700;color:#1e2532;margin:0}.lineas-table-wrap{overflow-x:auto}.lineas-table{width:100%;border-collapse:collapse}.lineas-table th{background:#f8fafc;padding:8px 10px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e8edf2;text-align:left;white-space:nowrap}.lineas-table td{padding:8px 10px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.lineas-table tr:last-child td{border-bottom:none}.linea-stock{font-size:10.5px;color:#94a3b8;margin:3px 0 0}.linea-unidad{font-size:13px;font-weight:600;color:#64748b}.linea-sub{font-size:13.5px;font-weight:700;color:#6366f1}.compra-totales{display:flex;flex-direction:column;gap:6px;align-items:flex-end;padding:12px 0 0;border-top:1.5px solid #f1f5f9}.total-row{display:flex;gap:40px;justify-content:flex-end;align-items:center;font-size:13.5px;color:#374151;min-width:280px}.total-row span:first-child{flex:1;text-align:right;color:#94a3b8}.total-row span:last-child{min-width:110px;text-align:right;font-weight:600}.anticipo-row span:last-child{color:#f59e0b}.total-final{margin-top:4px;padding-top:8px;border-top:1.5px solid #e2e8f0}.total-final span{font-size:16px!important;font-weight:800!important;color:#1e2532!important}.detalle-compra{display:flex;flex-direction:column;gap:0}.compra-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:4px}.compra-info-item{background:#f8fafc;border-radius:8px;padding:10px 14px}.ci-label{font-size:10.5px;color:#94a3b8;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin:0}.ci-val{font-size:14px;font-weight:700;color:#1e2532;margin:3px 0 0}.ci-sub{font-size:11px;color:#64748b;margin:0;font-family:monospace}.ci-val.mono{font-family:JetBrains Mono,monospace;color:#6366f1}.anticipos-aplicados{background:#fffbeb;border-radius:8px;padding:12px 14px;margin-top:12px}.ant-ap-titulo{font-size:12px;font-weight:700;color:#92400e;margin:0 0 8px}.ant-ap-item{display:flex;justify-content:space-between;font-size:13px;color:#374151;padding:3px 0}.ant-ap-monto{font-weight:700;color:#f59e0b}.compra-notas{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;background:#f8fafc;border-radius:8px;margin-top:12px}.compra-notas p{font-size:13px;color:#64748b;margin:0;font-style:italic}@media (max-width: 600px){.compra-header-fields,.compra-info-grid{grid-template-columns:1fr}.compras-toolbar{flex-direction:column;align-items:stretch}.date-range{flex-wrap:wrap}}.inv-tabs{display:flex;gap:4px;background:#f4f6f8;border-radius:10px;padding:4px;margin-bottom:16px;width:-moz-fit-content;width:fit-content}.inv-tab{padding:8px 18px;border-radius:7px;font-size:13px;font-weight:600;color:#64748b;border:none;background:none;cursor:pointer;transition:all var(--transition);font-family:inherit;display:flex;align-items:center;gap:6px}.inv-tab.active{background:#fff;color:#6366f1;box-shadow:var(--shadow)}.inv-tab:hover:not(.active){color:#1e2532}.inv-toolbar{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:12px;flex-wrap:wrap}.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.prod-card{background:#fff;border-radius:12px;border:1.5px solid #f1f5f9;padding:16px;cursor:pointer;transition:all var(--transition);position:relative;overflow:hidden}.prod-card:hover{border-color:#6366f1;box-shadow:var(--shadow-md);transform:translateY(-2px)}.prod-card-alerta{border-color:#fde68a!important}.prod-card-sin-stock{border-color:#fecaca!important}.prod-card-codigo{font-family:JetBrains Mono,monospace;font-size:11px;color:#6366f1;font-weight:700;background:#f0f0ff;padding:2px 8px;border-radius:4px;display:inline-block;margin-bottom:8px}.prod-card-nombre{font-size:14px;font-weight:700;color:#1e2532;margin:0 0 4px}.prod-card-familia{font-size:11.5px;color:#94a3b8;margin:0 0 12px}.prod-card-stock{display:flex;align-items:baseline;gap:6px;font-size:22px;font-weight:800;color:#1e2532}.prod-card-unidad{font-size:13px;color:#94a3b8;font-weight:500}.prod-card-alerta-badge{position:absolute;top:12px;right:12px;font-size:10px;font-weight:700;padding:2px 8px;border-radius:99px}.prod-card-precio{font-size:12px;color:#64748b;margin:6px 0 0}.catalogo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.catalogo-card{background:#fff;border-radius:10px;border:1.5px solid #f1f5f9;padding:14px 16px;transition:var(--transition)}.catalogo-card:hover{border-color:#6366f1}.catalogo-prefijo{font-family:monospace;font-size:11px;font-weight:800;color:#6366f1;background:#f0f0ff;padding:2px 8px;border-radius:4px;display:inline-block;margin-bottom:6px}.catalogo-nombre{font-size:14px;font-weight:700;color:#1e2532;margin:0 0 4px}.catalogo-sub{font-size:12px;color:#94a3b8;margin:0}.catalogo-actions{display:flex;gap:4px;margin-top:10px;justify-content:flex-end}.historial-list{display:flex;flex-direction:column;gap:6px;max-height:400px;overflow-y:auto}.hist-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;background:#f8fafc}.hist-tipo{font-size:10px;font-weight:800;text-transform:uppercase;padding:3px 8px;border-radius:4px;letter-spacing:.4px;white-space:nowrap}.hist-compra{background:#dcfce7;color:#15803d}.hist-salida{background:#dbeafe;color:#1d4ed8}.hist-ajuste{background:#f3f4f6;color:#374151}.hist-devolucion{background:#fef9c3;color:#92400e}.hist-info{flex:1}.hist-fecha{font-size:12px;color:#94a3b8;margin:0}.hist-cantidad{font-size:13px;font-weight:700}.hist-positivo{color:#15803d}.hist-negativo{color:#dc2626}.hist-stock{font-size:11px;color:#64748b;margin:0}.hist-usuario{font-size:11.5px;color:#64748b}.ajuste-info{background:#f8fafc;border-radius:10px;padding:14px 16px;margin-bottom:16px}.ajuste-info p{margin:0}.ajuste-stock-actual{font-size:24px;font-weight:800;color:#1e2532}@media (max-width: 640px){.inv-tabs{width:100%}.inv-tab{flex:1;justify-content:center}.prod-grid{grid-template-columns:1fr 1fr}.catalogo-grid{grid-template-columns:1fr}}.ant-toolbar{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:12px;flex-wrap:wrap}.ant-alertas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;margin-bottom:14px}.ant-alerta-card{background:#fff;border-radius:11px;border:1.5px solid #fde68a;padding:14px 16px;display:flex;flex-direction:column;gap:6px}.ant-alerta-card.critico{border-color:#fecaca;background:#fff5f5}.ant-alerta-card.alto{border-color:#fde68a}.ant-alerta-card.normal{border-color:#e2e8f0}.ant-alerta-nombre{font-weight:700;font-size:13.5px;color:#1e2532;margin:0}.ant-alerta-monto{font-weight:800;font-size:18px;color:#f59e0b;margin:0}.ant-alerta-monto.critico{color:#ef4444}.ant-alerta-accion{font-size:12px;color:#64748b;margin:0;line-height:1.4}.ant-resumen-strip{background:linear-gradient(135deg,#14532d,#16a34a);border-radius:12px;padding:14px 20px;display:flex;align-items:center;gap:24px;margin-bottom:14px;flex-wrap:wrap}.ant-resumen-item{text-align:center}.ant-resumen-val{font-size:20px;font-weight:800;color:#fff;margin:0}.ant-resumen-lbl{font-size:11px;color:#fff9;margin:0}.ant-resumen-sep{width:1px;height:36px;background:#fff3}.cam-tabs{display:flex;gap:4px;background:#f4f6f8;border-radius:10px;padding:4px;margin-bottom:16px;width:-moz-fit-content;width:fit-content}.cam-tab{padding:8px 18px;border-radius:7px;font-size:13px;font-weight:600;color:#64748b;border:none;background:none;cursor:pointer;transition:all var(--transition);font-family:inherit;display:flex;align-items:center;gap:6px}.cam-tab.active{background:#fff;color:#16a34a;box-shadow:var(--shadow)}.camiones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.camion-card{background:#fff;border-radius:12px;border:1.5px solid #f1f5f9;padding:18px;box-shadow:var(--shadow);transition:all var(--transition);position:relative}.camion-card:hover{border-color:#16a34a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.camion-placa{font-family:JetBrains Mono,monospace;font-size:13px;font-weight:800;background:#dcfce7;color:#15803d;padding:3px 10px;border-radius:5px;display:inline-block;margin-bottom:10px;letter-spacing:1px}.camion-nombre{font-size:16px;font-weight:800;color:#1e2532;margin:0 0 4px}.camion-info{font-size:12.5px;color:#64748b;margin:0 0 2px}.camion-conductor{font-size:13px;font-weight:600;color:#374151;margin:8px 0 0;display:flex;align-items:center;gap:6px}.camion-rutas-hoy{position:absolute;top:14px;right:14px}.agenda-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.agenda-fecha-nav{display:flex;align-items:center;gap:8px}.agenda-fecha-label{font-size:15px;font-weight:700;color:#1e2532;min-width:200px;text-align:center}.agenda-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}.ruta-card{background:#fff;border-radius:12px;border:1.5px solid #f1f5f9;padding:16px;box-shadow:var(--shadow);position:relative;transition:all var(--transition)}.ruta-card:hover{box-shadow:var(--shadow-md)}.ruta-card.en_ruta{border-left:4px solid #16a34a}.ruta-card.completada{border-left:4px solid #15803d;opacity:.9}.ruta-card.cancelada{border-left:4px solid #ef4444;opacity:.6}.ruta-card.programada{border-left:4px solid #f59e0b}.ruta-tipo-badge{position:absolute;top:14px;right:14px}.ruta-hora{font-size:13px;font-weight:700;color:#64748b;margin:0 0 6px;display:flex;align-items:center;gap:6px}.ruta-camion{font-size:12px;font-weight:700;color:#15803d;background:#dcfce7;padding:2px 8px;border-radius:4px;display:inline-block;margin-bottom:8px}.ruta-contacto{font-size:13px;font-weight:700;color:#1e2532;margin:0 0 2px}.ruta-tel{font-size:12px;color:#64748b;margin:0}.ruta-dir{font-size:12px;color:#64748b;margin:4px 0 0;display:flex;align-items:flex-start;gap:4px}.ruta-notas{font-size:12px;color:#94a3b8;margin:6px 0 0;font-style:italic}.ruta-actions{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap}.seguimiento-strip{background:linear-gradient(135deg,#14532d,#16a34a);border-radius:12px;padding:14px 20px;display:flex;align-items:center;gap:20px;margin-bottom:14px;flex-wrap:wrap}.seg-item{text-align:center}.seg-val{font-size:22px;font-weight:800;color:#fff;margin:0}.seg-lbl{font-size:10.5px;color:#fff9;margin:0}.seg-sep{width:1px;height:32px;background:#fff3}.estado-programada{background:#fef9c3;color:#92400e}.estado-en_ruta{background:#dbeafe;color:#1d4ed8}.estado-completada{background:#dcfce7;color:#15803d}.estado-cancelada{background:#fee2e2;color:#dc2626}.rep-tabs{display:flex;gap:4px;background:#f4f6f8;border-radius:10px;padding:4px;margin-bottom:20px;width:-moz-fit-content;width:fit-content;flex-wrap:wrap}.rep-tab{padding:8px 18px;border-radius:7px;font-size:13px;font-weight:600;color:#64748b;border:none;background:none;cursor:pointer;transition:all var(--transition);font-family:inherit}.rep-tab.active{background:#fff;color:#16a34a;box-shadow:var(--shadow)}.rep-card{padding:24px}.rep-section-title{font-size:16px;font-weight:800;color:#1e2532;margin:0 0 4px}.rep-section-sub{font-size:13px;color:#94a3b8;margin:0 0 20px}.rep-filtros{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;margin-bottom:20px}.rep-filtros .form-field{margin:0}.rep-filtros label{font-size:12px;font-weight:600;color:#374151;display:block;margin-bottom:4px}.rep-botones{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}.rep-btn-accion{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 20px;border-radius:12px;border:1.5px solid #e2e8f0;background:#fff;cursor:pointer;transition:all var(--transition);font-family:inherit;min-width:140px}.rep-btn-accion:hover{border-color:#16a34a;background:#f0fdf4;transform:translateY(-2px);box-shadow:var(--shadow-md)}.rep-btn-accion .rep-btn-icon{font-size:28px}.rep-btn-accion .rep-btn-label{font-size:13px;font-weight:700;color:#1e2532}.rep-btn-accion .rep-btn-desc{font-size:11px;color:#94a3b8;text-align:center}.rep-preview{margin-top:20px;border-top:1.5px solid #f1f5f9;padding-top:20px}.rep-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.rep-preview-title{font-size:14px;font-weight:700;color:#1e2532}.rep-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.rep-kpi{background:#f8fafc;border-radius:10px;padding:14px;text-align:center}.rep-kpi-val{font-size:20px;font-weight:800;color:#1e2532;margin:0 0 2px}.rep-kpi-lbl{font-size:11.5px;color:#94a3b8;margin:0}.usr-nombre-cell{display:flex;align-items:center;gap:10px}.usr-avatar{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.usr-nombre{font-size:13.5px;font-weight:600;color:#1e2532;margin:0}.usr-correo{font-size:12px;color:#94a3b8;margin:0}.plan-uso-card{padding:16px 20px;margin-bottom:14px}.plan-progress-bar{height:8px;background:#f1f5f9;border-radius:99px;overflow:hidden}.plan-progress-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,#6366f1,#4f46e5);transition:width .5s ease}.roles-list{display:flex;flex-direction:column;gap:10px}.rol-card{background:#fff;border-radius:12px;border:1.5px solid #f1f5f9;box-shadow:var(--shadow);overflow:hidden;transition:border-color var(--transition)}.rol-card.expanded{border-color:#16a34a}.rol-card-header{display:flex;align-items:center;gap:12px;padding:16px 18px;cursor:pointer;transition:background var(--transition)}.rol-card-header:hover{background:#f8fafc}.rol-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#16a34a,#15803d);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.rol-info{flex:1;min-width:0}.rol-nombre{font-size:15px;font-weight:700;color:#1e2532;margin:0}.rol-descripcion{font-size:12px;color:#94a3b8;margin:2px 0 0}.rol-permisos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;padding:16px 20px;background:#f8fafc;border-top:1.5px solid #f1f5f9}.rol-perm-modulo-titulo{font-size:11px;font-weight:800;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin:0 0 6px}.rol-perm-badges{display:flex;flex-wrap:wrap;gap:4px}.permisos-matriz{border:1.5px solid #e2e8f0;border-radius:10px;overflow:hidden;max-height:380px;overflow-y:auto}.permiso-modulo{border-bottom:1px solid #f1f5f9}.permiso-modulo:last-child{border-bottom:none}.permiso-modulo-header{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;background:#f8fafc;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background var(--transition)}.permiso-modulo-header:hover{background:#f0fdf4}.permiso-expand-btn{background:none;border:none;cursor:pointer;color:#94a3b8;display:flex;padding:0}.permiso-modulo-nombre{font-size:13px;font-weight:700;color:#1e2532;flex:1}.permiso-modulo-count{font-size:11px;color:#94a3b8;background:#e2e8f0;padding:1px 7px;border-radius:99px}.permiso-items{display:flex;flex-wrap:wrap;gap:4px;padding:8px 14px 12px}.permiso-item{display:flex;align-items:center;gap:7px;padding:5px 10px;border-radius:6px;border:1.5px solid #e2e8f0;background:#fff;cursor:pointer;transition:all var(--transition);font-size:12px}.permiso-item:hover{border-color:#16a34a}.permiso-item.checked{background:#f0fdf4;border-color:#16a34a}.permiso-accion{font-weight:600;color:#1e2532}.permiso-clave{font-size:10px;color:#94a3b8;font-family:monospace}@media (max-width:640px){.rol-permisos-grid{grid-template-columns:1fr 1fr}.rol-card-header{flex-wrap:wrap}}.correo-form-card{padding:24px;max-width:680px}.correo-toolbar{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:12px;flex-wrap:wrap}.editor-html{font-family:monospace;font-size:13px;min-height:200px;resize:vertical}.preview-html{border:1px solid #e2e8f0;border-radius:8px;padding:16px;background:#fff;min-height:100px;overflow:auto}.adj-lista{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.adj-chip{display:flex;align-items:center;gap:6px;background:#f1f5f9;border-radius:6px;padding:4px 10px;font-size:12px;color:#374151}.adj-chip button{background:none;border:none;cursor:pointer;color:#94a3b8;padding:0;display:flex}.adj-chip button:hover{color:#ef4444}.config-tabs{display:flex;gap:4px;background:#f4f6f8;border-radius:10px;padding:4px;margin-bottom:20px;width:-moz-fit-content;width:fit-content;flex-wrap:wrap}.config-tab{padding:8px 18px;border-radius:7px;font-size:13px;font-weight:600;color:#64748b;border:none;background:none;cursor:pointer;transition:all var(--transition);font-family:inherit}.config-tab.active{background:#fff;color:#16a34a;box-shadow:var(--shadow)}.config-section{max-width:640px}.config-card{padding:24px;margin-bottom:16px}.logo-area{display:flex;align-items:center;gap:20px;margin-bottom:20px;padding:20px;background:#f8fafc;border-radius:12px;border:2px dashed #e2e8f0;transition:border-color var(--transition)}.logo-area:hover{border-color:#16a34a}.logo-preview{width:96px;height:96px;border-radius:12px;-o-object-fit:contain;object-fit:contain;background:#fff;border:1px solid #e2e8f0;padding:4px}.logo-placeholder{width:96px;height:96px;border-radius:12px;background:linear-gradient(135deg,#16a34a,#15803d);display:flex;align-items:center;justify-content:center;font-size:36px;flex-shrink:0}.logo-info{flex:1}.logo-nombre{font-weight:800;font-size:16px;color:#1e2532;margin:0 0 4px}.logo-plan{font-size:13px;color:#94a3b8;margin:0 0 12px}.logo-btn-wrap{display:flex;gap:8px}.plan-card-config{background:linear-gradient(135deg,#14532d,#15803d);border-radius:12px;padding:20px;color:#fff;margin-bottom:16px}.plan-card-nombre{font-size:22px;font-weight:800;color:#86efac;margin:0 0 4px}.plan-card-info{font-size:13px;color:#fff9;margin:0 0 14px}.plan-dias-badge{display:inline-flex;align-items:center;gap:6px;background:#ffffff26;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600}.smtp-test-result{padding:10px 14px;border-radius:8px;font-size:13px;font-weight:600;margin-top:12px;display:flex;align-items:center;gap:8px}.smtp-ok{background:#dcfce7;color:#15803d}.smtp-error{background:#fee2e2;color:#dc2626}.renovar-wrap{max-width:1000px}.renovar-grid{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}.renovar-card{padding:28px}.renovar-plan-info{text-align:center;margin-bottom:24px;padding-bottom:20px;border-bottom:1.5px solid #f1f5f9}.renovar-plan-badge{display:inline-block;background:#dcfce7;color:#15803d;font-size:12px;font-weight:700;padding:4px 14px;border-radius:99px;margin-bottom:10px}.renovar-plan-precio{font-size:42px;font-weight:800;color:#1e2532;line-height:1}.renovar-plan-precio span{font-size:18px;color:#94a3b8;font-weight:500}.renovar-plan-desc{font-size:12.5px;color:#64748b;margin:8px 0 0}.renovar-tabs{display:flex;gap:4px;background:#f4f6f8;border-radius:10px;padding:4px;margin-bottom:24px}.renovar-tab{flex:1;padding:9px 12px;border-radius:7px;font-size:13px;font-weight:600;color:#64748b;border:none;background:none;cursor:pointer;transition:all var(--transition);font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px}.renovar-tab.active{background:#fff;color:#16a34a;box-shadow:var(--shadow)}.renovar-tab.disabled{opacity:.5;cursor:not-allowed}.renovar-tab-soon{font-size:10px;font-weight:700;background:#f1f5f9;color:#94a3b8;padding:1px 6px;border-radius:99px}.renovar-form{display:flex;flex-direction:column;gap:16px}.renovar-bank-info{background:#f8fafc;border-radius:10px;padding:16px;border:1.5px solid #f1f5f9;display:flex;flex-direction:column;gap:8px}.renovar-bank-title{font-size:12px;font-weight:800;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin:0 0 4px}.renovar-bank-row{display:flex;justify-content:space-between;font-size:13px;color:#374151}.renovar-bank-row span{color:#94a3b8}.renovar-upload-area{display:block;border:2px dashed #e2e8f0;border-radius:10px;padding:20px;cursor:pointer;text-align:center;transition:border-color var(--transition);min-height:100px}.renovar-upload-area:hover{border-color:#16a34a}.renovar-upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px}.renovar-upload-placeholder span{font-size:13px;color:#64748b;font-weight:500}.renovar-upload-placeholder small{font-size:11px;color:#94a3b8}.renovar-upload-file{display:flex;align-items:center;gap:10px;color:#16a34a;font-size:13px;font-weight:600}.renovar-preview-img{max-height:120px;border-radius:8px;-o-object-fit:contain;object-fit:contain}.renovar-payphone-soon{display:flex;flex-direction:column;align-items:center;gap:14px;padding:40px 24px;text-align:center;border:2px dashed #e2e8f0;border-radius:12px;background:#f8fafc}.renovar-payphone-title{font-size:16px;font-weight:700;color:#1e2532;margin:0}.renovar-payphone-desc{font-size:13px;color:#64748b;margin:0;line-height:1.6}.renovar-resultado{display:flex;align-items:flex-start;gap:16px;padding:18px 20px;border-radius:12px;margin-bottom:20px}.renovar-resultado-ok{background:#f0fdf4;border:1.5px solid #bbf7d0;color:#15803d}.renovar-resultado-error{background:#fff1f2;border:1.5px solid #fecdd3;color:#dc2626}.renovar-resultado-title{font-size:15px;font-weight:700;margin:0 0 4px}.renovar-resultado p:last-child{font-size:13px;margin:0;opacity:.85}.renovar-resultado .btn{margin-left:auto;white-space:nowrap}.renovar-historial-card{padding:24px}.renovar-historial-title{font-size:15px;font-weight:800;color:#1e2532;margin:0 0 16px}.renovar-historial-list{display:flex;flex-direction:column;gap:8px}.renovar-historial-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:9px;background:#f8fafc;border:1.5px solid #f1f5f9;transition:border-color var(--transition)}.renovar-historial-item:hover{border-color:#e2e8f0}.renovar-hist-left{display:flex;flex-direction:column;gap:3px}.renovar-hist-fecha{font-size:12.5px;font-weight:700;color:#1e2532}.renovar-hist-metodo{font-size:11px;color:#64748b;display:flex;align-items:center;gap:3px;text-transform:capitalize}.renovar-hist-ref{font-size:11px;color:#94a3b8;font-family:monospace}.renovar-hist-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.renovar-hist-monto{font-size:14px;font-weight:800;color:#1e2532}@media (max-width: 760px){.renovar-grid{grid-template-columns:1fr}.renovar-historial-card{order:-1}}.sa-wrap{max-width:1200px}.sa-alerta{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;margin-bottom:16px;background:#fef9c3;color:#92400e;border:1px solid #fde68a;font-size:13.5px;font-weight:600}.sa-filtros{display:flex;gap:4px;background:#f4f6f8;border-radius:10px;padding:4px;margin-bottom:16px;width:-moz-fit-content;width:fit-content}.sa-filtro-btn{padding:7px 16px;border-radius:7px;font-size:13px;font-weight:600;color:#64748b;border:none;background:none;cursor:pointer;transition:all var(--transition);font-family:inherit;display:flex;align-items:center;gap:6px}.sa-filtro-btn.active{background:#fff;color:#16a34a;box-shadow:var(--shadow)}.sa-filtro-count{background:#e2e8f0;color:#64748b;font-size:10.5px;font-weight:700;padding:1px 6px;border-radius:99px}.sa-filtro-btn.active .sa-filtro-count{background:#dcfce7;color:#15803d}.sa-btn-confirmar{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;font-size:12px;font-weight:700;display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px}.sa-btn-confirmar:hover{background:#bbf7d0}.sa-btn-rechazar{background:#fee2e2;color:#dc2626;border:1px solid #fecaca;font-size:12px;font-weight:700;display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px}.sa-btn-rechazar:hover{background:#fecaca}.search-bar{display:flex;align-items:center;gap:8px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;padding:8px 12px;transition:var(--transition)}.search-bar:focus-within{border-color:var(--verde);background:#fff}.search-bar-icon{color:#94a3b8;flex-shrink:0}.search-bar-input{border:none;background:transparent;outline:none;font-family:inherit;font-size:13.5px;color:#1e2532;flex:1;min-width:0}.search-bar-input::-moz-placeholder{color:#94a3b8}.search-bar-input::placeholder{color:#94a3b8}.search-bar-clear{background:none;border:none;cursor:pointer;color:#94a3b8;display:flex;align-items:center;padding:2px;border-radius:4px}.search-bar-clear:hover{color:#ef4444;background:#fee2e2}.pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 0 0;flex-wrap:wrap;gap:10px}.pagination-info{font-size:12.5px;color:#94a3b8}.pagination-btns{display:flex;gap:4px;align-items:center}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Plus Jakarta Sans,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.flex-1{flex:1 1 0%}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.border{border-width:1px}.text-right{text-align:right}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.outline{outline-style:solid}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--verde: #16a34a;--verde-oscuro: #15803d;--verde-claro: #dcfce7;--verde-suave: #f0fdf4;--sidebar-w: 240px;--sidebar-w-col: 68px;--navbar-h: 62px;--radius: 12px;--shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--transition: .25s cubic-bezier(.4,0,.2,1)}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:DM Sans,Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;background:#f4f6f8;color:#1e2532;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid #f1f5f9}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:99px;font-size:11.5px;font-weight:600;letter-spacing:.3px}.badge-green{background:#dcfce7;color:#15803d}.badge-red{background:#fee2e2;color:#dc2626}.badge-yellow{background:#fef9c3;color:#a16207}.badge-gray{background:#f1f5f9;color:#64748b}.badge-blue{background:#dbeafe;color:#1d4ed8}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:8px;font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:var(--transition);white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--verde);color:#fff;box-shadow:0 2px 8px #16a34a4d}.btn-primary:hover:not(:disabled){background:var(--verde-oscuro);box-shadow:0 4px 16px #16a34a66;transform:translateY(-1px)}.btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-danger{background:#fee2e2;color:#dc2626}.btn-danger:hover:not(:disabled){background:#fecaca}.btn-ghost{background:transparent;color:#64748b}.btn-ghost:hover:not(:disabled){background:#f1f5f9}.btn-sm{padding:6px 12px;font-size:12.5px}.btn-lg{padding:12px 24px;font-size:15px}.btn-icon{padding:8px;border-radius:8px}.input{width:100%;padding:9px 13px;border-radius:8px;border:1.5px solid #e2e8f0;background:#f8fafc;font-family:inherit;font-size:14px;color:#1e2532;transition:var(--transition);outline:none}.input:focus{border-color:var(--verde);background:#fff;box-shadow:0 0 0 3px #16a34a1f}.input::-moz-placeholder{color:#94a3b8}.input::placeholder{color:#94a3b8}.input-error{border-color:#ef4444}.input-error:focus{box-shadow:0 0 0 3px #ef44441f}label.form-label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:5px}.table-wrap{overflow-x:auto;border-radius:var(--radius)}table.tbl{width:100%;border-collapse:collapse}table.tbl th{background:#f8fafc;padding:11px 14px;font-size:11.5px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.6px;border-bottom:1.5px solid #e8edf2;text-align:left;white-space:nowrap}table.tbl td{padding:12px 14px;font-size:13.5px;color:#374151;border-bottom:1px solid #f1f5f9}table.tbl tr:last-child td{border-bottom:none}table.tbl tbody tr:hover td{background:#f8fafc}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .18s ease}.modal-box{background:#fff;border-radius:16px;box-shadow:0 24px 80px #00000038;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #f1f5f9}.modal-body{padding:20px 24px}.modal-footer{padding:16px 24px;border-top:1px solid #f1f5f9;display:flex;gap:10px;justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s ease infinite}.animate-fade{animation:fadeIn .25s ease}.spinner{width:20px;height:20px;border-radius:50%;border:2.5px solid #e2e8f0;border-top-color:var(--verde);animation:spin .7s linear infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:56px 24px;text-align:center;gap:12px}.empty-state .icon{font-size:40px;opacity:.3}.empty-state p{color:#94a3b8;font-size:14px;margin:0}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-title{font-size:22px;font-weight:800;color:#1e2532;margin:0}.page-subtitle{font-size:13px;color:#94a3b8;margin:2px 0 0}
