:root{--alc-primary-color:var(--primary-color,#6366f1);--alc-text-primary:var(--text-primary,#1a1a2e);--alc-text-secondary:var(--text-secondary,#6b7280);--alc-border-color:var(--border-color,#e5e7eb);--alc-card-bg:var(--card-bg,#fff)}.alc-loading{justify-content:center;align-items:center;height:16rem;display:flex}.alc-loading__text{color:var(--alc-text-secondary)}.alc-empty{flex-direction:column;justify-content:center;align-items:center;padding:4rem 1rem;display:flex}.alc-empty__icon{background-color:#f1f5f9;border-radius:9999px;justify-content:center;align-items:center;width:4rem;height:4rem;margin-bottom:1rem;display:flex}.alc-empty__icon svg{color:#94a3b8;width:2rem;height:2rem}.alc-empty__title{color:#475569;margin-bottom:.25rem;font-size:1.125rem;font-weight:600}.alc-empty__description{color:#94a3b8;text-align:center;max-width:24rem;font-size:.875rem}.alc-container{width:100%}.alc-scroll-wrapper{overflow-x:auto}.alc-table{border-collapse:collapse;width:100%}.alc-header-user{z-index:20;background-color:var(--alc-card-bg);text-align:left;color:#374151;border-bottom:2px solid #d1d5db;min-width:180px;padding:.75rem 1rem;font-size:.875rem;font-weight:600;position:sticky;left:0}.alc-header-user__inner{align-items:center;gap:.5rem;display:flex}.alc-header-user__icon{width:1rem;height:1rem;color:var(--alc-text-secondary)}.alc-header-day{text-align:center;border-bottom:2px solid #d1d5db;min-width:140px;padding:.5rem}.alc-header-day--default{background-color:var(--alc-card-bg)}.alc-header-day--weekend{background-color:#f9fafb}.alc-header-day__weekday{text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px;font-size:11px;font-weight:600}.alc-header-day__weekday--default{color:var(--alc-text-secondary)}.alc-header-day__weekday--weekend{color:#dc2626}.alc-header-day__number{font-size:1.125rem;font-weight:700}.alc-header-day__number--default{color:#111827}.alc-header-day__number--weekend{color:#b91c1c}.alc-row--even{background-color:var(--alc-card-bg)}.alc-row--odd{background-color:#f9fafb}.alc-user-cell{z-index:10;border-bottom:1px solid var(--alc-border-color);border-right:1px solid var(--alc-border-color);background:inherit;padding:.75rem 1rem;position:sticky;left:0}.alc-user-cell__inner{flex-direction:column;display:flex}.alc-user-cell__name{color:#111827;margin-bottom:2px;font-size:.875rem;font-weight:600}.alc-user-cell__role{color:var(--alc-text-secondary);font-size:11px}.alc-user-cell__total{color:#4b5563;margin-top:.375rem;font-size:11px}.alc-user-cell__total-label{font-weight:600}.alc-user-cell__total-value{color:#2563eb;font-weight:700}.alc-day-cell{border-bottom:1px solid var(--alc-border-color);border-right:1px solid var(--alc-border-color);vertical-align:top;padding:.5rem}.alc-day-cell--default{background-color:var(--alc-card-bg)}.alc-day-cell--weekend{background-color:#f9fafb}.alc-day-cell__tasks{min-height:80px}.alc-day-cell__tasks>*+*{margin-top:.375rem}.alc-task-card{cursor:pointer;border-radius:.375rem;padding:.5rem;transition:all .15s}.alc-task-card:hover{transform:scale(1.02);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.alc-task-card__header{justify-content:space-between;align-items:center;margin-bottom:.25rem;display:flex}.alc-task-card__hours{font-size:.75rem;font-weight:700}.alc-task-card__title{text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px;font-size:11px;font-weight:600;overflow:hidden}.alc-task-card__project{opacity:.8;text-overflow:ellipsis;white-space:nowrap;font-size:10px;overflow:hidden}.alc-day-empty{color:#d1d5db;justify-content:center;align-items:center;height:5rem;font-size:.875rem;font-weight:500;display:flex}.alc-day-total{text-align:center;margin-top:.5rem}.alc-day-total__text{color:#374151;font-size:11px;font-weight:700}
.allocations-page{background:linear-gradient(#f8fafc 0%,#f1f5f9 100%);flex-direction:column;width:100%;min-height:100vh;padding:0;display:flex}.allocations-header{background:linear-gradient(135deg,#1e293b 0%,#334155 100%);border-bottom:3px solid #0ea5e9;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:1.5rem;padding:1.5rem 6rem 1.5rem 2rem;animation:.5s ease-in fadeIn;display:flex;box-shadow:0 2px 8px #0000001a}.allocations-header-content{align-items:center;gap:1rem;display:flex}.allocations-header-icon{background:linear-gradient(135deg,#0ea5e9 0%,#0284c7 100%);border-radius:.375rem;justify-content:center;align-items:center;padding:.875rem;display:flex}.allocations-header-icon svg{color:#fff;width:1.5rem;height:1.5rem}.allocations-header-text h1{color:#fff;letter-spacing:-.025em;margin:0;font-size:1.875rem;font-weight:700}.allocations-header-text p{color:#cbd5e1;margin:.25rem 0 0;font-size:.875rem;font-weight:400}.allocations-content{flex-direction:column;flex:1;padding:1.5rem;display:flex;overflow-x:hidden}.summary-grid{grid-template-columns:repeat(1,1fr);gap:1rem;margin-bottom:1.5rem;animation:.5s ease-in fadeIn;display:grid}@media (min-width:640px){.summary-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.summary-grid{grid-template-columns:repeat(4,1fr)}}.summary-card{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;padding:1.25rem;transition:all .2s;box-shadow:0 1px 3px #0000001a}.summary-card:hover{border-color:#0ea5e9;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.summary-card-label{color:#64748b;margin-bottom:.5rem;font-size:.875rem;font-weight:500}.summary-card-value{font-size:2rem;font-weight:700;line-height:1}.summary-card-value.default{color:#0f172a}.summary-card-value.blue{color:#0ea5e9}.summary-card-value.green{color:#10b981}.summary-card-value.purple{color:#8b5cf6}.summary-card-available-wrapper{cursor:default;position:relative}.summary-card-tooltip{z-index:50;color:#f8fafc;pointer-events:none;background:#1e293b;border-radius:.5rem;min-width:200px;max-width:280px;padding:.75rem 1rem;display:none;position:absolute;top:calc(100% + 8px);left:0;box-shadow:0 8px 24px #0003}.summary-card-tooltip:before{content:"";border-bottom:6px solid #1e293b;border-left:6px solid #0000;border-right:6px solid #0000;position:absolute;top:-6px;left:1.25rem}.summary-card-available-wrapper:hover .summary-card-tooltip{display:block}.summary-card-tooltip-title{text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;margin-bottom:.5rem;font-size:.7rem;font-weight:600}.summary-card-tooltip-list{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.summary-card-tooltip-list li{color:#e2e8f0;border-bottom:1px solid #ffffff0f;padding:.2rem 0;font-size:.8125rem;font-weight:500}.summary-card-tooltip-list li:last-child{border-bottom:none}.filters-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.filters-top-bar{background:linear-gradient(90deg,#f8fafc,#fff);border-bottom:1px solid #e2e8f0;flex-direction:column;gap:.75rem;padding:1rem;display:flex}@media (min-width:640px){.filters-top-bar{flex-direction:row;justify-content:space-between;align-items:center}}.date-navigation{align-items:center;gap:.5rem;display:flex}.nav-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:.5rem;padding:.5rem;transition:all .2s}.nav-btn:hover{color:#0f172a;background:#f1f5f9}.nav-btn svg{width:1.25rem;height:1.25rem}.date-display{background:#fff;border:1px solid #cbd5e1;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;min-width:280px;padding:.5rem 1rem;display:flex;box-shadow:0 1px 2px #0000000d}.date-display svg{color:#0ea5e9;width:1rem;height:1rem}.date-display-text{color:#0f172a;font-size:.875rem;font-weight:600}.nav-divider{background:#cbd5e1;width:1px;height:2rem;margin:0 .25rem}.today-btn{color:#0c4a6e;cursor:pointer;background:#e0f2fe;border:1px solid #bae6fd;border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.today-btn:hover{background:#bae6fd;border-color:#7dd3fc}.view-toggle{background:#f1f5f9;border-radius:.5rem;align-items:center;padding:.25rem;display:inline-flex}.view-toggle-btn{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:.375rem;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.view-toggle-btn.active{color:#0c4a6e;background:#fff;box-shadow:0 1px 2px #0000000d}.view-toggle-btn:not(.active):hover{color:#0f172a}.view-toggle-btn svg{width:1rem;height:1rem}.filters-bottom-bar{background:#f9fafb;flex-wrap:wrap;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.filter-label-group svg{width:1.125rem;height:1.125rem}.filter-input-group{align-items:center;gap:.625rem;display:flex}.filter-input-label{color:#475569;white-space:nowrap;font-size:.875rem;font-weight:500}.filter-select{cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:.5rem;min-width:220px;max-width:280px;padding:.625rem 2.5rem .625rem .875rem;font-size:.875rem;transition:all .2s}.filter-select:disabled{color:#94a3b8;cursor:not-allowed;opacity:.6;background:#f1f5f9}.filter-select:not(:disabled):hover{border-color:#94a3b8}.filter-select:not(:disabled):focus{border-color:#0ea5e9;outline:none;box-shadow:0 0 0 3px #0ea5e91a}.autocomplete-container{flex:1;min-width:220px;max-width:280px;position:relative}.autocomplete-input-wrapper{align-items:center;display:flex;position:relative}.filter-input{cursor:text;background:#fff;border:1px solid #cbd5e1;border-radius:.5rem;width:100%;padding:.625rem 2.5rem .625rem .875rem;font-size:.875rem;transition:all .2s}.filter-input:hover{border-color:#94a3b8}.filter-input:focus{border-color:#0ea5e9;outline:none;box-shadow:0 0 0 3px #0ea5e91a}.filter-input::placeholder{color:#94a3b8}.autocomplete-clear-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;font-size:1rem;transition:color .2s;display:flex;position:absolute;right:.625rem}.autocomplete-clear-btn:hover{color:#475569}.autocomplete-dropdown{z-index:9999;background:#fff;border:1px solid #cbd5e1;border-radius:.5rem;max-height:300px;position:absolute;top:calc(100% + .25rem);left:0;right:0;overflow-y:auto;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.autocomplete-option{cursor:pointer;border-bottom:1px solid #f1f5f9;padding:.625rem .875rem;transition:background-color .15s}.autocomplete-option:last-child{border-bottom:none}.autocomplete-option:hover,.autocomplete-option.highlighted{background-color:#f0f9ff}.autocomplete-option-name{color:#1e293b;font-size:.875rem;font-weight:500}.autocomplete-option-role{color:#64748b;margin-top:.125rem;font-size:.75rem}.autocomplete-no-results{text-align:center;color:#94a3b8;padding:.875rem;font-size:.875rem}.filter-divider-text{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;padding:0 .5rem;font-size:.75rem;font-weight:700}.clear-filters-btn{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;align-items:center;gap:.375rem;margin-left:auto;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.clear-filters-btn:hover{background:#fee2e2;border-color:#fca5a5}.clear-filters-btn svg{width:1rem;height:1rem}@media (max-width:768px){.filters-bottom-bar{flex-direction:column;align-items:stretch;gap:.75rem}.filter-label-group{justify-content:center;width:100%}.filter-input-group{flex-direction:column;align-items:stretch;gap:.375rem}.filter-select{min-width:100%;max-width:100%}.filter-divider-text{text-align:center;padding:.5rem 0}.clear-filters-btn{justify-content:center;margin-left:0}}.calendar-container{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;max-width:100%;overflow:auto visible;box-shadow:0 1px 3px #0000001a}.empty-state{text-align:center;color:#64748b;padding:4rem 2rem}.empty-state svg{color:#cbd5e1;width:4rem;height:4rem;margin:0 auto 1rem}.empty-state h3{color:#475569;margin:0 0 .75rem;font-size:1.25rem;font-weight:600}.empty-state p{max-width:32rem;margin:0 auto;font-size:.95rem;line-height:1.6}.loading-state{color:#64748b;justify-content:center;align-items:center;padding:3rem;display:flex}.error-alert{background:#fef2f2;border-left:4px solid #dc2626;border-radius:.375rem;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex}.error-alert svg{color:#dc2626;flex-shrink:0;width:1.25rem;height:1.25rem}.error-alert p{color:#991b1b;margin:0;font-size:.875rem;font-weight:500}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.task-modal-overlay{z-index:50;background-color:#00000080;justify-content:center;align-items:center;padding:1rem;animation:.2s ease-out modalFadeIn;display:flex;position:fixed;inset:0}.task-modal-container{background:#fff;border-radius:1rem;width:100%;max-width:48rem;max-height:90vh;animation:.3s ease-out modalSlideIn;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.task-modal-header{background:linear-gradient(90deg,#f8fafc,#fff);border-bottom:2px solid #e2e8f0;border-radius:1rem 1rem 0 0;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.task-modal-title{color:#1e293b;margin:0;font-size:1.5rem;font-weight:700}.task-modal-close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:.5rem;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.task-modal-close-btn:hover{color:#475569;background:#f1f5f9}.task-modal-close-btn svg{width:1.5rem;height:1.5rem}.task-modal-body{padding:2rem}.task-modal-section{margin-bottom:1.5rem}.task-modal-section:last-child{margin-bottom:0}.task-modal-label{text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-bottom:.5rem;font-size:.75rem;font-weight:600;display:block}.task-modal-value{color:#1e293b;margin-top:.25rem;font-size:1rem;font-weight:600}.task-modal-value-light{color:#475569;font-size:.875rem;font-weight:400;line-height:1.6}.task-modal-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (min-width:640px){.task-modal-grid{grid-template-columns:repeat(2,1fr)}}.task-modal-status-badge{text-transform:capitalize;border-radius:9999px;align-items:center;padding:.375rem .875rem;font-size:.75rem;font-weight:600;display:inline-flex}.task-modal-status-pending{color:#92400e;background:#fef3c7}.task-modal-status-in-progress{color:#1e40af;background:#dbeafe}.task-modal-status-completed{color:#065f46;background:#d1fae5}.task-modal-priority{text-transform:capitalize;border-radius:.5rem;align-items:center;padding:.375rem .875rem;font-size:.75rem;font-weight:600;display:inline-flex}.task-modal-priority-low{color:#075985;background:#e0f2fe}.task-modal-priority-medium{color:#92400e;background:#fef3c7}.task-modal-priority-high{color:#991b1b;background:#fee2e2}.task-modal-progress-bar-container{align-items:center;gap:.75rem;display:flex}.task-modal-progress-bar-wrapper{background:#e2e8f0;border-radius:9999px;flex:1;height:.5rem;overflow:hidden}.task-modal-progress-bar-fill{background:linear-gradient(90deg,#0ea5e9,#0284c7);border-radius:9999px;height:100%;transition:width .3s}.task-modal-progress-text{color:#1e293b;text-align:right;min-width:3rem;font-size:.875rem;font-weight:600}.task-modal-footer{background:#f8fafc;border-top:1px solid #e2e8f0;border-radius:0 0 1rem 1rem;justify-content:flex-end;padding:1.5rem 2rem;display:flex}.task-modal-footer-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0ea5e9,#0284c7);border:none;border-radius:.5rem;padding:.625rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s;box-shadow:0 1px 2px #0000000d}.task-modal-footer-btn:hover{background:linear-gradient(135deg,#0284c7,#0369a1);transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.task-modal-footer-btn:active{transform:translateY(0)}
