:root{--viafon-primary: #4C4034;--viafon-secondary: #766B5D;--viafon-accent: #EE9B2D;--viafon-accent-light: #F4AA41;--accent-color: #F5812C;--accent-light: #FF9D5C;--accent-dark: #D16117;--primary-color: #4C4034;--primary-light: #766D62;--primary-dark: #2E2820;--text-primary: #333333;--text-secondary: #666666;--text-tertiary: #999999;--text-light: #FFFFFF;--background-light: #F8F8F8;--background-white: #FFFFFF;--background-dark: #333333;--success-color: #4CAF50;--warning-color: #FFC107;--error-color: #F44336;--info-color: #2196F3;--border-color: #E0E0E0;--border-light: #F0F0F0;--border-dark: #CCCCCC;--shadow-color: rgba(0, 0, 0, .1);--overlay-color: rgba(0, 0, 0, .5);--workload-low: #4CAF50;--workload-medium: #FFC107;--workload-high: #FF9800;--workload-overload: #F44336;--color-primary: var(--viafon-accent);--color-primary-dark: #D87F00;--color-primary-rgb: 238, 155, 45;--color-background-light: var(--background-light);--color-background-dark: #F5F5F5;--color-text: #333333;--color-text-dark: #333333;--color-text-light: #777777;--color-border: var(--border-color);--color-border-light: #E0E0E0;--color-border-dark: #CCCCCC;--color-hover: rgba(238, 155, 45, .05);--color-selected: rgba(238, 155, 45, .1);--color-danger: #F44336;--color-danger-dark: #D32F2F}body.dark-mode{--background-light: #2C2C2C;--background-white: #383838;--text-primary: #F0F0F0;--text-secondary: #BBBBBB;--text-tertiary: #999999;--text-light: #FFFFFF;--border-color: #555555;--border-light: #444444;--border-dark: #666666;--shadow-color: rgba(0, 0, 0, .3);background-color:var(--background-light);color:var(--text-primary)}body.dark-mode .app-container,body.dark-mode .main-content{background-color:var(--background-light);color:var(--text-light)}body.dark-mode .sidebar{background-color:#1a1a1a;border-right:1px solid #444444}body.dark-mode .sidebar-header{border-bottom-color:#444}body.dark-mode .sidebar-footer{border-top-color:#444}body.dark-mode .sidebar-nav a{color:var(--text-light)}body.dark-mode .sidebar-nav a:hover{background-color:#333}body.dark-mode .sidebar-nav a.active{background-color:#444;border-left-color:var(--viafon-accent)}body.dark-mode .card,body.dark-mode .profile-card,body.dark-mode .settings-card,body.dark-mode .stat-card,body.dark-mode .dashboard-card{background-color:var(--background-white);border-color:var(--border-color);box-shadow:0 4px 8px #0003}body.dark-mode .welcome-section{background-color:#333;border-color:#444}body.dark-mode .welcome-section h1{color:var(--text-light)}body.dark-mode .welcome-section p{color:var(--text-secondary)}body.dark-mode .stat-card{background-color:var(--background-white)}body.dark-mode .stat-card h2{color:var(--text-light)}body.dark-mode .stat-value{color:var(--viafon-accent)}body.dark-mode .stat-label{color:var(--text-secondary)}body.dark-mode .view-details-button{background-color:transparent;color:var(--viafon-accent);border:1px solid var(--viafon-accent)}body.dark-mode .view-details-button:hover{background-color:var(--viafon-accent);color:var(--text-light)}body.dark-mode input,body.dark-mode select,body.dark-mode textarea{background-color:#444;border-color:#555;color:var(--text-light)}body.dark-mode input:focus,body.dark-mode select:focus,body.dark-mode textarea:focus{border-color:var(--viafon-accent);box-shadow:0 0 0 1px var(--viafon-accent)}body.dark-mode .secondary-button{background-color:transparent;color:var(--text-light);border-color:var(--border-dark)}body.dark-mode .secondary-button:hover{background-color:#444}body.dark-mode table{border-color:#444}body.dark-mode th{background-color:#333;color:var(--text-light)}body.dark-mode tr:nth-child(2n){background-color:#383838}body.dark-mode tr:hover{background-color:#404040}body.dark-mode .user-profile-container{background-color:var(--background-light)}body.dark-mode .preference-item{border-bottom-color:var(--border-color)}body.dark-mode h1,body.dark-mode h2,body.dark-mode h3,body.dark-mode h4,body.dark-mode h5,body.dark-mode h6{color:var(--text-light)}body.dark-mode .toggle-switch .toggle-slider{background-color:#666}body.dark-mode .toggle-switch input:checked+.toggle-slider{background-color:var(--viafon-accent)}body.dark-mode .settings-container{background-color:var(--background-light)}body.dark-mode .settings-section{border-bottom-color:var(--border-color)}body.dark-mode button{background-color:var(--viafon-accent);color:var(--text-light)}body.dark-mode button:hover{background-color:var(--viafon-accent-light)}body.dark-mode .employee-list-container,body.dark-mode .employee-grid{background-color:var(--background-light)}body.dark-mode .employee-card,body.dark-mode .employee-detail-view,body.dark-mode .employee-filter-bar{background-color:var(--background-white);border-color:var(--border-color)}body.dark-mode .project-list-container,body.dark-mode .project-grid{background-color:var(--background-light)}body.dark-mode .project-card,body.dark-mode .project-detail-view{background-color:var(--background-white);border-color:var(--border-color)}body.dark-mode .project-team-member{background-color:#444;border-color:#555}body.dark-mode .shift-planner-container{background-color:var(--background-light)}body.dark-mode .shift-calendar{background-color:var(--background-white);border-color:var(--border-color)}body.dark-mode .shift-day{background-color:#333;border-color:#444}body.dark-mode .shift-cell{background-color:var(--background-white);border-color:#444}body.dark-mode .shift-cell:hover{background-color:#444}body.dark-mode .shift-cell.active{background-color:#ee9b2d33}body.dark-mode .weekly-schedule-container{background-color:var(--background-light)}body.dark-mode .schedule-day{background-color:var(--background-white);border-color:var(--border-color)}body.dark-mode .schedule-hour{border-color:#444}body.dark-mode .schedule-appointment{background-color:#ee9b2d33;border-color:var(--viafon-accent)}body.dark-mode .modal-backdrop{background-color:#000000b3}body.dark-mode .modal-content{background-color:var(--background-white);border-color:var(--border-color);box-shadow:0 5px 15px #0000004d}body.dark-mode .modal-header{border-bottom-color:var(--border-color)}body.dark-mode .modal-footer{border-top-color:var(--border-color)}body.dark-mode .tooltip{background-color:var(--background-white);border-color:var(--border-color);color:var(--text-light);box-shadow:0 2px 5px #0003}body.dark-mode .dropdown-menu{background-color:var(--background-white);border-color:var(--border-color);box-shadow:0 3px 6px #0003}body.dark-mode .dropdown-item{color:var(--text-light)}body.dark-mode .dropdown-item:hover{background-color:#444}body.dark-mode .tab-list{border-bottom-color:var(--border-color)}body.dark-mode .tab{background-color:transparent;color:var(--text-secondary)}body.dark-mode .tab.active{background-color:var(--background-white);color:var(--viafon-accent);border-color:var(--border-color);border-bottom-color:var(--background-white)}body.dark-mode .tab-content{background-color:var(--background-white);border-color:var(--border-color)}*{box-sizing:border-box;margin:0;padding:0;border:0;outline:0}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5;color:var(--text-dark);background-color:var(--background-light);overflow:hidden}button{font-family:inherit;font-size:inherit;cursor:pointer;background:none}a{color:var(--accent-color);text-decoration:none}a:hover{text-decoration:underline}#root{height:100%;width:100%}.container{max-width:1200px;margin:0 auto;padding:0 20px}h1,h2,h3,h4,h5,h6{font-weight:600}.fade-in{animation:fadeIn .5s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.login-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.floating-shapes{position:relative;width:100%;height:100%}.shape{position:absolute;border-radius:50%;background:#ffffff1a;animation:float 6s ease-in-out infinite}.shape-1{width:80px;height:80px;top:20%;left:10%;animation-delay:0s}.shape-2{width:120px;height:120px;top:60%;right:10%;animation-delay:2s}.shape-3{width:60px;height:60px;top:80%;left:20%;animation-delay:4s}.shape-4{width:100px;height:100px;top:10%;right:30%;animation-delay:1s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(180deg)}}.login-content{display:flex;width:100%;max-width:1200px;height:600px;background:#fffffff2;border-radius:20px;box-shadow:0 20px 40px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:2;overflow:hidden}.login-welcome{flex:1;background:linear-gradient(135deg,#1e70bf,#2c3e50);color:#fff;padding:40px;display:flex;flex-direction:column;justify-content:space-between;position:relative}.welcome-content{height:100%;display:flex;flex-direction:column;justify-content:space-between}.logo-section{text-align:center;margin-bottom:30px}.logo-container{display:inline-flex;align-items:center;background:#ffffff1a;padding:15px 25px;border-radius:12px;margin-bottom:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.logo-v{font-size:42px;font-weight:700;color:gold;margin-right:5px}.logo-text{font-size:32px;font-weight:700;color:#fff}.welcome-title{font-size:28px;font-weight:600;margin:0 0 10px;text-align:center}.welcome-subtitle{font-size:16px;opacity:.9;text-align:center;margin:0}.time-section{text-align:center;margin:30px 0}.current-time{font-size:48px;font-weight:300;margin-bottom:10px;font-family:Courier New,monospace}.current-date{font-size:16px;opacity:.8;text-transform:capitalize}.features-section{flex:1;margin:20px 0}.features-section h3{font-size:18px;margin-bottom:15px;text-align:center}.features-list{list-style:none;padding:0;margin:0}.features-list li{padding:8px 0;font-size:14px;opacity:.9;display:flex;align-items:center}.features-list li:before{content:"✓";color:#4caf50;font-weight:700;margin-right:10px;font-size:16px}.status-section{text-align:center;margin-top:auto}.status-indicator{display:inline-flex;align-items:center;background:#4caf5033;padding:8px 16px;border-radius:20px;border:1px solid rgba(76,175,80,.3)}.status-dot{width:8px;height:8px;border-radius:50%;margin-right:8px}.status-dot.online{background:#4caf50;box-shadow:0 0 10px #4caf5080;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.status-text{font-size:14px;font-weight:500}.login-form-section{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:#fff}.login-card{width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:30px}.login-header h2{font-size:24px;font-weight:600;color:#333;margin:0 0 8px}.login-header p{font-size:14px;color:#666;margin:0}.login-form{width:100%}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:#333;margin-bottom:8px}.input-wrapper{position:relative;display:flex;align-items:center}.login-input{width:100%;padding:12px 45px 12px 15px;border:2px solid #e1e5e9;border-radius:8px;font-size:14px;transition:all .3s ease;background:#f8f9fa}.login-input:focus{outline:none;border-color:#1e70bf;background:#fff;box-shadow:0 0 0 3px #1e70bf1a}.login-input:disabled{background:#f5f5f5;cursor:not-allowed}.input-icon{position:absolute;right:15px;font-size:16px;color:#666;pointer-events:none}.password-toggle{position:absolute;right:45px;background:none;border:none;font-size:16px;cursor:pointer;padding:0;color:#666;transition:color .3s ease}.password-toggle:hover{color:#1e70bf}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.error-message{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px;display:flex;align-items:center;border:1px solid #ffcdd2}.error-icon{margin-right:8px;font-size:16px}.login-button{width:100%;padding:14px 20px;background:linear-gradient(135deg,#1e70bf,#2c3e50);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px;position:relative;overflow:hidden}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #1e70bf4d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.button-icon{font-size:16px}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-right:8px}.login-footer{margin-top:30px;text-align:center}.security-info{display:flex;align-items:center;justify-content:center;gap:8px;font-size:12px;color:#666;margin-bottom:10px}.security-icon{font-size:14px}.copyright{font-size:12px;color:#999;margin:0}@media (max-width: 768px){.login-container{padding:0;min-height:100vh;height:100vh}.login-content{flex-direction:column;height:100vh;margin:0;max-width:none;border-radius:0;width:100%}.login-welcome{padding:20px;min-height:40vh}.login-form-section{padding:20px;flex:1;min-height:60vh}.current-time{font-size:32px}.welcome-title{font-size:22px}.logo-v{font-size:32px}.logo-text{font-size:24px}.features-section{display:none}}@media (max-width: 480px){.login-container{padding:0;min-height:100vh;height:100vh}.login-content{margin:0;height:100vh;border-radius:0}.login-welcome{padding:15px;min-height:35vh}.login-form-section{padding:15px;min-height:65vh}.current-time{font-size:24px}.welcome-title{font-size:18px}.logo-v{font-size:28px}.logo-text{font-size:20px}.features-list li{font-size:13px}.welcome-subtitle{font-size:12px}}@media (max-width: 768px) and (orientation: landscape){.login-content{flex-direction:row;height:100vh}.login-welcome{flex:.4;padding:15px}.login-form-section{flex:.6;padding:15px}.features-section{display:block}.features-list li{font-size:11px;margin-bottom:3px}.current-time{font-size:20px}.welcome-title{font-size:16px}}.project-management{padding:24px;max-width:1400px;margin:0 auto;background:#f8f9fa;min-height:100vh}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding:24px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.header-content h2{margin:0 0 8px;color:#2c3e50;font-size:28px;font-weight:600}.header-content p{margin:0;color:#7f8c8d;font-size:16px}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;gap:20px}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}.project-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease,box-shadow .2s ease;overflow:hidden}.project-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.project-card-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 16px;border-bottom:1px solid #e9ecef}.project-card-header h3{margin:0;color:#2c3e50;font-size:18px;font-weight:600;flex:1}.project-actions{display:flex;gap:8px}.btn-icon{background:none;border:none;padding:8px;border-radius:6px;cursor:pointer;font-size:14px;transition:background .2s ease}.btn-icon:hover{background:#f8f9fa}.btn-icon.edit:hover{background:#e3f2fd}.btn-icon.delete:hover{background:#ffebee}.project-card-body{padding:20px}.project-description{color:#6c757d;font-size:14px;line-height:1.5;margin:0 0 16px}.project-info{display:flex;flex-direction:column;gap:12px}.info-item{display:flex;justify-content:space-between;align-items:center}.info-item label{font-weight:500;color:#495057;font-size:14px}.info-item span{color:#6c757d;font-size:14px}.status-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.status-badge.completed{background:#cce7ff;color:#004085;border:1px solid #b3d7ff}.status-badge.cancelled{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.status-badge.inactive{background:#f8f9fa;color:#6c757d;border:1px solid #dee2e6}.empty-state{grid-column:1 / -1;text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.empty-state h3{margin:0 0 12px;color:#2c3e50;font-size:24px}.empty-state p{margin:0 0 24px;color:#6c757d;font-size:16px}.btn{padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px}.btn-primary{background:#ee9b2d;color:#fff}.btn-primary:hover:not(:disabled){background:#d68910;transform:translateY(-1px)}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn:disabled{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-height:90vh;overflow-y:auto;width:100%;max-width:600px}.project-form-modal{max-width:700px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e9ecef}.modal-header h3{margin:0;color:#2c3e50;font-size:20px;font-weight:600}.btn-close{background:none;border:none;font-size:20px;cursor:pointer;padding:4px;border-radius:4px;color:#6c757d}.btn-close:hover{background:#f8f9fa;color:#495057}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:1px solid #e9ecef}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-weight:500;color:#495057;font-size:14px}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#ee9b2d;box-shadow:0 0 0 3px #ee9b2d1a}.form-group textarea{resize:vertical;min-height:80px}.error-list{background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;padding:12px;margin-bottom:20px}.error-item{color:#721c24;font-size:14px;margin:4px 0}@media (max-width: 768px){.project-management{padding:16px}.project-header{flex-direction:column;gap:16px;align-items:stretch;text-align:center}.project-grid{grid-template-columns:1fr;gap:16px}.form-grid{grid-template-columns:1fr}.modal{margin:10px;max-height:calc(100vh - 20px)}.modal-header,.modal-body,.modal-footer{padding:16px}}.weekdays-selector{display:flex;gap:12px;flex-wrap:wrap;margin:8px 0 12px}.weekday-item{display:flex;flex-direction:column;align-items:center;gap:4px}.weekday-item input[type=checkbox]{width:16px;height:16px;accent-color:#ee9b2d;cursor:pointer}.weekday-label{font-size:12px;font-weight:500;color:#7f8c8d;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease;min-width:24px;text-align:center}.weekday-item input[type=checkbox]:checked+.weekday-label{background:#ee9b2d;color:#fff;font-weight:600}.weekday-label:hover{background:#f8f9fa}.weekday-item input[type=checkbox]:checked+.weekday-label:hover{background:#d68910}.help-text{color:#95a5a6;font-size:12px;line-height:1.4;margin-top:4px;display:block}.day-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.day-badge.active{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.day-badge.inactive{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;opacity:.7}.form-group.full-width{grid-column:1 / -1}.compact-schedules{display:flex;flex-direction:column;gap:8px;margin:8px 0 12px;padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.compact-day-row{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid #dee2e6;min-height:44px}.day-checkbox{display:flex;align-items:center;gap:10px;min-width:100px}.day-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:#ee9b2d;cursor:pointer}.compact-day-name{font-weight:600;color:#2c3e50;font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none}.compact-times{display:flex;align-items:center;gap:8px}.compact-time-input{border:1px solid #ced4da;border-radius:4px;padding:6px 8px;font-size:13px;width:70px;background:#fff;font-weight:500}.compact-time-input:focus{outline:none;border-color:#ee9b2d;box-shadow:0 0 0 2px #ee9b2d33}.compact-separator{color:#7f8c8d;font-size:14px;font-weight:600;margin:0 4px}.compact-closed{color:#95a5a6;font-style:italic;font-size:13px;padding:6px 12px}.individual-schedules{display:flex;flex-direction:column;gap:12px;margin:8px 0 12px}.day-schedule{background:#f8f9fa;border-radius:8px;padding:12px;border:1px solid #e9ecef}.day-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.day-header input[type=checkbox]{width:16px;height:16px;accent-color:#ee9b2d;cursor:pointer}.day-name{font-weight:600;color:#2c3e50;font-size:14px;cursor:pointer;min-width:80px}.day-times{display:flex;align-items:center;gap:12px;margin-left:26px;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid #dee2e6}.time-input{border:1px solid #ced4da;border-radius:4px;padding:6px 8px;font-size:13px;width:80px;background:#fff}.time-input:focus{outline:none;border-color:#ee9b2d;box-shadow:0 0 0 2px #ee9b2d33}.time-separator{color:#7f8c8d;font-size:12px;font-weight:500}.weekly-schedule-display{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.day-schedule-item{display:flex;flex-direction:column;align-items:center;padding:6px 4px;border-radius:8px;border:1px solid #e9ecef;background:#f8f9fa;min-width:65px;text-align:center;transition:all .2s ease}.day-schedule-item.working{background:#d4edda;border-color:#c3e6cb;color:#155724}.day-schedule-item.closed{background:#f8d7da;border-color:#f5c6cb;color:#721c24;opacity:.7}.day-schedule-item.today{border:2px solid #ee9b2d;box-shadow:0 0 8px #ee9b2d4d;transform:scale(1.05);font-weight:700}.day-schedule-item.today.working{background:#fff3cd;border-color:#ee9b2d;color:#856404}.day-schedule-item.today.closed{background:#f8d7da;border-color:#ee9b2d;color:#721c24}.day-name{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.day-time{font-size:9px;font-weight:500;line-height:1.2}.working-days-display{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.day-badge{font-size:10px;font-weight:600;padding:3px 6px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px;border:1px solid transparent}.day-badge.active{background:#d4edda;color:#155724;border-color:#c3e6cb}.day-badge.inactive{background:#f8d7da;color:#721c24;border-color:#f5c6cb;opacity:.7}.day-badge.individual{background:#fff3cd;color:#856404;border-color:#ffeeba;font-size:9px;padding:2px 4px;display:flex;flex-direction:column;align-items:center;line-height:1.1}.time-hint{font-size:7px;font-weight:400;margin-top:1px;opacity:.8}@media (max-width: 768px){.weekdays-selector{gap:8px}.weekday-label{font-size:11px;padding:3px 6px}.working-days-display{gap:2px}.day-badge{font-size:9px;padding:1px 4px}.individual-schedules{gap:8px}.day-schedule{padding:8px}.day-times{flex-direction:column;gap:8px;align-items:stretch;margin-left:20px}.time-input{width:100%}.compact-day-row{flex-direction:column;align-items:stretch;gap:8px;padding:10px}.day-checkbox{min-width:auto;justify-content:center}.compact-times{justify-content:center}.compact-time-input{width:60px}}.employee-management{padding:2rem;max-width:1400px;margin:0 auto}.employee-header{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.header-info h1{font-size:1.75rem;font-weight:600;color:#2c3e50;margin:0 0 .5rem;display:flex;align-items:center;gap:.5rem}.header-info h1 i{color:#3498db}.header-info p{color:#7f8c8d;margin:0;font-size:.95rem}.create-btn{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;white-space:nowrap}.create-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #3498db4d}.employee-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease}.stat-card:hover{transform:translateY(-2px)}.stat-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#ecf0f1;color:#7f8c8d;font-size:1.5rem}.stat-icon.active{background:#d5f4e6;color:#27ae60}.stat-icon.contract{background:#fef9e7;color:#f39c12}.stat-content h3{font-size:1.75rem;font-weight:700;color:#2c3e50;margin:0}.stat-content p{color:#7f8c8d;margin:0;font-size:.9rem}.success-message{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff;padding:1rem 1.5rem;border-radius:8px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 4px 12px #2ecc714d;animation:slideInDown .3s ease-out}.success-message i{font-size:1.25rem}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.employee-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:.75rem}.employee-card{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;border:1px solid transparent}.employee-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026;border-color:#3498db}.employee-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #ecf0f1}.employee-info h3{font-size:1.1rem;font-weight:600;color:#2c3e50;margin:0 0 .25rem}.employee-position{color:#3498db;font-weight:500;margin:0 0 .25rem;font-size:.95rem}.employee-department{color:#7f8c8d;margin:0;font-size:.9rem}.employee-actions{display:flex;gap:.5rem}.action-btn{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:.9rem}.edit-btn{background:#f8f9fa;color:#3498db}.edit-btn:hover{background:#3498db;color:#fff}.delete-btn{background:#f8f9fa;color:#e74c3c}.delete-btn:hover{background:#e74c3c;color:#fff}.employee-details{display:grid;gap:.5rem}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0}.detail-label{font-weight:500;color:#7f8c8d;font-size:.8rem}.detail-value{color:#2c3e50;font-weight:500;font-size:.8rem}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status-badge.aktiv{background:#d5f4e6;color:#27ae60}.status-badge.inaktiv{background:#f8f9fa;color:#7f8c8d}.status-badge.urlaub{background:#fef9e7;color:#f39c12}.status-badge.beendet{background:#fdf2f2;color:#e74c3c}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.empty-state i{font-size:4rem;color:#bdc3c7;margin-bottom:1rem}.empty-state h3{color:#2c3e50;margin-bottom:.5rem}.empty-state p{color:#7f8c8d;margin-bottom:2rem}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.loading-spinner i{font-size:2rem;color:#3498db;margin-bottom:1rem}.loading-spinner p{color:#7f8c8d;margin:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #ecf0f1}.modal-header h2{font-size:1.5rem;font-weight:600;color:#2c3e50;margin:0;display:flex;align-items:center;gap:.5rem}.modal-header h2 i{color:#3498db}.close-btn{width:36px;height:36px;border:none;background:#f8f9fa;color:#7f8c8d;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn:hover{background:#e9ecef;color:#495057}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #ecf0f1}.employee-form{display:grid;gap:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:500;color:#2c3e50;margin-bottom:.5rem;font-size:.9rem}.form-group input,.form-group select{padding:.75rem;border:2px solid #e9ecef;border-radius:8px;font-size:.95rem;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-group input::placeholder{color:#adb5bd}.error-list{background:#fff5f5;border:1px solid #feb2b2;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.error-item{display:flex;align-items:center;gap:.5rem;color:#e53e3e;font-size:.9rem;margin-bottom:.5rem}.error-item:last-child{margin-bottom:0}.error-item i{font-size:.8rem}.cancel-btn{background:#f8f9fa;color:#6c757d;border:1px solid #dee2e6;border-radius:8px;padding:.75rem 1.5rem;font-size:.95rem;cursor:pointer;transition:all .2s ease}.cancel-btn:hover{background:#e9ecef;color:#495057}.save-btn{background:linear-gradient(135deg,#27ae60,#229954);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease}.save-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 25px #27ae604d}.save-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.form-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #ecf0f1}.form-section h3{font-size:1.1rem;font-weight:600;color:#2c3e50;margin:0 0 .5rem}.form-help{color:#7f8c8d;font-size:.9rem;margin:0 0 1.5rem}.project-assignments{display:flex;flex-direction:column;gap:1rem}.assignment-row{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:1rem;align-items:end;padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.assignment-project,.assignment-percentage,.assignment-hours{display:flex;flex-direction:column}.assignment-project label,.assignment-percentage label,.assignment-hours label{font-weight:500;color:#2c3e50;margin-bottom:.5rem;font-size:.85rem}.assignment-project select,.assignment-percentage input,.assignment-hours input{padding:.6rem;border:1px solid #dee2e6;border-radius:6px;font-size:.9rem}.remove-assignment-btn{width:36px;height:36px;border:none;background:#e74c3c;color:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease;align-self:end}.remove-assignment-btn:hover{background:#c0392b}.add-assignment-btn{background:#3498db;color:#fff;border:none;border-radius:8px;padding:.75rem 1rem;font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background .2s ease;margin-top:.5rem}.add-assignment-btn:hover{background:#2980b9}.assignment-summary{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:1rem;margin-top:1rem}.summary-item{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.9rem}.summary-item:last-child{margin-bottom:0;font-weight:600;color:#2c3e50;border-top:1px solid #ecf0f1;padding-top:.5rem}.employee-projects{margin-top:1rem;padding-top:1rem;border-top:1px solid #ecf0f1}.employee-projects h4{font-size:.9rem;font-weight:600;color:#2c3e50;margin:0 0 .75rem}.project-assignment-list{display:flex;flex-direction:column;gap:.5rem}.project-assignment-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#f8f9fa;border-radius:6px;font-size:.85rem}.project-name{font-weight:500;color:#2c3e50}.project-allocation{color:#3498db;font-weight:500}@media (max-width: 768px){.employee-management{padding:1rem}.header-content{flex-direction:column;align-items:stretch}.create-btn{justify-content:center}.employee-grid{grid-template-columns:1fr;gap:.75rem}.employee-card-header{flex-direction:column;gap:1rem;align-items:stretch}.employee-actions{justify-content:flex-end}.form-row{grid-template-columns:1fr}.modal-footer{flex-direction:column}.detail-item{flex-direction:column;align-items:flex-start;gap:.25rem}.assignment-row{grid-template-columns:1fr;gap:1rem}.assignment-summary{margin-top:1rem}}*{box-sizing:border-box}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5}.app-layout{display:flex;height:100vh;width:100vw;background:#f5f5f5;overflow:hidden}.sidebar{width:280px;min-width:280px;background:linear-gradient(180deg,#2c3e50,#34495e);color:#fff;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000001a;height:100vh;position:relative;flex-shrink:0}.sidebar-header{padding:20px;border-bottom:1px solid #34495e;text-align:center}.sidebar-header h2{margin:0;color:#ee9b2d;font-size:24px;font-weight:700}.sidebar-header p{margin:5px 0 0;color:#bdc3c7;font-size:12px}.user-info{padding:15px 20px;border-bottom:1px solid #34495e;background:#0000001a}.user-info p{margin:0;font-size:14px}.user-info p:first-child{font-weight:700;color:#ee9b2d}.sidebar-nav{flex:1;padding:20px 0}.nav-item{padding:12px 20px;cursor:pointer;display:flex;align-items:center;gap:12px;transition:all .3s ease;text-decoration:none;color:#fff;font-size:14px;font-weight:500}.nav-item:hover{background:#ee9b2d1a}.nav-item.active{background:#ee9b2d;border-right:3px solid #d68910}.nav-item.disabled{opacity:.5;cursor:not-allowed}.nav-item i{width:16px;text-align:center}.sidebar-footer{padding:20px;border-top:1px solid #34495e}.logout-btn{width:100%;padding:10px;background:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .3s ease}.logout-btn:hover{background:#c0392b}.main-content{flex:1;overflow-y:auto;padding:0;height:100vh;width:calc(100vw - 280px);background:#f8f9fa}.dashboard{padding:40px 50px;width:100%;height:100%;overflow-y:auto;background:#f8f9fa}.dashboard-header{text-align:center;margin-bottom:30px}.dashboard-header h1{margin:0;color:#2c3e50;font-size:32px;font-weight:700}.dashboard-header p{margin:10px 0 0;color:#7f8c8d;font-size:16px}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:50vh;gap:20px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #ee9b2d;border-radius:50%;animation:spin 1s linear infinite}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px}.kpi-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 10px #0000001a;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #00000026}.kpi-card h3{margin:0 0 10px;color:#7f8c8d;font-size:14px;font-weight:400}.kpi-value{font-size:28px;font-weight:700;color:#2c3e50;margin-bottom:5px}.kpi-label{color:#95a5a6;font-size:12px}.data-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px;margin-bottom:40px}.data-section{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.data-section h2{margin:0;padding:20px;background:#f8f9fa;color:#2c3e50;font-size:18px;border-bottom:1px solid #e9ecef}.data-table{max-height:300px;overflow-y:auto}.data-row{padding:15px 20px;border-bottom:1px solid #f1f2f6;display:flex;flex-direction:column;gap:5px;transition:background .3s ease}.data-row:hover{background:#f8f9fa}.data-row:last-child{border-bottom:none}.data-row strong{color:#2c3e50;font-size:14px}.data-row span{color:#7f8c8d;font-size:12px}.status-badge{padding:2px 8px;border-radius:12px;font-size:10px;font-weight:700;text-transform:uppercase}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.shift-type{padding:2px 8px;border-radius:12px;font-size:10px;font-weight:700;text-transform:uppercase}.shift-type.early{background:#d1ecf1;color:#0c5460}.shift-type.late{background:#fff3cd;color:#856404}.shift-type.night{background:#d1ecf1;color:#0c5460}.shift-type.weekend{background:#f8d7da;color:#721c24}.status-info{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 10px #0000001a;border-left:4px solid #ee9b2d}.status-info h3{margin:0 0 15px;color:#2c3e50;font-size:18px}.status-info p{margin:8px 0;font-size:14px;color:#7f8c8d}.status-info p strong{color:#2c3e50}.api-status{background:#fff;padding:25px;border-radius:12px;box-shadow:0 2px 15px #0000001a;margin-bottom:30px;border-left:4px solid #ee9b2d}.api-status h3{margin:0 0 15px;color:#2c3e50;font-size:18px;font-weight:600}.api-status p{margin:8px 0;font-size:14px;color:#7f8c8d}.quick-actions{background:#fff;padding:25px;border-radius:12px;box-shadow:0 2px 15px #0000001a;margin-bottom:30px}.quick-actions h3{margin:0 0 20px;color:#2c3e50;font-size:18px;font-weight:600}.action-buttons{display:flex;gap:15px;flex-wrap:wrap}.action-btn{padding:12px 24px;background:#ee9b2d;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:all .3s ease;border:2px solid transparent}.action-btn:hover:not(:disabled){background:#d68910;transform:translateY(-1px);box-shadow:0 4px 12px #ee9b2d4d}.action-btn:disabled{background:#bdc3c7;cursor:not-allowed;opacity:.6}.data-preview{background:#fff;padding:25px;border-radius:12px;box-shadow:0 2px 15px #0000001a}.data-preview h3{margin:0 0 20px;color:#2c3e50;font-size:18px;font-weight:600}.preview-section{margin-bottom:20px}.preview-section h4{margin:0 0 10px;color:#7f8c8d;font-size:14px;font-weight:500}.preview-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f1f2f6}.preview-item:last-child{border-bottom:none}.preview-item strong{color:#2c3e50;font-size:14px}.preview-item span{color:#7f8c8d;font-size:12px}.sync-status{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;border:1px solid transparent;transition:all .3s ease}.sync-status.loading{background:#f8f9fa;border-color:#dee2e6;color:#6c757d}.sync-status.connected{background:#d4edda;border-color:#c3e6cb;color:#155724}.sync-status.local{background:#fff3cd;border-color:#ffeaa7;color:#856404}.sync-icon{font-size:1rem;flex-shrink:0}.sync-text{font-weight:500;flex-shrink:0}.sync-detail{font-size:.75rem;opacity:.8;white-space:nowrap}.last-sync{font-size:.7rem;opacity:.7;margin-left:auto}.sync-actions{display:flex;gap:.25rem;margin-left:.5rem}.export-btn,.import-btn{padding:.25rem .5rem;border:none;border-radius:4px;background:#0000001a;color:inherit;font-size:.7rem;cursor:pointer;transition:background .2s ease;text-decoration:none;display:inline-block}.export-btn:hover,.import-btn:hover{background:#0003}.import-btn{position:relative;cursor:pointer}@media (max-width: 768px){.sync-status{flex-direction:column;align-items:flex-start;gap:.25rem;padding:.75rem}.sync-detail{white-space:normal}.sync-actions{margin-left:0;margin-top:.25rem}.last-sync{margin-left:0;align-self:flex-end}}.sync-status.compact{padding:.25rem .5rem;font-size:.75rem;border-radius:4px}.sync-status.compact .sync-detail,.sync-status.compact .sync-actions,.sync-status.compact .last-sync{display:none}.sync-status.loading .sync-icon{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
