:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #64748b;--border-color: #e2e8f0;--accent-primary: #2563eb;--accent-hover: #1d4ed8;--accent-active: #1e40af;--color-holiday: #ef4444;--color-cuti: #fca5a5;--color-weekend: #22c55e;--color-a: #3b82f6;--color-a1: #2563eb;--color-a2: #7c3aed;--color-oc: #f59e0b;--color-bt: #14b8a6;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-modal: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}a{color:var(--accent-primary);text-decoration:none}a:hover{text-decoration:underline}.hidden{display:none!important}.text-center{text-align:center}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.mt-4{margin-top:var(--space-4)}.mb-4{margin-bottom:var(--space-4)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--accent-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover)}.btn-outline{background-color:transparent;border-color:var(--border-color);color:var(--text-primary)}.btn-outline:hover:not(:disabled){background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-danger{background-color:#ef4444;color:#fff;border-color:#ef4444}.btn-danger:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626}.btn-header-outline{background-color:transparent;border-color:#ffffff4d;color:#fff}.btn-header-outline:hover:not(:disabled){background-color:#ffffff1a;border-color:#fff}.btn-icon{padding:.5rem;display:flex;align-items:center;justify-content:center}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.25rem;color:var(--text-secondary)}.form-control{width:100%;padding:.5rem .75rem;font-size:.875rem;line-height:1.5;color:var(--text-primary);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;font-family:inherit}.form-control:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #2563eb1a}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .2s ease}.modal-backdrop.show{opacity:1;pointer-events:auto}.modal-content{background-color:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;transform:translateY(-20px);transition:transform .2s ease}.modal-backdrop.show .modal-content{transform:translateY(0)}.modal-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-title{margin:0;font-size:1.125rem}.modal-close{background:transparent;border:none;font-size:1.5rem;line-height:1;color:var(--text-tertiary);cursor:pointer}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.5rem}.app-header{background-color:#1e293b;color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-md);position:sticky;top:0;z-index:40}.app-title{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1.25rem;font-weight:600}.header-controls{display:flex;align-items:center;gap:1rem}.toolbar{padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:1rem}.toolbar-actions{display:flex;gap:.5rem}.toast-container{position:fixed;bottom:1rem;right:1rem;z-index:100;display:flex;flex-direction:column;gap:.5rem}.toast{background-color:var(--bg-secondary);border-left:4px solid var(--accent-primary);box-shadow:var(--shadow-lg);padding:1rem;border-radius:var(--radius-md);min-width:300px;animation:slideIn .3s ease forwards}.toast.error{border-left-color:#ef4444}.toast.success{border-left-color:#22c55e}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .4s ease-out forwards}@media(max-width:768px){.app-header{flex-direction:column;padding:1rem;gap:1rem}.toolbar{flex-direction:column;align-items:stretch;padding:1rem}.toolbar-actions{flex-wrap:wrap;justify-content:center}.btn{flex:1 1 auto}}.dashboard-container{flex:1;display:flex;flex-direction:column;padding:1.5rem 2rem;gap:1.5rem;max-width:1600px;margin:0 auto;width:100%}.top-section{display:flex;gap:1.5rem;align-items:flex-start;flex-wrap:wrap}.legend-panel{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);min-width:250px}.legend-title{font-size:.875rem;font-weight:700;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.75rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.legend-items{display:flex;flex-direction:column;gap:.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.legend-color{width:16px;height:16px;border-radius:4px;display:inline-block}.roster-tables-wrapper{display:flex;flex-direction:column;gap:1.5rem}.week-panel{background-color:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);overflow:hidden;transition:box-shadow .3s ease}.week-panel:hover{box-shadow:var(--shadow-md)}.week-title{background-color:var(--bg-tertiary);padding:.75rem 1rem;font-size:1rem;font-weight:600;border-bottom:1px solid var(--border-color)}.week-panel.highlight-week{border:2px solid var(--accent-primary);box-shadow:0 0 15px #2563eb26}.week-panel.highlight-week .week-title{background-color:var(--accent-primary);color:#fff;border-bottom:none}.week-panel.highlight-week .week-title:after{content:" (Minggu Ini)";font-weight:400;font-size:.85em;opacity:.9}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.5rem}.roster-table{width:100%;border-collapse:collapse;min-width:800px}.roster-table th,.roster-table td{border:1px solid var(--border-color);padding:.5rem;text-align:center;font-size:.875rem}.roster-table th{background-color:#f8fafc;font-weight:600;color:var(--text-secondary)}.col-static{text-align:left!important;font-weight:600;width:150px;background-color:#f8fafc;position:sticky;left:0;z-index:10}.th-holiday{background-color:var(--color-holiday)!important;color:#fff!important}.th-cuti{background-color:var(--color-cuti)!important;color:#fff!important}.th-weekend{background-color:var(--color-weekend)!important;color:#fff!important}.th-today{border-top:3px solid var(--accent-primary)!important;border-left:3px solid var(--accent-primary)!important;border-right:3px solid var(--accent-primary)!important}.td-today{border-left:3px solid var(--accent-primary)!important;border-right:3px solid var(--accent-primary)!important}tr:last-child .td-today{border-bottom:3px solid var(--accent-primary)!important}.cell-schedule{cursor:pointer;position:relative;transition:transform .1s ease,filter .2s ease;height:40px;vertical-align:middle;font-weight:600}.cell-schedule:hover{filter:brightness(1.1);transform:scale(1.02);z-index:10;box-shadow:var(--shadow-sm)}.cell-schedule:after{content:"▾";position:absolute;right:2px;bottom:0;font-size:10px;opacity:0;transition:opacity .2s}.cell-schedule:hover:after{opacity:.5}.type-A{background-color:var(--color-a);color:#fff}.type-A1{background-color:var(--color-a1);color:#fff}.type-A2{background-color:var(--color-a2);color:#fff}.type-OC{background-color:var(--color-oc);color:#fff}.type-BT{background-color:var(--color-bt);color:#fff}.type-empty{background-color:transparent}.bg-holiday{background-color:#ef44441a}.bg-cuti{background-color:#fca5a533}.bg-weekend{background-color:#22c55e1a}.cell-editor{position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:30;display:flex;flex-direction:column;min-width:120px;padding:.25rem 0}.editor-option{padding:.5rem 1rem;text-align:left;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;gap:.5rem}.editor-option:hover{background-color:var(--bg-tertiary)}.notes-panel{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:1.5rem;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);margin-top:1rem}.notes-title{font-weight:700;margin-bottom:.5rem}.notes-list{list-style-type:none;display:flex;flex-direction:column;gap:.25rem}.notes-list li:before{content:"- "}
