:root{--navy: #0F1B2D;--teal: #00B4D8;--teal-light: #E1F5EE;--amber: #FFF3CD;--amber-dark: #B08000;--red-light: #FDECEA;--red-dark: #9A2A2A;--gray-bg: #F5F5F5;--gray-text: #666666;--white: #FFFFFF;--text: #1A1A1A;--radius-sm: 6px;--radius-md: 10px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.12);--sidebar-w: 220px;--header-h: 56px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:var(--text);background:var(--gray-bg);min-width:1280px}a{color:var(--teal);text-decoration:none}a:hover{text-decoration:underline}#app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--navy);color:var(--white);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-logo{padding:20px 20px 16px;font-size:16px;font-weight:700;color:var(--teal);border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo span{display:block;font-size:11px;font-weight:400;color:#ffffff80;margin-top:2px}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-section-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#ffffff59;padding:12px 20px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 20px;color:#ffffffbf;cursor:pointer;border-radius:0;transition:background .15s,color .15s;font-size:13.5px}.nav-item:hover{background:#ffffff0f;color:var(--white)}.nav-item.active{background:#00b4d826;color:var(--teal);font-weight:600}.nav-item .nav-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}.sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:#fff6}.header{position:fixed;top:0;left:var(--sidebar-w);right:0;height:var(--header-h);background:var(--white);border-bottom:1px solid #E5E7EB;display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:90;box-shadow:var(--shadow-sm)}.header-title{font-size:16px;font-weight:600;color:var(--navy)}.header-user{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--gray-text)}.header-user .role-badge{background:var(--teal-light);color:var(--teal);padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase}.btn-logout{background:none;border:1px solid #E5E7EB;border-radius:var(--radius-sm);padding:4px 10px;font-size:12px;color:var(--gray-text);cursor:pointer;transition:border-color .15s,color .15s}.btn-logout:hover{border-color:var(--red-dark);color:var(--red-dark)}.main-content{margin-left:var(--sidebar-w);margin-top:var(--header-h);padding:28px 32px;min-height:calc(100vh - var(--header-h))}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;cursor:pointer;border:none;transition:opacity .15s,background .15s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--teal);color:var(--white)}.btn-primary:hover{background:#009cbd}.btn-secondary{background:var(--white);color:var(--text);border:1px solid #D1D5DB}.btn-secondary:hover{background:var(--gray-bg)}.btn-danger{background:var(--red-light);color:var(--red-dark);border:1px solid #F5C6C6}.btn-danger:hover{background:#fadadd}.btn-sm{padding:5px 10px;font-size:12.5px}.btn-ghost{background:transparent;color:var(--teal);padding:4px 8px}.btn-ghost:hover{background:var(--teal-light)}.card{background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:24px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-title{font-size:20px;font-weight:700;color:var(--navy)}.page-subtitle{font-size:13px;color:var(--gray-text);margin-top:2px}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13.5px}thead th{background:var(--gray-bg);color:var(--gray-text);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;text-align:left;border-bottom:1px solid #E5E7EB;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}thead th:hover{color:var(--navy)}thead th.sort-asc:after{content:" ↑"}thead th.sort-desc:after{content:" ↓"}tbody tr{border-bottom:1px solid #F3F4F6;transition:background .1s}tbody tr:hover{background:#fafafa}tbody td{padding:11px 14px;vertical-align:middle}.table-empty{text-align:center;padding:40px;color:var(--gray-text);font-size:14px}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 0 0;font-size:13px;color:var(--gray-text)}.pagination-controls{display:flex;gap:4px}.pagination-controls button{padding:4px 10px;border:1px solid #E5E7EB;background:var(--white);border-radius:var(--radius-sm);cursor:pointer;font-size:13px}.pagination-controls button:hover:not(:disabled){background:var(--gray-bg)}.pagination-controls button:disabled{opacity:.4;cursor:not-allowed}.pagination-controls button.active{background:var(--teal);color:var(--white);border-color:var(--teal)}.status-dot{display:inline-flex;align-items:center;gap:6px;font-size:13px}.status-dot:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-active:before{background:#22c55e}.status-pending_activation:before{background:#f59e0b}.status-paused:before{background:#94a3b8}.status-cancelled:before{background:#ef4444}.status-confirmed:before{background:#22c55e}.status-pending:before{background:#f59e0b}.status-discrepancy:before{background:#ef4444}.status-skipped:before{background:#94a3b8}.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-group label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-text)}input[type=text],input[type=email],input[type=number],input[type=date],select,textarea{width:100%;padding:8px 12px;border:1px solid #D1D5DB;border-radius:var(--radius-sm);font-size:13.5px;color:var(--text);background:var(--white);outline:none;transition:border-color .15s;font-family:inherit}input:focus,select:focus,textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px #00b4d81a}input.error,select.error{border-color:var(--red-dark)}.input-sm{padding:5px 9px;font-size:13px}select{cursor:pointer}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 24px}.form-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.form-grid.cols-1{grid-template-columns:1fr}.form-field{display:flex;flex-direction:column;gap:5px}.form-field.full-width{grid-column:1 / -1}.form-field label{font-size:12px;font-weight:600;color:var(--navy)}.form-field label .required{color:var(--red-dark);margin-left:2px}.form-field .hint{font-size:11px;color:var(--gray-text)}.input-group{display:flex;border:1px solid #D1D5DB;border-radius:var(--radius-sm);overflow:hidden}.input-group:focus-within{outline:2px solid var(--teal);outline-offset:-1px}.input-group-select{flex:0 0 auto;width:auto!important;border:none;border-right:1px solid #D1D5DB;border-radius:0;background:var(--gray-bg);padding:8px 6px;font-size:13px;font-weight:600;color:var(--text);outline:none;cursor:pointer;min-width:70px}.input-group-input{flex:1 1 auto;width:auto!important;border:none;border-radius:0;padding:8px 10px;font-size:13px;outline:none;min-width:0;background:var(--white)}.form-field .field-error{font-size:11px;color:var(--red-dark)}.form-section{margin-bottom:24px}.form-section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--navy);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid #E5E7EB}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid #E5E7EB}.toggle-field{display:flex;align-items:center;gap:10px;padding:8px 0}.toggle-field input[type=checkbox]{width:36px;height:20px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#d1d5db;border-radius:20px;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0;border:none;padding:0}.toggle-field input[type=checkbox]:after{content:"";position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:2px;left:2px;transition:left .2s;box-shadow:0 1px 2px #0003}.toggle-field input[type=checkbox]:checked{background:var(--teal)}.toggle-field input[type=checkbox]:checked:after{left:18px}.toggle-field label{font-size:13.5px;cursor:pointer}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-md);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.modal-lg{max-width:760px}.modal-xl{max-width:1000px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #E5E7EB}.modal-title{font-size:16px;font-weight:700;color:var(--navy)}.modal-close{background:none;border:none;font-size:20px;color:var(--gray-text);cursor:pointer;line-height:1;padding:2px 6px;border-radius:var(--radius-sm)}.modal-close:hover{background:var(--gray-bg)}.modal-body{padding:20px 24px;flex:1}.modal-footer{padding:16px 24px 20px;border-top:1px solid #E5E7EB;display:flex;justify-content:flex-end;gap:10px}#toast-container{position:fixed;top:20px;right:20px;z-index:999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{padding:12px 18px;border-radius:var(--radius-md);box-shadow:var(--shadow-md);font-size:13.5px;font-weight:500;min-width:260px;max-width:400px;animation:toast-in .25s ease;pointer-events:auto}.toast-success{background:#ecfdf5;color:#166534;border-left:4px solid #22C55E}.toast-error{background:var(--red-light);color:var(--red-dark);border-left:4px solid #EF4444}.toast-info{background:#eff6ff;color:#1e40af;border-left:4px solid #3B82F6}.toast-warning{background:var(--amber);color:var(--amber-dark);border-left:4px solid #F59E0B}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}.badge-teal{background:var(--teal-light);color:var(--teal)}.badge-amber{background:var(--amber);color:var(--amber-dark)}.badge-red{background:var(--red-light);color:var(--red-dark)}.badge-gray{background:#f3f4f6;color:var(--gray-text)}.badge-navy{background:#0f1b2d14;color:var(--navy)}.loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--gray-text);font-size:14px;gap:10px}.spinner{width:20px;height:20px;border:2px solid #E5E7EB;border-top-color:var(--teal);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:13.5px;display:flex;align-items:flex-start;gap:10px}.alert-info{background:#eff6ff;color:#1e40af;border:1px solid #BFDBFE}.alert-warning{background:var(--amber);color:var(--amber-dark);border:1px solid #FDE68A}.alert-error{background:var(--red-light);color:var(--red-dark);border:1px solid #FECACA}.alert-success{background:#ecfdf5;color:#166534;border:1px solid #BBF7D0}.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:var(--gray-text)}.text-sm{font-size:12px}.fw-600{font-weight:600}.fw-700{font-weight:700}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-center{display:flex;justify-content:center;align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.separator{border:none;border-top:1px solid #E5E7EB;margin:20px 0}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--navy)}.login-card{background:var(--white);border-radius:var(--radius-md);padding:48px 40px;width:100%;max-width:400px;box-shadow:var(--shadow-md);text-align:center}.login-logo{font-size:24px;font-weight:800;color:var(--navy);margin-bottom:4px}.login-logo span{color:var(--teal)}.login-subtitle{font-size:13px;color:var(--gray-text);margin-bottom:32px}.login-card h2{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:20px}.hist-timeline{position:relative;padding-left:24px}.hist-timeline:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:#e5e7eb}.hist-entry{position:relative;margin-bottom:24px;padding-bottom:4px}.hist-entry:last-child{margin-bottom:0}.hist-dot{position:absolute;left:-21px;top:5px;width:12px;height:12px;border-radius:50%;border:2px solid var(--white);box-shadow:0 0 0 2px #e5e7eb}.hist-dot--create{background:var(--teal);box-shadow:0 0 0 2px var(--teal)}.hist-dot--edit{background:#6366f1;box-shadow:0 0 0 2px #6366f1}.hist-entry--latest .hist-body{border-left:3px solid var(--teal);padding-left:12px;background:#f0fdfb;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.hist-body{padding:10px 12px}.hist-meta{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}.hist-tipo{font-size:12px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.04em}.hist-fecha{font-size:12px;color:var(--gray-text)}.hist-usuario{font-size:12px;color:var(--gray-text);background:var(--gray-bg);padding:1px 8px;border-radius:999px}.hist-cambios{display:flex;flex-direction:column;gap:5px}.hist-campo{display:flex;align-items:center;gap:8px;font-size:13px;flex-wrap:wrap}.hist-label{color:var(--gray-text);font-size:12px;min-width:160px}.hist-anterior{background:var(--red-light);color:var(--red-dark);padding:1px 8px;border-radius:var(--radius-sm);font-size:12px;text-decoration:line-through}.hist-arrow{color:var(--gray-text);font-size:12px}.hist-nuevo{background:var(--teal-light);color:#065f46;padding:1px 8px;border-radius:var(--radius-sm);font-size:12px;font-weight:500}
