.schedule-container{background-color:var(--color-white);border-radius:var(--border-radius);box-shadow:var(--shadow-md);overflow:hidden;border:1px solid var(--color-gray-border);font-family:var(--font-sans)}.schedule-header{background-color:#f8fafc;padding:1.5rem;border-bottom:1px solid var(--color-gray-border);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center}.controls-group{display:flex;align-items:center;gap:1rem;flex:1}.input-group{display:flex;flex-direction:column}.input-label{font-size:.75rem;color:var(--color-gray-text);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.input-field{background:transparent;border:none;border-bottom:2px solid var(--color-gray-border);font-weight:700;color:var(--color-blue-deep);font-size:1rem;padding:.25rem 0;outline:none;transition:border-color .2s}.input-field:focus{border-bottom-color:var(--color-blue-deep)}.divider{width:1px;height:32px;background-color:var(--color-gray-border);margin:0 .5rem}.toggle-group{display:flex;background-color:var(--color-white);border:1px solid var(--color-gray-border);border-radius:var(--border-radius);padding:.25rem;box-shadow:var(--shadow-sm)}.toggle-btn{padding:.5rem 1rem;border-radius:.25rem;border:none;background:transparent;font-size:.875rem;font-weight:500;cursor:pointer;color:var(--color-gray-text);transition:all .2s}.toggle-btn.active{background-color:#eff6ff;color:var(--color-blue-deep);font-weight:600}.toggle-btn:hover:not(.active){background-color:#f1f5f9}.actions-group{display:flex;gap:.5rem}.btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--border-radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent}.btn-story{background-color:var(--color-white);border-color:var(--color-gray-border);color:var(--color-gray-text);box-shadow:var(--shadow-sm)}.btn-story:hover{background-color:#f8fafc;border-color:#cbd5e1}.btn-pdf{background-color:#fef2f2;color:#991b1b;border-color:#fecaca}.btn-pdf:hover{background-color:#fee2e2}.btn-excel{background-color:#f0fdf4;color:#166534;border-color:#bbf7d0}.btn-excel:hover{background-color:#dcfce7}.date-nav{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;background-color:var(--color-white)}.nav-btn{padding:.5rem;border-radius:50%;border:none;background:transparent;cursor:pointer;color:var(--color-gray-text);transition:background-color .2s}.nav-btn:hover{background-color:#f1f5f9}.current-date{font-size:1.25rem;font-weight:700;color:var(--color-blue-deep);text-transform:capitalize;display:flex;align-items:center;gap:.5rem}.loading-indicator{font-size:.75rem;color:#3b82f6;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.shifts-scroll{overflow-x:auto;padding:0 1.5rem 1.5rem;scrollbar-width:thin}.shifts-container{display:flex;gap:.75rem;min-width:min-content}.shift-pill{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:9999px;border:1px solid var(--color-gray-border);background-color:var(--color-white);cursor:pointer;transition:all .2s;white-space:nowrap}.shift-pill:hover{background-color:#f8fafc;border-color:#cbd5e1}.shift-pill.selected{border-color:var(--color-blue-deep);box-shadow:0 0 0 2px #0d1e4c1a;transform:translateY(-1px)}.shift-pill.selected.shift-green{background-color:#dcfce7;color:#166534;border-color:#166534}.shift-pill.selected.shift-blue{background-color:#dbeafe;color:#1e40af;border-color:#1e40af}.shift-pill.selected.shift-purple{background-color:#f3e8ff;color:#6b21a8;border-color:#6b21a8}.shift-pill.selected.shift-yellow{background-color:#fef9c3;color:#854d0e;border-color:#854d0e}.shift-pill.selected.shift-red{background-color:#fee2e2;color:#991b1b;border-color:#991b1b}.shift-pill.selected.shift-gray{background-color:#f3f4f6;color:#374151;border-color:#374151}.shift-dot{width:.75rem;height:.75rem;border-radius:50%;background-color:#9ca3af}.shift-green .shift-dot{background-color:#166534}.shift-blue .shift-dot{background-color:#1e40af}.shift-purple .shift-dot{background-color:#6b21a8}.shift-yellow .shift-dot{background-color:#854d0e}.shift-red .shift-dot{background-color:#991b1b}.shift-gray .shift-dot{background-color:#374151}.shift-name{font-weight:600;font-size:.875rem}.shift-time{font-size:.75rem;color:inherit;opacity:.8}.btn-delete-shift{background:transparent;border:none;color:#94a3b8;padding:.1rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s;margin-left:.5rem}.shift-pill:hover .btn-delete-shift{opacity:1}.btn-delete-shift:hover{background-color:#fee2e2;color:#ef4444}.btn-new-shift{border-style:dashed;color:var(--color-gray-text)}.schedule-table-container{overflow-x:auto;border-top:1px solid var(--color-gray-border)}.schedule-table{width:100%;border-collapse:collapse;min-width:800px}.schedule-table th,.schedule-table td{padding:.75rem;text-align:center;border-bottom:1px solid var(--color-gray-border);border-right:1px solid var(--color-gray-border)}.schedule-table th{background-color:#f8fafc;font-weight:600;color:var(--color-gray-text)}.col-employee{text-align:left!important;position:sticky;left:0;background-color:#f8fafc;z-index:10;min-width:200px;box-shadow:2px 0 5px -2px #0000001a}.col-total{position:sticky;right:0;background-color:#f8fafc;z-index:10;box-shadow:-2px 0 5px -2px #0000001a}.day-header{display:flex;flex-direction:column;align-items:center;gap:.25rem}.day-name{font-size:.75rem;text-transform:uppercase;color:#64748b}.day-number{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:600;font-size:.875rem;color:var(--color-gray-text)}.day-number.today{background-color:var(--color-blue-deep);color:var(--color-white)}.row-employee td{transition:background-color .2s}.row-employee:hover td{background-color:#f8fafc}.row-employee .col-employee{background-color:var(--color-white)}.row-employee:hover .col-employee{background-color:#f8fafc}.emp-name{font-weight:600;color:var(--color-blue-deep);display:block}.emp-role{font-size:.75rem;color:#64748b}.cell-shift{cursor:pointer;position:relative;height:3rem}.cell-shift:hover{background-color:#f1f5f9}.shift-block{height:100%;width:100%;border-radius:.25rem;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;box-shadow:var(--shadow-sm)}.block-green{background-color:#dcfce7;color:#166534}.block-blue{background-color:#dbeafe;color:#1e40af}.block-purple{background-color:#f3e8ff;color:#6b21a8}.block-yellow{background-color:#fef9c3;color:#854d0e}.block-red{background-color:#fee2e2;color:#991b1b}.block-gray{background-color:#f3f4f6;color:#374151;border:1px dashed #cbd5e1}.empty-cell-icon{opacity:0;transition:opacity .2s;color:#cbd5e1}.cell-shift:hover .empty-cell-icon{opacity:1}.total-hours{font-weight:700;font-size:.875rem}.total-hours.valid{color:#334155}.total-hours.invalid{color:#dc2626}.footer-info{padding:1rem;background-color:#f8fafc;font-size:.75rem;color:#64748b;display:flex;justify-content:space-between;border-top:1px solid var(--color-gray-border)}.modal-overlay{position:fixed;inset:0;z-index:50;background-color:#00000080;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(2px)}.modal-content{background-color:var(--color-white);border-radius:var(--border-radius);box-shadow:var(--shadow-md);width:100%;max-width:28rem;margin:1rem;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--color-gray-border)}.modal-title{font-size:1.125rem;font-weight:700;color:var(--color-gray-text)}.btn-close{padding:.25rem;border-radius:50%;color:#94a3b8;background:transparent;border:none;cursor:pointer}.btn-close:hover{background-color:#f1f5f9;color:var(--color-gray-text)}.modal-body{padding:1rem;max-height:60vh;overflow-y:auto}.employee-list{display:flex;flex-direction:column;gap:.5rem}.employee-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:var(--border-radius);border:1px solid var(--color-gray-border);cursor:pointer;transition:all .2s;background-color:#f8fafc}.employee-item:hover{background-color:#f1f5f9}.employee-item.active{background-color:#eff6ff;border-color:#bfdbfe}.check-box{width:1.25rem;height:1.25rem;border-radius:.25rem;border:1px solid #cbd5e1;display:flex;align-items:center;justify-content:center;background-color:var(--color-white)}.employee-item.active .check-box{background-color:#2563eb;border-color:#2563eb;color:#fff}.modal-footer{padding:1rem;border-top:1px solid var(--color-gray-border);display:flex;justify-content:flex-end;background-color:#f8fafc}.btn-primary{background-color:#2563eb;color:#fff;padding:.5rem 1rem;border-radius:var(--border-radius);border:none;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:#1d4ed8}
