:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:var(--text-color);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{background-color:#fff;--primary-color: #FF6B35;--secondary-color: #4A4A4A;--background-color: #F4F4F4;--white: #FFFFFF;--accent-gray: #E0E0E0;--text-color: #213547;--text-color-light: #667085;--text-color-inverted: #FFFFFF;--input-background: #FFFFFF;--success-color: #10B981;--warning-color: #F59E0B;--danger-color: #EF4444;--danger-background: #FEF2F2;--success-background: #D1FAE5;--warning-background: #FFFBEB}a:hover{color:#747bff}button{background-color:#f9f9f9}}@media (prefers-color-scheme: dark){:root{background-color:#242424;--primary-color: #FF6B35;--secondary-color: #d1d5db;--background-color: #111827;--white: #1f2937;--accent-gray: #374151;--text-color: rgba(255, 255, 255, .87);--text-color-light: #9CA3AF;--text-color-inverted: #FFFFFF;--input-background: #1f2937;--success-color: #34D399;--warning-color: #FBBF24;--danger-color: #F87171;--danger-background: #4B1F1F;--success-background: #064E3B;--warning-background: #4A2E0A}button{background-color:#1a1a1a}}.form-container{max-width:600px;margin:0 auto}.form-section{margin-bottom:20px}.form-row{display:flex;flex-direction:row;gap:15px;margin-bottom:15px}.form-col{display:flex;flex-direction:column;flex:1}.form-label{display:block;margin-bottom:5px;font-weight:700;color:var(--secondary-color)}.form-input,.form-select{width:100%;padding:8px;border:1px solid var(--accent-gray);border-radius:4px;background-color:var(--input-background);color:var(--text-color);box-sizing:border-box}.form-input:focus,.form-select:focus{outline:2px solid var(--primary-color);border-color:var(--primary-color)}.form-checkbox-label{display:flex;align-items:center;gap:10px}.form-checkbox-label span{font-weight:700;color:var(--secondary-color)}.form-group{margin-bottom:15px}.form-actions{display:flex;gap:10px;justify-content:flex-end}.form-actions-center{display:flex;gap:10px;justify-content:center}.recurrence-section{background-color:var(--background-color);padding:15px;border-radius:4px;margin-bottom:15px;border:1px solid var(--accent-gray)}.weekday-selector{display:flex;flex-wrap:wrap;gap:8px}.weekday-label{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid var(--accent-gray);border-radius:4px;background-color:var(--white);color:var(--text-color);cursor:pointer;font-size:14px;-webkit-user-select:none;user-select:none;transition:background-color .2s,color .2s}.weekday-label.selected{background-color:var(--primary-color);color:var(--text-color-inverted);border-color:var(--primary-color)}.weekday-checkbox{display:none}.weekday-hint{font-size:12px;color:var(--secondary-color);margin-top:5px}.required-trait-list{margin-top:10px;display:flex;flex-direction:column;gap:5px}.required-trait-item{display:flex;justify-content:space-between;align-items:center;padding:8px;background-color:var(--background-color);margin-bottom:5px;border-radius:4px;border:1px solid var(--accent-gray)}.validation-error{color:var(--danger-color);font-size:14px;margin-bottom:15px;padding:8px;background-color:var(--danger-background);border:1px solid var(--danger-color);border-radius:4px}.form-section-title{margin-bottom:10px;color:var(--secondary-color);font-size:1.1rem}.tags-container{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}.tag-item{display:flex;align-items:center;padding:6px 10px;background-color:var(--background-color);border-radius:4px;font-size:14px;border:1px solid var(--accent-gray);color:var(--text-color)}.tag-item .btn-danger{margin-left:6px}.constraint-row{display:flex;flex-direction:row;gap:15px;flex-wrap:wrap;align-items:center}.constraint-block{border:1px solid var(--accent-gray);border-radius:8px;padding:12px;margin-bottom:10px;background-color:var(--white);transition:background-color .2s}.constraint-block.editing{background-color:var(--background-color)}.constraint-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.constraint-header h4{margin:0;color:var(--secondary-color)}.constraint-display{display:flex;gap:8px;justify-content:space-between;align-items:center}.constraint-display span{color:var(--secondary-color)}.sub-label{display:block;margin-bottom:5px;font-weight:700;font-size:14px;color:var(--secondary-color)}.staff-panel-member{padding:12px;margin-bottom:8px;background-color:var(--white);border-radius:6px;cursor:grab;transition:all .2s;font-size:14px;color:var(--text-color);border-width:3px;border-style:solid}.staff-panel-member:active{cursor:grabbing}.staff-panel-member-name{font-weight:700;margin-bottom:6px}.staff-panel-member-info{font-size:11px;color:var(--text-color-light);margin-bottom:2px}.staff-panel-member-traits{font-size:10px;color:var(--text-color-light);border-top:1px solid var(--accent-gray);padding-top:4px}.staff-badge{display:inline-flex;align-items:center;background-color:var(--white);border:1px solid var(--accent-gray);border-radius:12px;padding:3px 8px;font-size:12px;font-weight:700;color:var(--text-color);max-width:120px}.staff-badge-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:4px}.staff-badge-remove-btn{background:none;border:none;color:var(--text-color-light);cursor:pointer;font-size:10px;padding:0;margin-left:2px;line-height:1}.shift-cell.status-properly-staffed{background-color:var(--success-background)}.shift-cell.status-under-staffed{background-color:var(--warning-background)}.shift-cell.status-not-staffed,.shift-cell.status-constraint-violation{background-color:var(--danger-background)}.shift-cell-empty{background-color:var(--background-color)}.day-header,.shift-name-cell{color:var(--text-color)}.day-header div:last-child,.shift-name-cell div:last-child{color:var(--text-color-light)}.shift-cell .unassigned-text{color:var(--text-color-light);font-size:12px;font-style:italic}.shift-cell .no-occurrence-text{display:flex;align-items:center;justify-content:center;height:100%;min-height:60px;color:var(--text-color-light);font-size:24px;font-weight:700}.app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--background-color)}.app-header{background-color:var(--white);padding:0;border-bottom:1px solid var(--accent-gray);box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:100}.header-container{max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.brand-section{display:flex;align-items:baseline;gap:.5rem}.brand-title{margin:0;color:var(--primary-color);font-size:1.8rem;font-weight:700;letter-spacing:-.5px}.brand-subtitle{color:var(--secondary-color);opacity:.7;font-size:.9rem;font-weight:400;font-style:italic}.main-nav{display:flex;gap:.5rem;align-items:center}.nav-link{padding:.75rem 1.25rem;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;text-decoration:none;color:var(--secondary-color);font-weight:500;font-size:.9rem}.nav-link:hover{color:var(--primary-color)}.nav-link.active{color:var(--primary-color);border-bottom-color:var(--primary-color);font-weight:600}.nav-link[href*="/planning"]{background:var(--primary-color);color:var(--white);border-radius:6px;border-bottom:3px solid transparent;font-weight:600}.nav-link[href*="/planning"]:hover{background:var(--primary-color);color:var(--white);opacity:.9}.nav-link[href*="/planning"].active{background:var(--primary-color);color:var(--white);border-bottom-color:var(--secondary-color)}.header-actions{display:flex;align-items:center;gap:1rem}.app-main{flex:1;padding:1rem 2rem;max-width:100%;width:100%;box-sizing:border-box}.shifts-view,.staff-view{max-width:1200px;margin:0 auto;width:100%}.shifts-list,.staff-list{display:grid;gap:1rem;margin-top:2rem}.shift-item,.staff-item{border:1px solid var(--accent-gray);border-radius:8px;padding:1.5rem;background:var(--white);box-shadow:0 2px 4px #0000001a;width:100%;box-sizing:border-box}.shift-item h3,.staff-item h3{margin-top:0;color:var(--secondary-color)}.shift-item p,.staff-item p{margin:.5rem 0;color:var(--secondary-color);opacity:.8}.language-switcher{display:flex;background:var(--white);border-radius:6px;padding:3px;border:1px solid var(--accent-gray)}.language-btn{padding:.5rem .875rem;background:transparent;border:none;border-radius:4px;cursor:pointer;color:var(--secondary-color);font-weight:500;font-size:.8rem;min-width:40px}.language-btn:hover{background:var(--white);color:var(--primary-color)}.language-btn.active{background:var(--primary-color);color:var(--white);font-weight:600}@media (max-width: 768px){.header-container{padding:1rem;flex-direction:column;gap:1rem;text-align:center}.brand-section{justify-content:center}.main-nav{justify-content:center;flex-wrap:wrap}.nav-link{padding:.6rem 1rem;font-size:.85rem}.app-main{padding:1rem}.calendar-view{height:calc(100vh - 220px)}.shifts-view,.staff-view{max-width:100%}}.hamburger-menu{position:relative;display:none}.hamburger-trigger{background:none;border:none;cursor:pointer;padding:8px;z-index:1001;position:relative}.hamburger-icon{width:24px;height:18px;display:flex;flex-direction:column;justify-content:space-between;transition:all .3s ease}.hamburger-icon span{display:block;height:3px;width:100%;background-color:var(--secondary-color);border-radius:2px;transition:all .3s ease}.hamburger-icon.open span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger-icon.open span:nth-child(2){opacity:0}.hamburger-icon.open span:nth-child(3){transform:rotate(-45deg) translate(8px,-8px)}.hamburger-overlay{position:fixed;inset:0;background-color:#00000080;z-index:999}.hamburger-nav{position:fixed;top:0;right:-300px;width:280px;height:100vh;background-color:var(--white);box-shadow:-2px 0 10px #0000001a;transition:right .3s ease;z-index:1000;overflow-y:auto}.hamburger-nav.open{right:0}.hamburger-nav-content{padding:80px 24px 24px;display:flex;flex-direction:column;gap:8px}.hamburger-nav-link{display:block;padding:16px;text-decoration:none;color:var(--secondary-color);border-radius:8px;font-weight:500;font-size:16px;transition:all .2s ease}.hamburger-nav-link:hover{background-color:var(--background-color);color:var(--primary-color)}.hamburger-nav-link.active{background-color:var(--primary-color);color:var(--white)}.hamburger-nav-divider{height:1px;background-color:var(--accent-gray);margin:16px 0}.hamburger-language-section{padding:16px}.hamburger-language-label{display:block;font-size:14px;color:var(--secondary-color);margin-bottom:12px;font-weight:500}.hamburger-language-switcher{display:flex;gap:8px}.hamburger-language-btn{flex:1;padding:12px;background:var(--background-color);border:1px solid var(--accent-gray);border-radius:6px;cursor:pointer;color:var(--secondary-color);font-weight:500;font-size:14px;transition:all .2s ease}.hamburger-language-btn:hover{background:var(--white);color:var(--primary-color)}.hamburger-language-btn.active{background:var(--primary-color);color:var(--white);font-weight:600}@media (max-width: 480px){.main-nav{display:none}.hamburger-menu{display:block}.header-actions{gap:.5rem}.language-switcher{display:none}.header-container{flex-direction:row!important;justify-content:space-between;align-items:center;padding:8px 12px}.brand-section{justify-content:flex-start}.brand-title{font-size:1.5rem}.brand-subtitle{font-size:.8rem}.app-main{padding:.5rem}.calendar-view{height:calc(100vh - 280px)}}.calendar-view .rbc-calendar{height:100%!important}.rbc-calendar{height:100%}.weekly-planning-container{display:flex;height:calc(100vh - 140px);gap:20px;overflow:hidden}.week-nav-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px;background-color:var(--background-color);border-radius:8px;border:1px solid var(--accent-gray);flex-wrap:wrap;gap:8px}.week-nav-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.week-nav-title{font-weight:700;font-size:18px;color:var(--secondary-color);text-align:center;flex-shrink:0}.week-nav-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.staff-panel{flex:.2;flex-shrink:0;display:flex;flex-direction:column;background-color:var(--white);border-radius:8px;padding:16px;overflow-y:auto;border:1px solid var(--accent-gray)}.calendar-panel{flex:.8;display:flex;flex-direction:column;min-width:0;overflow:auto}.staff-members{display:flex;flex-direction:row;flex-wrap:wrap;flex:0 1 auto;gap:8px}.staff-member{flex:1 1 100px;max-width:100px}.shift-table-container{flex:1;background-color:var(--white);border-radius:8px;padding:16px;overflow:auto;border:1px solid var(--accent-gray)}.shift-table{width:100%;border-collapse:collapse;font-size:14px;table-layout:fixed}.shift-header{border:1px solid var(--accent-gray);padding:12px 8px;background-color:var(--background-color);font-weight:700;text-align:left;color:var(--secondary-color)}.day-header{border:1px solid var(--accent-gray);padding:12px 8px;background-color:var(--background-color);font-weight:700;text-align:center;color:var(--secondary-color)}.shift-name-cell{border:1px solid var(--accent-gray);padding:12px 8px;background-color:var(--background-color);font-weight:700;vertical-align:top;color:var(--secondary-color)}.shift-cell{border:1px solid var(--accent-gray);padding:8px;vertical-align:top;min-height:60px;position:relative;background-color:var(--white)}@media (max-width: 1400px){.week-nav-container{justify-content:center}.week-nav-title{width:100%;order:-1;margin-bottom:8px;font-size:16px}.week-nav-controls,.week-nav-actions{justify-content:center}}@media (max-width: 1024px){.weekly-planning-container{gap:15px}.shift-table{font-size:13px}.week-nav-actions{gap:8px}.week-nav-actions button{padding:4px 8px!important;font-size:12px!important}.week-nav-actions label span{font-size:12px}}@media (max-width: 768px){.weekly-planning-container{flex-direction:column;height:auto;gap:15px}.staff-panel{width:96%;padding:2%;flex:.4;order:2;background-color:var(--background-color)}.staff-members{flex-direction:row;overflow-x:auto;gap:8px;padding-bottom:8px}.staff-member{flex-shrink:0;min-width:100px}.calendar-panel{order:1;flex:.6;background-color:var(--background-color)}.shift-table{font-size:12px}.week-nav-container{flex-direction:column;gap:12px;text-align:center}.week-nav-title{width:100%;order:0;margin-bottom:0;font-size:16px}.week-nav-controls,.week-nav-actions{width:100%;justify-content:center;flex-wrap:wrap}.day-header div:first-child{font-size:11px}.day-header div:last-child{font-size:10px}.shift-header{font-size:12px}.shift-name-cell{font-size:11px}.shift-name-cell div:last-child{font-size:10px}.shift-cell{padding:4px}}@media (max-width: 480px){.weekly-planning-container{gap:10px}.shift-table-container{padding:10px}.shift-table{font-size:11px}.day-header div:first-child{font-size:10px}.day-header div:last-child{font-size:9px}.shift-header{font-size:11px}.shift-name-cell,.shift-name-cell div:first-child{font-size:10px}.shift-name-cell div:last-child{font-size:9px}.shift-cell div{font-size:10px}.shift-cell div>div{padding:2px 4px!important;font-size:9px!important;margin-bottom:2px}}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.9rem;transition:opacity .2s ease}.btn:hover{opacity:.9}.btn-primary{background-color:var(--primary-color);color:var(--white)}.btn-secondary{background-color:var(--secondary-color);color:var(--white)}.btn-success{background-color:#28a745;color:var(--white)}.btn-danger{background-color:#dc3545;color:var(--white)}.btn-small{padding:5px 10px;font-size:.8rem}.btn-xs{padding:2px 8px;font-size:.75rem}.week-nav-btn{padding:8px 12px;border:none;border-radius:6px;cursor:pointer;font-weight:500;color:var(--white);font-size:.85rem}.week-nav-btn.prev,.week-nav-btn.next{background-color:var(--secondary-color)}.week-nav-btn.current{background-color:var(--primary-color)}.week-nav-btn:hover{opacity:.9}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background-color:var(--white);border-radius:8px;box-shadow:0 10px 25px #0003;min-width:25vw;max-width:90vw;max-height:90vh;overflow:auto;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 0;border-bottom:1px solid var(--accent-gray);margin-bottom:20px}.modal-title{margin:0;color:var(--secondary-color)}.modal-close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:var(--secondary-color);padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.modal-body{padding:0 20px 20px}.confirm-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.confirm-dialog-content{background-color:var(--white);border-radius:8px;padding:24px;max-width:500px;width:90%;box-shadow:0 4px 12px #00000026}.confirm-dialog-header{margin-bottom:16px}.confirm-dialog-title{margin:0 0 16px;color:var(--secondary-color);font-size:18px}.confirm-dialog-message{margin:0 0 12px;line-height:1.5;color:var(--text-color)}.confirm-dialog-question{margin:0;font-weight:700;color:var(--danger-color)}.confirm-dialog-actions{display:flex;gap:12px;justify-content:flex-end}@media (max-width: 768px){.modal-overlay{padding:0;align-items:stretch;justify-content:stretch}.modal-content{border-radius:0;max-width:100vw;max-height:100vh;width:100vw;height:100vh;display:flex;flex-direction:column}.modal-header{padding:16px;margin-bottom:0;border-bottom:1px solid var(--accent-gray);flex-shrink:0;background:var(--white);position:sticky;top:0;z-index:1}.modal-title{font-size:18px}.modal-close-btn{font-size:28px;width:40px;height:40px;margin:-8px}.modal-body{padding:16px;flex:1;overflow-y:auto}.confirm-dialog-overlay{padding:0;align-items:stretch;justify-content:stretch}.confirm-dialog-content{border-radius:0;max-width:100vw;width:100vw;height:100vh;display:flex;flex-direction:column;justify-content:center;padding:20px}.confirm-dialog-title{font-size:20px;text-align:center}.confirm-dialog-message{text-align:center;font-size:16px;margin-bottom:16px}.confirm-dialog-question{text-align:center;font-size:16px;margin-bottom:24px}.confirm-dialog-actions{flex-direction:column;gap:16px}.confirm-dialog-actions button{width:100%;padding:16px;font-size:16px;min-width:auto}}@media print{.app-header,.header-actions,.no-print,.toast-container{display:none!important}.calendar-view{height:auto}.app-main{padding:.5rem}.staff-panel,.week-nav-container,.print-hide{display:none!important}.weekly-planning-container{flex-direction:column;gap:0}.calendar-panel{width:100%!important;max-width:none!important}.shift-table-container{overflow:visible!important;max-height:none!important}.shift-table{width:100%!important;font-size:12px!important;border-collapse:collapse!important}.shift-table th,.shift-table td{border:1px solid #000!important;padding:8px 4px!important;text-align:center!important;vertical-align:top!important;page-break-inside:avoid}.shift-table th{background-color:#f0f0f0!important;font-weight:700!important;font-size:11px!important}.shift-name-cell{text-align:left!important;font-weight:700!important;background-color:#f8f8f8!important}.shift-cell{min-height:60px!important;background-color:#fff!important}.shift-cell button{display:none!important}.print-title{display:block!important;text-align:center;font-size:18px;font-weight:700;margin-bottom:16px;color:#000!important;position:relative}.print-app-title{display:block!important;position:absolute;top:0;right:0;font-size:10px;color:#666!important;font-weight:400}*{color:#000!important;background-color:transparent!important}.shift-table th{background-color:#f0f0f0!important}.shift-name-cell{background-color:#f8f8f8!important}}.app-wrapper{display:flex;flex-direction:column;min-height:100vh}.login-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--background-color);padding:2rem}.login-container{max-width:400px;width:100%;background:var(--white);padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a}.app-branding{text-align:center;margin-bottom:2rem}.app-branding h1{font-size:2rem;margin:0 0 .5rem;color:var(--primary-color)}.app-branding p{margin:0;color:var(--secondary-color)}.login-form-container{width:100%}.login-form-header{text-align:center;margin-bottom:2rem}.login-form-header h2{margin:0 0 .5rem;font-size:1.5rem;color:var(--secondary-color)}.login-form-subtitle{color:var(--secondary-color);margin:0;opacity:.8}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:500;font-size:.875rem;color:var(--secondary-color)}.form-input{width:100%;padding:.75rem;border:1px solid var(--accent-gray);border-radius:6px;background:var(--background-color);color:var(--secondary-color);box-sizing:border-box;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #ff6b3533}.password-input-container{position:relative}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:.25rem;color:var(--secondary-color)}.password-toggle:hover{opacity:.7}.login-submit{margin-top:1rem}.login-form-footer{margin-top:2rem;text-align:center}.login-help-text{color:var(--secondary-color);font-size:.875rem;margin:0;opacity:.8}.auth-header{padding:.5rem 1rem;background:var(--white);border-bottom:1px solid var(--accent-gray);display:flex;justify-content:flex-end}.user-profile{display:flex;align-items:center;gap:.75rem;padding:.25rem .5rem;border-radius:8px;transition:background-color .2s}.user-profile:hover{background:#ff6b350d}.user-avatar{width:2rem;height:2rem;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.user-details{display:flex;flex-direction:column;align-items:flex-start;min-width:0;flex:1}.user-name{font-weight:600;font-size:.875rem;color:var(--secondary-color);line-height:1.2;margin-bottom:.125rem}.user-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.role-badge{padding:.125rem .375rem;border-radius:12px;font-size:.6875rem;font-weight:500;text-transform:lowercase;line-height:1}.role-badge-admin{background:#dc3545;color:#fff}.role-badge-instance-admin{background:#6610f2;color:#fff}.role-badge-manager{background:#0d6efd;color:#fff}.role-badge-staff{background:#198754;color:#fff}.role-badge-default{background:var(--accent-gray);color:var(--secondary-color)}.user-instances{font-size:.6875rem;color:var(--secondary-color);opacity:.8;line-height:1}.user-actions{flex-shrink:0}.user-actions .btn-sm{padding:.375rem .75rem;font-size:.75rem;border-radius:6px}.loading-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;gap:1rem;background:var(--background-color)}.loading-spinner{width:2rem;height:2rem;border:2px solid var(--accent-gray);border-top:2px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.config-error{padding:2rem;text-align:center;color:#dc3545;background:var(--background-color);min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center}.config-error pre{background:var(--white);padding:1rem;border-radius:4px;text-align:left;overflow-x:auto;border:1px solid var(--accent-gray)}.user-management-view{padding:2rem;background:var(--background-color);min-height:100vh}.staff-table-container,.shifts-table-container{overflow-x:auto;margin-top:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.staff-table,.shifts-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:8px;overflow:hidden}.staff-table th,.staff-table td,.shifts-table th,.shifts-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--accent-gray)}.staff-table th,.shifts-table th{background:var(--background-color);font-weight:600;color:var(--secondary-color)}.staff-table tbody tr:hover,.shifts-table tbody tr:hover{background:#ff6b350d}.traits-list{display:flex;flex-wrap:wrap;gap:.25rem}.trait-badge{padding:.125rem .375rem;background:var(--primary-color);color:#fff;border-radius:12px;font-size:.6875rem;font-weight:500}.constraints-list{font-size:.8rem;line-height:1.4}.constraints-list>div{margin-bottom:.25rem}.blocked-times-summary{font-size:.8rem}.blocked-times-count{font-weight:500;display:block;margin-bottom:.25rem}.blocked-times-preview{display:flex;flex-wrap:wrap;gap:.25rem}.blocked-time-item{background:var(--accent-gray);padding:.125rem .25rem;border-radius:4px;font-size:.75rem;display:flex;align-items:center;gap:.125rem}.recurrence-indicator{font-size:.6875rem;opacity:.7}.blocked-times-more{color:var(--secondary-color);opacity:.7;font-size:.75rem;align-self:center}.empty-state-inline{color:var(--secondary-color);opacity:.6;font-style:italic}.shift-name{font-weight:600;font-size:1rem}.shift-schedule{font-size:.9rem}.shift-time{font-weight:500;margin-bottom:.25rem}.shift-duration{color:var(--secondary-color);opacity:.8}.shift-requirements{font-size:.8rem;line-height:1.4}.required-traits{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.25rem}.trait-requirement{background:var(--accent-gray);padding:.125rem .25rem;border-radius:4px;font-size:.75rem}.assignment-status{font-size:.9rem;text-align:center}.assignment-ratio{display:block;font-weight:600;font-size:1.1rem;margin-bottom:.25rem}.assignment-complete{color:#198754}.assignment-incomplete{color:#dc3545}.assignment-occurrences{font-size:.75rem;color:var(--secondary-color);opacity:.8}.recurrence-info{font-size:.8rem}.recurrence-type{font-weight:500;display:block;margin-bottom:.25rem}.recurrence-details{color:var(--secondary-color);opacity:.8;line-height:1.3}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.view-header h1{margin:0;color:var(--secondary-color)}.view-content{max-width:1200px;margin:0 auto}.access-denied{text-align:center;padding:4rem 2rem;background:var(--white);border-radius:8px;margin:2rem auto;max-width:600px}.users-table-container{overflow-x:auto;margin-top:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.users-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:8px;overflow:hidden}.users-table th,.users-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--accent-gray)}.users-table th{background:var(--background-color);font-weight:600;color:var(--secondary-color)}.users-table tbody tr:hover{background:#ff6b350d}.status-badge{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500}.status-active{background:#198754;color:#fff}.status-disabled{background:#6c757d;color:#fff}.table-actions{display:flex;gap:.5rem}.empty-state{text-align:center;color:var(--secondary-color);font-style:italic;padding:2rem;opacity:.8}.user-form{display:flex;flex-direction:column;gap:1rem}.form-checkbox{display:flex;align-items:center;gap:.5rem}.form-checkbox input[type=checkbox]{margin:0}.form-checkbox label{margin:0;cursor:pointer}.logout-confirm-content{text-align:center;padding:1rem}
