@charset "UTF-8";.app-container{display:flex;flex-direction:column;margin:0 auto;max-width:1800px;min-height:100vh;padding:var(--spacing-lg);width:100%}header{border-radius:var(--border-radius-lg)}header h1{text-shadow:0 2px 4px #0000004d}main{flex:1 1;max-width:100%;width:100%}.app-footer{background:var(--gray-100);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);margin-top:auto;padding:var(--spacing-lg);text-align:center}.signout-button{background:var(--danger-color);border:none;border-radius:var(--border-radius-md);box-shadow:var(--shadow-sm);color:var(--white);cursor:pointer;font-size:var(--font-size-base);font-weight:500;min-height:48px;min-width:120px;padding:var(--spacing-md) var(--spacing-lg);transition:all .3s ease}.signout-button:hover{background:#d9363e;box-shadow:var(--shadow-md);transform:translateY(-2px)}.signout-button:focus{outline:2px solid var(--danger-color);outline-offset:2px}@media (max-width:575.98px){.app-container,header{padding:var(--spacing-md)}header h1{font-size:var(--font-size-xl)}main{padding:var(--spacing-md)}.signout-button{font-size:var(--font-size-base);min-height:56px;width:100%}}@media (min-width:576px) and (max-width:767.98px){.app-container{padding:var(--spacing-lg)}header h1{font-size:var(--font-size-xxl)}}@media (min-width:768px){.app-container{padding:var(--spacing-xl)}}.app-container{animation:fadeIn .5s ease-out}.loading{align-items:center;color:var(--gray-600);display:flex;font-size:var(--font-size-lg);justify-content:center;min-height:200px}.loading:after{animation:spin 1s linear infinite;border-top:2px solid var(--gray-300);border:2px solid var(--gray-300);border-radius:50%;border-top-color:var(--primary-color);content:"";height:20px;margin-left:var(--spacing-sm);width:20px}.control-panel{background-color:#f8f9fa;border-radius:8px;box-shadow:0 2px 8px #0000001a;box-sizing:border-box;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:1800px;padding:20px;width:100%}.control-panel h2{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:1.8em;font-weight:600;margin-bottom:20px;padding-bottom:10px;text-align:left}.month-navigation{margin-bottom:15px;padding:10px 0}.month-navigation button{background-color:#3498db;border:none;border-radius:6px;box-shadow:0 2px 4px #3498db33;color:#fff;cursor:pointer;font-size:.85em;font-weight:500;max-width:120px;min-width:80px;padding:8px 16px;transition:background-color .3s ease}.month-navigation button:hover{background-color:#2980b9;box-shadow:0 3px 6px #3498db4d}.month-navigation span{background-color:#ecf0f1;border:1px solid #bdc3c7;border-radius:6px;color:#2c3e50;font-size:1.3em;font-weight:600;padding:8px 16px}.calendar-grid{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 3px 12px #00000014;margin-bottom:25px;overflow-x:auto;padding:20px;width:100%}.calendar-header{grid-gap:8px;display:grid;font-weight:600;gap:8px;grid-template-columns:repeat(7,1fr);margin-bottom:10px;min-width:1200px;text-align:center}.calendar-header-cell{background:linear-gradient(135deg,#8e44ad,#9b59b6);border-radius:6px;box-shadow:0 2px 6px #8e44ad4d;color:#fff;font-size:.9em;font-weight:600;letter-spacing:.5px;padding:12px 8px;text-transform:uppercase;transition:all .3s ease}.calendar-header-cell:hover{box-shadow:0 4px 10px #8e44ad66;transform:translateY(-1px)}.calendar-cells{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr);min-height:1200px;min-width:1200px}.day{align-items:center;background:linear-gradient(145deg,#fff,#f8f9fa);border:2px solid #e9ecef;border-radius:8px;box-shadow:0 2px 6px #0000000d;box-sizing:border-box;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-start;padding:15px;position:relative;transition:all .3s ease}.day,.day.empty{max-height:360px;min-height:280px}.day.empty{background:#0000;border:none;box-shadow:none;cursor:default}.day:hover{background:linear-gradient(145deg,#e3f2fd,#bbdefb);border-color:#2196f3;box-shadow:0 6px 20px #2196f326}.day.selected,.day:hover{transform:translateY(-2px)}.day.selected{background:linear-gradient(135deg,#3498db,#2980b9);border-color:#3498db;box-shadow:0 6px 20px #3498db40;color:#fff}.day.full-shift{background:linear-gradient(145deg,#fff8e1,#ffecb3);border-color:#ffc107;overflow:hidden;position:relative}.day.full-shift:before{background:linear-gradient(90deg,#ff9800,#ffc107,#ffeb3b);content:"";height:3px;left:0;position:absolute;right:0;top:0}.day .day-number{color:#2c3e50;flex-shrink:0;font-size:1.4em;font-weight:700;margin-bottom:8px;position:relative;text-shadow:0 1px 2px #0000001a;z-index:2}.day.selected .day-number{color:#fff;text-shadow:0 1px 3px #0000004d}.day.full-shift .day-number{color:#e65100;font-weight:800}.day .grouping-details{background:#ffffffe6;border:1px solid #fff3;border-radius:4px;box-shadow:0 1px 3px #0000001a;color:#34495e;display:flex;flex:1 1;flex-direction:column;font-size:.8em;line-height:1.35;margin-top:auto;max-height:250px;min-height:150px;overflow-y:auto;padding:4px 6px;text-align:left;width:95%}.day.selected .grouping-details{background:#ffffff26;border:1px solid #ffffff4d;color:#fff}.group-label{background-color:#ffffff26!important;border-radius:3px;color:#fff!important;display:inline-block;font-size:.75em;font-weight:600;margin:1px 0;min-width:60px;padding:2px 6px;text-align:left!important}.day.selected .group-label{background-color:#ffffff40!important;color:#fff!important}.day.full-shift .group-label{background-color:#fff3!important;color:#fff!important}.empty-group{background:#9999991a;border:1px dashed #9999994d;border-radius:3px;font-style:italic;margin:1px 0;opacity:.6;padding:2px 4px}.user-name{color:inherit;font-size:.8em;font-weight:500;margin:0;overflow:hidden;padding:1px 0;text-align:left;text-overflow:ellipsis;transition:all .2s ease;white-space:nowrap}.user-name:hover{background:#fff3;overflow:visible;transform:scale(1.02);white-space:normal}.day.selected .user-name{color:#fff}.day.full-shift .user-name{color:#34495e}.grouping-line{border-radius:3px;font-weight:500;margin:0;overflow:hidden;padding:1px 0;text-align:left;text-overflow:ellipsis;transition:all .2s ease;white-space:nowrap}.grouping-line:hover{background:#fff3;overflow:visible;transform:scale(1.02);white-space:normal}.special-marker{animation:pulse 2s infinite;color:#e74c3c;font-size:1.2em;font-weight:800;margin-left:4px;text-shadow:0 1px 2px #0003}.special-day-checkbox{align-items:center;background:#fffc;border:1px solid #0000001a;border-radius:4px;display:flex;flex-direction:column;flex-shrink:0;font-size:.95em;gap:8px;justify-content:center;margin-top:8px;min-width:160px;padding:8px 12px;transition:all .2s ease}.special-day-checkbox:hover{background:#fffffff2;transform:scale(1.05)}.special-day-checkbox input[type=checkbox]{accent-color:#ffc107;transform:scale(1.1)}.time-inputs{display:flex;flex-direction:column;gap:8px;margin-top:8px;width:100%}.time-input-group{align-items:center;display:flex;font-size:.9em;gap:6px}.time-input-group label{color:#2c3e50;font-weight:600;min-width:40px}.time-input-group input[type=number]{border:1px solid #ddd;border-radius:3px;font-size:.9em;height:28px;padding:4px;text-align:center;width:48px}.time-input-group input[type=number]:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db1a;outline:none}.month-default-button{background-color:#9b59b6;border:none;border-radius:6px;box-shadow:0 2px 6px #9b59b633;color:#fff;cursor:pointer;font-size:.95em;font-weight:500;padding:12px 24px;transition:background-color .3s ease,box-shadow .2s ease}.month-default-button:hover{background-color:#8e44ad;box-shadow:0 4px 10px #9b59b64d;transform:translateY(-1px)}.month-default-button:active{transform:translateY(0)}.month-default-button:disabled{background-color:#bdc3c7;box-shadow:none;cursor:not-allowed;transform:none}.manual-trigger-button{background:linear-gradient(135deg,#f093fb,#f5576c);border:none;border-radius:6px;box-shadow:0 2px 6px #f093fb33;color:#fff;cursor:pointer;font-size:.9em;font-weight:500;padding:12px 20px;transition:all .3s ease}.manual-trigger-button:hover{box-shadow:0 4px 10px #f093fb4d;transform:translateY(-1px)}.manual-trigger-button:active{transform:translateY(0)}.manual-trigger-button:disabled{background-color:#bdc3c7;box-shadow:none;cursor:not-allowed;transform:none}.control-buttons{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 2px 6px #0000000d;display:flex;flex-direction:column;gap:20px;margin-top:30px;padding:20px}.control-buttons-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.control-buttons-row.secondary{justify-content:center;margin-top:10px}.control-buttons button{background-color:#27ae60;border:none;border-radius:6px;box-shadow:0 2px 6px #27ae6033;color:#fff;cursor:pointer;flex:1 1;font-size:.9em;font-weight:500;max-width:200px;min-width:160px;padding:12px 20px;text-align:center;transition:all .3s ease}.control-buttons button:hover{background-color:#229954;box-shadow:0 4px 10px #27ae604d;transform:translateY(-1px)}.control-buttons button:active{transform:translateY(0)}.control-buttons .month-default-button{background:linear-gradient(135deg,#9b59b6,#8e44ad);box-shadow:0 2px 6px #9b59b633}.control-buttons .month-default-button:hover{background:linear-gradient(135deg,#8e44ad,#7d3c98);box-shadow:0 4px 10px #9b59b64d}.control-buttons .manual-trigger-button{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 2px 6px #f093fb33;flex:1 1;max-width:300px;min-width:200px}.control-buttons .manual-trigger-button:hover{background:linear-gradient(135deg,#f5576c,#e74c3c);box-shadow:0 4px 10px #f093fb4d}.modal-overlay{animation:fadeIn .2s ease-in;background-color:#00000080;height:100%;left:0;overscroll-behavior:contain;position:fixed;top:0;width:100%;z-index:1000}.modal-nav-arrow,.modal-overlay{align-items:center;display:flex;justify-content:center}.modal-nav-arrow{background-color:#ffffffe6;border:none;border-radius:50%;box-shadow:0 2px 8px #0003;color:#333;cursor:pointer;font-size:20px;font-weight:700;height:45px;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:45px;z-index:1001}.modal-nav-arrow:hover{background-color:#fff;box-shadow:0 4px 12px #0000004d;transform:translateY(-50%) scale(1.1)}.modal-nav-arrow:active{transform:translateY(-50%) scale(.95)}.modal-nav-left{left:20px}.modal-nav-right{right:20px}.modal{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-width:90%;padding:25px;position:relative;width:350px}.enhanced-grouping-modal{max-height:85vh;max-width:95%;overflow-y:auto;overscroll-behavior:contain;width:650px}.modal h3{color:#2c3e50;font-size:1.4em;font-weight:600;text-align:center}.modal h3,.modal-header{border-bottom:2px solid #e9ecef;margin-bottom:20px;padding-bottom:10px}.modal-header{flex-direction:column;gap:10px}.modal-header h3{border-bottom:none;margin:0;padding-bottom:0;text-align:center}.requirement-selector-container{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;display:flex;gap:10px;margin:10px 0;padding:10px 15px}.requirement-label{color:#495057;font-size:14px;font-weight:500;white-space:nowrap}.requirement-select{background:#fff;border:1px solid #ced4da;border-radius:4px;color:#495057;cursor:pointer;font-size:14px;min-width:80px;padding:6px 10px;transition:all .2s ease}.requirement-select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.requirement-select:hover{background:#f8f9fa;border-color:#007bff}.clear-date-btn{background-color:#e74c3c;border:none;border-radius:6px;box-shadow:0 2px 4px #e74c3c33;color:#fff;cursor:pointer;font-size:.9em;font-weight:500;padding:8px 16px;transition:all .3s ease;white-space:nowrap}.clear-date-btn:hover{background-color:#c0392b;box-shadow:0 4px 8px #e74c3c4d;transform:translateY(-1px)}.clear-date-btn:active{transform:translateY(0)}.group-management{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-bottom:20px;padding:15px}.group-controls{display:flex;flex-direction:column;gap:15px}.group-count{background-color:#fff;border:1px solid #dee2e6;border-radius:4px;color:#6c757d;font-size:.95em;font-weight:500;padding:8px;text-align:center}.grouping-form.enhanced{display:flex;flex-direction:column;gap:15px;margin-bottom:20px}.form-group.enhanced{background-color:#fff;border:1px solid #e9ecef;border-radius:6px;box-shadow:0 1px 3px #0000000d;padding:15px;transition:all .3s ease}.form-group.enhanced:hover{border-color:#3498db;box-shadow:0 2px 8px #3498db1a}.form-group.enhanced.disabled{background-color:#f8f9fa;border-color:#dee2e6;filter:grayscale(50%);opacity:.6;pointer-events:none}.form-group.enhanced.disabled .group-header{pointer-events:auto}.form-group.enhanced.disabled .group-name-label{color:#6c757d;cursor:default}.form-group.enhanced.disabled .edit-icon{display:none}.form-group.enhanced.disabled .enhanced-select{background-color:#e9ecef;color:#6c757d;cursor:not-allowed}.form-group.enhanced.disabled .btn-enable-group{background-color:#27ae60;color:#fff;cursor:pointer;filter:none;opacity:1;pointer-events:auto}.form-group.enhanced.disabled .btn-enable-group:hover{background-color:#229954;transform:scale(1.1)}.group-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.group-name-section{flex:1 1}.group-name-label{align-items:center;border-radius:4px;color:#2c3e50;cursor:pointer;display:flex;font-size:1em;font-weight:600;gap:8px;margin:0;padding:6px 10px;transition:background-color .3s ease}.group-name-label:hover{background-color:#f8f9fa}.edit-icon{font-size:.8em;opacity:.6;transition:opacity .3s ease}.group-name-label:hover .edit-icon{opacity:1}.group-name-edit{align-items:center;display:flex;gap:6px;width:100%}.group-name-input{background-color:#fff;border:2px solid #3498db;border-radius:4px;flex:1 1;font-size:1em;font-weight:500;min-width:120px;padding:10px 14px;transition:border-color .3s ease,box-shadow .3s ease}.group-name-input:focus{border-color:#2980b9;box-shadow:0 0 0 3px #3498db1a;outline:none}.btn-cancel-name,.btn-save-name{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:.85em;font-weight:700;justify-content:center;min-height:32px;min-width:32px;padding:6px 10px;transition:all .3s ease}.btn-save-name{background-color:#27ae601a;color:#27ae60}.btn-save-name:hover{background-color:#27ae60;color:#fff;transform:scale(1.1)}.btn-cancel-name{background-color:#e74c3c1a;color:#e74c3c}.btn-cancel-name:hover{background-color:#e74c3c;color:#fff;transform:scale(1.1)}.btn-disable-group{align-items:center;background-color:#e74c3c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;height:24px;justify-content:center;transition:all .3s ease;width:24px}.btn-disable-group:hover{background-color:#c0392b;transform:scale(1.1)}.btn-enable-group{align-items:center;background-color:#27ae60;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:24px;justify-content:center;transition:all .3s ease;width:24px}.btn-enable-group:hover{background-color:#229954;transform:scale(1.1)}.select-clear-container{align-items:center;display:flex;gap:8px}.enhanced-select{background-color:#fff;border:2px solid #e9ecef;border-radius:4px;flex:1 1;font-size:.95em;padding:10px;transition:border-color .3s ease,box-shadow .3s ease}.btn-clear-group{background-color:#f39c12;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.85em;font-weight:500;max-width:20px;padding:8px 12px;transition:all .3s ease;white-space:nowrap}.btn-clear-group:hover{background-color:#e67e22;box-shadow:0 2px 4px #f39c124d;transform:translateY(-1px)}.btn-clear-group:active{transform:translateY(0)}.enhanced-select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.enhanced-select:disabled{background-color:#e9ecef;border-color:#dee2e6;color:#6c757d;cursor:not-allowed}.selected-employee{background-color:#e8f5e8;border-left:3px solid #27ae60;border-radius:4px;font-size:.9em;font-weight:500;margin-top:10px;padding:10px 12px}.modal-buttons{display:flex;gap:12px;justify-content:space-around;margin-top:20px}.modal-buttons button{border:none;border-radius:6px;cursor:pointer;font-size:.95em;font-weight:500;min-width:100px;padding:10px 20px;transition:all .3s ease}.modal-buttons .btn-primary{background-color:#3498db;color:#fff}.modal-buttons .btn-primary:hover{background-color:#2980b9;box-shadow:0 3px 8px #3498db33;transform:translateY(-1px)}.modal-buttons .btn-secondary{background-color:#95a5a6;color:#fff}.modal-buttons .btn-secondary:hover{background-color:#7f8c8d;box-shadow:0 3px 8px #95a5a633;transform:translateY(-1px)}@media (max-width:768px){.control-panel{padding:15px}.calendar-grid{margin-bottom:20px;padding:15px}.control-buttons{gap:15px;padding:15px}.control-buttons-row{flex-direction:column;gap:10px}.control-buttons button{max-width:none;min-width:auto;width:100%}.control-buttons .manual-trigger-button{max-width:none}.calendar-header-cell{font-size:.8em;padding:8px 4px}.day{max-height:140px;min-height:100px;padding:8px}.day .day-number{font-size:1.1em}.day .grouping-details{font-size:.7em;max-height:70px;padding:3px 5px;width:95%}.special-day-checkbox{font-size:.85em;min-width:140px;padding:6px 8px}.time-input-group{font-size:.8em}.time-input-group input[type=number]{font-size:.8em;height:24px;width:42px}.enhanced-grouping-modal{margin:10px;width:95%}.modal-header{align-items:center;flex-direction:column;gap:10px}.modal-header h3{text-align:center}.clear-date-btn{font-size:.95em;padding:10px;width:100%}.modal-nav-arrow{font-size:18px;height:40px;width:40px}.modal-nav-left{left:10px}.modal-nav-right{right:10px}.group-controls{gap:10px}.group-header{align-items:flex-start;flex-direction:column;gap:10px}.group-name-edit{width:100%}.group-name-input{font-size:.9em;min-width:100px}.select-clear-container{flex-direction:column;gap:6px}.btn-clear-group{font-size:.9em;padding:10px;width:100%}.modal-buttons{flex-direction:column}.modal-buttons button{width:100%}}@media (max-width:480px){.calendar-grid,.control-panel{padding:10px}.control-buttons{gap:12px;padding:10px}.control-buttons button{font-size:.85em;padding:10px 16px}.calendar-header-cell{font-size:.75em;padding:6px 2px}.day{max-height:120px;min-height:80px;padding:6px}.day .day-number{font-size:1em}.day .grouping-details{font-size:.65em;max-height:60px;padding:2px 4px}.special-day-checkbox{font-size:.8em;min-width:120px;padding:4px 6px}.time-input-group{font-size:.75em}.time-input-group input[type=number]{font-size:.75em;height:20px;width:36px}.modal-nav-arrow{font-size:16px;height:35px;width:35px}.modal-nav-left{left:5px}.modal-nav-right{right:5px}}.control-panel.loading{opacity:.7;pointer-events:none}.btn-cancel-name:focus,.btn-clear-group:focus,.btn-disable-group:focus,.btn-enable-group:focus,.btn-save-name:focus,.clear-date-btn:focus,.enhanced-select:focus,.group-name-input:focus,.modal-nav-arrow:focus{outline:2px solid #3498db;outline-offset:2px}@media (prefers-contrast:high){.calendar-grid{border:2px solid #000}.calendar-header-cell{background:#000;border:1px solid #fff;color:#fff}.day{background:#fff;border:2px solid #000}.day:hover{background:#e0e0e0;border-color:#000}.day.selected{background:#000;border-color:#fff;color:#fff}.day.full-shift{background:#ffffe0}.day.full-shift,.form-group.enhanced{border-color:#000}.form-group.enhanced.disabled{background-color:#000;border-color:#fff;color:#fff}.selected-employee{background-color:#000;border-left-color:#fff;color:#fff}.btn-disable-group,.btn-enable-group{background-color:#000;border:1px solid #fff;color:#fff}}@media (prefers-reduced-motion:reduce){.btn-cancel-name,.btn-disable-group,.btn-enable-group,.btn-save-name,.calendar-header-cell,.day,.modal-buttons button,.modal-nav-arrow,.special-day-checkbox{transition:none}.btn-cancel-name:hover,.btn-disable-group:hover,.btn-enable-group:hover,.btn-save-name:hover,.calendar-header-cell:hover,.day:hover,.modal-nav-arrow:hover{transform:none}.special-marker{animation:none}}.day.other-month{background:#f8f9fa!important;border:1px solid #e9ecef!important;color:#ccc!important;opacity:.1}.time-display{background:#0000000d;border-radius:3px;margin-top:5px;padding:2px 4px;text-align:center}.time-text{color:#333;font-size:10px;font-weight:500;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day.selected .time-text{color:#fff}.day.selected .time-display{background:#fff3}.employee-color-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.employee-color-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden;width:1200px}.modal-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e5e7eb;justify-content:space-between;padding:24px 32px}.modal-header,.modal-header h2{align-items:center;display:flex}.modal-header h2{color:#1f2937;font-size:24px;font-weight:600;gap:12px;margin:0}.close-button{align-items:center;background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:32px;justify-content:center;transition:all .2s ease;width:32px}.close-button:hover{background:#dc2626;transform:scale(1.05)}.modal-content{flex:1 1;overflow-y:auto;padding:32px}.error-message,.success-message{border-radius:8px;font-weight:500;margin-bottom:20px}.user-stats{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-left:4px solid #3b82f6;border-radius:12px;margin-bottom:30px;padding:20px}.user-stats p{color:#1f2937;font-size:16px;font-weight:500;margin:8px 0}.user-stats strong{color:#3b82f6;font-weight:700}.users-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:20px}.user-color-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:20px;transition:all .3s ease}.user-color-card:hover{border-color:#3b82f6;box-shadow:0 8px 25px #3b82f626;transform:translateY(-2px)}.user-info{margin-bottom:20px}.user-name{align-items:center;color:#1f2937;display:flex;font-size:18px;font-weight:600;gap:10px;margin-bottom:8px}.google-badge{background:linear-gradient(135deg,#4285f4,#34a853);border-radius:12px;color:#fff;font-size:11px;font-weight:500;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.user-username{color:#6b7280;font-family:Courier New,monospace;font-size:14px;margin-bottom:8px}.google-profile-info,.shift-info{color:#6b7280;font-size:12px}.shift-info{font-weight:500;margin-top:4px}.color-section{display:flex;flex-direction:column;gap:15px}.current-color-display{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:12px;padding:12px}.color-preview{border:2px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000001a;height:40px;width:40px}.color-code{background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;font-family:Courier New,monospace;font-size:14px;font-weight:600;padding:4px 8px}.color-controls{align-items:center;display:flex;gap:12px}.color-input{border:none;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;height:50px;transition:all .2s ease;width:50px}.color-input:hover{box-shadow:0 4px 8px #00000026;transform:scale(1.05)}.save-button{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-weight:600;padding:12px 20px;transition:all .2s ease}.save-button:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.save-button:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.no-users{color:#6b7280;padding:40px 20px;text-align:center}.no-users p{font-size:16px;margin:8px 0}@media (max-width:768px){.employee-color-modal{max-height:95vh;width:95vw}.modal-content,.modal-header{padding:20px}.users-grid{gap:16px;grid-template-columns:1fr}.user-color-card{padding:16px}.color-controls{align-items:stretch;flex-direction:column}.save-button{width:100%}}@media (max-width:480px){.modal-header h2{font-size:20px}.user-name{font-size:16px}.color-preview{height:30px;width:30px}.color-input{height:40px;width:40px}}.auto-schedule-modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;max-height:90vh;max-width:1200px;overflow-y:auto;width:95vw}.auto-schedule-modal .modal-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e5e7eb;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;padding:20px 24px}.auto-schedule-modal .modal-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.auto-schedule-modal .close-btn{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:24px;padding:4px;transition:all .2s}.auto-schedule-modal .close-btn:hover{background:#f3f4f6;color:#374151}.auto-schedule-modal .modal-content{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;padding:24px}.generate-section,.month-selection-section,.submissions-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:32px;padding:20px}.generate-section{grid-column:1/-1}.generate-section h4,.month-selection-section h4,.submissions-section h4{color:#1f2937;font-size:1.1rem;font-weight:600;margin:0 0 12px}.section-description{color:#6b7280;font-size:.9rem;line-height:1.5;margin:0 0 16px}.month-selector{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:16px}.year-month-inputs{align-items:center;display:flex;flex-wrap:wrap;gap:16px}.input-group{align-items:center;display:flex;gap:8px}.input-group label{color:#374151;font-size:.9rem;font-weight:500}.month-select,.year-select{background:#fff;border:1px solid #d1d5db;border-radius:4px;font-size:.9rem;min-width:80px;padding:8px 12px}.month-select:focus,.year-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.refresh-btn{background:#3b82f6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:all .2s}.refresh-btn:hover{background:#2563eb}.no-data{background:#f9fafb;border:1px dashed #d1d5db;border-radius:6px;color:#6b7280;font-style:italic;padding:20px;text-align:center}.auto-priority{background:#dbeafe;border-radius:12px;color:#1e40af;font-size:.8rem;font-weight:500;padding:2px 8px}.users-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.user-priority-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;display:flex;justify-content:space-between;padding:12px 16px;transition:all .2s}.user-priority-item:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.user-info{gap:8px}.nickname{color:#6b7280;font-size:.9rem}.priority-control{align-items:center;display:flex;gap:8px}.priority-control label{color:#374151;font-size:.9rem;font-weight:500}.priority-input{border:1px solid #d1d5db;border-radius:4px;font-size:.9rem;padding:4px 8px;text-align:center;width:60px}.priority-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.update-btn{background:#3b82f6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;padding:4px 12px;transition:all .2s}.update-btn:hover{background:#2563eb}.batch-update-btn{background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:all .2s}.batch-update-btn:hover{background:#059669}.submissions-list{display:flex;flex-direction:column;gap:12px}.submission-item{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:16px;transition:all .2s}.submission-item:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.submission-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:8px}.submission-header .username{color:#1f2937;font-weight:600}.submission-header .nickname{color:#6b7280;font-size:.9rem}.submission-header .priority{background:#fef3c7;color:#92400e}.submission-header .count,.submission-header .priority{border-radius:12px;font-size:.8rem;font-weight:500;padding:2px 8px}.submission-header .count{background:#dbeafe;color:#1e40af}.submitted-dates{display:flex;flex-wrap:wrap;gap:4px}.date-tag{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;color:#374151;font-size:.8rem;padding:2px 6px}.generate-btn{background:#8b5cf6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .2s;width:100%}.generate-btn:hover:not(:disabled){background:#7c3aed;box-shadow:0 4px 12px #8b5cf64d;transform:translateY(-1px)}.generate-btn:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626}.error-message,.success-message{font-size:.9rem;margin-bottom:16px;padding:12px 16px}.success-message{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;color:#16a34a}.auto-schedule-modal .modal-buttons{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.btn-secondary{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;padding:8px 16px;transition:all .2s}.btn-secondary:hover{background:#e5e7eb}.priority-list{display:flex;flex-direction:column;gap:8px;margin-top:16px}.priority-item{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:grab;display:flex;padding:12px 16px;position:relative;touch-action:none;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none}.priority-item:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626;transform:translateY(-1px)}.priority-item.dragging{opacity:0;transition:opacity .2s ease}.priority-item.drag-over{background:#f0fdf4;border-color:#10b981;box-shadow:0 4px 12px #10b98133;transform:scale(1.02)}.priority-item.drag-overlay{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-color:#3b82f6;box-shadow:0 12px 30px #00000040;cursor:grabbing;opacity:.95;transform:scale(1.1);z-index:9999}.month-requirement-setting{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:16px;padding:20px}.requirement-input-group{align-items:center;display:flex;gap:12px;margin-bottom:12px}.requirement-input-group .requirement-label{color:#374151;font-size:16px;font-weight:600;white-space:nowrap}.requirement-input-group .requirement-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:16px;min-width:100px;padding:8px 12px;transition:all .2s ease}.requirement-input-group .requirement-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.requirement-input-group .requirement-select:hover{background:#f9fafb;border-color:#3b82f6}.set-requirement-btn{background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.set-requirement-btn:hover{background:#059669;box-shadow:0 4px 8px #10b9814d;transform:translateY(-1px)}.set-requirement-btn:active{box-shadow:0 2px 4px #10b9814d;transform:translateY(0)}.requirement-note{color:#6b7280;font-size:14px;font-style:italic;margin:0}.date-input .requirement-select:hover{background:#f9fafb;border-color:#3b82f6}.individual-dates-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:24px;padding:20px}.individual-dates-header{align-items:center;display:flex;justify-content:center;margin-bottom:12px}.individual-dates-section h5{color:#374151;font-size:16px;font-weight:600;margin:0}.expand-dates-btn{background:#3b82f6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;margin-left:70px;margin-right:70px;padding:4px 8px;transition:all .2s ease}.expand-dates-btn:hover{background:#2563eb;box-shadow:0 4px 8px #3b82f64d;transform:translateY(-1px)}.auto-schedule-calendar-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:0 auto;max-width:500px;overflow:hidden}.auto-schedule-calendar-header{background:#f8fafc;border-bottom:1px solid #e5e7eb;display:grid;grid-template-columns:repeat(7,1fr)}.auto-schedule-calendar-header-cell{border-right:1px solid #e5e7eb;color:#374151;font-size:12px;font-weight:600;min-height:24px;padding:6px 4px;text-align:center}.auto-schedule-calendar-header-cell:last-child{border-right:none}.auto-schedule-calendar-grid{grid-gap:0;display:grid;gap:0;grid-template-columns:repeat(7,1fr)}.auto-schedule-calendar-cell{align-items:center;border-bottom:1px solid #e5e7eb;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;justify-content:center;min-height:35px;padding:3px;transition:all .2s ease}.auto-schedule-calendar-cell:nth-child(7n){border-right:none}.auto-schedule-date-cell{background:#fff;cursor:pointer}.auto-schedule-date-cell:hover{background:#f8fafc;border-color:#3b82f6}.auto-schedule-empty-cell{background:#f9fafb;border-color:#f3f4f6}.auto-schedule-date-info{margin-bottom:2px}.auto-schedule-date-day{color:#1f2937;font-size:13px;font-weight:700;line-height:1}.auto-schedule-date-input{width:100%}.auto-schedule-date-input .auto-schedule-requirement-select{background:#fff;border:1px solid #d1d5db;border-radius:3px;color:#374151;cursor:pointer;font-size:11px;min-height:18px;padding:2px 3px;text-align:center;transition:all .2s ease;width:100%}.auto-schedule-date-input .auto-schedule-requirement-select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.auto-schedule-date-input .auto-schedule-requirement-select:hover{background:#f9fafb;border-color:#3b82f6}.priority-number{align-items:center;background:#3b82f6;border-radius:50%;color:#fff;display:flex;font-size:.9rem;font-weight:600;height:32px;justify-content:center;margin-right:12px;width:32px}.priority-user-info{align-items:center;display:flex;flex:1 1;gap:12px}.priority-username{color:#1f2937;font-weight:600}.priority-nickname{color:#6b7280;font-size:.9rem}.priority-count{background:#dbeafe;border-radius:12px;color:#1e40af;font-size:.8rem;font-weight:500;padding:4px 8px}.priority-drag-handle{color:#9ca3af;cursor:grab;padding:4px}.priority-drag-handle:hover{color:#6b7280}.priority-min-days{align-items:center;display:flex;gap:8px;margin-left:12px}.priority-min-days.no-drag{pointer-events:auto;-webkit-user-select:auto;user-select:auto}.min-days-label{color:#6b7280;font-size:12px;white-space:nowrap}.min-days-select{background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;font-size:12px;min-width:50px;padding:4px 6px;transition:all .2s ease}.min-days-select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.min-days-select:hover{border-color:#3b82f6}.user-hours-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:24px;padding:20px}.user-hours-section h4{color:#374151;font-size:16px;font-weight:600;margin:0 0 12px}.user-hours-btn{background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.user-hours-btn:hover{background:#059669;box-shadow:0 4px 8px #10b9814d;transform:translateY(-1px)}.user-hours-btn:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.user-hours-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:80vh;max-width:800px;overflow:hidden;width:90%}.user-hours-modal .modal-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px}.user-hours-modal .modal-header h3{color:#1f2937;font-size:18px;font-weight:600;margin:0}.user-hours-modal .close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:all .2s ease;width:30px}.user-hours-modal .close-btn:hover{background:#f3f4f6;color:#374151}.user-hours-content{max-height:60vh;overflow-y:auto;padding:20px}.user-hours-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:12px;padding:16px}.user-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.username{color:#1f2937;font-size:16px;font-weight:600}.work-stats{align-items:center;display:flex;gap:16px}.work-stats .days{color:#6b7280;font-size:14px}.work-stats .hours{color:#059669;font-size:14px;font-weight:600}.work-days{margin-top:8px}.work-days-label{color:#6b7280;font-size:12px;margin-bottom:6px}.work-days-list{display:flex;flex-wrap:wrap;gap:6px}.work-day{background:#dbeafe;border-radius:4px;color:#1e40af;font-size:12px;font-weight:500;padding:2px 8px}@media (max-width:1024px){.auto-schedule-modal .modal-content{gap:16px;grid-template-columns:1fr}.generate-section{grid-column:1}}@media (max-width:768px){.auto-schedule-modal{margin:20px;max-width:95vw;width:95vw}.auto-schedule-modal .modal-content{gap:12px;padding:16px}.user-priority-item{align-items:flex-start;flex-direction:column;gap:12px}.priority-control{justify-content:space-between;width:100%}.submission-header{align-items:flex-start;flex-direction:column;gap:8px}.submission-header>span{display:block}}.generate-btn:disabled{overflow:hidden;position:relative}.generate-btn:disabled:after{animation:loading 1.5s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes loading{0%{left:-100%}to{left:100%}}.loading-feedback{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin:20px 0;padding:20px}.progress-container{align-items:center;display:flex;gap:15px;margin-bottom:10px}.progress-bar{background:#e9ecef;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#4a90e2,#357abd);border-radius:4px;height:100%;position:relative;transition:width .3s ease}.progress-fill:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d 50%,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.progress-text{color:#4a90e2;font-weight:600;min-width:40px;text-align:right}.loading-step{color:#6c757d;font-size:14px;font-weight:500;text-align:center}.error-feedback,.success-feedback{align-items:center;border-radius:6px;display:flex;font-size:14px;font-weight:500;gap:10px;margin:15px 0;padding:12px 16px}.error-feedback{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.success-feedback{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.error-icon,.success-icon{font-size:16px}.error-text,.success-text{flex:1 1}.generate-btn.loading{background:linear-gradient(135deg,#4a90e2,#357abd);cursor:not-allowed}.btn-loading-content{align-items:center;display:flex;gap:8px;justify-content:center}.spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.admin-layout .sidebar-container *{box-sizing:border-box!important}.admin-layout .sidebar-container button{background:none!important;border:none!important;border-radius:0!important;box-shadow:none!important;color:inherit!important;cursor:pointer!important;font:inherit!important;line-height:normal!important;margin:0!important;min-height:auto!important;min-width:auto!important;outline:none!important;padding:0!important;text-decoration:none!important;white-space:normal!important}.admin-layout .sidebar-container,.admin-layout .sidebar-container *,.admin-layout .sidebar-container .nav-button,.admin-layout .sidebar-container button{background-color:#fff!important;background:#fff!important;color:#374151!important}.admin-layout .sidebar-container{--primary-color:#374151!important;--primary-hover:#111827!important}.admin-layout .sidebar-container,.admin-layout .sidebar-container *{background:#fff!important;background-attachment:scroll!important;background-clip:padding-box!important;background-color:#f8f9fa!important;background-image:none!important;background-origin:initial!important;background-position:0 0!important;background-repeat:repeat!important;background-size:auto!important}.admin-layout .sidebar-container .nav-button,.admin-layout .sidebar-container .nav-button:hover,.admin-layout .sidebar-container button,.admin-layout .sidebar-container button:hover{background:#fff!important;background-color:#fff!important;background-image:none!important;border:none!important;box-shadow:none!important;color:#374151!important}.admin-layout .sidebar-container{background:#fff!important;border-right:1px solid #e5e7eb!important;box-shadow:0 0 20px #0000001a!important;contain:layout style paint!important;display:flex!important;flex-direction:column!important;height:100vh!important;isolation:isolate!important;left:0!important;overflow:hidden!important;position:fixed!important;top:0!important;width:280px!important;z-index:1000!important}.admin-layout .sidebar-container .sidebar-header{background:#fff!important;border-bottom:1px solid #ccc!important;padding:24px 20px!important}.admin-layout .sidebar-container .sidebar-header h2{background-color:#fff!important;color:#111827!important;font-size:18px!important;font-weight:600!important;letter-spacing:-.025em!important;margin:0 0 8px!important}.admin-layout .sidebar-container .sidebar-header h2:before{color:#6b7280!important;content:"⚡"!important;margin-right:8px!important}.admin-layout .sidebar-container .admin-status{align-items:center!important;background-color:#fff!important;color:#6b7280!important;display:flex!important;font-size:12px!important;font-weight:500!important;gap:8px!important;margin-top:6px!important}.admin-layout .sidebar-container .status-indicator{animation:pulse 2s infinite!important;background:#fff!important;border-radius:50%!important;box-shadow:0 0 4px #10b9814d!important;height:6px!important;width:6px!important}.admin-layout .sidebar-container .sidebar-nav{contain:layout style paint!important;flex:1 1!important;max-height:calc(100vh - 200px)!important;overflow-x:hidden!important;overflow-y:auto!important;padding:20px 0!important;position:relative!important;z-index:1!important}.admin-layout .sidebar-container .sidebar-nav::-webkit-scrollbar{width:4px!important}.admin-layout .sidebar-container .sidebar-nav::-webkit-scrollbar-track{background:#f9fafb!important}.admin-layout .sidebar-container .sidebar-nav::-webkit-scrollbar-thumb{background:#d1d5db!important;border-radius:2px!important}.admin-layout .sidebar-container .sidebar-nav::-webkit-scrollbar-thumb:hover{background:#9ca3af!important}.admin-layout .sidebar-container .nav-section{margin-bottom:24px!important;padding:0 8px!important}.admin-layout .sidebar-container .nav-section h3{color:#6b7280!important;font-size:10px!important;font-weight:600!important;letter-spacing:.05em!important;margin:0 0 8px!important;padding:0 20px!important;text-transform:uppercase!important}.admin-layout .sidebar-container .nav-button{align-items:center!important;background:none!important;border:none!important;border-radius:0!important;box-shadow:none!important;color:#374151!important;contain:layout style paint!important;cursor:pointer!important;display:flex!important;font-size:14px!important;font-weight:500!important;gap:12px!important;isolation:isolate!important;line-height:normal!important;margin:2px 0!important;min-height:auto!important;min-width:auto!important;padding:12px 20px!important;position:relative!important;text-align:left!important;text-decoration:none!important;transform-origin:left center!important;transition:all .2s ease!important;white-space:normal!important;width:100%!important;will-change:transform,background-color,box-shadow!important}.admin-layout .sidebar-container .nav-button:before{background:#111827!important;content:""!important;height:100%!important;left:0!important;position:absolute!important;top:0!important;transform:scaleY(0)!important;transition:transform .2s ease!important;width:3px!important}.admin-layout .sidebar-container .nav-button:hover:not(:disabled){background:#f3f4f6!important;border-radius:6px!important;box-shadow:0 2px 8px #0000001a!important;color:#111827!important;contain:layout style paint!important;isolation:isolate!important;transform:translateX(2px)!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important}.admin-layout .sidebar-container .nav-button:hover:not(:disabled):before{background:#111827!important;border-radius:0 2px 2px 0!important;transform:scaleY(1)!important;width:4px!important}.admin-layout .sidebar-container .nav-button.active{background:#f3f4f6!important;border-right:3px solid #374151!important;color:#111827!important}.admin-layout .sidebar-container .nav-button.active:before{transform:scaleY(1)!important}.admin-layout .sidebar-container .nav-button.danger{color:#dc2626!important}.admin-layout .sidebar-container .nav-button.danger:hover:not(:disabled){background:#e0a2a2!important;border-radius:6px!important;box-shadow:0 2px 8px #dc262626!important;color:#dc2626!important;contain:layout style paint!important;isolation:isolate!important;transform:translateX(2px)!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important}.admin-layout .sidebar-container .nav-button.danger:hover:not(:disabled):before{background:#dc2626!important;border-radius:0 2px 2px 0!important;transform:scaleY(1)!important;width:4px!important}.admin-layout .sidebar-container .nav-button:disabled{cursor:not-allowed!important;opacity:.4!important}.admin-layout .sidebar-container .nav-icon{align-items:center!important;color:#6b7280!important;display:flex!important;font-size:16px!important;justify-content:center!important;width:20px!important}.admin-layout .sidebar-container .nav-button:hover:not(:disabled) .nav-icon{color:#111827!important;transform:scale(1.05)!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important}.admin-layout .sidebar-container .nav-button.active .nav-icon{color:#111827!important;transform:scale(1.05)!important}.admin-layout .sidebar-container .nav-button.danger .nav-icon{color:#dc2626!important}.admin-layout .sidebar-container .nav-button.danger:hover:not(:disabled) .nav-icon{color:#dc2626!important;transform:scale(1.05)!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important}.admin-layout .sidebar-container .nav-text{background:#0000!important;flex:1 1!important;font-weight:500!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important}.admin-layout .sidebar-container .nav-button:hover:not(:disabled) .nav-text{color:#111827!important}.admin-layout .sidebar-container .nav-button.danger:hover:not(:disabled) .nav-text,.admin-layout .sidebar-container .nav-button:hover:not(:disabled) .nav-text{background:#0000!important;font-weight:600!important;transform:translateX(1px)!important}.admin-layout .sidebar-container .sidebar-footer{background:#fff!important;border-top:1px solid #e5e7eb!important;padding:20px!important}.admin-layout .sidebar-container .current-month{background:#f9fafb!important;border:1px solid #e5e7eb!important;border-radius:8px!important;padding:12px!important;text-align:center!important}.admin-layout .sidebar-container .month-label{color:#6b7280!important;display:block!important;font-size:10px!important;font-weight:600!important;letter-spacing:.05em!important;margin-bottom:4px!important;text-transform:uppercase!important}.admin-layout .sidebar-container .month-value{color:#111827!important;display:block!important;font-size:14px!important;font-weight:600!important;letter-spacing:-.025em!important}.admin-layout .sidebar-container .nav-button:focus{background:#f3f4f6!important;box-shadow:0 0 0 3px #11182733!important;outline:none!important;transform:translateX(2px)!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important}.admin-layout .sidebar-container .nav-button:focus:before{background:#111827!important;border-radius:0 2px 2px 0!important;transform:scaleY(1)!important;width:4px!important}@media (max-width:768px){.admin-layout .sidebar-container{height:auto!important;position:relative!important;width:100%!important;z-index:1001!important}.admin-layout .sidebar-container .sidebar-nav{padding:16px 0!important}.admin-layout .sidebar-container .nav-button{padding:10px 16px!important}.admin-layout .sidebar-container .sidebar-header{padding:20px 16px!important}.admin-layout .sidebar-container .sidebar-footer{padding:16px!important}}@media (max-width:480px){.admin-layout .sidebar-container{width:100%!important}.admin-layout .sidebar-container .nav-button{font-size:13px!important;padding:8px 12px!important}.admin-layout .sidebar-container .sidebar-header h2{font-size:16px!important}}.login-container{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;box-sizing:border-box;margin:20px auto;max-width:400px;padding:20px;width:90%}.login-container h2{color:#333;margin-bottom:20px;text-align:center}.login-container form>div{margin-bottom:15px}.login-container label{color:#555;display:block;font-weight:500;margin-bottom:5px}.login-container input{-webkit-appearance:none;appearance:none;border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:16px;padding:15px;width:100%}.login-container input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.login-container button{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;min-height:48px;padding:16px;transition:all .3s ease;width:100%}.login-container button:hover{background:#0056b3}.login-container button:disabled{background:#6c757d;cursor:not-allowed}.login-container .error{background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#dc3545;margin-bottom:15px;padding:10px;text-align:center}.divider{margin:20px 0;position:relative;text-align:center}.divider:before{background:#e9ecef;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.divider span{background:#fff;color:#6c757d;font-size:14px;padding:0 15px}.google-login-button{align-items:center;background:#fff!important;border:2px solid #e0e0e0!important;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#333!important;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:12px;justify-content:center;margin-bottom:20px;min-height:48px;padding:16px;transition:all .3s ease;width:100%}.google-login-button:hover{background:#f8f9fa;border-color:#c1c7cd;box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.google-login-button:active{background:#f1f3f4;box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.google-login-button:disabled{background:#f8f9fa;border-color:#e8eaed;box-shadow:none;color:#9aa0a6;cursor:not-allowed;transform:none}.google-icon{flex-shrink:0}.forgot-password-section{margin:16px 0;text-align:center}.forgot-password-text{color:#007bff;cursor:pointer;font-size:14px;text-decoration:underline;transition:color .3s ease}.forgot-password-text:hover{color:#0056b3}.register-section{border-top:1px solid #e9ecef;margin-top:20px;padding-top:20px;text-align:center}.register-section p{color:#6c757d;font-size:14px;margin-bottom:15px}.register-button{background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;min-height:44px;padding:12px 24px;transition:all .3s ease}.register-button:hover{background:#218838}.register-button:active{background:#1e7e34}@media (max-width:480px){.login-container{border-radius:12px;margin:10px auto;padding:16px;width:95%}.login-container h2{font-size:24px;margin-bottom:24px}.login-container input{border-radius:12px;font-size:18px;padding:18px}.google-login-button,.login-container button{border-radius:12px;font-size:18px;min-height:56px;padding:18px}.google-login-button{font-weight:600}.register-button{font-size:16px;min-height:52px;padding:16px 28px}.register-section{margin-top:24px;padding-top:24px}.register-section p{font-size:16px;margin-bottom:18px}}@media (min-width:481px) and (max-width:768px){.login-container{margin:30px auto;padding:24px;width:85%}.login-container input{padding:16px}.google-login-button,.login-container button{min-height:52px;padding:16px}.google-login-button{font-weight:600}}@media (min-width:769px) and (max-width:1024px){.login-container{margin:40px auto;padding:28px;width:80%}}@media (min-width:1025px){.login-container{margin:50px auto;padding:32px;width:400px}.login-container:hover{box-shadow:0 4px 20px #00000026;transform:translateY(-2px)}}@media (hover:none) and (pointer:coarse){.login-container button:active,.register-button:active{background:#0056b3;transform:scale(.98)}.register-button:active{background:#1e7e34}.login-container input:focus{border-color:#0056b3;box-shadow:0 0 0 3px #007bff4d}}.login-container{animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-container button,.register-button{overflow:hidden;position:relative}.login-container button:before,.register-button:before{background:#fff3;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.login-container button:active:before,.register-button:active:before{height:300px;width:300px}.register-container{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:40px auto;max-width:400px;padding:20px}.register-container h2{color:#333}.guide-text,.register-container h2{margin-bottom:20px;text-align:center}.guide-text{color:#666;font-size:1em}.form-field{display:flex;flex-direction:column;margin-bottom:15px}.form-field label{color:#333;font-size:1em;margin-bottom:5px}.form-field input{border:1px solid #ccc;border-radius:4px;font-size:1em;padding:10px}.success{color:green;margin-bottom:10px}button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1em;padding:10px;transition:background .3s ease;width:100%}button:hover{background:#0056b3}.code-hint{color:#666;display:block;font-size:.85em;font-style:italic;margin-top:5px}@media (max-width:480px){.register-container{margin:20px auto;padding:16px;width:95%}.form-field input{font-size:16px;padding:12px}button{font-size:16px;padding:14px}}.admin-login-container{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:40px auto;max-width:400px;padding:20px}.admin-login-container h2{color:#333;margin-bottom:20px;text-align:center}.admin-login-container form{display:flex;flex-direction:column}.admin-login-container label{color:#333;margin-bottom:5px}.admin-login-container input{border:1px solid #ccc;border-radius:4px;margin-bottom:15px;padding:10px}.admin-login-container button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:10px}.admin-login-container button:hover{background:#0056b3}.setup-nickname-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-sizing:border-box;display:flex;justify-content:center;min-height:100vh;padding:20px}.setup-nickname-card{animation:slideUp .6s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a;max-width:480px;padding:40px;text-align:center;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.google-info{margin-bottom:32px}.google-avatar{align-items:center;background:#f8f9fa;border:3px solid #e8eaed;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.google-icon{height:40px;width:40px}.google-info h2{color:#333;font-size:24px;font-weight:600;margin:0 0 8px}.google-info p{color:#666;font-size:16px;margin:0}.form-group{margin-bottom:24px;text-align:left}.form-group label{color:#333}.required{color:#e74c3c}.form-group input{border:2px solid #e1e5e9;border-radius:12px;padding:16px;transition:all .3s ease}.form-group input:focus{border-color:#4285f4;box-shadow:0 0 0 3px #4285f41a}.form-group input:disabled{background:#f8f9fa}.input-hint{color:#6c757d;font-size:12px;margin-top:6px}.validating-hint{color:#4285f4}.validating-hint,.validation-error{align-items:center;display:flex;font-size:12px;gap:4px;margin-top:6px}.validation-error{color:#e74c3c}.error-input{border-color:#e74c3c!important;box-shadow:0 0 0 3px #e74c3c1a!important}.button-group{margin-bottom:24px}.primary-button{background:#4285f4;border-radius:12px;min-height:52px;padding:16px}.primary-button:hover:not(:disabled){background:#3367d6;box-shadow:0 4px 12px #4285f44d}.primary-button:disabled{background:#9aa0a6;box-shadow:none}.error{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;margin-bottom:20px;padding:12px 16px}.help-text{border-top:1px solid #e1e5e9}.help-text p{align-items:center;display:flex;font-size:14px;gap:8px;justify-content:center;margin:0}@media (max-width:480px){.setup-nickname-container{padding:16px}.setup-nickname-card{border-radius:12px;padding:24px}.google-info h2{font-size:20px}.google-info p{font-size:14px}.form-group input,.primary-button{font-size:16px;padding:14px}.primary-button{min-height:48px}}.primary-button{overflow:hidden;position:relative}.primary-button:before{background:#fff3;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.primary-button:active:before{height:300px;width:300px}.forgot-password-container{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;box-sizing:border-box;margin:20px auto;max-width:400px;padding:20px;width:90%}.forgot-password-card{width:100%}@media (max-width:480px){.forgot-password-container{margin:10px auto;padding:16px;width:95%}.header h2{font-size:20px}.form-group input{font-size:16px;padding:14px 16px}.primary-button{font-size:16px;padding:14px 24px}}.verify-code-container{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;box-sizing:border-box;margin:20px auto;max-width:400px;padding:20px;width:90%}.verify-code-card{width:100%}.code-input{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:18px;font-weight:600;letter-spacing:2px;padding:12px 16px;text-align:center;transition:border-color .3s ease;width:100%}.code-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.code-input:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.time-left{margin-top:8px;text-align:center}.timer{color:#007bff}.expired,.timer{font-size:14px;font-weight:600}.expired{color:#dc3545}.resend-section{margin-bottom:20px;text-align:center}.resend-button{background:none;border:1px solid #007bff;border-radius:6px;color:#007bff;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .3s ease}.resend-button:hover:not(:disabled){background:#007bff;color:#fff}.resend-button:disabled{border-color:#6c757d;color:#6c757d;cursor:not-allowed}.back-to-forgot{margin-bottom:20px;text-align:center}@media (max-width:480px){.verify-code-container{margin:10px auto;padding:16px;width:95%}.code-input,.header h2{font-size:20px}.code-input{padding:14px 16px}.primary-button{font-size:16px;padding:14px 24px}}.reset-password-container{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;box-sizing:border-box;margin:20px auto;max-width:400px;padding:20px;width:90%}.reset-password-card{width:100%}.header{margin-bottom:24px;text-align:center}.header h2{color:#333;font-size:24px;margin-bottom:8px}.header p{color:#666;font-size:14px;line-height:1.5}.header strong{color:#007bff;font-weight:600}.form-group{margin-bottom:20px}.form-group label{color:#555;font-size:14px;margin-bottom:8px}.form-group input{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:16px;padding:12px 16px;transition:border-color .3s ease;width:100%}.form-group input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-group input:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.password-requirements{background:#f8f9fa;border-left:4px solid #007bff;border-radius:6px;margin-bottom:20px;padding:12px}.password-requirements p{color:#333;font-size:14px;font-weight:600;margin:0 0 8px}.password-requirements ul{margin:0;padding-left:16px}.password-requirements li{font-size:13px;list-style:none;margin:4px 0;position:relative}.password-requirements li:before{content:"✓";font-weight:700;left:-16px;position:absolute}.password-requirements li.valid{color:#28a745}.password-requirements li.valid:before{color:#28a745;content:"✓"}.password-requirements li.invalid{color:#dc3545}.password-requirements li.invalid:before{color:#dc3545;content:"✗"}.button-group{margin-bottom:20px}.primary-button{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease;width:100%}.primary-button:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.primary-button:disabled{background:#6c757d;cursor:not-allowed;transform:none}.back-to-login{margin-bottom:20px;text-align:center}.back-button{background:none;border:none;color:#007bff;cursor:pointer;font-size:14px;text-decoration:underline;transition:color .3s ease}.back-button:hover:not(:disabled){color:#0056b3}.back-button:disabled{color:#6c757d;cursor:not-allowed}.help-text{border-top:1px solid #e9ecef;margin-top:20px;padding-top:20px}.help-text p{color:#6c757d;font-size:12px;line-height:1.4;margin:4px 0}.error{background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#dc3545}.error,.success{font-size:14px;margin-bottom:15px;padding:10px;text-align:center}.success{background:#d4edda;border:1px solid #c3e6cb;border-radius:4px;color:#155724}@media (max-width:480px){.reset-password-container{margin:10px auto;padding:16px;width:95%}.header h2{font-size:20px}.form-group input{font-size:16px;padding:14px 16px}.primary-button{font-size:16px;padding:14px 24px}}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker-wrapper{border:0;display:inline-block;padding:0}.react-datepicker{background-color:#fff;border:1px solid #aeaeae;border-radius:.3rem;color:#000;display:inline-block;font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;line-height:normal;position:relative}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker-popper{line-height:0;z-index:1}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker__header{background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative;text-align:center}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select){border-top-right-radius:.3rem}.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__year-dropdown-container--select{display:inline-block;margin:0 15px}.react-datepicker-time__header,.react-datepicker-year-header,.react-datepicker__current-month{color:#000;font-size:.944rem;font-weight:700;margin-top:0}h2.react-datepicker__current-month{margin:0;padding:0}.react-datepicker-time__header{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.react-datepicker__navigation{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:32px;justify-content:center;overflow:hidden;padding:0;position:absolute;text-align:center;text-indent:-999em;top:2px;width:32px;z-index:1}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{display:block;margin-left:auto;margin-right:auto;position:relative;top:0}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover :before{border-color:#a6a6a6}.react-datepicker__navigation-icon{font-size:20px;position:relative;top:-1px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{left:-7px;transform:rotate(45deg)}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{right:-7px;transform:rotate(225deg)}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.4rem;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;margin:2px;width:4rem}.react-datepicker__month{margin:.4rem;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;margin:2px;width:4rem}.react-datepicker__input-time-container{clear:both;float:left;margin:5px 0 10px 15px;text-align:left;width:100%}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{display:inline-block;margin-left:5px}.react-datepicker__time-container{border-left:1px solid #aeaeae;float:right;width:85px}.react-datepicker__time-container--with-today-button{border:1px solid #aeaeae;border-radius:.3rem;display:inline;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{background:#fff;border-bottom-right-radius:.3rem;position:relative}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{border-bottom-right-radius:.3rem;margin:0 auto;overflow-x:hidden;text-align:center;width:85px}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{box-sizing:initial;height:calc(195px + .85rem);list-style:none;margin:0;overflow-y:scroll;padding-left:0;padding-right:0;width:100%}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{background-color:#f0f0f0;cursor:pointer}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{background-color:initial;cursor:default}.react-datepicker__week-number{color:#ccc;display:inline-block;line-height:1.7rem;margin:.166rem;text-align:center;width:1.7rem}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__week-number--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{margin-bottom:-8px;white-space:nowrap}.react-datepicker__week{white-space:nowrap}.react-datepicker__day,.react-datepicker__day-name,.react-datepicker__time-name{color:#000;display:inline-block;line-height:1.7rem;margin:.166rem;text-align:center;width:1.7rem}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{background-color:#3dcc4a;border-radius:.3rem;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{background-color:#ff6803;border-radius:.3rem;color:#fff;position:relative}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{background-color:#333;border-radius:4px;bottom:100%;color:#fff;left:50%;opacity:0;padding:4px;position:absolute;transform:translateX(-50%);transition:visibility 0s,opacity .3s ease-in-out;visibility:hidden;white-space:nowrap}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{opacity:1;visibility:visible}.react-datepicker__day--in-range,.react-datepicker__day--in-selecting-range,.react-datepicker__day--selected,.react-datepicker__month-text--in-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--selected,.react-datepicker__quarter-text--in-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--selected,.react-datepicker__year-text--in-range,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{background-color:#bad9f1;border-radius:.3rem;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{color:#ccc;cursor:default}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{background-color:#333;border-radius:4px;bottom:70%;color:#fff;left:50%;opacity:0;padding:4px;position:absolute;transform:translateX(-50%);transition:visibility 0s,opacity .3s ease-in-out;visibility:hidden;white-space:nowrap}.react-datepicker__input-container{display:inline-block;position:relative;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{box-sizing:initial;padding:.5rem;position:absolute}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__month-read-view,.react-datepicker__month-year-read-view,.react-datepicker__year-read-view{border:1px solid #0000;border-radius:.3rem;position:relative}.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover,.react-datepicker__year-read-view:hover{cursor:pointer}.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__year-read-view--down-arrow{right:-16px;top:0;transform:rotate(135deg)}.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown,.react-datepicker__year-dropdown{background-color:#f0f0f0;border:1px solid #aeaeae;border-radius:.3rem;left:25%;position:absolute;text-align:center;top:30px;width:50%;z-index:1}.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover,.react-datepicker__year-dropdown:hover{cursor:pointer}.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable,.react-datepicker__year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__month-option,.react-datepicker__month-year-option,.react-datepicker__year-option{display:block;line-height:20px;margin-left:auto;margin-right:auto;width:100%}.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type,.react-datepicker__year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type,.react-datepicker__year-option:last-of-type{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem;-webkit-user-select:none;user-select:none}.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover,.react-datepicker__year-option:hover{background-color:#ccc}.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected,.react-datepicker__year-option--selected{left:15px;position:absolute}.react-datepicker__close-icon{background-color:initial;border:0;cursor:pointer;display:table-cell;height:100%;outline:0;padding:0 6px 0 0;position:absolute;right:0;top:0;vertical-align:middle}.react-datepicker__close-icon:after{background-color:#216ba5;border-radius:50%;color:#fff;content:"×";cursor:pointer;display:table-cell;font-size:12px;height:16px;line-height:1;padding:2px;text-align:center;vertical-align:middle;width:16px}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{background-color:#ccc;cursor:default}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;clear:left;cursor:pointer;font-weight:700;padding:5px 0;text-align:center}.react-datepicker__portal{align-items:center;background-color:#000c;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:2147483647}.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__time-name{line-height:3rem;width:3rem}@media (max-height:550px),(max-width:400px){.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__time-name{line-height:2rem;width:2rem}}.react-datepicker__portal .react-datepicker-time__header,.react-datepicker__portal .react-datepicker__current-month{font-size:1.44rem}.react-datepicker__children-container{height:auto;margin:.4rem;padding-left:.2rem;padding-right:.2rem;width:13.8rem}.react-datepicker__aria-live{border:0;clip-path:circle(0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.react-datepicker__calendar-icon{height:1em;vertical-align:-.125em;width:1em}.calendar-container{align-items:center;animation:fadeIn .5s ease-out;background-color:var(--white);border:1px solid var(--gray-300);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:column;margin:0 auto;margin-bottom:var(--spacing-xxl);min-width:100%;padding:var(--spacing-xl);width:100%}.calendar-container h2{color:var(--gray-900);font-size:var(--font-size-xxl);font-weight:600;margin-bottom:var(--spacing-lg);text-align:center}.react-datepicker{background-color:var(--white);border:2px solid var(--gray-300);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);font-family:inherit}.react-datepicker__header{background-color:var(--primary-color);border-bottom:2px solid var(--primary-color);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0;padding:var(--spacing-md)}.react-datepicker__current-month{color:var(--white);font-weight:600;margin-bottom:var(--spacing-sm)}.react-datepicker__day-name{color:var(--white);font-weight:500;margin:var(--spacing-xs)}.react-datepicker__day{background-color:var(--white);border-radius:var(--border-radius-md);color:var(--gray-900);cursor:pointer;font-weight:500;margin:var(--spacing-xs);transition:all .3s ease}.react-datepicker__day:hover{background-color:var(--primary-color);color:var(--white);transform:scale(1.1)}.react-datepicker__day--disabled{background-color:var(--gray-200)!important;color:var(--gray-500)!important;cursor:not-allowed!important;transform:none!important}.react-datepicker__day--outside-month{color:var(--gray-400)}.react-datepicker__navigation{top:var(--spacing-md)}.react-datepicker__navigation-icon:before{border-color:var(--white);border-width:2px 2px 0 0}.react-datepicker__navigation:hover .react-datepicker__navigation-icon:before{border-color:var(--gray-200)}.react-datepicker__day--selected{animation:selectedPulse .6s ease-out;background:linear-gradient(135deg,var(--primary-color),#4f46e5)!important;border-radius:50%!important;box-shadow:0 4px 12px #3b82f666,0 0 0 2px var(--white),0 0 0 4px var(--primary-color)!important;color:var(--white)!important;font-weight:700!important;position:relative!important;transform:scale(1.15)!important;z-index:3!important}.full-shift{position:relative}.full-shift-marker{background-color:#ff4d4f33;border-radius:var(--border-radius-sm);color:var(--danger-color);font-size:var(--font-size-sm);font-weight:700;margin-left:2px;padding:0 2px;position:absolute;right:-2px;top:-2px}.react-datepicker__day--selected .full-shift-marker{background-color:#ffffff4d;color:var(--white);font-weight:800}.full-shift-note{background-color:#ff4d4f1a;border:1px solid #ff4d4f33;border-radius:var(--border-radius-md);color:var(--danger-color);font-size:var(--font-size-sm);margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);text-align:center}@media (max-width:575.98px){.calendar-container{border-radius:var(--border-radius-md);margin-bottom:var(--spacing-md);max-width:100%;padding:var(--spacing-sm);width:100%}.calendar-container h2{font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm)}.react-datepicker{max-width:100%;transform:none;width:100%}.react-datepicker__month-container{width:100%}.react-datepicker__day{font-size:var(--font-size-sm);line-height:2rem;margin:1px;width:2rem}.react-datepicker__day-name{font-size:var(--font-size-xs);line-height:2rem;margin:1px;width:2rem}.react-datepicker__current-month{font-size:var(--font-size-base)}.full-shift-marker{font-size:var(--font-size-xs);right:-1px;top:-1px}.full-shift-note{font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm)}}@media (min-width:576px) and (max-width:767.98px){.calendar-container{max-width:100%;width:95%}.react-datepicker{max-width:100%;width:100%}.react-datepicker__day,.react-datepicker__day-name{line-height:2.2rem;width:2.2rem}}@media (min-width:768px){.calendar-container{max-width:600px}.react-datepicker__day:hover{transform:scale(1.05)}}@media (prefers-contrast:high){.react-datepicker__day--selected{background-color:navy!important;color:#fff!important}.full-shift-marker{background-color:#fcc;color:maroon}}@media (prefers-reduced-motion:reduce){.react-datepicker__day{transition:none}.react-datepicker__day:hover{transform:none}}.calendar-container.mobile{align-items:center;animation:fadeIn .5s ease-out;background-color:var(--white);border:1px solid var(--gray-300);border-radius:var(--border-radius-md);box-shadow:var(--shadow-md);display:flex;flex-direction:column;margin:0 auto;margin-bottom:var(--spacing-md);max-width:100%;padding:var(--spacing-sm);width:100%}.calendar-container.mobile h2{color:var(--gray-900);font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-sm);text-align:center}.calendar-container.mobile .react-datepicker{background-color:var(--white);border:2px solid var(--gray-300);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);font-family:inherit;max-width:100%;width:100%}.calendar-container.mobile .react-datepicker__header{background-color:var(--primary-color);border-bottom:2px solid var(--primary-color);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0;padding:var(--spacing-md)}.calendar-container.mobile .react-datepicker__current-month{color:var(--white);font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--spacing-sm)}.calendar-container.mobile .react-datepicker__day-name{color:var(--white);font-size:var(--font-size-xs);font-weight:500;line-height:2rem;margin:1px;width:2rem}.calendar-container.mobile .react-datepicker__day{background-color:var(--white);border-radius:var(--border-radius-md);color:var(--gray-900);cursor:pointer;font-size:var(--font-size-sm);font-weight:500;line-height:2rem;margin:1px;transition:all .3s ease;width:2rem}.calendar-container.mobile .react-datepicker__day:hover{background-color:var(--primary-color);color:var(--white);transform:scale(1.05)}.calendar-container.mobile .react-datepicker__day--disabled{background-color:var(--gray-200)!important;color:var(--gray-500)!important;cursor:not-allowed!important;transform:none!important}.calendar-container.mobile .react-datepicker__day--outside-month{color:var(--gray-400)}.calendar-container.mobile .react-datepicker__navigation{top:var(--spacing-md)}.calendar-container.mobile .react-datepicker__navigation-icon:before{border-color:var(--white);border-width:2px 2px 0 0}.calendar-container.mobile .react-datepicker__navigation:hover .react-datepicker__navigation-icon:before{border-color:var(--gray-200)}.calendar-container.mobile .react-datepicker__day--selected{animation:selectedPulseMobile .4s ease-out;background:linear-gradient(135deg,var(--primary-color),#4f46e5)!important;border-radius:50%!important;box-shadow:0 2px 8px #3b82f666!important;color:var(--white)!important;font-weight:700!important;position:relative!important;transform:scale(1.1)!important;z-index:3!important}@keyframes selectedPulseMobile{0%{box-shadow:0 0 0 0 #3b82f6b3;transform:scale(1)}50%{box-shadow:0 0 0 6px #3b82f600;transform:scale(1.15)}to{box-shadow:0 2px 8px #3b82f666;transform:scale(1.1)}}.calendar-container.mobile .full-shift{position:relative}.calendar-container.mobile .full-shift-marker{background-color:#ff4d4f33;border-radius:var(--border-radius-sm);color:var(--danger-color);font-size:var(--font-size-xs);font-weight:700;margin-left:2px;padding:0 2px;position:absolute;right:-1px;top:-1px}.calendar-container.mobile .react-datepicker__day--selected .full-shift-marker{background-color:#ffffff4d;color:var(--white);font-weight:800}.calendar-container.mobile .full-shift-note{background-color:#ff4d4f1a;border:1px solid #ff4d4f33;border-radius:var(--border-radius-md);color:var(--danger-color);font-size:var(--font-size-xs);margin-top:var(--spacing-md);padding:var(--spacing-xs) var(--spacing-sm);text-align:center}@media (max-width:575.98px){.calendar-container.mobile{margin-bottom:16px;padding:8px}.calendar-container.mobile .react-datepicker__day{font-size:.75rem;line-height:1.8rem;width:1.8rem}.calendar-container.mobile .react-datepicker__day-name{font-size:.7rem;line-height:1.8rem;width:1.8rem}.calendar-container.mobile .react-datepicker__current-month{font-size:.9rem}}.calendar-container.desktop{align-items:center;animation:fadeIn .5s ease-out;background-color:var(--white);border:1px solid var(--gray-300);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:column;margin:0 auto;margin-bottom:var(--spacing-xxl);max-width:600px;padding:var(--spacing-xl);width:100%}.calendar-container.desktop h2{color:var(--gray-900);font-size:var(--font-size-xxl);font-weight:600;margin-bottom:var(--spacing-lg);text-align:center}.calendar-container.desktop .react-datepicker{background-color:var(--white);border:2px solid var(--gray-300);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);font-family:inherit}.calendar-container.desktop .react-datepicker__header{background-color:var(--primary-color);border-bottom:2px solid var(--primary-color);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0;padding:var(--spacing-md)}.calendar-container.desktop .react-datepicker__current-month{color:var(--white);font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-sm)}.calendar-container.desktop .react-datepicker__day-name{color:var(--white);font-size:var(--font-size-sm);font-weight:500;line-height:2rem;margin:var(--spacing-xs);width:2rem}.calendar-container.desktop .react-datepicker__day{background-color:var(--white);border-radius:var(--border-radius-md);color:var(--gray-900);cursor:pointer;font-size:var(--font-size-base);font-weight:500;line-height:2rem;margin:var(--spacing-xs);transition:all .3s ease;width:2rem}.calendar-container.desktop .react-datepicker__day:hover{background-color:var(--primary-color);color:var(--white);transform:scale(1.1)}.calendar-container.desktop .react-datepicker__day--disabled{background-color:var(--gray-200)!important;color:var(--gray-500)!important;cursor:not-allowed!important;transform:none!important}.calendar-container.desktop .react-datepicker__day--outside-month{color:var(--gray-400)}.calendar-container.desktop .react-datepicker__navigation{top:var(--spacing-md)}.calendar-container.desktop .react-datepicker__navigation-icon:before{border-color:var(--white);border-width:2px 2px 0 0}.calendar-container.desktop .react-datepicker__navigation:hover .react-datepicker__navigation-icon:before{border-color:var(--gray-200)}.calendar-container.desktop .react-datepicker__day--selected{animation:selectedPulse .6s ease-out;background:linear-gradient(135deg,var(--primary-color),#4f46e5)!important;border-radius:50%!important;box-shadow:0 4px 12px #3b82f666,0 0 0 2px var(--white),0 0 0 4px var(--primary-color)!important;color:var(--white)!important;font-weight:700!important;position:relative!important;transform:scale(1.15)!important;z-index:3!important}@keyframes selectedPulse{0%{box-shadow:0 0 0 0 #3b82f6b3;transform:scale(1)}50%{box-shadow:0 0 0 10px #3b82f600;transform:scale(1.2)}to{box-shadow:0 4px 12px #3b82f666,0 0 0 2px var(--white),0 0 0 4px var(--primary-color);transform:scale(1.15)}}.calendar-container.desktop .full-shift{position:relative}.calendar-container.desktop .full-shift-marker{background-color:#ff4d4f33;border-radius:var(--border-radius-sm);color:var(--danger-color);font-size:var(--font-size-sm);font-weight:700;margin-left:2px;padding:0 2px;position:absolute;right:-2px;top:-2px}.calendar-container.desktop .react-datepicker__day--selected .full-shift-marker{background-color:#ffffff4d;color:var(--white);font-weight:800}.calendar-container.desktop .full-shift-note{background-color:#ff4d4f1a;border:1px solid #ff4d4f33;border-radius:var(--border-radius-md);color:var(--danger-color);font-size:var(--font-size-sm);margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);text-align:center}@media (min-width:768px){.calendar-container.desktop{max-width:600px}.calendar-container.desktop .react-datepicker__day:hover{transform:scale(1.05)}}.shift-selector{background:#f9f9f9;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin:0 auto;max-width:1200px;padding:20px;text-align:center;width:95%}.shift-selector h2{color:#333;font-size:1.5em;margin-bottom:10px}.shift-selector p{color:#666;font-size:1.1em;margin-bottom:20px;padding:0 10px}.error{background:#ffebee;color:red;font-weight:700;margin-bottom:10px;padding:5px 10px}.buttons,.error{border-radius:5px}.buttons{background:#fff;box-shadow:0 1px 5px #0000001a;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin:20px 0;padding:10px}.buttons button{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1em;padding:10px 20px;transition:background-color .3s ease,transform .2s ease}.buttons button:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6}.buttons button:hover:not(:disabled){background-color:#0056b3;transform:scale(1.05)}.shift-selected-dates{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:0 auto;max-width:1000px;padding:15px;width:90%}.shift-selected-dates h3{color:#333;font-size:1.2em;margin-bottom:10px}.shift-selected-dates ul{list-style:none;padding:0;text-align:left}.shift-selected-dates li{border-bottom:1px solid #eee;color:#444;font-size:1em;padding:8px 12px;transition:background-color .2s ease}.shift-selected-dates li:hover{background-color:#f5f5f5;cursor:pointer}@media (min-width:1200px){.shift-selector{max-width:1400px;width:90%}.shift-selected-dates{max-width:1200px;width:85%}}@media (max-width:768px){.shift-selector{padding:15px;width:98%}.shift-selected-dates{padding:10px;width:95%}}.home-container{margin:0 auto;max-width:1200px;padding:20px}.month-navigation{align-items:center;background:#f8f9fa;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.nav-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.nav-button:hover{background:linear-gradient(135deg,#764ba2,#667eea);box-shadow:0 6px 16px #667eea66;transform:translateY(-2px)}.nav-button:active{transform:translateY(0)}.month-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#2d3748;font-size:28px;font-weight:700;margin:0;text-align:center}@media (max-width:768px){.home-container{padding:10px}.month-navigation{flex-direction:column;gap:15px;padding:15px}.nav-button{font-size:14px;padding:10px 20px;width:100%}.month-title{font-size:24px;order:-1}}@media (max-width:480px){.month-title{font-size:20px}.nav-button{font-size:12px;padding:8px 16px}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{background-color:#f4f4f4;color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:16px;line-height:1.6}:root{--primary-color:#007bff;--primary-hover:#0056b3;--secondary-color:#6c757d;--success-color:#28a745;--danger-color:#ff4d4f;--warning-color:#ffc107;--info-color:#17a2b8;--light-color:#f8f9fa;--dark-color:#343a40;--white:#fff;--gray-100:#f8f9fa;--gray-200:#e9ecef;--gray-300:#dee2e6;--gray-400:#ced4da;--gray-500:#adb5bd;--gray-600:#6c757d;--gray-700:#495057;--gray-800:#343a40;--gray-900:#212529;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-xxl:3rem;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-xxl:1.5rem;--font-size-xxxl:2rem;--border-radius-sm:0.25rem;--border-radius-md:0.375rem;--border-radius-lg:0.5rem;--border-radius-xl:0.75rem;--shadow-sm:0 1px 3px #0000001a;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 15px #0000001a;--shadow-xl:0 20px 25px #0000001a;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpoint-lg:992px;--breakpoint-xl:1200px}.container{margin:0 auto;max-width:1200px;width:100%}.container,header{padding:1.5rem;padding:var(--spacing-lg)}header{background:#343a40;background:var(--dark-color);box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);color:#fff;color:var(--white);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);text-align:center}header h1{font-size:2rem;font-size:var(--font-size-xxxl);font-weight:600;margin:0}nav{background:#007bff;background:var(--primary-color);border-radius:.5rem;border-radius:var(--border-radius-lg);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);margin-bottom:2rem;margin-bottom:var(--spacing-xl);padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg)}nav ul{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem;gap:var(--spacing-lg);justify-content:flex-start;list-style:none}nav ul li a{border-radius:.375rem;border-radius:var(--border-radius-md);color:#fff;color:var(--white);font-size:1.125rem;font-size:var(--font-size-lg);font-weight:500;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;transition:all .3s ease}nav ul li a:hover{background-color:#ffffff1a;transform:translateY(-1px)}main{background:#fff;background:var(--white);border-radius:.5rem;border-radius:var(--border-radius-lg);box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);margin-bottom:2rem;margin-bottom:var(--spacing-xl);min-height:400px;padding:2rem;padding:var(--spacing-xl)}.button,button{align-items:center;border:none;border-radius:.375rem;border-radius:var(--border-radius-md);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--font-size-base);font-weight:500;justify-content:center;line-height:1.5;min-height:44px;min-width:44px;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;transition:all .3s ease;white-space:nowrap}.btn-primary{background-color:#007bff;background-color:var(--primary-color);color:#fff;color:var(--white)}.btn-primary:hover{background-color:#0056b3;background-color:var(--primary-hover);box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background-color:#6c757d;background-color:var(--secondary-color)}.btn-secondary,.btn-success{color:#fff;color:var(--white)}.btn-success{background-color:#28a745;background-color:var(--success-color)}.btn-danger{background-color:#ff4d4f;background-color:var(--danger-color);color:#fff;color:var(--white)}.btn-warning{background-color:#ffc107;background-color:var(--warning-color);color:#212529;color:var(--gray-900)}.btn-outline{background-color:initial;border:2px solid #007bff;border:2px solid var(--primary-color);color:#007bff;color:var(--primary-color)}.btn-outline:hover{background-color:#007bff;background-color:var(--primary-color);color:#fff;color:var(--white)}.btn-sm{font-size:.875rem;font-size:var(--font-size-sm);min-height:32px;padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm)}.btn-lg{font-size:1.125rem;font-size:var(--font-size-lg);min-height:56px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg)}.button:disabled,button:disabled{cursor:not-allowed;opacity:.6;transform:none!important}input,select,textarea{background-color:#fff;background-color:var(--white);border:2px solid #dee2e6;border:2px solid var(--gray-300);border-radius:.375rem;border-radius:var(--border-radius-md);font-size:1rem;font-size:var(--font-size-base);padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);transition:border-color .3s ease,box-shadow .3s ease;width:100%}input:focus,select:focus,textarea:focus{border-color:#007bff;border-color:var(--primary-color);box-shadow:0 0 0 3px #007bff1a;outline:none}input:disabled,select:disabled,textarea:disabled{background-color:#f8f9fa;background-color:var(--gray-100);cursor:not-allowed}.form-group{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.form-group label{color:#495057;color:var(--gray-700);display:block;font-weight:500;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.card{background:#fff;background:var(--white);border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--border-radius-lg);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding:2rem;padding:var(--spacing-xl);transition:box-shadow .3s ease,transform .3s ease}.card:hover{box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--gray-200);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding-bottom:1rem;padding-bottom:var(--spacing-md)}.card-title{color:#212529;color:var(--gray-900);font-size:1.25rem;font-size:var(--font-size-xl);font-weight:600;margin:0}table{background:#fff;background:var(--white);border-collapse:collapse;border-radius:.5rem;border-radius:var(--border-radius-lg);box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);overflow:hidden;width:100%}td,th{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--gray-200);padding:1rem;padding:var(--spacing-md);text-align:left}th{background-color:#f8f9fa;background-color:var(--gray-100);color:#495057;color:var(--gray-700);font-size:.875rem;font-size:var(--font-size-sm);font-weight:600;letter-spacing:.5px;text-transform:uppercase}tr:hover{background-color:var(--gray-50)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:#007bff;color:var(--primary-color)}.text-success{color:#28a745;color:var(--success-color)}.text-danger{color:#ff4d4f;color:var(--danger-color)}.text-warning{color:#ffc107;color:var(--warning-color)}.text-muted{color:#6c757d;color:var(--gray-600)}.bg-primary{background-color:#007bff;background-color:var(--primary-color)}.bg-success{background-color:#28a745;background-color:var(--success-color)}.bg-danger{background-color:#ff4d4f;background-color:var(--danger-color)}.bg-warning{background-color:#ffc107;background-color:var(--warning-color)}.bg-light{background-color:#f8f9fa;background-color:var(--light-color)}.d-none{display:none}.d-block{display:block}.d-flex{display:flex}.d-grid{display:grid}.justify-content-center{justify-content:center}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.w-100{width:100%}.h-100{height:100%}.m-0{margin:0}.mt-1{margin-top:.5rem;margin-top:var(--spacing-sm)}.mb-1{margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.ml-1{margin-left:.5rem;margin-left:var(--spacing-sm)}.mr-1{margin-right:.5rem;margin-right:var(--spacing-sm)}.p-0{padding:0}.pt-1{padding-top:.5rem;padding-top:var(--spacing-sm)}.pb-1{padding-bottom:.5rem;padding-bottom:var(--spacing-sm)}.pl-1{padding-left:.5rem;padding-left:var(--spacing-sm)}.pr-1{padding-right:.5rem;padding-right:var(--spacing-sm)}@media (max-width:575.98px){.container,header{padding:1rem;padding:var(--spacing-md)}header h1{font-size:1.25rem;font-size:var(--font-size-xl)}main{padding:1rem;padding:var(--spacing-md)}nav ul{flex-direction:column;gap:.5rem;gap:var(--spacing-sm)}nav ul li{width:100%}nav ul li a{display:block;padding:1rem;padding:var(--spacing-md);text-align:center}.button,button{margin-bottom:.5rem;margin-bottom:var(--spacing-sm);width:100%}.btn-group{flex-direction:column}table{font-size:.875rem;font-size:var(--font-size-sm)}td,th{padding:.5rem;padding:var(--spacing-sm)}.card{padding:1rem;padding:var(--spacing-md)}}@media (min-width:576px) and (max-width:767.98px){.container{padding:1.5rem;padding:var(--spacing-lg)}header h1{font-size:1.5rem;font-size:var(--font-size-xxl)}nav ul{gap:1rem;gap:var(--spacing-md)}}@media (min-width:768px){.container{padding:2rem;padding:var(--spacing-xl)}.d-md-flex{display:flex}.d-md-none{display:none}.btn-group{display:flex;gap:.5rem;gap:var(--spacing-sm)}.btn-group button{margin-bottom:0;width:auto}}@media (min-width:1200px){.container{max-width:1400px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.fade-in{animation:fadeIn .5s ease-out}.slide-in{animation:slideIn .3s ease-out}.pulse{animation:pulse 2s infinite}a:focus,button:focus,input:focus,select:focus,textarea:focus{outline:2px solid #007bff;outline:2px solid var(--primary-color);outline-offset:2px}@media (prefers-contrast:high){:root{--primary-color:navy;--gray-300:#000;--gray-600:#000}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media print{.no-print{display:none!important}body{background:#fff!important;color:#000!important}.card{border:1px solid #000!important;box-shadow:none!important}}