.login-container{display:flex;flex-direction:column;align-items:center;margin:80px auto;font-family:Segoe UI,sans-serif}.login-card{width:100%;max-width:400px;background-color:#fff;padding:30px 40px;border-radius:12px;box-shadow:0 6px 20px #0000001a;text-align:center}.dark .login-card{background-color:#1e293b;color:#f1f5f9}.login-card img{width:120px;margin-bottom:20px}.login-card h2{font-size:1.3rem;margin-bottom:20px;color:#333}.dark .login-card h2{color:#f1f5f9}.login-form{display:flex;flex-direction:column;gap:15px}.login-form input{padding:12px;border:1px solid #ccc;border-radius:8px;transition:border-color .3s ease;background-color:#f9fafb}.login-form input:focus{border-color:#3f51b5;outline:none}.dark .login-form input{background-color:#334155;border:1px solid #475569;color:#f8fafc}.dark .login-form input::placeholder{color:#94a3b8}.login-form button{padding:12px;background-color:#3f51b5;color:#fff;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s ease}.login-form button:hover{background-color:#303f9f}.dark .login-form button{background-color:#4f46e5}.dark .login-form button:hover{background-color:#4338ca}.login-error{color:#e53935;font-size:.9rem;text-align:center;margin-top:10px}.dark .login-error{color:#f87171}:root{--bg: #ffffff;--text: #111827;--subtext: #475569;--card-bg: #ffffff;--card-title: #64748b;--card-value: #1e40af;--input-bg: #fff;--input-text: #334155;--input-border: #cbd5e1;--input-disabled-bg: #f1f5f9;--input-disabled-text: #94a3b8;--chart-title: #1f2937;--loading: #4b5563;--border: #e5e7eb}html.dark{--bg: #0b1220;--text: #f1f5f9;--subtext: #94a3b8;--card-bg: #0f172a;--card-title: #cbd5e1;--card-value: #e0f2fe;--input-bg: #0f172a;--input-text: #f1f5f9;--input-border: #334155;--input-disabled-bg: #1f2937;--input-disabled-text: #64748b;--chart-title: #f1f5f9;--loading: #cbd5e1;--border: #334155}.dashboard-container{max-width:1600px;margin:0 auto;padding:16px;background:var(--bg);color:var(--text);border-radius:16px;box-shadow:0 6px 24px #0000000a;font-family:Inter,Segoe UI,sans-serif;min-height:calc(100vh - 32px);transition:background .3s ease,color .3s ease}@media (min-width: 640px){.dashboard-container{padding:20px}}@media (min-width: 1024px){.dashboard-container{padding:28px}}@media (min-width: 1280px){.dashboard-container{padding:32px}}.dash-head{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}@media (min-width: 640px){.dash-head{flex-direction:row;align-items:center;justify-content:space-between}}.dashboard-header{font-size:clamp(1.5rem,1.2rem + 1.5vw,2.2rem);font-weight:700;margin-bottom:2px}.welcome-message{font-size:.95rem;color:var(--subtext)}.dash-state{color:#64748b;display:flex;align-items:center;gap:8px}.filters-bar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:12px 0 20px}.account-select,.filters-bar select,.filters-bar input[type=date]{padding:.5rem .75rem;font-size:.9rem;border-radius:8px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--input-text);outline:none;transition:border .2s ease}.filters-bar select:disabled,.filters-bar input[type=date]:disabled{background:var(--input-disabled-bg);color:var(--input-disabled-text)}.radio-group{display:flex;align-items:center;gap:10px}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:18px}@media (min-width: 640px){.stats-grid{grid-template-columns:repeat(3,1fr);gap:14px}}@media (min-width: 1024px){.stats-grid{grid-template-columns:repeat(6,1fr);gap:16px}}.stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:14px;text-align:center}.stat-card h3{font-size:.95rem;color:var(--card-title);margin-bottom:4px}.stat-card p{font-size:clamp(1.1rem,.9rem + .8vw,1.6rem);font-weight:700;color:var(--card-value)}.dash-sub{margin:4px 0 8px;opacity:.8;font-size:.85rem}.charts-grid{display:grid;gap:16px}@media (min-width: 1024px){.charts-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.chart-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:12px}.chart-title{font-weight:600;margin-bottom:8px;color:var(--chart-title)}.chart-box{position:relative;width:100%;aspect-ratio:16 / 9}.chart-box>*{position:absolute;top:0;right:0;bottom:0;left:0}.dash-foot{margin-top:10px;text-align:center;opacity:.85}.dashboard-loading{font-size:1.1rem;padding:2rem;color:var(--loading);text-align:center}.skeleton-box{background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 37%,#e5e7eb 63%);background-size:400% 100%;animation:skeleton-shimmer 1.4s ease infinite}@keyframes skeleton-shimmer{0%{background-position:100% 0}to{background-position:0 0}}.error-banner{background:#fef2f2;color:#991b1b;border:1px solid #fecaca;padding:10px 12px;border-radius:8px;margin-bottom:12px}html.dark .error-banner{background:#2a1313;color:#fecaca;border-color:#7f1d1d}.campaign-form{background-color:#fff;color:#1f2937;padding:30px;border-radius:12px;box-shadow:0 8px 20px #0000000f;font-family:Segoe UI,sans-serif;max-width:720px;margin:0 auto}.campaign-form h1,.campaign-form h2{font-size:1.6rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:10px;color:#1e293b}.dark .campaign-form h1,.dark .campaign-form h2{color:#f1f5f9}.campaign-form label{display:block;margin-top:20px;font-weight:500;color:#374151}.dark .campaign-form label{color:#cbd5e1}.campaign-form textarea,.campaign-form select,.campaign-form input[type=text],.campaign-form input[type=email],.campaign-form input[type=number]{width:100%;margin-top:5px;padding:12px;border-radius:8px;border:1px solid #ccc;font-size:.95rem;background-color:#fff;color:#111827}.dark .campaign-form textarea,.dark .campaign-form select,.dark .campaign-form input[type=text],.dark .campaign-form input[type=email],.dark .campaign-form input[type=number]{background-color:#334155;border:1px solid #475569;color:#f8fafc}.modo-selector{display:flex;gap:2rem;margin-bottom:1rem}.modo-selector label{display:flex;align-items:center;gap:10px;font-weight:500;color:#374151;cursor:pointer}.dark .modo-selector label{color:#cbd5e1}.params-section{margin-top:20px}.preview-section{margin-top:30px}.preview-box{background-color:#f9fafb;padding:20px;border-radius:10px;border-left:4px solid #6366f1;font-size:.95rem;line-height:1.5;color:#1f2937}.dark .preview-box{background-color:#334155;border-left-color:#818cf8;color:#f1f5f9}.preview-box strong{display:block;margin-bottom:10px;color:#111827}.dark .preview-box strong{color:#f8fafc}.enviar-btn{margin-top:30px;padding:12px 24px;background-color:#3f51b5;color:#fff;border:none;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;transition:background-color .3s ease}.enviar-btn:hover{background-color:#303f9f}.dark .enviar-btn{background-color:#4f46e5}.dark .enviar-btn:hover{background-color:#4338ca}.campaign-form{background-color:#fff;color:#1f2937;padding:30px;border-radius:12px;box-shadow:0 8px 20px #0000000f;font-family:Segoe UI,sans-serif;max-width:720px;margin:0 auto;text-align:left}.dark .campaign-form{background-color:#1e293b;color:#f1f5f9}.campaign-form h1,.campaign-form h2,.campaign-form h4,.campaign-form label,.campaign-form input,.campaign-form textarea,.campaign-form select,.campaign-form .preview-box,.campaign-form .params-section,.campaign-form .preview-section{text-align:left!important}.campaign-form input,.campaign-form textarea,.campaign-form select{display:block;margin-left:0}.campaign-form input[type=datetime-local]{width:100%;margin-top:5px;padding:12px;border-radius:8px;border:1px solid #ccc;font-size:.95rem;background-color:#fff;color:#111827}.dark .campaign-form input[type=datetime-local]{background-color:#334155;border:1px solid #475569;color:#f8fafc}.cw-toast{padding:12px;border-radius:6px;margin-bottom:20px;font-size:.95rem}.cw-toast--error{background-color:#fdecea;color:#b71c1c}.cw-toast--success{background-color:#e8f5e9;color:#1b5e20}.cw-toast__details{margin-top:10px;white-space:pre-wrap}.cw-uploader{margin-top:20px;border:2px dashed #d1d5db;border-radius:8px;padding:20px;text-align:center;background-color:#fafafa;position:relative;transition:background-color .2s,border-color .2s}.cw-uploader:hover{background-color:#f0f4f8;border-color:#9ca3af}.cw-uploader label{cursor:pointer;font-size:.95rem;color:#4b5563}.cw-uploader input[type=file]{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.cw-uploader__preview{margin-top:15px}.cw-uploader__preview img{max-width:200px;max-height:200px;border-radius:6px;box-shadow:0 4px 12px #00000014}.preview-header-img{max-width:300px;height:auto;margin-bottom:1rem;border-radius:6px}.dark .cw-uploader{background-color:#334155;border-color:#475569}.dark .cw-uploader:hover{background-color:#3e4a63}.dark .cw-uploader label{color:#cbd5e1}.campaigns-container{background:#fff;padding:2rem;border-radius:16px;font-family:Inter,Segoe UI,sans-serif;box-shadow:0 6px 24px #0000000f;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.campaigns-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;margin-bottom:1.8rem;gap:1rem}.header-left{display:flex;align-items:center;gap:1rem}.header-right{display:flex;align-items:center;gap:.6rem}.campaigns-title{font-size:1.7rem;font-weight:700;color:#1e293b;margin:0}.account-select{padding:.55rem 1rem;font-size:.95rem;border:1px solid #cbd5e1;border-radius:8px;background-color:#f9fafb;color:#1e293b;box-shadow:0 1px 3px #0000000d;transition:border .3s,box-shadow .3s}.account-select:hover{border-color:#94a3b8;box-shadow:0 2px 6px #00000012}.account-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}.add-campaign-btn,.close-sidebar,.csv-export-btn{background:#2d66f5;color:#fff;padding:.55rem 1.2rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;box-shadow:0 2px 8px #2d66f540;transition:background .2s ease;cursor:pointer}.add-campaign-btn:hover,.close-sidebar:hover{background:#1e40af}.csv-export-btn{background-color:#10b981;box-shadow:0 2px 6px #10b9814d}.csv-export-btn:hover{background-color:#059669}.campaigns-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.8rem;padding:.8rem 1rem;background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:12px}.campaigns-list{display:flex;flex-direction:column;gap:1rem}.campaign-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:transform .25s ease,box-shadow .3s ease;box-shadow:0 2px 4px #0000000a}.campaign-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px #00000014}.campaign-title-date{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.campaign-title{color:#2563eb;font-size:1.15rem;font-weight:700}.campaign-date{color:#6b7280;font-size:.85rem}.campaign-description{font-size:.95rem;color:#374151;margin-bottom:.5rem}.campaign-meta{display:flex;gap:1.5rem;font-size:.9rem;color:#4b5563;margin-bottom:.5rem}.contact-title{text-align:left;margin-top:1rem;margin-left:0;font-weight:600;color:#1f2937;font-size:.95rem}.contact-list{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.3rem}.contact-card{display:flex;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:999px;padding:.45rem .75rem;box-shadow:0 1px 2px #0000000d;font-size:.85rem}.contact-avatar{background:#3b82f6;color:#fff;font-weight:600;font-size:.75rem;border-radius:999px;width:26px;height:26px;display:flex;align-items:center;justify-content:center;margin-right:.5rem}.message-status{font-size:.75rem;color:#6b7280}.status-read{color:#10b981}.status-delivered{color:#3b82f6}.status-sent{color:#f59e0b}.status-sin_estado{color:#9ca3af}.message-status:before{content:"●";margin-right:4px;font-size:.7rem}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:.75rem;margin-top:2rem;font-size:.9rem}.pagination-controls button{background:#f3f4f6;border:1px solid #d1d5db;padding:.45rem .75rem;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s ease}.pagination-controls button:hover:not(:disabled){background:#e5e7eb}.pagination-controls button:disabled{opacity:.5;cursor:not-allowed}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1000;display:flex;justify-content:flex-end;animation:fadeIn .3s ease-in-out}.sidebar-panel{background:#fff;width:320px;max-width:90vw;height:100%;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;box-shadow:-2px 0 6px #0000001a;animation:slideIn .3s ease forwards;overflow-y:auto}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.sidebar-panel h3{font-size:1.2rem;font-weight:600;color:#1e293b}.sidebar-panel label{text-align:left;display:block;margin-bottom:.2rem}.sidebar-panel input,.sidebar-panel select{background:#f9fafb;border:1px solid #d1d5db;padding:.5rem;border-radius:8px;font-size:.95rem}.filters-float-button{position:fixed;bottom:30px;right:30px;background-color:#2d66f5;color:#fff;border-radius:50%;padding:.8rem;box-shadow:0 6px 20px #00000026;cursor:pointer;z-index:1000;display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.filters-float-button:hover{transform:scale(1.1)}.filters-float-button .tooltip{visibility:hidden;opacity:0;background-color:#1f2937;color:#fff;text-align:center;border-radius:6px;padding:.3rem .6rem;position:absolute;bottom:120%;right:50%;transform:translate(50%);white-space:nowrap;font-size:.75rem;transition:opacity .3s;pointer-events:none}.filters-float-button:hover .tooltip{visibility:visible;opacity:1;transform:translate(50%) scale(1)}.toast-success{position:fixed;bottom:30px;right:30px;background-color:#10b981;color:#fff;padding:.9rem 1.5rem;border-radius:12px;font-size:.95rem;font-weight:500;box-shadow:0 6px 20px #10b98159;z-index:9999;animation:toastInOut 3s ease forwards}@keyframes toastInOut{0%{opacity:0;transform:translateY(20px)}10%,90%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.retry-button{margin-left:8px;background:none;border:none;cursor:pointer;color:#555}.retry-button:hover{color:#1d72b8}.retry-button.loading svg{animation:spin 1s linear infinite;color:#2563eb}body.dark,html[data-theme=dark]{background-color:#0f172a;color:#e2e8f0}body.dark .campaigns-container,html[data-theme=dark] .campaigns-container{background:#1e293b;box-shadow:0 6px 24px #0006}body.dark .campaigns-title,html[data-theme=dark] .campaigns-title,body.dark .account-label{color:#f1f5f9}body.dark .account-select,html[data-theme=dark] .account-select{background-color:#334155;border-color:#475569;color:#f8fafc}body.dark .account-select:hover{border-color:#64748b}body.dark .campaigns-toolbar,html[data-theme=dark] .campaigns-toolbar{background-color:#334155;border-color:#475569;color:#f8fafc}body.dark .campaigns-toolbar span{color:#f1f5f9}body.dark .campaign-card{background:#1e293b;border-color:#334155;box-shadow:0 2px 6px #0000004d}body.dark .campaign-title{color:#60a5fa}body.dark .campaign-date,body.dark .campaign-meta,body.dark .campaign-description,body.dark .message-status{color:#cbd5e1}body.dark .contact-card{background:#0f172a;border-color:#334155;color:#e2e8f0}body.dark .contact-avatar{background-color:#3b82f6;color:#fff}body.dark .csv-export-btn{background-color:#059669;box-shadow:0 2px 6px #10b9814d}body.dark .csv-export-btn:hover{background-color:#047857}body.dark .pagination-controls button{background:#1e293b;border-color:#334155;color:#e2e8f0}body.dark .pagination-controls button:hover:not(:disabled){background:#2f3e56}body.dark .sidebar-panel{background:#1e293b;color:#f1f5f9}body.dark .sidebar-panel input,body.dark .sidebar-panel select{background:#0f172a;border-color:#334155;color:#f1f5f9}body.dark .filters-float-button{background-color:#3b82f6;color:#fff}body.dark .filters-float-button .tooltip{background-color:#0f172a;color:#f8fafc}body.dark .toast-success{background-color:#059669;box-shadow:0 6px 20px #05966966}body.dark .retry-button{color:#cbd5e1}html.dark .campaigns-container{background:#1e293b;color:#e2e8f0}html.dark .campaign-card{background:#334155;border-color:#475569;box-shadow:0 2px 8px #0006}html.dark .campaign-title{color:#93c5fd}html.dark .campaign-date{color:#cbd5e1}html.dark .campaign-description{color:#e2e8f0}html.dark .campaign-meta{color:#cbd5e1}html.dark .message-content{color:#e2e8f0;text-align:left!important}.message-content{text-align:left!important;margin-top:.5rem;font-size:.95rem;color:#111827;line-height:1.5}html.dark .contact-card{background:#475569;border-color:#64748b;color:#f1f5f9}html.dark .contact-avatar{background:#60a5fa}html.dark .message-status{color:#f1f5f9}html.dark .pagination-controls button{background:#475569;border-color:#64748b;color:#e2e8f0}html.dark .filters-float-button{background-color:#3b82f6}html.dark .sidebar-panel{background:#1e293b;color:#e2e8f0}html.dark .sidebar-panel input,html.dark .sidebar-panel select{background:#334155;border-color:#64748b;color:#f1f5f9}html.dark .csv-export-btn{background-color:#22c55e}html.dark .campaigns-toolbar{background-color:#334155;border-color:#475569;color:#f1f5f9}html.dark .account-select{background-color:#475569;color:#f8fafc;border-color:#64748b}body.dark .account-label,html.dark .account-label,body.dark .campaigns-toolbar span,html.dark .campaigns-toolbar span{color:#f8fafc}body.dark .campaign-description{text-align:left}.campaign-description{text-align:left!important}body.dark .retry-button{color:#e2e8f0}body.dark .retry-button:hover{color:#60a5fa}body.dark .retry-button.loading svg{color:#60a5fa}.contact-title{font-weight:600;font-size:.95rem;color:#1f2937}body.dark .contact-title{color:#f1f5f9}.campaigns-toolbar span{font-size:.95rem;font-weight:500;color:#1e293b}html.dark .campaigns-toolbar span{color:#f1f5f9}.account-label{font-size:.95rem;color:#334155;font-weight:500}html.dark .account-label,html.dark .campaigns-title{color:#f1f5f9}html.dark .contact-title{color:#f1f5f9!important}body.dark .retry-button svg{color:#f1f5f9}body.dark .retry-button svg,html.dark .retry-button svg{color:#f1f5f9!important}html.dark .account-label,body.dark .account-label,html.dark .campaigns-toolbar span,body.dark .campaigns-toolbar span,html.dark .contact-title,body.dark .contact-title{color:#f1f5f9!important}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.modal-content{background:#fff;border-radius:12px;padding:2rem;width:90%;max-width:600px;max-height:80vh;overflow-y:auto;position:relative}.close-modal{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.3rem;cursor:pointer}.modal-search{width:100%;margin-bottom:1rem;padding:.5rem;border-radius:8px;border:1px solid #ccc}.contact-list-modal{display:flex;flex-direction:column;gap:.5rem}.view-contacts-btn{background:none;border:none;color:#3b82f6;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;padding:.3rem 0}.view-contacts-btn:hover{color:#1d4ed8}.contact-list-actions{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.view-all-btn{background:none;border:none;color:#3b82f6;font-weight:600;cursor:pointer}.view-all-btn:hover{color:#1d4ed8}.contact-list-table{display:flex;flex-direction:column;gap:.5rem}.contact-row{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:1rem;padding:.5rem 0;border-bottom:1px solid #e5e7eb}.contact-avatar{font-size:1.2rem}.contact-name{font-weight:500;color:#374151}.message-status{font-size:.85rem}.retry-button{background:none;border:none;color:#3b82f6;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.3rem}.retry-button:hover{color:#1d4ed8}.status-read{color:#10b981;font-size:1.2rem}.status-delivered{color:#3b82f6;font-size:1.2rem}.status-sent{color:#f59e0b;font-size:1.2rem}.status-failed{color:#ef4444;font-size:1.2rem}.status-unknown{color:#9ca3af;font-size:1.2rem}.contact-list-table .message-status:before{content:none!important}html.dark input,html.dark select,html.dark button{background-color:#334155;color:#f1f5f9;border-color:#475569}html.dark .modal-content,body.dark .modal-content{background:#1e293b;color:#f1f5f9}html.dark .modal-search{background:#334155;border-color:#475569;color:#f1f5f9}html.dark .contact-name{color:#f1f5f9}html.dark .contact-row{border-bottom:1px solid #475569}.csv-export-btn.loading{position:relative}.csv-export-btn.loading:after{content:"";position:absolute;right:12px;width:16px;height:16px;border:2px solid #fff;border-top:2px solid #10b981;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:3px solid #f3f3f3;border-top:3px solid #fff;border-radius:50%;width:14px;height:14px;animation:spin 1s linear infinite;display:inline-block;vertical-align:middle;margin-right:8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}html,body,#root{height:100%}.layout{display:flex;min-height:100vh;font-family:Segoe UI,sans-serif;background:#fff}.topbar{position:sticky;top:0;z-index:30;height:56px;padding:0 12px;display:none;align-items:center;justify-content:space-between;background:var(--bg);border-bottom:1px solid var(--border)}.topbar-btn{width:36px;height:36px;border:0;border-radius:8px;background:transparent;display:inline-flex;align-items:center;justify-content:center;color:var(--text)}.topbar-btn:hover{background:#94a3b826}.topbar-title{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text)}.topbar-logo{height:22px}.topbar-spacer{width:36px}@media (max-width: 1023px){.topbar{display:flex}}.sidebar{width:240px;background-color:#f9fafb;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;transition:width .25s ease,transform .25s ease;z-index:40}.sidebar.collapsed{width:72px}.sidebar-header{position:relative;padding:16px 12px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid #e5e7eb}.sidebar-logo{height:28px;transition:opacity .2s ease}.sidebar-logo--icon{display:none;height:30px}.sidebar-logo--full{display:block}.sidebar.collapsed .sidebar-logo--full{display:none}.sidebar.collapsed .sidebar-logo--icon{display:block;margin-top:-32px;margin-bottom:26px}.hamburger{position:absolute;right:8px;top:8px;width:36px;height:36px;border:0;border-radius:8px;background:transparent;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:#374151;z-index:2}.hamburger:hover{background:#eef2ff}.menu{display:flex;flex-direction:column;gap:8px;padding:12px;margin:0}.menu-item{display:flex;align-items:center;gap:12px;text-decoration:none;color:#4b5563;font-weight:500;padding:10px 12px;border-radius:8px;transition:background .2s ease,color .2s ease;white-space:nowrap}.menu-item:hover,.menu-item.active{background-color:#e0e7ff;color:#1e40af}.menu-icon{font-size:1.2rem;flex-shrink:0}.menu-text{overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .menu-item{justify-content:center;padding:10px 0}.sidebar.collapsed .menu-item .menu-text{display:none}.sidebar-footer{margin-top:auto;padding:16px 12px 20px;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;align-items:center;gap:10px}.profile-avatar,.profile-initials{width:44px;height:44px;border-radius:9999px;object-fit:cover}.profile-initials{background-color:#3b82f6;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}.profile-info{text-align:center}.profile-name{font-weight:600;font-size:.95rem;color:#1f2937}.profile-email{font-size:.8rem;color:#64748b}.logout-btn{margin-top:6px;padding:8px 12px;background-color:#ef4444;color:#fff;border:none;border-radius:8px;cursor:pointer;width:100%;transition:background-color .2s ease}.logout-btn:hover{background-color:#dc2626}.sidebar.collapsed .profile-info,.sidebar.collapsed .logout-btn{display:none}.main-content{flex-grow:1;background-color:#fff;min-width:0}.content-wrap{max-width:1600px;margin:0 auto;padding:16px}@media (min-width: 640px){.content-wrap{padding:20px}}@media (min-width: 1024px){.content-wrap{padding:32px}}@media (min-width: 1280px){.content-wrap{padding:40px}}html.dark .sidebar{background-color:#1f2937;border-color:#374151}html.dark .sidebar-header{border-bottom-color:#374151}html.dark .menu-item{color:#d1d5db}html.dark .menu-item:hover,html.dark .menu-item.active{background-color:#374151;color:#60a5fa}html.dark .sidebar-footer{border-top-color:#374151;color:#9ca3af}html.dark .main-content{background-color:#111827;color:#f9fafb}html.dark .topbar{background:var(--bg);border-bottom-color:var(--border)}html.dark .topbar-title,html.dark .topbar-btn{color:var(--text)}html.dark .topbar-btn:hover{background:#64748b40}@media (max-width: 1023px){.layout{display:block}.sidebar{position:fixed;left:0;top:0;bottom:0;width:82vw;max-width:320px;transform:translate(-100%);box-shadow:0 10px 30px #00000026}.sidebar.open{transform:translate(0)}.sidebar.collapsed{width:82vw}.sidebar.collapsed .menu-item{justify-content:flex-start;padding:10px 12px}.sidebar.collapsed .menu-item .menu-text{display:inline}.sidebar.collapsed .sidebar-logo--full{display:block}.sidebar.collapsed .sidebar-logo--icon{display:none}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:20}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center;transition:background .3s,color .3s}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}html.dark,html.dark #root{background-color:#0f172a;color:#f1f5f9}html.dark a{color:#60a5fa}html.dark .card{background-color:#1e293b;border:1px solid #334155;box-shadow:0 2px 10px #0006}html.dark .read-the-docs{color:#94a3b8}html.dark .dark-toggle-button{background-color:#1e293b;color:#f8fafc;border:1px solid #475569}.darkmode-toggle{position:fixed;top:20px;right:20px;background:transparent;border:none;color:#64748b;font-size:1rem;cursor:pointer;z-index:9999;transition:color .3s}.darkmode-toggle:hover{color:#0ea5e9}html.dark{background-color:#0f172a;color:#e2e8f0}.labels-container{padding:2rem;background:var(--bg);border-radius:12px;box-shadow:0 4px 20px #0000000d}.labels-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.labels-header h2{margin:0}.labels-header p{flex:1;margin:0 1rem;color:var(--subtext)}.add-label-btn{background-color:#3b82f6;color:#fff;border:none;border-radius:8px;padding:.6rem 1rem;cursor:pointer;font-weight:600}.add-label-btn:hover{background-color:#2563eb}.filters-bar{margin-bottom:1rem}.labels-table{width:100%;border-collapse:collapse}.labels-table th,.labels-table td{padding:.75rem;border-bottom:1px solid #e5e7eb;text-align:left}.color-box{display:inline-block;width:20px;height:20px;border-radius:4px;margin-right:.5rem;vertical-align:middle}.actions button{background:none;border:none;cursor:pointer;margin-right:.5rem;font-size:1.1rem;color:#374151}.actions button:hover{color:#111827}.labelnew-container{max-width:500px;margin:2rem auto;background:var(--card-bg);padding:2rem;border-radius:12px;box-shadow:0 4px 20px #00000014;text-align:left}.labelnew-form h2{margin-bottom:.5rem;font-size:1.5rem}.labelnew-form p{margin-bottom:1.5rem;color:var(--subtext)}.labelnew-group{margin-bottom:1rem}.labelnew-group label{display:block;margin-bottom:.3rem;font-weight:600}.labelnew-group input[type=text],.labelnew-group input[type=color]{width:100%;padding:.6rem;border:1px solid var(--input-border);border-radius:8px}.labelnew-group input[type=color]{height:40px;padding:0}.form-group.checkbox label{display:flex;align-items:center;font-weight:500}.form-group.checkbox input{margin-right:.5rem}.labelnew-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.cancel-btn{background:#e2e8f0;border:none;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer}.cancel-btn:hover{background:#cbd5e1}.create-btn{background:#3b82f6;color:#fff;border:none;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer}.create-btn:hover{background:#2563eb}.labelnew-error{background:#fee2e2;color:#b91c1c;padding:.5rem;border-radius:8px;margin-bottom:1rem}.delete-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:9999}.delete-modal-content{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 20px #0003;max-width:400px;width:100%}.delete-modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.delete-btn{background:#ef4444;color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;cursor:pointer}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:9999}.modal-content{background:#fff;padding:2rem;border-radius:12px;max-width:500px;width:100%;text-align:left}.modal-group{margin-bottom:1rem}.modal-group label{display:block;font-weight:600;margin-bottom:.4rem}.modal-group input[type=text],.modal-group input[type=color]{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:8px}.modal-group input[type=color]{height:40px;padding:0}.modal-actions{display:flex;justify-content:flex-end;gap:1rem}.filters-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.filters-left{display:flex;align-items:center;gap:8px}.filters-right{display:flex;align-items:center;gap:10px}.search-box{position:relative;width:320px;max-width:42vw}.search-box .search-ico{position:absolute;top:9px;left:10px;pointer-events:none;opacity:.6}.search-box input{width:100%;padding:8px 10px 8px 32px;border:1px solid #e5e7eb;border-radius:8px;outline:none}.search-box input:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #93c5fd40}.sort-box{position:relative}.sort-box .sort-ico{position:absolute;right:10px;top:10px;pointer-events:none;opacity:.6}.sort-box select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:8px 30px 8px 10px;border:1px solid #e5e7eb;border-radius:8px;background:#fff}.contactos-container{padding:2rem;background:var(--bg);border-radius:12px;box-shadow:0 4px 20px #0000000d}.contactos-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.filters-bar{display:flex;align-items:center;gap:.5rem}.contactos-list{display:flex;flex-direction:column;gap:1rem}.contact-card{background:var(--card-bg);border-radius:8px;box-shadow:0 2px 8px #0000000d;display:flex;flex-direction:column;width:100%;position:relative;overflow:visible;z-index:0}.contact-row{display:flex;align-items:center;justify-content:flex-start;padding:.75rem;gap:1rem;cursor:pointer;width:100%;box-sizing:border-box}.contact-avatar{width:45px;height:45px;border-radius:50%;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-weight:700;overflow:hidden;flex-shrink:0}.contact-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-placeholder{color:#475569}.contact-info{flex-grow:1;display:flex;flex-direction:column}.first-line,.second-line{display:flex;align-items:center;gap:.4rem;font-size:.9rem;flex-wrap:wrap}.pipe{color:#cbd5e1}.mini-icon{color:#64748b;font-size:.85rem}.flag-icon{width:20px;height:auto;border-radius:3px}.expand-btn{margin-left:auto;background:none;border:none;font-size:1rem;cursor:pointer;color:#475569}.contact-details{border-top:1px solid #e5e7eb;padding:1rem;background:var(--card-bg);display:flex;flex-direction:column;gap:.75rem;width:100%;box-sizing:border-box}.contact-details h4{margin-top:.5rem;margin-bottom:.5rem;font-size:1rem;font-weight:600}.contact-details input,.contact-details select{width:100%;background:#f9fafb;border:1px solid #e5e7eb;padding:.5rem;border-radius:6px;font-size:.9rem}.contact-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.social-links{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.social-input{display:flex;align-items:center;gap:.5rem;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;padding:.4rem .8rem}.social-input svg{flex-shrink:0}.social-input input{border:none;background:transparent;width:100%;font-size:.85rem;color:#475569}.social-input input:focus{outline:none}.actions{margin-top:1rem}.update-btn,.delete-btn{padding:.5rem 1rem;border-radius:6px;border:none;cursor:pointer;margin-right:.5rem}.update-btn{background:#3b82f6!important;color:#fff!important}.update-btn:hover{background:#2563eb!important}.delete-btn{background:#ef4444!important;color:#fff!important}.delete-btn:hover{background:#dc2626!important}.delete-section{margin-top:1rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.delete-section p{font-size:.85rem;color:#64748b}.delete-now{color:#ef4444;cursor:pointer;font-weight:500}.delete-now:hover{text-decoration:underline}.pagination{margin-top:1rem;display:flex;justify-content:center;gap:1rem}.pagination button{background:#3b82f6;color:#fff;border:none;padding:.4rem .8rem;border-radius:6px;cursor:pointer}.pagination button:disabled{background:#cbd5e1;cursor:not-allowed}.contact-name-company{display:flex;align-items:center;gap:.5rem}.company-name{font-size:.9rem;color:#64748b}.contact-details-row{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.85rem;color:#475569}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}.modal-content{background:#fff;padding:2rem;border-radius:8px;max-width:400px;width:90%;text-align:center}.modal-actions{margin-top:1rem;display:flex;justify-content:space-between;gap:1rem}.modal-actions button{flex:1;padding:.5rem;border-radius:6px;border:none;cursor:pointer}.modal-actions button:first-child{background:#e5e7eb}.modal-actions button:last-child{background:#ef4444;color:#fff}.input-updated{border-color:#22c55e;background:#f0fdf4;transition:all .3s ease-in-out}.search-input{padding:.4rem .8rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.9rem}.search-input:focus{outline:none;border-color:#3b82f6}.third-line{margin-top:6px;margin-left:0;padding-left:0;display:flex;justify-content:flex-start}.lightbox-etiquetas{z-index:9999}.etiqueta-manager-container{position:relative;z-index:1000}.etiqueta-manager-container{position:relative;display:inline-block;margin-top:6px;z-index:1000}.chatwoot-label-button{background-color:transparent;color:#6b7280;border:1px dashed #cbd5e0;padding:4px 10px;font-size:14px;border-radius:6px;cursor:pointer;transition:all .2s ease-in-out}.chatwoot-label-button:hover{background-color:#f9fafb;border-color:#a0aec0;color:#374151}.lightbox-etiquetas{position:absolute;top:36px;left:0;background:#fff;border:1px solid #e5e7eb;box-shadow:0 4px 12px #0000001a;border-radius:8px;width:240px;z-index:9999;padding:12px;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.search-etiqueta{width:100%;padding:6px 8px;margin-bottom:8px;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;outline:none}.lista-etiquetas{max-height:180px;overflow-y:auto;margin-bottom:10px}.etiqueta-item{display:flex;align-items:center;font-size:14px;padding:6px 0;gap:8px;cursor:pointer}.etiqueta-item:hover{background-color:#f3f4f6;border-radius:4px;padding-left:4px}.etiqueta-item input{cursor:pointer}.color-dot{width:10px;height:10px;border-radius:50%;display:inline-block;vertical-align:middle;margin-right:2px}.acciones-etiqueta{display:flex;justify-content:space-between;gap:8px;margin-top:8px}.asignar-btn{background-color:#2563eb;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:13px;cursor:pointer;transition:background-color .2s ease}.asignar-btn:hover{background-color:#1d4ed8}.cancelar-btn{background-color:transparent;border:none;color:#6b7280;font-size:13px;cursor:pointer;transition:color .2s ease}.cancelar-btn:hover{color:#374151}.success-box,.error-box{margin-top:8px;font-size:13px;padding:6px;border-radius:6px}.success-box{background-color:#ecfdf5;color:#065f46;border:1px solid #34d399}.error-box{background-color:#fef2f2;color:#991b1b;border:1px solid #f87171}.lightbox-etiquetas:before{content:"";position:absolute;top:-8px;left:16px;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid #e5e7eb}.etiquetas-asignadas{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0 4px}.etiqueta-badge{color:#fff;padding:3px 8px;font-size:12px;border-radius:12px;line-height:1}.etiqueta-badge{display:inline-flex;align-items:center;padding:4px 8px;margin:2px;border-radius:16px;background-color:#ccc;font-size:13px}.etiqueta-remove{margin-left:6px;font-weight:700;cursor:pointer;color:#666}.etiqueta-remove:hover{color:#000}:root{--cw-bg: #ffffff;--cw-overlay: rgba(17, 24, 39, .35);--cw-border: #e5e7eb;--cw-muted: #6b7280;--cw-text: #111827;--cw-pill: #f7f7fb;--cw-placeholder: #9aa3b2;--cw-primary: #6477f2;--cw-primary-press: #5164e6;--cw-shadow: 0 16px 48px rgba(0,0,0,.12);--cw-radius: 14px;--h-control: 36px;--gap: 8px;--cw-focus: rgba(99,102,241,.18);--cw-focus-border: #c7d2fe}.dark,[data-theme=dark]{--cw-bg: #1f2430;--cw-overlay: rgba(4, 6, 12, .55);--cw-border: #2f3543;--cw-muted: #a3aab8;--cw-text: #e6e9ef;--cw-pill: #242a36;--cw-placeholder: #8c95a6;--cw-primary: #6f86ff;--cw-primary-press: #5f74ff;--cw-shadow: 0 16px 48px rgba(0,0,0,.35);--cw-focus: rgba(111,134,255,.22);--cw-focus-border: #6f86ff}.cw-modal,.cw-modal *{box-sizing:border-box}.cw-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--cw-overlay);display:flex;align-items:center;justify-content:center;padding:24px;z-index:50}.cw-modal{width:760px;max-width:calc(100vw - 48px);background:var(--cw-bg);border-radius:var(--cw-radius);box-shadow:var(--cw-shadow);overflow:hidden}.cw-modal-header{padding:18px 22px;border-bottom:1px solid var(--cw-border)}.cw-modal-header h4{margin:0;font-size:18px;font-weight:600;color:var(--cw-text)}.cw-alert{margin:16px 22px 0;padding:12px 14px;background:#fff2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:10px;font-size:14px}.dark .cw-alert,[data-theme=dark] .cw-alert{background:#3b2121;color:#fecaca;border-color:#7a3b3b}.cw-form{padding:18px 22px 22px}.cw-grid{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:12px 16px}@media (max-width: 720px){.cw-grid{grid-template-columns:1fr}}.cw-field{min-width:0}.cw-field label{display:block;font-size:12px;color:var(--cw-muted);margin-bottom:6px;text-align:left;padding-left:2px}.cw-input,.cw-modal select,.cw-modal textarea{width:100%;border:1px solid var(--cw-border);background:var(--cw-pill);color:var(--cw-text);border-radius:10px;padding:8px 12px;height:var(--h-control);font-size:14px;outline:none;transition:background .15s,border-color .15s,box-shadow .15s}.cw-input::placeholder,.cw-modal textarea::placeholder{color:var(--cw-placeholder)}.cw-input:focus,.cw-modal select:focus,.cw-modal textarea:focus{background:transparent;border-color:var(--cw-focus-border);box-shadow:0 0 0 3px var(--cw-focus)}.cw-phone{display:flex;align-items:stretch;gap:0;position:relative}.cw-phone-country,.cw-phone-dial,.cw-phone-input{height:var(--h-control);border:1px solid var(--cw-border);background:var(--cw-pill);color:var(--cw-text);font-size:14px}.cw-phone-country{width:56px;min-width:56px;max-width:56px;padding:0 6px;border-radius:10px 0 0 10px;border-right:none;text-align:center;-webkit-appearance:none;-moz-appearance:none;appearance:none}.cw-phone-dial{width:64px;min-width:64px;max-width:64px;display:flex;align-items:center;justify-content:center;border-radius:0;border-left:none;border-right:none;color:var(--cw-muted)}.cw-phone-input{flex:1 1 auto;padding:8px 12px;border-radius:0 10px 10px 0;border-left:none;background:var(--cw-pill)}.cw-phone-input::placeholder{color:var(--cw-placeholder)}.cw-phone:focus-within .cw-phone-country,.cw-phone:focus-within .cw-phone-dial,.cw-phone:focus-within .cw-phone-input{border-color:var(--cw-focus-border)}.cw-phone:focus-within:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:12px;box-shadow:0 0 0 3px var(--cw-focus);pointer-events:none}.cw-section-title{margin:18px 0 10px;font-size:13px;color:var(--cw-muted);text-align:center}.cw-social-grid{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:10px 12px;margin-bottom:6px}@media (max-width: 720px){.cw-social-grid{grid-template-columns:1fr}}.cw-chip{display:flex;align-items:center;gap:10px;background:var(--cw-pill);border:1px solid var(--cw-border);color:var(--cw-text);border-radius:999px;padding:6px 12px;height:var(--h-control)}.cw-chip-ico{font-size:16px;color:var(--cw-muted)}.cw-chip input{border:0;background:transparent;outline:none;width:100%;font-size:14px;color:var(--cw-text)}.cw-chip input::placeholder{color:var(--cw-placeholder)}.cw-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.cw-btn{height:40px;border-radius:10px;padding:0 14px;font-size:14px;border:1px solid transparent;cursor:pointer}.cw-btn.primary{background:var(--cw-primary);color:#fff}.cw-btn.primary:active{background:var(--cw-primary-press)}.cw-btn.ghost{background:transparent;color:var(--cw-muted);border-color:var(--cw-border)}.cw-btn:disabled{opacity:.6;cursor:not-allowed}.cw-contact-modal label{text-align:left;margin-bottom:6px}.cw-contact-modal .phone-group{display:flex;gap:4px}.cw-contact-modal .phone-group select{flex:0 0 60px}.cw-contact-modal .phone-group input{flex:1}.label-contacts-container{padding:1.25rem 1.5rem;background:var(--bg, #fff);border-radius:12px;box-shadow:0 4px 20px #0000000d}.lc-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.lc-header h2{margin:0;font-size:1.35rem;font-weight:700}.lc-back{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;border:1px solid #e5e7eb;background:#f8fafc;cursor:pointer}.lc-toolbar{display:flex;flex-wrap:wrap;gap:12px;margin:10px 0 14px}.lc-field{display:flex;flex-direction:column;gap:4px}.lc-label{font-size:12px;color:#64748b}.lc-control{height:36px;border:1px solid #e5e7eb;border-radius:8px;background:#f7f7fb;padding:6px 10px}.lc-select{width:200px}.lc-input{width:220px}.lc-label-select-wrap{display:flex;align-items:center;gap:8px}.lc-select--wide{width:260px}.lc-clear{height:36px;padding:0 10px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;cursor:pointer}.lc-clear:hover{background:#f8fafc}.lc-search{display:flex;flex-direction:column;gap:4px}.lc-search-wrap{display:flex;align-items:center;gap:8px;background:#f7f7fb;border:1px solid #e5e7eb;border-radius:8px;padding:0 10px;height:36px}.lc-search-ico{width:16px;height:16px;color:#94a3b8}.lc-search-input{flex:1;height:100%;border:0;background:transparent;outline:none}.lc-meta{display:flex;gap:14px;font-size:.9rem;color:#475569;margin-bottom:6px}.lc-table-wrapper{overflow:auto;border:1px solid #e5e7eb;border-radius:10px}.lc-table{width:100%;border-collapse:collapse;background:var(--card-bg,#fff)}.lc-table thead th{text-align:left;font-weight:600;font-size:.9rem;color:#475569;background:#f8fafc;border-bottom:1px solid #e5e7eb;padding:10px}.lc-table tbody td{padding:10px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.lc-namecell{display:flex;align-items:center;gap:10px}.lc-avatar{width:34px;height:34px;border-radius:50%;object-fit:cover}.lc-avatar--fallback{display:inline-flex;align-items:center;justify-content:center;background:#e2e8f0;color:#475569;font-weight:700}.lc-nameblock{display:flex;flex-direction:column}.lc-name{font-weight:600}.lc-sub{font-size:12px;color:#64748b}.lc-empty{text-align:center;color:#94a3b8;padding:18px 0}.lc-pagination{margin-top:12px;display:flex;justify-content:center;align-items:center;gap:12px}.lc-pagination button{height:34px;padding:0 10px;border:none;border-radius:8px;background:#6477f2;color:#fff;cursor:pointer}.lc-pagination button:disabled{background:#cbd5e1;cursor:not-allowed}.lc-footer-note{margin-top:12px;font-size:.9rem}.dark .label-contacts-container{background:#1f2430;box-shadow:0 10px 30px #0000004d}.dark .lc-control,.dark .lc-search-wrap,.dark .lc-clear{background:#242a36;border-color:#2f3543;color:#e6e9ef}.dark .lc-label{color:#c9d1e1}.dark .lc-table-wrapper{border-color:#2f3543}.dark .lc-table thead th{background:#242a36;border-color:#2f3543;color:#c9d1e1}.dark .lc-table tbody td{border-color:#2f3543;color:#e6e9ef}.dark .lc-avatar--fallback{background:#334155;color:#e2e8f0}.dark .lc-search-ico{color:#a0aec0}.lc-actions{display:flex;gap:8px;align-items:end;margin-top:24px}.lc-btn.danger{background:#ef4444}.lc-btn.danger:hover{background:#dc2626}.lc-actions{display:flex;align-items:flex-end;gap:8px}.lc-btn{height:36px;padding:0 12px;border-radius:8px;border:1px solid transparent;background:#6477f2;color:#fff;cursor:pointer}.lc-btn:disabled{opacity:.6;cursor:not-allowed}.lc-col-select{width:44px;text-align:center}.lc-col-select input[type=checkbox]{width:18px;height:18px;cursor:pointer}.mu-container{--border:#e5e7eb;--muted:#6b7280;--ink:#111827;color:var(--ink)}.mu-page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.mu-head-actions{display:flex;gap:8px;align-items:center}.mu-banner{padding:10px;border-radius:8px;margin-bottom:12px}.mu-input{border:1px solid var(--border);border-radius:8px;padding:8px 10px;min-width:320px;outline:none}.mu-input:focus{border-color:#a78bfa;box-shadow:0 0 0 3px #a78bfa33}.mu-subtle{opacity:.7}.mu-ghost{border:1px solid #e5e7eb;background:#fff;border-radius:8px;padding:8px 10px;cursor:pointer}.mu-ghost:hover{background:#f9fafb}.mu-danger{background:#ef4444;border:1px solid #ef4444;color:#fff;border-radius:8px;padding:8px 10px;cursor:pointer}.mu-danger:disabled,.mu-ghost:disabled{opacity:.5;cursor:not-allowed}.mu-small{border:1px solid #e5e7eb;background:#fff;border-radius:8px;padding:6px 10px;font-size:12px;cursor:pointer}.mu-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:2px 8px;border-radius:999px;border:1px solid transparent}.status-running{background:#eef2ff;border-color:#c7d2fe;color:#3730a3}.status-queued{background:#f1f5f9;border-color:#e2e8f0;color:#334155}.status-paused{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.status-done{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.status-failed{background:#fef2f2;border-color:#fecaca;color:#991b1b}.status-canceled{background:#f3f4f6;border-color:#e5e7eb;color:#4b5563}.mu-progressbar{height:8px;background:#f1f5f9;border-radius:999px;overflow:hidden}.mu-progress{height:100%;background:#8b5cf6;transition:width .25s}.jobs-list{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;background:#fff}.jobs-list-head,.jobs-list-row{display:grid;grid-template-columns:120px 1fr 180px 210px 240px 160px 120px;gap:12px;align-items:center}.jobs-list-head{background:#f8fafc;font-weight:600;font-size:14px;padding:10px 12px;border-bottom:1px solid #e5e7eb}.jobs-list-row{padding:12px;border-bottom:1px solid #f1f5f9}.jobs-list-row:hover{background:#fafafa}.mu-empty{padding:16px;text-align:center;color:#6b7280}.jl-ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.jl-progress{padding-right:16px}.mu-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:60}.mu-modal{width:min(920px,92vw);background:#fff;border-radius:16px;box-shadow:0 15px 40px #0000002e;overflow:hidden}.mu-modal-header{display:flex;align-items:center;gap:8px;padding:14px 16px;border-bottom:1px solid #e5e7eb;background:#fafafa}.mu-modal-body{padding:16px}.mu-modal-actions{display:flex;gap:8px;align-items:center;padding:12px 16px;border-top:1px solid #e5e7eb;background:#fafafa}.mu-close{margin-left:auto;border:none;background:transparent;font-size:18px;line-height:1;cursor:pointer}.mu-kv{display:flex;gap:10px;align-items:center;margin-bottom:8px}.mu-k{min-width:88px;font-weight:600;color:#374151}.mu-v{color:#111827}.dark .mu-container{--border:#2f3543;--muted:#a3aab8;--ink:#e6e9ef;color:var(--ink)}.dark .mu-input{background:#242a36;border-color:#2f3543;color:#e6e9ef}.dark .mu-input::placeholder{color:#8a93a4}.dark .mu-ghost:hover{background:#2a3140}.dark .mu-danger{background:#dc2626;border-color:#dc2626}.dark .jobs-list{background:#1f2430;border-color:#2f3543}.dark .jobs-list-head{background:#242a36;border-color:#2f3543;color:#e6e9ef}.dark .jobs-list-row{border-color:#2f3543}.dark .jobs-list-row:hover{background:#232a38}.dark .mu-empty{color:#a3aab8}.dark .mu-progressbar{background:#2b3040}.dark .mu-progress{background:#8b5cf6}.dark .mu-modal-header,.dark .mu-modal-actions{background:#242a36;border-color:#2f3543}.dark .mu-k{color:#c7ccd7}.dark .mu-v{color:#e6e9ef}.dark .status-running{background:#283152;border-color:#3a4a7a;color:#cbd5ff}.dark .status-queued{background:#2a313c;border-color:#384354;color:#d1d5db}.dark .status-paused{background:#3a2e1f;border-color:#6b4e2e;color:#fcd9b6}.dark .status-done{background:#153f2b;border-color:#1f5a3e;color:#bff3d4}.dark .status-failed{background:#4b2020;border-color:#7a2e2e;color:#fecaca}.dark .status-canceled{background:#2a2f3a;border-color:#3a404d;color:#cbd5e1}.mu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:10000}.mu-modal{width:min(920px,96vw);background:#fff;border-radius:14px;box-shadow:0 20px 60px #00000040;overflow:hidden;display:flex;flex-direction:column}.mu-header{padding:16px 18px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.mu-close{border:0;background:transparent;font-size:18px;cursor:pointer;color:#64748b}.mu-body{padding:16px 18px;display:flex;flex-direction:column;gap:12px}.mu-row{display:flex;gap:18px;color:#334155}.mu-uploader input{display:block}.mu-hint{margin:.25rem 0 0;font-size:.85rem;color:#64748b}.mu-error{color:#b91c1c;background:#fee2e2;border:1px solid #fecaca;padding:8px 10px;border-radius:8px}.mu-info{color:#334155}.mu-preview .mu-table-scroll{max-height:220px;overflow:auto;border:1px solid #e5e7eb;border-radius:10px}.mu-preview table{width:100%;border-collapse:collapse;background:#fff}.mu-preview th,.mu-preview td{padding:8px 10px;border-bottom:1px solid #f1f5f9;text-align:left;font-size:.92rem}.mu-muted{color:#94a3b8;font-size:.85rem}.mu-progressbar{height:10px;border-radius:999px;background:#e5e7eb;overflow:hidden}.mu-progress{height:100%;background:#6477f2;width:0;transition:width .25s}.mu-results .ok{color:#065f46}.mu-results .err{color:#b91c1c}.mu-results-list{max-height:160px;overflow:auto;border:1px solid #e5e7eb;border-radius:8px;padding:8px;background:#fafafa}.mu-actions{padding:14px 18px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:8px}.mu-primary{background:#6477f2;color:#fff;border:0;padding:8px 14px;border-radius:10px;cursor:pointer}.mu-primary:disabled{opacity:.6;cursor:not-allowed}.mu-ghost{background:#f8fafc;border:1px solid #e5e7eb;color:#334155;padding:8px 14px;border-radius:10px;cursor:pointer}.dark .mu-modal{background:#1f2430;color:#e6e9ef}.dark .mu-header,.dark .mu-actions,.dark .mu-preview .mu-table-scroll,.dark .mu-preview th,.dark .mu-preview td{border-color:#2f3543}.dark .mu-hint{color:#a3aab8}.dark .mu-ghost{background:#242a36;border-color:#2f3543;color:#e6e9ef}.mu-modal-overlay{z-index:10001}.mu-modal-overlay .mu-modal{width:min(920px,92vw);background:#fff;border-radius:16px;box-shadow:0 15px 40px #0000002e}.mu-modal.lg{max-width:720px}.mu-results-list .ok{color:#065f46}.mu-results-list .err{color:#b91c1c}.dark .mu-modal-overlay .mu-modal{background:#1f2430;color:#e6e9ef;box-shadow:0 15px 40px #00000059}.dark .mu-results-list .ok{color:#34d399}.dark .mu-results-list .err{color:#fecaca}.mu-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000061;display:flex;align-items:center;justify-content:center;z-index:1000;pointer-events:auto}.mu-modal{background:#fff;border-radius:12px;max-width:720px;width:min(92vw,820px);max-height:86vh;overflow:hidden;box-shadow:0 10px 30px #00000040}body.modal-open{overflow:hidden}.jobs-list-head,.jobs-list-row{min-width:1200px}.jobs-list-head>:last-child,.jobs-list-row>:last-child{justify-self:end;min-width:120px}.jobs-list-head,.jobs-list-row{grid-template-columns:100px 1fr 160px 150px 150px 150px 120px;min-width:1040px}.jl-progress{padding-right:5px}.jobs-list-row>:nth-child(4){font-size:11px}.jobs-list{overflow-x:auto;overflow-y:hidden}.jobs-list-head,.jobs-list-row{gap:8px}.jobs-list-head{padding:8px 10px}.jobs-list-row{padding:10px}.jl-progress{padding-right:6px}.mu-progressbar{height:6px}.jobs-list-head,.jobs-list-row{grid-template-columns:96px 1.2fr 160px 150px 150px minmax(220px,1.1fr) 110px;min-width:980px}.jobs-list-row>:nth-child(4),.jobs-list-head>:nth-child(4){font-size:12px}.jobs-list-row>:nth-child(7){white-space:nowrap}@media (max-width: 1280px){.jobs-list-head,.jobs-list-row{grid-template-columns:90px 1.1fr 150px 135px 140px minmax(200px,1fr) 100px}}@media (max-width: 1024px){.jobs-list-head,.jobs-list-row{grid-template-columns:84px 1fr 140px 120px 130px minmax(180px,1fr) 96px}.jobs-list-row>:nth-child(2),.jobs-list-row>:nth-child(6){font-size:13px}}.jl-ellipsis{min-width:0}:root{--bg:#fff;--text:#0f172a;--subtext:#64748b;--card-bg:#fff;--thead-bg:#f8fafc;--border:#e5e7eb;--border-soft:#eef1f4;--muted:#f3f4f6;--muted-hover:#e5e7eb;--icon:#64748b;--icon-hover:#ef4444;--backdrop:rgba(107,114,128,.75);--modal-bg:#fff;--pill-success-bg:#dcfce7;--pill-success-fg:#166534;--pill-active-bg:#dbeafe;--pill-active-fg:#1e40af;--pill-danger-bg:#fee2e2;--pill-danger-fg:#991b1b;--pill-paused-bg:#fff7ed;--pill-paused-fg:#9a3412;--pill-unknown-bg:#f1f5f9;--pill-unknown-fg:#334155}:root[data-theme=dark],.dark,.theme-dark,.cmpv2-container.dark{--bg:#0b1220;--text:#e5e7eb;--subtext:#94a3b8;--card-bg:#0f172a;--thead-bg:#0b1220;--border:#1f2937;--border-soft:#1f2937;--muted:#1f2937;--muted-hover:#334155;--icon:#94a3b8;--icon-hover:#ef4444;--backdrop:rgba(11,18,32,.85);--modal-bg:#0f172a;--pill-success-bg:#064e3b;--pill-success-fg:#a7f3d0;--pill-active-bg:#0b3b70;--pill-active-fg:#bfdbfe;--pill-danger-bg:#4a1d1d;--pill-danger-fg:#fecaca;--pill-paused-bg:#4a2a10;--pill-paused-fg:#fed7aa;--pill-unknown-bg:#1f2937;--pill-unknown-fg:#cbd5e1}.cmpv2-container{padding:1.25rem;background:var(--bg);color:var(--text);border-radius:12px;box-shadow:0 4px 20px #0000000d;position:relative;max-width:100%;overflow-x:hidden}.cmpv2-container *{box-sizing:border-box}.cmpv2-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.25rem;min-height:initial}.cmpv2-title h2{margin:0;line-height:1.15}.cmpv2-actions{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.cmpv2-account{display:flex;align-items:center;gap:.5rem;margin:0;padding:0}.cmpv2-account label{display:block;margin:0 0 .15rem;line-height:1}.cmpv2-account select{padding:.45rem .6rem;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text)}.cmpv2-export{display:inline-flex;align-items:center;gap:.45rem;background:#22c55e;color:#fff;border:none;border-radius:8px;padding:.55rem .9rem;font-weight:600;cursor:pointer}.cmpv2-export:hover{background:#16a34a}.cmpv2-toolbar{display:grid;grid-template-columns:1fr auto auto;gap:.6rem;align-items:end;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:.7rem;margin:.35rem 0 .5rem}.cmpv2-search{display:flex;align-items:center;gap:.5rem;border:1px solid var(--border);background:var(--card-bg);border-radius:8px;padding:0 .6rem}.cmpv2-search input{border:none;outline:none;padding:.5rem .2rem;width:100%;color:var(--text);background:transparent}.cmpv2-dates{display:flex;gap:.6rem}.cmpv2-date{display:grid;gap:.2rem;color:var(--subtext)}.cmpv2-date input{padding:.4rem .55rem;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text)}.cmpv2-apply{display:inline-flex;align-items:center;gap:.45rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;padding:.55rem .9rem;font-weight:600;cursor:pointer}.cmpv2-apply:hover{background:#2563eb}.cmpv2-summary{margin:.25rem 0 .6rem;color:var(--subtext);font-weight:500}.cmpv2-tablewrap{overflow:auto;border:1px solid var(--border);border-radius:12px;background:var(--card-bg);position:relative;z-index:1;width:100%}.cmpv2-table{width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0;color:var(--text)}.cmpv2-table thead th{position:sticky;top:0;z-index:2;background:var(--thead-bg);font-weight:700;color:#334155;padding:.6rem .8rem;border-bottom:1px solid var(--border-soft);box-shadow:0 2px #00000005}:root[data-theme=dark] .cmpv2-table thead th,.dark .cmpv2-table thead th,.theme-dark .cmpv2-table thead th,.cmpv2-container.dark .cmpv2-table thead th{color:var(--text)}.cmpv2-table th,.cmpv2-table td{padding:.6rem .8rem;border-bottom:1px solid var(--border-soft);text-align:left;vertical-align:top}.cmpv2-strong{font-weight:600}.cmpv2-nowrap{white-space:nowrap}.cmpv2-inbox{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cmpv2-link{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .6rem;border-radius:999px;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;font-weight:600;text-decoration:none;cursor:pointer}.cmpv2-link:hover{background:#dbeafe;border-color:#93c5fd}.cmpv2-link:disabled{color:#94a3b8;border-color:#cbd5e1;background:#f8fafc;cursor:not-allowed}.cmpv2-loading,.cmpv2-empty{text-align:center;padding:1.2rem;color:var(--subtext)}.cmpv2-table td{overflow-wrap:break-word;word-break:break-word}.cmpv2-table td:is(:first-child,:nth-child(4)),.cmpv2-table .cmpv2-audience{white-space:normal}.status-pill{display:inline-block;padding:.25rem .55rem;border-radius:999px;font-size:.78rem;font-weight:700;text-transform:capitalize;white-space:nowrap}.status-completed,.status-success,.status-read{background:var(--pill-success-bg);color:var(--pill-success-fg)}.status-active,.status-running,.status-delivered{background:var(--pill-active-bg);color:var(--pill-active-fg)}.status-draft,.status-sent{background:var(--pill-danger-bg);color:var(--pill-danger-fg)}.status-paused{background:var(--pill-paused-bg);color:var(--pill-paused-fg)}.status-unknown,.status-pending{background:var(--pill-unknown-bg);color:var(--pill-unknown-fg)}.cmpv2-pager{display:flex;justify-content:center;align-items:center;gap:.45rem;margin-top:.6rem;position:relative;z-index:1}.cmpv2-pager button{background:var(--muted);border:1px solid var(--border);padding:.45rem .6rem;border-radius:8px;cursor:pointer;color:var(--text)}.cmpv2-pager button:disabled{opacity:.5;cursor:not-allowed}.cmpv2-pager button:hover:not(:disabled){background:var(--muted-hover)}.cmpv2-pageinfo{padding:.3rem .7rem;border-radius:8px;background:var(--card-bg);border:1px solid var(--border);color:var(--subtext)}.cmpv2-actions-head{text-align:right}.cmpv2-actions-cell{text-align:right;vertical-align:middle}.cmpv2-iconbtn{background:transparent;border:none;padding:.35rem;border-radius:8px;cursor:pointer;color:var(--icon);line-height:1}.cmpv2-iconbtn:hover{background:var(--muted)}.cmpv2-iconbtn.danger:hover{color:#ef4444}.delete-modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.1rem}.cancel-btn{background:var(--muted);color:var(--text);border:1px solid var(--border);padding:.55rem .95rem;border-radius:8px;cursor:pointer}.cancel-btn:hover{background:var(--muted-hover)}.delete-btn{background:#ef4444;color:#fff;border:none;padding:.55rem .95rem;border-radius:8px;cursor:pointer}.delete-btn:hover{background:#dc2626}.delete-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--backdrop);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.delete-modal-content{background:var(--modal-bg);color:var(--text);padding:1.6rem;border-radius:12px;box-shadow:0 10px 30px #00000040;max-width:480px;width:calc(100% - 2rem);border:1px solid var(--border)}@media (max-width:1200px){.cmpv2-container{padding:1rem}.cmpv2-header{gap:.5rem;flex-wrap:wrap}.cmpv2-title{flex:1 1 100%}.cmpv2-actions{flex:1 1 100%;justify-content:flex-start}.cmpv2-account{flex:0 1 auto;min-width:0}}@media (max-width:900px){.cmpv2-toolbar{grid-template-columns:1fr}.cmpv2-dates{flex-wrap:wrap}}@media (max-width:640px){.cmpv2-header{flex-direction:column;align-items:stretch;gap:.25rem}.cmpv2-actions{width:100%;flex-direction:column;gap:.35rem}.cmpv2-account{width:100%;display:grid;grid-template-columns:1fr;gap:.25rem}.cmpv2-account select{width:100%;padding:.35rem .5rem}.cmpv2-export{width:100%;justify-content:center}.cmpv2-toolbar{padding:.65rem;gap:.55rem}}@media (max-width:700px){.cmpv2-table thead,.cmpv2-table colgroup{display:none}.cmpv2-table,.cmpv2-table tbody,.cmpv2-table tr,.cmpv2-table td{display:block;width:100%}.cmpv2-table tr{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 6px #0000000f;margin:0 0 .7rem;padding:.15rem 0}.cmpv2-table td{border:none;padding:.55rem .85rem;display:grid;grid-template-columns:minmax(110px,38%) 1fr;align-items:start;gap:.5rem;min-width:0;word-break:break-word}.cmpv2-table td:nth-child(1):before{content:"Nombre";color:var(--subtext);font-weight:600;white-space:nowrap}.cmpv2-table td:nth-child(2):before{content:"Inbox";color:var(--subtext);font-weight:600;white-space:nowrap}.cmpv2-table td:nth-child(3):before{content:"Estado";color:var(--subtext);font-weight:600;white-space:nowrap}.cmpv2-table td:nth-child(4):before{content:"Programada";color:var(--subtext);font-weight:600;white-space:nowrap}.cmpv2-table td:nth-child(5):before{content:"Audiencia";color:var(--subtext);font-weight:600;white-space:nowrap}.cmpv2-table td:nth-child(6):before{content:"Acciones";color:var(--subtext);font-weight:600;white-space:nowrap}.cmpv2-table td>*{min-width:0}.cmpv2-inbox{white-space:normal;overflow:visible;text-overflow:clip}.cmpv2-nowrap{white-space:normal}.cmpv2-link{white-space:normal;max-width:100%}.cmpv2-table td.cmpv2-actions-cell:before{display:none}.cmpv2-table td.cmpv2-actions-cell{display:flex;justify-content:flex-end;align-items:center;gap:.45rem;padding:.45rem .85rem}}:root{--bg:#f6f7fb;--card:#ffffff;--text:#0f172a;--muted:#6b7280;--border:#e5e7eb;--primary:#3b82f6;--primary-hover:#2563eb;--ring:rgba(59,130,246,.35);--chip:#eef2ff;--chip-border:#c7d2fe;--chip-text:#111827;--chip-on-text:var(--primary);--label-text:#111827;--section-title-text:#1f2937;--placeholder-bg:#f3f4f6;--placeholder-stripe:#eef2f7;--sk-base:#e0e0e0;--sk-hi:#f0f0f0}html.dark{--bg:#0d1117;--card:#161b22;--text:#e6edf3;--muted:#848d97;--border:#30363d;--primary:#2f81f7;--primary-hover:#58a6ff;--ring:rgba(47,129,247,.4);--chip:var(--primary);--chip-border:var(--primary-hover);--chip-text:#c9d1d9;--chip-on-text:#ffffff;--label-text:#e6edf3;--section-title-text:#f0f6fc;--placeholder-bg:#21262d;--placeholder-stripe:#2b313a;--sk-base:#21262d;--sk-hi:#30363d}.ccw{max-width:1080px;margin:0 auto;padding:24px;color:var(--text);box-sizing:border-box}.ccw h2{margin:0}.ccw-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}.ccw-title{display:flex;align-items:center;gap:10px}.ccw-emoji{font-size:22px}.ccw-header .btn-link{background:transparent;border:none;color:var(--primary);font-weight:700;cursor:pointer;padding:.4rem .6rem;border-radius:8px}.ccw-header .btn-link:hover{text-decoration:underline}.ccw-header .btn-secondary,.ccw-header .btn-danger{padding:.55rem .8rem;border-radius:10px;font-weight:700;border:1px solid var(--border);background:var(--bg);color:var(--text)}.ccw-header .btn-secondary:hover{background:var(--border)}.ccw-header .btn-danger{border-color:#fecaca;background:#fff1f2;color:#b91c1c}.ccw-header .btn-danger:hover{background:#ffe4e6}.card{background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:0 6px 18px #0f172a0a;padding:18px;overflow:hidden}.form-row,.ccw-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}.field{display:grid;gap:6px;min-width:0}.field label{font-weight:600;font-size:.95rem;color:var(--label-text)}.input{width:100%;background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:.6rem .7rem;outline:none;transition:box-shadow .15s,border-color .15s;box-sizing:border-box}.input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--ring)}.section-title{margin:8px 0 10px;font-weight:700;color:var(--section-title-text)}.params-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:10px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:6px}.col{min-width:0}.chips{display:flex;flex-wrap:wrap;gap:8px;border:1px dashed var(--border);padding:10px;border-radius:12px;background:var(--bg);max-height:170px;overflow:auto}.chip{border:1px solid var(--border);background:var(--card);color:var(--chip-text);border-radius:999px;padding:.35rem .7rem;cursor:pointer;font-weight:600;font-size:.9rem;white-space:nowrap}.chip.chip-on{background:var(--chip);border-color:var(--chip-border);color:var(--chip-on-text)}.uploader{border:1px solid var(--border);border-radius:12px;background:var(--bg);margin-bottom:10px;transition:box-shadow .15s,border-color .15s}.uploader.dragging{border-color:var(--primary);box-shadow:0 0 0 4px var(--ring)}.uploader-top{border-bottom:1px solid var(--border);background:transparent;padding:10px}.uploader-preview{display:flex;align-items:center;justify-content:center;height:240px;background:repeating-linear-gradient(45deg,var(--placeholder-bg),var(--placeholder-bg) 10px,var(--placeholder-stripe) 10px,var(--placeholder-stripe) 20px);border-radius:10px;overflow:hidden;cursor:pointer}.uploader-preview img,.uploader-preview video{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}.uploader-placeholder{color:var(--muted);font-weight:600;text-align:center;padding:0 12px}.uploader-bottom{display:flex;align-items:center;gap:12px;padding:10px}.ccw .file-btn{position:relative}.ccw .file-btn input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.file-name{flex:1;min-width:0;color:var(--text);font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-card{border:1px solid var(--border);border-radius:12px;background:var(--card);padding:12px}.preview-title{font-weight:700;margin-bottom:6px}.preview-body{white-space:pre-wrap;margin:0;color:var(--text);line-height:1.45;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.previewBox{border:1px solid var(--border);background:var(--card);border-radius:12px;padding:12px;min-height:120px}.ccw .btn,.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border:1px solid transparent;border-radius:10px;font-weight:700;line-height:1;cursor:pointer}.ccw .btn-primary,.btn-primary{background:var(--primary);color:#fff}.ccw .btn-primary:hover,.btn-primary:hover{background:var(--primary-hover)}.ccw .btn-secondary,.btn-secondary{background:#fff;color:#111827;border-color:#d1d5db;box-shadow:0 1px 1px #0000000a}.ccw .btn-secondary:hover,.btn-secondary:hover{background:#f9fafb;border-color:#cbd5e1}.ccw .btn-secondary:active,.btn-secondary:active{background:#f3f4f6}.ccw .btn-danger,.btn-danger{background:#dc2626;color:#fff;border-color:#dc2626}.ccw .btn-danger:hover,.btn-danger:hover{background:#b91c1c;border-color:#b91c1c}.ccw .btn-light{background:var(--bg);color:var(--text);border:1px solid var(--border)}.ccw .btn-light:hover{background:var(--border)}.ccw .btn-link,.btn-link{background:transparent;border:none;color:#2563eb;font-weight:700;padding:0}.ccw .btn-link:hover,.btn-link:hover{text-decoration:underline}.btn[disabled],.btn:disabled,.ccw .btn[disabled],.ccw .btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none;filter:grayscale(100%)}.actions{margin-top:14px;display:flex;justify-content:space-between;align-items:center}.ccw-footer{display:flex;align-items:center;gap:12px;margin-top:8px}.result{margin-top:16px;border:1px solid var(--border);background:var(--card);border-radius:12px;padding:12px}.lb-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:grid;place-items:center;z-index:9999}.lb-card{background:var(--card);color:var(--text);width:min(520px,92vw);border-radius:16px;box-shadow:0 20px 60px #00000040;padding:20px 22px;animation:lb-pop .16s ease-out}.lb-title{font-size:18px;font-weight:700;margin-bottom:8px}.lb-message{font-size:15px;line-height:1.4;margin-bottom:4px}.lb-detail{font-size:13px;color:var(--muted);margin-top:4px;white-space:pre-wrap}.lb-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}@keyframes lb-pop{0%{transform:translateY(6px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.help-scheduled{font-size:12px;color:var(--muted);margin:6px 0 0}.help-scheduled strong{color:var(--text)}.skeleton-box{background-color:var(--sk-base);border-radius:4px;animation:pulse 1.5s infinite ease-in-out}@keyframes pulse{0%{background-color:var(--sk-base)}50%{background-color:var(--sk-hi)}to{background-color:var(--sk-base)}}@media (max-width:980px){.form-row,.ccw-row,.two-col{grid-template-columns:1fr}.uploader-preview{height:200px}}.ccw a{color:var(--primary);text-decoration:none;font-weight:600}.ccw a:hover{text-decoration:underline}:root{--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--text-color-primary: #1f2937;--text-color-secondary: #6b7280;--border-color: #e5e7eb;--background-app: #f9fafb;--background-surface: #ffffff;--brand-primary: #3b82f6;--brand-primary-hover: #2563eb;--pill-bg-default: #f3f4f6;--pill-text-default: #374151;--pill-bg-sent: #eff6ff;--pill-text-sent: #3b82f6;--pill-bg-delivered: #ecfdf5;--pill-text-delivered: #10b981;--pill-bg-read: #fefce8;--pill-text-read: #f59e0b;--pill-bg-failed: #fef2f2;--pill-text-failed: #ef4444;--note-bg: #fffbeb;--note-border: #fde68a;--note-text: #b45309;--shadow-1: 0 1px 3px rgba(0, 0, 0, .05);--shadow-2: 0 1px 2px rgba(0, 0, 0, .08);--transition-fast: .2s ease}:root.dark,html.dark,body.dark,#root.dark,.app.dark,[data-theme=dark],[data-theme=dark-mode],[data-theme*=dark],.theme-dark{--text-color-primary: #e5e7eb;--text-color-secondary: #9ca3af;--border-color: #374151;--background-app: #0b1220;--background-surface: #111827;--brand-primary: #60a5fa;--brand-primary-hover: #3b82f6;--pill-bg-default: #1f2937;--pill-text-default: #d1d5db;--pill-bg-sent: #0b1220;--pill-text-sent: #93c5fd;--pill-bg-delivered: #0f172a;--pill-text-delivered: #34d399;--pill-bg-read: #1f2937;--pill-text-read: #fbbf24;--pill-bg-failed: #1f2937;--pill-text-failed: #f87171;--note-bg: #2a1a12;--note-border: #a16207;--note-text: #fbbf24;--shadow-1: 0 1px 3px rgba(0, 0, 0, .4);--shadow-2: 0 1px 2px rgba(0, 0, 0, .45)}html,body{background-color:var(--background-app)}.aud-cmp-wrap{font-family:var(--font-sans);padding:24px;background-color:var(--background-app);color:var(--text-color-primary);transition:background-color var(--transition-fast),color var(--transition-fast)}.aud-cmp-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.aud-titles{flex-grow:1}.aud-titles h2{font-size:24px;font-weight:600;margin:0 0 8px}.aud-back,.aud-refresh{display:inline-flex;align-items:center;gap:8px;background-color:var(--background-surface);border:1px solid var(--border-color);color:var(--text-color-primary);padding:8px 14px;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color var(--transition-fast)}.aud-back:hover,.aud-refresh:hover{background-color:#00000008}html.dark .aud-back:hover,html.dark .aud-refresh:hover,body.dark .aud-back:hover,body.dark .aud-refresh:hover,.theme-dark .aud-back:hover,.theme-dark .aud-refresh:hover,.app.dark .aud-back:hover,.app.dark .aud-refresh:hover{background-color:#ffffff0f}.aud-headcard{display:grid;grid-template-columns:1.2fr 2.8fr;gap:20px;background-color:var(--background-surface);border:1px solid var(--border-color);border-radius:12px;padding:16px;margin-bottom:16px;box-shadow:var(--shadow-1)}.aud-meta{display:grid;grid-auto-rows:minmax(24px,auto);gap:8px;font-size:14px;justify-items:start;text-align:left}.aud-meta-row .lbl{color:var(--text-color-secondary);margin-right:6px}.aud-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.kpi-card{display:flex;align-items:center;gap:12px;background-color:var(--background-surface);border:1px solid var(--border-color);border-radius:12px;padding:14px;box-shadow:var(--shadow-1);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.kpi-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-2)}.kpi-icon{font-size:22px;line-height:1;color:var(--text-color-secondary)}.kpi-value{font-size:22px;font-weight:700;line-height:1;color:var(--text-color-primary)}.kpi-label{font-size:12px;color:var(--text-color-secondary)}.kpi-total .kpi-icon{color:var(--pill-text-default)}.kpi-sent .kpi-icon{color:var(--pill-text-sent)}.kpi-delivered .kpi-icon{color:var(--pill-text-delivered)}.kpi-read .kpi-icon{color:var(--pill-text-read)}.kpi-failed .kpi-icon{color:var(--pill-text-failed)}.kpi-rate .kpi-icon{color:var(--brand-primary)}.aud-note,.aud-error{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.aud-note{background-color:var(--note-bg);color:var(--note-text);border:1px solid var(--note-border)}.aud-error{background-color:var(--pill-bg-failed);color:var(--pill-text-failed);border:1px solid rgba(239,68,68,.35)}.aud-tablewrap{overflow-x:auto;border:1px solid var(--border-color);border-radius:8px;background-color:var(--background-surface);box-shadow:var(--shadow-1)}.aud-table{width:100%;border-collapse:collapse;table-layout:fixed}.aud-table th,.aud-table td{padding:12px 16px;text-align:left;vertical-align:middle;border-bottom:1px solid var(--border-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.aud-table th{font-size:12px;font-weight:600;color:var(--text-color-secondary);text-transform:uppercase;background-color:color-mix(in oklab,var(--background-surface),var(--border-color) 20%)}.aud-table tbody tr:last-child td{border-bottom:none}.aud-table tbody tr:hover{background-color:color-mix(in oklab,var(--background-surface),var(--border-color) 25%)}.aud-ellipsis{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.aud-number{font-family:var(--font-mono)}.aud-tpl{font-family:var(--font-mono);background-color:color-mix(in oklab,var(--background-surface),var(--border-color) 35%);padding:2px 6px;border-radius:4px;font-size:13px}.aud-table td.aud-status-cell,.aud-table td.aud-actions{display:table-cell!important;vertical-align:middle}.aud-status-cell .status-pill{display:inline-block;margin:0 0 6px}.aud-actions .aud-date{display:block;margin:0 0 8px;font-size:13px;color:var(--text-color-secondary);white-space:normal;overflow-wrap:anywhere}.aud-actions .aud-resend{display:inline-flex}.aud-mini{background-color:var(--background-surface);border:1px solid var(--border-color);color:var(--text-color-secondary);padding:4px 8px;border-radius:6px;cursor:pointer;font-size:12px;line-height:1;transition:background-color var(--transition-fast)}.aud-mini:hover{background-color:color-mix(in oklab,var(--background-surface),var(--border-color) 20%)}.aud-resend{display:inline-flex;align-items:center;gap:6px;background-color:var(--brand-primary);color:#fff;border:none;padding:8px 12px;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color var(--transition-fast),opacity var(--transition-fast)}.aud-resend:hover:not(:disabled){background-color:var(--brand-primary-hover)}.aud-resend:disabled{opacity:.6;cursor:not-allowed}.status-pill{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500;text-transform:capitalize}.status-sent{background-color:var(--pill-bg-sent);color:var(--pill-text-sent)}.status-delivered{background-color:var(--pill-bg-delivered);color:var(--pill-text-delivered)}.status-read,.status-open{background-color:var(--pill-bg-read);color:var(--pill-text-read)}.status-failed{background-color:var(--pill-bg-failed);color:var(--pill-text-failed)}.status-sin-estado{background-color:var(--pill-bg-default);color:var(--pill-text-default)}.aud-loading,.aud-empty{text-align:center;padding:48px 16px!important;color:var(--text-color-secondary)}.aud-skel td{padding:0!important;border:none!important}.aud-skel td:after{content:"";display:block;height:40px;margin:8px 0;background:linear-gradient(90deg,#0000000f,#0000001f,#0000000f);background-size:200% 100%;animation:audShimmer 1.5s infinite;border-radius:6px}html.dark .aud-skel td:after,body.dark .aud-skel td:after,.theme-dark .aud-skel td:after,.app.dark .aud-skel td:after{background:linear-gradient(90deg,#ffffff0f,#ffffff1f,#ffffff0f);background-size:200% 100%}@keyframes audShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 1024px){.aud-headcard{grid-template-columns:1fr;gap:14px}}@media (max-width: 768px){.aud-cmp-wrap{padding:16px}.aud-cmp-header{flex-direction:column;align-items:stretch}}.aud-table td.aud-status-cell{overflow:visible;white-space:normal;text-overflow:clip;display:table-cell!important;vertical-align:middle}.aud-status-cell .status-pill{display:block;width:max-content;margin:0 0 6px}.aud-status-cell .aud-mini{display:inline-flex;white-space:nowrap}@media (max-width: 720px){.aud-table thead,.aud-table colgroup{display:none}.aud-table,.aud-table tbody,.aud-table tr,.aud-table td{display:block;width:100%}.aud-table tr{background:var(--background-surface);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-1);margin:0 0 .8rem;overflow:hidden}.aud-table td{border:none;padding:.75rem .9rem;display:grid;grid-template-columns:minmax(110px,42%) 1fr;align-items:start;gap:.55rem;min-width:0;white-space:normal;text-overflow:clip}.aud-table td>*{grid-column:2;min-width:0}.aud-table td:nth-child(1):before{content:"Campaña"}.aud-table td:nth-child(2):before{content:"Número"}.aud-table td:nth-child(3):before{content:"Plantilla"}.aud-table td:nth-child(4):before{content:"Estado"}.aud-table td:nth-child(5):before{content:"Enviado"}.aud-table td:before{grid-column:1;color:var(--text-color-secondary);font-weight:600;white-space:nowrap}.aud-ellipsis,.aud-number,.aud-tpl{white-space:normal}.aud-table td.aud-status-cell{grid-auto-rows:min-content}.aud-table td.aud-status-cell .status-pill{display:inline-block;margin:0 0 .4rem}.aud-table td.aud-status-cell .aud-mini{display:inline-flex;white-space:nowrap}.aud-table td.aud-actions{grid-auto-rows:min-content}.aud-table td.aud-actions .aud-date{display:block;margin:0 0 .5rem;color:var(--text-color-secondary)}.aud-table td.aud-actions .aud-resend{display:inline-flex}}.bulkjobs .jobs-list{border:1px solid #e5e7eb;border-radius:12px;background:#fff;overflow-x:auto;overflow-y:hidden}.bulkjobs .jobs-list-head,.bulkjobs .jobs-list-row{display:grid;align-items:center;gap:8px;grid-template-columns:96px 1.2fr 160px 140px 140px minmax(220px,1fr) 110px;min-width:960px}.bulkjobs .jobs-list-head{background:#f8fafc;font-weight:600;font-size:14px;padding:8px 10px;border-bottom:1px solid #e5e7eb}.bulkjobs .jobs-list-row{padding:10px;border-bottom:1px solid #f1f5f9}.bulkjobs .jobs-list-row:hover{background:#fafafa}.bulkjobs .jl-ellipsis{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bulkjobs .jl-progress{padding-right:6px}.bulkjobs .mu-progressbar{height:6px}.bulkjobs .jobs-list-row>:nth-child(4),.bulkjobs .jobs-list-head>:nth-child(4){font-size:12px}.bulkjobs .jobs-list-head>:last-child,.bulkjobs .jobs-list-row>:last-child{justify-self:end;min-width:110px;white-space:nowrap}@media (max-width:1280px){.bulkjobs .jobs-list-head,.bulkjobs .jobs-list-row{grid-template-columns:90px 1.1fr 150px 130px 130px minmax(200px,1fr) 100px;min-width:900px}}@media (max-width:1024px){.bulkjobs .jobs-list-head,.bulkjobs .jobs-list-row{grid-template-columns:84px 1fr 140px 120px 120px minmax(180px,1fr) 96px;min-width:860px}.bulkjobs .jobs-list-row>:nth-child(2),.bulkjobs .jobs-list-row>:nth-child(6){font-size:13px}}@media (max-width:860px){.bulkjobs .jobs-list{overflow-x:hidden}.bulkjobs .jobs-list-head{display:none!important}.bulkjobs .jobs-list-row{display:flex!important;flex-direction:column;gap:10px;border:1px solid #e5e7eb;border-radius:12px;margin:10px;padding:12px;background:#fff;min-width:0}.bulkjobs .jobs-list-row>:nth-child(2){order:1;font-weight:600;font-size:16px}.bulkjobs .jobs-list-row>:nth-child(1){order:2}.bulkjobs .jobs-list-row>:nth-child(3){order:3;opacity:.85}.bulkjobs .jobs-list-row>:nth-child(4){order:4;font-size:12px}.bulkjobs .jobs-list-row>:nth-child(5){order:5}.bulkjobs .jobs-list-row>:nth-child(6){order:6;color:#6b7280}.bulkjobs .jobs-list-row>:nth-child(7){order:7;align-self:flex-end;display:flex;gap:8px}.bulkjobs .jl-progress .mu-progressbar{width:100%}.bulkjobs .mu-page-head{flex-direction:column;align-items:stretch;gap:10px}.bulkjobs .mu-head-actions{width:100%}.bulkjobs .mu-input{min-width:0;width:100%}}@media (max-width:420px){.bulkjobs .jobs-list-row>:nth-child(3){align-self:flex-start}}.dark .bulkjobs .jobs-list{background:#1f2430;border-color:#2f3543}.dark .bulkjobs .jobs-list-head{background:#242a36;border-color:#2f3543;color:#e6e9ef}.dark .bulkjobs .jobs-list-row{border-color:#2f3543}.dark .bulkjobs .jobs-list-row:hover{background:#232a38}
