.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a8a,#1e40af,#3b82f6);padding:1rem}.login-card{background:var(--card-bg, var(--white));border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2.5rem 2rem;width:100%;max-width:400px;transition:background-color .3s ease}.login-header{text-align:center;margin-bottom:2rem}.login-logo{display:inline-block;margin-bottom:.75rem}.login-header h1{font-size:1.5rem;font-weight:700;color:var(--primary);margin-bottom:.25rem}.login-header p{font-size:.875rem;color:var(--gray-500)}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-error{background:var(--red-bg);color:var(--red-600);padding:.625rem .875rem;border-radius:var(--radius);font-size:.813rem;font-weight:500;border:1px solid #fecaca}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.813rem;font-weight:600;color:var(--gray-700)}.form-group input{padding:.625rem .875rem;font-size:1rem}.login-btn{width:100%;padding:.75rem;background:var(--primary);color:#fff;font-size:.875rem;font-weight:600;border-radius:var(--radius);transition:background var(--transition);margin-top:.5rem}.login-btn:hover:not(:disabled){background:var(--primary-dark)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.topbar{display:flex;align-items:center;justify-content:space-between;height:var(--topbar-height);padding:0 1.5rem;background:var(--topbar-bg, var(--white));border-bottom:1px solid var(--topbar-border, var(--gray-200));position:sticky;top:0;z-index:50;transition:background-color .3s ease,border-color .3s ease}.topbar-left{display:flex;align-items:center}.topbar-title{font-size:.875rem;font-weight:600;color:var(--text-secondary, var(--gray-500))}.topbar-right{display:flex;align-items:center;gap:.5rem}.topbar-dropdown{position:relative}.topbar-btn{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:var(--radius);background:transparent;color:var(--text-primary, var(--gray-700));font-size:.813rem;font-weight:500;transition:background var(--transition);cursor:pointer}.topbar-btn:hover{background:var(--gray-100)}.topbar-company-logo{display:flex;align-items:center;margin-right:.5rem}.topbar-company-logo img{height:32px;max-width:120px;object-fit:contain;border-radius:4px}.topbar-theme-icon{display:flex;align-items:center;line-height:1}.topbar-theme-label{display:inline}.topbar-avatar{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem;flex-shrink:0}.topbar-user-info{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.topbar-user-name{font-size:.813rem;font-weight:600;color:var(--text-primary, var(--gray-800))}.topbar-user-role{font-size:.688rem;color:var(--text-secondary, var(--gray-500));text-transform:capitalize}.topbar-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--card-bg, var(--white));border:1px solid var(--border-color, var(--gray-200));border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:180px;padding:.375rem;animation:fadeIn .15s ease;z-index:60}.topbar-menu-header{display:flex;align-items:center;gap:.625rem;padding:.625rem .5rem}.topbar-menu-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.topbar-menu-name{font-size:.813rem;font-weight:600;color:var(--text-primary, var(--gray-800))}.topbar-menu-role{font-size:.688rem;color:var(--text-secondary, var(--gray-500));text-transform:capitalize}.topbar-menu-divider{height:1px;background:var(--border-color, var(--gray-200));margin:.25rem 0}.topbar-menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .625rem;border-radius:6px;background:transparent;color:var(--text-primary, var(--gray-700));font-size:.813rem;font-weight:500;cursor:pointer;transition:background var(--transition)}.topbar-menu-item:hover{background:var(--gray-100)}.topbar-menu-item.active{background:var(--primary-bg);color:var(--primary);font-weight:600}.topbar-menu-item.logout{color:var(--red-500)}.topbar-menu-item.logout:hover{background:var(--red-bg)}.topbar-menu-icon{display:flex;align-items:center;line-height:1}.topbar-check{margin-left:auto;color:var(--primary)}@media(max-width:767px){.topbar{padding:0 .75rem}.topbar-title,.topbar-theme-label,.topbar-user-info{display:none}}@media(min-width:768px)and (max-width:1024px){.topbar-theme-label{display:none}}.stats-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.25rem}.stat-card{background:var(--card-bg, var(--white));border-radius:var(--radius-lg);padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color, var(--gray-200));transition:background-color .3s ease,border-color .3s ease}.stat-icon{width:48px;height:48px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon-today{background:var(--stat-today-bg);color:var(--stat-today-color)}.stat-icon-week{background:var(--stat-week-bg);color:var(--stat-week-color)}.stat-icon-workers{background:var(--stat-workers-bg);color:var(--stat-workers-color)}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;color:var(--gray-900);line-height:1.2}.stat-label{font-size:.75rem;color:var(--gray-500);font-weight:500}@media(max-width:767px){.stats-cards{grid-template-columns:1fr;gap:.75rem}.stat-card{padding:1rem}.stat-icon{width:40px;height:40px}.stat-value{font-size:1.25rem}}@media(min-width:768px)and (max-width:1024px){.stats-cards{grid-template-columns:repeat(3,1fr);gap:.75rem}}.toolbar{background:var(--card-bg, var(--white));border-radius:var(--radius-lg);padding:.875rem 1rem;margin-bottom:1rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color, var(--gray-200));transition:background-color .3s ease,border-color .3s ease}.toolbar-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.toolbar-left,.toolbar-center,.toolbar-right{display:flex;align-items:center;gap:.5rem}.view-selector{display:flex;background:var(--gray-100);border-radius:var(--radius);padding:2px}.view-btn{padding:.375rem .875rem;font-size:.813rem;font-weight:500;background:transparent;color:var(--gray-600);border-radius:6px;transition:all var(--transition)}.view-btn:hover{color:var(--gray-800)}.view-btn.active{background:var(--white);color:var(--primary);box-shadow:var(--shadow-sm)}.nav-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);background:var(--gray-100);color:var(--gray-600);transition:all var(--transition)}.nav-btn:hover{background:var(--gray-200);color:var(--gray-800)}.today-btn{padding:.375rem .75rem;font-size:.813rem;font-weight:600;background:var(--primary-bg);color:var(--primary);border-radius:var(--radius);transition:all var(--transition)}.today-btn:hover{background:var(--primary-bg);filter:brightness(.97)}.toolbar-date-label{font-size:.875rem;font-weight:600;color:var(--gray-700);text-transform:capitalize;white-space:nowrap}.date-jump{padding:.375rem .5rem;font-size:.813rem;border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-600)}.new-cita-btn{padding:.5rem 1rem;font-size:.813rem;font-weight:600;background:var(--primary);color:#fff;border-radius:var(--radius);transition:background var(--transition);white-space:nowrap}.new-cita-btn:hover{background:var(--primary-dark)}@media(max-width:767px){.toolbar-row{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-center,.toolbar-right{justify-content:center}.toolbar-center{flex-wrap:wrap}.toolbar-date-label{width:100%;text-align:center}.toolbar-right{flex-direction:column}.date-jump,.new-cita-btn{width:100%}.new-cita-btn{text-align:center}}@media(min-width:768px)and (max-width:1024px){.view-btn{padding:.375rem .625rem;font-size:.75rem}.toolbar-date-label{font-size:.813rem}.date-jump{max-width:140px}}.worker-legend{display:flex;flex-wrap:wrap;gap:.75rem;padding:.75rem 1rem;background:var(--card-bg);border-radius:var(--radius-lg);margin-bottom:1rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:background-color .3s ease,border-color .3s ease}.legend-item{display:flex;align-items:center;gap:.375rem}.legend-color{width:14px;height:14px;border-radius:4px;border:2px solid transparent;flex-shrink:0}.legend-available{background:#f0fdf4;border:2px dashed #86efac}.legend-name{font-size:.75rem;font-weight:500;color:var(--gray-600)}@media(max-width:767px){.worker-legend{gap:.5rem;padding:.5rem .75rem}.legend-name{font-size:.688rem}.legend-color{width:12px;height:12px}}.day-section{margin-bottom:1.5rem}.day-section-header{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.75rem;padding:0 .25rem}.day-number{font-size:1.75rem;font-weight:700;color:var(--primary);line-height:1}.day-name{font-size:1rem;font-weight:700;color:var(--gray-800);letter-spacing:.025em}.day-month-year{font-size:.813rem;color:var(--gray-500);text-transform:capitalize;margin-left:.25rem}.grid-wrapper{overflow-x:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color, var(--gray-200));background:var(--card-bg, var(--white));transition:background-color .3s ease,border-color .3s ease}.day-grid{width:100%;border-collapse:collapse;min-width:700px}.grid-th{padding:.625rem .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--gray-600);background:var(--gray-50);border-bottom:2px solid var(--gray-200);text-align:center;white-space:nowrap}.grid-th-time{width:100px;min-width:100px;text-align:left;position:sticky;left:0;z-index:2;background:var(--gray-50)}.grid-td{padding:.625rem .75rem;font-size:.813rem;border-bottom:1px solid var(--gray-100);text-align:center;vertical-align:middle;height:56px;transition:background var(--transition)}.grid-td-time{width:100px;min-width:100px;text-align:left;position:sticky;left:0;z-index:1;background:var(--white);border-right:1px solid var(--gray-200)}.row-alt .grid-td,.row-alt .grid-td-time{background-color:var(--row-alt-bg)}.time-label{display:block;font-weight:600;color:var(--gray-700);font-size:.813rem;line-height:1.2}.time-sublabel{display:block;font-size:.688rem;color:var(--gray-400);font-weight:400}.cell-occupied{cursor:pointer;border-radius:0;position:relative}.cell-occupied:hover{opacity:.85}.cell-client{display:block;font-weight:600;font-size:.813rem;color:var(--gray-800);line-height:1.3}.cell-phone{display:block;font-size:.688rem;color:var(--gray-500);font-weight:400;margin-top:1px}.cell-available{background:var(--green-light);border:1px dashed var(--green-border);color:var(--green-text);font-size:.75rem;font-weight:500;cursor:pointer}.cell-available:hover{background:var(--green-light);filter:brightness(.97)}.row-alt .cell-available{background:var(--green-light)}.cell-inactive{background:#fef2f2!important;border:1px dashed #fca5a5;color:#dc2626;font-size:.75rem;font-weight:500;cursor:not-allowed;text-align:center}.cell-inactive svg{opacity:.4}.cell-inactive:hover,.row-alt .cell-inactive{background:#fee2e2!important}.grid-th-inactive{background:#fef2f2!important;color:#dc2626!important}.grid-th-inactive-badge{display:block;font-size:.625rem;font-weight:700;color:#dc2626;text-transform:uppercase;letter-spacing:.03em;margin-top:2px}.lunch-row .grid-td,.lunch-row .grid-td-time{background:var(--orange-light)}.lunch-cell{color:#c2410c;font-weight:600;font-size:.813rem;text-align:center;border-left:3px solid var(--orange-border)}.lunch-row .grid-td-time.lunch-cell{text-align:left}.day-closed,.sunday-closed{margin-bottom:1.5rem}.closed-day-message,.sunday-message{background:var(--gray-100);border-radius:var(--radius-lg);padding:1.25rem;text-align:center;font-size:.875rem;font-weight:500;color:var(--gray-500);border:1px solid var(--gray-200);display:flex;align-items:center;justify-content:center;gap:.5rem}.closed-day-message svg{color:var(--red-500, #ef4444);flex-shrink:0}.week-view,.month-view{display:flex;flex-direction:column;gap:0}@media(max-width:767px){.day-number{font-size:1.25rem}.day-name{font-size:.813rem}.grid-td,.grid-th{padding:.5rem;font-size:.75rem}.grid-td{height:48px}.grid-th-time,.grid-td-time{width:60px;min-width:60px;font-size:.7rem}.day-grid{min-width:400px}.day-section-header{flex-wrap:wrap}.cell-client{font-size:.7rem}.cell-phone{display:none}.cell-available{font-size:.65rem}}@media(min-width:768px)and (max-width:1024px){.grid-td,.grid-th{padding:.5rem .625rem;font-size:.75rem}.grid-td{height:50px}}.ss-wrap{position:relative;width:100%}.ss-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--gray-50);color:var(--text-primary);font-size:.85rem;font-family:inherit;cursor:pointer;transition:border-color .15s,box-shadow .15s;text-align:left;gap:.5rem}.ss-trigger:hover{border-color:var(--primary)}.ss-trigger.open{border-color:var(--primary);box-shadow:0 0 0 2px #3b82f626}.ss-trigger-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ss-chevron{flex-shrink:0;color:var(--text-secondary);transition:transform .15s}.ss-trigger.open .ss-chevron{transform:rotate(180deg)}.ss-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:0 8px 24px #0000001f;overflow:hidden}.ss-search-wrap{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-bottom:1px solid var(--border-color)}.ss-search-icon{flex-shrink:0;color:var(--text-secondary)}.ss-search-input{flex:1;border:none;background:transparent;font-size:.85rem;font-family:inherit;color:var(--text-primary);outline:none}.ss-search-input::placeholder{color:var(--text-secondary)}.ss-options{max-height:220px;overflow-y:auto}.ss-option{display:block;width:100%;padding:.5rem .75rem;border:none;background:transparent;color:var(--text-primary);font-size:.83rem;font-family:inherit;cursor:pointer;text-align:left;transition:background .1s}.ss-option:hover{background:#3b82f60f}.ss-option.selected{background:#3b82f61a;color:var(--primary);font-weight:600}.ss-no-results{padding:.75rem;text-align:center;color:var(--text-secondary);font-size:.82rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--card-bg, var(--white));border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease;transition:background-color .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, var(--gray-200))}.modal-header h2{font-size:1.125rem;font-weight:700;color:var(--gray-900)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);background:transparent;color:var(--gray-400);transition:all var(--transition)}.modal-close:hover{background:var(--gray-100);color:var(--gray-600)}.modal-error{margin:.75rem 1.5rem 0;padding:.625rem .875rem;background:var(--red-bg);color:var(--red-600);border-radius:var(--radius);font-size:.813rem;font-weight:500;border:1px solid #fecaca}.modal-form{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.modal-field{display:flex;flex-direction:column;gap:.375rem}.modal-field label{font-size:.813rem;font-weight:600;color:var(--gray-700)}.modal-field input,.modal-field select,.modal-field textarea{width:100%}.modal-field textarea{resize:vertical;min-height:60px}.modal-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.modal-actions{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;border-top:1px solid var(--gray-100);margin-top:.5rem;gap:.5rem}.modal-actions-right{display:flex;gap:.5rem;margin-left:auto}.modal-btn{padding:.5rem 1rem;font-size:.813rem;font-weight:600;border-radius:var(--radius);transition:all var(--transition)}.modal-btn:disabled{opacity:.6;cursor:not-allowed}.modal-btn-cancel{background:var(--gray-100);color:var(--gray-600)}.modal-btn-cancel:hover{background:var(--gray-200)}.modal-btn-save{background:var(--primary);color:#fff}.modal-btn-save:hover:not(:disabled){background:var(--primary-dark)}.modal-btn-delete{background:var(--red-bg);color:var(--red-600);border:1px solid var(--red-500)}.modal-btn-delete:hover:not(:disabled){background:var(--red-600);color:#fff;border-color:var(--red-600)}.dias-inactivos-section{border:1px solid var(--border-color, var(--gray-200));border-radius:var(--radius-lg);padding:1rem;background:var(--gray-50, #f9fafb)}.dias-inactivos-header{margin-bottom:.75rem}.dias-inactivos-label{display:flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:700;color:var(--text-primary, var(--gray-900))}.dias-inactivos-hint{display:block;font-size:.75rem;color:var(--text-secondary, var(--gray-500));margin-top:.25rem}.dias-inactivos-add{display:flex;gap:.5rem;margin-bottom:.75rem}.dias-inactivos-date{flex:1;padding:.438rem .625rem;font-size:.813rem;border:1px solid var(--border-color, var(--gray-200));border-radius:var(--radius);background:var(--card-bg, #fff);color:var(--text-primary, var(--gray-900))}.dias-inactivos-date:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.dias-inactivos-add-btn{padding:.438rem .875rem;font-size:.75rem;font-weight:600;background:var(--red-600, #dc2626);color:#fff;border-radius:var(--radius);white-space:nowrap;transition:background var(--transition)}.dias-inactivos-add-btn:hover:not(:disabled){background:#b91c1c}.dias-inactivos-add-btn:disabled{opacity:.5;cursor:not-allowed}.dias-inactivos-list{display:flex;flex-direction:column;gap:.375rem;max-height:180px;overflow-y:auto}.dia-inactivo-item{display:flex;align-items:center;justify-content:space-between;padding:.438rem .625rem;background:var(--card-bg, #fff);border:1px solid var(--border-color, var(--gray-200));border-radius:var(--radius);border-left:3px solid var(--red-500, #ef4444)}.dia-inactivo-info{display:flex;align-items:center;gap:.5rem;font-size:.813rem;font-weight:500;color:var(--text-primary, var(--gray-900))}.dia-inactivo-info svg{color:var(--red-500, #ef4444);flex-shrink:0}.dia-inactivo-remove{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:transparent;color:var(--text-secondary, var(--gray-400));transition:all var(--transition)}.dia-inactivo-remove:hover{background:var(--red-bg, #fef2f2);color:var(--red-500, #ef4444)}.dias-inactivos-empty,.dias-inactivos-loading{font-size:.75rem;color:var(--text-secondary, var(--gray-500));text-align:center;padding:.5rem;margin:0}@media(max-width:767px){.modal{max-width:100%;margin:.5rem}.modal-row{grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-actions-right{width:100%;margin-left:0}.modal-btn-delete{width:100%}.modal-actions-right .modal-btn{flex:1}.dias-inactivos-add{flex-direction:column}}@media(min-width:768px)and (max-width:1024px){.modal{max-width:480px}}.agenda{max-width:1400px}.week-export-bar{display:flex;gap:.5rem;margin-bottom:1rem}.agenda-content{margin-top:0}.agenda-search{display:flex;gap:.5rem;margin-bottom:1rem;align-items:center}.agenda-search-input-wrap{position:relative;flex:1;display:flex;align-items:center}.agenda-search-icon{position:absolute;left:.75rem;color:var(--text-secondary);pointer-events:none}.agenda-search-input{width:100%;padding:.5rem 2rem .5rem 2.25rem;border:1px solid var(--input-border);border-radius:var(--radius);background:var(--input-bg);color:var(--text-primary);font-size:.875rem}.agenda-search-input:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #3b82f626}.agenda-search-clear{position:absolute;right:.5rem;background:none;color:var(--text-secondary);display:flex;align-items:center;padding:.25rem;border-radius:4px}.agenda-search-clear:hover{background:var(--gray-100)}.agenda-search-btn{padding:.5rem 1rem;background:var(--primary);color:#fff;font-size:.813rem;font-weight:600;border-radius:var(--radius);white-space:nowrap;transition:background var(--transition)}.agenda-search-btn:hover{background:var(--primary-dark)}.agenda-search-btn:disabled{opacity:.6}.search-results{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1rem;margin-bottom:1rem;max-height:400px;overflow-y:auto}.search-results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.search-results-header h3{font-size:.875rem;font-weight:700;color:var(--text-primary)}.search-results-close{background:none;color:var(--text-secondary);font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:var(--radius)}.search-results-close:hover{background:var(--gray-100);color:var(--text-primary)}.search-results-empty{font-size:.813rem;color:var(--text-secondary);text-align:center;padding:1rem}.search-results-list{display:flex;flex-direction:column;gap:.5rem}.search-result-item{padding:.75rem;border:1px solid var(--border-color);border-left:4px solid var(--primary);border-radius:var(--radius);cursor:pointer;transition:background var(--transition)}.search-result-item:hover{background:var(--gray-50)}.search-result-date{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:.25rem;text-transform:capitalize}.search-result-info{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.search-result-client{font-size:.875rem;font-weight:600;color:var(--text-primary)}.search-result-phone{font-size:.813rem;color:var(--text-secondary)}.search-result-worker{font-size:.75rem;font-weight:600}.search-result-notes{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem;font-style:italic}@media(max-width:767px){.agenda-search{flex-direction:column}.agenda-search-btn{width:100%;text-align:center}.search-results{max-height:300px}.search-result-info{flex-direction:column;gap:.25rem;align-items:flex-start}}.month-pagination{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;gap:.5rem}.month-pagination-bottom{border-top:1px solid var(--border-color);margin-top:1rem;padding-top:1rem}.month-page-btn{display:flex;align-items:center;gap:.35rem;padding:.5rem 1rem;border-radius:var(--radius, 8px);background:var(--primary, #2563eb);color:#fff;font-size:.813rem;font-weight:600;border:none;cursor:pointer;transition:opacity .15s}.month-page-btn:hover:not(:disabled){opacity:.85}.month-page-btn:disabled{opacity:.4;cursor:not-allowed}.month-page-info{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:capitalize}.empleados{max-width:1200px;margin:0 auto}.empleados-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.empleados-title{font-size:1.25rem;font-weight:700;color:var(--text-primary, var(--gray-900))}.empleados-subtitle{font-size:.813rem;color:var(--text-secondary, var(--gray-500));margin-top:.125rem}.empleados-limit-info{color:var(--text-secondary, var(--gray-500));font-weight:500}.empleados-btn-new{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--primary);color:#fff;font-size:.813rem;font-weight:600;border-radius:var(--radius);transition:background var(--transition)}.empleados-btn-new:hover{background:var(--primary-dark)}.empleados-error{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--red-bg);color:var(--red-600);border:1px solid #fecaca;border-radius:var(--radius);font-size:.813rem;font-weight:500;margin-bottom:1rem}.empleados-error button{background:none;color:var(--red-500);font-size:1.25rem;padding:0 .25rem;line-height:1}.empleados-loading{text-align:center;padding:3rem;color:var(--text-secondary, var(--gray-500));font-size:.875rem}.empleados-empty{text-align:center;padding:3rem;color:var(--text-secondary, var(--gray-500));display:flex;flex-direction:column;align-items:center;gap:1rem}.empleados-empty svg{color:var(--gray-300)}.empleados-empty p{font-size:.875rem}.empleados-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.empleado-card{background:var(--card-bg, var(--white));border:1px solid var(--border-color, var(--gray-200));border-radius:var(--radius-lg);padding:1.25rem;display:flex;flex-direction:column;gap:.875rem;transition:box-shadow var(--transition),background-color .3s ease}.empleado-card:hover{box-shadow:var(--shadow-md)}.empleado-card.inactive{opacity:.6}.empleado-card-top{display:flex;align-items:center;gap:.75rem}.empleado-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;border:2px solid;flex-shrink:0}.empleado-info{display:flex;flex-direction:column;gap:.125rem}.empleado-name{font-size:.938rem;font-weight:600;color:var(--text-primary, var(--gray-800))}.empleado-status{font-size:.688rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.empleado-status.active{color:var(--green-text)}.empleado-status.inactive{color:var(--red-500)}.empleado-colors{display:flex;align-items:center}.empleado-color-preview{display:flex;align-items:center;gap:.5rem}.color-dot{width:20px;height:20px;border-radius:50%;flex-shrink:0}.color-label{font-size:.75rem;color:var(--text-secondary, var(--gray-500))}.empleado-actions{display:flex;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color, var(--gray-100))}.empleado-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:500;border-radius:6px;transition:all var(--transition);flex:1;justify-content:center}.empleado-btn.edit{background:var(--primary-bg);color:var(--primary)}.empleado-btn.edit:hover{background:var(--primary);color:#fff}.empleado-btn.delete{background:var(--red-bg);color:var(--red-600)}.empleado-btn.delete:hover,.empleado-btn.delete.confirm{background:var(--red-600);color:#fff}.empleado-btn.delete.confirm:hover{background:#b91c1c}.color-presets{display:flex;flex-wrap:wrap;gap:.5rem}.color-preset-btn{width:36px;height:36px;border-radius:50%;border:2px solid;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition)}.color-preset-btn:hover{transform:scale(1.15)}.color-preset-btn.selected{transform:scale(1.15);box-shadow:0 0 0 3px #3b82f64d}.color-preview-card{padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem}@media(max-width:767px){.empleados-header{flex-direction:column;align-items:flex-start;gap:.75rem}.empleados-grid{grid-template-columns:1fr}.empleados-btn-new{width:100%;justify-content:center}}@media(min-width:768px)and (max-width:1024px){.empleados-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}.configuracion{max-width:800px;margin:0 auto}.configuracion-header{margin-bottom:1.5rem}.configuracion-title{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.configuracion-subtitle{font-size:.813rem;color:var(--text-secondary);margin-top:.125rem}.config-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.25rem;transition:background-color .3s ease,border-color .3s ease}.config-section-title{font-size:.938rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.config-section-desc{font-size:.813rem;color:var(--text-secondary);margin-bottom:1rem}.theme-options{display:flex;gap:.75rem;flex-wrap:wrap}.theme-option{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;border-radius:var(--radius);border:2px solid var(--border-color);background:var(--card-bg);color:var(--text-primary);font-size:.813rem;font-weight:500;cursor:pointer;transition:all var(--transition);min-width:140px}.theme-option:hover{border-color:var(--primary-light)}.theme-option.selected{border-color:var(--primary);background:var(--primary-bg)}.theme-option-icon{display:flex;align-items:center}.theme-option-check{margin-left:auto;color:var(--primary)}.logo-upload-area{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}.logo-preview{width:120px;height:80px;border-radius:var(--radius);border:2px dashed var(--border-color);display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--gray-50);transition:border-color .3s ease,background-color .3s ease}.logo-preview img{max-width:100%;max-height:100%;object-fit:contain}.logo-preview-empty{color:var(--gray-400)}.logo-actions{display:flex;flex-direction:column;gap:.5rem}.logo-upload-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--primary);color:#fff;font-size:.813rem;font-weight:600;border-radius:var(--radius);transition:background var(--transition)}.logo-upload-btn:hover{background:var(--primary-dark)}.logo-remove-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--red-bg);color:var(--red-600);font-size:.813rem;font-weight:600;border-radius:var(--radius);transition:all var(--transition)}.logo-remove-btn:hover{background:var(--red-600);color:#fff}.logo-hint{font-size:.75rem;color:var(--text-secondary)}.config-save-msg{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--green-light);color:var(--green-text);border:1px solid var(--green-border);border-radius:var(--radius);font-size:.813rem;font-weight:500;margin-bottom:1rem}.horarios-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.horarios-header .config-section-title{margin-bottom:.25rem}.horarios-header .config-section-desc{margin-bottom:0}.horario-add-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:var(--primary);color:#fff;font-size:.75rem;font-weight:600;border-radius:var(--radius);white-space:nowrap;transition:background var(--transition)}.horario-add-btn:hover{background:var(--primary-dark)}.horario-form{background:var(--gray-50);border:1px solid var(--border-color);border-radius:var(--radius);padding:1rem;margin-bottom:1rem}.horario-form-row{display:flex;gap:.75rem;flex-wrap:wrap}.horario-form-field{flex:1;min-width:120px}.horario-form-field label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:.25rem}.horario-form-field input,.horario-form-field select{width:100%;padding:.5rem;font-size:.813rem}.horario-ampm-group{display:flex;align-items:center;gap:.25rem}.horario-ampm-group select{width:auto;min-width:50px;padding:.5rem .35rem;font-size:.813rem}.horario-ampm-sep{font-weight:700;font-size:1rem;color:var(--text-secondary)}.horario-form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.75rem}.horario-form-cancel{padding:.375rem .75rem;background:transparent;color:var(--text-secondary);font-size:.813rem;font-weight:500;border-radius:var(--radius);border:1px solid var(--border-color)}.horario-form-cancel:hover{background:var(--gray-100)}.horario-form-save{padding:.375rem .75rem;background:var(--primary);color:#fff;font-size:.813rem;font-weight:600;border-radius:var(--radius)}.horario-form-save:hover{background:var(--primary-dark)}.horarios-list{display:flex;flex-direction:column;gap:.5rem}.horarios-empty{font-size:.813rem;color:var(--text-secondary);text-align:center;padding:1.5rem}.horario-item{display:flex;align-items:center;justify-content:space-between;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-bg);transition:background var(--transition)}.horario-item:hover{background:var(--gray-50)}.horario-item.descanso{border-left:3px solid var(--gray-400);opacity:.8}.horario-item-info{display:flex;align-items:center;gap:.75rem}.horario-tipo-badge{font-size:.688rem;font-weight:700;text-transform:uppercase;padding:.125rem .5rem;border-radius:4px;letter-spacing:.03em}.horario-tipo-badge.cita{background:var(--primary-bg);color:var(--primary)}.horario-tipo-badge.descanso{background:var(--orange-light);color:var(--gray-600)}.horario-item-time{font-size:.875rem;font-weight:600;color:var(--text-primary)}.horario-item.new-item{border-left:3px solid var(--green-text, #16a34a)}.horario-item.modified-item{border-left:3px solid var(--primary)}.horario-pending-badge{font-size:.625rem;font-weight:700;text-transform:uppercase;padding:.1rem .375rem;border-radius:4px;background:var(--green-light, #dcfce7);color:var(--green-text, #16a34a);letter-spacing:.03em}.horario-pending-badge.modified{background:var(--primary-bg);color:var(--primary)}.horario-item-actions{display:flex;gap:.25rem}.horario-item-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;background:transparent;color:var(--text-secondary);transition:all var(--transition)}.horario-item-btn:hover{background:var(--gray-100)}.horario-item-btn.edit:hover{color:var(--primary)}.horario-item-btn.delete:hover{color:var(--red-500);background:var(--red-bg)}.config-save-bar{display:flex;align-items:center;gap:1rem;padding:1rem 0;position:sticky;bottom:0;background:var(--body-bg);border-top:1px solid var(--border-color);margin-top:.5rem;z-index:10}.config-save-btn{padding:.625rem 1.5rem;background:var(--primary);color:#fff;font-size:.875rem;font-weight:700;border-radius:var(--radius);transition:background var(--transition),opacity var(--transition)}.config-save-btn:hover:not(:disabled){background:var(--primary-dark)}.config-save-btn.disabled,.config-save-btn:disabled{opacity:.4;cursor:default}.config-save-hint{font-size:.75rem;font-weight:500;color:var(--red-500)}.template-variables{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap;margin-bottom:1rem;padding:.75rem;background:var(--gray-50);border:1px solid var(--border-color);border-radius:var(--radius)}.template-variables-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.template-variables-list{display:flex;gap:.5rem;flex-wrap:wrap}.template-variable-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.313rem .625rem;background:var(--primary-bg);color:var(--primary);font-size:.75rem;font-weight:600;border-radius:999px;cursor:grab;-webkit-user-select:none;user-select:none;border:1px solid transparent;transition:all var(--transition)}.template-variable-chip:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.template-variable-chip:active{cursor:grabbing;transform:scale(.95)}.template-editor-row{display:flex;gap:1rem}.template-editor-col{flex:1;min-width:0}.template-editor-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:.375rem}.template-textarea{width:100%;padding:.75rem;font-size:.813rem;font-family:inherit;line-height:1.6;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-bg);color:var(--text-primary);resize:vertical;min-height:200px;transition:border-color var(--transition),box-shadow var(--transition)}.template-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.template-textarea.drag-over{border-color:var(--primary);background:var(--primary-bg)}.template-editor-actions{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.template-reset-btn{padding:.313rem .625rem;font-size:.75rem;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.template-reset-btn:hover{background:var(--gray-100);color:var(--text-primary)}.template-preview{background:#e5ddd5;border-radius:var(--radius);padding:1rem;min-height:200px;max-height:320px;overflow-y:auto}.template-preview-bubble{background:#fff;border-radius:0 8px 8px;padding:.625rem .875rem;font-size:.813rem;line-height:1.6;color:#111b21;box-shadow:0 1px .5px #00000021;word-break:break-word}.wa-country-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.wa-country-label{font-size:.813rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.wa-country-select{padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-bg);color:var(--text-primary);min-width:200px}.wa-country-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.wa-connection{background:var(--gray-50);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem}.wa-connected{display:flex;align-items:center;justify-content:space-between;gap:1rem}.wa-connected-info{display:flex;align-items:center;gap:.75rem}.wa-connected-label{display:block;font-size:.875rem;font-weight:700;color:var(--green-text, #16a34a)}.wa-connected-number{display:block;font-size:.813rem;color:var(--text-secondary);margin-top:.125rem}.wa-disconnect-btn{padding:.5rem 1rem;font-size:.813rem;font-weight:600;color:#dc2626;background:transparent;border:1px solid #dc2626;border-radius:var(--radius);transition:all var(--transition)}.wa-disconnect-btn:hover{background:#dc2626;color:#fff}.wa-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.wa-status-dot.connected{background:#22c55e;box-shadow:0 0 0 3px #22c55e33}.wa-status-dot.disconnected{background:#9ca3af}.wa-config-form{display:flex;flex-direction:column;gap:.75rem}.wa-form-field{display:flex;flex-direction:column;gap:.25rem}.wa-form-label{font-size:.813rem;font-weight:600;color:var(--text-primary)}.wa-form-input{flex:1;padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-bg);color:var(--text-primary);font-family:inherit}.wa-form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.wa-form-hint{font-size:.75rem;color:var(--text-secondary)}.wa-token-row{display:flex;gap:.5rem}.wa-token-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius);background:var(--gray-100);color:var(--text-secondary);flex-shrink:0;transition:all var(--transition)}.wa-token-toggle:hover{background:var(--gray-200, #e5e7eb);color:var(--text-primary)}.wa-form-error{font-size:.813rem;color:var(--red-500, #ef4444);background:var(--red-bg, #fef2f2);padding:.5rem .75rem;border-radius:var(--radius);border:1px solid var(--red-200, #fecaca)}.wa-disconnected-info{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.wa-connect-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#25d366;color:#fff;font-size:.875rem;font-weight:700;border-radius:var(--radius);transition:background var(--transition)}.wa-connect-btn:hover:not(:disabled){background:#1da851}.wa-connect-btn:disabled{opacity:.5;cursor:default}.wa-connect-btn svg{width:18px;height:18px}@media(max-width:767px){.wa-country-row{flex-direction:column;align-items:flex-start}.wa-country-select{width:100%}.wa-connected{flex-direction:column;align-items:flex-start}.wa-token-row{flex-direction:column}.wa-token-toggle{width:100%;height:32px}}@media(max-width:767px){.theme-options{flex-direction:column}.logo-upload-area{flex-direction:column;align-items:flex-start}.horarios-header,.horario-form-row,.template-editor-row{flex-direction:column}.template-variables{flex-direction:column;align-items:flex-start}.config-section{padding:1rem}.config-save-bar{flex-direction:column;gap:.5rem;align-items:stretch}.config-save-btn{width:100%;text-align:center}.horario-item{flex-wrap:wrap;gap:.5rem}.horario-item-info{flex-wrap:wrap}.wa-connection{padding:1rem}}@media(min-width:768px)and (max-width:1024px){.configuracion{max-width:100%}.template-editor-row{flex-direction:column}}.confirmaciones{max-width:800px;margin:0 auto}.confirmaciones-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.confirmaciones-title{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.confirmaciones-subtitle{font-size:.813rem;color:var(--text-secondary);margin-top:.125rem}.confirmaciones-refresh{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius);background:var(--card-bg);border:1px solid var(--border-color);color:var(--text-secondary);transition:all var(--transition);flex-shrink:0}.confirmaciones-refresh:hover{background:var(--gray-100);color:var(--text-primary)}.confirmaciones-date-bar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:.875rem;margin-bottom:1rem}.confirmaciones-date-bar svg{color:var(--primary);flex-shrink:0}.confirmaciones-count{margin-left:auto;font-weight:700;color:var(--primary);font-size:.813rem}.confirmaciones-country-bar{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:.813rem;margin-bottom:1rem}.confirmaciones-country-bar svg{color:#25d366;flex-shrink:0}.confirmaciones-country-hint{margin-left:auto;font-size:.75rem;color:var(--text-secondary)}.confirmacion-phone-code{font-weight:700;color:var(--primary)}.confirmaciones-loading{text-align:center;padding:3rem 1rem;color:var(--text-secondary);font-size:.875rem}.confirmaciones-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.confirmaciones-empty svg{opacity:.3;margin-bottom:.75rem}.confirmaciones-empty p{font-size:.875rem}.confirmaciones-actions{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.confirmaciones-send-all{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#25d366;color:#fff;font-size:.875rem;font-weight:700;border-radius:var(--radius);transition:background var(--transition)}.confirmaciones-send-all:hover:not(:disabled){background:#1da851}.confirmaciones-send-all:disabled{opacity:.5;cursor:default}.confirmaciones-sent-count{font-size:.813rem;color:var(--text-secondary);font-weight:500}.confirmaciones-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.confirmacion-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.875rem 1rem;background:var(--card-bg);border:1px solid var(--border-color);border-left:4px solid var(--primary);border-radius:var(--radius-lg);transition:all var(--transition)}.confirmacion-item.sent{opacity:.6}.confirmacion-item:hover{background:var(--gray-50)}.confirmacion-info{flex:1;min-width:0}.confirmacion-client{font-size:.938rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.confirmacion-details{display:flex;align-items:center;gap:.875rem;flex-wrap:wrap}.confirmacion-phone,.confirmacion-time{display:flex;align-items:center;gap:.25rem;font-size:.813rem;color:var(--text-secondary)}.confirmacion-worker{font-size:.813rem;font-weight:600}.confirmacion-notes{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem;font-style:italic}.confirmacion-action{flex-shrink:0}.confirmacion-send-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:#25d366;color:#fff;font-size:.813rem;font-weight:600;border-radius:var(--radius);transition:background var(--transition);white-space:nowrap}.confirmacion-send-btn:hover:not(:disabled){background:#1da851}.confirmacion-send-btn:disabled{opacity:.5;cursor:default}.confirmacion-error{font-size:.75rem;color:#dc2626;margin-top:.25rem}.confirmaciones-wa-warning{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius-lg);color:#92400e;font-size:.813rem;margin-bottom:1rem}.confirmacion-send-btn svg{width:16px;height:16px}.confirmacion-sent-badge{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;font-size:.75rem;font-weight:700;color:var(--green-text, #16a34a);background:var(--green-light, #dcfce7);border-radius:var(--radius)}.confirmaciones-test{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;margin-top:1rem}.confirmaciones-test-title{font-size:.938rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.confirmaciones-test-desc{font-size:.813rem;color:var(--text-secondary);margin-bottom:1rem}.confirmaciones-test-row{display:flex;gap:.5rem;align-items:center}.confirmaciones-test-prefix{padding:.5rem .75rem;font-size:.875rem;font-weight:600;color:var(--text-secondary);background:var(--gray-100);border:1px solid var(--border-color);border-radius:var(--radius);white-space:nowrap}.confirmaciones-test-result{margin-top:.5rem;padding:.5rem .75rem;font-size:.813rem;font-weight:600;border-radius:var(--radius)}.confirmaciones-test-result.success{background:var(--green-light, #dcfce7);color:var(--green-text, #16a34a)}.confirmaciones-test-result.error{background:#fee2e2;color:#dc2626}.confirmaciones-test-input{flex:1;padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-bg);color:var(--text-primary)}.confirmaciones-test-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.confirmaciones-test-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:#25d366;color:#fff;font-size:.813rem;font-weight:600;border-radius:var(--radius);transition:background var(--transition);white-space:nowrap}.confirmaciones-test-btn:hover:not(:disabled){background:#1da851}.confirmaciones-test-btn:disabled{opacity:.5;cursor:default}.confirmaciones-test-btn svg{width:16px;height:16px}.confirmaciones-test-hint{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:.5rem}@media(max-width:767px){.confirmaciones-header{flex-direction:column}.confirmaciones-actions{flex-direction:column;align-items:stretch}.confirmacion-item{flex-direction:column;align-items:flex-start;gap:.5rem;padding:.75rem}.confirmacion-action{width:100%}.confirmacion-send-btn,.confirmacion-sent-badge{width:100%;justify-content:center}.confirmaciones-test{padding:1rem}.confirmaciones-test-row{flex-direction:column}.confirmaciones-test-prefix{align-self:flex-start}.confirmaciones-test-input{width:100%;box-sizing:border-box}.confirmaciones-test-btn,.confirmaciones-send-all{width:100%;justify-content:center}.confirmaciones-date-bar{flex-wrap:wrap;font-size:.813rem}.confirmaciones-country-bar{flex-wrap:wrap}.confirmaciones-country-hint{margin-left:0;width:100%}.confirmaciones-wa-warning{flex-wrap:wrap}}@media(min-width:768px)and (max-width:1024px){.confirmaciones{max-width:100%}}.calendario-laboral{max-width:800px;margin:0 auto}.calendario-laboral-header{margin-bottom:1.5rem}.calendario-laboral-title{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.calendario-laboral-subtitle{font-size:.813rem;color:var(--text-secondary);margin-top:.125rem}.dias-semana-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:1rem}.dia-semana-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;border-radius:var(--radius-lg);border:2px solid var(--border-color);background:var(--card-bg);cursor:pointer;transition:all var(--transition)}.dia-semana-btn.active{border-color:var(--primary);background:var(--primary-bg)}.dia-semana-btn.inactive{border-color:var(--border-color);opacity:.6}.dia-semana-btn:hover{transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.dia-semana-short{font-size:.875rem;font-weight:700;color:var(--text-primary)}.dia-semana-label{font-size:.688rem;color:var(--text-secondary);display:none}.dia-semana-status{font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:.1rem .375rem;border-radius:4px}.dia-semana-status.active{background:var(--green-light, #dcfce7);color:var(--green-text, #16a34a)}.dia-semana-status.inactive{background:var(--red-bg, #fef2f2);color:var(--red-500, #ef4444)}.dias-semana-actions{display:flex;align-items:center;gap:1rem}.dia-no-laboral-form{background:var(--gray-50);border:1px solid var(--border-color);border-radius:var(--radius);padding:1rem;margin-bottom:1rem}.dia-no-laboral-row{display:flex;gap:.75rem;margin-bottom:.75rem}.dia-no-laboral-field{display:flex;flex-direction:column;gap:.25rem}.dia-no-laboral-field.motivo-field{flex:1}.dia-no-laboral-field label{font-size:.75rem;font-weight:600;color:var(--text-secondary)}.dia-no-laboral-field input{padding:.5rem .75rem;font-size:.813rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-bg);color:var(--text-primary)}.dia-no-laboral-field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.dia-no-laboral-add-btn{padding:.5rem 1rem;font-size:.813rem;font-weight:600;background:var(--primary);color:#fff;border-radius:var(--radius);transition:background var(--transition)}.dia-no-laboral-add-btn:hover:not(:disabled){background:var(--primary-dark)}.dia-no-laboral-add-btn:disabled{opacity:.5;cursor:not-allowed}.dias-no-laborales-list{display:flex;flex-direction:column;gap:.5rem;max-height:400px;overflow-y:auto}.dia-no-laboral-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);border-left:3px solid var(--red-500, #ef4444);transition:background var(--transition)}.dia-no-laboral-item:hover{background:var(--gray-50)}.dia-no-laboral-item.past{opacity:.5}.dia-no-laboral-info{display:flex;align-items:center;gap:.75rem}.dia-no-laboral-info>svg{color:var(--red-500, #ef4444);flex-shrink:0}.dia-no-laboral-details{display:flex;flex-direction:column;gap:.125rem}.dia-no-laboral-fecha{font-size:.875rem;font-weight:600;color:var(--text-primary)}.dia-no-laboral-motivo{font-size:.75rem;color:var(--text-secondary);font-style:italic}.dia-no-laboral-remove{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;background:transparent;color:var(--text-secondary);transition:all var(--transition)}.dia-no-laboral-remove:hover{background:var(--red-bg, #fef2f2);color:var(--red-500, #ef4444)}.dias-no-laborales-empty,.dias-no-laborales-loading{font-size:.813rem;color:var(--text-secondary);text-align:center;padding:1.5rem}@media(max-width:767px){.dias-semana-grid{grid-template-columns:repeat(4,1fr)}.dia-no-laboral-row{flex-direction:column}.dia-semana-label{display:block}.dia-no-laboral-item{flex-wrap:wrap;gap:.5rem}}@media(min-width:768px)and (max-width:1024px){.calendario-laboral{max-width:100%}.dias-semana-grid{grid-template-columns:repeat(7,1fr);gap:.375rem}}.ea-container{padding:0}.ea-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.ea-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.ea-subtitle{font-size:.8rem;color:var(--text-secondary);margin:.15rem 0 0}.ea-btn-new{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.ea-btn-new:hover{background:var(--primary-dark)}.ea-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.ea-empty svg{margin-bottom:1rem;opacity:.5}.ea-empty p{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem}.ea-empty span{font-size:.85rem}.ea-list{display:flex;flex-direction:column;gap:.75rem}.ea-card{border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .15s}.ea-card:hover{box-shadow:var(--shadow-sm)}.ea-card-inactive{opacity:.6}.ea-card-main{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem}.ea-card-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.ea-card-info{flex:1;display:flex;flex-direction:column;gap:.1rem}.ea-card-name{font-weight:600;color:var(--text-primary);font-size:.95rem}.ea-card-email{color:var(--text-secondary);font-size:.8rem}.ea-status-badge{font-size:.7rem;font-weight:600;padding:.2rem .6rem;border-radius:20px}.ea-status-badge.active{background:var(--green-light);color:var(--green-text)}.ea-status-badge.inactive{background:var(--red-bg);color:var(--red-500)}.ea-card-modulos{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;border-top:1px solid var(--gray-100);flex-wrap:wrap}.ea-modulos-label{font-size:.75rem;color:var(--text-secondary);font-weight:600}.ea-modulos-tags{display:flex;gap:.35rem;flex-wrap:wrap}.ea-modulo-tag{font-size:.7rem;padding:.15rem .5rem;border-radius:4px;background:var(--primary-bg);color:var(--primary);font-weight:500}.ea-no-modulos{font-size:.75rem;color:var(--gray-400);font-style:italic}.ea-card-actions{display:flex;gap:.5rem;padding:.5rem 1.25rem;border-top:1px solid var(--gray-100);background:var(--gray-50)}.ea-action-btn{display:flex;align-items:center;gap:.35rem;padding:.35rem .65rem;border:1px solid var(--border-color);border-radius:6px;background:var(--card-bg);color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .15s}.ea-action-btn:hover{background:var(--gray-100);color:var(--text-primary)}.ea-action-delete:hover{background:var(--red-bg);color:var(--red-500);border-color:var(--red-500)}.ea-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.ea-modal{background:var(--card-bg);border-radius:14px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.ea-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.ea-modal-header h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.ea-modal-close{background:none;border:none;font-size:1.5rem;color:var(--gray-400);cursor:pointer;line-height:1}.ea-modal-body{padding:1.25rem 1.5rem}.ea-modal-error{background:var(--red-bg);color:var(--red-500);border:1px solid #fecaca;border-radius:8px;padding:.6rem .85rem;font-size:.8rem;margin-bottom:1rem}.ea-modal-section{margin-bottom:1.25rem}.ea-modal-section-title{font-size:.9rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem;padding-bottom:.4rem;border-bottom:1px solid var(--gray-100)}.ea-modal-hint{font-size:.78rem;color:var(--text-secondary);margin:0 0 .75rem}.ea-modal-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.ea-modal-field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.5rem}.ea-modal-field label{font-size:.75rem;font-weight:600;color:var(--gray-600)}.ea-required{color:var(--red-500)}.ea-hint{font-weight:400;color:var(--gray-400);font-size:.7rem}.ea-modal-field input{padding:.55rem .7rem;border:1px solid var(--input-border);border-radius:8px;font-size:.85rem;color:var(--text-primary);background:var(--input-bg);transition:border-color .15s}.ea-modal-field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #1e40af1a}.ea-password-wrap{position:relative}.ea-password-wrap input{width:100%;padding-right:2.5rem;box-sizing:border-box}.ea-password-toggle{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--gray-400);cursor:pointer;padding:.2rem}.ea-modulos-grid{display:flex;flex-wrap:wrap;gap:.5rem}.ea-modulo-chip{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;border-radius:8px;border:1.5px solid var(--input-border);background:var(--card-bg);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .15s}.ea-modulo-chip:hover{border-color:var(--primary);color:var(--primary)}.ea-modulo-chip.active{border-color:var(--primary);background:var(--primary-bg);color:var(--primary)}.ea-modulo-check{display:flex;align-items:center;color:var(--primary)}.ea-modulo-chip:not(.active) .ea-modulo-check{color:var(--input-border)}.ea-modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding-top:1rem;border-top:1px solid var(--gray-100)}.ea-btn-cancel{padding:.5rem 1rem;background:var(--gray-100);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:.85rem;cursor:pointer}.ea-btn-save{padding:.5rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer}.ea-btn-save:hover{background:var(--primary-dark)}@media(max-width:767px){.ea-header{flex-direction:column;align-items:flex-start;gap:.75rem}.ea-btn-new{width:100%;justify-content:center}.ea-card-main,.ea-card-actions{flex-wrap:wrap}.ea-modal{max-width:100%;margin:.5rem}.ea-modal-row{grid-template-columns:1fr}.ea-modal-header,.ea-modal-body{padding:1rem}}@media(min-width:768px)and (max-width:1024px){.ea-modal{max-width:500px}}.rep-container{width:100%}.rep-header-banner{background:linear-gradient(135deg,#2563eb,#1e40af);border-radius:var(--radius-lg);padding:1.5rem 2rem;margin-bottom:1.5rem;color:#fff}.rep-banner-empresa{font-size:1.5rem;font-weight:800;margin:0 0 .25rem;color:#fff;letter-spacing:-.02em}.rep-banner-subtitle{font-size:.9rem;font-weight:400;margin:0;color:#fffc}.rep-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.5rem;transition:background-color .3s ease,border-color .3s ease}.rep-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.rep-section-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.rep-periodo-tabs{display:flex;gap:.25rem;background:var(--gray-100);border-radius:var(--radius);padding:.2rem}.rep-periodo-btn{padding:.4rem .9rem;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.rep-periodo-btn.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.rep-periodo-btn:hover:not(.active){color:var(--text-primary)}.rep-date-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.rep-date-input{padding:.4rem .6rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--gray-50);color:var(--text-primary);font-size:.82rem;font-family:inherit;cursor:pointer;transition:border-color .15s}.rep-date-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #3b82f626}.rep-date-label{font-size:.82rem;color:var(--text-secondary);font-weight:500}.rep-summary-cards{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.rep-summary-card{display:flex;flex-direction:column;gap:.2rem;background:var(--gray-50);border:1px solid var(--border-color);border-radius:var(--radius);padding:.75rem 1.25rem;min-width:140px}.rep-summary-income{border-color:var(--green-border);background:var(--green-light)}.rep-summary-number{font-size:1.4rem;font-weight:700;color:var(--text-primary);line-height:1}.rep-summary-income .rep-summary-number{color:var(--green-text)}.rep-summary-label{font-size:.75rem;color:var(--text-secondary)}.rep-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border-color)}.rep-table{width:100%;border-collapse:collapse;font-size:.85rem}.rep-table thead th{text-align:left;padding:.65rem 1rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:1px solid var(--border-color);white-space:nowrap}.rep-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .1s}.rep-table tbody tr:last-child{border-bottom:none}.rep-table tbody tr:hover{background:#3b82f60a}.rep-table td{padding:.6rem 1rem;color:var(--text-primary);white-space:nowrap}.rep-total-row{background:var(--gray-50)}.rep-total-row td{border-top:2px solid var(--border-color)}.rep-money{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.85rem}.rep-type-badge{display:inline-block;padding:.2rem .6rem;border-radius:6px;font-size:.78rem;font-weight:600;border:1px solid}.rep-worker-name{display:flex;align-items:center;gap:.5rem}.rep-worker-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.rep-export-bar{display:flex;gap:.5rem;margin-bottom:1rem}.rep-export-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-bg);color:var(--text-primary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.rep-export-btn:hover{border-color:var(--primary);color:var(--primary);background:#3b82f60a}.rep-export-btn svg{width:15px;height:15px}.rep-export-pdf{color:#dc2626;border-color:#fca5a5}.rep-export-pdf:hover{background:#dc26260d;border-color:#dc2626;color:#dc2626}.rep-export-excel{color:#16a34a;border-color:#86efac}.rep-export-excel:hover{background:#16a34a0d;border-color:#16a34a;color:#16a34a}.rep-loading,.rep-empty{text-align:center;padding:2rem;color:var(--text-secondary);font-size:.9rem}.rep-mobile-cards{display:none;flex-direction:column;gap:.5rem}.rep-mobile-card{border:1px solid var(--border-color);border-radius:var(--radius);padding:.75rem;background:var(--gray-50)}.rep-mobile-card-header{margin-bottom:.5rem}.rep-mobile-card-stats{display:flex;gap:1rem}.rep-mobile-stat{display:flex;flex-direction:column;gap:.1rem}.rep-mobile-stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.rep-mobile-stat-value{font-size:.95rem;font-weight:600;color:var(--text-primary)}@media(max-width:767px){.rep-header-banner{padding:1rem 1.25rem}.rep-banner-empresa{font-size:1.2rem}.rep-banner-subtitle{font-size:.8rem}.rep-section{padding:.75rem}.rep-section-header{flex-direction:column;align-items:flex-start}.rep-periodo-tabs{width:100%}.rep-periodo-btn{flex:1;text-align:center;padding:.4rem .5rem;font-size:.75rem}.rep-summary-cards{flex-direction:column}.rep-summary-card{min-width:0}.rep-export-bar{flex-wrap:wrap}.rep-export-btn{flex:1;justify-content:center;min-width:0}.rep-table-wrap{display:none}.rep-mobile-cards{display:flex}}@media(min-width:768px)and (max-width:1024px){.rep-section{padding:1rem}.rep-summary-card{min-width:120px}}.dashboard{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;justify-content:space-between;z-index:100;transition:background-color .3s ease;border-right:1px solid var(--sidebar-border)}.sidebar-top{padding:1.25rem}.sidebar-logo{display:flex;align-items:center;gap:.625rem;font-size:1.125rem;font-weight:700;padding-bottom:1.5rem;border-bottom:1px solid var(--sidebar-border);margin-bottom:1rem;color:var(--sidebar-text)}.sidebar-logo-img{height:28px;max-width:80px;object-fit:contain;border-radius:4px}.mobile-logo-img{height:24px;max-width:60px;object-fit:contain;border-radius:4px}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem}.sidebar-link{display:flex;align-items:center;gap:.625rem;padding:.625rem .75rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;transition:background var(--transition);background:transparent;color:var(--sidebar-text);width:100%;text-align:left;cursor:pointer}.sidebar-link:hover{background:var(--sidebar-hover)}.sidebar-link.active{background:var(--sidebar-active)}.sidebar-bottom{padding:1.25rem;border-top:1px solid var(--sidebar-border)}.sidebar-user{display:flex;align-items:center;gap:.625rem;margin-bottom:.75rem}.sidebar-user-avatar{width:36px;height:36px;border-radius:50%;background:var(--sidebar-avatar-bg);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:var(--sidebar-text)}.sidebar-user-info{display:flex;flex-direction:column}.sidebar-user-name{font-size:.813rem;font-weight:600;color:var(--sidebar-text)}.sidebar-user-role{font-size:.688rem;opacity:.7;text-transform:capitalize;color:var(--sidebar-text)}.sidebar-logout{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;border-radius:var(--radius);background:var(--sidebar-hover);color:var(--sidebar-text);font-size:.813rem;font-weight:500;transition:background var(--transition)}.sidebar-logout:hover{background:var(--sidebar-active)}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--sidebar-bg);color:var(--sidebar-text);align-items:center;gap:.75rem;padding:0 1rem;z-index:100;transition:background-color .3s ease}.hamburger-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--sidebar-text);cursor:pointer;padding:.25rem;border-radius:6px;transition:background .15s}.hamburger-btn:hover{background:var(--sidebar-hover)}.mobile-header-brand{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:var(--sidebar-text)}.mobile-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:199}.mobile-sidebar{display:none;position:fixed;top:0;left:-280px;width:280px;height:100%;background:var(--sidebar-bg);color:var(--sidebar-text);z-index:200;flex-direction:column;transition:left .3s ease;overflow-y:auto}.mobile-sidebar.open{left:0}.mobile-sidebar-top{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.1)}.mobile-sidebar-brand{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;color:var(--sidebar-text)}.mobile-close-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--sidebar-text);cursor:pointer;padding:.25rem;border-radius:6px;opacity:.7;transition:opacity .15s}.mobile-close-btn:hover{opacity:1}.mobile-sidebar-nav{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;flex:1}.mobile-sidebar-bottom{padding:1rem .75rem;border-top:1px solid rgba(255,255,255,.1)}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;display:flex;flex-direction:column}.main-content-body{padding:1.5rem;flex:1}@media(max-width:1024px){.sidebar{display:none}.mobile-header{display:flex}.mobile-overlay{display:block}.mobile-sidebar{display:flex}.main-content{margin-left:0;margin-top:var(--header-height)}.main-content-body{padding:.75rem;overflow-x:hidden}}.cambiar-pwd-container{display:flex;justify-content:center;padding:2rem 1rem}.cambiar-pwd-card{background:var(--card-bg);border-radius:12px;padding:2rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);width:100%;max-width:440px;transition:background-color .3s ease,border-color .3s ease}.cambiar-pwd-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 1.25rem}.cambiar-pwd-alert{background:#fef3c7;color:#92400e;border:1px solid #fde68a;border-radius:8px;padding:.75rem 1rem;font-size:.85rem;margin-bottom:1.25rem;line-height:1.4}.cambiar-pwd-field{margin-bottom:1rem}.cambiar-pwd-field label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.35rem}.cambiar-pwd-input-wrap{position:relative}.cambiar-pwd-input-wrap input{width:100%;padding:.6rem 2.5rem .6rem .75rem;border:1px solid var(--input-border);border-radius:8px;font-size:.85rem;color:var(--text-primary);background:var(--input-bg);box-sizing:border-box;transition:border-color .15s}.cambiar-pwd-input-wrap input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #1e40af1a}.cambiar-pwd-eye{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--gray-400);cursor:pointer;padding:.2rem}.cambiar-pwd-eye:hover{color:var(--gray-600)}.cambiar-pwd-btn{width:100%;padding:.65rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;margin-top:.5rem;transition:background .15s}.cambiar-pwd-btn:hover{background:var(--primary-dark)}.cambiar-pwd-btn:disabled{opacity:.6;cursor:not-allowed}.temp-pwd-banner{background:#fef3c7;color:#92400e;border-bottom:1px solid #fde68a;padding:.6rem 1.25rem;font-size:.85rem;font-weight:500;text-align:center}@media(max-width:767px){.cambiar-pwd-container{padding:1rem .75rem}.cambiar-pwd-card{padding:1.5rem 1.25rem}}.bit-container{width:100%}.bit-breadcrumb{font-size:.8rem;color:var(--text-secondary, #94a3b8);margin-bottom:.5rem;display:flex;align-items:center;gap:.4rem}.bit-breadcrumb-sep{opacity:.5}.bit-breadcrumb-active{color:var(--text-primary, #e2e8f0)}.bit-title{font-size:1.5rem;font-weight:700;color:var(--text-primary, #e2e8f0);margin:0 0 1.25rem}.bit-stats-bar{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.bit-stat-card{display:flex;align-items:center;gap:.6rem;background:var(--card-bg, #1e293b);border:1px solid var(--border-color, #334155);border-radius:10px;padding:.75rem 1.25rem}.bit-stat-number{font-size:1.4rem;font-weight:700;color:var(--text-primary, #e2e8f0);display:block;line-height:1}.bit-stat-label{font-size:.7rem;color:var(--text-secondary, #94a3b8);display:block}.bit-delete-btn{display:flex;align-items:center;gap:.5rem;background:none;border:1px solid var(--border-color, #334155);border-radius:10px;padding:.75rem 1.25rem;color:#ef4444;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s}.bit-delete-btn:hover{background:#ef44441a}.bit-filters{display:flex;gap:.75rem;margin-bottom:1.25rem;align-items:center;flex-wrap:wrap}.bit-search-wrap{flex:1;min-width:200px;position:relative}.bit-search-wrap svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-secondary, #94a3b8)}.bit-search{width:100%;padding:.6rem .75rem .6rem 2.25rem;background:var(--card-bg, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;color:var(--text-primary, #e2e8f0);font-size:.85rem;outline:none;box-sizing:border-box}.bit-search::placeholder{color:var(--text-secondary, #64748b)}.bit-search:focus{border-color:var(--accent, #3b82f6)}.bit-select,.bit-date{padding:.6rem .75rem;background:var(--card-bg, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;color:var(--text-primary, #e2e8f0);font-size:.85rem;outline:none;min-width:130px}.bit-select:focus,.bit-date:focus{border-color:var(--accent, #3b82f6)}.bit-date::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}.bit-table-wrap{overflow-x:auto;border-radius:10px;border:1px solid var(--border-color, #334155);background:var(--card-bg, #1e293b)}.bit-table{width:100%;border-collapse:collapse;font-size:.85rem}.bit-table thead th{text-align:left;padding:.75rem 1rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary, #94a3b8);border-bottom:1px solid var(--border-color, #334155);white-space:nowrap}.bit-table tbody tr{border-bottom:1px solid var(--border-color, #1e293b);transition:background .1s}.bit-table tbody tr:last-child{border-bottom:none}.bit-table tbody tr:hover{background:#ffffff08}.bit-table td{padding:.7rem 1rem;color:var(--text-primary, #e2e8f0);white-space:nowrap}.bit-date-cell{color:var(--text-secondary, #94a3b8)!important;font-size:.82rem}.bit-desc-cell{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary, #94a3b8)!important}.bit-user-cell{color:var(--text-secondary, #94a3b8)!important}.bit-ip-cell{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.8rem;color:var(--text-secondary, #94a3b8)!important}.bit-empty{text-align:center;padding:2rem!important;color:var(--text-secondary, #64748b)!important}.bit-badge{display:inline-block;padding:.2rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600}.badge-red{background:#ef444426;color:#ef4444}.badge-orange{background:#f59e0b26;color:#f59e0b}.badge-purple{background:#a855f726;color:#a855f7;letter-spacing:.5px;font-size:.68rem}.bit-view-btn{padding:.3rem .75rem;background:none;border:1px solid var(--border-color, #334155);border-radius:6px;color:var(--accent, #3b82f6);font-size:.8rem;cursor:pointer;transition:background .15s}.bit-view-btn:hover{background:#3b82f61a}.bit-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem;font-size:.85rem;color:var(--text-secondary, #94a3b8)}.bit-pagination button{padding:.4rem 1rem;background:var(--card-bg, #1e293b);border:1px solid var(--border-color, #334155);border-radius:6px;color:var(--text-primary, #e2e8f0);cursor:pointer;font-size:.8rem;transition:background .15s}.bit-pagination button:hover:not(:disabled){background:#ffffff14}.bit-pagination button:disabled{opacity:.4;cursor:not-allowed}.bit-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.bit-modal{background:var(--card-bg, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;width:90%;max-width:600px;max-height:80vh;overflow-y:auto}.bit-modal-sm{max-width:400px}.bit-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color, #334155)}.bit-modal-header h2{font-size:1.1rem;font-weight:600;color:var(--text-primary, #e2e8f0);margin:0}.bit-modal-close{background:none;border:none;color:var(--text-secondary, #94a3b8);font-size:1.4rem;cursor:pointer;padding:0;line-height:1}.bit-modal-close:hover{color:var(--text-primary, #e2e8f0)}.bit-modal-body{padding:1.25rem}.bit-detail-row{display:flex;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--border-color, #1e293b);align-items:flex-start}.bit-detail-row:last-child{border-bottom:none}.bit-detail-label{font-weight:600;color:var(--text-secondary, #94a3b8);min-width:100px;flex-shrink:0;font-size:.85rem}.bit-detail-desc{word-break:break-word;white-space:pre-wrap}.bit-detail-ua{word-break:break-all;font-size:.8rem;color:var(--text-secondary, #64748b)}.bit-delete-form{display:flex;flex-direction:column;gap:1rem}.bit-delete-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;color:var(--text-secondary, #94a3b8)}.bit-delete-confirm-btn{padding:.65rem 1rem;background:#dc2626;color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s;margin-top:.5rem}.bit-delete-confirm-btn:hover{background:#b91c1c}@media(max-width:768px){.bit-filters{flex-direction:column}.bit-search-wrap,.bit-select,.bit-date{width:100%}.bit-stats-bar{flex-wrap:wrap;gap:.5rem}.bit-stat-card{flex:1 1 calc(50% - .25rem);min-width:0}.bit-delete-btn{width:100%;justify-content:center}.bit-title{font-size:1.2rem}.bit-detail-row{flex-direction:column;gap:.25rem}.bit-detail-label{min-width:auto}.bit-pagination{flex-direction:column;gap:.5rem}.bit-table thead th:nth-child(4),.bit-table tbody td:nth-child(4),.bit-table thead th:nth-child(6),.bit-table tbody td:nth-child(6),.bit-table thead th:nth-child(7),.bit-table tbody td:nth-child(7){display:none}.bit-table{font-size:.75rem}.bit-table thead th{padding:.5rem;font-size:.6rem}.bit-table td{padding:.5rem;font-size:.75rem}.bit-modal{width:95%}}@media(min-width:768px)and (max-width:1024px){.bit-table thead th:nth-child(6),.bit-table tbody td:nth-child(6){display:none}}.sa-dashboard{display:flex;min-height:100vh;background:var(--body-bg)}.sa-sidebar{width:240px;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;justify-content:space-between;position:fixed;top:0;left:0;height:100vh;z-index:100}.sa-sidebar-top{padding:1.25rem}.sa-sidebar-logo{display:flex;align-items:center;gap:.6rem;font-size:1.15rem;font-weight:700;margin-bottom:.75rem}.sa-role-badge{background:#ffffff26;padding:.25rem .75rem;border-radius:20px;font-size:.7rem;text-transform:uppercase;letter-spacing:1px;text-align:center;margin-bottom:1.5rem}.sa-sidebar-nav{display:flex;flex-direction:column;gap:.25rem}.sa-sidebar-link{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:8px;background:none;border:none;color:#ffffffb3;font-size:.9rem;cursor:pointer;transition:all .15s;width:100%;text-align:left}.sa-sidebar-link:hover{background:var(--sidebar-hover);color:var(--sidebar-text)}.sa-sidebar-link.active{background:var(--sidebar-active);color:var(--sidebar-text);font-weight:600}.sa-sidebar-bottom{padding:1.25rem;border-top:1px solid var(--sidebar-border)}.sa-sidebar-user{display:flex;align-items:center;gap:.6rem;margin-bottom:.75rem}.sa-sidebar-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--sidebar-avatar-bg);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.sa-sidebar-user-info{display:flex;flex-direction:column}.sa-sidebar-user-name{font-size:.85rem;font-weight:600}.sa-sidebar-user-role{font-size:.7rem;opacity:.6}.sa-sidebar-logout{display:flex;align-items:center;gap:.5rem;background:none;border:none;color:#fff9;font-size:.8rem;cursor:pointer;padding:.4rem 0;transition:color .15s;width:100%}.sa-sidebar-logout:hover{color:#fca5a5}.sa-theme-switcher{display:flex;gap:.35rem;margin-bottom:.75rem;padding:.35rem;background:#ffffff14;border-radius:8px}.sa-theme-btn{flex:1;display:flex;align-items:center;justify-content:center;padding:.35rem;border:none;border-radius:6px;background:transparent;color:#ffffff80;cursor:pointer;transition:all .15s}.sa-theme-btn:hover{color:#fffc;background:#ffffff14}.sa-theme-btn.active{background:#fff3;color:#fff}.sa-main{flex:1;margin-left:240px;padding:1.5rem}.sa-stats-bar{display:flex;gap:1rem;margin-bottom:1.5rem}.sa-stat{flex:1;background:var(--card-bg);border-radius:10px;padding:1rem 1.25rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center}.sa-stat-number{font-size:1.75rem;font-weight:700;color:var(--primary)}.sa-stat.warning .sa-stat-number{color:var(--red-500)}.sa-stat-label{font-size:.75rem;color:var(--text-secondary);margin-top:.15rem}.sa-module{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm)}.sa-module-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.sa-module-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.sa-module-subtitle{font-size:.8rem;color:var(--text-secondary);margin:.2rem 0 0}.sa-btn-primary{background:var(--primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.sa-btn-primary:hover{background:var(--primary-dark)}.sa-btn-cancel{background:var(--gray-100);color:var(--text-secondary);border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .15s}.sa-btn-cancel:hover{background:var(--gray-200)}.sa-btn-sm{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--border-color);padding:.3rem .6rem;border-radius:6px;font-size:.75rem;cursor:pointer;transition:all .15s}.sa-btn-sm:hover{background:var(--gray-200)}.sa-btn-sm.danger{color:var(--red-500);border-color:#fecaca}.sa-btn-sm.danger:hover{background:var(--red-bg)}.sa-form{background:var(--gray-50);border:1px solid var(--border-color);border-radius:10px;padding:1.25rem;margin-bottom:1.25rem}.sa-form-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.sa-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.sa-form-field{display:flex;flex-direction:column;gap:.3rem}.sa-form-field label{font-size:.75rem;font-weight:600;color:var(--gray-600)}.sa-form-field input,.sa-form-field textarea,.sa-form-field select{padding:.5rem .65rem;border:1px solid var(--input-border);border-radius:6px;font-size:.85rem;color:var(--text-primary);background:var(--input-bg);transition:border-color .15s}.sa-form-field input:focus,.sa-form-field textarea:focus,.sa-form-field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #1e40af1a}.sa-form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.sa-plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;overflow:hidden}.sa-plan-card{border:1px solid var(--border-color);border-radius:10px;padding:1.25rem;transition:all .15s;background:var(--card-bg);overflow:hidden;min-width:0}.sa-plan-card:hover{box-shadow:var(--shadow-md)}.sa-plan-card.inactive{opacity:.6;background:var(--gray-50)}.sa-plan-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.sa-plan-name{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sa-plan-status{font-size:.65rem;font-weight:600;padding:.2rem .5rem;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.sa-plan-status.active{background:var(--green-light);color:var(--green-text)}.sa-plan-status.inactive{background:var(--gray-100);color:var(--text-secondary)}.sa-plan-price{display:flex;align-items:baseline;gap:.15rem;margin-bottom:.5rem}.sa-plan-currency{font-size:1rem;font-weight:600;color:var(--primary)}.sa-plan-amount{font-size:1.75rem;font-weight:800;color:var(--primary)}.sa-plan-period{font-size:.8rem;color:var(--text-secondary)}.sa-plan-desc{font-size:.8rem;color:var(--text-secondary);margin:.5rem 0;line-height:1.4}.sa-plan-limits{display:grid;grid-template-columns:repeat(4,1fr);gap:.25rem;margin:.75rem 0;padding:.5rem 0;border-top:1px solid var(--gray-100)}.sa-plan-limit{display:flex;flex-direction:column;min-width:0;overflow:hidden}.sa-plan-limit-label{font-size:.6rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sa-plan-limit-value{font-size:.8rem;font-weight:600;color:var(--gray-700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sa-plan-actions{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--gray-100)}.sa-filters{display:flex;gap:.5rem;margin-bottom:1.25rem;flex-wrap:wrap}.sa-filter-btn{display:flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:20px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .15s}.sa-filter-btn:hover{border-color:var(--primary);color:var(--primary)}.sa-filter-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.sa-filter-count{background:#00000014;padding:.1rem .4rem;border-radius:10px;font-size:.7rem;font-weight:600}.sa-filter-btn.active .sa-filter-count{background:#fff3}.sa-empresas-list{display:flex;flex-direction:column;gap:.75rem}.sa-empresa-card{border:1px solid var(--border-color);border-radius:10px;overflow:hidden;transition:all .15s}.sa-empresa-card:hover{box-shadow:var(--shadow-md)}.sa-empresa-card.disabled{opacity:.6}.sa-empresa-main{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;cursor:pointer}.sa-empresa-main:hover{background:var(--gray-50)}.sa-empresa-info{flex:1}.sa-empresa-name-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.sa-empresa-name{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.sa-empresa-meta{display:flex;gap:1rem;margin-top:.3rem;font-size:.78rem;color:var(--text-secondary);flex-wrap:wrap}.sa-empresa-plan-info{font-size:.78rem;color:var(--gray-600);margin-top:.3rem}.sa-empresa-expand{font-size:.75rem;color:var(--gray-400);padding:.25rem}.sa-empresa-actions-bar{display:flex;gap:.4rem;padding:.5rem 1.25rem;background:var(--gray-50);border-top:1px solid var(--gray-100)}.sa-estado-badge{font-size:.65rem;font-weight:600;padding:.15rem .5rem;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.sa-estado-badge.active{background:var(--green-light);color:var(--green-text)}.sa-estado-badge.expired{background:var(--red-bg);color:var(--red-500)}.sa-estado-badge.no-plan{background:var(--gray-100);color:var(--text-secondary)}.sa-estado-badge.cancelled{background:var(--orange-light);color:#92400e}.sa-estado-badge.replaced{background:#e0e7ff;color:#3730a3}.sa-estado-badge.disabled{background:var(--red-bg);color:var(--red-600)}.sa-sub-form{padding:1rem 1.25rem;background:var(--primary-bg);border-top:1px solid var(--gray-200)}.sa-sub-form-title{font-size:.9rem;font-weight:600;color:var(--primary);margin:0 0 .75rem}.sa-empresa-detalle{padding:1rem 1.25rem;background:var(--gray-50);border-top:1px solid var(--border-color)}.sa-detalle-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem}.sa-subs-table{font-size:.8rem}.sa-subs-header{display:grid;grid-template-columns:1fr 1fr 1fr .8fr .8fr;gap:.5rem;padding:.4rem 0;border-bottom:2px solid var(--border-color);font-weight:600;color:var(--gray-600)}.sa-subs-row{display:grid;grid-template-columns:1fr 1fr 1fr .8fr .8fr;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--gray-100);align-items:center}.sa-no-subs{font-size:.8rem;color:var(--gray-400);text-align:center;padding:1rem}.sa-empty{text-align:center;padding:2rem;color:var(--gray-400);font-size:.9rem}.sa-table-container{overflow-x:auto}.sa-table{width:100%;border-collapse:collapse;font-size:.85rem}.sa-table thead tr{border-bottom:1px solid var(--border-color)}.sa-table th{text-align:left;padding:.75rem;font-size:.7rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.sa-table td{padding:.85rem .75rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color);vertical-align:middle}.sa-table tbody tr{border-bottom:1px solid var(--gray-100);transition:background .1s}.sa-table tbody tr:hover{background:var(--gray-50)}.sa-table tbody tr.row-disabled{opacity:.5}.sa-cell-nombre{display:flex;align-items:center;gap:.6rem}.sa-empresa-icon{width:32px;height:32px;border-radius:8px;background:var(--primary-bg);display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}.sa-cell-nombre-text{font-weight:600;color:var(--text-primary)}.sa-cell-slug{color:var(--gray-400);font-size:.8rem}.sa-cell-empleados{display:flex;align-items:center;gap:.35rem;color:var(--text-secondary)}.sa-cell-date{color:var(--text-secondary);font-size:.8rem;white-space:nowrap}.sa-cell-actions{display:flex;gap:.5rem;align-items:center}.sa-action-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:none;background:transparent;color:var(--gray-400);cursor:pointer;transition:all .15s}.sa-action-btn:hover{background:var(--gray-100);color:var(--gray-600)}.sa-action-btn.action-delete:hover{background:var(--red-bg);color:var(--red-500)}.sa-action-btn.action-key:hover{background:var(--orange-light);color:#a16207}.sa-action-btn.action-activate{color:var(--green-text)}.sa-action-btn.action-activate:hover{background:var(--green-light);color:#166534}.sa-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:.2rem .6rem;border-radius:20px;white-space:nowrap}.sa-badge-active{background:var(--green-light);color:var(--green-text)}.sa-badge-expired{background:var(--red-bg);color:var(--red-500)}.sa-badge-noplan{background:var(--gray-100);color:var(--text-secondary)}.sa-badge-cancelled{background:var(--orange-light);color:#92400e}.sa-badge-inactive{background:var(--red-bg);color:var(--red-600)}.sa-badge-plan{background:var(--primary-bg);color:var(--primary)}.sa-content{min-height:200px}.sa-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.sa-modal{background:var(--card-bg);border-radius:14px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.sa-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.sa-modal-title{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0}.sa-modal-subtitle{font-size:.8rem;color:var(--text-secondary);margin:.15rem 0 0}.sa-modal-close{background:none;border:none;font-size:1.5rem;color:var(--gray-400);cursor:pointer;padding:0;line-height:1}.sa-modal-close:hover{color:var(--gray-600)}.sa-modal-body{padding:1.25rem 1.5rem}.sa-modal-error{background:var(--red-bg);color:var(--red-500);border:1px solid #fecaca;border-radius:8px;padding:.6rem .85rem;font-size:.8rem;margin-bottom:1rem}.sa-modal-section{margin-bottom:1.25rem}.sa-modal-section-title{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem;padding-bottom:.4rem;border-bottom:1px solid var(--gray-100)}.sa-modal-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.sa-modal-field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.5rem}.sa-modal-field label{font-size:.75rem;font-weight:600;color:var(--gray-600)}.sa-required{color:var(--red-500)}.sa-modal-field input,.sa-modal-field select{padding:.55rem .7rem;border:1px solid var(--input-border);border-radius:8px;font-size:.85rem;color:var(--text-primary);background:var(--input-bg);transition:border-color .15s}.sa-modal-field input:focus,.sa-modal-field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #1e40af1a}.sa-input-readonly{background:var(--gray-50)!important;color:var(--gray-400)!important;cursor:default}.sa-password-field{position:relative}.sa-password-field input{width:100%;padding-right:2.5rem;box-sizing:border-box}.sa-password-toggle{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--gray-400);cursor:pointer;padding:.2rem}.sa-password-toggle:hover{color:var(--gray-600)}.sa-modulos-grid{display:flex;flex-wrap:wrap;gap:.5rem}.sa-modulo-chip{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;border-radius:8px;border:1.5px solid var(--input-border);background:var(--card-bg);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .15s}.sa-modulo-chip:hover{border-color:var(--primary);color:var(--primary)}.sa-modulo-chip.active{border-color:var(--primary);background:var(--primary-bg);color:var(--primary)}.sa-modulo-check{display:flex;align-items:center;justify-content:center;color:var(--primary)}.sa-modulo-chip:not(.active) .sa-modulo-check{color:var(--input-border)}.sa-modal-info{display:flex;align-items:flex-start;gap:.5rem;background:var(--primary-bg);color:var(--primary);border:1px solid var(--gray-200);border-radius:8px;padding:.65rem .85rem;font-size:.8rem;line-height:1.4;margin-top:.25rem}.sa-modal-info svg{flex-shrink:0;margin-top:.1rem}.sa-modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding-top:1rem;border-top:1px solid var(--gray-100)}.sa-mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height, 56px);background:var(--sidebar-bg);color:var(--sidebar-text);align-items:center;gap:.75rem;padding:0 1rem;z-index:100;transition:background-color .3s ease}.sa-hamburger-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--sidebar-text);cursor:pointer;padding:.25rem;border-radius:6px;transition:background .15s}.sa-hamburger-btn:hover{background:var(--sidebar-hover)}.sa-mobile-header-brand{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:var(--sidebar-text)}.sa-mobile-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:199}.sa-mobile-sidebar{display:none;position:fixed;top:0;left:-280px;width:280px;height:100%;background:var(--sidebar-bg);color:var(--sidebar-text);z-index:200;flex-direction:column;transition:left .3s ease;overflow-y:auto}.sa-mobile-sidebar.open{left:0}.sa-mobile-sidebar-top{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem}.sa-mobile-sidebar-brand{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;color:var(--sidebar-text)}.sa-mobile-close-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--sidebar-text);cursor:pointer;padding:.25rem;border-radius:6px;opacity:.7;transition:opacity .15s}.sa-mobile-close-btn:hover{opacity:1}.sa-mobile-sidebar-nav{display:flex;flex-direction:column;gap:.25rem;padding:.5rem .75rem}.sa-mobile-sidebar>.sa-role-badge{margin:0 1.25rem .5rem;align-self:flex-start}.sa-mobile-sidebar>.sa-theme-switcher{margin:0 1.25rem .5rem}.sa-mobile-sidebar-bottom{margin-top:auto;padding:1rem .75rem;border-top:1px solid rgba(255,255,255,.1)}.sa-mobile-cards{display:none;flex-direction:column;gap:.75rem}.sa-mobile-card{border:1px solid var(--border-color);border-radius:10px;padding:1rem;background:var(--card-bg);transition:box-shadow .15s}.sa-mobile-card:hover{box-shadow:var(--shadow-md)}.sa-mobile-card.disabled{opacity:.5}.sa-mobile-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.sa-mobile-card-name{display:flex;align-items:center;gap:.5rem}.sa-mobile-card-name h4{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0}.sa-mobile-card-slug{font-size:.75rem;color:var(--gray-400)}.sa-mobile-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem}.sa-mobile-card-field{display:flex;flex-direction:column;gap:.1rem}.sa-mobile-card-label{font-size:.65rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.sa-mobile-card-value{font-size:.8rem;color:var(--text-primary)}.sa-mobile-card-actions{display:flex;gap:.35rem;flex-wrap:wrap;padding-top:.75rem;border-top:1px solid var(--gray-100)}@media(max-width:1024px){.sa-sidebar{display:none}.sa-mobile-header{display:flex}.sa-mobile-overlay{display:block}.sa-mobile-sidebar{display:flex}.sa-main{margin-left:0;margin-top:var(--header-height, 56px);padding:.75rem;overflow-x:hidden}.sa-stats-bar{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.sa-stat{padding:.75rem}.sa-stat-number{font-size:1.25rem}.sa-stat-label{font-size:.65rem}.sa-form-grid,.sa-plans-grid{grid-template-columns:1fr}.sa-subs-header,.sa-subs-row{grid-template-columns:1fr;gap:.25rem}.sa-empresa-meta{flex-direction:column;gap:.15rem}.sa-empresa-main{flex-direction:column;align-items:flex-start;gap:.75rem}.sa-module{padding:1rem}.sa-module-header{flex-direction:column;align-items:flex-start;gap:.75rem}.sa-module-header .sa-btn-primary{width:100%;text-align:center;justify-content:center;display:flex}.sa-module-title{font-size:1.1rem}.sa-filters{gap:.35rem}.sa-filter-btn{padding:.3rem .6rem;font-size:.7rem}.sa-table-container{display:none}.sa-mobile-cards{display:flex}.sa-modal{max-width:100%;margin:.5rem;border-radius:10px}.sa-modal-row{grid-template-columns:1fr}.sa-modal-header,.sa-modal-body{padding:1rem}.sa-empresa-actions-bar{flex-wrap:wrap}.sa-emp-filters{flex-direction:column}.sa-emp-search-wrap{max-width:100%}.sa-emp-pagination{flex-direction:column;gap:.5rem;align-items:center}.sa-table{font-size:.78rem}.sa-table th,.sa-table td{padding:.5rem .4rem}.sa-emp-table th:nth-child(4),.sa-emp-table td:nth-child(4),.sa-emp-table th:nth-child(5),.sa-emp-table td:nth-child(5){display:none}.sa-emp-nombre-cell{gap:.5rem}.sa-emp-avatar{width:28px;height:28px;font-size:.7rem}.sa-emp-nombre-text{font-size:.8rem}.sa-emp-username{font-size:.7rem}.sa-plan-card{padding:1rem}.sa-plan-amount{font-size:1.4rem}.sa-form{padding:1rem}.sa-form-actions{flex-direction:column}.sa-form-actions button{width:100%}.sa-sub-form,.sa-empresa-detalle{padding:.75rem}.sa-modulos-grid{gap:.35rem}.sa-modulo-chip{font-size:.7rem;padding:.3rem .5rem}}.sa-emp-limit-max{color:var(--text-secondary);font-size:.8rem}.sa-emp-limit-full,.sa-emp-limit-full .sa-emp-limit-max{color:var(--red-500)}.sa-select-trial{border-color:#eab308!important}.sa-trial-info{margin-top:.75rem;padding:1rem 1.25rem;background:var(--green-light);border:1px solid var(--green-border);border-radius:10px}.sa-trial-info-header{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:var(--text-primary);margin-bottom:.6rem}.sa-trial-info-desc{color:var(--text-secondary);font-size:.85rem;margin:.4rem 0 .5rem}.sa-trial-info-list{list-style:none;padding:0;margin:0 0 .75rem}.sa-trial-info-list li{color:var(--text-primary);font-size:.85rem;padding:.2rem 0 .2rem 1.25rem;position:relative}.sa-trial-info-list li:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;background:var(--green-text);border-radius:50%}.sa-trial-info-cta{color:var(--primary);font-size:.82rem;margin:0;font-style:italic}.sa-emp-breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.8rem;margin-bottom:.5rem}.sa-emp-breadcrumb-link{color:var(--primary);cursor:pointer}.sa-emp-breadcrumb-link:hover{text-decoration:underline}.sa-emp-breadcrumb-sep{color:var(--gray-400)}.sa-emp-breadcrumb-current{color:var(--text-primary);font-weight:600}.sa-emp-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.sa-emp-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border-color);border-radius:8px;background:transparent;color:var(--gray-400);cursor:pointer;transition:all .2s}.sa-emp-back-btn:hover{background:var(--gray-100);color:var(--text-primary);border-color:var(--gray-300)}.sa-emp-filters{display:flex;gap:.75rem;margin-bottom:1.25rem}.sa-emp-search-wrap{position:relative;flex:1;max-width:400px}.sa-emp-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.sa-emp-search{width:100%;padding:.6rem .75rem .6rem 2.25rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--text-primary);font-size:.85rem;outline:none;transition:border-color .2s}.sa-emp-search::placeholder{color:var(--text-secondary)}.sa-emp-search:focus{border-color:var(--primary)}.sa-emp-role-select{padding:.6rem 2rem .6rem .75rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--text-secondary);font-size:.85rem;outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color .2s}.sa-emp-role-select:focus{border-color:var(--primary)}.sa-emp-table th:nth-child(1){width:40%}.sa-emp-nombre-cell{display:flex;align-items:center;gap:.75rem}.sa-emp-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;flex-shrink:0}.sa-emp-nombre-info{display:flex;flex-direction:column;gap:.15rem}.sa-emp-nombre-text{color:var(--text-primary);font-weight:500;font-size:.9rem}.sa-emp-username{color:var(--text-secondary);font-size:.78rem}.sa-emp-rol-badge,.sa-emp-estado-badge{display:inline-block;padding:.2rem .6rem;border-radius:4px;font-size:.78rem;font-weight:500}.sa-emp-estado-activo{background:var(--green-light);color:var(--green-text)}.sa-emp-estado-inactivo{background:var(--orange-light);color:#ea580c}.sa-emp-pagination{display:flex;align-items:center;justify-content:space-between;margin-top:1rem;padding:.5rem 0}.sa-emp-pagination-info{color:var(--text-secondary);font-size:.82rem}.sa-emp-pagination-controls{display:flex;align-items:center;gap:.35rem}.sa-emp-page-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color);border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.82rem;cursor:pointer;transition:all .2s}.sa-emp-page-btn:hover:not(:disabled){background:var(--gray-100);border-color:var(--gray-300);color:var(--text-primary)}.sa-emp-page-btn.active{background:transparent;border-color:var(--primary);color:var(--primary)}.sa-emp-page-btn:disabled{opacity:.35;cursor:not-allowed}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden;max-width:100vw}:root,[data-theme=light]{--primary: #1e40af;--primary-light: #3b82f6;--primary-dark: #1e3a8a;--primary-bg: #eff6ff;--white: #ffffff;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--green-light: #f0fdf4;--green-border: #86efac;--green-text: #16a34a;--red-500: #ef4444;--red-600: #dc2626;--red-bg: #fef2f2;--orange-light: #fff7ed;--orange-border: #fdba74;--sidebar-width: 250px;--header-height: 56px;--topbar-height: 52px;--radius: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05);--transition: .2s ease;--body-bg: #f9fafb;--card-bg: #ffffff;--border-color: #e5e7eb;--text-primary: #1f2937;--text-secondary: #6b7280;--input-bg: #ffffff;--input-border: #d1d5db;--topbar-bg: #ffffff;--topbar-border: #e5e7eb;--sidebar-bg: #1e40af;--sidebar-text: #ffffff;--sidebar-hover: rgba(255, 255, 255, .1);--sidebar-active: rgba(255, 255, 255, .2);--sidebar-border: rgba(255, 255, 255, .15);--sidebar-avatar-bg: rgba(255, 255, 255, .2);--stat-today-bg: #eff6ff;--stat-today-color: #2563eb;--stat-week-bg: #f0fdf4;--stat-week-color: #16a34a;--stat-workers-bg: #faf5ff;--stat-workers-color: #9333ea;--row-alt-bg: #f8faff}[data-theme=dark]{--primary: #60a5fa;--primary-light: #93c5fd;--primary-dark: #3b82f6;--primary-bg: rgba(59, 130, 246, .15);--white: #1e293b;--gray-50: #0f172a;--gray-100: #1e293b;--gray-200: #334155;--gray-300: #475569;--gray-400: #94a3b8;--gray-500: #94a3b8;--gray-600: #cbd5e1;--gray-700: #e2e8f0;--gray-800: #f1f5f9;--gray-900: #f8fafc;--green-light: #0f2a1a;--green-border: #166534;--green-text: #4ade80;--red-500: #f87171;--red-600: #ef4444;--red-bg: #2a1515;--orange-light: #2a1f0f;--orange-border: #92400e;--body-bg: #0f172a;--card-bg: #1e293b;--border-color: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--input-bg: #0f172a;--input-border: #475569;--topbar-bg: #1e293b;--topbar-border: #334155;--sidebar-bg: #0f172a;--sidebar-text: #e2e8f0;--sidebar-hover: rgba(148, 163, 184, .1);--sidebar-active: rgba(96, 165, 250, .2);--sidebar-border: rgba(148, 163, 184, .12);--sidebar-avatar-bg: rgba(148, 163, 184, .2);--stat-today-bg: rgba(59, 130, 246, .15);--stat-today-color: #60a5fa;--stat-week-bg: rgba(74, 222, 128, .12);--stat-week-color: #4ade80;--stat-workers-bg: rgba(192, 132, 252, .12);--stat-workers-color: #c084fc;--row-alt-bg: #162033;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4), 0 2px 4px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .4), 0 4px 6px rgba(0, 0, 0, .3)}[data-theme=blue]{--primary: #1d4ed8;--primary-light: #3b82f6;--primary-dark: #1e3a8a;--primary-bg: #dbeafe;--white: #f0f5ff;--gray-50: #e8f0fe;--gray-100: #dbeafe;--gray-200: #bfdbfe;--gray-300: #93c5fd;--gray-400: #60a5fa;--gray-500: #3b82f6;--gray-600: #1e40af;--gray-700: #1e3a8a;--gray-800: #1e3a8a;--gray-900: #172554;--green-light: #ecfdf5;--green-border: #86efac;--green-text: #16a34a;--red-500: #ef4444;--red-600: #dc2626;--red-bg: #fef2f2;--orange-light: #fff7ed;--orange-border: #fdba74;--body-bg: #e0ecff;--card-bg: #eef4ff;--border-color: #bfdbfe;--text-primary: #1e3a8a;--text-secondary: #1e40af;--input-bg: #f0f5ff;--input-border: #93c5fd;--topbar-bg: #dbeafe;--topbar-border: #bfdbfe;--sidebar-bg: #1d4ed8;--sidebar-text: #ffffff;--sidebar-hover: rgba(255, 255, 255, .12);--sidebar-active: rgba(255, 255, 255, .22);--sidebar-border: rgba(255, 255, 255, .18);--sidebar-avatar-bg: rgba(255, 255, 255, .2);--stat-today-bg: #dbeafe;--stat-today-color: #1d4ed8;--stat-week-bg: #dcfce7;--stat-week-color: #16a34a;--stat-workers-bg: #ede9fe;--stat-workers-color: #7c3aed;--row-alt-bg: #e5efff}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-primary);background-color:var(--body-bg);line-height:1.5;transition:background-color .3s ease,color .3s ease}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:inherit;border:none;outline:none}input,select,textarea{font-family:inherit;font-size:.875rem;border:1px solid var(--input-border);border-radius:var(--radius);padding:.5rem .75rem;color:var(--text-primary);background:var(--input-bg);transition:border-color var(--transition),background-color .3s ease;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #3b82f626}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}@media(max-width:767px){html{font-size:15px}}@media(min-width:1440px){html{font-size:17px}}
