@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap";:root{--bg-app: #f4f7f9;--bg-card: #ffffff;--bg-input: #f8fafc;--text-main: #0f172a;--text-muted: #64748b;--border: #e2e8f0;--shadow: rgba(0, 0, 0, .04)}body.dark-mode{--bg-app: #0a0a0a;--bg-card: #18181b;--bg-input: #09090b;--text-main: #ffffff;--text-muted: #a1a1aa;--border: #27272a;--shadow: rgba(0, 0, 0, .5)}body{background-color:var(--bg-app);color:var(--text-main);transition:background-color .3s,color .3s}:root{--bg-landing: #f4f7f6;--bg-card: #ffffff;--text-black: #000000;--border-card: #f8f9fa;--shadow-card: rgba(0,0,0,.04)}.landing-container.dark-mode{--bg-landing: #0a0a0a;--bg-card: #18181b;--text-black: #ffffff;--border-card: #27272a;--shadow-card: rgba(0,0,0,.5)}.landing-container{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:var(--bg-landing);font-family:Inter,sans-serif;padding:20px;text-align:center;transition:background-color .3s ease}.landing-content{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;max-width:1100px;width:100%;margin-top:-5vh}.logo-section{margin-bottom:10px;position:relative}.landing-logo{max-width:250px;height:auto;object-fit:contain}.landing-title{color:var(--text-black);font-size:2.2rem;font-weight:700;margin:0 0 10px}.landing-subtitle{color:var(--text-black);font-size:1.1rem;font-weight:500;margin:0 0 30px}.landing-instruction{color:var(--text-black);font-size:.95rem;margin-bottom:35px;font-weight:500}.landing-cards-grid{display:flex;gap:25px;width:100%;justify-content:center;flex-wrap:wrap}.landing-card{background:var(--bg-card);border-radius:12px;padding:35px 20px;width:280px;max-width:100%;text-decoration:none;box-shadow:0 4px 15px var(--shadow-card);transition:all .3s ease;display:flex;flex-direction:column;align-items:center;border:1px solid var(--border-card);cursor:pointer}.landing-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0000001a;border-color:#d32f2f}.card-icon-container{display:flex;align-items:center;justify-content:center;margin-bottom:20px}.card-icon{font-size:3rem}.public-card .card-icon{color:#066}.admin-card .card-icon{color:#0d6efd}.merca-card .card-icon{color:#d32f2f}.landing-card h3{color:var(--text-black);font-size:1.1rem;font-weight:700;margin:0 0 10px}.landing-card p{color:var(--text-black);font-size:.85rem;line-height:1.4;margin:0;font-weight:400;text-align:center}.landing-theme-toggle{position:absolute;right:-60px;top:50%;transform:translateY(-50%);background:var(--bg-card);border:1px solid var(--border-card);width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:0 4px 10px #0000001a;color:var(--text-black);transition:all .3s}.landing-footer{margin-top:auto;padding:20px;color:var(--text-black);font-size:.8rem;font-weight:500}@media(max-width:992px){.landing-cards-grid{gap:20px}.landing-card{width:250px;padding:30px 15px}}@media(max-width:768px){.landing-content{margin-top:0}.landing-logo{max-width:280px}.landing-title{font-size:1.8rem}.landing-subtitle{font-size:1rem}.landing-theme-toggle{right:0;top:-60px;transform:none}}@media(max-width:480px){.landing-logo{max-width:220px}.landing-title{font-size:1.5rem}.landing-card{width:100%}}.login-container{--login-bg: #e9ecef;--login-card: #ffffff;--login-text-h2: #111827;--login-text-p: #6b7280;--login-label: #374151;--login-input-bg: #f9fafb;--login-input-border: #e5e7eb;--login-input-text: #1f2937;--login-shadow: rgba(0, 0, 0, .15)}.login-container.dark-mode{--login-bg: #0a0a0a;--login-card: #1e1e1e;--login-text-h2: #ffffff;--login-text-p: #a1a1aa;--login-label: #e4e4e7;--login-input-bg: #121212;--login-input-border: #333333;--login-input-text: #ffffff;--login-shadow: rgba(0, 0, 0, .5)}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:var(--login-bg);font-family:Inter,sans-serif;padding:20px;transition:background-color .3s ease}.login-card{background:var(--login-card);padding:45px 40px;border-radius:20px;box-shadow:0 20px 40px var(--login-shadow),0 5px 15px #0000000d;width:100%;max-width:420px;position:relative;border:1px solid var(--login-input-border);transition:background-color .3s,border-color .3s}.back-link{position:absolute;top:25px;left:25px;display:flex;align-items:center;gap:8px;color:var(--login-text-p);text-decoration:none;font-size:.85rem;font-weight:600;transition:color .3s}.back-link:hover{color:#0d6efd}.login-header{text-align:center;margin-bottom:30px;margin-top:15px}.login-logo{max-width:170px;height:auto;margin-bottom:20px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.08))}.login-header h2{color:var(--login-text-h2);font-size:1.8rem;font-weight:800;margin:0 0 5px}.login-header p{color:var(--login-text-p);font-size:.95rem;margin:0;font-weight:500}.login-form{display:flex;flex-direction:column;gap:22px}.form-group{text-align:left}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--login-label);font-size:.9rem}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:15px;color:#9ca3af;font-size:1rem;transition:color .3s ease;z-index:2}.input-wrapper input{width:100%;padding:14px 15px 14px 45px;border:2px solid var(--login-input-border);border-radius:10px;font-size:.95rem;color:var(--login-input-text);transition:all .3s ease;background-color:var(--login-input-bg);outline:none;font-weight:500}.input-wrapper input:focus{background-color:var(--login-card);border-color:#0d6efd;box-shadow:0 0 0 4px #0d6efd26}.input-wrapper:focus-within .input-icon{color:#0d6efd}.btn-login{width:100%;padding:15px;background:linear-gradient(135deg,#0d6efd,#0043a8);color:#fff;border:none;border-radius:10px;font-size:1.05rem;font-weight:700;cursor:pointer;transition:all .3s ease;margin-top:10px;box-shadow:0 6px 15px #0d6efd4d;animation:pulse-shadow 2s infinite}.btn-login:hover{transform:translateY(-3px);box-shadow:0 10px 25px #0d6efd73;background:linear-gradient(135deg,#1175ff,#0056d6)}@keyframes pulse-shadow{0%{box-shadow:0 0 #0d6efd66}70%{box-shadow:0 0 0 10px #0d6efd00}to{box-shadow:0 0 #0d6efd00}}.alert-error{background-color:#fef2f2;color:#dc2626;padding:14px 15px;border-radius:10px;margin-bottom:20px;font-size:.9rem;font-weight:600;border-left:5px solid #dc2626;text-align:center;animation:shake .4s ease-in-out}.dark-mode .alert-error{background-color:#dc262626}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}50%{transform:translate(5px)}75%{transform:translate(-5px)}}.navbar-premium{background-color:#fff;padding:0 30px;height:75px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 20px #0000000f;position:sticky;top:0;z-index:1000;font-family:Poppins,sans-serif;border-bottom:1px solid #f1f5f9;transition:background-color .3s,border-color .3s}.navbar-brand{display:flex;align-items:center;gap:15px}.btn-hamburger{background:transparent;border:none;color:#1e293b;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:8px;border-radius:8px;transition:all .2s}.btn-hamburger:hover{background-color:#f1f5f9;color:#d32f2f}.navbar-logo{max-height:60px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.05))}.brand-text{color:#1e293b;font-size:1.15rem;font-weight:500;letter-spacing:.3px;border-left:2px solid #e2e8f0;padding-left:15px}.brand-text strong{color:#d32f2f;font-weight:700}.navbar-user{display:flex;align-items:center;gap:15px}.user-info{display:flex;align-items:center;gap:12px;text-align:right}.user-text{display:flex;flex-direction:column;line-height:1.2}.user-text .name{font-weight:700;font-size:.9rem;color:#334155}.user-text .role{font-size:.75rem;color:#94a3b8;font-weight:500}.avatar-circle{color:#d32f2f;background:#fef2f2;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:2px;width:40px;height:40px}.divider{width:1px;height:35px;background-color:#e2e8f0;margin:0 5px}.theme-toggle-btn{background:transparent;border:none;color:#64748b;font-size:1.2rem;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s}.theme-toggle-btn:hover{background-color:#f1f5f9;color:#0d6efd;transform:rotate(15deg)}.btn-logout-premium{background:transparent;border:none;color:#64748b;padding:8px 15px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:8px;font-weight:600;font-size:.9rem;transition:all .3s ease;font-family:Poppins,sans-serif}.btn-logout-premium:hover{background:#fff1f2;color:#e11d48}.sidebar-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0f172a66;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1500;opacity:0;visibility:hidden;transition:all .3s ease-in-out}.sidebar-overlay.open{opacity:1;visibility:visible}.sidebar-drawer{position:fixed;top:0;left:-300px;width:280px;height:100vh;background:#fff;box-shadow:4px 0 25px #0000001a;z-index:2000;transition:left .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.sidebar-drawer.open{left:0}.sidebar-header{padding:25px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f1f5f9}.sidebar-header h3{margin:0;font-size:1.2rem;color:#1e293b;font-weight:700}.btn-close-sidebar{background:transparent;border:none;color:#94a3b8;font-size:1.2rem;cursor:pointer;padding:5px;border-radius:6px;transition:all .2s}.btn-close-sidebar:hover{color:#ef4444;background:#fef2f2}.sidebar-menu{padding:20px 15px;display:flex;flex-direction:column;gap:8px;flex:1}.sidebar-link{display:flex;align-items:center;gap:15px;padding:14px 18px;text-decoration:none;color:#475569;font-weight:600;font-size:.95rem;border-radius:10px;transition:all .3s ease}.sidebar-icon{font-size:1.2rem;color:#94a3b8;transition:color .3s ease}.sidebar-link:hover{background-color:#f8fafc;color:#d32f2f;transform:translate(5px)}.sidebar-link:hover .sidebar-icon{color:#d32f2f}.sidebar-link.active{background-color:#fef2f2;color:#d32f2f;border-left:4px solid #d32f2f}.sidebar-link.active .sidebar-icon{color:#d32f2f}.sidebar-footer{padding:20px;text-align:center;border-top:1px solid #f1f5f9;color:#94a3b8;font-size:.8rem;font-weight:500}@media(max-width:992px){.navbar-premium{padding:0 20px}}@media(max-width:768px){.navbar-premium{padding:0 15px}.brand-text,.user-text,.logout-text{display:none}.divider{margin:0 2px}}@media(max-width:576px){.navbar-premium{padding:0 10px;height:65px}.btn-hamburger{font-size:1.3rem;padding:5px}.navbar-brand,.navbar-user{gap:8px}.divider{display:none}.btn-logout-premium{padding:8px 10px}.avatar-circle{width:35px;height:35px}}body.dark-mode .navbar-premium{background-color:#18181b;border-bottom:1px solid #27272a}body.dark-mode .brand-text{color:#fff;border-left:2px solid #333333}body.dark-mode .user-text .name{color:#fff}body.dark-mode .user-text .role{color:#a1a1aa}body.dark-mode .divider{background-color:#333}body.dark-mode .btn-hamburger{color:#e4e4e7}body.dark-mode .btn-hamburger:hover{background-color:#27272a;color:#ef4444}body.dark-mode .btn-logout-premium{color:#a1a1aa}body.dark-mode .btn-logout-premium:hover{background-color:#ef444426;color:#f87171}body.dark-mode .theme-toggle-btn{color:#e4e4e7}body.dark-mode .theme-toggle-btn:hover{background-color:#27272a;color:#fbbf24}body.dark-mode .avatar-circle{background-color:#d32f2f26;color:#ef4444}body.dark-mode .sidebar-drawer{background-color:#18181b;box-shadow:4px 0 25px #00000080}body.dark-mode .sidebar-header{border-bottom:1px solid #27272a}body.dark-mode .sidebar-header h3{color:#fff}body.dark-mode .btn-close-sidebar{color:#a1a1aa}body.dark-mode .btn-close-sidebar:hover{background-color:#ef444426;color:#ef4444}body.dark-mode .sidebar-link{color:#a1a1aa}body.dark-mode .sidebar-link:hover{background-color:#27272a;color:#ef4444}body.dark-mode .sidebar-link.active{background-color:#d32f2f26;color:#ef4444;border-left:4px solid #ef4444}body.dark-mode .sidebar-footer{border-top:1px solid #27272a;color:#a1a1aa}:root{--bg-app: #f4f7f9;--primary: #d32f2f;--primary-light: #fef2f2;--dark: #0f172a;--text-muted: #64748b;--white: #ffffff;--border: #e2e8f0;--border-light: #f1f5f9;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--blue-kpi: #0d6efd;--meta-bg: #f8fbff}body.dark-mode{--bg-app: #0a0a0a;--white: #18181b;--dark: #ffffff;--text-muted: #a1a1aa;--border: #27272a;--border-light: #1f1f23;--meta-bg: #121212;--primary-light: #450a0a}body{font-family:Poppins,sans-serif;background-color:var(--bg-app);color:var(--dark);margin:0;padding:0;transition:background-color .3s ease,color .3s ease}.page-container{min-height:100vh}.content-wrap{max-width:1450px;margin:0 auto;padding:20px}.header-flex{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.header-titles h2{font-weight:700;font-size:1.5rem;color:var(--dark);margin:0;letter-spacing:-.5px}.subtitle{margin:2px 0 0;color:var(--text-muted);font-size:.85rem;font-weight:400}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none!important;margin:0!important}input[type=number]{-moz-appearance:textfield!important}.global-meta{background-color:var(--white);padding:8px 15px;border-radius:10px;box-shadow:0 4px 10px #00000008;display:flex;align-items:center;gap:10px;font-weight:500;font-size:.9rem;color:var(--dark);border:1px solid var(--border);transition:all .3s ease;white-space:nowrap}.input-wrapper-global{display:flex;align-items:center;background-color:var(--bg-app);border:1px solid var(--border);border-radius:6px;padding:2px 8px;transition:all .3s}.input-wrapper-global:focus-within{border-color:var(--blue-kpi);background-color:var(--white)}.input-wrapper-global input{width:35px;text-align:center;border:none;background-color:transparent;font-weight:600;color:var(--blue-kpi);outline:none;font-size:.95rem;padding:0}.percent-sign-global{color:var(--text-muted);font-weight:600;font-size:.85rem}.section-title{font-size:1.05rem;font-weight:700;color:var(--dark);margin:0 0 12px;display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.5px}.section-title:before{content:"";display:block;width:4px;height:18px;background:linear-gradient(to bottom,var(--primary),var(--danger));border-radius:4px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:15px;margin-bottom:25px}.kpi-card{background-color:var(--white);padding:18px 15px;border-radius:12px;box-shadow:0 4px 15px #00000008;display:flex;align-items:center;gap:15px;border:1px solid var(--border-light);transition:all .3s ease}.card-meta-highlight{background:linear-gradient(135deg,var(--white) 0%,var(--meta-bg) 100%);border:1px solid var(--border);border-left:4px solid var(--blue-kpi)}.icon-box{width:45px;height:45px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.gray{background-color:#f1f5f9;color:#475569}.blue{background-color:#eff6ff;color:var(--blue-kpi)}.dark{background-color:#f8fafc;color:var(--dark)}.green{background-color:#ecfdf5;color:var(--success)}.orange{background-color:#fffbeb;color:var(--warning)}.red{background-color:#fef2f2;color:var(--danger)}body.dark-mode .icon-box.gray{background-color:#27272a;color:#fff}body.dark-mode .icon-box.dark{background-color:#121212;color:#fff;border:1px solid #333}.kpi-card p{margin:0;font-size:.75rem;color:var(--text-muted);font-weight:600;text-transform:uppercase}.kpi-card h3{margin:4px 0 0;font-size:1.2rem;font-weight:700;color:var(--dark);word-break:break-word}.card-meta-highlight h3{color:var(--blue-kpi)}.filters-bar{background-color:var(--white);padding:20px;border-radius:12px;box-shadow:0 4px 15px #00000008;margin-bottom:25px;border:1px solid var(--border-light);transition:all .3s ease}.filters-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:15px;align-items:end}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding-left:2px}.filter-control{display:flex;align-items:center;background-color:var(--bg-app);border-radius:8px;border:1px solid var(--border);padding:0 12px;height:42px;transition:all .3s ease;cursor:pointer;position:relative}.filter-control:hover{border-color:var(--blue-kpi);box-shadow:0 2px 10px #0d6efd14}.filter-control:focus-within{border-color:var(--primary);background-color:var(--white);box-shadow:0 0 0 3px #d32f2f1a}body.dark-mode .filter-control:hover{box-shadow:0 2px 10px #38bdf826}.filter-control input{border:none;background-color:transparent;width:100%;outline:none;font-size:.85rem;color:var(--dark);font-weight:500;font-family:Poppins,sans-serif}.icon-input{color:var(--text-muted);margin-right:8px;font-size:1rem;transition:color .3s;flex-shrink:0}.filter-control:hover .icon-input{color:var(--blue-kpi)}.custom-select-display{flex:1;font-size:.85rem;font-weight:600;color:var(--dark);-webkit-user-select:none;user-select:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.custom-select-arrow{color:var(--text-muted);font-size:.8rem;transition:transform .3s ease;flex-shrink:0}.filter-control:hover .custom-select-arrow{color:var(--blue-kpi)}.invisible-overlay{position:fixed;inset:0;z-index:99}.custom-dropdown-menu{position:absolute;top:calc(100% + 5px);left:0;width:100%;background-color:var(--white);border:1px solid var(--border-light);border-radius:10px;box-shadow:0 10px 30px #0000001a;z-index:100;max-height:220px;overflow-y:auto;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}body.dark-mode .custom-dropdown-menu{box-shadow:0 10px 30px #0009}.custom-dropdown-item{padding:12px 15px;font-size:.85rem;color:var(--dark);cursor:pointer;transition:background-color .2s;border-bottom:1px solid var(--border-light)}.custom-dropdown-item:last-child{border-bottom:none}.custom-dropdown-item:hover{background-color:var(--bg-app);color:var(--blue-kpi)}.custom-dropdown-item.selected{background-color:#2563eb1a;color:var(--blue-kpi);font-weight:700}body.dark-mode .custom-dropdown-item.selected{background-color:#38bdf81a;color:#38bdf8}.custom-dropdown-menu::-webkit-scrollbar{width:6px}.custom-dropdown-menu::-webkit-scrollbar-track{background:var(--bg-app);border-radius:10px}.custom-dropdown-menu::-webkit-scrollbar-thumb{background-color:var(--border-light);border-radius:10px}.filter-actions{display:flex;height:42px}.btn-refresh{background:linear-gradient(135deg,#1e293b,#0f172a);color:#fff;border:none;padding:0 24px;width:100%;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-refresh:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0f172a33}body.dark-mode .btn-refresh{background:linear-gradient(135deg,#3f3f46,#18181b);border:1px solid #52525b}.table-container{background-color:var(--white);border-radius:12px;box-shadow:0 4px 15px #0000000a;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border-light);position:relative;width:100%}.modern-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1200px}.modern-table td,.modern-table th{padding:8px 10px;border-bottom:1px solid var(--border-light);border-top:none;border-left:none;border-right:none;vertical-align:middle;white-space:nowrap}.col-sticky{position:sticky;left:0;background-color:var(--white)!important;z-index:2;box-shadow:2px 0 5px #0000000d;border-bottom:1px solid var(--border-light)!important;max-width:250px;overflow:hidden;text-overflow:ellipsis}.fila-sub .col-sticky{background-color:var(--bg-app)!important;padding-left:25px}.fila-main:hover .col-sticky{background-color:var(--border-light)!important}.super-header th{background-color:var(--white);padding:10px;text-transform:uppercase;font-size:.7rem;letter-spacing:.5px;font-weight:700;color:var(--dark);border-bottom:2px solid var(--border);position:sticky;top:0;z-index:1}.th-group{text-align:center}.th-base{border-bottom:3px solid #cbd5e1!important}.th-meta{background-color:var(--meta-bg)!important;border-bottom:3px solid #93c5fd!important;color:#1e40af!important}.th-real{border-bottom:3px solid #64748b!important}body.dark-mode .th-meta{color:#60a5fa!important}.sub-header th{padding:8px 10px;font-size:.7rem;font-weight:600;color:var(--text-muted);background-color:var(--bg-app);border-bottom:1px solid var(--border)}.th-meta-sub{background-color:var(--meta-bg)!important;color:#1e3a8a!important}body.dark-mode .th-meta-sub{color:#93c5fd!important}.modern-table td{font-size:.8rem;font-weight:400;color:var(--dark)}.bg-meta-light{background-color:var(--meta-bg)!important;border-left:1px dashed var(--border)!important;border-right:1px dashed var(--border)!important}.fila-main{background-color:var(--white)}.fila-main td{font-weight:500}.fila-main:hover td,.fila-main:hover .col-sticky{background-color:var(--border-light)!important}.fila-sub{background-color:var(--bg-app)}.fila-sub td{font-weight:400;color:var(--text-muted)}.col-nombre{display:flex;align-items:center;gap:8px}.btn-toggle{background-color:var(--primary-light);border:none;color:var(--primary);display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;font-size:.7rem;flex-shrink:0;cursor:pointer;transition:background .2s}.btn-toggle:hover{background-color:#d32f2f26}.text-right{text-align:right}.text-center{text-align:center}.align-middle{vertical-align:middle}.border-left{border-left:1px solid var(--border-light)!important}.text-blue{color:var(--blue-kpi)!important}.input-wrapper{display:flex;align-items:center;justify-content:flex-end;gap:2px}.input-mini{width:35px!important;height:22px!important;padding:0!important;margin:0!important;text-align:right;border:1px dashed var(--border);border-radius:4px;font-weight:500;font-size:.8rem!important;color:var(--dark)!important;background-color:transparent!important;outline:none!important;box-shadow:none!important;transition:all .2s;box-sizing:border-box!important}.input-mini:hover{border-color:var(--blue-kpi);background-color:var(--white)!important}.input-mini:focus{border:1px solid var(--blue-kpi)!important;color:var(--blue-kpi)!important;font-weight:600;background-color:var(--white)!important}.percent-sign{font-size:.8rem;font-weight:500;color:var(--text-muted)}.badge{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;display:inline-block;text-align:center;min-width:45px}.badge-success{background-color:#dcfce7;color:#166534}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-danger{background-color:#fee2e2;color:#991b1b}body.dark-mode .badge-success{background-color:#10b98133;color:#34d399}body.dark-mode .badge-warning{background-color:#f59e0b33;color:#fbbf24}body.dark-mode .badge-danger{background-color:#ef444433;color:#f87171}.empty-state{padding:40px;text-align:center;color:var(--text-muted);font-size:.9rem}@media(max-width:1200px){.filters-grid{grid-template-columns:1fr 1fr 1fr auto}.filter-group:first-child{grid-column:1 / -1}}@media(max-width:992px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.filters-grid{grid-template-columns:1fr 1fr}.filter-group:first-child{grid-column:1 / -1}.filter-actions{grid-column:1 / -1;height:auto}}@media(max-width:768px){.header-flex{flex-direction:column;align-items:stretch;text-align:center}.global-meta{width:100%;justify-content:center}.content-wrap{padding:10px}.filters-grid{grid-template-columns:1fr}.filter-group{width:100%}.modern-table{min-width:1000px}.col-sticky{position:static!important;box-shadow:none!important;max-width:none!important}.super-header th.col-sticky,.sub-header th.col-sticky{z-index:auto!important}}@media(max-width:576px){.kpi-grid{grid-template-columns:1fr}.header-titles h2{font-size:1.3rem}.subtitle{font-size:.8rem}.filters-bar{padding:15px}}.table-container::-webkit-scrollbar-track{background-color:var(--bg-app);border-radius:0 0 12px 12px;border-top:1px solid var(--border-light)}.table-container::-webkit-scrollbar-thumb:hover{background-color:var(--text-muted)}:root{--bg-app: #f4f7f9;--bg-card: #ffffff;--text-main: #1e293b;--text-muted: #64748b;--border-light: #e2e8f0;--border-hover: #f1f5f9;--modal-overlay: rgba(15, 23, 42, .6);--input-bg: #f8fafc;--input-disabled: #f1f5f9;--table-header: #f8fafc}body.dark-mode{--bg-app: #0a0a0a;--bg-card: #18181b;--text-main: #ffffff;--text-muted: #a1a1aa;--border-light: #27272a;--border-hover: #1f1f23;--modal-overlay: rgba(0, 0, 0, .8);--input-bg: #121212;--input-disabled: #27272a;--table-header: #121212}.content-wrap{padding:30px;max-width:1200px;margin:0 auto;font-family:Poppins,sans-serif;animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;background:var(--bg-card);padding:20px 25px;border-radius:16px;box-shadow:0 4px 15px #00000008;border:1px solid var(--border-light);transition:background-color .3s,border-color .3s}.header-actions h2{margin:0;color:var(--text-main);font-size:1.6rem;font-weight:700;letter-spacing:-.5px}.btn-primary.btn-add{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.95rem;background:linear-gradient(135deg,#d32f2f,#b91c1c);color:#fff;padding:12px 24px;border:none;border-radius:10px;cursor:pointer;box-shadow:0 4px 12px #d32f2f40;transition:all .3s ease;font-family:Poppins,sans-serif}.btn-primary.btn-add:hover{transform:translateY(-2px);box-shadow:0 6px 18px #d32f2f59}.table-responsive{background:var(--bg-card);border-radius:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:0 10px 30px -5px #0000000d;border:1px solid var(--border-light);transition:background-color .3s,border-color .3s}.table-responsive::-webkit-scrollbar{height:8px}.table-responsive::-webkit-scrollbar-track{background:var(--bg-app);border-radius:0 0 12px 12px}.table-responsive::-webkit-scrollbar-thumb{background-color:var(--text-muted);border-radius:10px}.users-table{width:100%;border-collapse:separate;border-spacing:0;min-width:800px}.users-table th{background-color:var(--table-header);color:var(--text-muted);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;padding:18px 20px;text-align:left;border-bottom:2px solid var(--border-light);white-space:nowrap}.users-table td{padding:16px 20px;border-bottom:1px solid var(--border-hover);color:var(--text-main);font-size:.95rem;font-weight:500;vertical-align:middle;background-color:var(--bg-card)}.users-table tbody tr{transition:background-color .2s ease}.users-table tbody tr:hover td{background-color:var(--border-hover)}.users-table tbody tr:last-child td{border-bottom:none}.status-badge{padding:6px 14px;border-radius:20px;font-size:.8rem;font-weight:700;letter-spacing:.5px;display:inline-block;text-transform:uppercase}.status-badge.active{background-color:#dcfce7;color:#166534}.status-badge.inactive{background-color:#fee2e2;color:#991b1b}body.dark-mode .status-badge.active{background-color:#10b98133;color:#34d399}body.dark-mode .status-badge.inactive{background-color:#ef444433;color:#f87171}.action-buttons{display:flex;gap:8px}.btn-icon{background:transparent;border:none;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:1.1rem;flex-shrink:0}.btn-icon.edit{color:#3b82f6}.btn-icon.edit:hover{background-color:#eff6ff}.btn-icon.delete{color:#ef4444}.btn-icon.delete:hover{background-color:#fef2f2}.btn-icon.activate{color:#10b981}.btn-icon.activate:hover{background-color:#ecfdf5}.btn-icon.key{color:#f59e0b}.btn-icon.key:hover{background-color:#fef3c7}body.dark-mode .btn-icon.edit:hover{background-color:#3b82f626}body.dark-mode .btn-icon.delete:hover{background-color:#ef444426}body.dark-mode .btn-icon.activate:hover{background-color:#10b98126}body.dark-mode .btn-icon.key:hover{background-color:#f59e0b26}.modal-overlay{position:fixed;inset:0;background:var(--modal-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .2s ease-out;padding:15px}.modal-content{background:var(--bg-card);padding:35px 40px;border-radius:20px;width:100%;max-width:450px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003;position:relative;transform:translateY(0);animation:slideUp .3s ease-out;border:1px solid var(--border-light)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-content h3{margin:0 0 25px;color:var(--text-main);font-size:1.5rem;font-weight:700}.form-group{margin-bottom:18px}.modal-content label{display:block;font-weight:600;font-size:.9rem;color:var(--text-muted);margin-bottom:8px}.modal-input,.modal-select{width:100%;padding:12px 15px;border:1px solid var(--border-light);border-radius:10px;font-size:.95rem;color:var(--text-main);transition:all .3s ease;background-color:var(--input-bg);font-family:Poppins,sans-serif;box-sizing:border-box}.modal-input:focus,.modal-select:focus{outline:none;border-color:#d32f2f;background-color:var(--bg-card);box-shadow:0 0 0 3px #d32f2f1a}.modal-input:disabled{background-color:var(--input-disabled);color:var(--text-muted);cursor:not-allowed}body.dark-mode .rol-group{background:#1f1212!important;border-color:#450a0a!important}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:30px;padding-top:20px;border-top:1px solid var(--border-hover)}.btn-secondary{background-color:var(--input-disabled);color:var(--text-muted);padding:12px 24px;border:none;border-radius:10px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-family:Poppins,sans-serif}.btn-secondary:hover{background-color:var(--border-light);color:var(--text-main)}.btn-primary{background:linear-gradient(135deg,#1e293b,#0f172a);color:#fff;padding:12px 24px;border:none;border-radius:10px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;font-family:Poppins,sans-serif;box-shadow:0 4px 10px #0f172a33}body.dark-mode .btn-primary{background:linear-gradient(135deg,#3f3f46,#18181b);border:1px solid #52525b}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 15px #0f172a4d}.tab-btn{flex:1;padding:12px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-muted);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s ease}.tab-btn:hover{color:#d32f2f}.tab-btn.active{color:#d32f2f;border-bottom:3px solid #d32f2f}.resultados-externos{max-height:250px;overflow-y:auto;border:1px solid var(--border-light);border-radius:8px;background:var(--input-bg)}.resultado-item{padding:15px;border-bottom:1px solid var(--border-light);cursor:pointer;background:var(--bg-card);display:flex;align-items:center;gap:15px;transition:background .2s}.resultado-item:hover{background:var(--border-hover)}.res-avatar{width:40px;height:40px;border-radius:50%;background:#fef2f2;color:#d32f2f;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}body.dark-mode .res-avatar{background:#d32f2f26}.res-info{flex:1;display:flex;flex-direction:column}.res-info strong{color:var(--text-main);font-size:.95rem}.res-info span{color:var(--text-muted);font-size:.8rem;display:flex;align-items:center;gap:5px;margin-top:3px}@media(max-width:768px){.content-wrap{padding:15px}.header-actions{flex-direction:column;gap:15px;align-items:stretch;text-align:center;padding:15px}.header-actions h2{font-size:1.4rem}.btn-primary.btn-add{justify-content:center}.modal-content{padding:25px 20px}.modal-actions{flex-direction:column-reverse}.btn-secondary,.btn-primary{width:100%;text-align:center}}@media(max-width:480px){.users-table td{padding:12px 15px;font-size:.85rem}.btn-icon{width:32px;height:32px;font-size:.95rem}}.public-view{--rv-bg: #f8fafc;--rv-card: #ffffff;--rv-text-main: #1e293b;--rv-border: #e2e8f0;--rv-blue: #2563eb}.public-view.dark-mode{--rv-bg: #0a0a0a;--rv-card: #18181b;--rv-text-main: #ffffff;--rv-border: #27272a;--rv-blue: #38bdf8}.public-view{background-color:var(--rv-bg);min-height:100vh;font-family:Poppins,sans-serif;overflow-x:hidden;transition:background-color .3s ease}.animated-header{position:relative;background:linear-gradient(135deg,#b91c1c,#ef4444);height:110px;width:100%;overflow:hidden;box-shadow:0 10px 25px #b91c1c4d}.header-overlay-content{position:relative;z-index:10;max-width:1200px;margin:0 auto;padding:10px 30px;display:flex;justify-content:space-between;align-items:center}.floating-brand{display:flex;align-items:center;gap:20px}.btn-back-float{color:#fff;font-size:1.2rem;display:flex;transition:all .3s ease;background:#ffffff26;padding:10px;border-radius:50%;border:none;cursor:pointer}.btn-back-float:hover{transform:translate(-3px);background:#ffffff4d}.logo-float{max-width:160px;height:auto;filter:drop-shadow(0 4px 10px rgba(0,0,0,.3))}.animated-float{animation:floatLogo 3s ease-in-out infinite}@keyframes floatLogo{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.header-text-right{text-align:right;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.15)}.header-text-right h1{font-size:1.5rem;font-weight:800;margin:0 0 4px;text-transform:uppercase;letter-spacing:.5px}.company-details-white{display:flex;justify-content:flex-end;align-items:center;gap:10px;font-weight:600;font-size:.95rem;color:#fffffff2}.separator-white{color:#fff6;font-size:1.2rem}.waves-container{position:absolute;bottom:-5px;width:100%;height:70px;z-index:5}.waves-svg{position:absolute;bottom:0;width:100%;height:100%}.parallax>use{animation:move-forever 25s cubic-bezier(.55,.5,.45,.5) infinite}.parallax>use:nth-child(1){animation-delay:-2s;animation-duration:7s}.parallax>use:nth-child(2){animation-delay:-3s;animation-duration:10s}.parallax>use:nth-child(3){animation-delay:-4s;animation-duration:13s}.parallax>use:nth-child(4){animation-delay:-5s;animation-duration:20s}@keyframes move-forever{0%{transform:translate3d(-90px,0,0)}to{transform:translate3d(85px,0,0)}}.container-overlap-animated{margin-top:15px!important;position:relative;z-index:20;padding-bottom:40px;max-width:1400px;margin:0 auto;padding-left:15px;padding-right:15px}.public-filters-modern{background-color:var(--rv-card);padding:20px;border-radius:12px;box-shadow:0 4px 15px #00000008;border:1px solid var(--rv-border);margin-bottom:25px}.filter-control{background-color:var(--rv-bg);border:1px solid var(--rv-border);border-radius:8px;padding:0 12px;height:42px;display:flex;align-items:center;transition:all .3s}.filter-control:focus-within,.filter-control:hover{border-color:var(--rv-blue);background-color:var(--rv-card);box-shadow:0 0 0 3px #2563eb1a}.filter-control input,.filter-control select{width:100%;border:none;background:transparent;font-family:Poppins,sans-serif;font-size:.85rem;color:var(--rv-text-main);font-weight:500;outline:none}.filter-control input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.5);cursor:pointer}.dark-mode .public-filters-modern,.dark-mode .read-only-meta-modern,.dark-mode .table-container{background-color:var(--rv-card)!important;border:1px solid var(--rv-border)!important;color:#fff!important}.dark-mode .filter-control{background-color:#121212!important;border-color:#333!important}.dark-mode .filter-control:focus-within,.dark-mode .filter-control:hover{border-color:var(--rv-blue)!important;box-shadow:0 0 0 3px #38bdf826!important}.dark-mode .filter-control input,.dark-mode .filter-control select{color:#fff!important}.dark-mode .filter-control input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1)}.dark-mode .filter-control select option{background-color:var(--rv-card);color:#fff}.table-container{background-color:var(--rv-card);border-radius:12px;border:1px solid var(--rv-border);overflow-x:auto;-webkit-overflow-scrolling:touch}.modern-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1000px}.modern-table td,.modern-table th{padding:8px 10px;border-bottom:1px solid var(--rv-border);border-top:none;border-left:none;border-right:none;vertical-align:middle;white-space:nowrap}.col-sticky{position:sticky;left:0;background-color:var(--rv-card)!important;z-index:2;box-shadow:2px 0 5px #0000000d;border-bottom:1px solid var(--rv-border)!important;max-width:250px;overflow:hidden;text-overflow:ellipsis}.fila-sub .col-sticky{background-color:var(--rv-bg)!important;padding-left:20px}.fila-main:hover .col-sticky{background-color:#00000005!important}.super-header th{border-bottom:2px solid var(--rv-border);background-color:var(--rv-card);font-weight:700;font-size:.75rem;color:var(--rv-text-main);text-transform:uppercase}.super-header th.col-sticky{z-index:3}.sub-header th{border-bottom:1px solid var(--rv-border);background-color:var(--rv-bg);font-weight:600;font-size:.75rem;color:#64748b}.sub-header th.col-sticky{z-index:3}.fila-main{background-color:var(--rv-card)}.fila-main td{font-weight:500;color:var(--rv-text-main)}.fila-main:hover td{background-color:#00000005!important}.dark-mode .modern-table td,.dark-mode .super-header th,.dark-mode .sub-header th{border-bottom-color:var(--rv-border)!important}.dark-mode .super-header th{background-color:#121212!important;color:#fff!important}.dark-mode .sub-header th{background-color:#1a1a1a!important;color:#a1a1aa!important}.dark-mode .col-sticky{background-color:var(--rv-card)!important;color:#fff!important;border-bottom-color:var(--rv-border)!important}.dark-mode .fila-main{background-color:var(--rv-card)}.dark-mode .fila-main td{color:#e2e8f0}.dark-mode .fila-main:hover td,.dark-mode .fila-main:hover .col-sticky{background-color:#27272a!important}.dark-mode .fila-sub{background-color:#121212!important}.dark-mode .fila-sub td{color:#a1a1aa!important}.dark-mode .fila-sub .col-sticky{background-color:#121212!important;border-bottom-color:var(--rv-border)!important}.btn-refresh-modern{background:linear-gradient(135deg,#b91c1c,#dc2626);color:#fff;border:none;border-radius:8px;font-weight:600;padding:0 25px;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #b91c1c4d;height:42px;display:flex;align-items:center;justify-content:center;gap:8px;font-family:Poppins,sans-serif}.btn-refresh-modern:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #b91c1c66}.dark-mode .btn-refresh-modern{background:linear-gradient(135deg,#7f1d1d,#b91c1c);box-shadow:0 4px 12px #00000080;border:1px solid #450a0a;color:#fff}.dark-mode .btn-refresh-modern:hover:not(:disabled){box-shadow:0 8px 20px #000000b3;background:linear-gradient(135deg,#991b1b,#dc2626)}.table-container::-webkit-scrollbar{height:8px;width:8px}.table-container::-webkit-scrollbar-track{background-color:var(--rv-bg);border-radius:0 0 12px 12px;border-top:1px solid var(--rv-border)}.table-container::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:10px}.table-container::-webkit-scrollbar-thumb:hover{background-color:#94a3b8}body.dark-mode .table-container::-webkit-scrollbar-thumb{background-color:#52525b}@media(max-width:992px){.filters-grid{grid-template-columns:1fr 1fr;gap:15px}}@media(max-width:768px){.animated-header{height:auto;padding-bottom:70px}.header-overlay-content{flex-direction:column;gap:15px;text-align:center}.header-text-right{text-align:center}.company-details-white{justify-content:center}.separator-white{display:none}.waves-container{height:50px}.floating-brand{width:100%;justify-content:center;position:relative}.btn-back-float{position:absolute;left:0;padding:8px}.filters-grid{display:flex;flex-direction:column;gap:15px}.filter-control{width:100%;box-sizing:border-box}.btn-refresh-modern{width:100%;justify-content:center}.col-sticky{position:static!important;box-shadow:none!important;max-width:none!important}.super-header th.col-sticky,.sub-header th.col-sticky{z-index:auto!important}}@media(max-width:480px){.header-text-right h1{font-size:1.2rem}.logo-float{max-width:130px}.container-overlap-animated{padding-left:10px;padding-right:10px}.public-filters-modern{padding:15px}}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{overflow:visible;text-transform:none;-webkit-appearance:button;-moz-appearance:button;appearance:button;cursor:pointer}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-calendar{-webkit-box-sizing:border-box;box-sizing:border-box;height:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:stretch;-ms-flex-align:stretch;align-items:stretch}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar *:before,.rbc-calendar *:after{-webkit-box-sizing:inherit;box-sizing:inherit}.rbc-abs-full,.rbc-row-bg{overflow:hidden;position:absolute;inset:0}.rbc-ellipsis,.rbc-show-more,.rbc-row-segment .rbc-event-content,.rbc-event-label{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbc-rtl{direction:rtl}.rbc-off-range{color:#999}.rbc-off-range-bg{background:#e6e6e6}.rbc-header{overflow:hidden;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;text-overflow:ellipsis;white-space:nowrap;padding:0 3px;text-align:center;vertical-align:middle;font-weight:700;font-size:90%;min-height:0;border-bottom:1px solid #ddd}.rbc-header+.rbc-header{border-left:1px solid #ddd}.rbc-rtl .rbc-header+.rbc-header{border-left-width:0;border-right:1px solid #ddd}.rbc-header>a,.rbc-header>a:active,.rbc-header>a:visited{color:inherit;text-decoration:none}.rbc-button-link{color:inherit;background:none;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.rbc-row-content{position:relative;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;z-index:4}.rbc-row-content-scrollable{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;height:100%}.rbc-row-content-scrollable .rbc-row-content-scroll-container{height:100%;overflow-y:scroll;-ms-overflow-style:none;scrollbar-width:none}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.rbc-toolbar{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:10px;font-size:16px}.rbc-toolbar .rbc-toolbar-label{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;padding:0 10px;text-align:center}.rbc-toolbar button{color:#373a3c;display:inline-block;margin:0;text-align:center;vertical-align:middle;background:none;background-image:none;border:1px solid #ccc;padding:.375rem 1rem;border-radius:4px;line-height:normal;white-space:nowrap}.rbc-toolbar button:active,.rbc-toolbar button.rbc-active{background-image:none;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px #00000020;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button.rbc-active:focus{color:#373a3c;background-color:#d4d4d4;border-color:#8c8c8c}.rbc-toolbar button:focus{color:#373a3c;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:hover{color:#373a3c;cursor:pointer;background-color:#e6e6e6;border-color:#adadad}.rbc-btn-group{display:inline-block;white-space:nowrap}.rbc-btn-group>button:first-child:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:0 4px 4px 0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px 0 0 4px}.rbc-btn-group>button:not(:first-child):not(:last-child){border-radius:0}.rbc-btn-group button+button{margin-left:-1px}.rbc-rtl .rbc-btn-group button+button{margin-left:0;margin-right:-1px}.rbc-btn-group+.rbc-btn-group,.rbc-btn-group+button{margin-left:10px}@media(max-width:767px){.rbc-toolbar{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}}.rbc-event,.rbc-day-slot .rbc-background-event{border:none;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-box-shadow:none;box-shadow:none;margin:0;padding:2px 5px;background-color:#3174ad;border-radius:5px;color:#fff;cursor:pointer;width:100%;text-align:left}.rbc-slot-selecting .rbc-event,.rbc-slot-selecting .rbc-day-slot .rbc-background-event,.rbc-day-slot .rbc-slot-selecting .rbc-background-event{cursor:inherit;pointer-events:none}.rbc-event.rbc-selected,.rbc-day-slot .rbc-selected.rbc-background-event{background-color:#265985}.rbc-event:focus,.rbc-day-slot .rbc-background-event:focus{outline:5px auto #3b99fc}.rbc-event-label{font-size:80%}.rbc-event-overlaps{-webkit-box-shadow:-1px 1px 5px 0px rgba(51,51,51,.5);box-shadow:-1px 1px 5px #33333380}.rbc-event-continues-prior{border-top-left-radius:0;border-bottom-left-radius:0}.rbc-event-continues-after{border-top-right-radius:0;border-bottom-right-radius:0}.rbc-event-continues-earlier{border-top-left-radius:0;border-top-right-radius:0}.rbc-event-continues-later{border-bottom-left-radius:0;border-bottom-right-radius:0}.rbc-row{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-row-segment{padding:0 1px 1px}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{background-color:#ffffff4d;z-index:4;font-weight:700;font-size:85%;height:auto;line-height:normal;color:#3174ad}.rbc-show-more:hover,.rbc-show-more:focus{color:#265985}.rbc-month-view{position:relative;border:1px solid #ddd;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;height:100%}.rbc-month-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-month-row{display:-webkit-box;display:-ms-flexbox;display:flex;position:relative;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px;overflow:hidden;height:100%}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;min-width:0;padding-right:5px;text-align:right}.rbc-date-cell.rbc-now{font-weight:700}.rbc-date-cell>a,.rbc-date-cell>a:active,.rbc-date-cell>a:visited{color:inherit;text-decoration:none}.rbc-row-bg{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:hidden;right:1px}.rbc-day-bg{-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%}.rbc-day-bg+.rbc-day-bg{border-left:1px solid #ddd}.rbc-rtl .rbc-day-bg+.rbc-day-bg{border-left-width:0;border-right:1px solid #ddd}.rbc-overlay{position:absolute;z-index:5;border:1px solid #e5e5e5;background-color:#fff;-webkit-box-shadow:0 5px 15px rgba(0,0,0,.25);box-shadow:0 5px 15px #00000040;padding:10px}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{width:100%;border:1px solid #ddd;border-spacing:0;border-collapse:collapse}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{padding:5px 10px;vertical-align:top}.rbc-agenda-view table.rbc-agenda-table .rbc-agenda-time-cell{padding-left:15px;padding-right:15px;text-transform:lowercase}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left-width:0;border-right:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table tbody>tr+tr{border-top:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{padding:3px 5px;text-align:left;border-bottom:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:right}.rbc-agenda-time-cell{text-transform:lowercase}.rbc-agenda-time-cell .rbc-continues-after:after{content:" »"}.rbc-agenda-time-cell .rbc-continues-prior:before{content:"« "}.rbc-agenda-date-cell,.rbc-agenda-time-cell{white-space:nowrap}.rbc-agenda-event-cell{width:100%}.rbc-time-column{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;min-height:100%}.rbc-time-column .rbc-timeslot-group{-webkit-box-flex:1;-ms-flex:1;flex:1}.rbc-timeslot-group{border-bottom:1px solid #ddd;min-height:40px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.rbc-time-gutter,.rbc-header-gutter{-webkit-box-flex:0;-ms-flex:none;flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{inset:0;position:absolute;margin-right:10px}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-event,.rbc-day-slot .rbc-background-event{border:1px solid #265985;display:-webkit-box;display:-ms-flexbox;display:flex;max-height:100%;min-height:20px;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column wrap;flex-flow:column wrap;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;overflow:hidden;position:absolute}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{-webkit-box-flex:0;-ms-flex:none;flex:none;padding-right:5px;width:auto}.rbc-day-slot .rbc-event-content{width:100%;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;word-wrap:break-word;line-height:1;height:100%;min-height:1em}.rbc-day-slot .rbc-time-slot{border-top:1px solid #f7f7f7}.rbc-time-view-resources .rbc-time-gutter,.rbc-time-view-resources .rbc-time-header-gutter{position:sticky;left:0;background-color:#fff;border-right:1px solid #ddd;z-index:10;margin-right:-1px}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{min-width:auto;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px}.rbc-time-view-resources .rbc-time-header-cell-single-day{display:none}.rbc-time-view-resources .rbc-day-slot{min-width:140px}.rbc-time-view-resources .rbc-header,.rbc-time-view-resources .rbc-day-bg{width:140px;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;-ms-flex-preferred-size:0 px;flex-basis:0 px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{z-index:10;position:absolute;background-color:#00000080;color:#fff;font-size:75%;width:100%;padding:3px}.rbc-slot-selecting{cursor:move}.rbc-time-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1;flex:1;width:100%;border:1px solid #ddd;min-height:0}.rbc-time-view .rbc-time-gutter{white-space:nowrap;text-align:right}.rbc-time-view .rbc-allday-cell{-webkit-box-sizing:content-box;box-sizing:content-box;width:100%;height:100%;position:relative}.rbc-time-view .rbc-allday-cell+.rbc-allday-cell{border-left:1px solid #ddd}.rbc-time-view .rbc-allday-events{position:relative;z-index:4}.rbc-time-view .rbc-row{-webkit-box-sizing:border-box;box-sizing:border-box;min-height:20px}.rbc-time-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-right-width:0;border-left:1px solid #ddd}.rbc-time-header>.rbc-row:first-child{border-bottom:1px solid #ddd}.rbc-time-header>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{-webkit-box-flex:1;-ms-flex:1;flex:1;display:-webkit-box;display:-ms-flexbox;display:flex;min-width:0;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;border-left:1px solid #ddd}.rbc-rtl .rbc-time-header-content{border-left-width:0;border-right:1px solid #ddd}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd;-ms-flex-negative:0;flex-shrink:0}.rbc-time-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;width:100%;border-top:2px solid #ddd;overflow-y:auto;position:relative}.rbc-time-content>.rbc-time-gutter{-webkit-box-flex:0;-ms-flex:none;flex:none}.rbc-time-content>*+*>*{border-left:1px solid #ddd}.rbc-rtl .rbc-time-content>*+*>*{border-left-width:0;border-right:1px solid #ddd}.rbc-time-content>.rbc-day-slot{width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none}.rbc-current-time-indicator{position:absolute;z-index:3;left:0;right:0;height:1px;background-color:#74ad31;pointer-events:none}.rbc-resource-grouping.rbc-time-header-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}:root{--bg-app: #f4f7f9;--bg-card: #ffffff;--text-main: #0f172a;--text-muted: #64748b;--border-light: #e2e8f0;--border-heavy: #bfdbfe;--input-bg: #ffffff;--hover-bg: #f8fafc;--blue-kpi: #2563eb;--shadow: rgba(0, 0, 0, .03)}body.dark-mode{--bg-app: #0a0a0a;--bg-card: #18181b;--text-main: #ffffff;--text-muted: #a1a1aa;--border-light: #27272a;--border-heavy: #3f3f46;--input-bg: #121212;--hover-bg: #1f1f23;--blue-kpi: #38bdf8;--shadow: rgba(0, 0, 0, .5)}.planificacion-wrap{max-width:1400px;margin:0 auto;font-family:Poppins,sans-serif;animation:fadeIn .3s ease-out;padding:0 15px}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.video-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px;margin-bottom:25px;background-color:var(--bg-card);padding:18px 25px;border-radius:12px;box-shadow:0 4px 15px var(--shadow);border:1px solid var(--border-light);transition:all .3s ease}.video-header h2{font-size:1.3rem;color:var(--text-main);margin:0;font-weight:700;letter-spacing:-.3px;display:flex;align-items:center}.btn-vid{display:flex;align-items:center;justify-content:center;padding:10px 18px;border:none;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s ease-in-out;font-family:Poppins,sans-serif}.btn-vid svg{transition:transform .2s ease}.btn-vid:hover svg{transform:scale(1.1)}.btn-gray{background-color:var(--hover-bg);color:var(--text-muted);border:1px solid var(--border-light)}.btn-gray:hover{background-color:var(--border-light);color:var(--text-main);transform:translateY(-2px);box-shadow:0 4px 10px #0000000d}.btn-blue{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 4px 10px #2563eb33}.btn-blue:hover{transform:translateY(-2px);box-shadow:0 6px 15px #2563eb4d}.btn-red{background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff;box-shadow:0 4px 10px #ef444433}.btn-red:hover{transform:translateY(-2px);box-shadow:0 6px 15px #ef44444d}.btn-vid.disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.view-toggle-container{display:inline-flex;background-color:var(--hover-bg);border-radius:8px;padding:4px;border:1px solid var(--border-light);flex-wrap:wrap}.view-toggle-btn{background:transparent;border:none;padding:8px 16px;font-size:.85rem;font-weight:600;color:var(--text-muted);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s ease-in-out;font-family:Poppins,sans-serif}.view-toggle-btn:hover:not(.active){color:var(--text-main)}.view-toggle-btn.active{background-color:var(--bg-card);color:var(--blue-kpi);box-shadow:0 2px 8px #0000000f}.view-toggle-btn.active svg{color:var(--blue-kpi)}.ruta-activa-container{background-color:var(--bg-card);border-radius:16px;border:1px solid var(--border-heavy);box-shadow:0 10px 30px -10px var(--shadow);overflow:hidden;animation:slideUp .3s ease-out}.ruta-activa-header{background:linear-gradient(135deg,var(--hover-bg) 0%,var(--bg-card) 100%);padding:18px 25px;border-bottom:1px solid var(--border-heavy);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.header-left{display:flex;align-items:center;gap:12px}.pulse-icon{background:#fee2e2;color:#ef4444;width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;animation:pulse-red 2s infinite}body.dark-mode .pulse-icon{background:#ef444426}@keyframes pulse-red{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 8px #ef444400}to{box-shadow:0 0 #ef444400}}.ruta-activa-header h2{margin:0;color:var(--text-main);font-weight:700;font-size:1.3rem;letter-spacing:-.3px}.badge-pill.in-progress{background:#dcfce7;color:#166534;border:1px solid #bbf7d0;padding:6px 12px;font-size:.8rem}body.dark-mode .badge-pill.in-progress{background:#10b98133;color:#34d399;border-color:#10b9814d}.ruta-activa-body{padding:25px}.info-cliente-premium{display:flex;align-items:center;gap:15px;background-color:var(--hover-bg);padding:18px;border-radius:12px;border:1px solid var(--border-light);margin-bottom:25px;flex-wrap:wrap}.cliente-avatar{width:50px;height:50px;background:#2563eb1a;color:var(--blue-kpi);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.cliente-datos{flex:1;min-width:200px}.cliente-subtitle{font-size:.75rem;font-weight:700;color:var(--text-muted);letter-spacing:.5px;margin:0 0 3px}.info-cliente-premium h3{font-size:1.4rem;color:var(--text-main);margin:0 0 4px;font-weight:700;word-break:break-word}.cliente-time{color:var(--text-muted);font-size:.85rem;margin:0;font-weight:500;display:flex;align-items:center;gap:6px}.premium-card{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:12px;padding:25px;text-align:center;box-shadow:0 4px 15px var(--shadow);position:relative}.card-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:#1e293b;color:#fff;padding:3px 12px;border-radius:12px;font-size:.7rem;font-weight:600;letter-spacing:.5px;box-shadow:0 2px 6px #0000001a;white-space:nowrap}.success-badge{background:#10b981}.actividad-card h4{font-size:1.25rem;color:var(--text-main);margin:20px 0 15px}.highlight-text{color:var(--blue-kpi);font-weight:700}.decision-text{color:var(--text-muted)}.obs-box{background-color:var(--hover-bg);padding:12px;border-radius:8px;border:1px dashed var(--border-light);margin:15px auto;max-width:600px;text-align:left;font-size:.85rem;color:var(--text-main);word-break:break-word}.bifurcacion-botones{display:flex;gap:15px;justify-content:center;margin-top:25px;flex-wrap:wrap}.large-btn{padding:14px 20px!important;font-size:.95rem!important;flex:1;min-width:250px;border-radius:10px!important}.outline-danger{background-color:transparent;color:#ef4444;border:1px solid #fecaca;box-shadow:none}.outline-danger:hover{background-color:#ef44441a;border-color:#ef4444;box-shadow:0 4px 10px #ef44441a}body.dark-mode .outline-danger{border-color:#ef4444}.heartbeat-btn{animation:heartbeat 2s ease-in-out infinite both}.modern-filters{display:flex;gap:15px;background:transparent;padding:0;border:none;margin-bottom:25px;box-shadow:none;flex-wrap:wrap}.modern-input{flex:1;position:relative;min-width:250px}.modern-input .icon-search{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:1rem;pointer-events:none}.modern-input input{width:100%;box-sizing:border-box;padding:12px 15px 12px 42px;border:1px solid var(--border-light);border-radius:10px;font-family:Poppins,sans-serif;font-size:.85rem;outline:none;transition:all .2s ease;background-color:var(--input-bg);color:var(--text-main);font-weight:500;box-shadow:0 2px 8px #00000005}.modern-input input:focus{border-color:var(--blue-kpi);box-shadow:0 0 0 3px #2563eb1a}.lista-agrupada-container{background-color:var(--bg-card);border-radius:12px;padding:25px;border:1px solid var(--border-light);min-height:400px;animation:fadeIn .2s ease-out}.empty-state-modern{display:flex;flex-direction:column;align-items:center;justify-content:center;height:250px;color:var(--text-muted);font-size:.95rem;font-weight:500}.empty-state-modern svg{font-size:2.5rem;margin-bottom:10px;color:var(--border-light)}.cliente-accordion{border:1px solid var(--border-light);border-radius:10px;margin-bottom:15px;overflow:hidden;transition:all .2s ease}.cliente-accordion:hover{border-color:var(--border-light);box-shadow:0 4px 15px var(--shadow);transform:translateY(-1px)}.accordion-header{background-color:var(--bg-card);padding:15px 20px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .2s;flex-wrap:wrap;gap:10px}.accordion-header:hover{background-color:var(--hover-bg)}.accordion-header h3{color:var(--text-main);word-break:break-word;flex:1;min-width:150px}.avatar-mini{width:32px;height:32px;background:#2563eb1a;color:var(--blue-kpi);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}.badge-pill.bg-blue-light{background:#2563eb1a;color:var(--blue-kpi);border:none;font-size:.75rem;padding:4px 10px;white-space:nowrap}.icon-collapse{color:var(--text-muted);font-size:1rem;transition:transform .2s ease;flex-shrink:0}.icon-collapse.open{transform:rotate(180deg);color:var(--blue-kpi)}.accordion-body{border-top:1px solid var(--border-light);padding:0;background-color:var(--bg-app);animation:slideDown .2s ease-out;overflow-x:auto;-webkit-overflow-scrolling:touch}.listado-table{width:100%;min-width:600px;border-collapse:separate;border-spacing:0}.listado-table th{background-color:var(--bg-app);font-size:.75rem;color:var(--text-muted);padding:14px 20px;border-bottom:1px solid var(--border-light);text-align:left;text-transform:uppercase;letter-spacing:.5px}.listado-table td{padding:14px 20px;font-size:.85rem;border-bottom:1px solid var(--border-light);background-color:var(--bg-card);color:var(--text-main);vertical-align:middle}.btn-table{border-radius:8px;padding:6px 12px;font-weight:600;font-size:.8rem;transition:all .2s;cursor:pointer;white-space:nowrap}.btn-ver-premium{background:transparent;color:var(--blue-kpi);border:1px solid var(--blue-kpi);display:flex;align-items:center;justify-content:center;gap:6px}.btn-ver-premium:hover{background:#2563eb1a;transform:translateY(-1px)}.badge-pill{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;display:inline-block;letter-spacing:.3px;text-align:center}.badge-pill.pendiente{background-color:#fffbeb;color:#d97706;border:1px solid #fde68a}.badge-pill.realizada{background-color:#ecfdf5;color:#059669;border:1px solid #a7f3d0}.badge-pill.cancelada{background-color:#fef2f2;color:#dc2626;border:1px solid #fecaca}body.dark-mode .badge-pill.pendiente{background-color:#f59e0b33;color:#fbbf24;border-color:#f59e0b66}body.dark-mode .badge-pill.realizada{background-color:#10b98133;color:#34d399;border-color:#10b98166}body.dark-mode .badge-pill.cancelada{background-color:#ef444433;color:#f87171;border-color:#ef444466}.bi-dashboard-container{animation:fadeIn .3s ease-out}.kpi-grid-modern{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:15px;margin-bottom:25px}.kpi-card-modern{padding:22px;border-radius:12px;display:flex;justify-content:space-between;align-items:center;color:#fff;box-shadow:0 8px 20px #0000000f;position:relative;overflow:hidden}.kpi-card-modern:after{content:"";position:absolute;right:-20px;top:-20px;width:100px;height:100px;background:#ffffff1a;border-radius:50%}.gradient-blue{background:linear-gradient(135deg,#2563eb,#1e40af)}.gradient-green{background:linear-gradient(135deg,#10b981,#047857)}.kpi-info p{margin:0;font-size:.8rem;font-weight:600;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.kpi-info h3{margin:4px 0 0;font-size:1.8rem;font-weight:700}.kpi-icon{font-size:2.2rem;opacity:.8}.charts-grid-modern{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.chart-card-modern{background-color:var(--bg-card);border-radius:12px;padding:20px;border:1px solid var(--border-light);box-shadow:0 6px 20px var(--shadow);transition:transform .2s;overflow-x:auto}.chart-card-modern:hover{transform:translateY(-2px);box-shadow:0 10px 25px var(--shadow)}.chart-header{margin-bottom:15px;text-align:left;border-bottom:1px dashed var(--border-light);padding-bottom:10px}.chart-header h4{margin:0 0 4px;color:var(--text-main);font-size:1rem;font-weight:700}.chart-header p{margin:0;color:var(--text-muted);font-size:.75rem}.pie-card{grid-column:1 / -1}.custom-tooltip{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px;border-radius:8px;border:1px solid var(--border-light);box-shadow:0 6px 15px var(--shadow)}.tooltip-label{margin:0;font-weight:700;color:var(--text-main);font-size:.85rem}.tooltip-divider{height:1px;background:var(--border-light);margin:6px 0}.tooltip-value{margin:0;display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-muted)}.tooltip-value .dot{width:8px;height:8px;border-radius:50%;display:inline-block}.tooltip-value strong{color:var(--text-main);font-size:.95rem}.calendario-contenedor{background-color:var(--bg-card);padding:20px;border-radius:0 0 12px 12px;border:1px solid var(--border-light);border-top:none;margin-bottom:30px;overflow-x:auto;-webkit-overflow-scrolling:touch}.rbc-calendar{min-width:600px}.rbc-month-view{border:1px solid var(--border-light);border-radius:8px;overflow:hidden}.rbc-header{padding:8px 0;background-color:var(--bg-app);font-weight:600;color:var(--text-muted);font-size:.8rem;border-bottom:1px solid var(--border-light);text-transform:uppercase}.rbc-day-bg+.rbc-day-bg{border-left:1px solid var(--border-light)}.rbc-month-row+.rbc-month-row{border-top:1px solid var(--border-light)}.rbc-date-cell{padding:6px;font-size:.85rem;font-weight:600;color:var(--text-main)}.rbc-off-range-bg{background-color:var(--bg-app);opacity:.7}.rbc-today{background-color:#2563eb0d!important}body.dark-mode .rbc-today{background-color:#ffffff0d!important}.rbc-toolbar{margin-bottom:15px;padding-top:5px;display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between}.rbc-toolbar button{font-family:Poppins,sans-serif;color:var(--text-muted);border:1px solid var(--border-light);border-radius:6px;font-weight:500;padding:6px 12px;font-size:.85rem}.rbc-toolbar button.rbc-active{background-color:var(--text-main);color:var(--bg-card);border-color:var(--text-main)}.rbc-month-row{min-height:45px!important}.rbc-event{min-height:16px!important;padding:2px 6px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-select,.modal-textarea,.modal-input{width:100%;padding:12px 15px;border:1px solid var(--border-light);border-radius:8px;font-size:.85rem;color:var(--text-main);background-color:var(--input-bg);font-family:Poppins,sans-serif;transition:.2s;box-sizing:border-box}.modal-select:focus,.modal-textarea:focus,.modal-input:focus{border-color:var(--blue-kpi);background-color:var(--bg-card);box-shadow:0 0 0 3px #2563eb1a;outline:none}.box-foto-antes{margin-top:15px;background-color:var(--hover-bg);padding:15px;border-radius:10px;border:1px dashed var(--border-light)}.box-foto-antes input[type=file]{width:100%;font-size:.8rem}.actividad-badge-info{background-color:#2563eb1a;border:1px solid var(--blue-kpi);padding:12px 15px;border-radius:8px;margin-bottom:15px;color:var(--blue-kpi)}.firma-box{border:2px solid var(--border-light);border-radius:10px;background-color:#fff;margin-top:8px;overflow:hidden;width:100%}.sigCanvas{width:100%!important;height:150px!important;touch-action:none}.viewer-modal{background-color:var(--bg-app)!important;overflow-x:hidden}.viewer-grid-info{display:grid;grid-template-columns:1fr 1fr;gap:15px;background-color:var(--bg-card);padding:20px;border-radius:12px;box-shadow:0 4px 15px var(--shadow);margin-bottom:25px;border:1px solid var(--border-light)}.viewer-actividad-card{background-color:var(--bg-card);border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 4px 15px var(--shadow);border:1px solid var(--border-light)}.viewer-number{background-color:#2563eb1a;padding:5px 10px;border-radius:8px;color:var(--blue-kpi)}.viewer-foto-box{background-color:var(--hover-bg);padding:15px;border-radius:10px;border:1px dashed var(--border-light)}.viewer-no-foto{padding:20px;text-align:center;background-color:var(--border-light);border-radius:8px;color:var(--text-muted);font-size:.8rem}.viewer-cierre-box{background-color:#ef44440d;border:1px solid rgba(239,68,68,.3);border-radius:12px;padding:20px;margin-top:30px}.viewer-firma-box{margin-top:15px;background-color:var(--bg-card);padding:10px;border-radius:8px;border:1px solid var(--border-light);display:inline-block;max-width:100%}.viewer-firma-box img{max-width:100%;height:auto}@media(max-width:992px){.charts-grid-modern{grid-template-columns:1fr}.video-header{flex-direction:column;align-items:stretch;text-align:center}.video-header h2{justify-content:center}.video-header>div:last-child{justify-content:center}.modern-filters{flex-direction:column;gap:10px}}@media(max-width:768px){.planificacion-wrap{padding:0 10px}.view-toggle-container{width:100%;justify-content:center;display:flex}.view-toggle-btn{flex:1;padding:10px 5px;font-size:.8rem}.heartbeat-btn{width:100%;justify-content:center}.filters-date-bar{justify-content:center;text-align:center}.filters-date-bar>div:first-child{width:100%;justify-content:center;margin-bottom:10px}.btn-filter-date{flex:1;min-width:30%;text-align:center;justify-content:center}.filters-date-bar>div:last-child{width:100%;justify-content:center;margin-top:10px;border-left:none;padding-left:0;flex-direction:column}.modal-content{padding:20px 15px;width:95%;margin:10px auto}.viewer-grid-info{grid-template-columns:1fr;gap:10px}.viewer-actividad-card>div{grid-template-columns:1fr!important}.info-cliente-premium{flex-direction:column;text-align:center;gap:10px}.bifurcacion-botones{flex-direction:column}.large-btn{width:100%;min-width:100%}.rbc-toolbar{flex-direction:column;justify-content:center;gap:15px}.rbc-toolbar .rbc-btn-group{display:flex;flex-wrap:wrap;justify-content:center;width:100%;gap:5px}.rbc-toolbar button{flex:1;min-width:30%;text-align:center}.lista-agrupada-container{padding:15px}.accordion-header{flex-direction:column;align-items:flex-start;gap:10px}.accordion-header>div{width:100%}.icon-collapse{position:absolute;right:20px;top:25px}.cliente-accordion{position:relative}}@media(max-width:480px){.ruta-activa-header{flex-direction:column;text-align:center;padding:15px;gap:15px}.ruta-activa-body{padding:15px}.premium-card{padding:20px 15px}.kpi-card-modern{flex-direction:column;text-align:center;gap:15px}.kpi-card-modern:after{right:50%;transform:translate(50%);top:-50px}.btn-filter-date{min-width:45%}.video-header h2,.info-cliente-premium h3{font-size:1.1rem}}
