body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}.login-container{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2a4a6b);display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-card{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;max-width:400px;padding:2.5rem;text-align:center;width:100%}.login-logo{align-items:center;display:flex;justify-content:center;margin:0 0 1rem}.login-logo-image{height:80px;object-fit:contain;width:auto}.login-header h2{color:#1e3a5f;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.login-header p{color:#7f8c8d;font-size:1rem;margin:0 0 2rem}.login-form{margin-bottom:2rem}.code-input-container{margin-bottom:1.5rem}.code-input{background-color:#f8f9fa;border:2px solid #ecf0f1;border-radius:8px;color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:.5rem;padding:1rem;text-align:center;transition:all .3s ease;width:100%}.code-input:focus{background-color:#fff;border-color:#7a9bb8;box-shadow:0 0 0 3px #7a9bb81a;outline:none}.code-input.error{background-color:#fff5f5;border-color:#e74c3c}.code-input::placeholder{color:#bdc3c7;letter-spacing:.5rem}.error-message{background-color:#fff5f5;border:1px solid #f8d7da;border-radius:6px;color:#e74c3c;font-size:.9rem;margin-bottom:1rem;padding:.5rem}.login-button{background:linear-gradient(135deg,#7a9bb8,#6789a5);border:none;border-radius:8px;box-shadow:0 4px 15px #7a9bb84d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem;transition:all .3s ease;width:100%}.login-button:hover:not(:disabled){background:linear-gradient(135deg,#6789a5,#7a9bb8);box-shadow:0 6px 20px #7a9bb866;transform:translateY(-2px)}.login-button:disabled{background:#bdc3c7;box-shadow:none;cursor:not-allowed;transform:none}.login-info{border-top:1px solid #ecf0f1;padding-top:1.5rem}.info-text{color:#7f8c8d;font-size:.85rem;line-height:1.5;margin:0}@media (max-width:480px){.login-card{margin:1rem;padding:2rem 1.5rem}.login-header h1{font-size:2rem}.login-header h2{font-size:1.3rem}.code-input{font-size:1.8rem;letter-spacing:.3rem}.login-logo-image{height:60px}}.login-button.loading:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;content:"";display:inline-block;height:16px;margin-left:8px;width:16px}.header{background-color:#a8c0df;box-shadow:0 1px 2px #0000001a;color:#fff;padding:.5rem 0}.header-content{justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 1rem}.header-content,.logo{align-items:center;display:flex}.logo{margin:0}.logo-image{height:32px;object-fit:contain;width:auto}.nav{align-items:center;display:flex;gap:1rem}.nav-title{color:#fff;font-size:.9rem;font-weight:500}.user-info{align-items:center;display:flex;gap:.8rem}.user-name{color:#fff;font-size:.85rem;font-weight:500}.logout-btn{background:#e74c3ccc;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;padding:.3rem .8rem;transition:background-color .3s ease}.logout-btn:hover{background:#e74c3c}@media (max-width:768px){.header-content,.nav{flex-direction:column;gap:.5rem}.nav{align-items:center}.user-info{flex-direction:column;gap:.3rem}.user-name{font-size:.8rem}.logout-btn{font-size:.7rem;padding:.25rem .6rem}.logo-image{height:28px}}.planning{background-color:#f8f9fa;min-height:100vh;padding:.5rem}.planning-header{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;margin-bottom:.8rem;padding:.8rem}.month-navigation{margin-bottom:.4rem;min-height:40px;position:relative;width:100%}.month-navigation,.nav-btn{align-items:center;display:flex;justify-content:center}.nav-btn{background:#7a9bb8;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.2rem;height:30px;position:absolute;top:50%;transform:translateY(-50%);width:30px}.nav-btn:first-child{left:0}.nav-btn:last-child{right:0}.nav-btn:hover{background:#6789a5}.planning-header h2{color:#1e3a5f;flex:1 1;font-size:1.3rem;margin:0;padding:0 40px;text-align:center}.planning-header p{color:#7f8c8d;font-size:.75rem;margin:0;text-align:center}.planning-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:.8rem;overflow-x:auto}.planning-table{border-collapse:collapse;font-size:.85rem;width:100%}.planning-table td,.planning-table th{border:1px solid #e0e0e0;height:35px;min-width:35px;text-align:center;vertical-align:middle}.employee-header{background-color:#1e3a5f;color:#fff;font-weight:700;left:0;max-width:150px;min-width:150px;padding:0 8px;position:-webkit-sticky;position:sticky;text-align:left;z-index:10}.day-header{background-color:#ecf0f1;color:#1e3a5f;font-weight:700;padding:4px}.day-header.clickable{transition:background-color .2s ease}.day-header.clickable:hover{background-color:#7a9bb81a}.day-header.hovered{text-decoration:underline}.day-header.adjacent-month,.shift-cell.adjacent-month,.summary-cell.adjacent-month{opacity:.5}.day-number{font-size:.9rem;font-weight:700}.day-name{font-size:.7rem;text-transform:uppercase}.count-header{background-color:#3498db;color:#fff;font-size:.9rem;font-weight:700;min-width:30px;text-align:center}.total-header{background-color:#1e3a5f;color:#fff;font-weight:700;min-width:60px;right:0;z-index:10}.employee-name,.total-header{position:-webkit-sticky;position:sticky}.employee-name{background-color:#ecf0f1;color:#1e3a5f;font-size:.8rem;font-weight:500;left:0;max-width:150px;min-width:150px;overflow:hidden;padding:0 8px;text-align:left;text-overflow:ellipsis;white-space:nowrap;z-index:5}.shift-cell{cursor:pointer;font-size:.9rem;font-weight:700;transition:all .2s ease;-webkit-user-select:none;user-select:none}.shift-cell.editable:hover{background-color:#f0f0f0!important}.shift-cell.non-editable{cursor:not-allowed;opacity:.6}.shift-cell.non-editable:hover{background-color:inherit;transform:none}.shift-cell.j{background-color:#fff3cd!important;color:#856404}.shift-cell.n{background-color:#d1ecf1!important;color:#0c5460}.shift-cell.c{background-color:#2c3e50!important;color:#fff}.shift-cell.f{background-color:wheat!important;color:#8b4513}.shift-cell.manager-only-locked{opacity:.8;position:relative}.shift-cell.manager-only-locked:hover{opacity:.9;transform:none!important}.shift-cell.manager-only-locked:after{content:"🔒";font-size:.6rem;opacity:.7;position:absolute;right:2px;top:2px}.shift-cell.x{background-color:#e2e3e5!important;color:#383d41}.count-cell{background-color:#f8f9fa;border-right:1px solid #dee2e6;color:#495057;font-size:.9rem;font-weight:500;text-align:center}.total-cell{background-color:#ecf0f1;color:#1e3a5f;font-weight:700;position:-webkit-sticky;position:sticky;right:0;z-index:5}.planning-legend{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;padding:.8rem}.planning-legend h3{color:#1e3a5f;font-size:1rem;margin-bottom:.5rem;text-align:center}.legend-items{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.legend-item{border-radius:3px;font-size:.75rem;font-weight:700;padding:.3rem .6rem}.legend-item.j{background-color:#fff3cd;color:#856404}.legend-item.n{background-color:#d1ecf1;color:#0c5460}.legend-item.c{background-color:#2c3e50;color:#fff}.legend-item.f{background-color:wheat;color:#8b4513}.legend-item.x{background-color:#e2e3e5;color:#383d41}.permission-note,.user-note{border-radius:4px;font-size:.8rem;margin-top:.8rem;padding:.5rem;text-align:center}.permission-note{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.user-note{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.current-user-row{border:2px solid #7a9bb8}.current-user-row .employee-name{font-weight:700}.summary-row{background-color:#f8f9fa;border-top:2px solid #dee2e6;font-weight:600}.summary-label{background-color:#6c757d!important;color:#fff;font-size:.8rem;font-weight:700;left:0;max-width:150px;min-width:150px;padding:8px;position:-webkit-sticky;position:sticky;text-align:center;z-index:5}.summary-cell{background-color:#f8f9fa!important;border:none}.summary-count-cell{background-color:#e9ecef!important;border-right:1px solid #dee2e6}.summary-count-cell,.summary-total{color:#495057;font-weight:700;text-align:center}.summary-total{background-color:#dee2e6!important;min-width:60px;position:-webkit-sticky;position:sticky;right:0;z-index:5}.current-user-indicator{color:#7a9bb8;font-size:.8rem}@media (max-width:768px){.planning{padding:.5rem}.planning-table{font-size:.75rem}.planning-table td,.planning-table th{height:30px;min-width:30px}.employee-name{font-size:.7rem;max-width:120px;min-width:120px}.employee-header{font-size:.8rem;max-width:120px;min-width:120px}.legend-items{align-items:center;flex-direction:column}.legend-item{max-width:250px;text-align:center;width:100%}}.day-header.weekend{background-color:#ffe6e6!important;color:#c0392b}.shift-cell.weekend:not(.j):not(.n):not(.c):not(.x){background-color:#fff5f5}.day-header.today{background-color:#7a9bb8!important}.shift-cell.today-cell,.summary-cell.today-cell{border-left:2px solid #7a9bb8;border-right:2px solid #7a9bb8}.loading-container{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;justify-content:center;margin-bottom:1rem;padding:4rem 2rem}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ecf0f1;border-radius:50%;border-top-color:#7a9bb8;height:40px;margin-bottom:1rem;width:40px}.loading-container p{color:#7f8c8d;font-size:1rem;margin:0}.error-banner{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;font-weight:500;margin-bottom:1rem;padding:1rem;text-align:center}.lock-indicator{font-size:.7rem;margin-left:4px;opacity:.8}.shift-cell.day-locked{position:relative}.day-lock-indicator{font-size:.6rem;opacity:.6;position:absolute;right:1px;top:1px}.employee-role{color:#666;font-size:.7rem;font-weight:400;margin-left:6px}.employee-code{color:#888;font-family:Courier New,monospace;font-size:.75rem;font-weight:300}.App{background-color:#f8f9fa;display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;padding-bottom:.5rem;padding-top:.5rem}.app-loading{align-items:center;background-color:#f8f9fa;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:100vh}.app-loading .loading-spinner{animation:spin 1s linear infinite;border:4px solid #ecf0f1;border-radius:50%;border-top-color:#7a9bb8;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.app-loading p{color:#7f8c8d;font-size:1rem;margin:0}
/*# sourceMappingURL=main.60e5630c.css.map*/