@font-face{font-display:swap;font-family:Arboria;font-style:normal;font-weight:100;src:url(/static/media/Arboria-Thin.6e6995e499547f63ca49.ttf) format("truetype")}@font-face{font-display:swap;font-family:Arboria;font-style:normal;font-weight:300;src:url(/static/media/Arboria-Light.72a1e02c929927b5691f.ttf) format("truetype")}@font-face{font-display:swap;font-family:Arboria;font-style:normal;font-weight:400;src:url(/static/media/Arboria-Book.eb9f8a66fddc99c4d070.ttf) format("truetype")}@font-face{font-display:swap;font-family:Arboria;font-style:normal;font-weight:500;src:url(/static/media/Arboria-Medium.028bf023fdebe127e18c.ttf) format("truetype")}@font-face{font-display:swap;font-family:Arboria;font-style:normal;font-weight:700;src:url(/static/media/Arboria-Bold.703d46c1f5cac2ca032f.ttf) format("truetype")}@font-face{font-display:swap;font-family:Arboria;font-style:normal;font-weight:900;src:url(/static/media/Arboria-Black.3a70826b8e873bc3ce6d.ttf) format("truetype")}body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root,body,html{height:100%}.error-boundary{align-items:center;background:#f8fafc;display:flex;justify-content:center;min-height:100vh;padding:24px}.error-boundary__card{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;max-width:460px;padding:40px;text-align:center;width:100%}.error-boundary__title{color:#1e293b;font-size:1.4rem;margin:0 0 12px}.error-boundary__message{color:#64748b;font-size:.95rem;line-height:1.5;margin:0 0 24px}.error-boundary__actions{display:flex;gap:12px;justify-content:center}.error-boundary__btn{border:1px solid #0000;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 20px}.error-boundary__btn--primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.error-boundary__btn--primary:hover{background:#2563eb}.error-boundary__btn--secondary{background:#fff;border-color:#e2e8f0;color:#64748b}.error-boundary__btn--secondary:hover{background:#f1f5f9;color:#475569}.absence-approval{margin:0 auto;max-width:1400px}.absence-approval__header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:20px}.absence-approval__title{align-items:center;color:#1e293b;display:flex;font-size:1.5rem;font-weight:600;gap:10px;margin:0}.absence-approval__title svg{color:#3b82f6}.absence-approval__controls{align-items:center;display:flex;gap:12px}.absence-approval__refresh{align-items:center;color:#64748b;display:flex;font-size:.8rem;gap:6px}.absence-approval__kpi-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:20px}.absence-approval__kpi-grid .kpi-card-container{height:120px}.absence-approval__kpi-grid .kpi-card__content{padding:12px 32px 12px 16px}.absence-approval__kpi-grid .kpi-card__title{font-size:.85rem}.absence-approval__kpi-grid .kpi-card__value{font-size:1.75rem}.absence-approval__kpi-grid .kpi-card__icon{height:20px;width:20px}.absence-approval__kpi-grid .kpi-card__flip-btn{display:none}.absence-approval .filter-bar{margin-bottom:20px}.absence-approval__table-card{margin-bottom:24px}.absence-approval__table-title{align-items:center;display:flex;font-size:1rem;gap:10px;margin:0}.absence-approval__count{align-items:center;background:#f1f5f9;border-radius:12px;color:#64748b;display:inline-flex;font-size:.75rem;font-weight:600;height:24px;justify-content:center;min-width:24px;padding:0 8px}.absence-approval__table-content{padding:0!important}.absence-approval__empty,.absence-approval__loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:40px 20px}.absence-approval__empty svg{color:#cbd5e1}.absence-cell-user{display:flex;flex-direction:column;gap:2px}.absence-cell-user__name{color:#1e293b;font-weight:500}.absence-cell-user__date{color:#94a3b8;font-size:.75rem}.absence-cell-type{color:#475569}.absence-action-btn--approve{background:#dcfce7;border-color:#bbf7d0;color:#16a34a}.absence-action-btn--approve:hover:not(:disabled){background:#16a34a;color:#fff}.absence-action-btn--approve:disabled{cursor:not-allowed;opacity:.4}.absence-action-btn--reject{background:#fee2e2;border-color:#fecaca;color:#dc2626}.absence-action-btn--reject:hover:not(:disabled){background:#dc2626;color:#fff}.absence-action-btn--doc{background:#fef3c7;border-color:#fde68a;color:#d97706}.absence-action-btn--doc:hover:not(:disabled){background:#d97706;color:#fff}.absence-modal-overlay{animation:fadeIn .15s ease}.absence-modal{animation:slideIn .2s ease;max-width:440px}.absence-modal__header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:16px 20px}.absence-modal__title{align-items:center;display:flex;gap:10px}.absence-modal__title h4{color:#1e293b;font-size:1rem;margin:0}.absence-modal__title svg{color:#64748b}.absence-modal__icon--success{color:#10b981!important}.absence-modal__icon--danger{color:#dc2626!important}.absence-modal__close{align-items:center;background:#0000;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;height:32px;justify-content:center;padding:0;width:32px}.absence-modal__close:hover{background:#f1f5f9;color:#64748b}.absence-modal__body{padding:20px}.absence-modal__info{background:#f8fafc;border-radius:8px;margin-bottom:16px;padding:12px}.absence-modal__info p{color:#475569;font-size:.875rem;margin:0 0 6px}.absence-modal__info p:last-child{margin-bottom:0}.absence-modal__actions{background:#f8fafc;border-top:1px solid #e2e8f0;justify-content:flex-end;padding:16px 20px}.absence-form-row{display:flex;flex-direction:column;gap:6px}.absence-form-row label{color:#475569;font-size:.8rem;font-weight:600}.absence-form-row textarea{border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;padding:10px 12px;resize:vertical;transition:border-color .15s;width:100%}.absence-form-row textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.absence-btn--success{background:#10b981;color:#fff}.absence-btn--success:hover:not(:disabled){background:#059669}@media (max-width:768px){.absence-approval__header{align-items:flex-start;flex-direction:column}.absence-approval__kpi-grid{grid-template-columns:repeat(3,1fr)}.absence-approval__kpi-grid .kpi-card-container{height:100px}.absence-approval__kpi-grid .kpi-card__value{font-size:1.5rem}.absence-table{font-size:.8rem}.absence-table td,.absence-table th{padding:10px 12px}.absence-cell-period{align-items:flex-start;flex-direction:column;gap:2px}.absence-cell-period__sep{display:none}}@media (max-width:640px){.absence-approval__kpi-grid{grid-template-columns:1fr}.absence-approval__kpi-grid .kpi-card-container{height:90px}.absence-table td:nth-child(4),.absence-table th:nth-child(4){display:none}}@media (max-width:480px){.absence-approval__title{font-size:1.25rem}.absence-modal{margin:8px}}.filter-bar{flex-shrink:0}.filter-bar__header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px;padding-bottom:8px}.filter-bar__title{align-items:center;color:#475569;display:flex;font-size:.9rem;font-weight:600;gap:8px;letter-spacing:.5px;margin:0;text-transform:uppercase}.filter-bar__title svg{color:#64748b}.filter-bar__actions{align-items:center;display:flex;gap:8px}.filter-bar__btn{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);color:#64748b;color:var(--color-text-secondary,#64748b);cursor:pointer;display:inline-flex;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.filter-bar__btn:hover:not(:disabled){background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);border-color:#94a3b8;border-color:var(--color-text-muted,#94a3b8);color:#0f172a;color:var(--color-text-primary,#0f172a)}.filter-bar__btn:disabled{cursor:not-allowed;opacity:.4}.filter-bar__btn--active{background-color:#2563eb;background-color:var(--color-primary,#2563eb);border-color:#2563eb;border-color:var(--color-primary,#2563eb);color:#fff}.filter-bar__btn--active:hover:not(:disabled){background-color:#1d4ed8;border-color:#1d4ed8;color:#fff}.filter-bar__body{max-height:500px;opacity:1;overflow:hidden;transition:max-height .3s ease,opacity .3s ease}.filter-bar__body--collapsed{max-height:0;opacity:0}.filter-bar__grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-bar__field{display:flex;flex-direction:column;gap:6px}.filter-bar__label{align-items:center;color:#64748b;color:var(--color-text-secondary,#64748b);display:flex;font-size:12px;font-weight:500;gap:6px;letter-spacing:.5px;text-transform:uppercase}.filter-bar__field input[type=date],.filter-bar__field input[type=number],.filter-bar__field input[type=search],.filter-bar__field input[type=text]{background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);box-sizing:border-box;color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:14px;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.filter-bar__field input:focus{border-color:#1890ff;border-color:var(--color-primary,#1890ff);box-shadow:0 0 0 3px #1890ff1a;box-shadow:0 0 0 3px var(--color-primary-light,#1890ff1a);outline:none}.filter-bar__field input::placeholder{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.filter-bar__field select{-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%2364748b' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);box-sizing:border-box;color:#0f172a;color:var(--color-text-primary,#0f172a);cursor:pointer;font-size:14px;padding:10px 36px 10px 12px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.filter-bar__field select:focus{border-color:#1890ff;border-color:var(--color-primary,#1890ff);box-shadow:0 0 0 3px #1890ff1a;box-shadow:0 0 0 3px var(--color-primary-light,#1890ff1a);outline:none}.filter-bar__field input:disabled,.filter-bar__field select:disabled{background-color:#f1f5f9;color:#94a3b8;cursor:not-allowed}.filter-bar__search-wrapper{align-items:center;display:flex;position:relative}.filter-bar__search-wrapper svg{color:#94a3b8;color:var(--color-text-muted,#94a3b8);left:12px;pointer-events:none;position:absolute}.filter-bar__search-wrapper input{padding-left:40px!important}.filter-bar__checkbox-label{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);color:#0f172a;color:var(--color-text-primary,#0f172a);cursor:pointer;display:flex;font-size:14px;gap:8px;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease;-webkit-user-select:none;user-select:none}.filter-bar__checkbox-label:hover{border-color:#94a3b8;border-color:var(--color-text-muted,#94a3b8)}.filter-bar__checkbox-label input[type=checkbox]{accent-color:#2563eb;accent-color:var(--color-primary,#2563eb);cursor:pointer;height:16px;width:16px}@media (max-width:768px){.filter-bar__grid{grid-template-columns:1fr}.filter-bar__header{gap:8px}}.toast-container{pointer-events:none;position:fixed;right:16px;top:80px;z-index:1400}.toast{align-items:flex-start;animation:toast-slide-in .3s ease-out;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;gap:12px;max-width:400px;min-width:300px;padding:14px 16px;pointer-events:auto}.toast.toast--closing{animation:toast-slide-out .2s ease-in forwards}@keyframes toast-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes toast-slide-out{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}.toast--success{border-left:4px solid #16a34a}.toast--success .toast__icon{color:#16a34a}.toast--error{border-left:4px solid #dc2626}.toast--error .toast__icon{color:#dc2626}.toast--warning{border-left:4px solid #f59e0b}.toast--warning .toast__icon{color:#f59e0b}.toast--info{border-left:4px solid #2563eb}.toast--info .toast__icon{color:#2563eb}.toast__icon{flex-shrink:0;height:20px;margin-top:1px;width:20px}.toast__content{flex:1 1;min-width:0}.toast__message{color:#1e293b;font-size:14px;font-weight:500;line-height:1.4;word-break:break-word}.toast__close{align-items:center;background:#0000;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;margin:-2px -4px -2px 0;padding:0;transition:all .15s ease;width:24px}.toast__close:hover{background:#f1f5f9;color:#64748b}.toast__close svg{height:16px;width:16px}@media (max-width:480px){.toast-container{bottom:16px;left:16px;right:16px;top:auto}.toast{max-width:none;min-width:auto;width:100%}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes toast-slide-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .2s ease,transform .2s ease}.card:hover{box-shadow:0 4px 12px #0000001a}.card--clickable{cursor:pointer}.card--clickable:hover{transform:scale(1.02)}.card-header{gap:12px;padding:16px 20px}.card-header--with-border{border-bottom:1px solid #e2e8f0}.card-title{align-items:center;color:#1e293b;display:flex;font-size:1rem;font-weight:600;gap:8px;margin:0}.card-content{flex:1 1;padding:16px 20px}.card-content--no-padding{padding:0}.card-footer{align-items:center;background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:12px 20px}.card--elevated{box-shadow:0 4px 16px #00000014}.card--flat{border:1px solid #e2e8f0;box-shadow:none}.card--bordered-left{border-left-width:4px}@media (max-width:640px){.card-content,.card-header{padding:12px 16px}.card-footer{padding:10px 16px}}.kpi-card-container{height:180px;perspective:1000px;position:relative}.kpi-card-flipper{height:100%;position:relative;transform-style:preserve-3d;transition:transform .5s ease;width:100%}.kpi-card-flipper--flipped{transform:rotateY(180deg)}.kpi-card-back,.kpi-card-front{-webkit-backface-visibility:hidden;backface-visibility:hidden;border-left-style:solid;border-left-width:4px;inset:0;position:absolute}.kpi-card-front{transition:box-shadow .2s ease,transform .2s ease}.kpi-card-front.kpi-card--clickable{cursor:pointer}.kpi-card-front.kpi-card--clickable:hover{box-shadow:0 8px 24px #0000001f;transform:scale(1.02)}.kpi-card-back{background:#f8fafc;overflow-y:auto;transform:rotateY(180deg)}.kpi-card__flip-btn{align-items:center;background:#f1f5f9;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:6px;position:absolute;right:8px;top:8px;transition:background .15s ease;z-index:10}.kpi-card__flip-btn:hover{background:#e2e8f0;color:#475569}.kpi-card__content{flex-direction:column;height:100%;padding:16px 40px 16px 20px}.kpi-card__content,.kpi-card__header{display:flex;justify-content:space-between}.kpi-card__header{align-items:center}.kpi-card__title{color:#64748b;display:block;font-size:1rem;font-weight:500}.kpi-card__subtitle{color:#94a3b8;display:block;font-size:.7rem;font-weight:400;margin-top:2px}.kpi-card__icon{flex-shrink:0}.kpi-card__body{display:flex;flex-direction:column;gap:8px}.kpi-card__loading{align-items:center;color:#94a3b8;display:flex;font-size:.875rem;gap:8px}.kpi-card__spinner{animation:kpi-spin .8s linear infinite}@keyframes kpi-spin{to{transform:rotate(1turn)}}.kpi-card__value-row{align-items:baseline;display:flex;gap:4px}.kpi-card__value{font-size:2.5rem;font-weight:700;line-height:1}.kpi-card__unit{color:#64748b;font-size:1.125rem;font-weight:500}.kpi-card__indicators{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.kpi-card__trend{align-items:center;display:flex;gap:2px}.kpi-card__trend-icon--up{color:#22c55e}.kpi-card__trend-icon--down{color:#ef4444}.kpi-card__trend-icon--neutral{color:#94a3b8}.kpi-card__trend-value{font-size:.75rem;font-weight:500}.kpi-card__trend-value--up{color:#16a34a}.kpi-card__trend-value--down{color:#dc2626}.kpi-card__trend-value--neutral{color:#64748b}.kpi-card__status{align-items:center;display:flex;gap:4px}.kpi-card__status-dot{border-radius:50%;height:8px;width:8px}.kpi-card__extra,.kpi-card__status-label{font-size:.75rem;font-weight:500}.kpi-card__extra{margin:0}.kpi-card__back-content{display:flex;flex-direction:column;height:100%;padding:12px 40px 12px 16px}.kpi-card__back-title{align-items:center;color:#1e293b;display:flex;font-size:.9375rem;font-weight:600;gap:6px;margin:0 0 8px}.kpi-card__back-info{display:flex;flex:1 1;flex-direction:column;gap:8px;overflow-y:auto}.kpi-card__back-section{display:flex;flex-direction:column;gap:2px}.kpi-card__back-label{color:#475569;font-size:.8125rem;font-weight:600;margin:0}.kpi-card__back-text{color:#475569;font-size:.8125rem;line-height:1.4;margin:0}.kpi-card__back-text--muted{color:#64748b}.kpi-card__back-meta{align-items:center;display:flex;gap:8px}.kpi-card__back-meta-value{border-radius:9999px;font-size:.8125rem;font-weight:600;padding:2px 8px}.kpi-card__back-tip{border-top:1px solid #e2e8f0;margin-top:auto;padding-top:8px}.kpi-card__back-tip p{color:#64748b;font-size:.8125rem;font-style:italic;line-height:1.4;margin:0}@media (max-width:640px){.kpi-card-container{height:160px}.kpi-card__content{padding:12px 36px 12px 16px}.kpi-card__title{font-size:.875rem}.kpi-card__value{font-size:2rem}.kpi-card__unit{font-size:1rem}.kpi-card__back-content{padding:10px 36px 10px 12px}.kpi-card__back-title{font-size:.875rem}.kpi-card__back-label,.kpi-card__back-text{font-size:.75rem}}.absence-page{margin:0 auto;max-width:1200px}.absence-page__header{margin-bottom:24px}.absence-page__header-main{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.absence-page__title{align-items:center;color:#1e293b;display:flex;font-size:1.5rem;font-weight:600;gap:10px;margin:0}.absence-page__title svg{color:#3b82f6}.absence-page__stats{display:flex;flex-wrap:wrap;gap:12px}.absence-stat{align-items:center;border-radius:20px;display:inline-flex;font-size:.8rem;font-weight:500;gap:6px;padding:6px 12px}.absence-stat--pending{background:#fef3c7;color:#92400e}.absence-stat--approved{background:#dcfce7;color:#166534}.absence-stat--rejected{background:#fee2e2;color:#991b1b}.absence-page__loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:60px 20px}.absence-section{margin-bottom:32px}.absence-section__title{align-items:center;border-bottom:1px solid #e2e8f0;color:#475569;display:flex;font-size:.9rem;font-weight:600;gap:8px;letter-spacing:.5px;margin:0 0 16px;padding-bottom:8px;text-transform:uppercase}.absence-section__title svg{color:#64748b}.absence-section__count{align-items:center;background:#f1f5f9;border-radius:12px;color:#64748b;display:inline-flex;font-size:.75rem;font-weight:600;height:24px;justify-content:center;margin-left:auto;min-width:24px;padding:0 8px}.absence-form{display:flex;flex-direction:column;gap:12px}.absence-form__grid{align-items:flex-end;display:flex;flex-wrap:wrap;gap:12px}.absence-form__field{display:flex;flex-direction:column;gap:4px}.absence-form__field--type{width:320px}.absence-form__field--motivo{width:520px}.absence-form__field--file{min-width:150px}.absence-form__field label{align-items:center;color:#64748b;display:flex;font-size:.75rem;font-weight:600;gap:4px;letter-spacing:.5px;text-transform:uppercase}.absence-form__field label svg{color:#94a3b8}.absence-form__field input,.absence-form__field select{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#1e293b;font-size:.875rem;padding:8px 10px;transition:border-color .15s}.absence-form__field input:focus,.absence-form__field select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.absence-form__field input[type=file]{font-size:.8rem;padding:6px}.absence-form__days-badge{align-items:center;background:#dcfce7;border:1px solid #86efac;border-radius:8px;display:flex;flex-direction:column;padding:8px 12px}.absence-form__days-label{color:#166534;font-size:.65rem;font-weight:600;text-transform:uppercase}.absence-form__days-value{color:#15803d;font-size:1.1rem;font-weight:700}.absence-form__days-value--empty{color:#dc2626}.absence-form__row-2{align-items:flex-end;display:flex;flex-wrap:wrap;gap:12px}.absence-form__notice{align-items:center;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;color:#92400e;display:flex;font-size:.8rem;gap:8px;margin-bottom:12px;padding:8px 12px}.absence-form__notice svg{color:#f59e0b;flex-shrink:0}.absence-btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.absence-btn:disabled{cursor:not-allowed;opacity:.6}.absence-btn--primary{background:#3b82f6;color:#fff}.absence-btn--primary:hover:not(:disabled){background:#2563eb}.absence-btn--secondary{background:#fff;border-color:#e2e8f0;color:#475569}.absence-btn--secondary:hover:not(:disabled){background:#f8fafc}.absence-btn--danger{background:#dc2626;color:#fff}.absence-btn--danger:hover:not(:disabled){background:#b91c1c}.absence-btn--icon{background:#fff;border-color:#e2e8f0;color:#64748b;padding:8px}.absence-btn--icon:hover:not(:disabled){background:#f8fafc;color:#475569}.absence-btn--active{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.absence-filters-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;display:flex;font-size:.8rem;gap:6px;margin-bottom:12px;padding:8px 12px}.absence-empty{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:40px 20px}.absence-empty svg{color:#cbd5e1}.absence-table-wrapper{border:1px solid #e2e8f0;border-radius:8px;overflow-x:auto}.absence-table{border-collapse:collapse;font-size:.875rem;width:100%}.absence-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.absence-table th.text-center{text-align:center}.absence-table th.text-right{text-align:right}.absence-table td{border-bottom:1px solid #f1f5f9;padding:12px 16px;vertical-align:middle}.absence-table td.text-center{text-align:center}.absence-table td.text-right{text-align:right}.absence-table tbody tr:hover{background:#fafbfc}.absence-table tbody tr:last-child td{border-bottom:none}.absence-row{border-left:3px solid #0000}.absence-row--pendiente{border-left-color:#f59e0b}.absence-row--aprobada{border-left-color:#10b981}.absence-row--rechazada{border-left-color:#ef4444}.absence-row--cancelada{border-left-color:#94a3b8}.absence-cell-type{display:flex;flex-direction:column;gap:2px}.absence-cell-type__name{color:#1e293b;font-weight:500}.absence-cell-type__date{color:#94a3b8;font-size:.75rem}.absence-cell-period{align-items:center;color:#475569;display:flex;gap:6px;white-space:nowrap}.absence-cell-period__sep{color:#cbd5e1}.absence-cell-days{color:#1e293b;font-weight:600}.absence-status-badge{align-items:center;border-radius:4px;display:inline-flex;font-size:.75rem;font-weight:500;gap:4px;padding:4px 8px;white-space:nowrap}.absence-status-badge--pendiente{background:#fef3c7;color:#92400e}.absence-status-badge--aprobada{background:#dcfce7;color:#166534}.absence-status-badge--rechazada{background:#fee2e2;color:#991b1b}.absence-status-badge--cancelada{background:#f1f5f9;color:#64748b}.absence-actions{display:flex;gap:6px;justify-content:flex-end}.absence-action-btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;height:28px;justify-content:center;padding:0;transition:all .15s;width:28px}.absence-action-btn--view{background:#e0e7ff;border-color:#c7d2fe;color:#4338ca}.absence-action-btn--view:hover{background:#4338ca;color:#fff}.absence-action-btn--upload{background:#dbeafe;border-color:#93c5fd;color:#2563eb}.absence-action-btn--upload:hover:not(:disabled){background:#2563eb;color:#fff}.absence-action-btn--upload:disabled{cursor:not-allowed;opacity:.5}.absence-action-btn--cancel{background:#fee2e2;border-color:#fecaca;color:#dc2626}.absence-action-btn--cancel:hover:not(:disabled){background:#dc2626;color:#fff}.absence-upload-input{display:none}.absence-selected-file,.absence-upload-container{align-items:center;display:flex;gap:4px}.absence-selected-file{background:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;max-width:200px;padding:4px 8px}.absence-selected-file__name{color:#0369a1;font-size:12px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.absence-selected-file__remove{align-items:center;background:#e0f2fe;border:none;border-radius:50%;color:#0284c7;cursor:pointer;display:flex;flex-shrink:0;height:18px;justify-content:center;padding:0;transition:all .15s ease;width:18px}.absence-selected-file__remove:hover{background:#dc2626;color:#fff}.absence-selected-file__icon{color:#0284c7;flex-shrink:0}.absence-btn-attach{align-items:center;background:#dbeafe;border:1px solid #93c5fd;border-radius:6px;color:#1d4ed8;cursor:pointer;display:inline-flex;font-size:12px;font-weight:500;gap:6px;padding:6px 12px;transition:all .15s ease;white-space:nowrap}.absence-btn-attach:hover:not(:disabled){background:#1d4ed8;border-color:#1d4ed8;color:#fff}.absence-btn-attach:disabled{cursor:not-allowed;opacity:.5}.absence-btn-confirm-upload{align-items:center;background:#10b981;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:4px 10px;transition:all .15s ease;white-space:nowrap}.absence-btn-confirm-upload:hover:not(:disabled){background:#059669}.absence-btn-confirm-upload:disabled{cursor:not-allowed;opacity:.7}.spinning{animation:spin 1s linear infinite}.absence-modal-overlay{align-items:center;background:#0f172a66;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.absence-modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;max-width:400px;padding:24px;text-align:center;width:100%}.absence-modal__icon{align-items:center;border-radius:50%;display:inline-flex;height:48px;justify-content:center;margin-bottom:16px;width:48px}.absence-modal__icon--warning{background:#fef3c7;color:#d97706}.absence-modal__title{color:#1e293b;font-size:1.1rem;font-weight:600;margin:0 0 8px}.absence-modal__text{color:#64748b;font-size:.9rem;line-height:1.5;margin:0 0 20px}.absence-modal__actions{display:flex;gap:10px;justify-content:center}@media (max-width:768px){.absence-page__header-main{align-items:flex-start;flex-direction:column}.absence-page__stats{width:100%}.absence-stat{flex:1 1;justify-content:center}.absence-form__grid{flex-direction:column}.absence-form__field--type{max-width:100%;min-width:100%}.absence-form__row-2{flex-direction:column}.absence-form__field--motivo{max-width:100%;min-width:100%}.absence-table{font-size:.8rem}.absence-table td,.absence-table th{padding:10px 12px}.absence-cell-period{align-items:flex-start;flex-direction:column;gap:2px}.absence-cell-period__sep{display:none}}@media (max-width:640px){.absence-page__stats{flex-direction:column}.absence-stat{justify-content:flex-start}.absence-table td:nth-child(3),.absence-table th:nth-child(3){display:none}}@media (max-width:480px){.absence-page__title{font-size:1.25rem}.absence-modal{margin:8px}.absence-modal__actions{flex-direction:column}.absence-modal__actions .absence-btn{width:100%}}.atm-page{margin:0 auto;max-width:1400px;padding:24px}.atm-header{justify-content:space-between;margin-bottom:24px}.atm-header,.atm-title{align-items:center;display:flex}.atm-title{color:#1e293b;font-size:1.5rem;font-weight:600;gap:10px;margin:0}.atm-title svg{color:#3b82f6}.atm-new-btn{align-items:center;background:#3b82f6;border:1px solid #0000;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.atm-new-btn:hover{background:#2563eb}.atm-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.atm-table{border-collapse:collapse;width:100%}.atm-table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.atm-table th{color:#64748b;font-size:12px;font-weight:500;letter-spacing:.5px;padding:14px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.atm-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s ease}.atm-table tbody tr:hover{background:#f8fafc}.atm-table tbody tr:last-child{border-bottom:none}.atm-table td{color:#0f172a;font-size:14px;padding:14px 12px;vertical-align:middle}.atm-status-badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.3px;padding:4px 10px;text-transform:uppercase}.atm-status-badge--activo{background:#ecfdf5;color:#10b981}.atm-status-badge--inactivo{background:#fef2f2;color:#dc2626}.atm-actions-column{min-width:80px;text-align:center;width:80px}.atm-actions{display:flex;gap:8px;justify-content:center}.atm-action-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;display:inline-flex;justify-content:center;padding:6px 8px;transition:all .2s ease}.atm-action-btn:hover:not(:disabled){background:#f9fafb}.atm-action-btn:disabled{cursor:not-allowed;opacity:.4}.atm-action-btn--edit{color:#3b82f6}.atm-action-btn--edit:hover:not(:disabled){background:#eff6ff;border-color:#3b82f6}.atm-action-btn--deactivate{color:#ef4444}.atm-action-btn--deactivate:hover:not(:disabled){background:#fef2f2;border-color:#ef4444}.atm-action-btn--activate{color:#10b981}.atm-action-btn--activate:hover:not(:disabled){background:#ecfdf5;border-color:#10b981}.atm-empty,.atm-loading{color:#64748b;font-size:14px;padding:48px;text-align:center}.atm-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.atm-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-width:520px;width:100%}.atm-modal__header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:16px 20px}.atm-modal__header h3{color:#1e293b;font-size:1.1rem;font-weight:600;margin:0}.atm-modal__close{align-items:center;background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;font-family:inherit;font-size:24px;height:28px;justify-content:center;padding:0;transition:all .2s ease;width:28px}.atm-modal__close:hover{background:#f3f4f6;color:#4b5563}.atm-modal__body{padding:16px 20px}.atm-modal__body .form-group{margin-bottom:12px}.atm-modal__body .form-group label{color:#374151;display:block;font-size:13px;font-weight:500;margin-bottom:4px}.atm-modal__body .form-group input[type=number],.atm-modal__body .form-group input[type=text],.atm-modal__body .form-group select{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;font-family:inherit;font-size:13px;padding:8px 10px;transition:all .2s ease;width:100%}.atm-modal__body .form-group input:focus,.atm-modal__body .form-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.atm-modal__body .form-row{margin-bottom:0}.atm-modal__body .form-row .form-group{margin-bottom:12px}.atm-modal__body .form-group label input[type=checkbox]{cursor:pointer;margin-right:8px;width:auto}.atm-modal__body .help-text{color:#64748b;display:block;font-size:12px;font-style:italic;font-weight:400;margin-top:2px}.info-message{background-color:#e0f2fe;border-left:3px solid #0ea5e9;border-radius:6px;color:#0369a1;font-size:12px;line-height:1.4;margin-top:6px;padding:8px 12px}.atm-modal__actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin:0 20px;padding:14px 0 16px}.atm-btn-cancel,.atm-btn-submit{align-items:center;border-radius:6px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.atm-btn-cancel{background:#fff;border:1px solid #d1d5db;color:#4b5563}.atm-btn-cancel:hover{background:#f9fafb}.atm-btn-submit{background:#3b82f6;border:none;color:#fff}.atm-btn-submit:hover:not(:disabled){background-color:#2563eb}.atm-btn-submit:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.atm-page{padding:16px}.atm-header{align-items:flex-start;flex-direction:column;gap:12px}.atm-new-btn{justify-content:center;width:100%}.atm-table{font-size:13px}.atm-table td,.atm-table th{padding:8px 12px}.atm-modal{max-width:100%}}.floor-modal-backdrop{align-items:center;background:#0f172a73;display:flex;height:100vh;justify-content:center;left:0;padding:16px;position:fixed;top:0;width:100vw;z-index:1000}.floor-modal{animation:floorModalFadeIn .25s ease;background:#fff;border-radius:16px;box-shadow:0 16px 40px #0f172a40;display:flex;flex-direction:column;max-width:420px;width:100%}.floor-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 24px 16px}.floor-modal-header h2{color:#0f172a;font-size:20px;font-weight:600;margin:0}.floor-modal-close{background:none;border:none;color:#64748b;cursor:pointer;font-size:24px;line-height:1;transition:color .2s ease}.floor-modal-close:hover{color:#0f172a}.floor-modal-body{padding:20px 24px}.floor-modal-description{color:#475569;font-size:14px;line-height:1.6;margin:0 0 16px}.floor-modal-select-wrapper{display:flex;flex-direction:column;gap:6px}.floor-modal-label{color:#1e293b;font-size:13px;font-weight:600}.floor-modal-select{background:#fff;border:1px solid #cbd5e1;border-radius:10px;color:#0f172a;font-size:14px;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease}.floor-modal-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26;outline:none}.floor-modal-error{color:#dc2626;font-size:13px;margin-top:4px}.floor-modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px 24px}.btn-secondary{color:#0f172a}.btn-secondary:hover{background-color:#cbd5e1;box-shadow:0 8px 16px #0f172a26;transform:translateY(-1px)}@keyframes floorModalFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.weekly-schedule-calendar{margin-bottom:24px}.schedule-subtitle{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:13px;font-weight:400;margin:4px 0 0}.schedule-no-config{padding:48px 24px;text-align:center}.schedule-no-config__icon{color:#94a3b8;color:var(--color-text-muted,#94a3b8);margin-bottom:16px;opacity:.5}.schedule-no-config__text{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:15px;font-weight:500;margin:0 0 8px}.schedule-no-config__help{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:13px;margin:0}.schedule-days-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(7,1fr);margin-bottom:20px}.schedule-day-card{background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);display:flex;flex-direction:column;justify-content:space-between;min-height:100px;padding:16px 12px;text-align:center;transition:all .2s ease}.schedule-day-card:hover{border-color:#94a3b8;border-color:var(--color-text-muted,#94a3b8);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm,0 1px 2px #0000000d)}.schedule-day-card--presencial{background-color:#1890ff0a;background-color:var(--color-primary-light,#1890ff0a);border-color:#1890ff;border-color:var(--color-primary,#1890ff)}.schedule-day-card--presencial:hover{border-color:#096dd9;border-color:var(--color-primary-dark,#096dd9)}.schedule-day-card--remoto{background-color:#10b9810a;background-color:var(--color-success-light,#10b9810a);border-color:#10b981;border-color:var(--color-success,#10b981)}.schedule-day-card--remoto:hover{border-color:#059669;border-color:var(--color-success-dark,#059669)}.schedule-day-card--no-config{background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);border-color:#e2e8f0;border-color:var(--color-border,#e2e8f0);opacity:.7}.schedule-day-card--no-config:hover{opacity:.8}.schedule-day-card--today{border-width:2px;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md,0 4px 6px -1px #0000001a)}.schedule-day-card__header{align-items:center;display:flex;gap:6px;justify-content:center;margin-bottom:12px}.schedule-day-card__name{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:14px;font-weight:500;letter-spacing:.3px}.schedule-day-card--today .schedule-day-card__name{color:#0f172a;color:var(--color-text-primary,#0f172a);font-weight:600}.schedule-day-card__today-badge{background-color:#0f172a;background-color:var(--color-text-primary,#0f172a);border-radius:4px;border-radius:var(--radius-sm,4px);color:#fff;font-size:9px;font-weight:600;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase}.schedule-day-card__content{align-items:center;display:flex;flex-direction:column;gap:6px}.schedule-day-card__location-icon{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;justify-content:center}.schedule-day-card--presencial .schedule-day-card__location-icon{color:#1890ff;color:var(--color-primary,#1890ff)}.schedule-day-card--remoto .schedule-day-card__location-icon{color:#10b981;color:var(--color-success,#10b981)}.schedule-day-card__location-text{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:13px;font-weight:500}.schedule-day-card--presencial .schedule-day-card__location-text{color:#1890ff;color:var(--color-primary,#1890ff)}.schedule-day-card--remoto .schedule-day-card__location-text{color:#10b981;color:var(--color-success,#10b981)}.schedule-day-card__time{align-items:center;background-color:#f1f5f9;background-color:var(--color-bg-tertiary,#f1f5f9);border-radius:4px;border-radius:var(--radius-sm,4px);color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:inline-flex;font-size:11px;font-weight:500;gap:4px;padding:2px 8px}.schedule-day-card--today .schedule-day-card__time{background-color:#e0f2fe;background-color:var(--color-primary-light,#e0f2fe);color:#1890ff;color:var(--color-primary,#1890ff)}.schedule-day-card__no-config{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:12px;font-style:italic}.schedule-legend{border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border,#e2e8f0);display:flex;flex-wrap:wrap;gap:24px;justify-content:center;padding-top:16px}.schedule-legend__item{align-items:center;color:#64748b;color:var(--color-text-secondary,#64748b);display:flex;font-size:13px;font-weight:400;gap:8px}.schedule-legend__indicator{align-items:center;border:1px solid;border-radius:4px;border-radius:var(--radius-sm,4px);display:flex;height:24px;justify-content:center;width:24px}.schedule-legend__indicator--presencial{background-color:#1890ff1a;background-color:var(--color-primary-light,#1890ff1a);border-color:#1890ff;border-color:var(--color-primary,#1890ff);color:#1890ff;color:var(--color-primary,#1890ff)}.schedule-legend__indicator--remoto{background-color:#10b9811a;background-color:var(--color-success-light,#10b9811a);border-color:#10b981;border-color:var(--color-success,#10b981);color:#10b981;color:var(--color-success,#10b981)}.schedule-legend__indicator--no-config{background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);border-color:#e2e8f0;border-color:var(--color-border,#e2e8f0)}@media (max-width:1024px){.schedule-days-grid{gap:10px;grid-template-columns:repeat(4,1fr)}.schedule-day-card{min-height:90px;padding:12px 10px}}@media (max-width:768px){.schedule-days-grid{gap:8px;grid-template-columns:repeat(3,1fr)}.schedule-day-card{min-height:80px;padding:12px 8px}.schedule-day-card__name{font-size:13px}.schedule-day-card__location-icon svg{height:18px;width:18px}.schedule-day-card__location-text{font-size:12px}.schedule-day-card__time{font-size:10px;padding:2px 6px}.schedule-legend{gap:16px}.schedule-legend__item{font-size:12px}.schedule-legend__indicator{height:20px;width:20px}}@media (max-width:480px){.schedule-days-grid{gap:8px;grid-template-columns:repeat(2,1fr)}.schedule-day-card{min-height:70px;padding:10px 8px}.schedule-day-card__header{margin-bottom:8px}.schedule-day-card__name{font-size:12px}.schedule-day-card__today-badge{font-size:8px;padding:1px 4px}.schedule-day-card__location-icon svg{height:16px;width:16px}.schedule-day-card__location-text{font-size:11px}.schedule-day-card__time{display:none}.schedule-legend{align-items:center;flex-direction:column;gap:8px}}.attendance-container{margin:0 auto;max-width:1200px;padding:24px}.attendance-page-header{margin-bottom:24px}.attendance-page-header__main{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:12px}.attendance-page-header__title{align-items:center;color:#1e293b;color:var(--color-text-primary,#1e293b);display:flex;font-size:1.5rem;font-weight:600;gap:10px;margin:0}.attendance-page-header__title svg{color:#3b82f6}.attendance-page-header__clock{align-items:baseline;display:flex;gap:12px}.attendance-clock__time{font-size:2.5rem}.attendance-clock__date{background:#f1f5f9;border-radius:20px;color:#64748b;color:var(--color-text-secondary,#64748b);font-size:.9rem;font-weight:500;padding:4px 12px}.attendance-page-header__status{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.attendance-status-text{font-size:.8rem;letter-spacing:1px}.attendance-leave-badge{align-items:center;background:#fee2e2;border-radius:20px;color:#991b1b;display:inline-flex;font-size:.8rem;font-weight:500;gap:6px;padding:6px 12px}.attendance-section{margin-bottom:32px}.attendance-section__title{align-items:center;border-bottom:1px solid #e2e8f0;color:#475569;display:flex;font-size:.9rem;font-weight:600;gap:8px;letter-spacing:.5px;margin:0 0 16px;padding-bottom:8px;text-transform:uppercase}.attendance-section__title svg{color:#64748b}.attendance-main-card{margin-bottom:24px}.attendance-status-section{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border,#e2e8f0);margin-bottom:24px;padding:24px 0;text-align:center}.attendance-clock{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:12px}.attendance-clock__icon{color:#1890ff;color:var(--color-primary,#1890ff)}.attendance-clock__time{color:#0f172a;color:var(--color-text-primary,#0f172a);font-family:Arboria,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:48px;font-weight:300;letter-spacing:-1px}.attendance-status-text{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:13px;font-weight:500;letter-spacing:1.2px;text-transform:uppercase}.attendance-leave-block{align-items:center;background-color:#fef2f2;background-color:var(--color-danger-light,#fef2f2);border-radius:8px;border-radius:var(--radius-md,8px);color:#dc2626;color:var(--color-danger,#dc2626);display:inline-flex;font-size:14px;font-weight:500;gap:8px;margin-top:12px;padding:8px 16px}.attendance-actions{display:flex;gap:16px;justify-content:center;margin-bottom:32px}.attendance-action-btn{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);color:#0f172a;color:var(--color-text-primary,#0f172a);cursor:pointer;display:inline-flex;font-size:15px;font-weight:500;gap:8px;justify-content:center;min-width:140px;padding:14px 32px;transition:all .2s ease}.attendance-action-btn:hover:not(:disabled){background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);border-color:#94a3b8;border-color:var(--color-text-muted,#94a3b8)}.attendance-action-btn:disabled{background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:not-allowed;opacity:.7}.attendance-action-btn--checkin:hover:not(:disabled){background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);border-color:#10b981;border-color:var(--color-success,#10b981);color:#10b981;color:var(--color-success,#10b981)}.attendance-action-btn--checkout:hover:not(:disabled){background-color:#fef2f2;background-color:var(--color-danger-light,#fef2f2);border-color:#dc2626;border-color:var(--color-danger,#dc2626);color:#dc2626;color:var(--color-danger,#dc2626)}.attendance-action-btn--break:hover:not(:disabled){background-color:#fffbeb;border-color:#f59e0b;color:#f59e0b}.attendance-action-btn--break--ending{background-color:#fef2f2;border-color:#ef4444;color:#ef4444}.attendance-action-btn--break--ending:hover:not(:disabled){background-color:#fee2e2;border-color:#dc2626;color:#dc2626}.attendance-today-summary{border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border,#e2e8f0);padding-top:24px}.attendance-summary-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.attendance-summary-item{align-items:flex-start;background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);gap:12px;padding:16px}.attendance-summary-item,.attendance-summary-item__icon{border-radius:8px;border-radius:var(--radius-md,8px);display:flex}.attendance-summary-item__icon{align-items:center;background-color:#f1f5f9;background-color:var(--color-bg-tertiary,#f1f5f9);color:#64748b;color:var(--color-text-secondary,#64748b);flex-shrink:0;height:36px;justify-content:center;width:36px}.attendance-summary-item__icon--checkin{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);color:#10b981;color:var(--color-success,#10b981)}.attendance-summary-item__icon--checkout{background-color:#fef2f2;background-color:var(--color-danger-light,#fef2f2);color:#dc2626;color:var(--color-danger,#dc2626)}.attendance-summary-item__icon--hours{background-color:#e0f2fe;background-color:var(--color-primary-light,#e0f2fe);color:#1890ff;color:var(--color-primary,#1890ff)}.attendance-summary-item__icon--break{background-color:#fffbeb;color:#f59e0b}.attendance-summary-item__icon--location{background-color:#fffbeb;background-color:var(--color-warning-light,#fffbeb);color:#f59e0b;color:var(--color-warning,#f59e0b)}.attendance-summary-item__content{display:flex;flex:1 1;flex-direction:column;gap:4px}.attendance-summary-item__label{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.attendance-summary-item__time{display:flex;flex-direction:column;gap:4px}.attendance-summary-item__actual{color:#0f172a;color:var(--color-text-primary,#0f172a);font-family:Arboria,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:18px;font-weight:600}.attendance-summary-item__planned{border:1px solid;border-radius:4px;border-radius:var(--radius-sm,4px);font-size:11px;padding:2px 8px;width:-webkit-fit-content;width:fit-content}.attendance-summary-item__planned.ontime{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);border-color:#10b981;border-color:var(--color-success,#10b981);color:#10b981;color:var(--color-success,#10b981)}.attendance-summary-item__planned.early{background-color:#fffbeb;background-color:var(--color-warning-light,#fffbeb);border-color:#f59e0b;border-color:var(--color-warning,#f59e0b);color:#f59e0b;color:var(--color-warning,#f59e0b)}.attendance-summary-item__planned.late{background-color:#fef2f2;background-color:var(--color-danger-light,#fef2f2);border-color:#dc2626;border-color:var(--color-danger,#dc2626);color:#dc2626;color:var(--color-danger,#dc2626)}.attendance-summary-item__value{color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:16px;font-weight:600}.attendance-summary-item__value--location{align-items:center;display:flex;gap:6px}.attendance-summary-item__value--location svg{color:#64748b;color:var(--color-text-secondary,#64748b)}.attendance-summary-item__subvalue{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:12px}.attendance-history-section{margin-top:24px}.attendance-history-card{overflow:visible}.history-loading-state{align-items:center;color:#64748b;color:var(--color-text-secondary,#64748b);display:flex;flex-direction:column;justify-content:center;padding:64px 24px}.history-loading-spinner{animation:spin 1s linear infinite;color:#1890ff;color:var(--color-primary,#1890ff);margin-bottom:16px}.history-loading-state p{font-size:14px;margin:0}.history-empty-state{padding:64px 24px;text-align:center}.history-empty-icon{color:#94a3b8;color:var(--color-text-muted,#94a3b8);margin-bottom:16px;opacity:.5}.history-empty-state h3{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:16px;font-weight:600;margin:0 0 8px}.history-empty-state p{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:14px;margin:0}.history-stats-grid{grid-gap:16px;background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);border-radius:8px;border-radius:var(--radius-md,8px);display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:24px;padding:16px}.history-stat-item{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);display:flex;gap:12px;padding:12px 16px}.history-stat-icon{align-items:center;background-color:#e0f2fe;background-color:var(--color-primary-light,#e0f2fe);border-radius:8px;border-radius:var(--radius-md,8px);color:#1890ff;color:var(--color-primary,#1890ff);display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.history-stat-item--success .history-stat-icon{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);color:#10b981;color:var(--color-success,#10b981)}.history-stat-item--warning .history-stat-icon{background-color:#fffbeb;background-color:var(--color-warning-light,#fffbeb);color:#f59e0b;color:var(--color-warning,#f59e0b)}.history-stat-content{display:flex;flex-direction:column}.history-stat-value{color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:24px;font-weight:600;line-height:1.2}.history-stat-label{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:12px;font-weight:500}.history-table-wrapper{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:12px;border-radius:var(--radius-lg,12px);overflow:hidden}.history-table-scroll{max-height:500px;overflow-x:auto;overflow-y:auto}.history-table{min-width:700px}.history-table thead{position:-webkit-sticky;position:sticky;top:0;z-index:10}.history-table th{background:linear-gradient(180deg,#f8fafc,#f1f5f9);background:linear-gradient(to bottom,var(--color-bg-secondary,#f8fafc),var(--color-bg-tertiary,#f1f5f9));border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--color-border,#e2e8f0);color:#475569;color:var(--color-text-secondary,#475569);font-size:11px;font-weight:600;letter-spacing:.6px;padding:14px 16px;text-align:center;text-transform:uppercase;white-space:nowrap}.th-date{text-align:center;width:130px}.th-time{text-align:center;width:140px}.th-break{text-align:center;width:150px}.th-hours{text-align:center;width:110px}.th-location{text-align:center;width:140px}.th-status{text-align:center;width:120px}.th-time-content{align-items:center;display:flex;gap:6px;justify-content:center}.th-time-content svg{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.history-table td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--color-border-light,#f1f5f9);color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:14px;padding:12px 16px;transition:background-color .15s ease;vertical-align:middle}.history-row{border-left:4px solid #0000}.history-row:hover{background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc)}.history-row--even{background-color:#f8fafc80}.history-row--even:hover{background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc)}.history-row.completo{border-left-color:#10b981;border-left-color:var(--color-success,#10b981)}.history-row.incompleto,.history-row.sin_egreso{border-left-color:#f59e0b;border-left-color:var(--color-warning,#f59e0b)}.history-row.sin_ingreso,.history-row.sin_registro{border-left-color:#dc2626;border-left-color:var(--color-danger,#dc2626)}.history-row.feriado{border-left-color:#06b6d4;border-left-color:var(--color-info,#06b6d4)}.history-row.feriado_trabajado{border-left-color:#059669;border-left-color:var(--color-success-dark,#059669)}.history-row.vacacion{border-left-color:#06b6d4;border-left-color:var(--color-info,#06b6d4)}.history-row.ausencia{border-left-color:#9333ea}.td-date{font-weight:500;text-align:center}.date-text{color:#0f172a;color:var(--color-text-primary,#0f172a)}.td-time{font-family:Arboria,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;text-align:center}.time-block{align-items:center;display:flex;flex-direction:column;gap:4px}.time-actual{color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:14px;font-weight:600}.time-planned{align-items:center;border-radius:4px;border-radius:var(--radius-sm,4px);display:inline-flex;font-size:10px;font-weight:500;padding:2px 6px;width:-webkit-fit-content;width:fit-content}.time-planned.ontime{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);color:#047857;color:var(--color-success-dark,#047857)}.time-planned.early{background-color:#fffbeb;background-color:var(--color-warning-light,#fffbeb);color:#b45309;color:var(--color-warning-dark,#b45309)}.time-planned.late{background-color:#fef2f2;background-color:var(--color-danger-light,#fef2f2);color:#b91c1c;color:var(--color-danger-dark,#b91c1c)}.td-break{text-align:center}.break-value{color:#64748b;color:var(--color-text-secondary,#64748b);font-family:Arboria,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;white-space:nowrap}.td-hours{text-align:center}.hours-value{background-color:#e0f2fe;background-color:var(--color-primary-light,#e0f2fe);border-radius:9999px;border-radius:var(--radius-full,9999px);color:#1890ff;color:var(--color-primary,#1890ff);font-family:Arboria,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;font-weight:600;padding:4px 10px}.td-location{min-width:120px;text-align:center}.location-badge{align-items:center;background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);color:#64748b;color:var(--color-text-secondary,#64748b);display:inline-flex;font-size:12px;font-weight:500;gap:6px;padding:4px 10px}.location-badge svg{color:#94a3b8;color:var(--color-text-muted,#94a3b8);height:14px;width:14px}.location-badge--sm{font-size:11px;padding:2px 6px}.location-badge--sm svg{height:12px;width:12px}.location-floor-badge{background-color:#e0f2fe;background-color:var(--color-primary-light,#e0f2fe);border-radius:4px;border-radius:var(--radius-sm,4px);color:#1890ff;color:var(--color-primary,#1890ff);font-size:10px;font-weight:600;margin-left:4px;padding:2px 6px}.location-split{align-items:center;display:inline-flex;gap:4px;justify-content:center}.location-divider{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:12px}.td-status{text-align:center}.history-status-badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full,9999px);display:inline-flex;font-size:11px;font-weight:600;justify-content:center;letter-spacing:.3px;padding:5px 12px;text-transform:uppercase;white-space:nowrap}.history-status-badge.completo{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);color:#047857;color:var(--color-success-dark,#047857)}.history-status-badge.incompleto,.history-status-badge.sin_egreso{background-color:#fffbeb;background-color:var(--color-warning-light,#fffbeb);color:#b45309;color:var(--color-warning-dark,#b45309)}.history-status-badge.sin_ingreso,.history-status-badge.sin_registro{background-color:#fef2f2;background-color:var(--color-danger-light,#fef2f2);color:#b91c1c;color:var(--color-danger-dark,#b91c1c)}.history-status-badge.feriado{background-color:#ecfeff;background-color:var(--color-info-light,#ecfeff);color:#0891b2;color:var(--color-info-dark,#0891b2)}.history-status-badge.feriado_trabajado{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);color:#059669;color:var(--color-success-dark,#059669)}.history-status-badge.vacacion{background-color:#ecfeff;background-color:var(--color-info-light,#ecfeff);color:#0891b2;color:var(--color-info-dark,#0891b2)}.history-status-badge.ausencia{background-color:#f3e8ff;color:#7c3aed}.location-cell{min-width:150px}.location-pair{display:flex;flex-direction:column;gap:4px;margin-bottom:4px}.location-pair:last-child{margin-bottom:0}.location-type{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:11px;font-weight:500;letter-spacing:.3px;text-transform:uppercase}.location-value{font-size:13px}.location-value--with-icon{align-items:center;display:inline-flex;gap:6px}.location-value--with-icon svg{color:#64748b;color:var(--color-text-secondary,#64748b);flex-shrink:0}.location-floor{color:var(--color-text-muted,#94a3b8);font-size:11px}.status-cell .status-badge{align-items:center;border:1px solid;border-radius:9999px;border-radius:var(--radius-full,9999px);display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:4px 10px}.status-badge.completo{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);border-color:#10b981;border-color:var(--color-success,#10b981);color:#10b981;color:var(--color-success,#10b981)}.status-badge.incompleto{background-color:#fffbeb;background-color:var(--color-warning-light,#fffbeb);border-color:#f59e0b;border-color:var(--color-warning,#f59e0b);color:#f59e0b;color:var(--color-warning,#f59e0b)}.status-badge.sin_ingreso{background-color:#fef2f2;background-color:var(--color-danger-light,#fef2f2);border-color:#dc2626;border-color:var(--color-danger,#dc2626);color:#dc2626;color:var(--color-danger,#dc2626)}.status-badge.vacacion{background-color:#ecfeff;background-color:var(--color-info-light,#ecfeff);border-color:#06b6d4;border-color:var(--color-info,#06b6d4);color:#06b6d4;color:var(--color-info,#06b6d4)}.status-badge.ausencia{background-color:#f3e8ff;border-color:#9333ea;color:#9333ea}.status-badge.feriado{background-color:#ecfeff;background-color:var(--color-info-light,#ecfeff);border-color:#0891b2;border-color:var(--color-info-dark,#0891b2);color:#0891b2;color:var(--color-info-dark,#0891b2)}.status-badge.feriado_trabajado{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);border-color:#059669;border-color:var(--color-success-dark,#059669);color:#059669;color:var(--color-success-dark,#059669)}.status-badge.sin_egreso{background-color:#fffbeb;background-color:var(--color-warning-light,#fffbeb);border-color:#f59e0b;border-color:var(--color-warning,#f59e0b);color:#f59e0b;color:var(--color-warning,#f59e0b)}.status-badge.sin_registro{background-color:#fef2f2;background-color:var(--color-danger-light,#fef2f2);border-color:#dc2626;border-color:var(--color-danger,#dc2626);color:#dc2626;color:var(--color-danger,#dc2626)}.time-comparison{display:flex;flex-direction:column;gap:4px}.time-with-status{display:flex;flex-direction:column;gap:2px}.actual-time{font-size:13px;font-weight:500}.planned-time{border:1px solid;border-radius:4px;border-radius:var(--radius-sm,4px);font-size:11px;padding:2px 8px;width:-webkit-fit-content;width:fit-content}.planned-time.ontime{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);border-color:#10b981;border-color:var(--color-success,#10b981);color:#10b981;color:var(--color-success,#10b981)}.planned-time.early{background-color:#fffbeb;background-color:var(--color-warning-light,#fffbeb);border-color:#f59e0b;border-color:var(--color-warning,#f59e0b);color:#f59e0b;color:var(--color-warning,#f59e0b)}.planned-time.late{background-color:#fef2f2;background-color:var(--color-danger-light,#fef2f2);border-color:#dc2626;border-color:var(--color-danger,#dc2626);color:#dc2626;color:var(--color-danger,#dc2626)}.history-cards-container{display:flex;flex-direction:column;gap:12px}.history-card{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);padding:16px}.history-card.completo{border-left:3px solid #10b981;border-left:3px solid var(--color-success,#10b981)}.history-card.incompleto{border-left:3px solid #f59e0b;border-left:3px solid var(--color-warning,#f59e0b)}.history-card.sin_ingreso{border-left:3px solid #dc2626;border-left:3px solid var(--color-danger,#dc2626)}.card-header{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--color-border-light,#f1f5f9);display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.card-date{color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:15px;font-weight:600}.card-row{align-items:flex-start;display:flex;gap:8px;justify-content:space-between;margin-bottom:8px}.card-row:last-child{margin-bottom:0}.card-label{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:13px;font-weight:500;min-width:120px}.card-value{color:#0f172a;color:var(--color-text-primary,#0f172a);flex:1 1;font-size:14px;text-align:right}.card-value--location{align-items:center;display:flex;gap:6px;justify-content:flex-end}.card-value--location svg{color:#64748b;color:var(--color-text-secondary,#64748b)}.history-footer{border-top:1px solid #f1f5f9;border-top:1px solid var(--color-border-light,#f1f5f9);margin-top:24px;padding-top:20px;text-align:center}.history-load-more-btn{background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);color:#64748b;color:var(--color-text-secondary,#64748b);cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:all .2s ease}.history-load-more-btn:hover{background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);border-color:#94a3b8;border-color:var(--color-text-muted,#94a3b8);color:#0f172a;color:var(--color-text-primary,#0f172a)}.history-footer-note{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:13px;font-style:italic;margin:12px 0 0}.desktop-only{display:block}.mobile-only{display:none}@media (max-width:1024px){.attendance-container{padding:20px}.attendance-page-header__main{align-items:flex-start;flex-direction:column}.attendance-page-header__clock{align-items:center;flex-direction:row}.attendance-summary-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.attendance-container{padding:16px}.attendance-page-header__title{font-size:1.25rem}.attendance-clock__time{font-size:2rem}.attendance-page-header__status{align-items:flex-start;flex-direction:column}.attendance-actions{flex-direction:column;gap:12px}.attendance-action-btn{width:100%}.attendance-summary-grid,.history-stats-grid{grid-template-columns:1fr}.desktop-only{display:none}.mobile-only{display:block}}@media (max-width:480px){.attendance-container{padding:12px}.attendance-clock__time{font-size:36px}.attendance-action-btn{font-size:14px;padding:12px 20px}.card-label{font-size:12px;min-width:100px}.card-value{font-size:13px}}.team-attendance-container{max-width:1200px}.team-filters-card{background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:16px;border-radius:var(--radius-lg,16px);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm,0 1px 2px #0000000d);margin-bottom:24px;padding:20px}.team-filters-card .filter-group label{color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.team-filters-card .filter-input{background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:14px;padding:10px 14px;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease;width:100%}.team-filters-card .filter-input:focus{background-color:#fff;border-color:#1890ff;border-color:var(--color-primary,#1890ff);box-shadow:0 0 0 3px #1890ff1a;box-shadow:0 0 0 3px var(--color-primary-light,#1890ff1a);outline:none}.team-filters-card .filter-reset-button{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:9999px;border-radius:var(--radius-full,9999px);color:#0f172a;color:var(--color-text-primary,#0f172a);cursor:pointer;font-size:13px;font-weight:600;padding:8px 14px;transition:border-color .2s ease,color .2s ease,background .2s ease}.team-filters-card .filter-reset-button:hover{border-color:#1890ff;border-color:var(--color-primary,#1890ff);color:#1890ff;color:var(--color-primary,#1890ff)}.team-table-container{border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);margin-top:16px;overflow:hidden}.metrics-grid{margin-bottom:8px;margin-top:24px}.metric-card{background-color:#fff;border:1px solid var(--color-border,#e2e8f0);border-radius:16px;border-radius:var(--radius-lg,16px);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm,0 1px 2px #0000000d);height:100%;width:100%}.metric-card .metric-value{color:#0f172a;color:var(--color-text-primary,#0f172a);font-weight:600;margin:8px 0}.metric-card .metric-helper{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:.9rem}:root{--auth-page-bg:#f5f7fb;--auth-card-shadow:0 20px 50px #0f172a14;--auth-card-radius:16px;--auth-primary:#007bff;--auth-primary-dark:#0062d1;--auth-text:#1f2937;--auth-text-muted:#4b5563;--auth-border:#e5e7eb}.auth-page{align-items:center;background:#f5f7fb;background:var(--auth-page-bg);display:flex;justify-content:center;min-height:100vh;padding:40px 16px}.auth-card{background:#fff;border-radius:16px;border-radius:var(--auth-card-radius);box-shadow:0 20px 50px #0f172a14;box-shadow:var(--auth-card-shadow);max-width:480px;padding:40px;width:100%}@media (max-width:640px){.auth-card{padding:28px}}.auth-header{margin-bottom:24px;text-align:center}.auth-header-icon{color:#007bff;color:var(--auth-primary);margin-bottom:12px}.auth-header h1{color:#1f2937;color:var(--auth-text);font-size:24px;font-weight:600;margin-bottom:8px}.auth-header p{color:#4b5563;color:var(--auth-text-muted);font-size:14px;margin:0}.auth-form{gap:20px}.auth-form,.auth-form .form-group{display:flex;flex-direction:column}.auth-form .form-group{gap:8px}.auth-form label{color:#1f2937;color:var(--auth-text);font-size:14px;font-weight:500}.auth-form input{border:1px solid #e5e7eb;border:1px solid var(--auth-border);border-radius:8px;font-size:14px;padding:12px;transition:border-color .2s ease,box-shadow .2s ease}.auth-form input:focus{border-color:#007bff;border-color:var(--auth-primary);box-shadow:0 0 0 3px #007bff26;outline:none}.auth-form input:disabled{background-color:#f8fafc;cursor:not-allowed}.auth-primary-button{align-items:center;background:#007bff;background:var(--auth-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:12px;text-align:center;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;width:100%}.auth-primary-button:hover:not(:disabled){box-shadow:0 10px 20px #007bff40;transform:translateY(-1px)}.auth-primary-button:disabled{cursor:not-allowed;opacity:.65}.auth-link{align-items:center;color:#007bff;color:var(--auth-primary);display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;text-decoration:none;transition:color .2s ease}.auth-link:hover{color:#0062d1;color:var(--auth-primary-dark)}a.auth-primary-button{text-decoration:none}.auth-icon-wrapper{display:flex;justify-content:center;margin-bottom:24px}.auth-icon-wrapper .success-icon{color:#38a169}.auth-icon-wrapper .error-icon{color:#e53e3e}.auth-status-text{color:#4b5563;color:var(--auth-text-muted);line-height:1.5;margin-bottom:16px;text-align:center}.first-login-page{padding:48px 16px}.first-login-card{max-width:500px;padding:40px}.first-login-form{display:flex;flex-direction:column;gap:20px}.success-message{align-items:center;background-color:#ecfdf5;border:1px solid #a7f3d0;border-radius:6px;color:#047857;display:flex;font-size:14px;gap:8px;padding:12px}.form-group label{color:var(--auth-text)}.password-input-wrapper input:disabled{cursor:not-allowed}.password-requirements{background-color:#f8fafc;border:1px solid #e5e7eb}@media (max-width:640px){.first-login-card{padding:28px}}.forgot-password-page{padding:48px 16px}.forgot-password-card{max-width:420px;padding:36px}.forgot-password-form .form-group label{color:var(--auth-text)}.forgot-password-form .form-group input::placeholder{color:#9ca3af}.forgot-password-form .form-group input:focus{border-color:var(--auth-primary);box-shadow:0 0 0 3px #007bff1f}.forgot-password-form .form-group input:disabled{background-color:#f5f7fb}.back-link svg{color:inherit}.login-container{align-items:center;background:#f8fafc;display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{animation:fadeInUp .6s ease;background:#fff;border:1px solid #0000000d;border-radius:12px;box-shadow:0 4px 12px #0000001a,0 2px 6px #0000000f;max-width:400px;padding:40px;width:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{margin-bottom:32px;text-align:center}.login-logo{height:48px;margin-bottom:16px;width:auto}.login-header h1{color:#1e293b;font-size:28px;font-weight:700;letter-spacing:-.025em;margin-bottom:8px}.login-header p{color:#64748b;font-size:14px;font-weight:500}.login-form{margin-bottom:32px}.required{color:#dc2626}.form-input{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#1e293b;font-size:14px;padding:12px 16px;transition:all .2s ease;width:100%}.form-input::placeholder{color:#94a3b8}.form-input:focus{border-color:#64748b;box-shadow:0 0 0 2px #64748b1a;outline:none}.form-input.error{border-color:#dc2626;box-shadow:0 0 0 2px #dc26261a}.error-message{background-color:#fef2f2;font-size:13px;font-weight:500;margin-top:6px;padding:8px 12px}.alert{margin-bottom:16px}.login-button{align-items:center;background:#1e293b;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;letter-spacing:normal;padding:12px 16px;text-transform:none;transition:all .2s ease;width:100%}.login-button:hover:not(:disabled){background:#334155;box-shadow:0 4px 12px #1e293b26,0 2px 6px #1e293b1a;transform:translateY(-1px)}.login-button:disabled{background:#cbd5e1;box-shadow:none;color:#94a3b8;cursor:not-allowed;transform:none}.spinner{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;height:16px;width:16px}.forgot-password-link{margin-top:16px;text-align:center}.forgot-password-link a{color:#667eea;font-size:14px;font-weight:500;text-decoration:none;transition:color .2s}.forgot-password-link a:hover{color:#764ba2;text-decoration:underline}.login-footer{margin-top:24px;text-align:center}.login-footer p{color:#64748b;font-size:13px;line-height:1.4}@media (max-width:480px){.login-container{padding:16px}.login-card{padding:32px 24px}.login-header h1{font-size:24px}.login-form,.login-header{margin-bottom:24px}}@media (max-width:360px){.login-card{padding:24px 20px}}.reset-password-page{padding:48px 16px}.reset-password-card{max-width:500px;padding:40px}.reset-password-form .form-group label{color:var(--auth-text)}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:14px;gap:8px;padding:12px}.form-group{gap:8px}.password-input-wrapper input{border:1px solid #e2e8f0;padding:12px 40px 12px 12px;transition:border-color .2s}.password-input-wrapper input:focus{border-color:var(--auth-primary)}.password-input-wrapper input:disabled{background-color:#f5f7fb}.toggle-password{color:#718096;right:12px}.toggle-password:hover{color:#2d3748}.field-error{color:#e53e3e;font-size:12px;margin-top:-4px}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:8px;padding:12px;transition:transform .2s,box-shadow .2s;width:100%}.submit-button:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{cursor:not-allowed;opacity:.6}.back-link{color:#667eea;display:block;font-size:14px;font-weight:500;text-align:center;text-decoration:none;transition:color .2s}.back-link:hover{color:#764ba2}.error-icon-wrapper,.success-icon-wrapper{display:flex;justify-content:center;margin-bottom:24px}.success-icon{color:#38a169}.error-icon{color:#e53e3e}.reset-password-card h1{color:#1a202c;font-size:24px;font-weight:600;margin-bottom:16px;text-align:center}.error-text,.success-message{color:#2d3748;font-size:14px;line-height:1.6;margin-bottom:16px;text-align:center}.success-note{color:#718096;font-size:13px;line-height:1.5;margin-bottom:24px;text-align:center}.action-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;display:block;font-size:16px;font-weight:600;padding:12px;text-align:center;text-decoration:none;transition:transform .2s,box-shadow .2s;width:100%}.action-button:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}@media (max-width:640px){.reset-password-card{padding:24px}.reset-password-card h1,.reset-password-header h1{font-size:20px}.error-icon,.header-icon,.success-icon{height:40px;width:40px}}.area-management{margin:0 auto;max-width:1200px;padding:20px}.area-header{align-items:center;border-bottom:2px solid #e5e7eb;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.area-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.area-new-btn{align-items:center;background:#3b82f6;border:1px solid #0000;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.area-new-btn:hover{background:#2563eb}.area-management.loading{color:#666;font-size:18px;padding:50px;text-align:center}.area-form-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.area-form{background:#fff;border-radius:8px;max-height:80vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}.area-form h3{color:#333;margin-bottom:25px;margin-top:0;text-align:center}.areas-list{margin-top:16px}.no-areas{background-color:#f8f9fa;border-radius:8px;color:#666;font-size:16px;padding:50px;text-align:center}.areas-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.area-card{background:#fff;border:1px solid #e2e8f0;border-left:4px solid #cbd5e1;border-radius:12px;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;gap:14px;padding:20px;transition:box-shadow .2s ease,transform .2s ease}.area-card:hover{box-shadow:0 4px 12px #0000001a;transform:scale(1.01)}.area-card-body{display:flex;flex-direction:column;gap:4px}.area-card-label{color:#94a3b8;font-size:.75rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.area-card-name{color:#1e293b;font-size:1.25rem;font-weight:700;line-height:1.3;margin:4px 0 0}.area-card-empresa{color:#64748b;font-size:.875rem;line-height:1.4;margin:0}.area-card-meta{display:flex;flex-direction:column;gap:6px;margin-top:10px}.area-card-meta-item{align-items:center;color:#475569;display:flex;flex-wrap:wrap;font-size:.8125rem;gap:6px}.area-card-meta-label{color:#94a3b8;font-size:.75rem;font-weight:500;letter-spacing:.03em;min-width:60px;text-transform:uppercase}.area-card-meta-item strong{color:#1e293b;font-weight:500}.meta-warning{color:#dc2626;font-size:.7rem;font-weight:600;margin-left:4px}.area-card-footer{align-items:center;display:flex;gap:16px;margin-top:8px}.area-card-status{align-items:center;display:flex;gap:6px}.area-status-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.area-status-dot.is-active{background-color:#22c55e}.area-status-dot.is-inactive{background-color:#ef4444}.area-status-text{color:#64748b;font-size:.75rem;font-weight:500}.area-card-actions{align-items:center;border-top:1px solid #f1f5f9;display:flex;gap:12px;justify-content:flex-end;padding-top:12px}.area-action-btn{align-items:center;background:none;border:none;color:#64748b;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:500;gap:6px;padding:0;transition:color .15s ease}.area-action-btn:hover{color:#1e293b}.area-action-btn--danger:hover{color:#dc2626}.area-action-btn--success:hover{color:#059669}.area-field-note{color:#475569;display:block;font-size:.8125rem;margin-top:6px}.confirm-btn--danger{background:#fff6f6;border-color:#fecaca;color:#b91c1c}.confirm-btn--danger:hover{background:#fee2e2}@media (max-width:768px){.area-management{padding:15px}.area-header{align-items:stretch;flex-direction:column;gap:15px}.areas-grid{grid-template-columns:1fr}.area-form{padding:20px;width:95%}.form-actions{flex-direction:column}}.company-management{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:1200px;padding:20px}.company-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:10px;padding-bottom:16px}.company-header h2{color:#1f2937;margin:0}.company-header p{color:#4b5563;margin:4px 0 0}.company-header-actions{display:flex;gap:10px}.company-toolbar{align-items:center;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;display:flex;flex-wrap:wrap;gap:12px;padding:16px}.company-search{display:flex;flex:1 1;gap:8px;min-width:260px}.company-search input{border:1px solid #d1d5db;border-radius:8px;flex:1 1;padding:10px 12px}.company-toggle{align-items:center;color:#374151;display:inline-flex;font-size:14px;gap:8px}.company-placeholder{background:#f8fafc;border:1px dashed #d1d5db;border-radius:10px;color:#6b7280;padding:50px;text-align:center}.company-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.company-card{background:#fff;border:1px solid #e2e8f0;border-left:4px solid #cbd5e1;border-radius:12px;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;gap:14px;padding:20px;transition:box-shadow .2s ease,transform .2s ease}.company-card:hover{box-shadow:0 4px 12px #0000001a;transform:scale(1.01)}.company-card-actions{align-items:center;border-top:1px solid #f1f5f9;display:flex;gap:12px;justify-content:flex-end;padding-top:12px}.company-action-btn{align-items:center;background:none;border:none;color:#64748b;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:500;gap:6px;padding:0;transition:color .15s ease}.company-action-btn:hover{color:#1e293b}.company-action-btn--danger:hover{color:#dc2626}.company-action-disabled{color:#94a3b8;font-size:.8125rem;font-weight:500}.company-card-body{cursor:pointer;display:flex;flex-direction:column;gap:4px;outline:none}.company-card-body:focus-visible{border-radius:8px;box-shadow:0 0 0 3px #2563eb4d}.company-card-label{color:#94a3b8;font-size:.75rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.company-card-name{color:#1e293b;font-size:1.25rem;font-weight:700;line-height:1.3;margin:4px 0 0}.company-card-razon{color:#64748b;font-size:.875rem;line-height:1.4;margin:0}.company-card-footer{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-top:12px}.company-card-cuit{color:#475569;font-size:.8125rem;font-weight:500;letter-spacing:.02em}.company-card-status{align-items:center;display:flex;gap:6px}.company-status-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.company-status-dot.is-active{background-color:#22c55e}.company-status-dot.is-inactive{background-color:#ef4444}.company-status-text{color:#64748b;font-size:.75rem;font-weight:500}.company-card-note{background:#fff7ed;border-radius:8px;color:#9a3412;display:flex;flex-direction:column;font-size:.8125rem;gap:4px;margin-top:8px;padding:10px 12px}.btn-secondary{border:1px solid #e5e7eb;border-radius:8px;color:#111827;padding:10px 16px}.btn-tertiary{background:#0000;border:1px dashed #d1d5db;border-radius:8px;color:#4b5563;padding:10px 16px}.btn-danger{background:#dc2626;border:none}.btn-disabled{background:#e5e7eb;color:#6b7280;cursor:not-allowed}.company-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a8c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.company-modal{background:#fff;border-radius:16px;box-shadow:0 30px 60px #0f172a40;display:flex;flex-direction:column;gap:20px;max-height:90vh;overflow-y:auto;padding:24px;width:min(560px,100%)}.company-modal-header{align-items:center;display:flex;justify-content:space-between}.company-modal-header h3{margin:0}.modal-close{color:#9ca3af}.company-confirm label,.company-form label{color:#111827;display:flex;flex-direction:column;font-weight:600;gap:6px}.company-confirm textarea,.company-form input,.company-form textarea{border:1px solid #d1d5db;border-radius:10px;font-size:14px;padding:10px 12px}.company-form .input-error{background:#fef2f2;border-color:#dc2626}.company-form .field-error{color:#dc2626;font-size:12px;margin-top:2px}.company-form .field-hint{color:#6b7280;font-size:12px;margin-top:2px}.company-modal-actions{display:flex;gap:12px;justify-content:flex-end}.company-detail{color:#1f2937;display:flex;flex-direction:column;gap:10px}.company-confirm p{color:#1f2937;margin:0 0 10px}.company-confirm-highlight{color:#111827;font-size:16px;font-weight:600}@media (max-width:768px){.company-header{flex-direction:column}.company-header-actions{justify-content:space-between;width:100%}.company-toolbar{align-items:stretch}.company-search,.company-toolbar{flex-direction:column}.company-card-actions{justify-content:space-between}}.company-structure{margin:0 auto;max-width:1400px;padding:20px}.structure-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:15px}.structure-header h2{color:#333;margin:0}.structure-actions{display:flex;gap:10px}.company-structure.loading{color:#666;font-size:18px;padding:50px;text-align:center}.org-summary{margin-bottom:30px}.summary-card{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.summary-card h3{color:#333;font-size:18px;margin:0 0 15px}.summary-stats{display:flex;gap:30px}.stat-item{text-align:center}.stat-number{color:#007bff;display:block;margin-bottom:5px}.stat-label{color:#666;font-size:14px}.org-hierarchy{background:#fff;border:1px solid #ddd;border-radius:8px;overflow:hidden}.no-structure{color:#666;padding:50px;text-align:center}.no-structure p{margin:10px 0}.hierarchy-tree{padding:0}.area-node{border-bottom:1px solid #f0f0f0}.area-node:last-child{border-bottom:none}.area-header{align-items:flex-start;cursor:pointer;display:flex;padding:15px 20px;transition:background-color .2s}.area-header:hover{background-color:#f8f9fa}.area-info{align-items:flex-start;display:flex;width:100%}.expand-icon{color:#666;font-size:12px;margin-right:10px;margin-top:2px;transition:transform .2s;-webkit-user-select:none;user-select:none}.expand-icon.expanded{transform:rotate(90deg)}.area-details{flex:1 1}.area-details h4{color:#333;font-size:16px;margin:0 0 5px}.area-details p{color:#666;font-size:14px;line-height:1.4;margin:0 0 10px}.area-stats{display:flex;flex-wrap:wrap;gap:15px}.stat{background-color:#f8f9fa;border-radius:12px;color:#888;font-size:12px;padding:2px 8px}.area-node.level-1 .area-header{background-color:#fafafa;padding-left:40px}.area-node.level-2 .area-header{background-color:#f5f5f5;padding-left:60px}.area-node.level-3 .area-header{background-color:#f0f0f0;padding-left:80px}.area-content{background-color:#fafafa;border-top:1px solid #e9ecef}.team-node{background-color:#f8f9fa;border-bottom:1px solid #e9ecef;padding:12px 20px 12px 50px}.team-node:last-child{border-bottom:none}.team-info h5{color:#495057;font-size:14px;margin:0 0 5px}.team-info p{color:#6c757d;font-size:13px;line-height:1.3;margin:0 0 8px}.team-stats{display:flex;flex-wrap:wrap;gap:12px}.team-stats .stat{background-color:#e9ecef;font-size:11px}.btn-secondary{font-size:13px;padding:8px 16px}@media (max-width:768px){.company-structure{padding:15px}.structure-header{align-items:stretch;flex-direction:column;gap:15px}.structure-actions,.summary-stats{flex-wrap:wrap;justify-content:center}.summary-stats{gap:20px}.area-header{padding:12px 15px}.area-node.level-1 .area-header{padding-left:30px}.area-node.level-2 .area-header{padding-left:45px}.area-node.level-3 .area-header{padding-left:60px}.team-node{padding-left:40px}.area-stats,.team-stats{flex-direction:column;gap:5px}}.organization-chart{--org-bg:#f0f4f8;--org-surface:#fff;--org-surface-subtle:#f7f9fc;--org-border:#e1e6ef;--org-border-strong:#c4cdd9;--org-line:#c4cdd9;--org-text-primary:#1a2332;--org-text-secondary:#5a6a7e;--org-text-muted:#8d99ab;--org-radius:10px;--org-shadow:0 2px 8px #00000012;--org-shadow-hover:0 4px 16px #0000001a;--org-role-director:#2563eb;--org-role-manager:#0891b2;--org-role-leader:#ea580c;--org-role-member:#6d28d9;background:var(--org-bg);box-sizing:border-box;color:var(--org-text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;min-height:100vh;padding:32px 24px}.organization-header{align-items:center;background:var(--org-surface);border:1px solid var(--org-border);border-radius:var(--org-radius);box-shadow:var(--org-shadow);display:flex;flex-direction:column;gap:10px;margin-bottom:32px;padding:24px;text-align:center}.organization-header h1{color:var(--org-text-primary);font-size:1.5rem;font-weight:700;margin:0}.organization-header p{font-size:.9rem}.org-config-hint,.organization-header p{color:var(--org-text-secondary);margin:0}.org-config-hint{background:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;font-size:.82rem;padding:10px 14px}.org-config-btn-header{margin-top:10px}.org-chart-wrapper{background:var(--org-surface);border:1px solid var(--org-border);border-radius:var(--org-radius);box-shadow:var(--org-shadow);overflow-x:auto;padding:40px 24px}.org-chart-static,.org-level{align-items:center;display:flex;flex-direction:column;gap:0;position:relative}.org-level{width:100%}.org-level-title{background:var(--org-bg);border-radius:20px;color:var(--org-text-muted);font-size:.7rem;font-weight:700;letter-spacing:.15em;margin:0 0 16px;padding:2px 14px;text-transform:uppercase;z-index:2}.org-level-grid{gap:16px;position:relative}.org-director-blocks,.org-level-grid{display:flex;flex-wrap:wrap;justify-content:center}.org-director-blocks{gap:48px;width:100%}.org-director-block{align-items:stretch;display:flex;flex-direction:column}.org-director-block>.org-node-clickable{align-self:center}.org-director-areas{margin-top:0}.org-unassigned-areas{margin-top:32px}.org-area-grid{display:flex;gap:20px;justify-content:center;padding-top:24px;position:relative}.org-area-grid:before{background:var(--org-line);content:"";height:2px;left:10%;position:absolute;right:10%;top:0}.org-area-grid:has(>.org-area-column:only-child):before{left:50%;right:50%}.org-area-column{align-items:stretch;background:#0000;border:none;border-radius:0;display:flex;flex-direction:column;gap:0;padding-top:24px;position:relative}.org-area-column>.org-node-clickable{align-self:center}.org-area-column:before{background:var(--org-line);content:"";height:24px;left:50%;position:absolute;top:0;transform:translateX(-50%);width:2px}.org-area-column.is-collapsed{background:#0000}.org-node-clickable{align-items:center;cursor:pointer;display:flex;flex-direction:column;position:relative;-webkit-user-select:none;user-select:none}.org-node-clickable.has-children:after{background:var(--org-line);bottom:-24px;content:"";height:0;left:50%;position:absolute;transform:translateX(-50%);transition:height .35s ease;width:2px}.is-expanded>.org-node-clickable.has-children:after{height:24px}.org-node-toggle{align-items:center;background:var(--org-surface);border:1px solid var(--org-border);border-radius:4px;color:var(--org-text-muted);display:inline-flex;font-size:.68rem;font-weight:600;gap:4px;margin-top:6px;padding:1px 10px;transition:color .2s,border-color .2s;z-index:2}.org-node-clickable:hover .org-node-toggle{border-color:var(--org-border-strong);color:var(--org-text-secondary)}.org-node-toggle-arrow{display:inline-block;transition:transform .35s ease}.is-expanded>.org-node-clickable .org-node-toggle-arrow{transform:rotate(180deg)}.org-expandable{display:grid;grid-template-rows:0fr;transition:grid-template-rows .4s ease}.is-expanded>.org-expandable,.org-expandable--open{grid-template-rows:1fr}.org-expandable-inner{overflow:hidden;padding-top:24px}.org-expandable-scroll{overflow-x:auto;overflow-y:hidden;scrollbar-color:var(--org-border-strong) #0000;scrollbar-width:thin}.org-expandable-scroll::-webkit-scrollbar{height:6px}.org-expandable-scroll::-webkit-scrollbar-track{background:#0000}.org-expandable-scroll::-webkit-scrollbar-thumb{background:var(--org-border-strong);border-radius:3px}.org-expandable-scroll::-webkit-scrollbar-thumb:hover{background:var(--org-text-muted)}.org-area-teams{display:flex;gap:24px;justify-content:center;margin-top:0;padding-top:24px;position:relative}.org-area-teams:before{background:var(--org-line);content:"";height:2px;left:50%;position:absolute;right:50%;top:0;transition:left .4s ease .15s,right .4s ease .15s}.is-expanded>.org-expandable .org-area-teams:before,.org-expandable--open .org-area-teams:before{left:10%;right:10%}.org-area-teams:has(>.org-team-column:only-child):before{left:50%;right:50%}.org-team-column{align-items:stretch;animation:org-card-appear .35s ease forwards;background:#0000;border:none;border-radius:0;display:flex;flex-direction:column;gap:0;opacity:0;padding:20px 0;position:relative;transform:translateY(-8px)}.org-team-column>.org-node-clickable{align-self:center}.org-area-teams .org-team-column:first-child{animation-delay:.1s}.org-area-teams .org-team-column:nth-child(2){animation-delay:.18s}.org-area-teams .org-team-column:nth-child(3){animation-delay:.26s}.org-area-teams .org-team-column:nth-child(n+4){animation-delay:.34s}.org-team-column:before{background:var(--org-line);content:"";height:20px;left:50%;position:absolute;top:0;transform:translateX(-50%);width:2px}.org-team-members{display:flex;gap:16px;justify-content:center;margin-top:0;padding-top:20px;position:relative}.org-team-members:before{background:var(--org-line);content:"";height:2px;left:50%;position:absolute;right:50%;top:0;transition:left .4s ease .15s,right .4s ease .15s}.is-expanded>.org-expandable .org-team-members:before,.org-expandable--open .org-team-members:before{left:10%;right:10%}.org-team-members .org-card{animation:org-card-appear .35s ease forwards;opacity:0;padding-top:24px;position:relative;transform:translateY(-8px)}.org-team-members .org-card:first-child{animation-delay:.15s}.org-team-members .org-card:nth-child(2){animation-delay:.2s}.org-team-members .org-card:nth-child(3){animation-delay:.25s}.org-team-members .org-card:nth-child(4){animation-delay:.3s}.org-team-members .org-card:nth-child(5){animation-delay:.35s}.org-team-members .org-card:nth-child(n+6){animation-delay:.4s}.org-team-members .org-card:before{background:var(--org-line);content:"";height:24px;left:50%;position:absolute;top:0;transform:translateX(-50%);width:2px}@keyframes org-card-appear{to{opacity:1;transform:translateY(0)}}.org-area-column.is-hidden-sibling,.org-director-block.is-hidden-sibling,.org-team-column.is-hidden-sibling{display:none}.org-area-grid:has(>.org-area-column.is-hidden-sibling):before{left:50%;right:50%}.org-area-teams:has(>.org-team-column.is-hidden-sibling):before{left:50%;right:50%}.org-empty-state{background:var(--org-surface-subtle);border:2px dashed var(--org-border);border-radius:var(--org-radius);color:var(--org-text-secondary);font-size:.95rem;padding:60px 20px;text-align:center}.org-card{align-items:center;background:var(--org-surface);border:1px solid var(--org-border);border-radius:12px;box-shadow:var(--org-shadow);display:flex;flex-direction:column;gap:8px;max-width:200px;min-width:150px;padding:20px 16px 16px;position:relative;text-align:center;transition:box-shadow .2s,transform .15s}.org-card:hover{box-shadow:var(--org-shadow-hover);transform:translateY(-1px)}.org-card.area,.org-card.type-team{max-width:180px;min-width:140px;padding:16px 20px}.org-card.area .org-card-name,.org-card.type-team .org-card-name{font-size:.82rem;font-weight:700}.org-card-avatar{align-items:center;background:#e8eaed;border-radius:50%;color:#9aa0a6;display:flex;flex-shrink:0;font-size:.95rem;font-weight:700;height:56px;justify-content:center;overflow:hidden;width:56px}.org-card-avatar img{border-radius:50%;height:100%;object-fit:cover;width:100%}.org-card-body{align-items:center;display:flex;flex-direction:column;gap:2px;min-width:0}.org-card-name{color:var(--org-text-primary);font-size:.78rem;font-weight:700;letter-spacing:.02em;line-height:1.3;text-transform:uppercase}.org-card-role{color:var(--org-text-secondary);font-size:.73rem;line-height:1.3}.org-card-area{color:var(--org-text-muted);font-size:.7rem}.org-card-badge{display:none}.org-card.size-compact{gap:6px;padding:14px 12px 10px}.org-card.size-compact .org-card-avatar{font-size:.8rem;height:44px;width:44px}.org-card.size-extended{gap:10px;padding:24px 20px 18px}.org-card.size-extended .org-card-avatar{font-size:1.05rem;height:64px;width:64px}.org-card.size-extended .org-card-name{font-size:.85rem}.error-message,.loading{align-items:center;background:var(--org-surface);border:1px solid var(--org-border);border-radius:var(--org-radius);box-shadow:var(--org-shadow);color:var(--org-text-secondary);display:flex;flex-direction:column;justify-content:center;min-height:220px}.loading .spinner{animation:org-spin .7s linear infinite;border:3px solid var(--org-border);border-radius:50%;border-top-color:var(--org-role-director);height:40px;margin-bottom:14px;width:40px}@keyframes org-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.org-config-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a33;inset:0;position:fixed;z-index:980}.org-config-panel{background:var(--org-surface);border-left:1px solid var(--org-border);bottom:0;box-shadow:-4px 0 24px #00000014;display:flex;flex-direction:column;gap:20px;overflow-y:auto;padding:24px;position:fixed;right:0;top:0;width:320px;z-index:990}.org-config-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.org-config-header h3{color:var(--org-text-primary);font-size:1.05rem;font-weight:700;margin:0}.org-config-close{align-items:center;background:var(--org-surface);border:1px solid var(--org-border);border-radius:8px;color:var(--org-text-secondary);cursor:pointer;display:inline-flex;font-size:.85rem;height:32px;justify-content:center;transition:background-color .2s,color .2s;width:32px}.org-config-close:hover{background:var(--org-surface-subtle);color:var(--org-text-primary)}.org-config-content{display:flex;flex-direction:column;gap:20px}.org-config-section{display:flex;flex-direction:column;gap:10px}.org-config-section h4{color:var(--org-text-muted);font-size:.8rem;font-weight:700;letter-spacing:.1em;margin:0;text-transform:uppercase}.org-config-checkboxes{display:flex;flex-direction:column;gap:8px}.org-config-checkboxes label{align-items:center;color:var(--org-text-secondary);cursor:pointer;display:flex;font-size:.9rem;gap:10px}.org-config-checkboxes input[type=checkbox]{accent-color:var(--org-role-director);height:16px;width:16px}.org-config-select{background:var(--org-surface);border:1px solid var(--org-border);border-radius:8px;color:var(--org-text-primary);font-size:.9rem;padding:8px 12px}.org-config-help{color:var(--org-text-muted);font-size:.78rem}.org-config-layouts{display:flex;flex-direction:column;gap:8px}.org-config-layout-option{align-items:flex-start;background:var(--org-surface-subtle);border:1px solid var(--org-border);border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:12px;transition:border-color .2s}.org-config-layout-option input{accent-color:var(--org-role-director);margin-top:2px}.org-config-layout-option:hover{border-color:var(--org-role-director)}.org-config-layout-info strong{color:var(--org-text-primary);display:block;font-size:.88rem;margin-bottom:2px}.org-config-layout-info span{color:var(--org-text-secondary);font-size:.8rem}.org-config-actions{display:flex;flex-direction:column;gap:8px}.org-config-actions .org-action-btn{width:100%}.org-action-btn{align-items:center;background:var(--org-surface);border:1px solid var(--org-border);border-radius:8px;color:var(--org-text-secondary);cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:600;gap:6px;justify-content:center;padding:8px 16px;transition:all .2s}.org-action-btn:hover:not(:disabled){background:var(--org-surface-subtle);border-color:var(--org-role-director);box-shadow:0 2px 8px #2563eb1a;color:var(--org-role-director)}.org-action-btn:disabled{cursor:not-allowed;opacity:.5}.org-standalone{border-top:2px solid var(--org-border);margin-top:32px;padding-top:24px}.org-standalone .org-level-grid{gap:16px}@media (max-width:768px){.organization-chart{padding:16px 12px}.org-chart-wrapper{padding:20px 12px}.org-director-blocks{gap:32px}.org-area-grid,.org-director-blocks{align-items:center;flex-direction:column}.org-area-column:before,.org-area-grid:before{display:none}.org-area-teams{align-items:center;flex-direction:column}.org-area-teams:before,.org-team-column:before{display:none}.org-team-members{flex-wrap:wrap}.org-config-panel{width:100%}.org-level-grid{align-items:center;flex-direction:column}}.confirm-btn{font-family:inherit}.confirm-btn:hover{background:#f8fafc}.confirm-btn--success{border-color:#bbf7d0}.confirm-btn--warning{background:#fee2e2;border-color:#fecaca;color:#991b1b}.puesto-management{margin:0 auto;max-width:1400px;padding:24px}.puesto-management.loading{color:#64748b;font-size:16px;padding:48px;text-align:center}.puesto-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.puesto-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.btn-new-puesto{align-items:center;background:#3b82f6;border:1px solid #0000;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.btn-new-puesto:hover{background:#2563eb}.puesto-list{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.no-puestos{color:#64748b;font-size:14px;padding:48px;text-align:center}.puesto-table{border-collapse:collapse;width:100%}.puesto-table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.puesto-table th{color:#64748b;font-size:12px;font-weight:500;letter-spacing:.5px;padding:14px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.puesto-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s ease}.puesto-table tbody tr:hover{background:#f8fafc}.puesto-table tbody tr:last-child{border-bottom:none}.puesto-table td{color:#0f172a;font-size:14px;padding:14px 12px;vertical-align:middle}.puesto-table td strong{color:#0f172a;font-weight:500}.badge-estado{align-items:center;border-radius:9999px;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.3px;padding:4px 10px;text-transform:uppercase}.badge-estado.activo{background:#ecfdf5;color:#10b981}.badge-estado.inactivo{background:#fef2f2;color:#dc2626}.puesto-table td.actions-column{min-width:80px;text-align:center;width:80px}.puesto-actions{display:flex;gap:8px;justify-content:center}.puesto-action-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;display:inline-flex;justify-content:center;padding:6px 8px;transition:all .2s ease}.puesto-action-btn:hover:not(:disabled){background:#f9fafb}.puesto-action-btn:disabled{cursor:not-allowed;opacity:.4}.puesto-action-btn--edit{color:#3b82f6}.puesto-action-btn--edit:hover:not(:disabled){background:#eff6ff;border-color:#3b82f6}.puesto-action-btn--deactivate{color:#ef4444}.puesto-action-btn--deactivate:hover:not(:disabled){background:#fef2f2;border-color:#ef4444}.puesto-action-btn--activate{color:#10b981}.puesto-action-btn--activate:hover:not(:disabled){background:#ecfdf5;border-color:#10b981}.pagination{align-items:center;display:flex;gap:16px;justify-content:center;margin-top:24px}.btn-pagination{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.btn-pagination:hover:not(:disabled){background:#f9fafb;border-color:#3b82f6}.btn-pagination:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.pagination-info{color:#64748b;font-size:14px}.modal-content{box-shadow:0 20px 25px -5px #0000001a;max-width:520px;width:100%}.modal-header{border-bottom:1px solid #e5e7eb}.btn-close{align-items:center;background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;font-size:24px;height:28px;justify-content:center;padding:0;transition:all .2s ease;width:28px}.btn-close:hover{background:#f3f4f6;color:#4b5563}.puesto-form{padding:16px 20px}.form-group{margin-bottom:12px}.form-group label{margin-bottom:4px}.form-group input,.form-group select,.form-group textarea{font-size:13px;padding:8px 10px;transition:all .2s ease}.form-group select:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.form-hint{color:#64748b;display:block}.form-actions{margin-top:16px}.btn-cancel,.btn-submit{align-items:center;display:inline-flex;font-family:inherit;font-size:.875rem;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.btn-cancel{background:#fff;border:1px solid #d1d5db;color:#4b5563}.btn-cancel:hover{background:#f9fafb}.btn-submit{border:none}.btn-submit:hover{background-color:#2563eb}@media (max-width:768px){.puesto-management{padding:16px}.puesto-header{align-items:flex-start;flex-direction:column;gap:12px}.btn-new-puesto{justify-content:center;width:100%}.puesto-table{font-size:13px}.puesto-table td,.puesto-table th{padding:8px 12px}.modal-content{max-width:100%}}.team-management{margin:0 auto;max-width:1200px;padding:20px}.team-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.team-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.team-new-btn{align-items:center;background:#3b82f6;border:1px solid #0000;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.team-new-btn:hover{background:#2563eb}.team-management.loading{color:#666;font-size:18px;padding:50px;text-align:center}.error-message{background-color:#ffe6e6;border-left:4px solid #d00;border-radius:5px;color:#d00;margin-bottom:20px;padding:15px}.team-form-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.team-form{background:#fff;border-radius:8px;max-height:80vh;max-width:600px;overflow-y:auto;padding:30px;width:90%}.team-form h3{color:#333;margin-bottom:25px;margin-top:0;text-align:center}.form-group label{color:#555;font-weight:700}.form-group input,.form-group select,.form-group textarea{border-radius:4px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{box-shadow:0 0 5px #007bff4d}.form-actions{border-top:1px solid #eee;margin-top:30px}.btn-secondary{border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .2s}.btn-secondary:hover{background-color:#545b62}.btn-edit{background-color:#28a745;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;margin-right:5px;padding:6px 12px}.btn-edit:hover{background-color:#218838}.btn-delete{background-color:#dc3545;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;padding:6px 12px}.btn-delete:hover{background-color:#c82333}.teams-list{margin-top:16px}.no-teams{background-color:#f8f9fa;border-radius:8px;color:#666;font-size:16px;padding:50px;text-align:center}.teams-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.team-card{background:#fff;border:1px solid #e2e8f0;border-left:4px solid #cbd5e1;border-radius:12px;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;gap:14px;padding:20px;transition:box-shadow .2s ease,transform .2s ease}.team-card:hover{box-shadow:0 4px 12px #0000001a;transform:scale(1.01)}.team-card-body{display:flex;flex-direction:column;gap:4px}.team-card-label{color:#94a3b8;font-size:.75rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.team-card-name{color:#1e293b;font-size:1.25rem;font-weight:700;line-height:1.3;margin:4px 0 0}.team-card-desc{color:#64748b;font-size:.875rem;line-height:1.4;margin:2px 0 0}.team-card-meta{display:flex;flex-direction:column;gap:6px;margin-top:10px}.team-card-meta-item{align-items:center;color:#475569;display:flex;flex-wrap:wrap;font-size:.8125rem;gap:6px}.team-card-meta-label{color:#94a3b8;font-size:.75rem;font-weight:500;letter-spacing:.03em;min-width:60px;text-transform:uppercase}.team-card-meta-item strong{color:#1e293b;font-weight:500}.team-card-footer{align-items:center;display:flex;gap:16px;margin-top:8px}.team-card-status{align-items:center;display:flex;gap:6px}.team-status-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.team-status-dot.is-active{background-color:#22c55e}.team-status-dot.is-inactive{background-color:#ef4444}.team-status-text{color:#64748b;font-size:.75rem;font-weight:500}.team-card-actions{align-items:center;border-top:1px solid #f1f5f9;display:flex;gap:12px;justify-content:flex-end;padding-top:12px}.team-action-btn{align-items:center;background:none;border:none;color:#64748b;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:500;gap:6px;padding:0;transition:color .15s ease}.team-action-btn:hover{color:#1e293b}.team-action-btn--danger:hover{color:#dc2626}.team-action-btn--success:hover{color:#059669}.confirm-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a59;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1100}.confirm-modal{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 25px 50px -12px #0f172a40;padding:24px;width:min(360px,100%)}.confirm-modal h4{color:#0f172a;font-size:1.05rem;margin:0 0 10px}.confirm-modal p{color:#475569;font-size:.9375rem;line-height:1.5;margin:0 0 18px}.confirm-modal strong{color:#0f172a}.confirm-actions{display:flex;gap:10px;justify-content:flex-end}.confirm-btn{background:#fff;border:1px solid #e2e8f0;border-radius:999px;color:#0f172a;cursor:pointer;font-size:.875rem;font-weight:600;padding:8px 16px;transition:background .2s}.confirm-btn:hover{background:#f1f5f9}.confirm-btn--warning{background:#fef3c7;border-color:#fde68a;color:#92400e}.confirm-btn--warning:hover{background:#fde68a}.confirm-btn--success{background:#d1fae5;border-color:#a7f3d0;color:#065f46}.confirm-btn--success:hover{background:#a7f3d0}@media (max-width:768px){.team-management{padding:15px}.team-header{align-items:stretch;flex-direction:column;gap:15px}.teams-grid{grid-template-columns:1fr}.team-form{padding:20px;width:95%}.form-actions{flex-direction:column}}.confirm-dialog-overlay{align-items:center;animation:confirm-fade-in .15s ease-out;background:#0f172a80;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1500}@keyframes confirm-fade-in{0%{opacity:0}to{opacity:1}}.confirm-dialog{animation:confirm-scale-in .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 50px #0003;max-width:420px;overflow:hidden;width:100%}@keyframes confirm-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.confirm-dialog__header{padding:20px 24px 0}.confirm-dialog__title{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.confirm-dialog__body{padding:16px 24px 24px}.confirm-dialog__message{color:#64748b;font-size:.9375rem;line-height:1.5;margin:0}.confirm-dialog__actions{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.confirm-dialog__btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.confirm-dialog__btn:focus{box-shadow:0 0 0 3px #2563eb33;outline:none}.confirm-dialog__btn--cancel{background:#fff;border-color:#e2e8f0;color:#64748b}.confirm-dialog__btn--cancel:hover{background:#f1f5f9;border-color:#cbd5e1;color:#475569}.confirm-dialog__btn--primary{background:#3b82f6;color:#fff}.confirm-dialog__btn--primary:hover{background:#2563eb}.confirm-dialog__btn--error{background:#dc2626;border-color:#dc2626;color:#fff}.confirm-dialog__btn--error:hover{background:#b91c1c;border-color:#b91c1c}.confirm-dialog__btn--warning{background:#f59e0b;border-color:#f59e0b;color:#fff}.confirm-dialog__btn--warning:hover{background:#d97706;border-color:#d97706}.confirm-dialog__btn--success{background:#16a34a;border-color:#16a34a;color:#fff}.confirm-dialog__btn--success:hover{background:#15803d;border-color:#15803d}@media (max-width:480px){.confirm-dialog{margin:16px;max-width:none}.confirm-dialog__actions{flex-direction:column-reverse;gap:8px}.confirm-dialog__btn{justify-content:center;width:100%}}.dashboard{padding:24px 0;width:100%}.kpi-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:32px;padding:0 24px}@media (max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.kpi-grid{grid-template-columns:1fr;padding:0 16px}}.stats-bar{display:flex;gap:16px;margin-bottom:32px;padding:0 24px}.stat-card{align-items:center;background:#fff;border:1px solid #0000000d;border-radius:12px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;display:flex;flex:1 1;gap:16px;padding:20px;transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 12px #0000001a,0 2px 6px #0000000f;transform:translateY(-1px)}.stat-icon{background:#f8fafc;border-radius:10px;color:#64748b;flex-shrink:0;padding:12px}.stat-info{flex:1 1}.stat-number{color:#1e293b;font-size:24px;font-weight:700;line-height:1;margin-bottom:4px}.stat-label{color:#64748b;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.dashboard-content{padding:0 24px}.welcome-message{background:#fff;border:1px solid #0000000d;border-radius:12px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;padding:32px;text-align:center}.welcome-message h2{color:#1e293b;font-size:24px;font-weight:600;margin:0 0 8px}.welcome-message p{color:#64748b;font-size:14px;margin:0}@media (max-width:1024px){.dashboard{padding:20px 0}.stats-bar{margin-bottom:28px}.dashboard-content,.stats-bar{padding:0 20px}}@media (max-width:768px){.dashboard{padding:16px 0}.stats-bar{flex-direction:column;gap:12px;margin-bottom:24px;padding:0 16px}.stat-card{padding:16px}.dashboard-content{padding:0 16px}.welcome-message{padding:24px}.welcome-message h2{font-size:20px}}@media (max-width:480px){.stat-card{padding:14px}.stat-number{font-size:20px}.welcome-message{padding:20px}.welcome-message h2{font-size:18px}}.documentos-institucionales{box-sizing:border-box;padding:24px;width:100%}.documentos-header{alignItems:center;display:flex;justify-content:space-between;margin-bottom:24px;margin-top:38px}.documentos-header h2{fontSize:1.5rem;fontWeight:600;color:#1e293b;margin:0}.documentos-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.documento-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;overflow:hidden;transition:all .2s ease}.documento-card:hover{box-shadow:0 4px 12px #0000001a,0 2px 6px #0000000f;transform:translateY(-2px)}.documento-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;gap:12px;padding:16px 20px}.documento-icon{align-items:center;background:#fff;border-radius:8px;color:#3b82f6;display:flex;justify-content:center;padding:8px}.documento-type{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.documento-content{padding:20px}.documento-title{color:#1e293b;font-size:16px;font-weight:600;line-height:1.4;margin:0 0 8px}.documento-description{color:#64748b;font-size:14px;line-height:1.5;margin:0 0 16px}.documento-meta{display:flex;flex-direction:column;gap:4px}.meta-item{display:flex;font-size:12px;justify-content:space-between}.meta-label{color:#64748b;font-weight:500}.meta-value{color:#1e293b;font-weight:600}.documento-actions{background:#f8fafc;border-top:1px solid #e2e8f0;padding:16px 20px}.empty-state{grid-column:1/-1}.action-btn:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}.action-btn.primary:hover{background:#2563eb;border-color:#2563eb}@media (max-width:1024px){.documentos-institucionales{padding:20px}.form-grid{grid-template-columns:1fr}.documentos-grid{gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.documentos-institucionales{padding:16px}.documentos-header{align-items:stretch;flex-direction:column;gap:16px}.create-form-card{padding:20px}.form-actions{flex-direction:column}.documentos-grid{grid-template-columns:1fr}}@media (max-width:480px){.documento-card{margin:0 -4px}.documento-header{padding:12px 16px}.documento-content{padding:16px}.documento-actions{padding:12px 16px}}.email-config-view{margin:0 auto;max-width:1200px;padding:2rem 1rem}.config-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:2rem}.config-header{border-bottom:1px solid #e5e7eb;margin-bottom:2rem;padding-bottom:1rem}.config-header h1{color:#1f2937;font-size:1.875rem;font-weight:600;margin:0 0 .5rem}.config-header p{color:#6b7280;font-size:1rem;margin:0}.loading-spinner{color:#6b7280;font-size:1.1rem;padding:3rem;text-align:center}.alert{border-radius:6px}.alert-error{background-color:#fef2f2}.alert-success{background-color:#f0fdf4}.config-form{grid-gap:1.5rem;display:grid;gap:1.5rem;margin-bottom:2rem}.form-group label{font-size:.875rem}.form-group input[type=email],.form-group input[type=number],.form-group input[type=password],.form-group input[type=text]{border:1px solid #d1d5db;border-radius:6px;font-size:1rem;padding:.75rem;transition:border-color .2s,box-shadow .2s}.form-group input:invalid{border-color:#ef4444}.checkbox-group{align-items:center;flex-direction:row;gap:.5rem}.checkbox-label{color:#374151;display:flex;gap:.5rem}.checkbox-label input[type=checkbox]{display:none}.checkbox-custom{background:#fff;border:2px solid #d1d5db;border-radius:4px;height:20px;position:relative;transition:all .2s;width:20px}.checkbox-label input[type=checkbox]:checked+.checkbox-custom{background:#3b82f6;border-color:#3b82f6}.checkbox-label input[type=checkbox]:checked+.checkbox-custom:after{color:#fff;content:"✓";font-size:12px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.password-input{align-items:center;display:flex;position:relative}.password-input input{flex:1 1;padding-right:3rem}.password-toggle{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:1.2rem;padding:.25rem;position:absolute;right:.75rem;transition:color .2s}.password-toggle:hover{background-color:#f3f4f6;color:#374151}.form-actions{border-top:1px solid #e5e7eb;gap:1rem;padding-top:1rem}.btn{min-width:120px}.btn-primary{background-color:#3b82f6}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-secondary{background-color:#f3f4f6;border:1px solid #d1d5db;color:#374151}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb;border-color:#9ca3af}.config-info{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:1.5rem}.config-info h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0 0 1rem}.config-info ul{color:#475569;margin:0;padding-left:1.5rem}.config-info li{line-height:1.5;margin-bottom:.5rem}.error-message{padding:3rem 2rem;text-align:center}.error-message p{font-size:1.1rem;margin:.5rem 0}@media (max-width:768px){.email-config-view{padding:1rem .5rem}.config-container{padding:1.5rem}.config-header h1{font-size:1.5rem}.form-actions{flex-direction:column;gap:.75rem}.btn{width:100%}.checkbox-group{align-items:flex-start;flex-direction:column}}.alert{animation:slideIn .3s ease-out}.holiday-management{box-sizing:border-box;display:flex;flex-direction:column;height:calc(100vh - 100px);margin:0;overflow:hidden;padding:0 20px 24px;width:100%}.holiday-header{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:20px;justify-content:space-between;margin:20px 0 16px}.holiday-header-info{flex:1 1 280px;min-width:260px}.holiday-header-info h2{color:#1e293b;font-size:1.8rem;font-weight:600;margin:0 0 6px}.page-description{color:#64748b;font-size:14px;margin:0 0 6px}.holiday-count{background:#f1f5f9;border-radius:12px;color:#64748b;display:inline-block;font-size:13px;font-weight:500;padding:4px 12px}.holiday-header-actions{display:flex;justify-content:flex-end}.holiday-new-btn{align-items:center;background:#3b82f6;border:1px solid #0000;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.holiday-new-btn:hover{background:#2563eb}.access-denied{padding:48px 24px}.access-denied h2{color:#dc2626;margin-bottom:12px}.admin-actions{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:24px;padding:20px}.admin-tabs{border-bottom:2px solid #e2e8f0;display:flex;gap:8px;margin-bottom:24px}.tab-btn{background:none;border:none;border-bottom:3px solid #0000;color:#64748b;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s}.tab-btn:hover{background:#f1f5f9;color:#1e40af}.tab-btn.active{border-bottom-color:#1e40af;color:#1e40af}.modal{animation:modalFadeIn .3s ease-out;border-radius:12px;box-shadow:0 4px 20px #00000026;max-height:95vh;max-width:95%;position:relative}.holiday-create-modal{max-width:640px;padding:0;width:100%}.modal-header{padding:24px 28px}.modal-header h3,.modal-header h4{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.modal-close{background:#0000;font-size:28px}.modal-body{padding:24px 28px}.modal-actions{padding:20px 28px}.manual-row,.upload-row{grid-gap:16px;display:grid;gap:16px}.upload-row{align-items:center;grid-template-columns:minmax(220px,1fr) auto}.manual-row{align-items:flex-end;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.upload-row input[type=file]{border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:14px;padding:10px}.manual-row .form-group{display:flex;flex-direction:column;gap:6px}.manual-row .manual-actions{align-self:flex-start}.manual-row .manual-actions .btn-primary{min-width:160px}@media (max-width:640px){.manual-row,.upload-row{grid-template-columns:1fr}.manual-row .manual-actions{align-self:stretch}.manual-row .manual-actions .btn-primary{width:100%}}.manual-row .form-group label{color:#475569;font-size:14px;font-weight:500}.manual-row .form-group input{border:1px solid #e2e8f0;border-radius:8px;font-size:14px;padding:10px 12px}.manual-row .form-group input:focus{border-color:#1e40af;box-shadow:0 0 0 3px #1e40af1a;outline:none}.hint-text{color:#64748b;font-size:13px}.warning-text{color:#dc2626;font-size:13px}.holiday-table-section{gap:16px}.holiday-section-title{align-items:center;display:flex;gap:12px;justify-content:space-between}.holiday-section-title h3{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.section-meta{color:#475569;font-size:13px}.form-group label{color:#475569}.form-group input[type=date],.form-group input[type=file],.form-group input[type=text]{border:1px solid #cbd5e1;border-radius:6px;font-size:14px;padding:8px 12px;transition:border-color .2s}.form-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.btn-secondary{background:#f1f5f9}.btn-secondary:hover{background:#e2e8f0}.holiday-table-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.holiday-table-container,.holiday-table-section{min-height:0}.holiday-table-container,.holiday-table-section,.table-responsive{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.holidays-list-scroll{flex:1 1;min-height:200px;overflow:auto}.simple-table{border-collapse:collapse;width:100%}.simple-table thead{background:#f8fafc;position:-webkit-sticky;position:sticky;top:0;z-index:10}.simple-table td,.simple-table th{border-bottom:1px solid #e2e8f0;padding:12px 16px;text-align:left}.simple-table th{color:#475569;font-size:13px;font-weight:600;text-transform:uppercase}.simple-table tbody tr:hover{background:#f8fafc}.table-sort{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;font:inherit;gap:6px;padding:0}.table-sort:hover{color:#1e40af}.sort-icon{align-items:center;display:flex}.row-actions{display:flex;gap:8px}.icon-btn{align-items:center;background:none;border:1px solid #e2e8f0;border-radius:4px;color:#475569;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s}.icon-btn:hover:not(:disabled){background:#f1f5f9;border-color:#1e40af;color:#1e40af}.icon-btn:disabled{cursor:not-allowed;opacity:.5}.loading,.no-data{color:#64748b;font-size:14px;padding:24px;text-align:center}.message{border-radius:6px;font-size:14px;margin-bottom:16px;padding:12px 16px}.message.error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.modal-overlay{z-index:9999}.modal{background:#fff;border-radius:8px;box-shadow:0 20px 25px -5px #0000001a;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{padding:20px}.modal-header h4{color:#1e3a8a;font-size:18px;margin:0}.modal-close{border-radius:4px;font-size:24px;height:32px;width:32px}.modal-close:hover{color:#1e40af}.modal-actions{border-top:1px solid #e2e8f0;gap:12px}@media (max-width:768px){.holiday-header{align-items:stretch;flex-direction:column}.holiday-header-actions{width:100%}.holiday-new-btn{justify-content:center;width:100%}.holiday-create-modal{max-width:100%}.modal-actions,.modal-body,.modal-header{padding-left:20px;padding-right:20px}.tab-btn{text-align:left}}.header{background-color:var(--color-bg-primary);border-bottom:1px solid var(--color-border);height:var(--header-height);justify-content:space-between;left:80px;padding:0 24px;position:fixed;right:0;top:0;transition:left .3s cubic-bezier(.2,0,0,1);z-index:var(--z-header)}.header,.header__left{align-items:center;display:flex}.header__left{gap:16px}.header__menu-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;display:none;height:40px;justify-content:center;transition:background-color var(--transition-fast),color var(--transition-fast);width:40px}.header__menu-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.header__right{align-items:center;display:flex;gap:8px}.header__icon-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;display:flex;height:40px;justify-content:center;position:relative;text-decoration:none;transition:background-color var(--transition-fast),color var(--transition-fast);width:40px}.header__icon-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.header__icon-btn--active{color:var(--color-primary)}.header__icon-btn--active,.header__icon-btn--active:hover{background-color:var(--color-primary-light)}.header__badge{background-color:var(--color-danger);border-radius:var(--radius-full);color:#fff;font-size:11px;font-weight:600;height:18px;line-height:18px;min-width:18px;padding:0 5px;position:absolute;right:4px;text-align:center;top:4px}.header__user-menu{margin-left:8px;position:relative}.header__user-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;gap:12px;padding:6px 12px 6px 6px;transition:background-color var(--transition-fast)}.header__user-btn--open,.header__user-btn:hover{background-color:var(--color-bg-tertiary)}.header__user-avatar{align-items:center;background-color:var(--color-primary);border-radius:var(--radius-full);color:#fff;display:flex;font-size:14px;font-weight:600;height:36px;justify-content:center;width:36px}.header__user-info{align-items:flex-start;display:flex;flex-direction:column;text-align:left}.header__user-name{color:var(--color-text-primary);font-size:14px;font-weight:500;line-height:1.2}.header__user-role{color:var(--color-text-secondary);font-size:12px;line-height:1.2}.header__user-btn svg{color:var(--color-text-muted);transition:transform var(--transition-fast)}.header__user-btn--open svg{transform:rotate(180deg)}.header__dropdown{animation:dropdownFadeIn .15s ease;background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:200px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:var(--z-dropdown)}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.header__dropdown-item{align-items:center;background:#0000;border:none;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:14px;gap:12px;padding:12px 16px;text-decoration:none;transition:background-color var(--transition-fast),color var(--transition-fast);width:100%}.header__dropdown-item:hover{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.header__dropdown-item--danger{color:var(--color-danger)}.header__dropdown-item--danger:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.header__dropdown-divider{background-color:var(--color-border);height:1px;margin:4px 0}@media (max-width:1024px) and (min-width:769px){.header{left:80px}.header__user-info{display:none}.header__user-btn{gap:0;padding:6px}.header__user-btn svg{display:none}}@media (max-width:768px){.header{left:0;padding:0 16px}.header__menu-btn{display:flex}.header__user-info{display:none}.header__user-btn{gap:0;padding:6px}.header__user-btn svg{display:none}.header__dropdown{right:-8px}}:root{--sidebar-bg:#0f172a;--sidebar-text:#ffffffb3;--sidebar-text-hover:#ffffffe6;--sidebar-text-active:#fff;--sidebar-accent:#3b82f6;--sidebar-accent-bg:#3b82f626;--sidebar-hover-bg:#ffffff0d;--sidebar-border:#ffffff14}.sidebar-overlay{animation:fadeIn .2s ease;background-color:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:998}.sidebar-mobile-toggle{align-items:center;background:#0f172a;background:var(--sidebar-bg);border:none;border-radius:8px;box-shadow:0 2px 8px #00000026;color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;left:12px;position:fixed;top:12px;transition:all .2s ease;width:44px;z-index:997}.sidebar-mobile-toggle:hover{background:#1e293b}.sidebar{background:#0f172a;background:var(--sidebar-bg);box-shadow:2px 0 12px #00000026;display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:228px;width:var(--sidebar-width);z-index:999}.sidebar--visible{transform:translateX(0)}.sidebar__header{align-items:center;border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--sidebar-border);display:flex;justify-content:space-between;min-height:64px;padding:16px 20px}.sidebar__logo{height:28px;object-fit:contain;width:auto}.sidebar__close{align-items:center;background:#0000;border:none;border-radius:6px;color:#ffffffb3;color:var(--sidebar-text);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.sidebar__close:hover{background:#ffffff0d;background:var(--sidebar-hover-bg);color:#fff;color:var(--sidebar-text-active)}.sidebar__nav{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:12px 0}.sidebar__nav::-webkit-scrollbar{width:6px}.sidebar__nav::-webkit-scrollbar-track{background:#0000}.sidebar__nav::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.sidebar__nav::-webkit-scrollbar-thumb:hover{background:#ffffff40}.sidebar__group{margin-bottom:2px}.sidebar__divider{border:none;border-top:2px solid #ffffff2e;margin:10px 16px}.sidebar__group-btn{align-items:center;background:#0000;border:none;color:#ffffffb3;color:var(--sidebar-text);cursor:pointer;display:flex;font-family:inherit;font-size:.9rem;font-weight:500;gap:12px;padding:10px 16px;text-align:left;text-decoration:none;transition:all .15s ease;width:100%}.sidebar__group-btn:hover{background:#ffffff0d;background:var(--sidebar-hover-bg);color:#ffffffe6;color:var(--sidebar-text-hover)}.sidebar__group-btn--active{color:#fff;color:var(--sidebar-text-active)}.sidebar__group-btn--active,.sidebar__group-btn--active:hover{background:#3b82f626;background:var(--sidebar-accent-bg)}.sidebar__icon{align-items:center;display:flex;flex-shrink:0;height:20px;justify-content:center;width:20px}.sidebar__icon svg{height:18px;width:18px}.sidebar__label{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__chevron{align-items:center;display:flex;height:20px;justify-content:center;opacity:.6;transition:transform .2s ease;width:20px}.sidebar__chevron--open{transform:rotate(180deg)}.sidebar__accordion{max-height:0;overflow:hidden;transition:max-height .25s cubic-bezier(.4,0,.2,1)}.sidebar__accordion--open{max-height:500px}.sidebar__links{padding:4px 0 8px}.sidebar__link{align-items:center;color:#ffffffb3;color:var(--sidebar-text);display:flex;font-family:inherit;font-size:.85rem;font-weight:400;gap:10px;padding:8px 16px 8px 48px;position:relative;text-decoration:none;transition:all .15s ease}.sidebar__link:before{background:#fff3;border-radius:50%;content:"";height:6px;left:28px;position:absolute;top:50%;transform:translateY(-50%);transition:all .15s ease;width:6px}.sidebar__link:hover{background:#ffffff0d;background:var(--sidebar-hover-bg);color:#ffffffe6;color:var(--sidebar-text-hover)}.sidebar__link:hover:before{background:#fff6}.sidebar__link--active{background:#3b82f626;background:var(--sidebar-accent-bg);color:#3b82f6;color:var(--sidebar-accent)}.sidebar__link--active:before{background:#3b82f6;background:var(--sidebar-accent);box-shadow:0 0 6px #3b82f6;box-shadow:0 0 6px var(--sidebar-accent)}.sidebar__link--active:hover{background:#3b82f626;background:var(--sidebar-accent-bg);color:#3b82f6;color:var(--sidebar-accent)}.sidebar__link-icon{display:none}.sidebar__link-label{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (min-width:1024px){.sidebar{transform:translateX(0)}.sidebar-mobile-toggle{display:none}}@media (min-width:768px) and (max-width:1023px){.sidebar{width:240px}.sidebar__group-btn{font-size:.875rem;padding:10px 14px}.sidebar__link{font-size:.8125rem;padding:8px 14px 8px 44px}.sidebar__link:before{left:24px}}@media (max-width:767px){.sidebar{width:280px}.sidebar__header{padding:12px 16px}.sidebar__logo{height:24px}.sidebar__group-btn{padding:12px 16px}.sidebar__link{padding:10px 16px 10px 48px}}.app-shell{background-color:var(--color-bg-secondary);min-height:100vh}.app-shell__content{margin-left:228px;margin-top:var(--header-height);min-height:calc(100vh - var(--header-height));padding:24px;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}@media (max-width:1023px){.app-shell__content{margin-left:0;padding:70px 16px 16px}}.app-shell__content>.page-container{margin:0 auto;max-width:1400px}.app-shell__content>.page-container--full{max-width:none}.chart-container{perspective:1000px;position:relative}.chart-flipper{height:100%;position:relative;transform-style:preserve-3d;transition:transform .5s ease;width:100%}.chart-flipper--flipped{transform:rotateY(180deg)}.chart-card{-webkit-backface-visibility:hidden;backface-visibility:hidden;inset:0;overflow:hidden;position:absolute}.chart-card--back{background:#f8fafc;overflow-y:auto;transform:rotateY(180deg)}.chart-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;padding:12px 16px}.chart-header,.chart-title{align-items:center;display:flex}.chart-title{color:#1e293b;font-size:.9375rem;font-weight:600;gap:8px;margin:0}.chart-title-icon{flex-shrink:0}.chart-title-icon--blue{color:#3b82f6}.chart-title-icon--purple{color:#8b5cf6}.chart-title-icon--green{color:#22c55e}.chart-flip-btn{align-items:center;background:#f1f5f9;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:background .15s ease}.chart-flip-btn:hover{background:#e2e8f0;color:#475569}.chart-content{height:calc(100% - 60px);padding:16px}.chart-empty{align-items:center;color:#94a3b8;display:flex;font-size:.875rem;height:100%;justify-content:center}.chart-donut-wrapper{height:100%;position:relative;width:100%}.chart-donut-center{left:50%;pointer-events:none;position:absolute;text-align:center;top:45%;transform:translate(-50%,-50%)}.chart-donut-center-value{color:#1e293b;font-size:1.5rem;font-weight:700}.chart-donut-center-label{color:#64748b;font-size:.625rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.chart-legend{display:flex;flex-wrap:wrap;gap:12px 16px;justify-content:center;list-style:none;margin:8px 0 0;padding:0}.chart-legend-item{align-items:center;color:#64748b;display:flex;font-size:.75rem;gap:4px}.chart-legend-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.chart-legend-label{white-space:nowrap}.chart-back-content{display:flex;flex-direction:column;gap:12px;height:calc(100% - 60px);overflow-y:auto;padding:16px}.chart-info-section{display:flex;flex-direction:column;gap:4px}.chart-info-label{font-weight:600}.chart-info-label,.chart-info-text{color:#475569;font-size:.875rem;margin:0}.chart-info-text{line-height:1.5}.chart-info-text--muted{color:#64748b}.chart-info-tip{border-top:1px solid #e2e8f0;margin-top:auto;padding-top:12px}.chart-info-tip p{color:#64748b;font-size:.875rem;font-style:italic;line-height:1.5;margin:0}.recharts-surface :focus,.recharts-surface:focus,.recharts-wrapper:focus{outline:none}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:#e5e7eb}.recharts-tooltip-wrapper{z-index:100}.recharts-default-tooltip{background-color:#fff!important;border:1px solid #e5e7eb!important;border-radius:8px!important;box-shadow:0 4px 6px -1px #0000001a!important}.recharts-tooltip-label{color:#1e293b!important;font-weight:600!important;margin-bottom:4px!important}.recharts-tooltip-item{color:#64748b!important}.recharts-legend-item-text{color:#64748b!important;font-size:12px!important}@media (max-width:640px){.chart-header{padding:10px 12px}.chart-title{font-size:.875rem}.chart-content{padding:12px}.chart-donut-center-value{font-size:1.25rem}.chart-back-content{gap:10px;padding:12px}.chart-info-label,.chart-info-text{font-size:.8125rem}}.user-form-tabs{width:100%}.tabs-nav{gap:4px;margin-bottom:2px}.tab-button{flex:1 1;font-size:14px;padding:5px 10px}.tab-button:hover{background-color:#eff6ff;color:#3b82f6}.tab-button.active{background-color:#f0f9ff;border-bottom-color:#3b82f6;color:#3b82f6}.tabs-content{display:grid;padding:0}.tab-pane{grid-column:1;grid-row:1;min-width:0}.tab-pane--active{animation:fadeIn .15s ease-in;visibility:visible}.tab-pane--hidden{pointer-events:none;visibility:hidden}.user-form-tabs .form-grid{grid-gap:3px 8px;display:grid;gap:3px 8px;grid-template-columns:repeat(3,1fr);margin-bottom:0}.user-form-tabs .form-group{display:flex;flex-direction:column}.user-form-tabs .form-group.full-width{grid-column:1/-1}.user-form-tabs .form-group label{color:#374151;font-size:12px;font-weight:500;margin-bottom:0}.user-form-tabs .form-group input,.user-form-tabs .form-group select,.user-form-tabs .form-group textarea{border:1px solid #d1d5db;border-radius:6px;font-family:inherit;font-size:13px;padding:4px 6px;transition:border-color .2s ease}.user-form-tabs .form-group input:focus,.user-form-tabs .form-group select:focus,.user-form-tabs .form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.user-form-tabs .form-hint{color:#6b7280;display:block;font-size:11px;margin-top:0}.user-form-tabs .form-group h4{color:#374151;font-size:13px;font-weight:600;margin:0}.user-form-tabs .photo-preview{margin-top:2px}.user-form-tabs .photo-preview img{border:2px solid #e5e7eb;border-radius:6px;max-height:80px;max-width:80px;object-fit:cover}.user-form-tabs .input-disabled{background-color:#f8fafc!important;color:#475569!important}.readonly-field{word-wrap:break-word;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;box-sizing:border-box;color:#374151;max-width:100%;min-height:38px;overflow-wrap:break-word;padding:8px 12px;white-space:pre-wrap}.user-form-tabs .form-group input.input-error,.user-form-tabs .form-group select.input-error,.user-form-tabs .form-group textarea.input-error{background-color:#fef2f2;border-color:#dc2626}.user-form-tabs .form-group input:invalid,.user-form-tabs .form-group select:invalid,.user-form-tabs .form-group textarea:invalid{background-color:#fff;border-color:#d1d5db;box-shadow:none}.user-form-tabs .form-group input.input-error:focus,.user-form-tabs .form-group select.input-error:focus,.user-form-tabs .form-group textarea.input-error:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.user-form-tabs .error-text{color:#dc2626;display:block;font-size:11px;font-weight:500;margin-top:0}.attachments-toolbar{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:12px;padding:12px}.attachments-select-all{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:14px;gap:8px;-webkit-user-select:none;user-select:none}.attachments-select-all input[type=checkbox]{cursor:pointer;height:16px;width:16px}.attachments-checkbox{align-items:center;cursor:pointer;display:flex;margin-right:12px}.attachments-checkbox input[type=checkbox]{cursor:pointer;height:16px;width:16px}.attachments-list{list-style:none;margin:0;padding:0}.attachments-item{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:6px;display:flex;margin-bottom:8px;padding:12px;transition:background-color .2s ease}.attachments-item:hover{background-color:#f9fafb}.attachments-meta{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.attachments-name{color:#111827;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachments-info{color:#6b7280;font-size:12px}.attachments-actions{display:flex;gap:8px;margin-left:12px}.attachments-actions button{background-color:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;font-size:13px;padding:6px 12px;transition:all .2s ease}.attachments-actions button:hover{background-color:#f3f4f6;border-color:#9ca3af}.attachments-empty,.attachments-error{color:#6b7280;font-size:14px;padding:20px;text-align:center}.attachments-error{color:#dc2626}@media (max-width:900px){.user-form-tabs .form-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.user-form-tabs .form-grid{grid-template-columns:1fr}.tabs-nav{flex-wrap:wrap}.tab-button{flex:1 1 45%}.attachments-toolbar{align-items:flex-start;flex-direction:column;gap:8px}.attachments-item{flex-wrap:wrap}.attachments-actions{margin-left:0;margin-top:8px;width:100%}}.metrics-layout{display:flex;flex-direction:column;gap:1.5rem;margin:0 auto;max-width:1400px;padding:1.5rem}.metrics-page-header{display:flex;flex-direction:column;gap:.5rem}.metrics-page-header__title-row{align-items:center;display:flex;justify-content:space-between;padding-bottom:.75rem}.metrics-page-header h2{align-items:center;color:#1e293b;display:flex;font-size:1.5rem;font-weight:600;gap:.5rem;margin:0}.metrics-page-header h2 svg{color:#64748b}.metrics-tabs-inline{border-bottom:2px solid #e2e8f0;display:flex;gap:4px}.metrics-tab-btn{background:#0000;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;margin-bottom:-2px;padding:.75rem 1.25rem;text-align:center;transition:all .2s ease}.metrics-tab-btn:hover{background-color:#eff6ff;color:#2563eb}.metrics-tab-btn.active{background-color:#f0f9ff;border-bottom-color:#2563eb;color:#2563eb;font-weight:600}.metrics-section__date{border-left:1px solid #e2e8f0;color:#475569;font-size:.8125rem;font-weight:500;letter-spacing:0;margin-left:1rem;padding-left:1rem;text-transform:none}.metrics-section__subtitle{align-items:center;border-bottom:1px solid #f1f5f9;color:#475569;display:flex;font-size:.8125rem;font-weight:600;gap:.375rem;letter-spacing:.03em;margin:0;padding-bottom:.5rem;text-transform:uppercase}.metrics-section__subtitle svg{color:#94a3b8}.metrics-content,.metrics-tab-content{display:flex;flex-direction:column;gap:1.5rem}.metrics-mode-switch{border-bottom:2px solid #e2e8f0;display:inline-flex;gap:4px}.metrics-mode-switch button{background:#0000;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;font-size:.8125rem;font-weight:500;margin-bottom:-2px;padding:.5rem 1rem;transition:all .2s ease}.metrics-mode-switch button:hover{background-color:#eff6ff;color:#2563eb}.metrics-mode-switch button.active{background-color:#f0f9ff;border-bottom-color:#2563eb;color:#2563eb;font-weight:600}.metrics-summary-inline{border-top:1px solid #f1f5f9;color:#64748b;display:flex;font-size:.875rem;gap:1.5rem;padding:.75rem 0}.metrics-summary-inline span{align-items:center;display:flex;gap:.375rem}.metrics-summary-inline strong{color:#475569;font-weight:500}.filters-error,.filters-loading{border-radius:8px;font-size:.875rem;padding:.75rem;text-align:center}.filters-loading{background:#f8fafc;color:#64748b}.filters-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.metrics-panel{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem}.metrics-panel__header{align-items:flex-start;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding-bottom:1rem}.metrics-panel__header>div:first-child{flex:1 1}.metrics-panel__header h3{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0 0 .25rem}.metrics-panel__header p{color:#64748b;font-size:.875rem;margin:0}.metrics-card-group{display:flex;flex-direction:column;gap:1rem}.metrics-card-group h4{color:#1e293b;font-size:1rem;font-weight:600;margin:0}.bajas-detail-section{border-top:1px solid #e2e8f0;margin-top:1rem;padding-top:1.5rem}.metrics-panel__footer{border-top:1px solid #f1f5f9;color:#94a3b8;font-size:.8125rem;padding-top:1rem}.metrics-panel__footer code{background:#f8fafc;border-radius:4px;font-family:Courier New,monospace;font-size:.75rem;padding:.125rem .375rem}.metric-card-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.metrics-kpi-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.metrics-range-picker{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:1rem;padding:1rem}.metrics-range-picker label{color:#475569;display:flex;flex:1 1;flex-direction:column;font-size:.875rem;font-weight:500;gap:.375rem}.metrics-range-picker input{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:.875rem;padding:.5rem .75rem;transition:all .2s ease}.metrics-range-picker input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.metrics-table{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.metrics-table table{border-collapse:collapse;width:100%}.metrics-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#475569;font-size:.8125rem;font-weight:600;padding:.75rem 1rem;text-align:left}.metrics-table td{border-bottom:1px solid #f1f5f9;color:#1e293b;font-size:.875rem;padding:.875rem 1rem}.metrics-table tr:last-child td{border-bottom:none}.metrics-table tr:hover td{background:#f8fafc}.metrics-table .empty-cell{color:#94a3b8;font-style:italic;padding:2rem;text-align:center}.metrics-error,.metrics-loading{border-radius:8px;font-size:.875rem;padding:2rem;text-align:center}.metrics-loading{background:#f8fafc}.metrics-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.muted{font-size:.875rem}.empty-cell,.muted{color:#94a3b8;font-style:italic}.empty-cell{text-align:center}.summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-grid>div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:.375rem;padding:1rem}.summary-grid span{color:#64748b;display:block;font-size:.8125rem;font-weight:500;min-height:1.25rem}.summary-grid strong{color:#1e293b;font-size:1rem;font-weight:600}@media (max-width:1280px){.metrics-kpi-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:1024px){.metrics-layout{padding:1.25rem}.metrics-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.metrics-layout{gap:1rem;padding:1rem}.metrics-page-header__title-row{align-items:flex-start;flex-direction:column;gap:1rem}.metrics-tabs-inline{overflow-x:auto;width:100%}.metrics-tab-btn{flex:1 1;white-space:nowrap}.metrics-kpi-grid{grid-template-columns:1fr}.metrics-section__date{border-left:none;display:block;margin-left:0;margin-top:.25rem;padding-left:0}.metrics-mode-switch{width:100%}.metrics-mode-switch button{flex:1 1}.metrics-range-picker{flex-direction:column;padding:.75rem}.metrics-summary-inline{flex-direction:column;gap:.5rem}.metrics-table{overflow-x:auto}.metrics-table table{min-width:500px}.metrics-table td,.metrics-table th{font-size:.8125rem;padding:.625rem .75rem}}@media (max-width:480px){.metrics-layout{padding:.75rem}.metrics-page-header h2{font-size:1.25rem}.metrics-tab-btn{font-size:.8125rem;padding:.5rem .75rem}.metrics-section__subtitle{font-size:.75rem}.metrics-mode-switch button{font-size:.75rem;padding:.3rem .5rem}}.notificaciones{box-sizing:border-box;padding:24px;width:100%}.notificaciones-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px;margin-top:38px}.header-title{align-items:center;display:flex;gap:12px}.header-title h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.unread-badge{background:#ef4444;border-radius:12px;color:#fff;font-size:12px;font-weight:600;min-width:20px;padding:4px 8px;text-align:center}.create-form-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #00000014;margin-bottom:24px;padding:24px}.create-form-card h3{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0 0 20px}.form-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:24px}.form-group input,.form-group select,.form-group textarea{outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{min-height:80px;resize:vertical}.form-actions{border-top:1px solid #f1f5f9;gap:12px;padding-top:20px}.notificaciones-list{display:flex;flex-direction:column;gap:12px;margin-top:20px}.notification-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #00000014;display:flex;gap:16px;padding:20px;position:relative;transition:all .2s ease}.notification-card:hover{box-shadow:0 4px 12px #0000001a,0 2px 6px #0000000f;transform:translateY(-1px)}.notification-card.unread{background:#f8faff;border-left:4px solid #3b82f6}.notification-card.read{opacity:.8}.notification-icon{align-items:center;background:#f8fafc;border-radius:10px;color:#3b82f6;display:flex;flex-shrink:0;justify-content:center;padding:12px}.notification-card.unread .notification-icon{background:#dbeafe;color:#2563eb}.notification-content{flex:1 1}.notification-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.notification-type{color:#3b82f6;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.notification-date{color:#64748b;font-size:12px;font-weight:500}.notification-title{color:#1e293b;font-size:16px;font-weight:600;line-height:1.4;margin:0 0 8px}.notification-message{color:#64748b;font-size:14px;line-height:1.5;margin:0 0 12px}.mark-read-btn{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:12px;font-weight:600;padding:4px 0;text-decoration:underline;transition:color .2s ease}.mark-read-btn:hover{color:#2563eb}.unread-indicator{background:#3b82f6;border-radius:50%;height:8px;position:absolute;right:10px;top:14px;width:8px}.empty-state{color:#64748b;padding:60px 20px;text-align:center}.empty-state svg{margin-bottom:16px;opacity:.5}.empty-state h3{color:#374151;font-size:18px;margin:0 0 8px}.empty-state p{font-size:14px;margin:0}.action-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px #0000000d;color:#4b5563;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;text-decoration:none;transition:all .2s ease}.action-btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}.action-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.action-btn.primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.action-btn.primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.action-btn.secondary{background:#f8fafc;border-color:#e2e8f0;color:#374151}.action-btn.secondary:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.btn{transition:all .2s ease}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#f8fafc;color:#4b5563}.alert-error{border:1px solid #fecaca;color:#dc2626}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.loading{color:#64748b;font-size:16px}@media (max-width:1024px){.notificaciones{padding:20px}.form-grid{grid-template-columns:1fr}}@media (max-width:768px){.notificaciones{padding:16px}.notificaciones-header{align-items:stretch;flex-direction:column;gap:16px}.header-actions{flex-wrap:wrap}.create-form-card{padding:20px}.form-actions{flex-direction:column}.notification-card{gap:12px;padding:16px}.notification-header{align-items:flex-start;flex-direction:column;gap:4px}}@media (max-width:480px){.notification-card{padding:12px}.notification-icon{padding:8px}.notification-title{font-size:14px}.notification-message{font-size:13px}.unread-indicator{right:16px;top:16px}}.notification-card.clickable{cursor:pointer}.notification-card.clickable:hover{background:#f0f7ff;border-color:#93c5fd}.notification-card.clickable.read:hover{opacity:1}.notification-link-icon{color:#94a3b8;display:inline;margin-left:6px;vertical-align:middle}.notification-card.clickable:hover .notification-link-icon{color:#3b82f6}.batch-upload-container{font-family:Arboria,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0 auto;max-width:1200px;padding:2rem}.batch-upload-container h2{color:#2c3e50;font-size:2rem;margin-bottom:2rem;text-align:center}.dropzone{border:2px dashed #3498db;border-radius:8px;margin-bottom:2rem;padding:3rem 1rem;transition:all .3s ease}.dropzone.active,.dropzone:hover{background-color:#ebf5fb;border-color:#2980b9}.dropzone p{color:#7f8c8d;margin:.5rem 0}.dropzone .small{color:#95a5a6;font-size:.9rem}.batch-upload-form{margin-top:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#2c3e50;margin-bottom:.5rem}.form-group input[type=text]{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .3s;width:100%}.form-group input[type=text]:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}.file-list{border-radius:8px;margin:1rem 0;max-height:400px;overflow-y:auto}.file-list h3{background-color:#f8fafc;border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:1.1rem;margin:0;padding:1rem}.file-list-header{background-color:#f1f5f9;border-bottom:1px solid #e2e8f0;color:#4a5568;font-size:.9rem;font-weight:600;padding:.75rem 1rem}.file-item,.file-list-header{display:grid;grid-template-columns:2fr 2fr 2fr 1fr}.file-item{border-bottom:1px solid #edf2f7;padding:1rem}.file-assignment,.file-name{align-items:center;display:flex;gap:.5rem}.file-assignment input{border:1px solid #e2e8f0;border-radius:4px;flex:1 1;font-size:.9rem;padding:.5rem}.or-divider{color:#a0aec0;font-size:.8rem;white-space:nowrap}.file-status{font-size:.9rem}.progress-container{align-items:center;display:flex;gap:8px;width:100%}.progress-bar{background-color:#e2e8f0;flex:1 1}.progress{background-color:#4299e1;height:100%;transition:width .3s ease}.progress-text{color:#4a5568;display:flex;font-size:.8rem;justify-content:flex-end;min-width:40px;text-align:right}.status-badge{align-items:center;border-radius:50%;display:inline-flex;font-size:.8rem;font-weight:700;height:20px;justify-content:center;width:20px}.status-badge.success{background-color:#48bb78;color:#fff}.status-badge.error{background-color:#f56565;color:#fff}.btn-primary,.btn-remove,.btn-secondary{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 16px;transition:all .15s}.btn-secondary{color:#4a5568;margin-left:.75rem}.btn-secondary:hover:not(:disabled){background-color:#cbd5e0}.btn-remove{background:none;color:#e53e3e;padding:.25rem .5rem;text-decoration:underline}.btn-remove:hover{color:#c53030}.user-info{background-color:#f8fafc;border-left:3px solid #3182ce;flex-direction:column;gap:4px;width:100%}.searching-state,.user-info{border-radius:4px;display:flex;padding:8px}.searching-state{align-items:center;background-color:#fff9e6;border-left:3px solid #ffc107;color:#8a6d3b;gap:8px}.searching-spinner{animation:spin 1s linear infinite}.error-message{color:#e53e3e;font-size:.85rem;font-style:italic;margin-top:4px}.input-group{align-items:center;display:flex;gap:8px;width:100%}.email-input.has-error{background-color:#fff5f5;border-color:#e53e3e}.form-actions{background-color:#f8fafc;padding:1rem}.alert{margin-bottom:1.5rem;padding:1rem}@media (max-width:768px){.file-item,.file-list-header{gap:.5rem;grid-template-columns:1fr}.file-actions{justify-content:flex-start;margin-top:.5rem}.form-actions{flex-direction:column;gap:.75rem}.btn-secondary{margin-left:0}}.payroll-upload-container{font-family:Arboria,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0 auto;max-width:1000px;padding:24px 16px}.payroll-upload-container h2{color:#2c3e50;font-size:24px;font-weight:600;margin:0 0 8px;text-align:center}.payroll-upload-container .subtitle{color:#4a5568;font-size:16px;margin:0 0 24px;text-align:center}.batch-upload-container{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-top:16px;padding:24px}.form-group label{color:#4a5568;margin-bottom:8px}.form-control{border:1px solid #e2e8f0;border-radius:4px;font-size:14px;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.form-control:focus{border-color:#3182ce;box-shadow:0 0 0 1px #3182ce;outline:none}.dropzone{background-color:#f8fafc;border:2px dashed #e2e8f0;border-radius:6px;cursor:pointer;margin-bottom:16px;padding:24px;text-align:center;transition:all .2s}.dropzone.active,.dropzone:hover{background-color:#ebf8ff;border-color:#3182ce}.dropzone p{color:#4a5568;margin:0 0 4px}.dropzone .small{color:#718096;font-size:12px}.file-list{border:1px solid #e2e8f0;border-radius:4px;margin-top:24px;overflow:hidden}.file-item{align-items:center;background-color:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:12px 16px;transition:background-color .2s}.file-item:last-child{border-bottom:none}.file-item:hover{background-color:#f8fafc}.file-info{flex:1 1;min-width:0}.file-name{color:#2d3748;font-weight:500;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-status{align-items:center;color:#718096;display:flex;font-size:12px;gap:4px}.file-status.completed{color:#38a169}.file-status.error{color:#e53e3e}.file-actions{display:flex;gap:8px;margin-left:16px}.btn{border-radius:4px;font-size:14px;transition:all .2s}.btn-primary{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 16px;transition:all .15s}.btn-secondary{background-color:#e2e8f0;color:#2d3748}.btn-secondary:hover{background-color:#cbd5e0}.btn-danger{background-color:#fff5f5;border-color:#fed7d7;color:#e53e3e}.btn-danger:hover{background-color:#fed7d7}.btn-icon{background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;padding:6px;transition:all .2s}.btn-icon:hover{background-color:#edf2f7;color:#4a5568}.progress-container{margin-top:24px}.progress-header{display:flex;justify-content:space-between;margin-bottom:8px}.progress-bar{background-color:#edf2f7;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden}.progress-fill{background-color:#3182ce;height:100%;transition:width .3s ease;width:0}.alert{align-items:flex-start;border-radius:4px;display:flex;font-size:14px;gap:8px;padding:12px 16px}.alert-icon{flex-shrink:0;margin-top:2px}.alert-content{flex:1 1}.alert-title{font-weight:600;margin-bottom:4px}.alert-description{color:inherit;font-size:13px;opacity:.9}.alert-success{background-color:#f0fff4;border:1px solid #c6f6d5;color:#2f855a}.alert-error{background-color:#fff5f5;border:1px solid #fed7d7;color:#c53030}.alert-info{background-color:#ebf8ff;border:1px solid #bee3f8;color:#2b6cb0}@media (max-width:768px){.batch-upload-container,.payroll-upload-container{padding:16px}.file-item{align-items:flex-start;flex-direction:column;gap:8px}.file-actions{justify-content:flex-end;margin-left:0;margin-top:8px;width:100%}.btn{width:100%}}.totp-dialog-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.totp-dialog{animation:slideIn .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:400px;width:90%}.totp-dialog-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:16px 20px}.totp-dialog-header h3{color:#2c3e50;font-size:1.2rem;margin:0}.totp-dialog-close{background:none;border:none;color:#6c757d;cursor:pointer;font-size:1.5rem;line-height:1;padding:0;transition:color .2s}.totp-dialog-close:hover:not(:disabled){color:#2c3e50}.totp-dialog-close:disabled{cursor:not-allowed;opacity:.5}.totp-dialog-body{padding:24px 20px;text-align:center}.totp-message{color:#495057;font-size:.95rem;margin:0 0 20px}.totp-inputs{display:flex;gap:8px;justify-content:center;margin-bottom:16px}.totp-digit-input{border:2px solid #dee2e6;border-radius:8px;font-size:1.5rem;font-weight:600;height:56px;text-align:center;transition:border-color .2s,box-shadow .2s;width:48px}.totp-digit-input:focus{border-color:#6c757d;box-shadow:0 0 0 3px #6c757d26;outline:none}.totp-digit-input:disabled{background:#f8f9fa;cursor:not-allowed}.totp-error{background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;font-size:.9rem;margin-bottom:16px;padding:10px 14px}.totp-hint{color:#6c757d;font-size:.85rem;line-height:1.4;margin:0}.totp-dialog-actions{border-top:1px solid #e9ecef;display:flex;gap:10px;justify-content:flex-end;padding:16px 20px}.totp-dialog-actions .btn-primary,.totp-dialog-actions .btn-secondary{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 16px;transition:all .15s}.totp-dialog-actions .btn-primary{background:#3b82f6;color:#fff}.totp-dialog-actions .btn-primary:hover:not(:disabled){background:#2563eb}.totp-dialog-actions .btn-primary:disabled{cursor:not-allowed;opacity:.6}.totp-dialog-actions .btn-secondary{background:#f1f3f5;border:1px solid #dee2e6;color:#2c3e50}.totp-dialog-actions .btn-secondary:hover:not(:disabled){background:#e9ecef}.totp-dialog-actions .btn-secondary:disabled{cursor:not-allowed;opacity:.6}@media (max-width:480px){.totp-digit-input{font-size:1.25rem;height:48px;width:40px}.totp-inputs{gap:6px}}.payroll-view-container{margin:0 auto;max-width:1400px;padding:16px}.payroll-view-header{border-bottom:2px solid #e9ecef;margin-bottom:16px;padding-bottom:12px;text-align:left}.payroll-view-header h2{color:#2c3e50;font-size:1.6rem;margin:0 0 6px}.payroll-view-header p{color:#6c757d;margin:0}.loading{color:#6c757d;font-size:1.1rem}.payroll-alert-error{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;font-weight:500;margin:15px 0;padding:12px 14px;text-align:left}.no-recibos{background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;padding:60px 20px;text-align:center}.no-recibos p{color:#6c757d;font-size:1.1rem;margin-bottom:6px}.no-recibos small{color:#adb5bd}.payroll-split{display:flex;gap:16px;height:calc(100vh - 210px);min-height:520px}.payroll-left{background:#fff;border:1px solid #dee2e6;border-radius:10px;display:flex;flex-direction:column;min-width:280px;overflow:hidden;width:340px}.tabs{background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;gap:6px;padding:10px}.tab-btn{background:#fff;border:1px solid #dee2e6;border-radius:8px;color:#2c3e50;cursor:pointer;flex:1 1;font-weight:600;padding:10px 12px}.tab-btn.active{background:#6c757d;border-color:#6c757d;color:#fff}.list-scroll{overflow:auto;padding:10px}.recibo-item{background:#f1f3f5;border:1px solid #e1e5ea;border-radius:10px;cursor:pointer;margin-bottom:10px;padding:12px 12px 12px 14px;position:relative;text-align:left;transition:background .15s ease-in-out,box-shadow .15s ease-in-out;width:100%}.recibo-item:hover{background:#e9ecef;box-shadow:0 1px 3px #00000014}.recibo-item.active{background:#dee2e6;border-left:4px solid #6c757d}.recibo-item-title{color:#2c3e50;font-weight:700;line-height:1.2;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recibo-item-sub{color:#6c757d;font-size:.92rem;margin-bottom:8px}.pill{border-radius:14px;display:inline-block;font-size:.78rem;font-weight:700;padding:4px 10px}.pill.ok{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.pill.pend{background:#fff3cd;border:1px solid #ffeeba;color:#856404}.pill.disconf{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.payroll-right{background:#fff;border:1px solid #dee2e6;border-radius:10px;display:flex;flex:1 1;flex-direction:column;min-width:0}.viewer-toolbar{align-items:center;background:#fff;border-bottom:1px solid #e9ecef;display:flex;gap:12px;justify-content:space-between;padding:10px 12px;position:-webkit-sticky;position:sticky;top:0;z-index:1}.signed-chip{color:#2c3e50;font-weight:600}.viewer-actions{display:flex;gap:8px}.btn-primary,.btn-secondary{border:1px solid #0000;font-size:.875rem;padding:8px 16px;transition:all .15s}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#f1f3f5;border:1px solid #dee2e6;color:#2c3e50;transition:all .2s ease-in-out}.btn-secondary:disabled{background:#e9ecef;border-color:#e9ecef;color:#adb5bd;cursor:not-allowed;opacity:.6;position:relative}.btn-secondary:disabled:hover:after{background:#333;border-radius:4px;bottom:100%;color:#fff;content:attr(title);font-size:.8rem;margin-bottom:5px;padding:5px 10px;pointer-events:none;white-space:nowrap}.btn-secondary:disabled:hover:after,.btn-secondary:disabled:hover:before{left:50%;opacity:0;position:absolute;transform:translateX(-50%);transition:opacity .2s}.btn-secondary:disabled:hover:before{border:5px solid #0000;border-top-color:#333;bottom:calc(100% - 5px);content:""}.btn-secondary:disabled:hover:after,.btn-secondary:disabled:hover:before{opacity:1}.pdf-viewer{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;display:flex;flex:1 1;flex-direction:column;overflow:auto;position:relative}.pdf-iframe{background-color:#fff;border:none;flex:1 1;height:100%;min-height:500px;width:100%}.pdf-fullscreen-btn{align-items:center;background:#ffffffe6;border:1px solid #dee2e6;border-radius:6px;box-shadow:0 1px 3px #0000001a;color:#495057;cursor:pointer;display:flex;justify-content:center;padding:6px;position:absolute;right:8px;top:8px;transition:all .2s ease;z-index:2}.pdf-fullscreen-btn:hover{background:#fff;box-shadow:0 2px 6px #00000026;color:#2c3e50}.pdf-viewer:fullscreen{background:#fff;border:none;border-radius:0}.pdf-viewer:fullscreen .pdf-iframe{min-height:100%}.pdf-viewer:fullscreen .pdf-fullscreen-btn{right:12px;top:12px}.pdf-alternative,.pdf-loading{align-items:center;color:#6c757d;display:flex;flex-direction:column;gap:1rem;height:100%;justify-content:center;padding:2rem;text-align:center}.pdf-alternative p,.pdf-loading p{color:#495057;font-size:1rem;margin:0}.pdf-loading{animation:fadeIn .3s ease-in}.pdf-fallback{background:#fff;border:2px dashed #dee2e6;border-radius:8px;margin:0 auto;max-width:560px;padding:40px;text-align:center}.pdf-fallback .pdf-icon{font-size:2.4rem;margin-bottom:8px}.empty-viewer{color:#6c757d;margin:auto;padding:20px;text-align:center}.firma-buttons{display:flex;gap:8px}.btn-disconforme{background:#dc3545;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:8px 14px;transition:background .2s ease-in-out}.btn-disconforme:hover:not(:disabled){background:#c82333}.btn-disconforme:disabled{cursor:not-allowed;opacity:.6}.modal-overlay{background:#00000080}.modal-content{animation:modalFadeIn .2s ease-out;box-shadow:0 4px 20px #00000026}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid #e9ecef}.modal-header h3{color:#2c3e50;font-size:1.2rem}.modal-close{color:#6c757d;line-height:1}.modal-close:hover{color:#2c3e50}.modal-body p{color:#495057;margin:0 0 12px}.modal-body textarea{border:1px solid #dee2e6;border-radius:8px;font-family:inherit;font-size:.95rem;min-height:100px;padding:12px;resize:vertical;width:100%}.modal-body textarea:focus{border-color:#6c757d;box-shadow:0 0 0 3px #6c757d26;outline:none}.char-count{color:#6c757d;display:block;font-size:.85rem;margin-top:6px;text-align:right}.modal-actions{border-top:1px solid #e9ecef;padding:16px 20px}.form-subtitle.notice{background:#e7f3fe;border:1px solid #b3e5fc;border-radius:8px;color:#0c5460;font-size:.95rem;padding:12px 16px}@media (max-width:1024px){.payroll-split{flex-direction:column;height:auto}.payroll-left{width:100%}.pdf-frame{height:70vh}}.receipt-management-layout{display:flex;flex-direction:column;gap:1.5rem;margin:0 auto;max-width:1400px;padding:1.5rem}.receipt-management-header{display:flex;flex-direction:column;gap:.5rem}.receipt-management-header__title-row{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding-bottom:.75rem}.receipt-management-header h2{align-items:center;color:#1e293b;display:flex;font-size:1.5rem;font-weight:600;gap:.5rem;margin:0}.receipt-management-header h2 svg{color:#64748b}.receipt-management-tabs{border-bottom:2px solid #e2e8f0;display:flex;gap:4px}.receipt-management-tab-btn{background:#0000;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;margin-bottom:-2px;padding:.75rem 1.25rem;text-align:center;transition:all .2s ease}.receipt-management-tab-btn:hover{background-color:#eff6ff;color:#2563eb}.receipt-management-tab-btn.active{background-color:#f0f9ff;border-bottom-color:#2563eb;color:#2563eb;font-weight:600}.receipt-management-content{display:flex;flex-direction:column;gap:1.5rem}.receipt-section{display:flex;flex-direction:column;gap:1rem}.receipt-section__header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;padding-bottom:.75rem}.receipt-section__title{align-items:center;color:#64748b;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;letter-spacing:.05em;margin:0;text-transform:uppercase}.receipt-panel{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #00000014;padding:1.5rem}.receipt-panel__header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.receipt-panel__header h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.receipt-table{border:1px solid #e2e8f0;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.receipt-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#475569;font-size:.8125rem;font-weight:600;padding:.75rem 1rem;text-align:left}.receipt-table td{border-bottom:1px solid #f1f5f9;color:#1e293b;font-size:.875rem;padding:.875rem 1rem}.receipt-table tr:last-child td{border-bottom:none}.receipt-table tr:hover td{background:#f8fafc}.row-highlight td{animation:rowHighlight 3s ease-out}.receipt-table .empty-row td{color:#94a3b8;font-style:italic;padding:2rem;text-align:center}.receipt-form{display:flex;flex-direction:column;gap:1rem}.receipt-form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.receipt-form-field{display:flex;flex-direction:column;gap:.375rem}.receipt-form-field label{color:#475569;font-size:.875rem;font-weight:500}.receipt-form-field label.required:after{color:#ef4444;content:" *"}.receipt-form-field input,.receipt-form-field select,.receipt-form-field textarea{border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:.875rem;padding:.625rem .75rem;transition:all .2s ease}.receipt-form-field input:focus,.receipt-form-field select:focus,.receipt-form-field textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.receipt-form-field textarea{min-height:80px;resize:vertical}.receipt-form-field .error-message{color:#ef4444;font-size:.75rem}.receipt-form-field--error input,.receipt-form-field--error select,.receipt-form-field--error textarea{border-color:#ef4444}.receipt-form-field--error input:focus,.receipt-form-field--error select:focus,.receipt-form-field--error textarea:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.receipt-field-error{color:#ef4444;display:block;font-size:.75rem;margin-top:.25rem}.receipt-form-actions{border-top:1px solid #f1f5f9;display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem}.receipt-btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.receipt-btn-primary{background:#3b82f6;color:#fff}.receipt-btn-primary:hover:not(:disabled){background:#2563eb}.receipt-btn-primary:disabled{cursor:not-allowed;opacity:.6}.receipt-btn-secondary{background:#fff;border:1px solid #e2e8f0;color:#475569}.receipt-btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.receipt-btn-secondary:disabled{background:#f1f5f9;border-color:#e2e8f0;color:#94a3b8;cursor:not-allowed}.receipt-btn-danger{background:#ef4444;border:1px solid #ef4444;color:#fff}.receipt-btn-danger:hover{background:#dc2626;border-color:#dc2626}.receipt-btn-icon{background:#0000;border:none;border-radius:4px;color:#64748b;cursor:pointer;padding:.375rem}.receipt-btn-icon:hover{background:#f1f5f9;color:#475569}.receipt-badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:500;padding:.25rem .625rem}.receipt-badge--pending{background:#fef3c7;color:#92400e}.receipt-badge--analyzing{background:#dbeafe;color:#1e40af}.receipt-badge--resolved{background:#d1fae5;color:#065f46}.receipt-badge--error{background:#fee2e2;color:#991b1b}.receipt-error,.receipt-loading{border-radius:8px;font-size:.875rem;padding:2rem;text-align:center}.receipt-loading{background:#f8fafc;color:#64748b}.receipt-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.receipt-empty{color:#94a3b8;padding:3rem 2rem;text-align:center}.receipt-empty svg{height:48px;margin-bottom:1rem;opacity:.5;width:48px}.receipt-summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.receipt-summary-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;text-align:center}.receipt-summary-card__value{color:#1e293b;font-size:1.5rem;font-weight:700}.receipt-summary-card__label{color:#64748b;font-size:.75rem;margin-top:.25rem}.receipt-config{align-items:center;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;display:flex;gap:1rem;padding:1rem}.receipt-config__label{color:#92400e;font-size:.875rem;font-weight:500}.receipt-config input{text-align:center;width:60px}@media (max-width:1024px){.receipt-management-layout{padding:1.25rem}}@media (max-width:768px){.receipt-management-layout{gap:1rem;padding:1rem}.receipt-management-header__title-row{align-items:flex-start;flex-direction:column}.receipt-management-tabs{overflow-x:auto;width:100%}.receipt-management-tab-btn{flex:1 1;font-size:.8125rem;padding:.625rem .5rem;text-align:center;white-space:nowrap}.receipt-form-row{grid-template-columns:1fr}.receipt-table{display:block;overflow-x:auto}.receipt-summary-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.receipt-management-layout{padding:.75rem}.receipt-management-header h2{font-size:1.25rem}.receipt-management-tab-btn{font-size:.75rem;padding:.5rem}.receipt-panel{padding:1rem}.receipt-summary-grid{grid-template-columns:1fr}}.reports-generator-container{font-family:Arboria,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0 auto;max-width:1200px;padding:20px}.reports-generator-container h2{color:#2c3e50;font-size:2rem;margin-bottom:30px;text-align:center}.report-config-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:30px}.report-config-section h3{border-bottom:2px solid #3498db;color:#2c3e50;font-size:1.3rem;margin:0 0 25px;padding-bottom:10px}.config-form{display:flex;flex-direction:column;gap:25px}.config-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.config-group{display:flex;flex-direction:column}.config-group label{color:#2c3e50;font-size:.95rem;font-weight:600;margin-bottom:8px}.config-group select{background:#fff;border:2px solid #e0e6ed;border-radius:6px;font-size:1rem;padding:12px;transition:border-color .3s ease}.config-group select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.config-actions{display:flex;justify-content:center;margin-top:10px}.generate-btn{background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;min-width:200px;padding:15px 30px;transition:all .3s ease}.generate-btn:hover:not(:disabled){background:linear-gradient(135deg,#2980b9,#1f5f8b);box-shadow:0 4px 15px #3498db4d;transform:translateY(-2px)}.generate-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.message{border-radius:8px;font-weight:500;margin:20px 0;padding:15px;text-align:center}.message.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.report-preview-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:30px}.report-preview{margin-bottom:25px}.report-preview h4{border-bottom:2px solid #e74c3c;color:#2c3e50;font-size:1.2rem;margin:0 0 20px;padding-bottom:10px}.preview-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:25px}.preview-stat{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;justify-content:space-between;padding:20px}.preview-stat span{color:#6c757d;font-size:.95rem}.preview-stat strong{color:#2c3e50;font-size:1.2rem;font-weight:700}.preview-table{margin-top:20px}.preview-table h5{color:#2c3e50;font-size:1rem;margin:0 0 15px}.preview-table table{border:1px solid #e0e6ed;border-collapse:collapse;border-radius:6px;overflow:hidden;width:100%}.preview-table th{background:#f8f9fa;border-bottom:1px solid #e0e6ed;color:#2c3e50;font-weight:600;padding:12px;text-align:left}.preview-table td{border-bottom:1px solid #f0f0f0;color:#495057;padding:12px}.preview-table tbody tr:hover{background-color:#f8f9fa}.preview-actions{border-top:1px solid #e9ecef;display:flex;justify-content:center;margin-top:20px;padding-top:20px}.download-btn{background:linear-gradient(135deg,#27ae60,#2ecc71);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.download-btn:hover{background:linear-gradient(135deg,#229954,#28b463);box-shadow:0 4px 15px #2ecc714d;transform:translateY(-2px)}.info-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:30px}.info-section h3{border-bottom:2px solid #f39c12;color:#2c3e50;font-size:1.3rem;margin:0 0 20px;padding-bottom:10px}.info-content{color:#495057;line-height:1.6}.info-content ul{margin:15px 0;padding-left:20px}.info-content li{margin-bottom:8px}.info-content strong{color:#2c3e50}.info-content p{color:#2c3e50;font-weight:600;margin:15px 0 5px}@media (max-width:768px){.reports-generator-container{padding:15px}.config-row,.preview-stats{grid-template-columns:1fr}.preview-stat{flex-direction:column;gap:8px;text-align:center}.preview-table{overflow-x:auto}.preview-table table{min-width:400px}.generate-btn{min-width:auto;width:100%}}@media (max-width:480px){.reports-generator-container h2{font-size:1.5rem}.info-section,.report-config-section,.report-preview-section{padding:20px}.config-group select{padding:10px}.generate-btn{font-size:1rem;padding:12px 20px}}.mc-calendar__grid{grid-gap:1px;background:#e2e8f0;border-radius:8px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);overflow:hidden}.mc-calendar__day-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#1e293b;font-size:.85rem;font-weight:600;padding:10px 8px;text-align:center}.mc-calendar__day{background:#fff;display:flex;flex-direction:column;min-height:90px;padding:8px;position:relative;transition:all .2s ease}.mc-calendar__day:hover{background:#f1f5f9}.mc-calendar__day--today{background:#eff6ff;box-shadow:inset 0 0 0 2px #3b82f6}.mc-calendar__day--other-month{background:#f8fafc;opacity:.5}.mc-calendar__day--holiday{background:#fefce8;border-left:3px solid #f59e0b}.mc-calendar__day--holiday.mc-calendar__day--other-month{background:#f8fafc;border-left:3px solid #d1d5db;opacity:.5}.mc-calendar__day--past{cursor:default!important;opacity:.5}.mc-calendar__day--past:hover{background:inherit}.mc-calendar__day--has-entries{border-left:3px solid #22c55e}.mc-calendar__day-number{color:#1e293b;font-size:14px;font-weight:500}.mc-calendar__holiday-tag{color:#d97706;font-size:11px;font-weight:700;opacity:.7;position:absolute;right:6px;top:6px}@media (max-width:768px){.mc-calendar__day{min-height:70px;padding:4px}}:root{--bg-base:#fff;--bg-alt:#f8fafc;--text-primary:#1e293b;--text-secondary:#64748b;--border-color:#e2e8f0;--hover-bg:#f1f5f9;--active-bg:#e0f2fe;--error-bg:#fef2f2;--success-bg:#f0fdf4;--shadow-subtle:0 1px 3px #0000000f;--shadow-hover:0 4px 12px #0000001a,0 2px 6px #0000000f;--radius:12px;--transition:all 0.2s ease}.room-calendar-view{background:#f8fafc;background:var(--bg-alt);display:flex;flex-direction:column;gap:16px;margin:0 auto;max-width:1400px;min-height:calc(100vh - 140px);padding:24px}.room-calendar-header{margin-bottom:4px}.room-calendar-header h2{color:#1e293b;color:var(--text-primary);font-size:1.8rem;font-weight:600;margin:0}.room-calendar-content{display:flex;flex:1 1;gap:20px;min-height:0}.calendar-main-area{flex:1 1;min-width:0}.calendar-nav-bar{align-items:center;background:#fff;background:var(--bg-base);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-subtle);display:flex;gap:16px;justify-content:space-between;padding:12px 20px}.calendar-controls{display:flex;gap:8px}.btn-nav,.btn-today{background:#fff;background:var(--bg-base);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:500;padding:8px 14px;transition:all .2s ease;transition:var(--transition)}.btn-nav:hover,.btn-today:hover{background:#f1f5f9;background:var(--hover-bg);border-color:#64748b;border-color:var(--text-secondary);color:#1e293b;color:var(--text-primary)}.btn-today{font-weight:600}.calendar-nav-label h4{color:#1e293b;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0;white-space:nowrap}.view-toggle{border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;display:flex;gap:0;overflow:hidden}.view-toggle-btn{background:#fff;background:var(--bg-base);border:none;border-right:1px solid #e2e8f0;border-right:1px solid var(--border-color);color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:500;padding:8px 16px;transition:all .2s ease;transition:var(--transition)}.view-toggle-btn:last-child{border-right:none}.view-toggle-btn:hover{background:#f1f5f9;background:var(--hover-bg);color:#1e293b;color:var(--text-primary)}.view-toggle-btn.active{background:#1e293b;background:var(--text-primary);color:#fff;color:var(--bg-base);font-weight:600}.error-message{align-items:center;background:#fef2f2;background:var(--error-bg);border:1px solid #fecaca;border-radius:12px;border-radius:var(--radius);color:#dc2626;display:flex;font-size:.9rem;justify-content:space-between;padding:12px 16px}.btn-retry{background:#64748b;background:var(--text-secondary);border:none;border-radius:6px;color:#fff;color:var(--bg-base);cursor:pointer;font-size:.85rem;font-weight:500;padding:6px 14px;transition:all .2s ease;transition:var(--transition)}.btn-retry:hover{background:#1e293b;background:var(--text-primary)}.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;height:300px;justify-content:center}.loading-spinner{border:4px solid #e2e8f0;border-top:4px solid #64748b;border:4px solid var(--border-color);border-top-color:var(--text-secondary)}.weekly-view{background:#fff;background:var(--bg-base);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-subtle);overflow:hidden}.weekly-grid{display:flex;flex-direction:column}.weekly-header{border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border-color);display:flex;overflow-y:scroll;scrollbar-color:#0000 #f8fafc;scrollbar-color:#0000 var(--bg-alt)}.weekly-header::-webkit-scrollbar{background:#f8fafc;background:var(--bg-alt)}.weekly-header::-webkit-scrollbar-thumb{background:#0000}.weekly-time-header{min-width:60px;width:60px}.weekly-day-header,.weekly-time-header{background:#f8fafc;background:var(--bg-alt)}.weekly-day-header{border-left:1px solid #e2e8f0;border-left:1px solid var(--border-color);flex:1 1;padding:12px 8px;text-align:center}.weekly-day-header.today{background:#e0f2fe;background:var(--active-bg)}.weekly-day-header.holiday{background:#fefce8}.weekly-holiday-tag{color:#b45309;display:block;font-size:.65rem;font-weight:500;margin-top:2px}.weekly-day-name{color:#64748b;color:var(--text-secondary);display:block;font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.weekly-day-number{color:#1e293b;color:var(--text-primary);display:block;font-size:1.2rem;font-weight:700;margin-top:2px}.weekly-day-header.today .weekly-day-number{color:#2563eb}.weekly-body{display:flex;max-height:calc(100vh - 340px);min-height:480px;overflow-y:auto;position:relative}.weekly-time-column{background:#f8fafc;background:var(--bg-alt);border-right:1px solid #e2e8f0;border-right:1px solid var(--border-color);min-width:60px;width:60px}.weekly-time-label{align-items:flex-start;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#64748b;color:var(--text-secondary);display:flex;font-size:.75rem;font-weight:500;height:60px;justify-content:center;padding-top:2px}.weekly-day-column{border-left:1px solid #e2e8f0;border-left:1px solid var(--border-color);flex:1 1;position:relative}.weekly-hour-slot{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);cursor:pointer;height:60px;transition:background .15s ease}.weekly-hour-slot:hover{background:#f1f5f9;background:var(--hover-bg)}.weekly-hour-slot.past{cursor:default}.weekly-hour-slot.past,.weekly-hour-slot.past:hover{background:repeating-linear-gradient(-45deg,#0000,#0000 4px,#00000008 0,#00000008 8px)}.weekly-reservation-block{border-radius:6px;box-shadow:0 1px 3px #00000026;color:#fff;cursor:pointer;font-size:.75rem;left:2px;overflow:hidden;padding:4px 6px;position:absolute;right:2px;transition:opacity .15s ease;z-index:2}.weekly-reservation-block:hover{box-shadow:0 2px 6px #00000040;opacity:.9}.weekly-res-time{font-weight:600}.weekly-res-room,.weekly-res-time{font-size:.7rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.weekly-res-room{opacity:.9}.weekly-res-user{font-size:.65rem;opacity:.8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-section{background:#fff;background:var(--bg-base);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-subtle);display:flex;flex-direction:column;overflow:hidden}.calendar-container{flex:1 1;padding:16px}.calendar-grid{grid-gap:1px;background:#e2e8f0;background:var(--border-color);border-radius:8px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);overflow:hidden}.calendar-day-header{background:#f8fafc;background:var(--bg-alt);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#1e293b;color:var(--text-primary);font-size:.85rem;font-weight:600;padding:10px 8px;text-align:center}.calendar-day{background:#fff;background:var(--bg-base);cursor:pointer;display:flex;flex-direction:column;min-height:90px;padding:8px;position:relative;transition:all .2s ease;transition:var(--transition)}.calendar-day:hover{background:#f1f5f9;background:var(--hover-bg)}.calendar-day.today{background:#eff6ff;box-shadow:inset 0 0 0 2px #3b82f6}.calendar-day.other-month{background:#f8fafc;background:var(--bg-alt);opacity:.5}.calendar-day.has-reservations{border-left:3px solid #22c55e}.calendar-day.holiday{background:#fefce8;border-left:3px solid #f59e0b}.calendar-day.holiday.other-month{background:#f8fafc;background:var(--bg-alt);border-left:3px solid #d1d5db;opacity:.5}.calendar-day.past{cursor:default;opacity:.5}.calendar-day.past:hover{background:inherit}.day-number{color:#1e293b;color:var(--text-primary);font-size:14px;font-weight:500}.holiday-indicator{color:#d97706;font-size:11px;font-weight:700;opacity:.7;position:absolute;right:6px;top:6px}.day-reservations{align-items:center;display:flex;flex-wrap:wrap;gap:3px;margin-top:6px}.reservation-dot{border-radius:50%;flex-shrink:0;height:8px;transition:transform .15s ease;width:8px}.reservation-dot:hover{transform:scale(1.4)}.reservation-dot--own{box-shadow:0 0 0 2px #fff,0 0 0 3px currentColor;box-shadow:0 0 0 2px var(--bg-base),0 0 0 3px currentColor}.dot-picker-popup{animation:modalSlideIn .15s ease;background:#fff;background:var(--bg-base);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #0000001a,0 2px 6px #0000000f;box-shadow:var(--shadow-hover);min-width:160px;padding:6px 0}.dot-picker-title{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#64748b;color:var(--text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:6px 12px;text-transform:uppercase}.dot-picker-item{background:none;border:none;color:#1e293b;color:var(--text-primary);cursor:pointer;display:block;font-size:.85rem;padding:8px 12px;text-align:left;transition:background .15s ease;width:100%}.dot-picker-item:hover{background:#f1f5f9;background:var(--hover-bg)}.rooms-panel{background:#fff;background:var(--bg-base);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-subtle);display:flex;flex-direction:column;max-height:calc(100vh - 280px);min-width:280px;width:280px}.rooms-panel-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:18px 20px}.rooms-panel-header h3{color:#1e293b;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0}.btn-primary.btn-small{align-items:center;background:#3b82f6;border:1px solid #0000;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.btn-primary.btn-small:hover{background:#2563eb}.error-message-small,.success-message-small{font-size:.85rem;margin:0;padding:10px 20px}.error-message-small{background:#fef2f2;background:var(--error-bg);color:#dc2626}.error-message-small,.success-message-small{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color)}.success-message-small{background:#f0fdf4;background:var(--success-bg);color:#16a34a}.rooms-filter{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);padding:12px 20px}.room-checkbox-label{align-items:center;color:#1e293b;color:var(--text-primary);cursor:pointer;display:flex;font-size:.9rem;gap:8px;-webkit-user-select:none;user-select:none}.room-checkbox-label input[type=checkbox]{accent-color:#1e293b;accent-color:var(--text-primary);cursor:pointer;flex-shrink:0;height:16px;margin:0;width:16px}.room-color-dot{border:1px solid #0000001a;border-radius:50%;flex-shrink:0;height:12px;width:12px}.room-checkbox-text{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rooms-list-panel{flex:1 1;overflow-y:auto;padding:4px 0}.no-rooms{color:#64748b;color:var(--text-secondary);font-style:italic;padding:30px 20px;text-align:center}.room-item{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);padding:12px 20px;transition:all .2s ease;transition:var(--transition)}.room-item:hover{background:#f1f5f9;background:var(--hover-bg)}.room-item.selected{background:#e0f2fe;background:var(--active-bg)}.room-details-small{color:#64748b;color:var(--text-secondary);font-size:.78rem;margin-left:36px;margin-top:4px}.room-capacity-small{margin-bottom:2px}.room-resources-small{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-actions-small{display:flex;gap:6px;margin-left:36px;margin-top:6px;opacity:0;transition:opacity .2s}.room-item:hover .room-actions-small{opacity:1}.btn-delete-small,.btn-edit-small{background:#fff;background:var(--bg-base);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:4px;color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:12px;padding:4px 8px;transition:all .2s ease;transition:var(--transition)}.btn-edit-small:hover{background:#e0f2fe;background:var(--active-bg);color:#1e293b;color:var(--text-primary)}.btn-delete-small:hover{background:#fef2f2;background:var(--error-bg);color:#dc2626}.reservation-history{background:#fff;background:var(--bg-base);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius);box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-subtle);padding:20px}.history-title{color:#1e293b;color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 12px}.history-empty{color:#64748b;color:var(--text-secondary);font-size:.9rem;font-style:italic;margin:0}.history-table-wrapper{overflow-x:auto}.history-table{border-collapse:collapse;font-size:.85rem;width:100%}.history-table thead th{border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border-color);color:#64748b;color:var(--text-secondary);font-size:.8rem;font-weight:600;letter-spacing:.04em;padding:8px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.history-table tbody td{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#1e293b;color:var(--text-primary);padding:10px 12px;white-space:nowrap}.history-table tbody tr:hover{background:#f1f5f9;background:var(--hover-bg)}.history-table tbody tr:last-child td{border-bottom:none}.history-room-badge{align-items:center;background:#f8fafc;background:var(--bg-alt);border-left:3px solid;border-radius:0 4px 4px 0;display:inline-flex;font-size:.85rem;font-weight:500;gap:6px;padding:4px 10px}.history-recurring-badge{color:#64748b;color:var(--text-secondary);cursor:help;font-size:1rem;margin-left:4px}.btn-cancel-small{background:#fff;background:var(--bg-base);border:1px solid #fecaca;border-radius:6px;color:#dc2626;cursor:pointer;font-size:.8rem;font-weight:500;padding:5px 12px;transition:all .2s ease;transition:var(--transition);white-space:nowrap}.btn-cancel-small:hover:not(:disabled){background:#fef2f2;background:var(--error-bg);border-color:#dc2626}.btn-cancel-small:disabled{cursor:not-allowed;opacity:.5}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073}.modal-content{background:var(--bg-base);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:0 4px 12px #0000001a,0 2px 6px #0000000f;box-shadow:var(--shadow-hover);max-height:85vh;max-width:500px;width:90%}.day-action-modal{max-width:560px}.modal-header{border-bottom:1px solid var(--border-color);padding:16px 20px}.modal-header h3{color:#1e293b;color:var(--text-primary);font-size:1.1rem}.modal-close{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;transition:all .2s ease;transition:var(--transition);width:30px}.modal-close:hover{background:#f1f5f9;background:var(--hover-bg);color:#1e293b;color:var(--text-primary)}.modal-body{padding:20px}.reservation-form-container{max-width:100%}.reservation-form{display:flex;flex-direction:column;gap:14px}.form-group label{color:#1e293b;color:var(--text-primary);font-size:.85rem}.form-group input,.form-group select,.form-group textarea{background:#fff;background:var(--bg-base);border:1px solid var(--border-color);box-sizing:border-box;color:#1e293b;color:var(--text-primary);font-size:.9rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61f}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#dc2626}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1 1}.error-text{font-size:.78rem}.checkbox-label{align-items:center;cursor:pointer;display:flex!important;flex-direction:row!important;font-weight:500;gap:8px}.checkbox-label input[type=checkbox]{accent-color:#1e293b;accent-color:var(--text-primary);cursor:pointer;height:16px;width:16px!important}.recurring-check{background:#f8fafc;background:var(--bg-alt);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;padding:10px 14px;transition:all .2s ease;transition:var(--transition);-webkit-user-select:none;user-select:none}.recurring-check:hover{background:#f1f5f9;background:var(--hover-bg);border-color:#64748b;border-color:var(--text-secondary)}.recurring-check input[type=checkbox]{display:none!important}.recurring-check .recurring-toggle-track{background:#e2e8f0;background:var(--border-color);border-radius:10px;display:inline-block;flex-shrink:0;height:20px;position:relative;transition:background .2s ease;vertical-align:middle;width:36px}.recurring-check .recurring-toggle-track:after{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;content:"";height:16px;left:2px;position:absolute;top:2px;transition:transform .2s ease;width:16px}.recurring-check input[type=checkbox]:checked+.recurring-toggle-track{background:#3b82f6}.recurring-check input[type=checkbox]:checked+.recurring-toggle-track:after{transform:translateX(16px)}.recurring-section{background:#f8fafc;background:var(--bg-alt);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;display:flex;flex-direction:column;gap:12px;padding:14px}.dias-selector{display:flex;flex-wrap:wrap;gap:6px}.dia-btn{background:#fff;background:var(--bg-base);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:.8rem;font-weight:500;padding:6px 12px;transition:all .2s ease;transition:var(--transition)}.dia-btn:hover{background:#f1f5f9;background:var(--hover-bg);border-color:#64748b;border-color:var(--text-secondary);color:#1e293b;color:var(--text-primary)}.dia-btn.active{background:#1e293b;background:var(--text-primary);border-color:#1e293b;border-color:var(--text-primary);color:#fff;color:var(--bg-base)}.form-actions{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);display:flex;gap:10px;justify-content:flex-end;margin-top:8px;padding-top:14px}.btn-cancel,.btn-submit{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:all .2s ease;transition:var(--transition)}.btn-cancel{background:#f8fafc;background:var(--bg-alt);border-color:#e2e8f0;border-color:var(--border-color);color:#64748b;color:var(--text-secondary)}.btn-cancel:hover:not(:disabled){background:#f1f5f9;background:var(--hover-bg);color:#1e293b;color:var(--text-primary)}.btn-submit{background:#3b82f6;color:#fff}.btn-submit:hover:not(:disabled){background:#2563eb}.btn-cancel:disabled,.btn-submit:disabled{cursor:not-allowed;opacity:.6}.modal-content h3{color:#1e293b;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0;padding:20px 20px 0}.modal-content form{padding:16px 20px 20px}.modal-content form .form-group{margin-bottom:14px}.btn-primary,.btn-secondary{border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:all .2s ease;transition:var(--transition)}.btn-primary{background:#1e293b;background:var(--text-primary);border-color:#1e293b;border-color:var(--text-primary);color:var(--bg-base)}.btn-primary:hover{background:#64748b;background:var(--text-secondary)}.btn-secondary{background:var(--bg-base);color:#64748b;color:var(--text-secondary)}.btn-secondary:hover{background:#f1f5f9;background:var(--hover-bg);color:#1e293b;color:var(--text-primary)}@media (max-width:1024px){.room-calendar-content{flex-direction:column}.rooms-panel{max-height:250px;min-width:0;min-width:auto;width:100%}.calendar-nav-bar{flex-wrap:wrap;gap:10px}}@media (max-width:768px){.room-calendar-view{gap:10px;padding:12px}.calendar-nav-bar{align-items:stretch;flex-direction:column;gap:8px}.calendar-controls{justify-content:center}.calendar-nav-label{text-align:center}.view-toggle{align-self:center}.calendar-day{min-height:70px;padding:4px}.weekly-body{min-height:400px}.weekly-time-column,.weekly-time-header,.weekly-time-label{min-width:45px;width:45px}.history-table{font-size:.8rem}.modal-content{max-height:90vh;width:95%}}.cancel-series-dialog{animation:modalSlideIn .2s ease;max-width:440px}.cancel-series-options{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.cancel-series-option{align-items:flex-start;border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px 14px;transition:all .2s ease;transition:var(--transition)}.cancel-series-option:hover{background:#f1f5f9;background:var(--hover-bg);border-color:#64748b;border-color:var(--text-secondary)}.cancel-series-option input[type=radio]{accent-color:#dc2626;flex-shrink:0;height:16px;margin-top:2px;width:16px}.cancel-series-option div{display:flex;flex-direction:column;gap:2px}.cancel-series-option strong{color:#1e293b;color:var(--text-primary);font-size:.9rem}.cancel-series-option span{color:#64748b;color:var(--text-secondary);font-size:.8rem}.my-surveys{margin:0 auto;max-width:1200px}.my-surveys__title{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0 0 24px}.my-surveys__loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:60px 20px}.my-surveys__table-wrapper{border:1px solid #e2e8f0;border-radius:8px;overflow-x:auto}.my-surveys__table{border-collapse:collapse;font-size:.875rem;width:100%}.my-surveys__table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.my-surveys__table td{border-bottom:1px solid #f1f5f9;color:#1e293b;padding:12px 16px;vertical-align:middle}.my-surveys__table tbody tr:hover{background:#fafbfc}.my-surveys__table tbody tr:last-child td{border-bottom:none}.my-surveys__badge{align-items:center;border-radius:4px;display:inline-flex;font-size:.75rem;font-weight:500;padding:4px 10px;white-space:nowrap}.my-surveys__badge--activa{background:#dcfce7;color:#166534}.my-surveys__badge--completa{background:#dbeafe;color:#1e40af}.my-surveys__badge--cerrada{background:#fee2e2;color:#991b1b}.my-surveys__btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.8rem;font-weight:500;gap:6px;justify-content:center;padding:6px 14px;transition:all .15s}.my-surveys__btn--primary{background:#3b82f6;color:#fff}.my-surveys__btn--primary:hover{background:#2563eb}.my-surveys__btn--outline{background:#fff;border-color:#3b82f6;color:#3b82f6}.my-surveys__btn--outline:hover{background:#eff6ff}.my-surveys__empty{align-items:center;color:#94a3b8;display:flex;flex-direction:column;font-size:.9rem;gap:8px;justify-content:center;padding:60px 20px}@media (max-width:768px){.my-surveys__table{font-size:.8rem}.my-surveys__table td,.my-surveys__table th{padding:10px 12px}.my-surveys__title{font-size:1.25rem}}@media (max-width:640px){.my-surveys__table td:nth-child(2),.my-surveys__table th:nth-child(2){display:none}}.survey-builder{display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;gap:1.5rem;margin:0 auto;max-width:960px;padding:1.5rem}.survey-builder__topbar{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end;padding-bottom:.5rem}.survey-builder__btn{border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1.25rem;transition:background-color .2s,opacity .2s}.survey-builder__btn:disabled{cursor:not-allowed;opacity:.55}.survey-builder__btn--primary{background-color:#2563eb;color:#fff}.survey-builder__btn--primary:hover:not(:disabled){background-color:#1d4ed8}.survey-builder__btn--secondary{background-color:#f1f5f9;border:1px solid #cbd5e1;color:#334155}.survey-builder__btn--secondary:hover:not(:disabled){background-color:#e2e8f0}.survey-builder__config{background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.survey-builder__config-title{color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 .25rem}.survey-builder__field{display:flex;flex-direction:column;gap:.3rem}.survey-builder__field label{color:#475569;font-size:.8125rem;font-weight:500}.survey-builder__field input[type=date],.survey-builder__field input[type=number],.survey-builder__field input[type=text],.survey-builder__field select{background:#fff;border:1px solid #cbd5e1;border-radius:6px;color:#1e293b;font-size:.875rem;outline:none;padding:.5rem .625rem;transition:border-color .15s}.survey-builder__field input:focus,.survey-builder__field select:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1f}.survey-builder__row{display:flex;flex-wrap:wrap;gap:1rem}.survey-builder__row>.survey-builder__field{flex:1 1;min-width:180px}.survey-builder__checkbox-label{align-items:center;color:#334155;cursor:pointer;display:flex;font-size:.875rem;gap:.4rem}.survey-builder__checkbox-label input[type=checkbox]{accent-color:#2563eb;height:16px;width:16px}.survey-builder__radio-group{align-items:center;display:flex;gap:1.25rem}.survey-builder__radio-label{align-items:center;color:#334155;cursor:pointer;display:flex;font-size:.875rem;gap:.35rem}.survey-builder__radio-label input[type=radio]{accent-color:#2563eb}.survey-builder__conditional-fields{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;flex-direction:column;gap:.75rem;padding:.75rem}.survey-builder__filters{background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.survey-builder__filters-title{color:#1e293b;font-size:1rem;font-weight:600;margin:0}.survey-builder__filters-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.survey-builder__multi-select{position:relative}.survey-builder__multi-select-toggle{align-items:center;background:#fff;border:1px solid #cbd5e1;border-radius:6px;color:#1e293b;cursor:pointer;display:flex;font-size:.8125rem;justify-content:space-between;min-height:38px;padding:.5rem .625rem;text-align:left;width:100%}.survey-builder__multi-select-toggle:after{border-left:4px solid #0000;border-right:4px solid #0000;border-top:5px solid #64748b;content:"";flex-shrink:0;margin-left:.5rem}.survey-builder__multi-select-dropdown{background:#fff;border:1px solid #cbd5e1;border-radius:6px;box-shadow:0 4px 12px #0000001a;left:0;margin-top:2px;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:50}.survey-builder__multi-select-option{align-items:center;cursor:pointer;display:flex;font-size:.8125rem;gap:.4rem;padding:.4rem .625rem;transition:background-color .1s}.survey-builder__multi-select-option:hover{background-color:#f1f5f9}.survey-builder__multi-select-badges{display:flex;flex-wrap:wrap;gap:.25rem;max-width:calc(100% - 20px);overflow:hidden}.survey-builder__badge{align-items:center;background:#dbeafe;border-radius:4px;color:#1e40af;display:inline-flex;font-size:.7rem;gap:.2rem;padding:.15rem .4rem;white-space:nowrap}.survey-builder__badge-remove{color:#3b82f6;cursor:pointer;font-size:.75rem;font-weight:700;line-height:1}.survey-builder__badge-remove:hover{color:#1d4ed8}.survey-builder__questions{display:flex;flex-direction:column;gap:1rem}.survey-builder__questions-title{color:#1e293b;font-size:1rem;font-weight:600;margin:0}.survey-builder__question-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:.75rem;padding:1rem 1.25rem;transition:box-shadow .15s}.survey-builder__question-card:hover{box-shadow:0 2px 8px #0000000f}.survey-builder__question-card--dragging{border:2px dashed #94a3b8;opacity:.5}.survey-builder__question-header{align-items:center;display:flex;gap:.5rem}.survey-builder__drag-handle{color:#94a3b8;cursor:grab;flex-shrink:0;font-size:1.1rem;-webkit-user-select:none;user-select:none}.survey-builder__question-number{background:#eff6ff;border-radius:4px;color:#2563eb;flex-shrink:0;font-size:.8125rem;font-weight:600;padding:.15rem .5rem}.survey-builder__question-type-label{background:#f1f5f9;border-radius:4px;color:#64748b;flex-shrink:0;font-size:.75rem;padding:.15rem .5rem}.survey-builder__question-actions{align-items:center;display:flex;gap:.5rem;margin-left:auto}.survey-builder__question-action-btn{background:none;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;font-size:1rem;padding:.25rem;transition:color .15s,background-color .15s}.survey-builder__question-action-btn:hover{background-color:#fef2f2;color:#ef4444}.survey-builder__question-action-btn--duplicate:hover{background-color:#eff6ff;color:#2563eb}.survey-builder__question-text-input{border:1px solid #cbd5e1;border-radius:6px;color:#1e293b;font-size:.9rem;outline:none;padding:.5rem .625rem;transition:border-color .15s;width:100%}.survey-builder__question-text-input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1f}.survey-builder__question-footer{align-items:center;display:flex;justify-content:flex-end}.survey-builder__switch-label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.survey-builder__switch-text{color:#334155;font-size:.875rem;font-weight:500}.survey-builder__switch{background:#cbd5e1;border-radius:11px;cursor:pointer;flex-shrink:0;height:22px;position:relative;transition:background-color .2s;width:40px}.survey-builder__switch:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.survey-builder__switch--active{background:#2563eb}.survey-builder__switch-thumb{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;height:18px;left:2px;position:absolute;top:2px;transition:transform .2s;width:18px}.survey-builder__switch--active .survey-builder__switch-thumb{transform:translateX(18px)}.survey-builder__options-list{display:flex;flex-direction:column;gap:.5rem;padding-left:.25rem}.survey-builder__option-row{align-items:center;display:flex;gap:.5rem}.survey-builder__option-input{border:1px solid #e2e8f0;border-radius:5px;color:#1e293b;flex:1 1;font-size:.8125rem;outline:none;padding:.4rem .5rem}.survey-builder__option-input:focus{border-color:#2563eb}.survey-builder__option-remove{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:1.1rem;line-height:1;padding:0}.survey-builder__option-remove:hover{color:#ef4444}.survey-builder__option-jump{background:#f8fafc;border:1px solid #e2e8f0;border-radius:5px;color:#475569;font-size:.75rem;min-width:100px;padding:.3rem .4rem}.survey-builder__add-option-btn{align-self:flex-start;background:none;border:1px dashed #cbd5e1;border-radius:5px;color:#2563eb;cursor:pointer;font-size:.8125rem;padding:.35rem .75rem;transition:background-color .15s}.survey-builder__add-option-btn:hover{background-color:#eff6ff}.survey-builder__type-config{color:#64748b;font-size:.8125rem;padding:.5rem 0}.survey-builder__type-config--hint{background:#f8fafc;border-left:3px solid #cbd5e1;border-radius:5px;font-style:italic;padding:.5rem .75rem}.survey-builder__scale-select{border:1px solid #cbd5e1;border-radius:5px;font-size:.8125rem;padding:.4rem .5rem;width:auto}.survey-builder__likert-table{border-collapse:collapse;font-size:.8125rem;width:100%}.survey-builder__likert-table td,.survey-builder__likert-table th{border:1px solid #e2e8f0;padding:.35rem .5rem;text-align:center}.survey-builder__likert-table th{background:#f8fafc;color:#475569;font-weight:500}.survey-builder__likert-table input{background:#0000;border:none;font-size:.8125rem;outline:none;text-align:center;width:100%}.survey-builder__likert-table input:focus{background:#eff6ff}.survey-builder__likert-actions{display:flex;gap:.5rem;margin-top:.35rem}.survey-builder__likert-btn{background:none;border:1px dashed #cbd5e1;border-radius:5px;color:#2563eb;cursor:pointer;font-size:.75rem;padding:.3rem .6rem}.survey-builder__likert-btn:hover{background-color:#eff6ff}.survey-builder__add-question{align-self:center;position:relative}.survey-builder__add-question-btn{align-items:center;background:#eff6ff;border:1px dashed #93c5fd;border-radius:8px;color:#2563eb;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.4rem;padding:.6rem 1.25rem;transition:background-color .15s}.survey-builder__add-question-btn:hover{background-color:#dbeafe}.survey-builder__question-type-menu{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 16px #0000001f;left:50%;margin-top:4px;min-width:220px;overflow:hidden;position:absolute;top:100%;transform:translateX(-50%);z-index:60}.survey-builder__question-type-option{background:none;border:none;color:#334155;cursor:pointer;display:block;font-size:.8125rem;padding:.55rem 1rem;text-align:left;transition:background-color .1s;width:100%}.survey-builder__question-type-option:hover{background-color:#f1f5f9;color:#2563eb}.survey-builder__loading{align-items:center;color:#64748b;display:flex;font-size:.9rem;justify-content:center;padding:4rem}@media (max-width:768px){.survey-builder{padding:1rem}.survey-builder__topbar{flex-wrap:wrap}.survey-builder__row{flex-direction:column}.survey-builder__filters-grid{grid-template-columns:1fr}.survey-builder__question-header{flex-wrap:wrap}.survey-builder__radio-group{align-items:flex-start;flex-direction:column;gap:.5rem}.survey-builder__option-row{flex-wrap:wrap}.survey-builder__option-jump{width:100%}}@media (max-width:480px){.survey-builder__btn{font-size:.8125rem;padding:.45rem .75rem}.survey-builder__question-card{padding:.75rem}}.survey-charts{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1200px;padding:1.5rem}.survey-charts__header{border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem;padding-bottom:1rem}.survey-charts__title{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0 0 .25rem}.survey-charts__subtitle{color:#64748b;font-size:.875rem;margin:0}.survey-charts__loading{color:#64748b}.survey-charts__empty,.survey-charts__loading{align-items:center;display:flex;font-size:1rem;justify-content:center;min-height:300px}.survey-charts__empty{color:#94a3b8;flex-direction:column;gap:.5rem;text-align:center}.survey-charts__empty-icon{font-size:2.5rem;opacity:.5}.survey-charts__grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.survey-charts__card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column;padding:1.25rem}.survey-charts__card-order{color:#94a3b8;font-size:.75rem;font-weight:500;margin-bottom:.25rem}.survey-charts__card-title{color:#334155;font-size:.95rem;font-weight:600;line-height:1.4;margin:0 0 1rem}.survey-charts__card-average{color:#2563eb;font-size:1.1rem;font-weight:600;margin-bottom:.75rem;text-align:center}.survey-charts__wordcloud{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;min-height:120px;padding:1rem}.survey-charts__word{border-radius:4px;cursor:default;display:inline-block;font-weight:500;line-height:1.3;padding:.15rem .4rem;transition:opacity .2s}.survey-charts__word:hover{opacity:.8}.survey-charts__likert-table{border-collapse:collapse;font-size:.8rem;width:100%}.survey-charts__likert-table th{background:#f8fafc;border-bottom:2px solid #e2e8f0;color:#475569;font-weight:600;padding:.5rem .6rem;text-align:center;white-space:nowrap}.survey-charts__likert-table th:first-child{min-width:140px;text-align:left}.survey-charts__likert-table td{border-bottom:1px solid #f1f5f9;color:#334155;padding:.45rem .6rem;text-align:center}.survey-charts__likert-table td:first-child{color:#1e293b;font-weight:500;text-align:left}.survey-charts__likert-table tr:hover td{background:#f8fafc}.survey-charts__file-list{display:flex;flex-direction:column;gap:.5rem}.survey-charts__file-row{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;font-size:.8125rem;gap:.75rem;padding:.5rem .75rem}.survey-charts__file-user{color:#334155;flex-shrink:0;font-weight:600;min-width:140px}.survey-charts__file-name{color:#64748b;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.survey-charts__file-btn{background:#3b82f6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-decoration:none;transition:background .15s;white-space:nowrap}.survey-charts__file-btn:hover{background:#2563eb}.survey-charts__file-btn--disabled{background:#cbd5e1;color:#94a3b8;cursor:not-allowed}.survey-charts__file-btn--disabled:hover{background:#cbd5e1}.survey-charts__no-chart{align-items:center;color:#94a3b8;display:flex;font-size:.875rem;font-style:italic;justify-content:center;min-height:100px}@media (max-width:768px){.survey-charts{padding:1rem}.survey-charts__grid{gap:1rem;grid-template-columns:1fr}.survey-charts__title{font-size:1.25rem}.survey-charts__card{padding:1rem}.survey-charts__likert-table{font-size:.7rem}.survey-charts__likert-table td,.survey-charts__likert-table th{padding:.35rem .4rem}}.survey-list{gap:1.5rem;margin:0 auto;max-width:1400px;padding:1.5rem}.survey-list,.survey-list__header{display:flex;flex-direction:column}.survey-list__header{gap:.5rem}.survey-list__title-row{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding-bottom:.75rem}.survey-list__title-row h2{align-items:center;color:#1e293b;display:flex;font-size:1.5rem;font-weight:600;gap:.5rem;margin:0}.survey-list__title-row h2 svg{color:#64748b}.survey-list__btn-nueva{align-items:center;background:#3b82f6;border:1px solid #0000;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;padding:8px 18px;transition:all .15s}.survey-list__btn-nueva:hover{background:#2563eb}.survey-list__tabs{border-bottom:2px solid #e2e8f0;display:flex;gap:4px}.survey-list__tab-btn{background:#0000;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;margin-bottom:-2px;padding:.75rem 1.25rem;text-align:center;transition:all .2s ease}.survey-list__tab-btn:hover{background-color:#eff6ff;color:#2563eb}.survey-list__tab-btn--active{background-color:#f0f9ff;border-bottom-color:#2563eb;color:#2563eb;font-weight:600}.survey-list__filters{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.survey-list__filter-label{color:#475569;font-size:.875rem;font-weight:500}.survey-list__filter-select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:.875rem;min-width:200px;padding:.5rem .75rem;transition:all .2s ease}.survey-list__filter-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.survey-list__content{display:flex;flex-direction:column;gap:1.5rem}.survey-list__panel{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #00000014;padding:1.5rem}.survey-list__table{border:1px solid #e2e8f0;border-collapse:collapse;border-radius:8px;width:100%}.survey-list__table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#475569;font-size:.8125rem;font-weight:600;padding:.75rem 1rem;text-align:left;white-space:nowrap}.survey-list__table td{border-bottom:1px solid #f1f5f9;color:#1e293b;font-size:.875rem;padding:.875rem 1rem}.survey-list__table tr:last-child td{border-bottom:none}.survey-list__table tr:hover td{background:#f8fafc}.survey-list__table .survey-list__empty-row td{color:#94a3b8;font-style:italic;padding:2rem;text-align:center}.survey-list__badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:500;padding:.25rem .625rem;white-space:nowrap}.survey-list__badge--pendiente{background:#f1f5f9;color:#475569}.survey-list__badge--activa{background:#d1fae5;color:#065f46}.survey-list__badge--inactiva{background:#ffedd5;color:#9a3412}.survey-list__badge--cerrada{background:#fee2e2;color:#991b1b}.survey-list__count-cell{font-feature-settings:"tnum";align-items:center;display:inline-flex;font-variant-numeric:tabular-nums;gap:4px}.survey-list__count-cell svg{flex-shrink:0;height:16px;width:16px}.survey-list__count-cell--ok svg{color:#22c55e}.survey-list__count-cell--pending svg{color:#f59e0b}.survey-list__actions-wrapper{position:relative}.survey-list__actions-btn{align-items:center;background:#0000;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;display:inline-flex;justify-content:center;padding:.375rem;transition:all .15s}.survey-list__actions-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#475569}.survey-list__actions-menu{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #0000001f;margin-top:4px;min-width:200px;padding:4px 0;position:absolute;right:0;top:100%;z-index:50}.survey-list__actions-menu--up{bottom:100%;margin-bottom:4px;margin-top:0;top:auto}.survey-list__actions-menu button{align-items:center;background:none;border:none;color:#334155;cursor:pointer;display:flex;font-size:.8125rem;gap:8px;padding:.5rem .875rem;text-align:left;transition:background .1s;width:100%}.survey-list__actions-menu button:hover:not(:disabled){background:#f1f5f9}.survey-list__actions-menu button:disabled{color:#cbd5e1;cursor:not-allowed}.survey-list__actions-menu button svg{flex-shrink:0;height:16px;width:16px}.survey-list__error,.survey-list__loading{border-radius:8px;font-size:.875rem;padding:2rem;text-align:center}.survey-list__loading{background:#f8fafc;color:#64748b}.survey-list__error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.survey-list__empty{color:#94a3b8;padding:3rem 2rem;text-align:center}.survey-list__empty svg{height:48px;margin-bottom:1rem;opacity:.5;width:48px}.survey-list__placeholder{color:#94a3b8;font-size:1rem;padding:4rem 2rem;text-align:center}.survey-list__placeholder span{display:block;font-size:.875rem;font-style:italic;margin-top:.5rem}@media (max-width:1024px){.survey-list{padding:1.25rem}}@media (max-width:768px){.survey-list{gap:1rem;padding:1rem}.survey-list__title-row{align-items:flex-start;flex-direction:column}.survey-list__tabs{overflow-x:auto;width:100%}.survey-list__tab-btn{flex:1 1;font-size:.8125rem;padding:.625rem .5rem;text-align:center;white-space:nowrap}.survey-list__filters{align-items:stretch;flex-direction:column}.survey-list__filter-select{min-width:0;min-width:auto;width:100%}.survey-list__table{display:block;overflow-x:auto}.survey-list__panel{padding:1rem}}@media (max-width:480px){.survey-list{padding:.75rem}.survey-list__title-row h2{font-size:1.25rem}.survey-list__tab-btn{font-size:.75rem;padding:.5rem}}.survey-pendientes{margin:0 auto;max-width:800px;padding:24px}.survey-pendientes__title{color:#111827;font-size:20px;font-weight:600;margin:0 0 20px}.survey-pendientes__table{background:#fff;border:1px solid #e5e7eb;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.survey-pendientes__table td,.survey-pendientes__table th{border-bottom:1px solid #e5e7eb;padding:12px 16px;text-align:left}.survey-pendientes__table th{background:#f9fafb;color:#374151;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.survey-pendientes__table td{color:#374151;font-size:14px}.survey-pendientes__table tr:hover td{background:#f9fafb}.survey-pendientes__empty{color:#6b7280;padding:40px 20px;text-align:center}.survey-pendientes__anonymous{background:#fef3c7;border-radius:8px;color:#92400e;padding:40px 20px;text-align:center}.survey-preview{margin:0 auto;max-width:800px;padding:24px}.survey-preview__header{border-bottom:2px solid #e5e7eb;margin-bottom:32px;padding-bottom:16px;text-align:center}.survey-preview__title{color:#111827;font-size:24px;font-weight:600;margin:0 0 8px}.survey-preview__badge{background:#dbeafe;border-radius:12px;color:#1d4ed8;display:inline-block;font-size:12px;font-weight:500;padding:4px 12px}.survey-preview__question{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:16px;padding:20px}.survey-preview__question-header{align-items:flex-start;display:flex;gap:8px;margin-bottom:12px}.survey-preview__question-number{align-items:center;background:#3b82f6;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:28px;justify-content:center;width:28px}.survey-preview__question-text{color:#111827;font-size:16px;font-weight:500;margin:0}.survey-preview__required{color:#ef4444;margin-left:4px}.survey-preview__options{list-style:none;margin:0;padding:0}.survey-preview__option{align-items:center;color:#374151;display:flex;gap:8px;padding:8px 0}.survey-preview__option input{pointer-events:none}.survey-preview__text-input{background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;color:#6b7280;font-size:14px;padding:8px 12px;width:100%}.survey-preview__rating{display:flex;flex-wrap:wrap;gap:8px}.survey-preview__rating-item{align-items:center;border:2px solid #d1d5db;border-radius:8px;color:#6b7280;display:flex;font-weight:500;height:40px;justify-content:center;width:40px}.survey-preview__likert-table{border-collapse:collapse;font-size:14px;width:100%}.survey-preview__likert-table td,.survey-preview__likert-table th{border:1px solid #e5e7eb;padding:8px 12px;text-align:center}.survey-preview__likert-table th{background:#f3f4f6;color:#374151;font-weight:500}.survey-preview__likert-table td:first-child{font-weight:500;text-align:left}.survey-preview__file-placeholder{border:2px dashed #d1d5db;border-radius:8px;color:#6b7280;padding:24px;text-align:center}.survey-preview__notice{background:#fef3c7;border-radius:8px;color:#92400e;font-size:14px;margin-top:24px;padding:16px;text-align:center}.survey-respond{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:800px;padding:0 1rem}.survey-respond__loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:12px;justify-content:center;padding:80px 24px}.survey-respond__spinner{animation:survey-respond-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#3b82f6;height:36px;width:36px}@keyframes survey-respond-spin{to{transform:rotate(1turn)}}.survey-respond__success{align-items:center;background:#dcfce7;border:1px solid #86efac;border-left:4px solid #16a34a;border-radius:8px;color:#166534;display:flex;font-size:.95rem;font-weight:500;gap:12px;margin-bottom:24px;padding:16px 20px}.survey-respond__success-icon{flex-shrink:0;font-size:1.25rem}.survey-respond__header{border-bottom:2px solid #e2e8f0;margin-bottom:28px;padding-bottom:16px}.survey-respond__title{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0 0 6px}.survey-respond__subtitle{color:#64748b;font-size:.875rem;margin:0}.survey-respond__read-only-badge{background:#f1f5f9;border-radius:4px;color:#475569;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;margin-top:8px;padding:4px 10px;text-transform:uppercase}.survey-respond__questions{display:flex;flex-direction:column;gap:20px;margin-bottom:32px}.survey-respond__question-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:20px 24px;transition:box-shadow .15s}.survey-respond__question-card:hover{box-shadow:0 2px 8px #0000000d}.survey-respond__question-card--hidden{display:none}.survey-respond__question-header{align-items:flex-start;display:flex;gap:10px;margin-bottom:14px}.survey-respond__question-number{align-items:center;background:#eff6ff;border-radius:6px;color:#2563eb;display:inline-flex;flex-shrink:0;font-size:.8125rem;font-weight:600;height:28px;justify-content:center;min-width:28px}.survey-respond__question-text{color:#1e293b;font-size:.95rem;font-weight:500;line-height:1.5;margin:0;padding-top:3px}.survey-respond__required{color:#dc2626;font-weight:700;margin-left:2px}.survey-respond__options{display:flex;flex-direction:column;gap:10px;padding-left:4px}.survey-respond__option-label{align-items:center;border:1px solid #e2e8f0;border-radius:6px;color:#334155;cursor:pointer;display:flex;font-size:.875rem;gap:10px;padding:8px 12px;transition:all .15s}.survey-respond__option-label:hover{background:#f8fafc;border-color:#cbd5e1}.survey-respond__option-label--selected{background:#eff6ff;border-color:#3b82f6;color:#1e40af}.survey-respond__option-label--disabled{cursor:default;opacity:.7}.survey-respond__option-label--disabled:hover{background:#0000;border-color:#e2e8f0}.survey-respond__option-label input[type=checkbox],.survey-respond__option-label input[type=radio]{accent-color:#2563eb;flex-shrink:0;height:16px;width:16px}.survey-respond__date-input,.survey-respond__text-input,.survey-respond__textarea{background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-sizing:border-box;color:#1e293b;font-size:.875rem;padding:10px 12px;transition:border-color .15s;width:100%}.survey-respond__date-input:focus,.survey-respond__text-input:focus,.survey-respond__textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.survey-respond__textarea{font-family:inherit;min-height:100px;resize:vertical}.survey-respond__date-input{max-width:240px}.survey-respond__date-input:disabled,.survey-respond__text-input:disabled,.survey-respond__textarea:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.survey-respond__rating{display:flex;flex-wrap:wrap;gap:8px}.survey-respond__rating-item{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;height:40px;justify-content:center;transition:all .15s;-webkit-user-select:none;user-select:none;width:40px}.survey-respond__rating-item:hover{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.survey-respond__rating-item--selected{background:#3b82f6;border-color:#3b82f6;color:#fff}.survey-respond__rating-item--selected:hover{background:#2563eb;border-color:#2563eb;color:#fff}.survey-respond__rating-item--disabled{cursor:default;opacity:.7}.survey-respond__rating-item--disabled:hover{background:#fff;border-color:#e2e8f0;color:#64748b}.survey-respond__rating-item--disabled.survey-respond__rating-item--selected:hover{background:#3b82f6;border-color:#3b82f6;color:#fff}.survey-respond__likert-wrapper{border:1px solid #e2e8f0;border-radius:8px;overflow-x:auto}.survey-respond__likert-table{border-collapse:collapse;font-size:.8125rem;width:100%}.survey-respond__likert-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#475569;font-size:.75rem;font-weight:600;padding:10px 12px;text-align:center;white-space:nowrap}.survey-respond__likert-table th:first-child{min-width:160px;text-align:left}.survey-respond__likert-table td{border-bottom:1px solid #f1f5f9;padding:10px 12px;text-align:center;vertical-align:middle}.survey-respond__likert-table td:first-child{color:#334155;font-weight:500;text-align:left}.survey-respond__likert-table tbody tr:hover{background:#fafbfc}.survey-respond__likert-table tbody tr:last-child td{border-bottom:none}.survey-respond__likert-table input[type=radio]{accent-color:#2563eb;cursor:pointer;height:16px;width:16px}.survey-respond__likert-table input[type=radio]:disabled{cursor:not-allowed}.survey-respond__file-area{display:flex;flex-direction:column;gap:8px}.survey-respond__file-input-wrapper{align-items:center;display:flex;gap:12px}.survey-respond__file-label{align-items:center;background:#f1f5f9;border:1px dashed #cbd5e1;border-radius:6px;color:#475569;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .15s}.survey-respond__file-label:hover{background:#e2e8f0;border-color:#94a3b8}.survey-respond__file-label--disabled{cursor:not-allowed;opacity:.6}.survey-respond__file-label--disabled:hover{background:#f1f5f9;border-color:#cbd5e1}.survey-respond__file-hidden{display:none}.survey-respond__file-name{color:#2563eb;font-size:.8125rem;font-weight:500}.survey-respond__file-hint{color:#94a3b8;font-size:.75rem}.survey-respond__actions{display:flex;gap:12px;justify-content:flex-end;margin-bottom:32px;padding-top:8px}.survey-respond__btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;gap:6px;justify-content:center;padding:10px 24px;transition:all .15s}.survey-respond__btn:disabled{cursor:not-allowed;opacity:.6}.survey-respond__btn--primary{background:#3b82f6;color:#fff}.survey-respond__btn--primary:hover:not(:disabled){background:#2563eb}.survey-respond__btn--secondary{background:#fff;border-color:#e2e8f0;color:#475569}.survey-respond__btn--secondary:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.survey-respond--read-only .survey-respond__option-label{cursor:default;opacity:.85}.survey-respond--read-only .survey-respond__option-label:hover{background:#0000;border-color:#e2e8f0}.survey-respond--read-only .survey-respond__option-label--selected:hover{background:#eff6ff;border-color:#3b82f6}.survey-respond--read-only .survey-respond__rating-item{cursor:default}.survey-respond--read-only .survey-respond__rating-item:hover{background:#fff;border-color:#e2e8f0;color:#64748b}.survey-respond--read-only .survey-respond__rating-item--selected:hover{background:#3b82f6;border-color:#3b82f6;color:#fff}@media (max-width:768px){.survey-respond{padding:0 .5rem}.survey-respond__title{font-size:1.25rem}.survey-respond__question-card{padding:16px 18px}.survey-respond__rating-item{font-size:.85rem;height:36px;width:36px}.survey-respond__likert-table td,.survey-respond__likert-table th{font-size:.75rem;padding:8px 6px}.survey-respond__likert-table th:first-child{min-width:120px}}@media (max-width:480px){.survey-respond__question-header{flex-direction:column;gap:6px}.survey-respond__actions{flex-direction:column}.survey-respond__btn{width:100%}.survey-respond__rating{gap:6px}.survey-respond__rating-item{font-size:.8rem;height:32px;width:32px}.survey-respond__file-input-wrapper{align-items:flex-start;flex-direction:column}}.survey-results-container{font-family:Arboria,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0 auto;max-width:100%;padding:20px}.survey-results-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px}.survey-results-header h2{color:#2c3e50;font-size:1.6rem;margin:0}.survey-results-subtitle{color:#6c757d;font-size:.9rem;margin:4px 0 0}.survey-results-export-btn{background:linear-gradient(135deg,#27ae60,#2ecc71);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 22px;transition:all .3s ease;white-space:nowrap}.survey-results-export-btn:hover:not(:disabled){background:linear-gradient(135deg,#229954,#28b463);box-shadow:0 4px 12px #2ecc714d;transform:translateY(-1px)}.survey-results-export-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.survey-results-charts-section{margin-bottom:2rem}.survey-results-table-wrapper{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow-x:auto}.survey-results-table{border-collapse:collapse;min-width:600px;width:100%}.survey-results-table thead th{background:#f8f9fa;border-bottom:2px solid #e0e6ed;color:#2c3e50;font-size:.9rem;font-weight:600;padding:14px 12px;position:-webkit-sticky;position:sticky;text-align:left;top:0;white-space:nowrap;z-index:1}.survey-results-table thead th:first-child,.survey-results-table thead th:nth-child(2),.survey-results-table thead th:nth-child(3){position:-webkit-sticky;position:sticky;z-index:2}.survey-results-table thead th:first-child{left:0;min-width:160px}.survey-results-table thead th:nth-child(2){left:160px;min-width:130px}.survey-results-table thead th:nth-child(3){left:290px;min-width:130px}.survey-results-th-question{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.survey-results-table tbody td{word-wrap:break-word;border-bottom:1px solid #f0f0f0;color:#495057;font-size:.9rem;max-width:250px;padding:12px;vertical-align:top}.survey-results-table tbody td:first-child,.survey-results-table tbody td:nth-child(2),.survey-results-table tbody td:nth-child(3){background:#fff;position:-webkit-sticky;position:sticky;z-index:1}.survey-results-table tbody td:first-child{color:#2c3e50;font-weight:600;left:0}.survey-results-table tbody td:nth-child(2){left:160px}.survey-results-table tbody td:nth-child(3){left:290px}.survey-results-table tbody tr:hover td{background-color:#f8f9fa}.survey-results-table tbody tr:nth-child(2n) td{background-color:#fdfdfd}.survey-results-table tbody tr:nth-child(2n):hover td{background-color:#f8f9fa}.survey-results-empty{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;color:#6c757d;padding:60px 20px;text-align:center}.survey-results-empty p{font-size:1.1rem;margin:0}.survey-results-loading{color:#6c757d;font-size:1.1rem;padding:60px 20px;text-align:center}@media (max-width:768px){.survey-results-container{padding:12px}.survey-results-header{align-items:flex-start;flex-direction:column}.survey-results-header h2{font-size:1.3rem}.survey-results-export-btn{text-align:center;width:100%}.survey-results-table tbody td:first-child,.survey-results-table tbody td:nth-child(2),.survey-results-table tbody td:nth-child(3),.survey-results-table thead th:first-child,.survey-results-table thead th:nth-child(2),.survey-results-table thead th:nth-child(3){position:static}}.team-absence-container{margin:0 auto;max-width:1400px;padding:24px}.team-absence-header{margin-bottom:24px}.team-absence-header h2{color:#1e293b;font-size:28px;font-weight:600;margin:0 0 8px}.team-absence-header .subtitle{color:#64748b;font-size:14px;margin:0}.message-box{margin-bottom:20px}.message-info{background:#dbeafe;border:1px solid #93c5fd;color:#1e40af}.message-error{color:#991b1b}.metrics-section{grid-gap:16px;display:grid;gap:16px;margin-bottom:24px;margin-top:20px}.metric-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.metric-card{padding:16px}.metric-card-label{color:#64748b;font-size:13px;letter-spacing:.05em;margin:0;text-transform:uppercase}.metric-card-value{color:#0f172a;font-size:32px;font-weight:700;margin:8px 0 0}.metric-card-helper{color:#94a3b8;font-size:13px;margin:4px 0 0}.top-motives-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px}.top-motives-card header{align-items:center;color:#475569;display:flex;font-size:14px;justify-content:space-between;margin-bottom:10px}.top-motives-card ul{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.top-motives-card li{background:#f8fafc;border-radius:8px;color:#0f172a;display:flex;font-size:14px;justify-content:space-between;padding:10px 12px}.top-motives-card strong{color:#2563eb}.metrics-loading{background:#e0f2fe;border-radius:8px;color:#0c4a6e;font-size:14px;margin-bottom:16px;padding:16px}.detail-table{min-width:600px}.hierarchy-status{margin-bottom:20px}.badge-default{background:#f1f5f9}@media (max-width:1024px){.absence-row,.absences-table-header{font-size:13px;gap:10px;grid-template-columns:1.8fr 1.6fr 1.4fr .9fr 1.1fr 1fr 2fr}}@media (max-width:768px){.team-absence-container{padding:16px}.absence-item{grid-template-columns:1fr}}.novedad-modal-overlay{align-items:center;animation:novedad-fade-in .15s ease-out;background:#0f172a80;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1300}@keyframes novedad-fade-in{0%{opacity:0}to{opacity:1}}.novedad-modal{animation:novedad-scale-in .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 50px #0003;max-width:480px;overflow:hidden;width:100%}@keyframes novedad-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.novedad-modal__header{border-bottom:1px solid #e2e8f0;padding:20px 24px}.novedad-modal__title{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.novedad-modal__content{display:flex;flex-direction:column;gap:16px;padding:20px 24px}.novedad-alert{align-items:center;border-radius:8px;display:flex;font-size:14px;gap:12px;justify-content:space-between;padding:12px 16px}.novedad-alert--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.novedad-alert__close{align-items:center;background:#0000;border:none;border-radius:4px;color:inherit;cursor:pointer;display:flex;justify-content:center;padding:4px}.novedad-alert__close:hover{background:#0000001a}.novedad-form-field{display:flex;flex-direction:column;gap:6px}.novedad-form-field label{color:#1e293b;font-size:14px;font-weight:500}.novedad-form-field label .required{color:#dc2626}.novedad-form-field__helper{color:#64748b;font-size:12px;margin-top:2px}.novedad-input,.novedad-select,.novedad-textarea{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#1e293b;font-size:14px;padding:10px 12px;transition:all .15s ease;width:100%}.novedad-input:focus,.novedad-select:focus,.novedad-textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.novedad-input:disabled,.novedad-select:disabled,.novedad-textarea:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.novedad-textarea{font-family:inherit;min-height:100px;resize:vertical}.novedad-modal__footer{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.novedad-modal__btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.novedad-modal__btn--secondary{background:#fff;border-color:#e2e8f0;color:#64748b}.novedad-modal__btn--secondary:hover:not(:disabled){background:#f1f5f9;color:#475569}.novedad-modal__btn--primary{background:#3b82f6;color:#fff}.novedad-modal__btn--primary:hover:not(:disabled){background:#2563eb}.novedad-modal__btn:disabled{cursor:not-allowed;opacity:.6}.novedad-modal__spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@media (max-width:480px){.novedad-modal{border-radius:0;margin:0;max-width:none;min-height:100vh}.novedad-modal__footer{flex-direction:column-reverse;gap:8px}.novedad-modal__btn{justify-content:center;width:100%}}.novedades-modal-overlay{align-items:center;animation:modal-fade-in .15s ease-out;background:#0f172a80;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1300}.novedades-modal{animation:modal-scale-in .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 50px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.novedades-modal__header{border-bottom:1px solid #e2e8f0;padding:20px 24px}.novedades-modal__title{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.novedades-modal__content{flex:1 1;overflow-y:auto;padding:20px 24px}.novedades-filters{align-items:flex-end;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.novedades-filter-group{display:flex;flex-direction:column;gap:4px}.novedades-filter-group label{color:#475569;font-size:12px;font-weight:600}.novedades-filter-input,.novedades-filter-select{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#1e293b;font-size:14px;min-width:150px;padding:8px 12px;transition:all .15s ease}.novedades-filter-input:focus,.novedades-filter-select:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.novedades-filter-select{min-width:200px}.novedades-search-btn{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#475569;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .15s ease}.novedades-search-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.novedades-search-btn:disabled{cursor:not-allowed;opacity:.6}.novedades-clear-btn{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .15s ease}.novedades-clear-btn:hover:not(:disabled){background:#f1f5f9;color:#475569}.novedades-clear-btn:disabled{cursor:not-allowed;opacity:.6}.novedades-alert{align-items:center;border-radius:8px;display:flex;font-size:14px;gap:12px;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.novedades-alert--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.novedades-alert__close{align-items:center;background:#0000;border:none;border-radius:4px;color:inherit;cursor:pointer;display:flex;justify-content:center;padding:4px}.novedades-alert__close:hover{background:#0000001a}.novedades-loading{display:flex;justify-content:center;padding:40px 0}.novedades-spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#2563eb;height:32px;width:32px}.novedades-table-container{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.novedades-table{border-collapse:collapse;table-layout:fixed;width:100%}.novedades-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#475569;font-size:13px;font-weight:600;padding:12px 14px;text-align:left}.novedades-table td:first-child,.novedades-table th:first-child{width:100px}.novedades-table td:nth-child(2),.novedades-table th:nth-child(2){width:150px}.novedades-table td:nth-child(4),.novedades-table th:nth-child(4){width:90px}.novedades-table td{border-bottom:1px solid #f1f5f9;color:#1e293b;font-size:14px;padding:12px 14px;vertical-align:middle}.novedades-table tr:last-child td{border-bottom:none}.novedades-table tr:hover td{background:#fafafa}.novedades-table__empty{color:#64748b;padding:24px!important;text-align:center}.novedad-text{max-width:100%}.novedades-actions{display:flex;gap:4px;justify-content:center}.novedades-action-btn{align-items:center;background:#0000;border:none;border-radius:6px;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .15s ease}.novedades-action-btn--edit{color:#2563eb}.novedades-action-btn--edit:hover{background:#eff6ff}.novedades-action-btn--delete{color:#dc2626}.novedades-action-btn--delete:hover{background:#fef2f2}.novedades-caption{color:#94a3b8;font-size:12px;margin-top:12px}.novedades-modal__footer{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.novedades-modal__btn{border:1px solid #0000;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .15s ease}.novedades-modal__btn--secondary{background:#fff;border-color:#e2e8f0;color:#64748b}.novedades-modal__btn--secondary:hover:not(:disabled){background:#f1f5f9;color:#475569}.novedades-modal__btn:disabled{cursor:not-allowed;opacity:.6}.delete-confirm-dialog__btn{align-items:center;display:inline-flex;gap:8px}.delete-confirm-dialog__spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@media (max-width:640px){.novedades-modal{border-radius:0;max-height:100vh}.novedades-filters{align-items:stretch;flex-direction:column}.novedades-filter-input,.novedades-filter-select,.novedades-search-btn{min-width:0;min-width:auto;width:100%}.novedades-table-container{overflow-x:auto}.novedades-table{min-width:500px;table-layout:auto}.delete-confirm-dialog{margin:16px}}.team-attendance-container{margin:0 auto;max-width:1400px;padding:24px}.team-attendance-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.team-attendance-header h1{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.header-actions{display:flex;gap:12px}.btn-secondary{background:#fff;border-color:#e2e8f0;color:#475569}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.alert,.hierarchy-status{font-size:.875rem}.alert{border:1px solid;border-radius:8px;margin:16px 0;padding:14px 18px}.alert-warning{background:#fffbeb;border-color:#fcd34d;color:#92400e}.alert-error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.alert-info{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.loading-container{padding:48px}.loading-spinner{border-top-color:#2563eb;height:32px;margin-bottom:12px;width:32px}.metrics-loading{align-items:center;color:#64748b;display:flex;gap:12px;justify-content:center;padding:24px}.metrics-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:24px 0}.metric-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:8px;padding:20px}.metric-label{color:#64748b;font-size:.8125rem;font-weight:500;letter-spacing:.025em;text-transform:uppercase}.metric-value{color:#1e293b;font-size:1.75rem;font-weight:600}.metric-helper{color:#94a3b8;font-size:.8125rem}.collab-cards-list{gap:16px}.collab-card,.collab-cards-list{display:flex;flex-direction:column}.collab-card{background:#fff;border:1px solid #e2e8f0;border-left:4px solid #cbd5e1;border-radius:12px;box-shadow:0 1px 3px #0000000d;gap:14px;padding:20px;transition:box-shadow .2s ease}.collab-card:hover{box-shadow:0 4px 12px #0000001a}.collab-card-body{cursor:pointer;display:flex;flex-direction:column;gap:4px}.collab-card-label{color:#94a3b8;font-size:.75rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.collab-card-name{color:#1e293b;font-size:1.25rem;font-weight:700;line-height:1.3;margin:4px 0 0}.collab-card-email{color:#64748b;font-size:.875rem;line-height:1.4;margin:0}.collab-card-meta{display:flex;flex-direction:column;gap:6px;margin-top:10px}.collab-card-meta-item{align-items:center;color:#475569;display:flex;flex-wrap:wrap;font-size:.8125rem;gap:6px}.collab-card-meta-label{color:#94a3b8;font-size:.75rem;font-weight:500;letter-spacing:.03em;min-width:60px;text-transform:uppercase}.collab-card-meta-item strong{color:#1e293b;font-weight:500}.collab-card-actions{align-items:center;border-top:1px solid #f1f5f9;display:flex;gap:12px;justify-content:flex-end;padding-top:12px}.collab-action-btn{align-items:center;background:none;border:none;color:#64748b;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:500;gap:6px;padding:0;transition:color .15s ease}.collab-action-btn:hover{color:#1e293b}.collab-card-detail{border-top:1px solid #f1f5f9;padding-top:14px}.collab-card-detail h4{color:#1e293b;font-size:.9375rem;font-weight:600;margin:0 0 12px}.detail-table{border-collapse:initial;border-spacing:0;min-width:1000px;table-layout:fixed}.detail-table th{font-size:.75rem;text-align:center!important}.detail-table td{border-right:1px solid #f1f5f9;font-size:.8125rem;max-width:0;overflow:hidden;padding:12px 10px;text-align:center;text-overflow:ellipsis}.detail-table td:last-child{border-right:none}.location-display{display:inline-flex;flex-direction:column;gap:6px;text-align:left}.location-item{display:flex;flex-direction:column}.location-label{color:#64748b;font-size:.75rem}.location-value{color:#1e293b;font-weight:500}.location-floor{color:#94a3b8;font-size:.75rem}.hours-minutes,.late-minutes{color:#dc2626;display:block;font-size:.75rem;margin-top:2px}.hours-minutes{color:#64748b}.break-minutes{align-items:center;color:#dc2626;display:inline-flex;font-size:.75rem;gap:2px;margin-top:2px}.detail-table .status-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-table .status-badge{align-items:center!important;border:1px solid!important;border-radius:4px!important;display:inline-flex!important;font-size:.75rem!important;font-weight:500!important;gap:4px!important;max-width:none!important;overflow:visible!important;padding:4px 10px!important;white-space:nowrap!important;width:auto!important}.detail-table .status-badge.completo{background:#f0fdf4;border-color:#bbf7d0;color:#16a34a}.detail-table .status-badge.incompleto,.detail-table .status-badge.sin_egreso{background:#fffbeb;border-color:#fde68a;color:#d97706}.detail-table .status-badge.sin_ingreso,.detail-table .status-badge.sin_registro{background:#fef2f2;border-color:#fecaca;color:#dc2626}.detail-table .status-badge.vacacion{background:#eff6ff;border-color:#bfdbfe;color:#2563eb}.detail-table .status-badge.ausencia{background:#faf5ff;border-color:#e9d5ff;color:#9333ea}.detail-table .status-badge.feriado{background:#f0fdfa;border-color:#99f6e4;color:#0f766e}.novedad-cell{max-width:0}.novedad-text{cursor:help;display:block;line-height:1.4;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap;width:100%}.no-records{font-size:.875rem}.detail-table .novedad-actions{display:inline-flex;gap:4px;justify-content:center}.novedad-action-btn{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .15s ease}.novedad-action-btn--edit{color:#2563eb}.novedad-action-btn--edit:hover{background:#eff6ff}.novedad-action-btn--delete{color:#dc2626}.novedad-action-btn--delete:hover{background:#fef2f2}.no-action{color:#94a3b8;display:block;text-align:center}.delete-confirm-overlay{background:#0f172a80;inset:0;padding:16px;z-index:1400}.delete-confirm-dialog{box-shadow:0 20px 50px #0003;max-width:420px;overflow:hidden;width:100%}.delete-confirm-dialog__header{padding:20px 24px 0}.delete-confirm-dialog__title{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.delete-confirm-dialog__body{padding:16px 24px 24px}.delete-confirm-dialog__message{color:#64748b;font-size:14px;margin:0 0 16px}.delete-confirm-dialog__details{background:#f8fafc;border-radius:8px;padding:12px}.delete-confirm-dialog__details p{color:#1e293b;font-size:13px;margin:0 0 4px}.delete-confirm-dialog__details p:last-child{margin-bottom:0}.delete-confirm-dialog__actions{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.delete-confirm-dialog__btn{border:1px solid #0000;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .15s ease}.delete-confirm-dialog__btn--cancel{background:#fff;border-color:#e2e8f0;color:#64748b}.delete-confirm-dialog__btn--cancel:hover:not(:disabled){background:#f1f5f9;color:#475569}.delete-confirm-dialog__btn--danger{background:#dc2626;border-color:#dc2626;color:#fff}.delete-confirm-dialog__btn--danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.delete-confirm-dialog__btn:disabled{cursor:not-allowed;opacity:.6}.message-box{align-items:center;border-radius:8px;display:flex;font-size:.875rem;gap:12px;justify-content:space-between;padding:12px 16px}.message-box.message-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.message-box button{background:#0000;border:1px solid;border-radius:4px;color:inherit;cursor:pointer;font-size:.8125rem;padding:6px 12px}.message-box button:hover{background:#0000000d}@media (max-width:1024px){.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.team-attendance-container{padding:16px}.team-attendance-header{align-items:stretch;flex-direction:column}.team-attendance-header h1{font-size:1.25rem;text-align:center}.header-actions{flex-direction:column}.header-actions .btn{justify-content:center}.metrics-grid{grid-template-columns:1fr}.collab-card{padding:16px}.detail-table{min-width:700px}}@media (max-width:480px){.team-attendance-container{padding:12px}.metric-card{padding:16px}.metric-value{font-size:1.5rem}.btn{font-size:.8125rem;padding:8px 12px}}.team-vacations-container{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:1400px;padding:24px}.team-vacations-header{display:flex;flex-direction:column;gap:4px}.team-vacations-header h2{color:#0f172a;font-size:28px;font-weight:700;margin:0}.team-vacations-header .subtitle{color:#64748b;font-size:14px;margin:0}.month-nav-btn{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.month-nav-btn:hover{border-color:#0ea5e9;color:#0ea5e9}.message-box{border-radius:12px;font-size:14px;padding:16px}.message-info{background:#e0f2fe;border:1px solid #bae6fd;color:#075985}.message-warning{background:#fef3c7;border:1px solid #fcd34d;color:#92400e}.message-error{background:#fee2e2;border:1px solid #fecaca;color:#b91c1c}.loading-container{color:#64748b;padding:60px 20px}.loading-spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-top-color:#3b82f6;margin-bottom:16px}.vacations-calendar{background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:16px}.calendar-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between}.calendar-month{color:#0f172a;font-size:20px;font-weight:700;margin:0;text-transform:capitalize}.calendar-legend{color:#64748b;font-size:13px;gap:12px}.calendar-legend,.legend-item{align-items:center;display:flex}.legend-item{gap:6px}.legend-dot{border-radius:50%;display:inline-block;height:10px;width:10px}.legend-approved{background:#22c55e}.legend-pending{background:#f97316}.calendar-day-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.calendar-badge{border-radius:8px;color:#fff;font-size:11px;letter-spacing:.05em;padding:2px 6px;text-transform:uppercase}.vacations-collaborators{display:flex;flex-direction:column;gap:12px}.vacations-table-container{border-radius:12px;overflow:hidden}.collaborator-detail-cell{background:#f8fafc;padding:0!important}.collaborator-summary{gap:16px;margin-bottom:12px}.collaborator-summary .MuiTypography-root,.value-pill{font-weight:600}.value-pill{align-items:center;background:#e0f2fe;border-radius:999px;color:#0c4a6e;display:inline-flex;font-size:12px;padding:2px 8px;width:-webkit-fit-content;width:fit-content}.inner-detail-table td,.inner-detail-table th{border-bottom:none}.badge{border-radius:12px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.025em;padding:4px 10px;text-transform:uppercase}.badge-aprobada{background:#d1fae5;color:#065f46}.badge-rechazada{background:#fee2e2;color:#991b1b}.badge-pendiente{background:#fef3c7;color:#92400e}.badge-default{background:#e2e8f0;color:#475569}.vacations-table{background:#fff;border:1px solid #e2e8f0;border-collapse:collapse;border-radius:12px;overflow:hidden;width:100%}.vacations-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#475569;font-size:13px;font-weight:600;padding:14px 16px;text-align:left}.vacations-table td{border-bottom:1px solid #f1f5f9;color:#1e293b;font-size:14px;padding:14px 16px;vertical-align:middle}.vacations-table-row{cursor:pointer;transition:background .15s ease}.vacations-table-row:hover td{background:#f8fafc}.vacations-table td strong{display:block;font-weight:600;margin-bottom:2px}.collaborator-position{color:#64748b;display:block;font-size:13px}.expand-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .15s ease}.expand-btn:hover{background:#f1f5f9;color:#475569}.expanded-row td{background:#f8fafc;padding:0!important}.expanded-content{padding:20px}.collaborator-summary{color:#475569;display:flex;flex-wrap:wrap;font-size:14px;font-weight:500;gap:24px;margin-bottom:16px}.detail-table-wrapper{overflow-x:auto}.detail-table{background:#fff;border:1px solid #e2e8f0;border-collapse:collapse;border-radius:8px;min-width:700px;overflow:hidden;width:100%}.detail-table th{background:#f1f5f9;border-bottom:1px solid #e2e8f0;color:#475569;font-size:12px;font-weight:600;letter-spacing:.025em;padding:12px 14px;text-align:left;text-transform:uppercase}.detail-table td{border-bottom:1px solid #f1f5f9;font-size:13px;padding:12px 14px;vertical-align:middle}.detail-table tr:last-child td{border-bottom:none}.detail-table tr:hover td{background:#fafafa}.no-records{color:#64748b;font-size:14px;margin:0;padding:16px 0}.hierarchy-status{color:#64748b;font-size:14px;margin-top:12px}.hierarchy-error{align-items:center;color:#dc2626;display:flex;gap:12px}.hierarchy-error button{background:#0000;border:1px solid #dc2626;border-radius:6px;color:#dc2626;cursor:pointer;font-size:13px;padding:4px 12px;transition:all .15s ease}.hierarchy-error button:hover{background:#fef2f2}.access-denied{color:#64748b;padding:60px 20px;text-align:center}.access-denied h3{color:#1e293b;margin-bottom:8px}@media (max-width:768px){.calendar-header{flex-direction:column}.collaborator-card{padding:0 12px 10px}.vacation-record{grid-template-columns:1fr}}.workday-container{display:flex;flex-direction:column;gap:24px;margin:0 auto;max-width:1200px;padding:24px}.workday-header{align-items:center;display:flex;justify-content:space-between}.workday-header h1{color:#1e293b;font-size:1.75rem;font-weight:600;margin:0}.workday-loading{display:flex;justify-content:center;padding:48px}.workday-spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#2563eb;height:32px;width:32px}.workday-alert{align-items:center;border-radius:8px;display:flex;font-size:14px;gap:10px;padding:14px 18px}.workday-alert--warning{background:#fffbeb;border:1px solid #fcd34d;color:#92400e}.workday-alert--info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.workday-tabs{border-bottom:1px solid #e2e8f0;display:flex;gap:4px;margin-bottom:24px}.workday-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-size:14px;font-weight:500;margin-bottom:-1px;padding:12px 20px;transition:all .15s ease}.workday-tab:hover{color:#1e293b}.workday-tab--active{border-bottom-color:#2563eb;color:#2563eb}.workday-section{display:flex;flex-direction:column;gap:24px}.workday-section__header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.workday-section__title{align-items:center;display:flex;gap:8px}.workday-section__title h2{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.workday-section__subtitle{color:#64748b;font-size:14px;margin:4px 0 0}.workday-form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.workday-form-group{display:flex;flex-direction:column;gap:6px}.workday-form-group label{color:#1e293b;font-size:14px;font-weight:500}.workday-form-group__helper{color:#64748b;font-size:12px}.workday-form-group__error{color:#dc2626;font-size:12px}.workday-input,.workday-select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:14px;padding:10px 12px;transition:all .15s ease}.workday-input:focus,.workday-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.workday-input--error,.workday-select--error{border-color:#dc2626}.workday-input:disabled,.workday-select:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.workday-btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.workday-btn--primary{background:#3b82f6;color:#fff}.workday-btn--primary:hover:not(:disabled){background:#2563eb}.workday-btn--secondary{background:#fff;border-color:#e2e8f0;color:#475569}.workday-btn--secondary:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.workday-btn--danger{background:#fff;border-color:#fecaca;color:#dc2626}.workday-btn--danger:hover:not(:disabled){background:#fef2f2;border-color:#dc2626}.workday-btn--icon{border-radius:6px;padding:8px}.workday-btn--icon-primary{color:#2563eb}.workday-btn--icon-primary:hover{background:#eff6ff}.workday-btn--icon-danger{color:#dc2626}.workday-btn--icon-danger:hover{background:#fef2f2}.workday-btn:disabled{cursor:not-allowed;opacity:.6}.workday-btn__spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.workday-btn--secondary .workday-btn__spinner{border-color:#2563eb #0000001a #0000001a}.workday-group-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:16px;padding:20px}.workday-group-card__header{align-items:center;display:flex;justify-content:space-between}.workday-group-card__title{color:#1e293b;font-size:1rem;font-weight:600;margin:0}.workday-days-selector{display:flex;flex-direction:column;gap:8px}.workday-days-selector__label{color:#1e293b;font-size:14px;font-weight:500}.workday-days-selector__buttons{display:flex;flex-wrap:wrap;gap:8px}.workday-day-btn{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#475569;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .15s ease}.workday-day-btn:hover{border-color:#2563eb;color:#2563eb}.workday-day-btn--selected{background:#2563eb;border-color:#2563eb;color:#fff}.workday-days-selector__helper{color:#94a3b8;font-size:12px}.workday-members{display:flex;flex-direction:column;gap:16px}.workday-members__list{display:flex;flex-direction:column;gap:12px}.workday-members__loading{align-items:center;color:#64748b;display:flex;font-size:14px;gap:12px}.workday-members__loading .workday-spinner{border-width:2px;height:18px;width:18px}.workday-member-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:16px}.workday-member-card__header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.workday-member-card__info h3{color:#1e293b;font-size:1rem;font-weight:600;margin:0}.workday-member-card__info p{color:#64748b;font-size:14px;margin:4px 0 0}.workday-member-card__actions{display:flex;gap:8px}.workday-member-card__details{display:flex;flex-direction:column;font-size:14px;gap:4px}.workday-member-card__details--override{color:#2563eb}.workday-member-card__schedule{display:flex;flex-direction:column;gap:4px}.workday-member-card__schedule-item{color:#64748b}.workday-member-card__note{color:#94a3b8;font-size:12px}.workday-member-card__extra{color:#f59e0b;font-size:12px}.workday-modal-overlay{align-items:center;animation:modal-fade-in .15s ease-out;background:#0f172a80;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1300}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.workday-modal{animation:modal-scale-in .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 50px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:560px;overflow:hidden;width:100%}@keyframes modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.workday-modal__header{border-bottom:1px solid #e2e8f0;padding:20px 24px}.workday-modal__title{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.workday-modal__subtitle{color:#64748b;font-size:14px;margin:4px 0 0}.workday-modal__content{display:flex;flex:1 1;flex-direction:column;gap:16px;overflow-y:auto;padding:20px 24px}.workday-modal__footer{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.workday-day-config{border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:12px;padding:16px;transition:border-color .15s ease}.workday-day-config--active{border-color:#2563eb}.workday-day-config__header{align-items:center;display:flex;justify-content:space-between}.workday-day-config__title{color:#1e293b;font-size:1rem;font-weight:600;margin:0}.workday-toggle{align-items:center;cursor:pointer;display:flex;gap:8px}.workday-toggle__input{display:none}.workday-toggle__slider{background:#e2e8f0;border-radius:12px;height:24px;position:relative;transition:background .2s ease;width:44px}.workday-toggle__slider:after{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;content:"";height:20px;left:2px;position:absolute;top:2px;transition:transform .2s ease;width:20px}.workday-toggle__input:checked+.workday-toggle__slider{background:#2563eb}.workday-toggle__input:checked+.workday-toggle__slider:after{transform:translateX(20px)}.workday-toggle__label{color:#64748b;font-size:14px}.workday-day-config__form{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.workday-confirm-dialog{max-width:420px}.workday-confirm-dialog__message{color:#64748b;font-size:14px;line-height:1.5;margin:0}@media (max-width:768px){.workday-container{padding:16px}.workday-header h1{font-size:1.5rem}.workday-tabs{overflow-x:auto}.workday-section__header{align-items:stretch;flex-direction:column}.workday-day-config__form,.workday-form-grid{grid-template-columns:1fr}.workday-modal{border-radius:0;height:100vh;max-height:none;max-width:none}.workday-member-card__header{flex-direction:column;gap:12px}.workday-member-card__actions{justify-content:flex-end;width:100%}}@media (max-width:480px){.workday-days-selector__buttons{display:grid;grid-template-columns:repeat(4,1fr)}.workday-day-btn{justify-content:center;padding:8px 4px}.workday-modal__footer{flex-direction:column-reverse}.workday-modal__footer .workday-btn{justify-content:center;width:100%}}.profile{margin:0 auto;max-width:800px}.photo-resolution-hint{background:#fef3c7;border:1px solid #fcd34d;border-radius:6px;color:#b45309;font-size:12px;margin-top:8px;padding:6px 10px}.profile-header{margin-bottom:30px;text-align:center}.profile-header h1{color:#333;font-size:28px;margin-bottom:10px}.profile-header p{color:#666;font-size:16px}.profile-content{display:flex;flex-direction:column;gap:30px}.profile-card{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;gap:30px;padding:30px}.profile-avatar{flex-shrink:0;position:relative}.profile-avatar img{object-fit:cover}.avatar-placeholder,.profile-avatar img{border:4px solid #e9ecef;border-radius:50%;height:100px;width:100px}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:36px;font-weight:700;justify-content:center}.profile-info h2{color:#333;font-size:24px;margin-bottom:5px}.profile-avatar__file{display:none}.profile-avatar__edit{align-items:center;background:#007bff;border:2px solid #fff;border-radius:50%;bottom:4px;box-shadow:0 4px 10px #0003;color:#fff;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:4px;transition:transform .2s ease,box-shadow .2s ease;width:36px}.profile-avatar__edit:focus,.profile-avatar__edit:hover{box-shadow:0 6px 14px #00000040;outline:none;transform:scale(1.05)}.read-only-field{display:flex;flex-direction:column;gap:6px}.read-only-field__value{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;color:#333;font-size:15px;padding:10px 12px}.profile-role{color:#007bff;font-size:16px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.profile-details{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:30px}.detail-section{margin-bottom:30px}.detail-section:last-child{margin-bottom:0}.detail-section h3{border-bottom:2px solid #f0f0f0;color:#333;font-size:20px;margin-bottom:20px;padding-bottom:10px}.detail-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.detail-item{display:flex;flex-direction:column;gap:5px}.detail-item label{color:#555;font-size:14px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-item span{border-bottom:1px solid #f0f0f0;color:#333;font-size:16px;padding:8px 0}.profile-actions{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:15px}.actions-note{color:#666;font-size:14px;font-style:italic;margin:0}@media (max-width:768px){.profile-card{flex-direction:column;gap:20px;text-align:center}.detail-grid{grid-template-columns:1fr}.profile-actions{justify-content:center}}@media (max-width:480px){.profile-content{gap:20px}.profile-card,.profile-details{padding:20px}.profile-header h1{font-size:24px}}.modal-overlay{background:#0006;inset:0;padding:16px}.modal-content{border-radius:10px;box-shadow:0 10px 30px #00000026;max-width:250px;padding:24px;width:80%}.password-modal-card{background:#fff;border-radius:12px;box-shadow:0 8px 30px #00000014;margin:0 auto;max-width:500px;padding:32px 40px;width:100%}.password-modal-header{margin-bottom:24px;text-align:center}.password-modal-icon{color:#007bff;margin-bottom:12px}.password-modal-header h3{color:#1f2937;font-size:22px;margin-bottom:4px}.password-modal-header p{color:#6b7280;font-size:14px;margin:0}.password-modal-form{display:flex;flex-direction:column;gap:18px}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:12px 42px 12px 12px;transition:border-color .2s ease;width:100%}.password-input-wrapper input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1f;outline:none}.toggle-password{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:10px;transition:color .2s}.toggle-password:hover{color:#111827}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.password-requirements{background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;margin-top:12px;padding:16px}.requirements-title{color:#2d3748;font-size:13px;font-weight:600;margin-bottom:12px}.requirements-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.requirement-item{align-items:center;display:flex;font-size:13px;gap:8px;transition:color .2s}.requirement-item.pending{color:#718096}.requirement-item.pending svg{color:#cbd5e0}.requirement-item.invalid,.requirement-item.invalid svg{color:#e53e3e}.requirement-item.valid,.requirement-item.valid svg{color:#38a169}.modal-content h3,.modal-content h3:after{border:none!important;box-shadow:none!important}.modal-content:focus{outline:none!important}.tabs-nav{border-bottom:2px solid #e5e7eb;display:flex;gap:8px;margin-bottom:24px}.tab-button{background:#0000;border:none;border-bottom:3px solid #0000;bottom:-2px;color:#6b7280;cursor:pointer;font-size:15px;font-weight:500;padding:12px 24px;position:relative;transition:all .2s ease}.tab-button:hover{background:#f9fafb;color:#374151}.tab-button.active{border-bottom-color:#007bff;color:#007bff;font-weight:600}.tabs-content{min-height:200px}.tab-pane{animation:fadeIn .3s ease}.form-grid{grid-gap:20px;gap:20px;margin-bottom:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full-width{grid-column:1/-1}.form-group label{color:#374151;font-size:14px;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;border-radius:6px;font-size:15px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{box-shadow:0 0 0 3px #007bff1a}.form-group input:disabled{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed}.form-hint{color:#6b7280;font-size:13px;font-style:italic}.detail-item.full-width{grid-column:1/-1}.profile-attachments{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:16px;padding:20px}.profile-attachments__header{align-items:center;display:flex;gap:12px;justify-content:space-between}.profile-attachments__header h4{color:#1f2933;font-size:18px;margin:0}.profile-attachments__status{color:#64748b;font-size:14px}.profile-attachments__error{color:#b91c1c;font-size:14px;margin:0}.profile-attachments__empty{color:#64748b;font-size:14px;margin:0}.profile-attachments__list{display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0}.profile-attachments__item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 6px #0f172a0a;display:flex;gap:16px;justify-content:space-between;padding:14px 18px}.profile-attachments__meta{display:flex;flex-direction:column;gap:4px}.profile-attachments__name{color:#0f172a;font-size:15px;font-weight:600;word-break:break-word}.profile-attachments__info{color:#64748b;font-size:13px}.profile-attachments__button{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:999px;box-shadow:0 2px 6px #0f172a14;color:#475569;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:10px 18px;transition:all .2s ease}.profile-attachments__button:hover{background:#f1f5f9;border-color:#cbd5e1;box-shadow:0 4px 12px #0f172a1f;color:#1e293b;transform:translateY(-1px)}.profile-attachments__button:active{box-shadow:0 1px 4px #0f172a14;transform:translateY(0)}.profile-attachments__button:focus-visible{outline:2px solid #2563eb;outline-offset:2px}@media (max-width:768px){.tabs-nav{overflow-x:auto}.tab-button{font-size:14px;padding:10px 16px;white-space:nowrap}.form-grid{grid-template-columns:1fr}.profile-attachments__item{align-items:flex-start;flex-direction:column}}.totp-setup{background:#fff;border:1px solid #dee2e6;border-radius:10px;max-width:500px;padding:24px}.totp-setup h3{color:#2c3e50;font-size:1.2rem;margin:0 0 16px}.totp-setup h4{color:#2c3e50;font-size:1rem;margin:0 0 12px}.totp-setup-loading{color:#6c757d;padding:20px;text-align:center}.totp-setup-message{border-radius:8px;font-size:.95rem;margin-bottom:16px;padding:12px 16px}.totp-setup-message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.totp-setup-message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.totp-status-section{text-align:center}.totp-status-badge{border-radius:20px;display:inline-block;font-size:.95rem;font-weight:600;margin-bottom:16px;padding:8px 16px}.totp-status-badge.active{background:#d4edda;color:#155724}.totp-status-badge.inactive{background:#f8f9fa;border:1px solid #dee2e6;color:#6c757d}.totp-description{color:#495057;font-size:.95rem;line-height:1.5;margin-bottom:20px}.totp-backup-section,.totp-deactivate-section,.totp-setup-section,.totp-verify-section{text-align:center}.totp-qr-container{background:#f8f9fa;border-radius:8px;display:inline-block;margin:20px 0;padding:16px}.totp-qr-container img{display:block;height:auto;max-width:200px}.totp-apps-hint{color:#6c757d;font-size:.85rem;margin-bottom:20px}.totp-code-input{border:2px solid #dee2e6;border-radius:8px;font-size:1.5rem;letter-spacing:8px;margin-bottom:20px;padding:16px;text-align:center;width:160px}.totp-code-input:focus{border-color:#6c757d;box-shadow:0 0 0 3px #6c757d26;outline:none}.totp-backup-actions,.totp-deactivate-actions,.totp-verify-actions{display:flex;gap:12px;justify-content:center;margin-top:16px}.totp-setup .btn-danger,.totp-setup .btn-primary,.totp-setup .btn-secondary{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 16px;transition:all .15s}.totp-setup .btn-primary{background:#3b82f6;color:#fff}.totp-setup .btn-primary:hover:not(:disabled){background:#2563eb}.totp-setup .btn-secondary{background:#f1f3f5;border:1px solid #dee2e6;color:#2c3e50}.totp-setup .btn-secondary:hover:not(:disabled){background:#e9ecef}.totp-setup .btn-danger{background:#dc3545;color:#fff}.totp-setup .btn-danger:hover:not(:disabled){background:#c82333}.totp-setup button:disabled{cursor:not-allowed;opacity:.6}.totp-backup-warning{background:#fff3cd;border:1px solid #ffeeba;border-radius:8px;color:#856404;font-size:.9rem;margin-bottom:20px;padding:12px 16px}.totp-backup-codes{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr);margin-bottom:20px}.totp-backup-code{background:#f8f9fa;border-radius:6px;font-family:monospace;font-size:1rem;font-weight:600;letter-spacing:1px;padding:10px}.totp-deactivate-warning{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;font-size:.9rem;margin-bottom:20px;padding:12px 16px}.career-timeline{padding:8px 0}.career-timeline__empty{color:#64748b;font-size:14px;padding:40px 20px;text-align:center}.career-timeline__empty-icon{font-size:40px;margin-bottom:12px;opacity:.5}.career-timeline__loading{color:#64748b;font-size:14px;padding:40px 20px;text-align:center}.career-timeline__error{background:#fee2e2;border-radius:8px;color:#dc2626;font-size:14px;padding:20px;text-align:center}.career-timeline__list{padding-left:32px;position:relative}.career-timeline__list:before{background:#e2e8f0;bottom:8px;content:"";left:11px;position:absolute;top:8px;width:2px}.career-timeline__item{padding-bottom:24px;position:relative}.career-timeline__item:last-child{padding-bottom:0}.career-timeline__dot{background:#e2e8f0;border:3px solid #fff;border-radius:50%;box-shadow:0 0 0 2px #e2e8f0;height:14px;left:-27px;position:absolute;top:4px;width:14px}.career-timeline__item--current .career-timeline__dot{background:#3b82f6;box-shadow:0 0 0 2px #3b82f6}.career-timeline__card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px 20px;transition:box-shadow .2s ease}.career-timeline__item--current .career-timeline__card{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.career-timeline__card:hover{box-shadow:0 2px 10px #0000000f}.career-timeline__header{align-items:center;display:flex;gap:10px;margin-bottom:10px}.career-timeline__puesto{color:#1e293b;font-size:16px;font-weight:600;margin:0}.career-timeline__badge{border-radius:999px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.3px;padding:2px 10px}.career-timeline__badge--actual{background:#ecfdf5;color:#10b981}.career-timeline__badge--anterior{background:#f1f5f9;color:#64748b}.career-timeline__fechas{color:#64748b;font-size:13px;margin-bottom:10px}.career-timeline__details{display:flex;flex-wrap:wrap;gap:16px}.career-timeline__detail{align-items:center;color:#475569;display:flex;font-size:13px;gap:6px}.career-timeline__detail-label{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.career-timeline__detail-value{color:#1e293b}@media (max-width:768px){.career-timeline__details,.career-timeline__header{flex-direction:column;gap:6px}.career-timeline__header{align-items:flex-start}.career-timeline__card{padding:12px 16px}}.pm-page{margin:0 auto;max-width:1400px;padding:24px}.pm-loading{color:#64748b;font-size:14px;padding:48px;text-align:center}.pm-header{justify-content:space-between;margin-bottom:24px}.pm-header,.pm-header h2{align-items:center;display:flex}.pm-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;gap:10px;margin:0}.pm-header h2 svg{color:#3b82f6}.pm-new-btn{align-items:center;background:#3b82f6;border:1px solid #0000;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.pm-new-btn:hover{background:#2563eb}.pm-empty{color:#64748b;font-size:14px;padding:48px;text-align:center}.pm-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.pm-table{border-collapse:collapse;width:100%}.pm-table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.pm-table th{color:#64748b;font-size:12px;font-weight:500;letter-spacing:.5px;padding:14px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.pm-table tbody tr{border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background-color .2s ease}.pm-table tbody tr:hover{background:#f8fafc}.pm-table tbody tr:last-child{border-bottom:none}.pm-table tbody tr.pm-row-expanded{background:#f8fafc}.pm-table td{color:#0f172a;font-size:14px;padding:14px 12px;vertical-align:middle}.pm-table td strong{color:#0f172a;font-weight:500}.pm-tipo-badge{background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:12px;color:#4b5563;display:inline-block;font-size:12px;font-weight:500;padding:3px 10px}.pm-permisos-count{color:#64748b;font-size:13px;gap:6px}.pm-permisos-count,.pm-status-badge{align-items:center;display:inline-flex}.pm-status-badge{border-radius:9999px;font-size:11px;font-weight:600;letter-spacing:.3px;padding:4px 10px;text-transform:uppercase}.pm-status-badge--activo{background:#ecfdf5;color:#10b981}.pm-status-badge--inactivo{background:#fef2f2;color:#dc2626}.pm-actions-column{min-width:80px;text-align:center;width:80px}.pm-actions{display:flex;gap:8px;justify-content:center}.pm-action-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;display:inline-flex;justify-content:center;padding:6px 8px;transition:all .2s ease}.pm-action-btn:hover:not(:disabled){background:#f9fafb}.pm-action-btn:disabled{cursor:not-allowed;opacity:.4}.pm-action-btn--edit{color:#3b82f6}.pm-action-btn--edit:hover:not(:disabled){background:#eff6ff;border-color:#3b82f6}.pm-action-btn--deactivate{color:#ef4444}.pm-action-btn--deactivate:hover:not(:disabled){background:#fef2f2;border-color:#ef4444}.pm-action-btn--activate{color:#10b981}.pm-action-btn--activate:hover:not(:disabled){background:#ecfdf5;border-color:#10b981}.pm-detail-row{cursor:default}.pm-detail-row:hover{background:#0000!important}.pm-detail-row td{padding:0 12px 14px}.pm-permissions-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.pm-permissions-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.pm-perm-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;justify-content:space-between;padding:8px 12px}.pm-perm-item--active{background:#f0fdf4;border-color:#bbf7d0}.pm-perm-label{color:#374151;font-size:13px;font-weight:400}.pm-perm-indicator{background:#f3f4f6;border-radius:9999px;color:#9ca3af;font-size:11px;font-weight:600;padding:2px 8px}.pm-perm-indicator--active{background:#ecfdf5;color:#10b981}.pm-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.pm-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;display:flex;flex-direction:column;max-height:calc(100vh - 80px);max-width:520px;width:100%}.pm-modal__header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;justify-content:space-between;padding:16px 20px}.pm-modal__header h3{color:#1e293b;font-size:1.1rem;font-weight:600;margin:0}.pm-modal__close{align-items:center;background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;font-family:inherit;font-size:24px;height:28px;justify-content:center;padding:0;transition:all .2s ease;width:28px}.pm-modal__close:hover{background:#f3f4f6;color:#4b5563}.pm-form{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.pm-form__body{flex:1 1;overflow-y:auto;padding:16px 20px}.pm-form-group{margin-bottom:12px}.pm-form-group label{color:#374151;display:block;font-size:13px;font-weight:500;margin-bottom:4px}.pm-form-group input,.pm-form-group select{border:1px solid #d1d5db;border-radius:6px;font-family:inherit;font-size:13px;padding:8px 10px;transition:all .2s ease;width:100%}.pm-form-group input:focus,.pm-form-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.pm-form-group input:disabled,.pm-form-group select:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.pm-form-hint{color:#64748b;display:block;font-size:12px;font-style:italic;margin-top:4px}.pm-switches-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;max-height:280px;overflow-y:auto;padding:12px}.pm-switch-row{align-items:center;display:flex;justify-content:space-between;padding:6px 4px}.pm-switch-row+.pm-switch-row{border-top:1px solid #f1f5f9}.pm-switch-label{color:#374151;font-size:13px;font-weight:400}.pm-form__actions{border-top:1px solid #e5e7eb;display:flex;flex-shrink:0;gap:12px;justify-content:flex-end;padding:14px 20px}.pm-btn-cancel,.pm-btn-submit{align-items:center;border-radius:6px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.pm-btn-cancel{background:#fff;border:1px solid #d1d5db;color:#4b5563}.pm-btn-cancel:hover{background:#f9fafb}.pm-btn-submit{background:#3b82f6;border:none;color:#fff}.pm-btn-submit:hover{background-color:#2563eb}.pm-confirm-overlay{align-items:center;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);background:#0f172a59;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1100}.pm-confirm-modal{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 25px 50px -12px #0f172a40;padding:24px;width:min(360px,100%)}.pm-confirm-modal h4{color:#0f172a;font-size:1.05rem;margin:0 0 10px}.pm-confirm-modal p{color:#475569;font-size:.9375rem;line-height:1.5;margin:0 0 18px}.pm-confirm-modal strong{color:#0f172a}.pm-confirm-actions{display:flex;gap:10px;justify-content:flex-end}.pm-confirm-btn{background:#fff;border:1px solid #e2e8f0;border-radius:999px;color:#0f172a;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:8px 16px;transition:background .2s}.pm-confirm-btn:hover{background:#f8fafc}.pm-confirm-btn--success{background:#d1fae5;border-color:#bbf7d0;color:#065f46}.pm-confirm-btn--warning{background:#fee2e2;border-color:#fecaca;color:#991b1b}@media (max-width:768px){.pm-page{padding:16px}.pm-header{align-items:flex-start;flex-direction:column;gap:12px}.pm-new-btn{justify-content:center;width:100%}.pm-table{font-size:13px}.pm-table td,.pm-table th{padding:8px 12px}.pm-permissions-grid{grid-template-columns:1fr}.pm-modal{max-width:100%}}.user-management{box-sizing:border-box;display:flex;flex-direction:column;gap:20px;height:calc(100vh - 64px);height:calc(100vh - var(--header-height, 64px));margin:0;overflow:hidden;padding:0 24px;width:100%}.users-page-header{flex-shrink:0;padding:20px 0 0}.users-page-header__main{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.users-page-header__title{align-items:center;color:#1e293b;color:var(--color-text-primary,#1e293b);display:flex;font-size:1.5rem;font-weight:600;gap:10px;margin:0}.users-page-header__title svg{color:#3b82f6}.users-page-header__stats{display:flex;flex-wrap:wrap;gap:12px}.users-stat{align-items:center;border-radius:20px;display:inline-flex;font-size:.8rem;font-weight:500;gap:6px;padding:6px 12px}.users-stat--total{background:#f1f5f9;color:#475569}.users-section--table{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.users-loading-card{margin-top:20px}.users-loading-state{align-items:center;color:#64748b;color:var(--color-text-secondary,#64748b);display:flex;flex-direction:column;justify-content:center;padding:80px 24px}.users-loading-spinner{animation:spin 1s linear infinite;color:#1890ff;color:var(--color-primary,#1890ff);margin-bottom:16px}.users-loading-state p{font-size:14px;margin:0}.users-new-btn{align-items:center;background:#3b82f6;border:1px solid #0000;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.users-new-btn:hover{background:#2563eb}.users-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:1000}.users-modal-content{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;border-radius:var(--radius-lg,12px);box-shadow:0 10px 40px #00000026;box-shadow:var(--shadow-lg,0 10px 40px #00000026);max-height:95vh;max-width:960px;overflow-y:auto;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.users-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border,#e2e8f0);display:flex;justify-content:space-between;padding:12px 16px}.users-modal-header__title{align-items:center;color:#0f172a;color:var(--color-text-primary,#0f172a);display:flex;gap:12px}.users-modal-header__title h3{font-size:18px;font-weight:600;margin:0}.users-modal-header__title svg{color:#1890ff;color:var(--color-primary,#1890ff)}.users-modal-close{align-items:center;background:#0000;border:none;border-radius:8px;border-radius:var(--radius-md,8px);color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.users-modal-close:hover{background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);color:#0f172a;color:var(--color-text-primary,#0f172a)}.users-modal-content form{padding:8px 12px}.users-modal-warning{align-items:flex-start;background-color:#fef2f2;background-color:var(--color-danger-light,#fef2f2);border:1px solid #fecaca;border:1px solid var(--color-danger,#fecaca);border-radius:8px;border-radius:var(--radius-md,8px);color:#991b1b;color:var(--color-danger-dark,#991b1b);display:flex;font-size:14px;gap:12px;margin-bottom:20px;padding:14px 16px}.users-modal-warning svg{flex-shrink:0;margin-top:2px}.users-form-actions{align-items:center;border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border,#e2e8f0);display:flex;flex-wrap:wrap;gap:6px;justify-content:space-between;margin-top:6px;padding-top:6px}.users-form-buttons{align-items:center;display:flex;gap:12px}.users-btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.users-btn--primary{background:#3b82f6;color:#fff}.users-btn--primary:hover:not(:disabled){background:#2563eb}.users-btn--primary:disabled{cursor:not-allowed;opacity:.6}.users-btn--secondary{background:#fff;border-color:#e2e8f0;color:#475569}.users-btn--secondary:hover{background:#f8fafc;color:#1e293b}.users-btn--sm{font-size:13px;padding:6px 12px}.users-form-attachments{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.users-attachments-trigger{align-items:center;background:#0000;border:1px solid #1890ff;border:1px solid var(--color-primary,#1890ff);border-radius:8px;border-radius:var(--radius-md,8px);color:#1890ff;color:var(--color-primary,#1890ff);cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .2s ease}.users-attachments-trigger:hover{background-color:#1890ff14;background-color:var(--color-primary-light,#1890ff14)}.users-attachments-list{display:flex;flex-direction:column;gap:6px;list-style:none;margin:0;max-height:120px;max-width:280px;overflow-y:auto;padding:0;width:100%}.users-attachment-item{align-items:center;background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);display:flex;font-size:13px;gap:8px;padding:8px 10px}.users-attachment-icon{color:#94a3b8;color:var(--color-text-muted,#94a3b8);flex-shrink:0}.users-attachment-name{color:#0f172a;color:var(--color-text-primary,#0f172a);flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.users-attachment-remove{align-items:center;background:#0000;border:none;border-radius:4px;border-radius:var(--radius-sm,4px);color:#dc2626;color:var(--color-danger,#dc2626);cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;transition:background-color .2s ease;width:24px}.users-attachment-remove:hover{background-color:#fee2e2;background-color:var(--color-danger-light,#fee2e2)}.users-attachments-input{display:none}.users-table-card{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.users-table-header{flex-shrink:0}.users-table-content{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden;padding:0!important}.users-empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:80px 24px;text-align:center}.users-empty-icon{color:#94a3b8;color:var(--color-text-muted,#94a3b8);margin-bottom:16px;opacity:.5}.users-empty-state h3{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:16px;font-weight:600;margin:0 0 8px}.users-empty-state p{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:14px;margin:0}.users-table-scroll{flex:1 1;min-height:200px;overflow:auto}.users-table{border-collapse:collapse;min-width:1000px;table-layout:auto;width:100%}.users-table thead{background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);position:-webkit-sticky;position:sticky;top:0;z-index:10}.users-table th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border,#e2e8f0);color:#64748b;color:var(--color-text-secondary,#64748b);font-size:12px;font-weight:500;letter-spacing:.5px;padding:14px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.users-table td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--color-border-light,#f1f5f9);color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:14px;padding:14px 12px;vertical-align:middle}.users-table td.expand-column,.users-table th.expand-column{min-width:50px;text-align:center;width:50px}.users-table td.id-column,.users-table th.id-column{min-width:60px;text-align:center;width:60px}.users-table td.name-column,.users-table th.name-column{min-width:180px}.users-table td.actions-column,.users-table th.actions-column{min-width:80px;text-align:center;width:80px}.users-table-row{transition:background-color .2s ease}.users-table-row:hover{background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc)}.users-table-row--scheduled{background-color:#0ea5e90f}.users-table-row--scheduled:hover{background-color:#0ea5e91a}.users-expand-btn{align-items:center;background:#0000;border:none;border-radius:8px;border-radius:var(--radius-md,8px);color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.users-expand-btn:hover{background-color:#f1f5f9;background-color:var(--color-bg-tertiary,#f1f5f9);color:#0f172a;color:var(--color-text-primary,#0f172a)}.users-expand-btn svg{transition:transform .2s ease}.users-expand-btn--expanded svg{transform:rotate(90deg)}.users-name-cell{display:flex;flex-direction:column;gap:4px}.users-scheduled-badge{align-items:center;background-color:#0ea5e926;border:1px solid #0ea5e94d;border-radius:9999px;border-radius:var(--radius-full,9999px);color:#0369a1;color:var(--color-info-dark,#0369a1);display:inline-flex;font-size:11px;font-weight:600;gap:6px;padding:2px 8px;width:-webkit-fit-content;width:fit-content}.users-cancel-scheduled-btn{align-items:center;background:#0000;border:none;border-radius:3px;color:#dc2626;color:var(--color-danger,#dc2626);cursor:pointer;display:inline-flex;flex-shrink:0;justify-content:center;margin-left:2px;opacity:.9;padding:2px;transition:all .2s ease}.users-cancel-scheduled-btn:hover{background-color:#dc2626;background-color:var(--color-danger,#dc2626);color:#fff;opacity:1;transform:scale(1.1)}.users-actions{display:flex;gap:8px;justify-content:center}.users-action-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;display:inline-flex;justify-content:center;padding:6px 8px;transition:all .2s ease}.users-action-btn:hover:not(:disabled){background:#f9fafb}.users-action-btn:disabled{cursor:not-allowed;opacity:.4}.users-action-btn--edit{color:#3b82f6}.users-action-btn--edit:hover:not(:disabled){background:#eff6ff;border-color:#3b82f6}.users-action-btn--view{color:#3b82f6}.users-action-btn--view:hover:not(:disabled){background:#eff6ff;border-color:#3b82f6}.users-detail-row{background-color:initial}.users-detail-cell{border-top:none!important;padding:0!important}.users-detail-container{animation:slideDown .2s ease-out;background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:12px;border-radius:var(--radius-lg,12px);box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md,0 4px 12px #00000014);margin:12px 16px 16px;padding:20px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.role-badge,.status-badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full,9999px);display:inline-flex;font-size:11px;font-weight:600;gap:4px;letter-spacing:.3px;padding:4px 10px;text-transform:uppercase}.status-activo{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);color:#10b981;color:var(--color-success,#10b981)}.status-inactivo{background-color:#fef2f2;background-color:var(--color-danger-light,#fef2f2);color:#dc2626;color:var(--color-danger,#dc2626)}.role-usuario{background-color:#e0f2fe;color:#0369a1}.role-líder{background-color:#f3e8ff;color:#7c3aed}.role-rrhh{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);color:#10b981;color:var(--color-success,#10b981)}.role-administrador-global{background-color:#fff7ed;color:#c2410c}.form-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-grid,.form-group{margin-bottom:0}.form-group label{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:13px;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);color:#0f172a;color:var(--color-text-primary,#0f172a);font-family:inherit;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#1890ff;border-color:var(--color-primary,#1890ff);box-shadow:0 0 0 3px #1890ff1a;box-shadow:0 0 0 3px var(--color-primary-light,#1890ff1a)}.form-group input:disabled,.form-group select:disabled{background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:not-allowed}.form-hint{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:12px;margin-top:4px}.input-error{border-color:#dc2626!important;border-color:var(--color-danger,#dc2626)!important}.error-text{color:#dc2626;color:var(--color-danger,#dc2626);font-size:12px;margin-top:4px}.readonly-field{align-items:center;background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px);color:#0f172a;color:var(--color-text-primary,#0f172a);display:flex;font-size:14px;min-height:42px;padding:10px 12px}.readonly-field:empty:before{color:#94a3b8;color:var(--color-text-muted,#94a3b8);content:"-"}.advance-toggle-row{align-items:center;background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;display:flex;gap:12px;justify-content:space-between;padding:8px 12px}.advance-toggle-info h4{color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:13px;font-weight:600;margin:0 0 2px}.toggle-switch{align-items:center;background-color:#e2e8f0;background-color:var(--color-bg-tertiary,#e2e8f0);border:1px solid #0000;border-radius:9999px;border-radius:var(--radius-full,9999px);color:#64748b;color:var(--color-text-secondary,#64748b);cursor:pointer;display:inline-flex;font-weight:600;gap:8px;letter-spacing:.5px;padding:4px 10px 4px 4px;position:relative;text-transform:uppercase;transition:all .2s ease}.toggle-switch .switch-track{background-color:#cbd5e1;background-color:var(--color-border,#cbd5e1);border-radius:9999px;border-radius:var(--radius-full,9999px);height:18px;position:relative;transition:background-color .2s ease;width:34px}.toggle-switch .switch-thumb{background-color:#fff;border-radius:50%;box-shadow:0 1px 4px #00000026;height:14px;left:2px;position:absolute;top:2px;transition:transform .2s ease;width:14px}.toggle-switch.on{background-color:#ecfdf5;background-color:var(--color-success-light,#ecfdf5);border-color:#10b981;border-color:var(--color-success,#10b981);color:#047857;color:var(--color-success-dark,#047857)}.toggle-switch.on .switch-track{background-color:#10b981;background-color:var(--color-success,#10b981)}.toggle-switch.on .switch-thumb{transform:translateX(16px)}.switch-label{font-size:11px;letter-spacing:.5px}.director-area-list{grid-gap:6px;background-color:#f8fafc;background-color:var(--color-bg-secondary,#f8fafc);display:grid;gap:6px;max-height:220px;overflow-y:auto;padding:12px}.director-area-item,.director-area-list{border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;border-radius:var(--radius-md,8px)}.director-area-item{align-items:center;background-color:#fff;cursor:pointer;display:flex;justify-content:space-between;padding:10px 12px;transition:all .2s ease}.director-area-item:hover{background-color:#e0f2fe;background-color:var(--color-primary-light,#e0f2fe);border-color:#1890ff;border-color:var(--color-primary,#1890ff)}.director-area-name{color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:14px;font-weight:500}.director-area-check{accent-color:#1890ff;accent-color:var(--color-primary,#1890ff);cursor:pointer;height:18px;width:18px}.offb-modal-overlay{align-items:center;background:#0f172a66;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.offb-modal{animation:modalSlideIn .25s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 50px #00000026;display:flex;flex-direction:column;max-height:95vh;max-width:820px;width:100%}.offb-modal__header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;justify-content:space-between;padding:16px 20px}.offb-modal__header h3{color:#0f172a;font-size:1.05rem;font-weight:600;margin:0}.offb-modal__close{align-items:center;background:#0000;border:none;border-radius:8px;color:#94a3b8;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.offb-modal__close:hover{background:#f1f5f9;color:#0f172a}.offb-modal__body{display:flex;flex:1 1;flex-direction:column;gap:14px;overflow-y:auto;padding:16px 20px}.offb-readonly-block{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px 14px}.offb-readonly-grid{grid-gap:6px 16px;color:#334155;display:grid;font-size:13px;gap:6px 16px;grid-template-columns:1fr 1fr}.offb-readonly-grid--full{grid-column:1/-1}.offb-label{color:#64748b;font-weight:600}.offb-fields-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.offb-field--full{grid-column:1/-1}.offb-field__label{color:#374151;display:block;font-size:13px;font-weight:500;margin-bottom:4px}.offb-field__input{border:1px solid #e2e8f0;border-radius:6px;color:#0f172a;font-size:13px;padding:8px 10px;resize:vertical;transition:border-color .2s;width:100%}.offb-field__input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.offb-attachments__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.offb-attachments__hint{color:#94a3b8;font-size:13px}.offb-attachments__list{grid-gap:6px;display:grid;gap:6px;list-style:none;margin:0;padding:0}.offb-attachment-item{align-items:center;border:1px solid #e2e8f0;border-radius:6px;display:flex;font-size:13px;justify-content:space-between;padding:6px 10px}.offb-attachment-item__name{max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.offb-attachment-item__actions{display:flex;gap:6px}.offb-hidden-input{display:none}.offb-checklists{display:flex;flex-wrap:wrap;gap:16px}.offb-checkbox{align-items:center;color:#334155;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px}.offb-checkbox input[type=checkbox]{accent-color:#3b82f6;height:16px;width:16px}.offb-btn{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:6px;justify-content:center;padding:10px 20px;transition:all .15s}.offb-btn--primary{background:#3b82f6;color:#fff}.offb-btn--primary:hover{background:#2563eb}.offb-btn--secondary{background:#fff;border-color:#e2e8f0;color:#475569}.offb-btn--secondary:hover{background:#f8fafc}.offb-btn--outline{background:#fff;border-color:#3b82f6;color:#3b82f6}.offb-btn--outline:hover{background:#eff6ff}.offb-btn--danger{background:#fee2e2;border-color:#fecaca;color:#991b1b}.offb-btn--danger:hover{background:#fecaca}.offb-btn--sm{border-radius:6px;font-size:12px;font-weight:500;padding:5px 12px}.offb-btn--disabled{cursor:not-allowed;opacity:.6}.offb-modal__footer{border-top:1px solid #e2e8f0;display:flex;flex-shrink:0;gap:12px;justify-content:flex-end;padding:14px 20px}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;border-radius:var(--radius-lg,12px);box-shadow:0 10px 40px #00000026;box-shadow:var(--shadow-lg,0 10px 40px #00000026);max-height:95vh;max-width:95%;overflow-y:auto}.user-form-modal{max-width:960px;padding:24px;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border,#e2e8f0);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.modal-header h3{color:#0f172a;color:var(--color-text-primary,#0f172a);font-size:18px;font-weight:600;margin:0}.delete-confirm-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.delete-confirm-dialog{background:#fff;border-radius:12px;border-radius:var(--radius-lg,12px);box-shadow:0 10px 40px #00000026;box-shadow:var(--shadow-lg,0 10px 40px #00000026);max-width:400px;padding:24px;width:90%}.delete-confirm-dialog h3{color:#dc2626;color:var(--color-danger,#dc2626);font-size:18px;margin:0 0 12px}.delete-confirm-dialog p{color:#64748b;color:var(--color-text-secondary,#64748b);line-height:1.5;margin:0 0 20px}.delete-confirm-actions{display:flex;gap:12px;justify-content:flex-end}@media (max-width:1024px){.user-management{padding:0 16px}.users-page-header__main{align-items:flex-start;flex-direction:column}.users-filters-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.offb-fields-grid,.offb-readonly-grid{grid-template-columns:1fr}.offb-checklists{flex-direction:column;gap:10px}.user-management{height:calc(100vh - 56px);padding:0 12px}.users-page-header__title{font-size:1.25rem}.users-section__header{align-items:stretch;flex-direction:column}.users-filters-actions{justify-content:space-between}.users-filters-grid{grid-template-columns:1fr}.users-form-actions{align-items:stretch;flex-direction:column}.users-form-buttons{flex-direction:column;width:100%}.users-btn{width:100%}.users-form-attachments{align-items:stretch;width:100%}.users-attachments-list{max-width:100%}.users-table{font-size:13px;min-width:800px}.users-table td,.users-table th{padding:10px 8px}.advance-toggle-row{align-items:flex-start;flex-direction:column;gap:16px}.form-grid{grid-template-columns:1fr}}@media (max-width:480px){.users-page-header__title{font-size:18px}.users-new-btn span{display:none}.users-new-btn{padding:10px}.users-table td,.users-table th{font-size:12px;padding:8px 6px}.users-detail-container{margin:8px;padding:16px}}.vacation-approval{margin:0 auto;max-width:1400px}.vacation-approval__header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:20px}.vacation-approval__title{align-items:center;color:#1e293b;display:flex;font-size:1.5rem;font-weight:600;gap:10px;margin:0}.vacation-approval__title svg{color:#3b82f6}.vacation-approval__controls{align-items:center;display:flex;gap:12px}.vacation-approval__refresh{align-items:center;color:#64748b;display:flex;font-size:.8rem;gap:6px}.vacation-approval__kpi-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:20px}.vacation-approval__kpi-grid .kpi-card-container{height:120px}.vacation-approval__kpi-grid .kpi-card__content{padding:12px 32px 12px 16px}.vacation-approval__kpi-grid .kpi-card__title{font-size:.85rem}.vacation-approval__kpi-grid .kpi-card__value{font-size:1.75rem}.vacation-approval__kpi-grid .kpi-card__icon{height:20px;width:20px}.vacation-approval__kpi-grid .kpi-card__flip-btn{display:none}.vacation-approval .filter-bar{margin-bottom:20px}.vacation-search{position:relative;width:100%}.vacation-search__icon{color:#94a3b8;left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);z-index:1}.vacation-search input{border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;padding:10px 32px;transition:border-color .15s;width:100%}.vacation-search input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.vacation-search__clear{align-items:center;background:#f1f5f9;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;height:20px;justify-content:center;padding:0;position:absolute;right:6px;top:50%;transform:translateY(-50%);width:20px}.vacation-search__clear:hover{background:#e2e8f0}.vacation-search__dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 4px 12px #0000001a;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 4px);z-index:100}.vacation-search__item{align-items:center;border-bottom:1px solid #f1f5f9;cursor:pointer;display:flex;font-size:.875rem;justify-content:space-between;padding:8px 12px}.vacation-search__item:last-child{border-bottom:none}.vacation-search__item:hover{background:#f8fafc}.vacation-search__empty{color:#94a3b8;font-size:.85rem;padding:12px;text-align:center}.vacation-approval__table-card{margin-bottom:24px}.vacation-approval__table-title{align-items:center;display:flex;font-size:1rem;gap:10px;margin:0}.vacation-approval__count{align-items:center;background:#f1f5f9;border-radius:12px;color:#64748b;display:inline-flex;font-size:.75rem;font-weight:600;height:24px;justify-content:center;min-width:24px;padding:0 8px}.vacation-approval__table-content{padding:0!important}.vacation-approval__empty,.vacation-approval__loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:40px 20px}.vacation-approval__empty svg{color:#cbd5e1}.vacation-table-wrapper{overflow-x:auto}.vacation-table{border-collapse:collapse;font-size:.875rem;width:100%}.vacation-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.vacation-table th.text-center{text-align:center}.vacation-table th.text-right{text-align:right}.vacation-table td{border-bottom:1px solid #f1f5f9;padding:12px 16px;vertical-align:middle}.vacation-table td.text-center{text-align:center}.vacation-table td.text-right{text-align:right}.vacation-table tbody tr:hover{background:#fafbfc}.vacation-table tbody tr:last-child td{border-bottom:none}.vacation-row{border-left:3px solid #0000}.vacation-row--pendiente{border-left-color:#f59e0b}.vacation-row--aprobada{border-left-color:#10b981}.vacation-row--rechazada{border-left-color:#ef4444}.vacation-row--cancelada{border-left-color:#94a3b8}.row-highlight{animation:rowHighlight 3s ease-out}.vacation-cell-user{display:flex;flex-direction:column;gap:2px}.vacation-cell-user__name{align-items:center;color:#1e293b;display:flex;font-weight:500;gap:6px}.vacation-cell-user__date{color:#94a3b8;font-size:.75rem}.vacation-badge-adelanto{align-items:center;background:#fef3c7;border-radius:50%;color:#d97706;display:inline-flex;height:18px;justify-content:center;width:18px}.vacation-cell-period{align-items:center;color:#475569;display:flex;gap:6px;white-space:nowrap}.vacation-cell-period__sep{color:#cbd5e1}.vacation-cell-days{align-items:center;display:flex;flex-direction:column;gap:2px}.vacation-cell-days__value{color:#1e293b;font-size:1rem;font-weight:600}.vacation-cell-days__label{color:#94a3b8;font-size:.7rem}.vacation-cell-type{color:#475569}.vacation-status-badge{align-items:center;border-radius:4px;display:inline-flex;font-size:.75rem;font-weight:500;gap:4px;padding:4px 8px;white-space:nowrap}.vacation-status-badge--pendiente{background:#fef3c7;color:#92400e}.vacation-status-badge--aprobada{background:#dcfce7;color:#166534}.vacation-status-badge--rechazada{background:#fee2e2;color:#991b1b}.vacation-status-badge--cancelada{background:#f1f5f9;color:#64748b}.vacation-actions{display:flex;gap:6px;justify-content:flex-end}.vacation-action-btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;height:28px;justify-content:center;padding:0;transition:all .15s;width:28px}.vacation-action-btn--approve{background:#dcfce7;border-color:#bbf7d0;color:#16a34a}.vacation-action-btn--approve:hover{background:#16a34a;color:#fff}.vacation-action-btn--reject{background:#fee2e2;border-color:#fecaca;color:#dc2626}.vacation-action-btn--reject:hover{background:#dc2626;color:#fff}.vacation-action-btn--edit{background:#e0e7ff;border-color:#c7d2fe;color:#4338ca}.vacation-action-btn--edit:hover{background:#4338ca;color:#fff}.vacation-modal-overlay{animation:fadeIn .15s ease;background:#0f172a66}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.vacation-modal{animation:slideIn .2s ease;box-shadow:0 20px 40px #00000026;max-width:440px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.vacation-modal__header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:16px 20px}.vacation-modal__title{align-items:center;display:flex;gap:10px}.vacation-modal__title h4{color:#1e293b;font-size:1rem;margin:0}.vacation-modal__title svg{color:#64748b}.vacation-modal__icon--success{color:#10b981!important}.vacation-modal__icon--danger{color:#dc2626!important}.vacation-modal__close{align-items:center;background:#0000;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;height:32px;justify-content:center;padding:0;width:32px}.vacation-modal__close:hover{background:#f1f5f9;color:#64748b}.vacation-modal__body{padding:20px}.vacation-modal__actions{background:#f8fafc;border-top:1px solid #e2e8f0;gap:10px;justify-content:flex-end;padding:16px 20px}.vacation-form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.vacation-form-row:last-child{margin-bottom:0}.vacation-form-row label{align-items:center;color:#475569;display:flex;font-size:.8rem;font-weight:600;gap:6px}.vacation-form-row label svg{color:#94a3b8}.vacation-form-row input[type=date],.vacation-form-row textarea{border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;padding:10px 12px;resize:vertical;transition:border-color .15s;width:100%}.vacation-form-row input:focus,.vacation-form-row textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.vacation-alert{align-items:flex-start;border-radius:6px;display:flex;font-size:.85rem;gap:10px;line-height:1.4;margin-bottom:16px;padding:12px}.vacation-alert svg{flex-shrink:0;margin-top:1px}.vacation-alert--warning{background:#fef3c7;border:1px solid #fcd34d;color:#92400e}.vacation-alert--warning svg{color:#d97706}.vacation-btn--secondary{color:#475569}.vacation-btn--success{background:#10b981;color:#fff}.vacation-btn--success:hover:not(:disabled){background:#059669}.spin{animation:spin 1s linear infinite}@media (max-width:768px){.vacation-approval__header{align-items:flex-start;flex-direction:column}.vacation-approval__kpi-grid{grid-template-columns:repeat(3,1fr)}.vacation-approval__kpi-grid .kpi-card-container{height:100px}.vacation-approval__kpi-grid .kpi-card__value{font-size:1.5rem}}@media (max-width:640px){.vacation-approval__kpi-grid{grid-template-columns:1fr}.vacation-approval__kpi-grid .kpi-card-container{height:90px}.vacation-table{font-size:.8rem}.vacation-table td,.vacation-table th{padding:10px 12px}.vacation-cell-period{align-items:flex-start;flex-direction:column;gap:2px}.vacation-cell-period__sep{display:none}}@media (max-width:480px){.vacation-approval__title{font-size:1.25rem}.vacation-table td:nth-child(4),.vacation-table th:nth-child(4){display:none}.vacation-modal{margin:8px}}.vacation-page{margin:0 auto;max-width:1200px;padding:0}.vacation-loading{align-items:center;color:#64748b;color:var(--color-text-secondary,#64748b);display:flex;flex-direction:column;gap:16px;justify-content:center;padding:80px 24px}.vacation-loading__spinner{animation:vacation-spin .8s linear infinite;border:3px solid #e2e8f0;border-top-color:#1890ff;border:3px solid var(--color-border,#e2e8f0);border-radius:50%;border-top-color:var(--color-primary,#1890ff);height:40px;width:40px}@keyframes vacation-spin{to{transform:rotate(1turn)}}.vacation-page__header{margin-bottom:24px}.vacation-page__header-main{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.vacation-page__header-main h1{align-items:center;color:#1e293b;color:var(--color-text-primary,#1e293b);display:flex;font-size:1.5rem;font-weight:600;gap:10px;margin:0}.vacation-page__header-main h1 svg{color:#3b82f6}.vacation-page__stats{display:flex;flex-wrap:wrap;gap:12px}.vacation-stat{align-items:center;border-radius:20px;display:inline-flex;font-size:.8rem;font-weight:500;gap:6px;padding:6px 12px}.vacation-stat--total{background:#f1f5f9;color:#475569}.vacation-stat--used{background:#dbeafe;color:#1e40af}.vacation-stat--pending{background:#fef3c7;color:#92400e}.vacation-stat--available{background:#dcfce7;color:#166534}.vacation-stat--warning{background:#fee2e2;color:#991b1b}.vacation-section{margin-bottom:32px}.vacation-section__title{align-items:center;border-bottom:1px solid #e2e8f0;color:#475569;display:flex;font-size:.9rem;font-weight:600;gap:8px;letter-spacing:.5px;margin:0 0 16px;padding-bottom:8px;text-transform:uppercase}.vacation-section__title svg{color:#64748b}.vacation-section__count{background:#f1f5f9;border-radius:12px;color:#64748b;font-size:.75rem;font-weight:600;height:24px;margin-left:auto;min-width:24px;padding:0 8px}.vacation-btn,.vacation-section__count{align-items:center;display:inline-flex;justify-content:center}.vacation-btn{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;gap:6px;padding:8px 16px;text-decoration:none;transition:all .15s;white-space:nowrap}.vacation-btn:disabled{cursor:not-allowed;opacity:.6}.vacation-btn--primary{background:#3b82f6;color:#fff}.vacation-btn--primary:hover:not(:disabled){background:#2563eb}.vacation-btn--secondary{background:#fff;border-color:#e2e8f0;border-color:var(--color-border,#e2e8f0);color:#64748b;color:var(--color-text-secondary,#64748b)}.vacation-btn--secondary:hover:not(:disabled){background:#f8fafc;background:var(--color-bg-secondary,#f8fafc);border-color:#cbd5e1;border-color:var(--color-border-hover,#cbd5e1);color:#1e293b;color:var(--color-text-primary,#1e293b)}.vacation-btn--danger{background:#dc2626;border-color:#dc2626;color:#fff}.vacation-btn--danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.vacation-btn--danger-ghost{background:#0000;border-color:#0000;color:#dc2626;font-size:13px;padding:6px 10px}.vacation-btn--danger-ghost:hover:not(:disabled){background:#fef2f2}.vacation-btn--icon{background:#f8fafc;background:var(--color-bg-secondary,#f8fafc);border-color:#e2e8f0;border-color:var(--color-border,#e2e8f0);color:#64748b;color:var(--color-text-secondary,#64748b);height:36px;padding:0;width:36px}.vacation-btn--icon:hover:not(:disabled){background:#f1f5f9;background:var(--color-bg-tertiary,#f1f5f9);border-color:#cbd5e1;border-color:var(--color-border-hover,#cbd5e1);color:#1e293b;color:var(--color-text-primary,#1e293b)}.vacation-btn--icon.vacation-btn--active{background:#1890ff1a;border-color:#1890ff;border-color:var(--color-primary,#1890ff);color:#1890ff;color:var(--color-primary,#1890ff)}.vacation-btn--icon.vacation-btn--clear{color:#dc2626}.vacation-btn--icon.vacation-btn--clear:hover:not(:disabled){background:#fef2f2;color:#dc2626}.vacation-form-card,.vacation-list-card{margin-bottom:24px}.vacation-card-title{align-items:center;color:#1e293b;color:var(--color-text-primary,#1e293b);display:flex;font-size:16px;font-weight:600;gap:10px}.vacation-card-title__icon{color:#1890ff;color:var(--color-primary,#1890ff);flex-shrink:0}.vacation-summary{margin-bottom:24px}.vacation-summary__header{align-items:center;display:flex;gap:10px;margin-bottom:16px}.vacation-summary__header h3{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:16px;font-weight:600;margin:0}.vacation-summary__icon{color:#1890ff;color:var(--color-primary,#1890ff)}.vacation-summary__cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.vacation-summary__card{align-items:center;background:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:10px;display:flex;gap:12px;padding:16px;transition:all .2s ease}.vacation-summary__card:hover{border-color:#cbd5e1;border-color:var(--color-border-hover,#cbd5e1);box-shadow:0 2px 8px #0000000f}.vacation-summary__card--available{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac}.vacation-summary__card--warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#fbbf24}.vacation-summary__card-icon{align-items:center;background:#f1f5f9;background:var(--color-bg-tertiary,#f1f5f9);border-radius:10px;color:#64748b;color:var(--color-text-secondary,#64748b);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.vacation-summary__card-icon--used{background:#dbeafe;color:#2563eb}.vacation-summary__card-icon--pending{background:#fef3c7;color:#d97706}.vacation-summary__card-icon--available{background:#dcfce7;color:#16a34a}.vacation-summary__card-icon--warning{background:#fee2e2;color:#dc2626}.vacation-summary__card-content{display:flex;flex-direction:column;gap:2px}.vacation-summary__card-label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.vacation-summary__card-value{align-items:center;color:#1e293b;color:var(--color-text-primary,#1e293b);display:flex;font-size:24px;font-weight:700;gap:6px;line-height:1}.vacation-summary__card--available .vacation-summary__card-value{color:#15803d}.vacation-summary__card--warning .vacation-summary__card-value{color:#d97706}.vacation-summary__warning-icon{color:#dc2626}.vacation-notice{align-items:flex-start;background:#fffbeb;border:1px solid #fde68a;border-left:4px solid #f59e0b;border-radius:8px;color:#92400e;display:flex;font-size:13px;gap:10px;line-height:1.5;margin-bottom:20px;padding:12px 14px}.vacation-notice svg{flex-shrink:0;margin-top:2px}.vacation-info-box{align-items:flex-start;background:#dbeafe;border:1px solid #93c5fd;border-left:4px solid #3b82f6;border-radius:8px;color:#1e40af;display:flex;font-size:13px;gap:10px;line-height:1.5;margin-bottom:16px;padding:12px 14px}.vacation-info-box svg{flex-shrink:0;margin-top:2px}.vacation-info-box--warning{background:#fef3c7;border-color:#fde68a #fde68a #fde68a #f59e0b;color:#92400e}.vacation-form{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:1fr 1fr}.vacation-form__left{display:flex;flex-direction:column;gap:16px}.vacation-form__right{display:flex;flex-direction:column;gap:20px}.vacation-form__group{display:flex;flex-direction:column;gap:6px}.vacation-form__group label{align-items:center;color:#475569;color:var(--color-text-secondary,#475569);display:flex;font-size:13px;font-weight:500;gap:6px}.vacation-form__group label svg{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.vacation-form__group input,.vacation-form__group select,.vacation-form__group textarea{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;box-sizing:border-box;color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:14px;padding:10px 12px;transition:all .2s ease;width:100%}.vacation-form__group input:focus,.vacation-form__group select:focus,.vacation-form__group textarea:focus{border-color:#1890ff;border-color:var(--color-primary,#1890ff);box-shadow:0 0 0 3px #1890ff1a;outline:none}.vacation-form__group textarea{min-height:80px;resize:vertical}.vacation-form__input--readonly{background-color:#f8fafc!important;background-color:var(--color-bg-secondary,#f8fafc)!important;color:#64748b!important;color:var(--color-text-secondary,#64748b)!important;cursor:not-allowed}.vacation-form__hint{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:12px;line-height:1.4}.vacation-form__warning{color:#b45309;font-size:12px;line-height:1.4}.vacation-form__actions{display:flex;justify-content:flex-end;padding-top:16px}.vacation-calendar-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px}.vacation-calendar-header h4{align-items:center;color:#1e293b;color:var(--color-text-primary,#1e293b);display:flex;font-size:14px;font-weight:600;gap:8px;margin:0}.vacation-calendar-fallback{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:11px}.vacation-calendar{background:#f8fafc;background:var(--color-bg-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:12px;padding:16px}.vacation-calendar__nav{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.vacation-calendar__nav-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:8px;color:#64748b;color:var(--color-text-secondary,#64748b);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.vacation-calendar__nav-btn:hover{background:#f1f5f9;background:var(--color-bg-tertiary,#f1f5f9);border-color:#cbd5e1;border-color:var(--color-border-hover,#cbd5e1);color:#1e293b;color:var(--color-text-primary,#1e293b)}.vacation-calendar__current{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:15px;font-weight:600}.vacation-calendar__grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr)}.vacation-calendar__weekday{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:11px;font-weight:600;padding:4px 2px 8px;text-align:center;text-transform:uppercase}.vacation-calendar__cell{align-items:center;background:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:6px;color:#1e293b;color:var(--color-text-primary,#1e293b);display:flex;justify-content:center;min-height:36px;position:relative;transition:all .15s ease}.vacation-calendar__cell--empty{background:#0000;border:none}.vacation-calendar__cell--weekend{background:#f1f5f9;background:var(--color-bg-tertiary,#f1f5f9);color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.vacation-calendar__cell--holiday{background:#fecaca;border-color:#ef4444}.vacation-calendar__cell--holiday .vacation-calendar__day{color:#b91c1c}.vacation-calendar__cell--clickable{cursor:pointer}.vacation-calendar__cell--clickable:hover:not(.vacation-calendar__cell--holiday):not(.vacation-calendar__cell--weekend){background:#e0e7ff;border-color:#1890ff;border-color:var(--color-primary,#1890ff)}.vacation-calendar__cell--disabled{background:#f8fafc;background:var(--color-bg-secondary,#f8fafc);color:#cbd5e1;color:var(--color-text-muted,#cbd5e1);cursor:not-allowed;opacity:.5}.vacation-calendar__cell--selected-range{outline:2px solid #1890ff;outline:2px solid var(--color-primary,#1890ff);outline-offset:-2px}.vacation-calendar__cell--selected-start{background:#1890ff;background:var(--color-primary,#1890ff);border-color:#096dd9;border-color:var(--color-primary-hover,#096dd9);color:#fff}.vacation-calendar__cell--selected-start .vacation-calendar__day{color:#fff;font-weight:700}.vacation-calendar__day{font-size:13px;font-weight:500}.vacation-calendar__legend{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;font-size:11px;gap:16px;margin-top:12px}.vacation-calendar__legend-item{align-items:center;display:inline-flex;gap:6px}.vacation-calendar__legend-dot{border-radius:50%;display:inline-block;height:10px;width:10px}.vacation-calendar__legend-dot--holiday{background:#ef4444}.vacation-calendar__legend-dot--weekend{background:#94a3b8}.vacation-calendar__legend-dot--selected{background:#1890ff;background:var(--color-primary,#1890ff)}.vacation-calendar__hint{display:block;font-size:11px;line-height:1.4;margin-top:12px}.vacation-calendar__hint,.vacation-empty{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.vacation-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 24px;text-align:center}.vacation-empty svg{margin-bottom:16px;opacity:.5}.vacation-empty p{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:15px;font-weight:500;margin:0 0 4px}.vacation-empty span{font-size:13px}.vacation-list{display:flex;flex-direction:column;gap:12px}.vacation-item{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:10px;display:flex;gap:16px;justify-content:space-between;padding:16px;transition:all .2s ease}.vacation-item:hover{border-color:#cbd5e1;border-color:var(--color-border-hover,#cbd5e1);box-shadow:0 2px 8px #0000000f}.vacation-item.estado-pendiente{border-left:4px solid #eab308}.vacation-item.estado-aprobada{border-left:4px solid #16a34a}.vacation-item.estado-rechazada{border-left:4px solid #dc2626}.vacation-item.estado-cancelada{border-left:4px solid #94a3b8}.vacation-item__main{display:flex;flex:1 1;flex-direction:column;gap:8px;min-width:0}.vacation-item__header{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.vacation-item__type{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:15px;font-weight:600}.vacation-item__adelanto{background:#fef3c7;border:1px solid #fbbf24;border-radius:10px;color:#92400e;padding:3px 8px}.vacation-item__adelanto,.vacation-item__status{align-items:center;display:inline-flex;font-size:11px;font-weight:600;gap:4px}.vacation-item__status{border-radius:12px;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.vacation-item__status.estado-pendiente{background:#fef3c7;color:#92400e}.vacation-item__status.estado-aprobada{background:#dcfce7;color:#166534}.vacation-item__status.estado-rechazada{background:#fee2e2;color:#991b1b}.vacation-item__status.estado-cancelada{background:#f1f5f9;color:#475569}.vacation-item__dates{align-items:center;color:#1e293b;color:var(--color-text-primary,#1e293b);display:flex;font-size:14px;gap:8px}.vacation-item__dates svg,.vacation-item__dates-separator{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.vacation-item__days{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:13px}.vacation-item__meta{display:flex;flex-direction:column;gap:4px}.vacation-item__request-date{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:12px;line-height:1.4}.vacation-item__rejection{align-items:center;color:#dc2626;display:inline-flex;font-size:12px;font-weight:500;gap:4px}.vacation-item__actions{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:8px}.vacation-modal-overlay{align-items:center;background:#0f172a80;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.vacation-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;padding:24px;text-align:center;width:100%}.vacation-modal__icon{align-items:center;border-radius:50%;display:inline-flex;height:56px;justify-content:center;margin-bottom:16px;width:56px}.vacation-modal__icon--warning{background:#fef3c7;color:#d97706}.vacation-modal__title{color:#1e293b;color:var(--color-text-primary,#1e293b);font-size:18px;font-weight:600;margin:0 0 8px}.vacation-modal__text{color:#64748b;color:var(--color-text-secondary,#64748b);font-size:14px;line-height:1.5;margin:0 0 24px}.vacation-modal__actions{display:flex;gap:12px;justify-content:center}.vacation-item.row-highlight{animation:rowHighlight 3s ease-out}@keyframes rowHighlight{0%,70%{background-color:#fef3c7}to{background-color:initial}}@media (max-width:1024px){.vacation-summary__cards{grid-template-columns:repeat(2,1fr)}.vacation-form{gap:24px;grid-template-columns:1fr}}@media (max-width:768px){.vacation-page__header-main{align-items:flex-start;flex-direction:column}.vacation-page__header-main h1{font-size:1.25rem}.vacation-page__stats{width:100%}.vacation-stat{flex:1 1;justify-content:center}.vacation-item{flex-direction:column;gap:12px}.vacation-item__actions{align-items:center;flex-direction:row;flex-wrap:wrap;justify-content:flex-end;width:100%}.vacation-modal__actions{flex-direction:column}.vacation-modal__actions .vacation-btn{width:100%}}@media (max-width:640px){.vacation-page__stats{flex-direction:column}.vacation-stat{justify-content:flex-start}}@media (max-width:480px){.vacation-item__header{align-items:flex-start;flex-direction:column;gap:6px}.vacation-item__dates{flex-wrap:wrap}.vacation-calendar__legend{flex-wrap:wrap;gap:8px}}:root{--sidebar-width:228px;--sidebar-collapsed-width:72px;--header-height:64px;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-light:#dbeafe;--color-text-primary:#1e293b;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--color-bg-primary:#fff;--color-bg-secondary:#f8fafc;--color-bg-tertiary:#f1f5f9;--color-border:#e2e8f0;--color-border-hover:#cbd5e1;--color-success:#16a34a;--color-success-light:#dcfce7;--color-warning:#f59e0b;--color-warning-light:#fef3c7;--color-danger:#dc2626;--color-danger-light:#fee2e2;--color-info:#0ea5e9;--color-info-light:#e0f2fe;--transition-fast:0.15s ease;--transition-normal:0.2s ease;--transition-slow:0.3s ease;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--z-dropdown:100;--z-sidebar:200;--z-header:300;--z-modal-backdrop:400;--z-modal:500;--z-toast:600}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333;font-family:Arboria,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{min-height:100vh}.App,.loading-container{display:flex;flex-direction:column}.loading-container{align-items:center;background-color:#f8f9fa;height:100vh;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e3e3e3;border-radius:50%;border-top-color:#007bff;height:40px;margin-bottom:20px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading{color:#666;font-size:18px;padding:40px}.btn,.loading{text-align:center}.btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;text-decoration:none;transition:all .15s}.btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333}.btn-sm{font-size:12px;padding:5px 10px}.alert{border-radius:5px;font-weight:500;margin-bottom:20px;padding:15px}.alert-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert-warning{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:5px}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:5px;font-size:14px;padding:10px;transition:border-color .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.error{background-color:#f8d7da;border-radius:5px;color:#dc3545;margin:20px 0;padding:20px;text-align:center}.dev-notice{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:5px;margin-top:30px;padding:15px;text-align:center}.dev-notice h4{color:#856404;margin-bottom:10px}.dev-notice p{color:#856404;margin:0}@media (max-width:768px){.btn{font-size:13px;padding:8px 16px}}
/*# sourceMappingURL=main.20b7147b.css.map*/