*{margin:0;padding:0}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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{background-color:#f5f5f5;min-height:100vh}*{box-sizing:border-box}.App.fullscreen-active nav.navbar,:-moz-full-screen nav.navbar,:-ms-fullscreen nav.navbar,:-webkit-full-screen nav.navbar,:fullscreen nav.navbar,body.fullscreen-active nav.navbar,html.fullscreen-active nav.navbar{display:none!important;height:0!important;margin:0!important;opacity:0!important;overflow:hidden!important;padding:0!important;visibility:hidden!important}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{background:#fff;border-radius:10px;box-shadow:0 10px 40px #0003;max-width:400px;padding:40px;width:100%}.login-box h2{color:#333;font-size:28px;margin-bottom:30px;text-align:center}.form-group input{border:2px solid #e0e0e0;border-radius:5px;font-size:16px;padding:12px;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.error-message{background-color:#fee;border-radius:5px;color:#c33;font-size:14px;margin-bottom:15px;padding:10px}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:transform .2s,box-shadow .2s;width:100%}.login-button:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.login-button:active{transform:translateY(0)}.login-hint{background:#f8f9fa;border-radius:5px;color:#666;font-size:13px;margin-top:20px;padding:15px;text-align:left}.login-hint p{font-weight:600;margin:0 0 10px}.example-accounts{margin:10px 0}.account-item{color:#555;font-size:12px;padding:5px 0}.account-item strong{color:#333;margin-right:5px}.demo-note{color:#888;font-size:11px;font-style:italic;margin-top:10px!important}@media (max-width:768px){.login-container{padding:15px}.login-box{padding:30px 25px}.login-box h2{font-size:24px;margin-bottom:25px}.form-group input,.login-button{font-size:15px;padding:11px}}@media (max-width:480px){.login-container{padding:10px}.login-box{padding:25px 20px}.login-box h2{font-size:22px;margin-bottom:20px}.form-group{margin-bottom:15px}.form-group label{font-size:14px}.form-group input,.login-button{font-size:14px;padding:10px}.login-hint{font-size:12px;padding:12px}}.navbar{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;padding:0;transition:opacity .3s ease,transform .3s ease,visibility .3s ease}.App.fullscreen-active .navbar,.App.fullscreen-active nav.navbar,:-moz-full-screen .navbar,:-moz-full-screen body .navbar,:-moz-full-screen body nav.navbar,:-moz-full-screen nav.navbar,:-ms-fullscreen .navbar,:-ms-fullscreen body .navbar,:-ms-fullscreen body nav.navbar,:-ms-fullscreen nav.navbar,:-webkit-full-screen .navbar,:-webkit-full-screen body .navbar,:-webkit-full-screen body nav.navbar,:-webkit-full-screen nav.navbar,:fullscreen .navbar,:fullscreen body .navbar,:fullscreen body nav.navbar,:fullscreen nav.navbar,body.fullscreen-active .navbar,body.fullscreen-active nav.navbar,html.fullscreen-active .navbar,html.fullscreen-active nav.navbar,html:has(body.fullscreen-active) .navbar,html:has(body.fullscreen-active) nav.navbar{display:none!important;height:0!important;left:-9999px!important;margin:0!important;max-height:0!important;opacity:0!important;overflow:hidden!important;padding:0!important;position:absolute!important;top:-9999px!important;transform:translateY(-100%)!important;visibility:hidden!important;width:0!important;z-index:-1!important}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:15px 30px;position:relative}.navbar-brand h1{font-size:24px;font-weight:600;margin:0}.navbar-menu{align-items:center;display:flex;flex:1 1;gap:30px;justify-content:center}.nav-link{border-radius:5px;color:#fff;font-weight:500;padding:8px 15px;text-decoration:none;transition:background-color .3s}.nav-link:hover{background-color:#fff3}.navbar-user{align-items:center;display:flex;gap:15px}.user-name{font-weight:500;text-transform:capitalize}.logout-button{background:#fff3;border:1px solid #ffffff4d;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;padding:8px 20px;transition:background-color .3s}.logout-button:hover{background:#ffffff4d}.nav-item-with-submenu{position:relative}.nav-item-with-submenu,.nav-item-with-submenu .nav-link{align-items:center;display:flex;height:100%}.submenu-arrow{font-size:10px;line-height:1;margin-left:5px}.submenu{background:#fff;border-radius:5px;box-shadow:0 4px 12px #00000026;left:0;margin-top:5px;min-width:180px;overflow:hidden;position:absolute;top:100%;z-index:1000}.submenu-link{border-bottom:1px solid #f0f0f0;color:#333;display:block;font-weight:500;padding:12px 20px;text-decoration:none;transition:background-color .3s}.submenu-link:last-child{border-bottom:none}.submenu-link:hover{background-color:#f8f9fa;color:#667eea}.mobile-menu-overlay{background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:999}.mobile-menu-toggle{background:none;border:none;cursor:pointer;display:none;padding:8px;z-index:1001}.mobile-menu-close{display:none}.hamburger{background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;height:20px;justify-content:space-around;padding:0;width:24px}.hamburger span{background-color:#fff;border-radius:3px;height:3px;transform-origin:center;transition:all .3s ease;width:100%}.hamburger.active span:first-child{transform:rotate(45deg) translate(6px,6px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}@media (min-width:1025px){.mobile-menu-close,.mobile-menu-overlay,.mobile-menu-toggle{display:none!important}.navbar-menu{background:#0000!important;box-shadow:none!important;flex:1 1;height:auto!important;justify-content:center;left:auto!important;position:static!important;top:auto!important}.mobile-menu-content,.navbar-menu{align-items:center;display:flex!important;gap:30px;overflow:visible!important;padding:0!important;width:auto!important}.mobile-menu-content{flex:none!important;flex-direction:row!important}.nav-link{border-bottom:none!important;border-radius:5px;color:#fff!important;display:inline-block!important;font-size:inherit!important;font-weight:500;margin:0!important;padding:8px 15px!important;text-align:center;text-decoration:none;transition:background-color .3s;width:auto!important}.nav-item-with-submenu{flex-direction:row!important;margin-top:0!important;position:relative!important}.nav-item-with-submenu,.nav-item-with-submenu .nav-link{align-items:center!important;display:flex!important;height:100%!important;width:auto!important}.nav-item-with-submenu .nav-link{border-bottom:none!important;padding:8px 15px!important}.submenu{background:#fff!important;border-radius:5px!important;box-shadow:0 4px 12px #00000026!important;flex-direction:column!important;left:0!important;margin-top:5px!important;min-width:180px!important;overflow:hidden!important;position:absolute!important;top:100%!important;width:auto!important;z-index:1000!important}.submenu,.submenu-link{display:block!important}.submenu-link{border-bottom:1px solid #f0f0f0!important;color:#333!important;font-size:inherit!important;font-weight:500;padding:12px 20px!important;text-align:left!important;text-decoration:none;transition:background-color .3s}.submenu-link:hover{background-color:#f8f9fa!important;color:#667eea!important}.navbar-user{align-items:center!important;background:#0000!important;border-top:none!important;bottom:auto!important;box-shadow:none!important;display:flex!important;flex-direction:row!important;gap:15px!important;left:auto!important;padding:0!important;position:static!important;top:auto!important;width:auto!important}.user-name{font-size:inherit;font-weight:500;margin:0;text-align:left;text-transform:capitalize}.logout-button{background:#fff3;border:1px solid #ffffff4d;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;padding:8px 20px;transition:background-color .3s;width:auto}.logout-button:hover{background:#ffffff4d}}@media (max-width:1024px){.mobile-menu-overlay,.mobile-menu-toggle{display:block}.navbar-container{padding:12px 20px}.navbar-brand h1{font-size:20px}.navbar-menu{align-items:stretch;background:linear-gradient(180deg,#667eea,#764ba2);box-shadow:2px 0 10px #0003;display:flex;flex-direction:column;gap:0;height:100vh;left:-100%;overflow:hidden;padding:0;position:fixed;top:0;transition:left .3s ease;width:280px;z-index:1000}.navbar-menu.mobile-open{left:0}.mobile-menu-close{align-items:center;background:#0000;border:1px solid #ffffff80;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:300;height:32px;justify-content:center;line-height:1;padding:0;position:absolute;right:15px;top:15px;transition:all .3s ease;width:32px;z-index:1001}.mobile-menu-close:hover{background:#ffffff1a;border-color:#fffc}.mobile-menu-content{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding-top:60px;width:100%}.nav-link{border-bottom:1px solid #ffffff26;color:#fff;display:block;font-size:16px;font-weight:500;margin:0;padding:15px 20px;text-align:left;transition:background-color .2s ease;width:100%}.nav-link:hover{background-color:#ffffff1a}.navbar-user{align-items:stretch;background:linear-gradient(180deg,#764ba2,#764ba2);border-top:1px solid #fff3;bottom:0;box-shadow:2px 0 10px #0003;flex-direction:column;gap:15px;left:-100%;padding:20px;position:fixed;top:auto;transition:left .3s ease;width:280px;z-index:1000}.navbar-user.mobile-open{left:0}.user-name{font-size:15px;margin:0;text-align:center}.logout-button,.user-name{color:#fff;font-weight:500}.logout-button{background:#ffffff26;border:1px solid #ffffff4d;border-radius:5px;font-size:14px;padding:12px;transition:all .3s ease;width:100%}.logout-button:hover{background:#ffffff40;border-color:#ffffff80}.nav-item-with-submenu{align-items:stretch;display:flex;flex-direction:column;height:auto;margin-top:0;position:static;width:100%}.nav-item-with-submenu .nav-link{align-items:center;display:flex;height:auto;justify-content:space-between;padding:15px 20px;width:100%}.submenu{background:#00000026;border-radius:0;box-shadow:none;display:flex;flex-direction:column;left:auto;margin-left:0;margin-top:0;padding:0;position:static;top:auto;width:100%}.submenu-link{border-bottom:1px solid #ffffff1a;color:#fff;display:block;font-size:15px;padding:14px 20px 14px 40px;text-align:left;transition:background-color .2s ease}.submenu-link:hover{background-color:#ffffff1a;color:#fff}.submenu-link:last-child{border-bottom:none}.submenu-arrow{font-size:12px;opacity:.8}}@media (max-width:768px){.navbar-container{padding:12px 15px}.navbar-brand h1{font-size:18px}.navbar-menu,.navbar-user{max-width:320px;width:100%}}@media (max-width:480px){.navbar-container{padding:10px 12px}.navbar-brand h1{font-size:16px}.navbar-menu{width:100%}.nav-link{font-size:13px;padding:12px}.user-name{font-size:12px}.logout-button{font-size:12px;padding:8px}}.dashboard{box-sizing:border-box;display:flex;margin:0;max-width:100%;min-height:100vh;overflow-x:hidden;padding:0;width:100%}.dashboard-content{box-sizing:border-box;flex:1 1;margin-left:50px;transition:margin-left .3s ease,width .3s ease;width:calc(100% - 50px)}.dashboard-content.toolbar-hidden{margin-left:0;width:100%}.dashboard-content.fullscreen-mode .dashboard-toolbar,.dashboard-content.fullscreen-mode .toolbar-toggle-btn-float{display:none!important}.dashboard-content.fullscreen-mode{margin-left:0!important;padding:0!important;width:100%!important}.dashboard-toolbar{align-items:center;background:linear-gradient(180deg,#667eea,#764ba2);border-radius:0 12px 12px 0;box-shadow:2px 0 10px #667eea4d;display:flex;flex-direction:column;left:0;max-height:90vh;overflow-y:auto;padding:12px 0;position:fixed;top:50%;transform:translateY(-50%);transition:left .3s ease,transform .3s ease;width:45px;z-index:1000}.dashboard-toolbar.hidden{left:-45px}.dashboard-toolbar.visible{left:0}.toolbar-toggle-btn{align-items:center;background:#ffffff1a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;height:32px;justify-content:center;margin-bottom:15px;transition:all .2s;width:32px}.toolbar-toggle-btn:hover{background:#fff3;transform:scale(1.1)}.toolbar-toggle-btn svg{height:16px;width:16px}.toolbar-toggle-btn-float{align-items:center;background:linear-gradient(180deg,#667eea,#764ba2);border:none;border-radius:0 8px 8px 0;box-shadow:2px 0 8px #667eea4d;cursor:pointer;display:flex;height:36px;justify-content:center;left:0;position:fixed;top:50%;transform:translateY(-50%);transition:all .3s ease;width:36px;z-index:1001}.toolbar-toggle-btn-float.toolbar-visible{left:45px}.toolbar-toggle-btn-float.toolbar-hidden{left:0}.toolbar-toggle-btn-float:hover{background:linear-gradient(180deg,#764ba2,#667eea);box-shadow:2px 0 12px #667eea80;transform:translateY(-50%) scale(1.1)}.toolbar-toggle-btn-float svg{height:16px;width:16px}.toolbar-logo{align-items:center;cursor:pointer;display:flex;height:32px;justify-content:center;margin-bottom:15px;transition:transform .2s;width:32px}.toolbar-logo:hover{transform:scale(1.1)}.toolbar-logo svg{height:100%;width:100%}.toolbar-icons{flex-direction:column;gap:8px;width:100%}.toolbar-icon,.toolbar-icons{align-items:center;display:flex}.toolbar-icon{background:#0000;border:none;border-radius:6px;color:#fff;cursor:pointer;height:32px;justify-content:center;position:relative;transition:all .2s;width:32px}.toolbar-icon svg{height:18px;width:18px}.toolbar-icon:hover{background:#ffffff1a;transform:scale(1.1)}.toolbar-icon.active{background:#fff3;box-shadow:0 2px 8px #0000004d}.toolbar-icon.active:before{background:#4caf50;border-radius:0 3px 3px 0;content:"";height:60%;left:0;position:absolute;top:50%;transform:translateY(-50%);width:3px}.dashboard-toolbar::-webkit-scrollbar{width:4px}.dashboard-toolbar::-webkit-scrollbar-track{background:#0000}.dashboard-toolbar::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.dashboard-toolbar::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.dashboard-header{margin-bottom:30px}.dashboard-header h2{color:#333;font-size:32px;margin-bottom:10px}.dashboard-header p{color:#666;font-size:16px}.dashboard-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.dashboard-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:25px;transition:transform .2s,box-shadow .2s}.dashboard-card:hover{box-shadow:0 5px 20px #00000026;transform:translateY(-5px)}.dashboard-card h3{color:#333;font-size:20px;margin-bottom:10px}.dashboard-card p{color:#666;font-size:14px;margin-bottom:20px}.card-stats{display:flex;flex-direction:column;gap:5px}.stat-value{font-size:36px}.stat-label{color:#888}@media (max-width:1024px){.dashboard{padding:20px}.dashboard-header h2{font-size:28px}.dashboard-grid{gap:15px}}@media (max-width:768px){.dashboard{padding:15px}.dashboard-header h2{font-size:24px}.dashboard-header p{font-size:14px}.dashboard-grid{gap:15px;grid-template-columns:1fr}.dashboard-card{padding:20px}.dashboard-card h3{font-size:18px}.stat-value{font-size:32px}}@media (max-width:480px){.dashboard{padding:10px}.dashboard-header h2{font-size:20px}.dashboard-card{padding:15px}.stat-value{font-size:28px}}.trailer-section{background:#f5f5f5;border-radius:0;box-sizing:border-box;display:block;margin-bottom:0;margin-top:0;overflow-x:hidden;overflow-y:visible;padding:20px 15px;position:relative;width:100%}.trailer-section-title{color:#333;font-size:24px;font-weight:600;margin-bottom:20px;text-align:center}.trailer-tables-container{box-sizing:border-box;display:flex;flex-direction:row;gap:12px;overflow-x:auto;overflow-y:visible;padding:0;position:relative;width:100%}.trailer-tables-container::-webkit-scrollbar{height:8px}.trailer-tables-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.trailer-tables-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.trailer-tables-container::-webkit-scrollbar-thumb:hover{background:#555}.trailer-table-wrapper{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 10px #0000001a;flex:1 1;max-width:calc(33.333% - 8px);min-width:0;overflow:visible;padding:12px;position:relative;z-index:1}.card-header-compact{align-items:flex-start;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e3f2fd;border-radius:8px;box-shadow:0 2px 8px #667eea1a;box-sizing:border-box;display:flex;flex-wrap:nowrap;gap:8px;margin-bottom:15px;overflow:hidden;padding:10px;width:100%}.last-update-section{align-items:center;background:linear-gradient(135deg,#f0f4ff,#e8f0ff);border:1px solid #c5d5ff;border-radius:6px;box-shadow:0 1px 4px #667eea14;display:flex;gap:12px;margin-bottom:12px;padding:8px 12px}.last-update-label{color:#667eea;font-size:14px;font-weight:600;margin:0;white-space:nowrap}.last-update-time{background:#fff;border:1px solid #cbd5e0;border-radius:4px;box-shadow:inset 0 1px 2px #0000000d;color:#4a5568;font-family:Courier New,monospace;font-size:15px;font-weight:700;letter-spacing:.5px;min-width:60px;padding:6px 12px;text-align:center}.extended-columns-toggle{align-items:center;display:flex;gap:8px;margin-left:auto}.toggle-switch-label{cursor:pointer;display:inline-block;height:24px;position:relative;width:44px}.toggle-switch-input{height:0;opacity:0;width:0}.toggle-switch-slider{background-color:#cbd5e0;border-radius:24px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.toggle-switch-slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:18px;left:3px;position:absolute;transition:.3s;width:18px}.toggle-switch-input:checked+.toggle-switch-slider{background-color:#667eea}.toggle-switch-input:checked+.toggle-switch-slider:before{transform:translateX(20px)}.toggle-switch-input:disabled+.toggle-switch-slider{cursor:not-allowed;opacity:.5}.toggle-switch-text{color:#4a5568;font-size:13px;font-weight:500;white-space:nowrap}.card-number-large{align-items:center;align-self:stretch;background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #ffffff4d;border-radius:8px;box-shadow:0 4px 12px #667eea4d;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:28px;font-weight:800;height:auto;justify-content:center;line-height:1;min-width:50px;padding:0;text-align:center;transition:all .3s ease;-webkit-user-select:none;user-select:none;width:50px}.card-number-large.disabled{cursor:default!important;pointer-events:none}.assignment-cell.disabled{cursor:not-allowed;pointer-events:none}.assignment-cell.disabled .assigned-user-badge,.assignment-cell.disabled .assignment-drop-zone{cursor:not-allowed}.card-number-large.card-number-hover,.card-number-large:hover{background:linear-gradient(135deg,#f44336,#d32f2f);border-color:#fff6;box-shadow:0 4px 12px #f4433666;transform:scale(1.05)}.card-number-large:active{box-shadow:0 2px 8px #f443364d;transform:scale(.98)}.card-fields-grid{align-items:flex-start;display:flex;flex:1 1;flex-wrap:nowrap;gap:6px;min-width:0;overflow:visible}.card-field-item{display:flex;flex:1 1;flex-direction:column;gap:4px}.card-field-item.trailer-field{flex:1.5 1;max-width:180px;min-width:120px}.card-field-item.status-field{flex:0.75 1;max-width:95px;min-width:80px}.card-field-label{color:#667eea;font-size:11px;font-weight:700;letter-spacing:.3px;line-height:1.2;margin-bottom:2px;text-transform:uppercase}.card-field-input,.card-field-select{background-color:#fff;border:2px solid #e0e0e0;border-radius:6px;box-shadow:0 1px 3px #0000000d;box-sizing:border-box;color:#333;font-size:16px;font-weight:600;height:38px;line-height:1;max-width:100%;min-width:0;padding:8px 10px;transition:all .2s;width:100%}.card-field-input:focus,.card-field-select:focus{background-color:#f8f9ff;border-color:#667eea;box-shadow:0 0 0 3px #667eea26,0 2px 8px #667eea33;outline:none}.card-field-input.validation-error,.table-input.validation-error{background-color:#fff5f5!important;border-color:#f44336!important;border-width:2px!important;box-shadow:0 0 0 3px #f4433626,0 2px 8px #f4433633!important}.card-field-input.validation-error:focus,.table-input.validation-error:focus{border-color:#d32f2f!important;box-shadow:0 0 0 3px #f4433640,0 2px 8px #f443364d!important}.card-field-input:hover,.card-field-select:hover{border-color:#667eea;box-shadow:0 2px 6px #667eea26}.card-field-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;padding-right:30px}.status-select-wrapper-compact{height:42px;position:relative;width:100%}.status-select-wrapper-compact .status-arrow{color:#667eea;font-size:12px;font-weight:700;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);z-index:10}.reset-card-btn-compact{align-items:center;align-self:flex-end;background:linear-gradient(135deg,#f44336,#d32f2f);border:2px solid #fff3;border-radius:6px;box-shadow:0 3px 8px #f443364d;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:10px;font-weight:700;height:38px;justify-content:center;letter-spacing:.2px;margin-left:4px;margin-top:18px;max-width:85px;min-width:70px;opacity:1;padding:0 12px;text-transform:uppercase;transition:all .2s;visibility:visible;white-space:nowrap}.reset-card-btn-compact:hover{background:linear-gradient(135deg,#d32f2f,#c62828);box-shadow:0 4px 12px #f4433666;transform:translateY(-1px)}.reset-card-btn-compact:active{box-shadow:0 1px 3px #f4433633;transform:translateY(0)}.card-header{margin-bottom:15px}.card-number{color:#333;font-size:24px;font-weight:700;line-height:1}.date-time-row{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;gap:15px;margin-bottom:20px;padding-bottom:15px;width:100%}.date-container,.time-container{align-items:center;display:flex;flex:0 0 auto;gap:6px}.bottom-row{border-bottom:2px solid #e0e0e0;gap:20px;justify-content:space-between;padding-bottom:15px}.bottom-row,.reset-button-container{align-items:center;display:flex;margin-bottom:15px}.reset-button-container{justify-content:center;padding-bottom:10px}.reset-card-btn{background:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.5px;padding:10px 20px;text-transform:uppercase;transition:background-color .2s,transform .2s}.reset-card-btn:hover{background:#d32f2f;box-shadow:0 2px 6px #f443364d;transform:translateY(-1px)}.reset-card-btn:active{box-shadow:0 1px 3px #f4433633;transform:translateY(0)}.trailer-container{flex:1 1}.status-container,.trailer-container{align-items:center;display:flex;gap:10px}.status-container{position:relative;z-index:100}.status-select-wrapper{align-items:center;display:flex;position:relative;width:90px}.status-arrow{color:#9c88ff;font-size:12px;font-weight:700;pointer-events:none;position:absolute;right:10px;top:50%;transform:translateY(-50%);-webkit-user-select:none;user-select:none;z-index:102}.field-label{color:#333;font-size:14px;font-weight:600;white-space:nowrap}.trailer-label{font-weight:700}.trailer-input{background-color:#fff;border:1px solid #ccc;border-radius:4px;color:#333;font-size:14px;font-weight:600;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:120px}.trailer-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea26;outline:none}.trailer-input:hover{border-color:#999}.date-input{background-color:#fff;border:1px solid #ccc;border-radius:4px;color:#333;font-size:13px;font-weight:600;padding:8px 10px;transition:border-color .2s,box-shadow .2s;width:140px}.date-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.7}.date-input::-webkit-calendar-picker-indicator:hover{opacity:1}.date-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea26;outline:none}.date-input:hover{border-color:#999}.time-input{background-color:#fff;border:1px solid #ccc;border-radius:4px;color:#333;font-size:13px;font-weight:600;padding:8px 10px;transition:border-color .2s,box-shadow .2s;width:100px}.time-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.7}.time-input::-webkit-calendar-picker-indicator:hover{opacity:1}.time-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea26;outline:none}.time-input:hover{border-color:#999}.status-select{background-color:#fff!important;background-image:none;border:2px solid #9c88ff;border-radius:4px;box-shadow:0 2px 4px #9c88ff33;color:#333!important;font-size:15px;font-weight:700;line-height:1.5;padding:10px 30px 10px 12px;position:relative;transition:all .2s;width:100%;z-index:101}.status-select:focus{background-color:#f8f9ff;border-color:#667eea;box-shadow:0 0 0 3px #667eea40,0 2px 6px #00000026;outline:none}.status-select:hover{background-color:#f8f9ff;border-color:#7c6aff;box-shadow:0 2px 6px #9c88ff4d}.status-select-wrapper:hover .status-arrow{color:#667eea;transform:translateY(-50%) scale(1.2)}.status-select option{background-color:#fff!important;border:none;color:#333!important;font-size:14px;font-weight:600;padding:10px 12px}.status-select option:checked,.status-select option[selected]{background-color:#667eea!important;color:#fff!important}.status-select option:hover{background-color:#f0f0f0!important}.status-select,.status-select:focus,.status-select:hover{background-color:#fff!important;color:#333!important}.trailer-table-wrapper select{max-width:100%}@supports (-webkit-appearance:none){.status-select{max-width:90px}}.trailer-table{box-sizing:border-box;display:flex;flex-direction:column;margin-top:10px;min-width:0;overflow-x:auto;width:100%}.trailer-table:has(.table-header-row.extended-columns){min-width:525px}.table-header-row{grid-gap:0;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:2px solid #667eea;display:grid;font-size:11px;font-weight:600;gap:0;grid-auto-flow:row;grid-template-columns:50px 70px 55px 55px 150px 1fr;overflow:visible}.table-header-cell{align-items:center;border-right:1px solid #ddd;box-sizing:border-box;color:#333;display:flex;font-size:10px;justify-content:center;min-width:0;overflow:hidden;padding:6px 3px;text-align:center;white-space:nowrap}.table-header-cell:first-child,.table-header-cell:nth-child(10),.table-header-cell:nth-child(2),.table-header-cell:nth-child(3),.table-header-cell:nth-child(4),.table-header-cell:nth-child(5),.table-header-cell:nth-child(6),.table-header-cell:nth-child(7),.table-header-cell:nth-child(8),.table-header-cell:nth-child(9){font-size:15px;font-weight:700}.table-header-cell:last-child{border-right:none}.table-data-row{grid-gap:0;border-bottom:1px solid #e0e0e0;display:grid;font-size:12px;gap:0;grid-auto-flow:row;grid-template-columns:50px 70px 55px 55px 150px 1fr;height:auto;min-height:40px;overflow:visible}.table-data-row.extended-columns,.table-header-row.extended-columns{grid-auto-flow:row!important;grid-template-columns:50px 70px 55px 55px 50px 50px 50px 50px 50px 50px!important;min-width:525px;overflow:visible!important}.settings-icon-container{align-items:center;display:flex;justify-content:flex-start;margin-top:20px;padding:20px 0 10px 15px}.settings-icon-btn{align-items:center;background:#667eea;border:none;border-radius:50%;box-shadow:0 4px 12px #667eea66;color:#fff;cursor:pointer;display:flex;font-size:24px;height:50px;justify-content:center;transition:all .3s;width:50px;z-index:1000}.settings-icon-btn:hover{background:#5568d3;box-shadow:0 6px 16px #667eea80;transform:scale(1.1)}.settings-icon-btn:active{transform:scale(.95)}.assignment-icon-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;box-shadow:0 4px 12px #667eea66;color:#fff;cursor:grab;display:flex;font-size:24px;height:50px;justify-content:center;position:fixed;transition:all .3s;-webkit-user-select:none;user-select:none;width:50px;z-index:1000}.assignment-icon-btn:active{cursor:grabbing}.assignment-icon-btn:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190);box-shadow:0 6px 16px #667eea80;transform:scale(1.1)}.assignment-icon-btn:active{background:linear-gradient(135deg,#4d5fc4,#5d387e);transform:scale(.95)}.modal-overlay{pointer-events:auto;z-index:2000}.modal-content{border-radius:8px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;max-height:80vh;overflow:hidden}.modal-header{background:#f8f9fa;border-bottom:2px solid #e0e0e0;padding:20px}.modal-header h3{color:#333}.modal-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;transition:all .2s;width:32px}.modal-close-btn:hover{background:#e0e0e0;color:#333}.modal-body{flex:1 1;overflow-y:auto;padding:20px}.seq-list h4{color:#333;font-size:16px;font-weight:600;margin:0 0 15px}.seq-items{margin-bottom:20px;max-height:300px;overflow-y:auto}.seq-item{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px;padding:12px}.seq-item-content{display:flex;flex:1 1;flex-direction:column;gap:8px}.seq-item-label{color:#333;font-size:14px;font-weight:600}.seq-description-input{background:#fff;border:1px solid #ddd;border-radius:4px;color:#333;font-size:13px;padding:6px 10px;transition:border-color .2s,box-shadow .2s;width:100%}.seq-description-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.seq-description-input::placeholder{color:#999;font-style:italic}.seq-delete-btn{background:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:background-color .2s}.seq-delete-btn:hover{background:#d32f2f}.bulk-add-section{border-top:2px solid #e0e0e0;margin-top:25px;padding-top:25px}.bulk-add-section h4{color:#333;font-size:16px;font-weight:600;margin:0 0 10px}.bulk-add-hint{color:#666;font-size:13px;margin:0 0 10px}.bulk-seq-textarea{border:2px solid #ddd;border-radius:4px;box-sizing:border-box;font-family:monospace;font-size:14px;margin-bottom:12px;min-height:120px;padding:12px;resize:vertical;width:100%}.bulk-seq-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26;outline:none}.bulk-add-btn{background:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:background-color .2s,transform .2s;width:100%}.bulk-add-btn:hover{background:#1976d2;transform:translateY(-2px)}.bulk-add-btn:active{transform:translateY(0)}.modal-actions{border-top:2px solid #e0e0e0;justify-content:center;padding-top:15px}.add-seq-btn{background:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:background-color .2s,transform .2s}.add-seq-btn:hover{background:#45a049;transform:translateY(-2px)}.add-seq-btn:active{transform:translateY(0)}.table-data-row:hover{background:#f8f9fa}.table-data-row.row-in-progress{background-color:#f4e4bc}.table-data-row.row-in-progress:hover{background-color:#e6d5b8}.table-data-row.row-completed{background-color:#81c784}.table-data-row.row-completed:hover{background-color:#66bb6a}.table-data-cell{align-items:center;border-right:1px solid #e0e0e0;box-sizing:border-box;color:#333;display:flex;height:100%;justify-content:center;min-height:40px;overflow:hidden;padding:5px 3px;text-align:center}.table-data-cell:last-child{border-right:none}.j-cell,.seq-cell{align-items:center;color:#555;display:flex;font-size:15px;font-weight:700;height:100%;justify-content:center;width:100%}.seq-cell{cursor:help;position:relative}.seq-cell:hover{background-color:#f0f0f0}.seq-cell-with-tooltip{cursor:help;position:relative}.seq-cell-with-tooltip:before{word-wrap:break-word;background-color:#333;border-radius:4px;bottom:calc(100% + 8px);box-shadow:0 2px 8px #0003;color:#fff;content:attr(data-tooltip);font-size:13px;font-weight:400;line-height:1.4;max-width:300px;min-width:150px;padding:8px 12px;text-align:left;white-space:normal;z-index:10000}.seq-cell-with-tooltip:after,.seq-cell-with-tooltip:before{left:50%;opacity:0;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .2s ease-in-out}.seq-cell-with-tooltip:after{border:5px solid #0000;border-top-color:#333;bottom:calc(100% + 3px);content:"";z-index:10001}.seq-cell-with-tooltip:hover:after,.seq-cell-with-tooltip:hover:before{opacity:1}.table-input{-webkit-appearance:textfield;appearance:textfield;background-color:#fff;border:1px solid #ddd;border-radius:3px;box-sizing:border-box;color:#333;font-size:15px;font-weight:600;height:auto;min-height:30px;padding:4px 2px;text-align:center;transition:border-color .2s,box-shadow .2s;width:100%}.table-input::-webkit-inner-spin-button,.table-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.comment-cell{align-items:flex-start!important;height:100%;min-height:40px;padding:5px 3px!important}.table-input-comment{background-color:#fff;border:1px solid #ddd;box-sizing:border-box;font-family:Arial,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:15px;font-style:normal;font-weight:400;max-height:30px;min-height:30px;min-width:0;padding:4px 8px;resize:none;resize:vertical;text-align:left;transition:background-color .2s;width:100%}.table-input-comment.has-comment{background-color:#ffd54f;border-radius:3px;font-family:inherit;font-weight:500;line-height:1.4}.table-input-readonly.ocz-calculated{align-items:center;background-color:#f5f5f5;border:1px solid #ddd;border-radius:3px;box-sizing:border-box;color:#333;cursor:not-allowed;display:flex;font-size:15px;font-weight:600;height:auto;justify-content:center;min-height:30px;padding:4px 8px;text-align:center;-webkit-user-select:none;user-select:none}.table-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea26;outline:none}.table-input:hover{border-color:#999}.zainfekowane-cell{font-weight:500}.zainfekowane-input{color:#d32f2f}.zainfekowane-input:focus{border-color:#d32f2f;box-shadow:0 0 0 2px #d32f2f26}@media (max-width:1400px){.trailer-table-wrapper{max-width:calc(33.333% - 8px)}.table-data-row:not(.extended-columns),.table-header-row:not(.extended-columns){grid-template-columns:65px 50px 50px 140px 1fr}.table-data-row.extended-columns,.table-header-row.extended-columns{grid-template-columns:50px 60px 50px 50px 45px 45px 45px 45px 45px 45px!important}.table-header-cell{font-size:9px;padding:5px 2px}.table-data-cell{min-height:32px;padding:4px 2px}.table-input{font-size:10px;padding:3px 2px}.table-input-comment{font-size:10px;max-height:28px;min-height:28px}}@media (max-width:1200px){.trailer-tables-container{flex-direction:row;gap:10px}.trailer-table-wrapper{max-width:calc(33.333% - 7px);padding:10px}.table-data-row:not(.extended-columns),.table-header-row:not(.extended-columns){grid-template-columns:60px 45px 45px 90px 1fr}.table-data-row.extended-columns,.table-header-row.extended-columns{grid-template-columns:45px 55px 45px 45px 40px 40px 40px 40px 40px 40px!important}}@media (max-width:768px){.trailer-section{box-sizing:border-box;overflow-x:auto;padding:10px 5px;width:100%}.trailer-tables-container{flex-direction:row;gap:15px;min-width:100%;overflow-x:auto;overflow-y:visible;padding-bottom:10px;width:-webkit-max-content;width:max-content}.trailer-table-wrapper{box-sizing:border-box;flex:0 0 auto;max-width:420px;min-width:420px;padding:10px;width:420px}.table-data-row:not(.extended-columns),.table-header-row:not(.extended-columns){font-size:11px;grid-template-columns:50px 70px 55px 55px 120px 1fr}.table-data-row.extended-columns,.table-header-row.extended-columns{font-size:11px;grid-template-columns:50px 70px 55px 55px 45px 45px 45px 45px 45px 45px!important}.table-header-cell{font-size:11px;padding:4px 2px}.table-data-cell,.table-input{padding:4px 2px}.table-input{font-size:12px}.table-input-comment{font-size:12px;max-height:25px;min-height:25px;padding:3px 4px}.card-header-compact{box-sizing:border-box;flex-wrap:wrap;gap:8px;padding:8px}.reset-card-btn-compact{flex-shrink:0;min-width:auto;width:auto}.card-number-large{font-size:24px;height:38px;min-width:45px}.card-fields-grid{flex:1 1;gap:6px;min-width:0}.card-field-item{flex:1 1 auto;min-width:0}.card-field-label{font-size:11px}.card-field-input,.card-field-select{font-size:16px;height:38px;padding:8px 10px}.reset-card-btn-compact{font-size:11px;height:38px;margin-top:0;padding:0 12px}.trailer-section::-webkit-scrollbar{height:8px}.trailer-section::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.trailer-section::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.trailer-section::-webkit-scrollbar-thumb:hover{background:#555}}@media (max-width:480px){.trailer-section{box-sizing:border-box;overflow-x:auto;padding:8px 5px;scroll-behavior:smooth;width:100%}.trailer-tables-container{flex-direction:row;gap:12px;min-width:100%;overflow-x:visible;overflow-y:visible;padding-bottom:10px;width:-webkit-max-content;width:max-content}.trailer-table-wrapper{box-sizing:border-box;flex:0 0 auto;max-width:380px;min-width:380px;padding:8px;width:380px}.table-data-row:not(.extended-columns),.table-header-row:not(.extended-columns){font-size:10px;gap:2px;grid-template-columns:45px 65px 50px 50px 110px 1fr}.table-data-row.extended-columns,.table-header-row.extended-columns{font-size:10px;gap:2px;grid-template-columns:45px 65px 50px 50px 40px 40px 40px 40px 40px 40px!important}.table-header-cell{font-size:10px;padding:4px 1px}.table-header-cell:first-child,.table-header-cell:nth-child(2),.table-header-cell:nth-child(3),.table-header-cell:nth-child(4),.table-header-cell:nth-child(5),.table-header-cell:nth-child(6){font-size:11px}.table-data-cell{font-size:10px;padding:4px 1px}.table-input{font-size:11px;padding:3px 1px}.table-input-comment{font-size:11px;max-height:22px;min-height:22px;padding:2px 3px}.j-cell,.seq-cell{font-size:11px}.trailer-table-header{font-size:12px;grid-template-columns:50px 15px 40px 50px}.dashboard-content{margin-left:0;width:100%}.dashboard-toolbar{left:-45px}.toolbar-toggle-btn-float{left:0}.card-header-compact{flex-direction:column;gap:10px;padding:8px}.card-number-large{align-self:center;font-size:24px;height:50px;width:50px}.card-fields-grid{flex-direction:column;gap:8px;width:100%}.card-field-item{width:100%}.reset-card-btn-compact{margin-top:0;width:100%}.modal-content{overflow-y:auto}.assignment-modal-content,.modal-content,.reminder-modal-content,.settings-modal-content{margin:10px;max-height:90vh;max-width:95%;padding:15px;width:95%}.reminder-popup{max-width:90%;padding:15px;width:90%}.reminder-popup-header h3{font-size:18px}.reminder-popup-title{font-size:16px}.reminder-popup-description{font-size:14px}.reminder-popup-footer{flex-direction:column;gap:10px}.reminder-postpone-section{flex-direction:column;gap:8px;width:100%}.reminder-popup-confirm-btn,.reminder-postpone-btn{width:100%}.confirm-delete-modal{max-width:90%;padding:15px;width:90%}.modal-footer{flex-direction:column;gap:10px}.confirm-delete-cancel-btn,.confirm-delete-ok-btn{width:100%}.excel-table-container,.seq-excel-table-wrapper{max-width:100%;overflow-x:auto}.excel-table,.seq-excel-table{min-width:500px}.seq-excel-th-j,.seq-excel-th-opis,.seq-excel-th-seq{font-size:11px;min-width:80px;padding:6px 4px}.seq-excel-input{font-size:12px;padding:6px 8px}.reminder-modal-tabs{flex-direction:column}.reminder-tab-btn{border-radius:0;width:100%}.reminder-days-checkboxes,.reminder-form-row{flex-direction:column;gap:8px}.reminder-day-checkbox-label{width:100%}.reminder-item{flex-direction:column;gap:10px}.reminder-delete-checkbox-label,.reminder-delete-selected-btn{width:100%}.history-tabs{flex-direction:column}.history-tab-btn{width:100%}.history-item-header{flex-direction:column;gap:5px}}@media (max-width:1024px) and (min-width:769px){.dashboard-content{margin-left:45px;width:calc(100% - 45px)}.card-header-compact{flex-wrap:nowrap;gap:10px;padding:12px}.card-fields-grid{flex:1 1;flex-wrap:nowrap;min-width:0}.card-field-item{flex:1 1 auto;min-width:100px}.reset-card-btn-compact{flex-shrink:0}.assignment-modal-content,.modal-content,.reminder-modal-content,.settings-modal-content{max-width:600px;width:85%}.reminder-popup{max-width:500px;width:80%}.confirm-delete-modal{max-width:400px;width:80%}.seq-excel-table{min-width:550px}.reminder-days-checkboxes{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr)}}.assignment-cell{height:100%;min-height:40px;padding:5px 3px;position:relative;transition:background-color .2s;z-index:1}.assignment-cell,.assignment-drop-zone{align-items:center;box-sizing:border-box;display:flex;justify-content:center;overflow:hidden}.assignment-drop-zone{border:2px dashed #ccc;border-radius:4px;color:#999;font-size:10px;height:30px;min-height:30px;padding:4px 2px;pointer-events:none;text-align:center;transition:all .2s;width:100%}.assignment-cell:hover .assignment-drop-zone{background-color:#f0f4ff;border-color:#667eea;color:#667eea}.assignment-cell.drag-over{background-color:#e3f2fd!important;border:2px solid #2196f3!important}.assignment-cell.drag-over .assignment-drop-zone{background-color:#bbdefb;border-color:#2196f3;color:#1976d2}.assigned-user-badge{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;border-radius:6px;box-shadow:0 2px 4px #2196f333;box-sizing:border-box;color:#1565c0;flex-shrink:0;font-size:13px;gap:6px;height:30px;justify-content:space-between;max-height:30px;overflow:hidden;padding:4px 8px;text-transform:uppercase;width:100%}.assigned-user-badge,.remove-assignment-btn{align-items:center;display:flex;font-weight:700;transition:all .2s}.remove-assignment-btn{background:#f44336;border:none;border-radius:50%;box-shadow:0 1px 3px #f443364d;color:#fff;cursor:pointer;font-size:16px;height:20px;justify-content:center;line-height:1;padding:0;width:20px}.remove-assignment-btn:hover{background:#d32f2f;box-shadow:0 2px 5px #f4433666;transform:scale(1.1)}.assigned-user-badge:hover{box-shadow:0 3px 6px #0003;opacity:.9;transform:translateY(-1px)}.assignment-modal-overlay{background:#0000!important;pointer-events:none;z-index:2000}.assignment-modal-overlay>*{pointer-events:auto}.assignment-modal-content{max-width:90vw;-webkit-user-select:none;user-select:none;width:350px}.assignment-modal-header{cursor:grab;-webkit-user-select:none;user-select:none}.assignment-modal-header:active{cursor:grabbing}.assignment-modal-body{max-height:400px;overflow-y:auto}.assignment-hint{color:#666;font-size:13px;font-style:italic;margin:0 0 15px;text-align:center}.users-list{display:flex;flex-direction:column;gap:8px}.user-item{align-items:center;background:#f5f5f5;border:2px solid #ddd;border-radius:6px;color:#333;cursor:grab;display:flex;font-size:14px;font-weight:500;justify-content:space-between;padding:12px 16px;position:relative;transition:all .2s;-webkit-user-select:none;user-select:none}.user-item:hover{background:#e3f2fd;border-color:#2196f3;transform:translateX(5px)}.user-item:active{cursor:grabbing;opacity:.7}.user-item.dragging{opacity:.5}.user-item.user-assigned{background:#e0e0e0;border-color:#bdbdbd;color:#757575;cursor:not-allowed;opacity:.6}.user-item.user-assigned:hover{background:#e0e0e0;border-color:#bdbdbd;transform:none}.assigned-badge{color:#4caf50;font-size:11px;font-weight:600;margin-left:8px}.no-users-message{color:#999;font-style:italic;padding:20px;text-align:center}.seq-excel-table-container{width:100%}.seq-excel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.seq-excel-header h4{color:#333;font-size:16px;font-weight:600;margin:0}.seq-excel-actions{display:flex;gap:10px}.seq-add-row-btn,.seq-remove-row-btn{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:background-color .2s}.seq-add-row-btn:hover{background:#5568d3}.seq-remove-row-btn{background:#f44336}.seq-remove-row-btn:hover:not(:disabled){background:#d32f2f}.seq-remove-row-btn:disabled{background:#ccc;cursor:not-allowed}.seq-excel-table-wrapper{border:1px solid #ddd;border-radius:4px;max-height:500px;overflow-x:auto;overflow-y:auto}.seq-excel-table{background:#fff;border-collapse:collapse;width:100%}.seq-excel-th{background:#f8f9fa;border-bottom:2px solid #ddd;border-right:1px solid #ddd;color:#333;font-size:13px;font-weight:600;padding:10px;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:10}.seq-excel-th:last-child{border-right:none}.seq-excel-th-j{min-width:80px;width:80px}.seq-excel-th-seq{min-width:150px;width:150px}.seq-excel-th-opis{min-width:200px;width:auto}.seq-excel-row{border-bottom:1px solid #e0e0e0}.seq-excel-row:hover{background:#f8f9fa}.seq-excel-cell{border-right:1px solid #e0e0e0;padding:0;vertical-align:middle}.seq-excel-cell:last-child{border-right:none}.seq-excel-input{background:#0000;border:none;box-sizing:border-box;color:#333;font-family:inherit;font-size:13px;outline:none;padding:8px 10px;width:100%}.seq-excel-input:focus{background:#fff;box-shadow:inset 0 0 0 2px #667eea}.seq-excel-input::placeholder{color:#999;font-style:italic}.seq-excel-cell-j .seq-excel-input{font-weight:600;text-align:center}.seq-excel-cell-seq .seq-excel-input{font-weight:600}.seq-excel-input.selected{background:#e3f2fd!important;box-shadow:inset 0 0 0 2px #2196f3}.seq-excel-input.selected:focus{background:#fff!important;box-shadow:inset 0 0 0 2px #667eea}.reminder-modal-content{max-height:80vh;max-width:600px;overflow-y:auto}.reminder-modal-tabs{border-bottom:2px solid #e0e0e0;display:flex;margin:0;padding:0}.reminder-tab{background:#f5f5f5;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:15px 20px;text-align:center;transition:all .2s}.reminder-tab:hover{background:#eee;color:#333}.reminder-tab.active{background:#fff;border-bottom-color:#667eea;color:#667eea}.reminder-delete-section{padding:20px 0}.reminder-delete-section h4{color:#333;font-size:16px;font-weight:600;margin:0 0 20px}.reminders-delete-list{margin-bottom:20px;max-height:400px;overflow-y:auto}.reminder-delete-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:12px;transition:all .2s}.reminder-delete-item:hover{background:#f0f0f0;border-color:#667eea}.reminder-delete-checkbox-label{align-items:flex-start;cursor:pointer;display:flex;gap:12px;margin:0;padding:15px}.reminder-delete-checkbox-label input[type=checkbox]{cursor:pointer;flex-shrink:0;height:20px;margin-top:2px;width:20px}.reminder-delete-item-content{flex:1 1}.reminder-delete-item-title{color:#333;font-size:15px;font-weight:700;margin-bottom:6px}.reminder-delete-item-description{color:#666;font-size:13px;line-height:1.4;margin-bottom:8px}.reminder-delete-item-details{margin-top:8px}.reminder-delete-selected-btn{background:#f44336;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.5px;padding:12px 24px;text-transform:uppercase;transition:background-color .2s,transform .2s;width:100%}.reminder-delete-selected-btn:hover:not(:disabled){background:#d32f2f;transform:translateY(-1px)}.reminder-delete-selected-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.history-clear-section{margin-bottom:30px}.history-clear-section h4{color:#333;font-size:18px;font-weight:600;margin:0 0 20px}.history-delete-list{border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;max-height:400px;overflow-y:auto;padding:10px}.history-delete-item{background:#fff;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:10px;transition:all .2s}.history-delete-item:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea26}.history-delete-checkbox-label{align-items:flex-start;cursor:pointer;display:flex;gap:12px;margin:0;padding:15px}.history-delete-checkbox-label input[type=checkbox]{cursor:pointer;flex-shrink:0;height:20px;margin-top:2px;width:20px}.history-delete-item-content{flex:1 1}.history-delete-item-title{color:#333;font-size:15px;font-weight:700;margin-bottom:8px}.history-delete-item-details{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.history-badge{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:4px;color:#666;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.history-delete-actions{border-top:2px solid #e0e0e0;margin-top:20px;padding-top:20px}.history-delete-btn{background:#f44336;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.5px;padding:12px 24px;text-transform:uppercase;transition:background-color .2s,transform .2s;width:100%}.history-delete-btn:hover:not(:disabled){background:#d32f2f;transform:translateY(-1px)}.history-delete-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.history-clear-message{align-items:flex-start;animation:slideIn .3s ease-out;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;gap:12px;margin-bottom:20px;padding:16px}.history-clear-message-success{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:2px solid #4caf50;box-shadow:0 2px 8px #4caf5033}.history-clear-message-error{background:linear-gradient(135deg,#ffebee,#ffcdd2);border:2px solid #f44336;box-shadow:0 2px 8px #f4433633}.history-clear-message-icon{flex-shrink:0;font-size:24px;margin-top:2px}.history-clear-message-content{flex:1 1}.history-clear-message-text{color:#333;font-size:14px;font-weight:500;line-height:1.4}.history-clear-message-close{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;flex-shrink:0;font-size:24px;height:24px;justify-content:center;padding:0;transition:color .2s;width:24px}.history-clear-message-close:hover{color:#333}.reminder-form{border-bottom:2px solid #e0e0e0;margin-bottom:30px;padding-bottom:20px}.reminder-form h4{color:#333;font-size:16px;font-weight:600;margin:0 0 15px}.reminder-success-message{align-items:flex-start;animation:slideIn .3s ease-out;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:2px solid #4caf50;border-radius:8px;box-shadow:0 2px 8px #4caf5033;display:flex;gap:12px;margin-bottom:20px;padding:16px}.reminder-success-icon{flex-shrink:0;font-size:24px;margin-top:2px}.reminder-success-content{flex:1 1}.reminder-success-title{color:#2e7d32;font-size:15px;font-weight:600;line-height:1.4;margin-bottom:6px}.reminder-success-info{color:#388e3c;font-size:13px;line-height:1.4}.reminder-success-close{align-items:center;background:#0000;border:none;border-radius:50%;color:#4caf50;cursor:pointer;display:flex;flex-shrink:0;font-size:20px;height:24px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:24px}.reminder-success-close:hover{background:#4caf501a;color:#2e7d32;transform:scale(1.1)}.reminder-form-row{margin-bottom:15px}.reminder-date-time-row{align-items:flex-end;display:flex;gap:15px}.reminder-form-field{display:flex;flex:1 1;flex-direction:column}.reminder-label{color:#555;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.reminder-input,.reminder-select,.reminder-textarea{background-color:#fff;border:2px solid #ddd;border-radius:4px;box-sizing:border-box;color:#333;font-family:inherit;font-size:14px;font-weight:500;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.reminder-input:focus,.reminder-select:focus,.reminder-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26;outline:none}.reminder-textarea{min-height:80px;resize:vertical}.reminder-checkbox-label{align-items:center;color:#333;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px}.reminder-checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.reminder-days-checkboxes{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-top:8px}.reminder-day-checkbox-label{align-items:center;background:#fff;border:2px solid #ddd;border-radius:6px;color:#333;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 12px;transition:all .2s}.reminder-day-checkbox-label:hover{background:#f8f9ff;border-color:#667eea}.reminder-day-checkbox-label input[type=checkbox]{cursor:pointer;height:18px;margin:0;width:18px}.reminder-day-checkbox-label input[type=checkbox]:checked+span{color:#667eea;font-weight:700}.reminder-day-checkbox-label:has(input[type=checkbox]:checked){background:#f0f2ff;border-color:#667eea}.reminder-add-btn{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:10px;padding:12px 24px;transition:background-color .2s,transform .2s;width:100%}.reminder-add-btn:hover{background:#5568d3;transform:translateY(-1px)}.reminders-list{margin-top:20px}.reminders-list h4{color:#333;font-size:16px;font-weight:600;margin:0 0 15px}.no-reminders{color:#999;font-style:italic;padding:20px;text-align:center}.reminders-items{max-height:400px;overflow-y:auto}.reminder-item{align-items:flex-start;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:10px;padding:15px;transition:background-color .2s}.reminder-item:hover{background:#f0f0f0}.reminder-item-content{flex:1 1}.reminder-item-title{color:#333;font-size:15px;font-weight:700;margin-bottom:6px}.reminder-item-description{color:#666;font-size:13px;line-height:1.4;margin-bottom:8px}.reminder-item-details{margin-top:8px}.reminder-badge{border-radius:12px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.reminder-badge.recurring{background:#e3f2fd;color:#1976d2}.reminder-badge.one-time{background:#fff3e0;color:#f57c00}.reminder-delete-btn{align-items:center;background:#f44336;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:28px;justify-content:center;margin-left:10px;transition:background-color .2s,transform .2s;width:28px}.reminder-delete-btn:hover{background:#d32f2f;transform:scale(1.1)}.reminder-popup-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.reminder-popup{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:600px;overflow:hidden;width:90%}.reminder-popup-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;gap:15px;padding:25px 30px}.reminder-popup-icon{font-size:36px}.reminder-popup-header h3{flex:1 1;font-size:24px;font-weight:700;margin:0}.reminder-popup-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;font-weight:700;height:32px;justify-content:center;transition:background-color .2s;width:32px}.reminder-popup-close:hover{background:#ffffff4d}.reminder-popup-body{padding:30px 35px}.reminder-popup-title{color:#333;font-size:22px;font-weight:700;line-height:1.4;margin-bottom:15px}.reminder-popup-description{color:#666;font-size:18px;line-height:1.6}.reminder-popup-footer{align-items:center;border-top:1px solid #e0e0e0;display:flex;gap:15px;justify-content:space-between;padding:20px 30px}.reminder-postpone-section{align-items:center;display:flex;gap:10px}.reminder-postpone-label{color:#666;font-size:14px;font-weight:600}.reminder-postpone-select{background-color:#fff;border:2px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:14px;font-weight:500;padding:8px 12px;transition:border-color .2s}.reminder-postpone-select:focus{border-color:#667eea;outline:none}.reminder-popup-postpone-btn{background:#ff9800;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background-color .2s,transform .2s}.reminder-popup-postpone-btn:hover{background:#f57c00;transform:translateY(-1px)}.reminder-popup-confirm-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 30px;transition:background-color .2s,transform .2s}.reminder-popup-confirm-btn:hover{background:#5568d3;transform:translateY(-1px)}.confirm-delete-modal{max-width:320px;padding:0;width:auto}.confirm-delete-content{padding:12px 16px;text-align:center}.confirm-delete-icon{font-size:32px;margin-bottom:10px}.confirm-delete-message{color:#333;font-size:14px;font-weight:500;line-height:1.3;margin-bottom:6px}.confirm-delete-warning{background:#fff3e0;border-left:3px solid #f57c00;border-radius:4px;color:#f57c00;font-size:12px;font-weight:500;margin-top:6px;padding:6px 10px}.modal-footer{background:#fafafa;border-top:1px solid #e0e0e0;display:flex;gap:8px;justify-content:flex-end;padding:12px 16px}.confirm-delete-cancel-btn{background:#fff;border:1.5px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:13px;font-weight:600;min-width:70px;padding:8px 16px;transition:all .2s}.confirm-delete-cancel-btn:hover{background:#f5f5f5;border-color:#bbb;color:#333}.confirm-delete-confirm-btn,.confirm-delete-ok-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;box-shadow:0 2px 4px #667eea4d;color:#fff;cursor:pointer;font-size:13px;font-weight:600;min-width:70px;padding:8px 16px;transition:all .2s}.confirm-delete-confirm-btn:hover,.confirm-delete-ok-btn:hover{background:linear-gradient(135deg,#5568d3,#653a8f);box-shadow:0 4px 8px #667eea66;transform:translateY(-1px)}.confirm-delete-confirm-btn:active,.confirm-delete-ok-btn:active{box-shadow:0 2px 4px #667eea4d;transform:translateY(0)}.history-tabs{border-bottom:2px solid #e0e0e0;display:flex;margin-bottom:20px}.history-tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .2s}.history-tab.active{border-bottom-color:#667eea;color:#667eea}.history-list{max-height:500px;overflow-x:hidden;overflow-y:auto}.history-items{display:flex;flex-direction:column;gap:12px}.no-history{color:#999;font-style:italic;padding:40px 20px;text-align:center}.history-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;padding:15px;transition:background-color .2s}.history-item:hover{background:#f0f0f0}.history-item-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.history-item-title{color:#333;flex:1 1;font-size:15px;font-weight:700}.history-item-date{color:#999;font-size:12px;margin-left:15px}.history-item-details{align-items:center;display:flex;gap:15px}.history-item-action{background:#e3f2fd;border-radius:12px;color:#667eea;font-size:13px;font-weight:600;padding:4px 10px}.history-item-user{color:#666;font-size:13px}.history-item-grouped{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:12px;padding:15px;transition:background-color .2s}.history-item-grouped:hover{background:#f0f0f0}.history-line{color:#333;font-size:14px;line-height:1.5;padding:6px 0}.history-line-1{border-bottom:1px solid #e0e0e0;font-weight:600;margin-bottom:8px;padding-bottom:10px}.history-line-2,.history-line-3{color:#555}.history-line-4{border-top:1px solid #e0e0e0;margin-top:8px;padding-top:8px}.history-send-btn{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:background-color .2s}.history-send-btn:hover{background:#5568d3}.history-send-btn:active{background:#4457b8}.history-sent-info{color:#28a745;font-size:14px;font-weight:500}.history-search-container{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:15px;padding:10px}.history-search-label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.history-search-input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.history-search-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.admin-container{box-sizing:border-box;margin:0 auto;max-width:1400px;padding:40px 20px}.admin-header{margin-bottom:32px;text-align:center}.admin-header h2{color:#1a1a1a;font-size:32px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.admin-header p{color:#6b7280;font-size:16px;font-weight:400;margin:0}.admin-header-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}.permissions-button{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.permissions-button:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.admin-content{grid-gap:32px;display:grid;gap:32px}.admin-section{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;padding:32px;transition:all .3s ease}.admin-section:hover{box-shadow:0 6px 32px #0000001a,0 2px 6px #00000014}.admin-section h3{border-bottom:2px solid #e5e7eb;color:#111827;font-size:24px;font-weight:700;letter-spacing:-.3px;margin:0 0 24px;padding-bottom:12px}.add-user-form{display:flex;flex-direction:column;gap:24px}.add-user-button{align-items:center;align-self:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 14px #667eea59;color:#fff;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:10px;letter-spacing:-.2px;padding:16px 48px;transition:all .3s ease}.add-user-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 6px 20px #667eea73;transform:translateY(-2px)}.add-user-button:active{box-shadow:0 2px 10px #667eea4d;transform:translateY(0)}.users-table-container{border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000000d;overflow-x:auto}.users-table{background:#fff;border-collapse:collapse;margin:0;width:100%}.users-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.users-table th{font-size:12px;font-weight:600;letter-spacing:.5px;padding:16px 20px;text-align:left;text-transform:uppercase}.users-table td{border-bottom:1px solid #f3f4f6;color:#374151;font-size:14px;padding:16px 20px}.users-table tbody tr{transition:background-color .2s ease}.users-table tbody tr:hover{background-color:#f9fafb}.users-table tbody tr:last-child td{border-bottom:none}.role-cell{align-items:center;display:flex;gap:10px}.role-select{background:#fff;border:2px solid #e0e0e0;border-radius:5px;cursor:pointer;font-size:14px;min-width:150px;padding:8px 12px}.role-select:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.role-badge{border-radius:12px;padding:4px 12px}.role-badge-owner{background-color:#ff6b6b;color:#fff}.role-badge-admin{background-color:#4ecdc4;color:#fff}.role-badge-lider{background-color:#ffe66d;color:#333}.role-badge-user{background-color:#95a5a6;color:#fff}.delete-button{align-items:center;background-color:#ef4444;border-radius:6px;box-shadow:0 1px 3px #ef44444d;box-sizing:border-box;display:inline-flex;font-size:13px;font-weight:600;height:36px;justify-content:center;line-height:20px;min-width:80px;padding:8px 16px;text-align:center;transition:all .2s ease}.delete-button:hover:not(:disabled){background-color:#dc2626;box-shadow:0 2px 6px #ef444466;transform:translateY(-1px)}.delete-button:active:not(:disabled){transform:translateY(0)}.delete-button:disabled{background-color:#d1d5db;box-shadow:none;cursor:not-allowed;opacity:.6}.action-buttons{gap:10px}.change-password-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;box-shadow:0 1px 3px #667eea4d;box-sizing:border-box;color:#fff;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;height:36px;justify-content:center;line-height:20px;min-width:80px;padding:8px 16px;text-align:center;transition:all .2s ease}.change-password-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 2px 6px #667eea66;transform:translateY(-1px)}.change-password-button:active{transform:translateY(0)}.edit-user-modal{max-width:750px!important;width:90%!important}.edit-user-form{padding:20px}.edit-user-form .form-group{margin-bottom:20px}.change-password-form,.edit-user-form{padding:32px}.edit-user-form .projects-group{margin-top:24px}.cancel-button{border-radius:8px;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.cancel-button:hover{box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.submit-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.submit-button:active{transform:translateY(0)}.password-error{color:#dc3545;font-size:12px;margin-top:5px}.project-badge{background-color:#e3f2fd;border-radius:12px;color:#1976d2;display:inline-block;font-size:12px;font-weight:500;padding:4px 12px}.project-select{width:100%}.form-group label{flex-wrap:wrap}.projects-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px}.projects-header label{color:#374151;font-size:14px;font-weight:600;letter-spacing:-.2px;margin:0}.add-project-button{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border-radius:8px;box-shadow:0 2px 6px #10b98140;display:inline-flex;font-weight:600;gap:6px;letter-spacing:-.1px;padding:10px 18px;transition:all .2s ease}.add-project-button:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98159;transform:translateY(-1px)}.add-project-button:active{box-shadow:0 2px 6px #10b98140;transform:translateY(0)}.add-icon{font-size:18px;font-weight:700;line-height:1}.projects-container{margin-top:0}.projects-grid{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1.5px solid #e2e8f0;border-radius:12px;box-shadow:inset 0 2px 4px #0000000a;display:flex;flex-wrap:wrap;gap:12px;max-height:320px;overflow-y:auto;padding:20px}.edit-user-modal .projects-grid{max-height:280px;padding:18px}.project-card{cursor:pointer;display:block;flex:0 0 auto;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1)}.project-checkbox{opacity:0;pointer-events:none;position:absolute}.project-card-content{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #0000000d;display:flex;justify-content:space-between;min-width:-webkit-fit-content;min-width:fit-content;padding:14px 18px;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap}.project-card:hover .project-card-content{background:#f8faff;border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.project-name{color:#374151;font-size:14px;letter-spacing:-.1px;transition:all .2s ease}.project-check-icon{align-items:center;background:#e2e8f0;border-radius:50%;color:#0000;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:22px;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);width:22px}.project-checkbox:checked~.project-card-content{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 16px #667eea4d;transform:translateY(-2px)}.project-checkbox:checked~.project-card-content .project-name{color:#fff;font-weight:600}.project-checkbox:checked~.project-card-content .project-check-icon{background:#ffffff40;color:#fff}.project-card:active .project-card-content{transform:translateY(0)}.no-projects-message{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1.5px dashed #cbd5e1;border-radius:12px;display:flex;flex-direction:column;justify-content:center;padding:48px 24px}.no-projects-icon{font-size:48px;margin-bottom:12px;opacity:.5}.no-projects-text{color:#64748b;font-size:15px;font-style:normal;font-weight:500;margin:0}.projects-badges{display:flex;flex-wrap:wrap;gap:5px}.project-badge.no-project{background-color:#f5f5f5;color:#999}.edit-button{align-items:center;background:linear-gradient(135deg,#06b6d4,#0891b2);border:none;border-radius:6px;box-shadow:0 1px 3px #06b6d44d;box-sizing:border-box;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;height:36px;justify-content:center;line-height:20px;min-width:80px;padding:8px 16px;text-align:center;transition:all .2s ease}.edit-button:hover{background:linear-gradient(135deg,#0891b2,#0e7490);box-shadow:0 2px 6px #06b6d466}.edit-button:active{transform:translateY(0)}@media (max-width:1366px){.admin-container{padding:28px 16px}.admin-header h2{font-size:28px}.admin-section{padding:28px}}@media (max-width:1024px){.admin-container{padding:24px 16px}.admin-header h2{font-size:26px}.admin-header p{font-size:15px}.admin-section{border-radius:12px;padding:24px}.admin-section h3{font-size:22px}.form-row{gap:20px}}@media (max-width:768px){.admin-container{padding:20px 12px}.admin-header{margin-bottom:24px}.admin-header h2{font-size:24px}.admin-header p{font-size:14px}.admin-section{border-radius:12px;padding:20px}.admin-section h3{font-size:20px;margin-bottom:20px}.form-row{gap:18px;grid-template-columns:1fr}.form-group input,.form-group select{font-size:15px;padding:12px 14px}.users-table-container{border-radius:10px;overflow-x:auto}.users-table td,.users-table th{font-size:13px;padding:12px 16px}.add-user-button{padding:14px;width:100%}.action-buttons{flex-wrap:wrap;gap:8px}.change-password-button,.delete-button,.edit-button{font-size:12px;height:32px;line-height:18px;min-width:70px;padding:6px 12px}.projects-header{align-items:flex-start;flex-direction:column;gap:10px}.projects-grid{gap:10px;max-height:280px;padding:16px}.project-card-content{font-size:13px;padding:12px 14px}.project-name{font-size:13px}.add-project-button{font-size:13px;padding:8px 14px}}@media (max-width:480px){.admin-container{padding:16px 10px}.admin-header h2{font-size:22px}.admin-header p{font-size:13px}.admin-section{border-radius:10px;padding:16px}.admin-section h3{font-size:18px;margin-bottom:16px}.form-group input,.form-group select{font-size:15px;padding:12px}.users-table td,.users-table th{font-size:12px;padding:10px 12px}.modal-content{border-radius:12px}.change-password-form,.edit-user-form,.modal-header{padding:20px}.projects-grid{gap:8px;max-height:240px;padding:12px}.project-card{flex:1 1 auto;min-width:calc(50% - 4px)}.project-card-content{padding:10px 12px}.project-name{font-size:12px}.add-project-button{justify-content:center;padding:10px;width:100%}.projects-header{gap:8px}}.project-manager{margin-top:20px}.add-project-form{margin-bottom:20px}.form-group-inline{align-items:flex-start;display:flex;gap:10px}.project-input{border:2px solid #e0e0e0;border-radius:5px;flex:1 1;font-size:14px;padding:10px;transition:border-color .3s}.project-input:focus{border-color:#667eea;outline:none}.add-project-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:transform .2s,box-shadow .2s;white-space:nowrap}.add-project-button:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.projects-list h4{color:#333;font-size:16px;margin-bottom:15px}.no-projects{color:#999;font-style:italic;padding:20px;text-align:center}.projects-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.project-item{align-items:center;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;display:flex;justify-content:space-between;padding:12px 15px;transition:background-color .3s}.project-item:hover{background-color:#e9ecef}.project-name{color:#333;font-weight:500}.delete-project-button{align-items:center;background:none;border:none;border-radius:50%;color:#dc3545;cursor:pointer;display:flex;font-size:24px;height:24px;justify-content:center;line-height:1;padding:0;transition:background-color .3s;width:24px}.delete-project-button:hover{background-color:#fee}@media (max-width:768px){.form-group-inline{flex-direction:column}.projects-grid{grid-template-columns:1fr}.modal-content{border-radius:12px}.modal-header{padding:20px}}.hr-container{box-sizing:border-box;margin:0;max-width:100%;padding:20px;width:100%}@media (min-width:2560px){.hr-container{margin:0 auto;max-width:2400px}}.hr-header{margin-bottom:30px}.hr-header h2{color:#333;font-size:32px;margin-bottom:0}.hr-content{margin-top:30px}.rotacja-container{min-height:200px;width:100%}.rotacja-tabs{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;box-sizing:border-box;display:flex;gap:10px;margin-bottom:20px;margin-left:auto;margin-right:auto;max-width:1200px;padding:10px 20px}.rotacja-tab{background:#f5f5f5;border:none;border-radius:6px;color:#666;cursor:pointer;flex:1 1;font-size:16px;font-weight:500;padding:12px 24px;transition:all .3s ease}.rotacja-tab:hover{background:#e5e5e5}.rotacja-tab.active{background:#667eea;color:#fff}.rotacja-tab.active:hover{background:#5568d3}.rotacja-content{margin:0 auto;max-width:1200px;width:100%}@media (max-width:1366px){.hr-container{padding:15px}.hr-header h2{font-size:28px}}@media (max-width:1024px){.hr-container{padding:15px}.hr-header h2{font-size:24px}.rotacja-tabs{padding:8px 15px}.rotacja-tab{font-size:14px;padding:10px 20px}}@media (max-width:768px){.hr-container{padding:10px}.hr-header{margin-bottom:20px}.hr-header h2{font-size:22px}.rotacja-tabs{flex-direction:column;gap:8px;padding:10px}.rotacja-tab{padding:12px;width:100%}}@media (max-width:480px){.hr-header h2{font-size:20px}.rotacja-tab{font-size:13px;padding:10px}}.dodaj-pracownika-container{box-sizing:border-box;margin:0 auto;max-width:1200px;padding:0 20px;width:100%}@media (min-width:1367px){.dodaj-pracownika-container{max-width:1400px}}@media (min-width:1920px){.dodaj-pracownika-container{max-width:1600px}}.dodaj-pracownika-section{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;box-sizing:border-box;max-width:100%;padding:40px;width:100%}.form-header{margin-bottom:32px;text-align:center}.dodaj-pracownika-section h3{color:#1a1a1a;font-size:28px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.form-subtitle{color:#6b7280;font-size:15px;font-weight:400;margin:0}.add-employee-form{display:flex;flex-direction:column;gap:32px;margin:0 auto;max-width:1000px;width:100%}.form-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:28px;transition:all .3s ease}.form-section:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000a}.form-section-header{border-bottom:2px solid #e5e7eb;margin-bottom:24px;padding-bottom:16px}.form-section-title{color:#111827;font-size:18px;font-weight:600;letter-spacing:-.3px;margin:0}.form-row{grid-gap:24px;align-items:start;gap:24px;width:100%}.form-row-three{grid-template-columns:1fr 1fr 1fr;width:100%}@media (min-width:1367px){.add-employee-form{max-width:1100px}.form-row,.form-row-three{gap:32px}.form-section{padding:32px}}@media (min-width:1920px){.add-employee-form{max-width:1300px}.form-row,.form-row-three{gap:40px}.form-section{padding:36px}}.form-group{align-items:stretch;gap:10px}.form-group label{align-items:center;color:#374151;display:flex;flex-wrap:nowrap;font-weight:600;gap:24px;height:32px;justify-content:space-between;letter-spacing:-.2px;margin-bottom:0;min-height:32px}.form-group label>span:first-child{flex:0 0 auto;min-width:0}.form-group input,.form-group select{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;font-family:inherit;font-size:15px;height:50px;line-height:1.5;max-width:100%;padding:14px 16px;text-align:left;transition:all .2s ease;width:100%}.form-group input:hover,.form-group select:hover{border-color:#9ca3af}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input::placeholder{color:#9ca3af}.form-group select:disabled{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed;opacity:.7}.projects-group{grid-column:1/-1}.projects-checkboxes{grid-gap:10px;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-top:10px;padding:15px}.project-checkbox-label{align-items:center;background:#fff;border:1px solid #ddd;border-radius:5px;cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:background-color .3s,border-color .3s}.project-checkbox-label:hover{background-color:#f0f0f0;border-color:#667eea}.project-checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.project-checkbox-label input[type=checkbox]:checked+span{color:#667eea;font-weight:600}.password-requirements{background-color:#f8f9fa;border-radius:5px;font-size:13px;margin-top:10px;padding:10px}.password-strength{margin-bottom:8px}.strength-label{color:#555;font-weight:500}.strength-value{border-radius:3px;font-weight:600;padding:2px 8px}.strength-0,.strength-1{background-color:#fee;color:#dc3545}.strength-2{background-color:#fff3e0;color:#fd7e14}.strength-3{background-color:#fffbf0;color:#ffc107}.strength-4,.strength-5{background-color:#efe;color:#28a745}.strength-6{background-color:#d4edda;color:#155724}.password-errors{color:#dc3545;list-style:none;margin:8px 0 0;padding:0}.password-errors li{font-size:12px;padding:4px 0}.password-errors li:before{content:"✗ ";margin-right:5px}.password-valid{color:#28a745;font-size:12px;font-weight:500;margin-top:8px}.password-hint{color:#666;font-size:11px;font-style:italic;margin-top:8px}.password-hint strong{color:#333}.form-submit-wrapper{display:flex;justify-content:center;margin-top:8px;padding-top:24px}.add-employee-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 14px #667eea59;color:#fff;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;letter-spacing:-.2px;min-width:200px;padding:16px 48px;transition:all .3s ease}.add-employee-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 6px 20px #667eea73;transform:translateY(-2px)}.add-employee-button:active{box-shadow:0 2px 10px #667eea4d;transform:translateY(0)}.add-employee-button .button-icon{font-size:18px;font-weight:700}.add-item-button{align-items:center;align-self:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;box-shadow:0 1px 3px #10b9814d;color:#fff;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:12px;font-weight:600;gap:4px;height:28px;line-height:1;margin-left:auto;margin-right:0;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.add-item-button:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 2px 6px #10b98166;transform:translateY(-1px)}.add-item-button:active{transform:translateY(0)}.add-item-button .button-icon{font-size:14px;font-weight:700;line-height:1}.add-item-button .button-text{font-size:11px}.add-position-button{margin-left:32px}.modal-form-group{margin-bottom:24px}.modal-form-group label{margin-bottom:10px}.modal-form-group input{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;font-family:inherit;font-size:15px;height:50px;padding:14px 16px;transition:all .2s ease;width:100%}.modal-form-group input:hover{border-color:#9ca3af}.modal-form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.modal-form-group input::placeholder{color:#9ca3af}.modal-actions .btn-cancel,.modal-actions .btn-confirm{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}@media (max-width:1366px){.dodaj-pracownika-container{max-width:100%;padding:0 15px}.dodaj-pracownika-section{padding:28px}.form-header{margin-bottom:28px}.dodaj-pracownika-section h3{font-size:24px}.form-section{padding:24px}.form-row{gap:20px}.form-group label{font-size:13px}.form-group input,.form-group select{font-size:15px;height:48px;padding:12px 14px}.add-item-button{font-size:11px;height:26px;padding:5px 10px}.projects-checkboxes{gap:8px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media (max-width:1024px){.dodaj-pracownika-section{padding:24px}.form-section{padding:20px}.form-row{gap:18px}.projects-checkboxes{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.add-employee-button{align-self:stretch;width:100%}}@media (max-width:768px){.dodaj-pracownika-container{padding:0 10px}.dodaj-pracownika-section{border-radius:12px;padding:20px}.form-header{margin-bottom:24px}.dodaj-pracownika-section h3{font-size:22px}.form-subtitle{font-size:14px}.form-section{border-radius:10px;padding:20px}.form-section-title{font-size:16px}.form-row{gap:18px}.form-row,.form-row-three{grid-template-columns:1fr}.form-group input,.form-group select{font-size:15px;height:48px;padding:12px 14px}.projects-checkboxes{gap:10px;grid-template-columns:1fr}.add-employee-button{font-size:16px;min-width:auto;padding:16px;width:100%}.add-item-button{font-size:11px;height:26px;padding:6px 10px}.modal-content{max-width:100%;padding:24px;width:95%}}@media (max-width:480px){.dodaj-pracownika-section{padding:16px}.form-header{margin-bottom:20px}.dodaj-pracownika-section h3{font-size:20px;margin-bottom:6px}.form-subtitle{font-size:13px}.form-section{padding:16px}.form-section-title{font-size:15px}.form-group label{font-size:13px}.form-group input,.form-group select{font-size:15px;height:46px;padding:12px}.add-item-button{font-size:10px;height:24px;margin-left:5px;padding:5px 8px}.add-item-button .button-text{display:none}.modal-content{padding:20px}.modal-content h3{font-size:18px}.add-employee-button{font-size:15px;padding:14px}}.employees-list-section{border-top:2px solid #e5e7eb;margin-top:40px;padding-top:32px}.employees-table-wrapper{margin-top:20px;overflow-x:auto}.employees-management-table{background:#fff;border-collapse:collapse;border-radius:12px;box-shadow:0 2px 8px #0000000d;overflow:hidden;width:100%}.employees-management-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.employees-management-table th{font-size:14px;font-weight:600;letter-spacing:-.2px;padding:16px;text-align:left;white-space:nowrap}.employees-management-table td{border-bottom:1px solid #e5e7eb;color:#374151;font-size:14px;padding:14px 16px}.employees-management-table tbody tr:hover{background-color:#f9fafb;transition:background-color .2s ease}.employees-management-table tbody tr:last-child td{border-bottom:none}.shift-badge{background:linear-gradient(135deg,#10b981,#059669)}.leader-badge,.shift-badge{border-radius:6px;white-space:nowrap}.leader-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}@media (max-width:1024px){.employees-management-table{font-size:13px}.employees-management-table td,.employees-management-table th{padding:12px}.modal-form-row{grid-template-columns:1fr}}@media (max-width:768px){.employees-list-section{margin-top:32px;padding-top:24px}.employees-management-table{font-size:12px}.employees-management-table td,.employees-management-table th{padding:10px 8px}.action-buttons{flex-direction:column;gap:4px}.delete-button,.edit-button{min-width:auto;width:100%}.edit-employee-modal{max-width:95%;padding:20px}}.lista-pracownikow-container{width:100%}.lista-pracownikow-header{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;margin-left:auto;margin-right:auto;max-width:800px;padding:20px}.stats{display:flex;flex-wrap:wrap;gap:30px}.stat-item{color:#333;font-size:16px}.stat-item strong{color:#667eea;margin-right:8px}.no-projects-message{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:30px}.no-projects-message p{color:#666;font-size:16px}.projects-list{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:800px}.project-section{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.project-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;display:flex;justify-content:space-between;padding:20px;transition:background .3s}.project-header:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f)}.project-header h3{font-size:20px;font-weight:600;margin:0}.project-info{align-items:center;display:flex;gap:15px}.employee-count{background:#fff3;border-radius:20px;font-size:14px;padding:5px 12px}.expand-icon{font-size:12px;transition:transform .3s}.employees-table-container{padding:20px}.no-employees{color:#666;padding:20px;text-align:center}.employees-table{border-collapse:collapse;width:100%}.employees-table thead{background-color:#f8f9fa}.employees-table th{border-bottom:2px solid #e0e0e0;color:#333;font-weight:600;padding:12px;text-align:left}.employees-table td{border-bottom:1px solid #f0f0f0;color:#555;padding:12px}.employees-table tbody tr:hover{background-color:#f8f9fa}.employees-table tbody tr:last-child td{border-bottom:none}.shift-badge{background-color:#667eea;border-radius:15px;color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}@media (max-width:1366px){.lista-pracownikow-header{padding:18px}.stats{gap:20px}}@media (max-width:1024px){.lista-pracownikow-header{padding:15px}.stats{gap:15px}.stat-item{font-size:14px}}@media (max-width:768px){.lista-pracownikow-header{margin-bottom:20px;padding:15px}.project-header,.stats{flex-direction:column;gap:10px}.project-header{align-items:flex-start;padding:15px}.project-header h3{font-size:18px}.project-info{justify-content:space-between;width:100%}.employees-table-container{overflow-x:auto;padding:15px}.employees-table{font-size:14px;min-width:600px}.employees-table td,.employees-table th{padding:8px}}@media (max-width:480px){.lista-pracownikow-header{padding:12px}.stat-item{font-size:13px}.project-header{padding:12px}.project-header h3{font-size:16px}.employees-table-container{padding:10px}.employees-table{font-size:12px;min-width:500px}.employees-table td,.employees-table th{padding:6px}}.action-buttons{align-items:center;display:flex;gap:8px}.delete-button,.edit-button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:16px;height:36px;justify-content:center;min-width:36px;padding:8px 12px;transition:all .2s ease}.edit-button{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f64d;color:#fff}.edit-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 8px #3b82f666;transform:translateY(-1px)}.delete-button{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 4px #ef44444d}.delete-button:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 8px #ef444466;transform:translateY(-1px)}.admin-message{align-items:center;animation:slideIn .3s ease;border-left:4px solid;border-radius:10px;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:24px;margin-left:auto;margin-right:auto;max-width:800px;padding:16px 20px}.admin-message.error{background-color:#fef2f2;border-left-color:#ef4444;color:#dc2626}.admin-message.success{background-color:#f0fdf4;border-left-color:#22c55e;color:#16a34a}.modal-content{padding:32px}.modal-content h3{border-bottom:2px solid #e5e7eb;color:#111827;font-size:22px;font-weight:700;letter-spacing:-.3px;margin:0 0 24px;padding-bottom:12px}.delete-confirm-modal p{color:#374151;font-size:15px;line-height:1.6;margin:12px 0}.modal-actions .btn-cancel,.modal-actions .btn-delete{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.edit-employee-modal{max-height:90vh;max-width:800px;overflow-y:auto;width:90%}.modal-form-section{display:flex;flex-direction:column;gap:20px}.modal-form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.modal-form-group{display:flex;flex-direction:column;gap:8px}.modal-form-group label{color:#374151;font-size:14px;font-weight:600;letter-spacing:-.2px}.modal-form-group input,.modal-form-group select{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;font-family:inherit;font-size:14px;height:46px;padding:12px 14px;transition:all .2s ease;width:100%}.modal-form-group input:hover,.modal-form-group select:hover{border-color:#9ca3af}.modal-form-group input:focus,.modal-form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.modal-form-group select:disabled{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed;opacity:.7}.required-asterisk{font-weight:700;margin-left:2px}@media (max-width:768px){.modal-content{max-width:100%;padding:24px;width:95%}.modal-form-row{grid-template-columns:1fr}.action-buttons{flex-direction:column;gap:4px}.delete-button,.edit-button{min-width:auto;width:100%}}.absencje-container{box-sizing:border-box;margin:0 auto;max-width:1800px;padding:20px;width:100%}.absencje-header{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;margin-bottom:24px;padding:24px}.absencje-header h3{color:#111827;font-size:28px;font-weight:700;margin:0 0 20px}.absencje-controls{align-items:flex-start;display:flex;flex-wrap:wrap;gap:20px}.date-selector,.month-selector,.project-selector,.quarter-selector,.rotation-selector,.view-mode-selector,.week-selector,.year-selector{align-items:flex-start;display:flex;flex:0 0 auto;flex-direction:column;gap:8px;justify-content:flex-start}.date-selector label,.month-selector label,.project-selector label,.quarter-selector label,.rotation-selector label,.view-mode-selector label,.week-selector label,.year-selector label{box-sizing:border-box;color:#374151;display:block;font-size:13px;font-weight:600;height:18px;line-height:18px;margin:0;max-height:18px;min-height:18px;padding:0;white-space:nowrap}.date-input,.month-select,.project-select,.quarter-select,.rotation-select,.view-mode-select,.week-select,.year-input{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;cursor:pointer;font-family:inherit;font-size:15px;height:44px;min-width:200px;padding:12px 16px;transition:all .2s ease}.year-input{cursor:text;min-width:120px}.week-select{min-width:250px}.month-select:hover,.project-select:hover,.rotation-select:hover,.view-mode-select:hover,.week-select:hover{border-color:#9ca3af}.date-input:focus,.month-select:focus,.project-select:focus,.rotation-select:focus,.view-mode-select:focus,.week-select:focus,.year-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.date-input{cursor:text;min-width:180px}.absencje-content{display:flex;flex-direction:column;gap:24px}.project-info-banner{align-items:center;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #93c5fd;border-radius:12px;color:#1e40af;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:8px;padding:16px 20px}.project-info-banner .info-icon{flex-shrink:0;font-size:20px}.stats-overview{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:32px}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 2px 8px #00000014,0 1px 3px #0000000d;overflow:hidden;padding:28px;position:relative;transition:all .3s ease}.stat-card:before{background:linear-gradient(135deg,#667eea,#764ba2);content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card:hover{border-color:#d1d5db;box-shadow:0 8px 24px #0000001f,0 2px 6px #00000014;transform:translateY(-4px)}.stat-icon{display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:48px;line-height:1;margin-bottom:16px}.stat-value{color:#111827;font-size:42px;font-weight:800;letter-spacing:-1px;line-height:1.2;margin-bottom:8px}.stat-label{color:#6b7280;font-size:15px;font-weight:600;letter-spacing:.5px;margin-top:4px}.charts-section{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin-bottom:24px}.chart-container{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;padding:24px}.chart-container.full-width{grid-column:1/-1}.chart-container h4{color:#111827;font-size:20px;font-weight:700;margin:0 0 20px}.no-data-message{color:#6b7280;font-size:16px;padding:60px 20px;text-align:center}.detailed-stats{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;padding:24px}.detailed-stats h4{color:#111827;font-size:24px;font-weight:700;margin:0 0 24px}.detailed-stats h5{color:#374151;font-size:18px;font-weight:600;margin:0 0 16px}.stats-by-type{margin-bottom:32px}.type-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.type-stat-card{align-items:center;background:#f9fafb;border-left:4px solid;border-radius:12px;display:flex;gap:16px;padding:16px;transition:all .2s ease}.type-stat-card:hover{background:#f3f4f6;transform:translateX(4px)}.type-stat-icon{font-size:32px}.type-stat-info{flex:1 1}.type-stat-label{color:#6b7280;font-size:14px;margin-bottom:4px}.type-stat-value{color:#111827;font-size:20px;font-weight:700}.stats-by-employee{margin-top:32px}.employee-stats-table{overflow-x:auto}.employee-stats-table table{background:#fff;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.employee-stats-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.employee-stats-table th{font-size:14px;font-weight:600;padding:14px 16px;text-align:left;white-space:nowrap}.employee-stats-table td{border-bottom:1px solid #f3f4f6;font-size:14px;padding:12px 16px}.employee-stats-table tbody tr:hover{background-color:#f9fafb}.employee-stats-table tbody tr:last-child td{border-bottom:none}.no-employees-message,.no-projects-message{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014;padding:60px 40px;text-align:center}.no-employees-message p,.no-projects-message p{color:#6b7280;font-size:16px;margin:0}@media (max-width:1024px){.charts-section{grid-template-columns:1fr}.chart-container.full-width{grid-column:1}}@media (max-width:768px){.absencje-container{padding:12px}.absencje-header{padding:16px}.absencje-controls,.date-selector,.project-selector,.rotation-selector,.view-mode-selector{align-items:stretch;flex-direction:column}.date-input,.project-select,.view-mode-select{min-width:0;width:100%}.stats-overview{grid-template-columns:repeat(2,1fr)}.type-stats-grid{grid-template-columns:1fr}.employee-stats-table{font-size:12px}.employee-stats-table td,.employee-stats-table th{padding:8px 12px}}@media (max-width:480px){.stats-overview{grid-template-columns:1fr}.stat-card{padding:20px}.stat-value{font-size:28px}.chart-container{padding:16px}}.zmiany-container{margin:0 auto;max-width:1200px;width:100%}.zmiany-header{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.zmiany-header h3{color:#333;font-size:24px;margin:0}.add-shift-btn{align-items:center;background:#667eea;border:none;border-radius:50%;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:28px;height:50px;justify-content:center;transition:all .3s ease;width:50px}.add-shift-btn:hover{background:#5568d3;box-shadow:0 4px 12px #667eea66;transform:scale(1.05)}.add-shift-form{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:25px}.add-shift-form h4{color:#333;font-size:20px;margin:0 0 20px}.form-group input[type=text],.form-group input[type=time]{border:1px solid #ddd;border-radius:6px;font-size:16px;padding:12px;transition:border-color .3s ease;width:100%}.form-group input[type=text]:focus,.form-group input[type=time]:focus{border-color:#667eea;outline:none}.color-picker{display:flex;flex-direction:column;gap:15px}.color-options-group{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.color-option{border:3px solid #0000;border-radius:50%;cursor:pointer;height:40px;position:relative;transition:all .3s ease;width:40px}.color-option:hover{transform:scale(1.1)}.color-option.active{border-color:#333;box-shadow:0 0 0 2px #fff,0 0 0 4px #667eea}.custom-color-wrapper{display:inline-block;position:relative}.custom-color-wrapper:hover .remove-color-btn{opacity:1}.remove-color-btn{align-items:center;background:#ef4444;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;height:20px;justify-content:center;line-height:1;opacity:0;padding:0;position:absolute;right:-8px;top:-8px;transition:opacity .3s ease;width:20px}.remove-color-btn:hover{background:#dc2626;transform:scale(1.1)}.color-picker-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.color-input{border:none;border-radius:50%;cursor:pointer;height:40px;overflow:hidden;padding:0;width:40px}.add-color-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .3s ease}.add-color-btn:hover:not(:disabled){background:#5568d3;transform:translateY(-1px)}.add-color-btn:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;opacity:.6}.duration-preview{background:#f5f5f5;border-radius:6px;color:#666;font-size:14px;margin-bottom:20px;padding:12px}.btn-cancel,.btn-save{border-radius:6px;font-size:16px;font-weight:500;transition:all .3s ease}.shifts-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.shift-item{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:row;gap:15px;justify-content:space-between;padding:15px;transition:transform .2s ease,box-shadow .2s ease}.shift-item:hover{box-shadow:0 4px 15px #00000026;transform:translateY(-2px)}.shift-icon{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:24px;font-weight:700;height:60px;justify-content:center;width:60px}.shift-details{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;gap:5px}.shift-name{color:#333;font-size:18px;font-weight:600;margin:0}.shift-time{color:#666;font-size:14px}.shift-actions{display:flex;flex-shrink:0;gap:10px}.delete-btn,.edit-btn{background:none;border:none;border-radius:6px;cursor:pointer;font-size:20px;padding:8px;transition:background .2s ease}.edit-btn:hover{background:#f0f0f0}.modal-content{padding:25px}.modal-content h3{border-bottom:2px solid #667eea;font-size:20px;margin:0 0 20px;padding-bottom:10px}.modal-form-group{margin-bottom:20px}.modal-form-group label{color:#555;display:block;font-weight:500;margin-bottom:8px}.color-input-group{align-items:center;display:flex;gap:10px;margin-bottom:15px}.color-hex-input{border:2px solid #e0e0e0;border-radius:6px;flex:1 1;font-family:monospace;font-size:16px;padding:12px;transition:border-color .3s}.color-hex-input:focus{border-color:#667eea;outline:none}.color-picker-input{border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;height:50px;overflow:hidden;padding:0;width:50px}.color-preview{align-items:center;border-radius:6px;color:#fff;display:flex;font-weight:500;justify-content:center;min-height:60px;padding:20px;text-align:center;text-shadow:0 1px 2px #0000004d}.modal-actions .btn-confirm:hover:not(:disabled){background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.modal-actions .btn-confirm:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;opacity:.6}.modal-header{margin:-25px -25px 25px}.modal-header h3{border-bottom:none;padding-bottom:0}@media (max-width:768px){.form-row,.shifts-list{grid-template-columns:1fr}.shift-item{align-items:center;flex-direction:row}.shift-details{align-items:flex-start}.shift-actions{flex-shrink:0}.modal-content{padding:20px;width:95%}}.rotacje-container{margin:0 auto;max-width:1200px;width:100%}.rotacje-header{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.project-selector{align-items:center;display:flex;gap:10px;margin-bottom:20px}.project-selector label{color:#333;font-weight:500}.project-selector select{background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;min-width:200px;padding:8px 12px}.project-selector select:focus{border-color:#667eea;outline:none}.rotacje-header h3{color:#333;font-size:24px;margin:0}.add-rotation-btn{align-items:center;background:#667eea;border:none;border-radius:50%;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:28px;height:50px;justify-content:center;transition:all .3s ease;width:50px}.add-rotation-btn:hover{background:#5568d3;box-shadow:0 4px 12px #667eea66;transform:scale(1.05)}.add-rotation-form{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:25px}.add-rotation-form h4{color:#333;font-size:20px;margin:0 0 20px}.form-group{margin-bottom:20px}.form-group label{color:#555;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input[type=number],.form-group input[type=text]{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .3s ease;width:100%}.form-group input[type=number]:focus,.form-group input[type=text]:focus{border-color:#667eea;outline:none}.form-row{grid-gap:15px;gap:15px;grid-template-columns:repeat(4,1fr)}.form-actions{justify-content:flex-end;margin-top:30px}.btn-cancel,.btn-clear,.btn-save{border:none;border-radius:6px;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .3s ease}.btn-clear{background:#f59e0b;color:#fff}.btn-clear:hover{background:#d97706}.btn-cancel{background:#e5e5e5;color:#333}.btn-cancel:hover{background:#d5d5d5}.btn-save{background:#667eea}.btn-save:hover{background:#5568d3}.rotation-pattern-editor{background:#f9f9f9;border-radius:10px;margin-top:30px;padding:20px}.pattern-header{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:20px}.pattern-header-left{flex:1 1}.pattern-header h5{color:#333;font-size:18px;margin:0 0 5px}.pattern-header p{color:#666;font-size:14px;margin:0}.pattern-header-actions{align-items:center;display:flex;gap:10px}.pattern-container{display:flex;flex-direction:column}.pattern-header-row-full{margin-bottom:15px;width:100%}.pattern-content-wrapper{align-items:flex-start;display:flex;gap:30px}.pattern-grid{flex:1 1;margin-bottom:0}.pattern-row{align-items:center;display:flex;gap:10px;margin-bottom:10px}.pattern-header-row{border-bottom:1px solid #e0e0e0;margin-bottom:15px;padding-bottom:10px}.row-number{color:#666;font-size:14px;font-weight:600;text-align:center;width:40px}.pattern-day-header{color:#555;font-size:12px;font-weight:600;height:30px;text-transform:uppercase}.pattern-cell,.pattern-day-header{align-items:center;display:flex;justify-content:center;width:50px}.pattern-cell{border:2px solid #0000;border-radius:50%;color:#fff;cursor:pointer;font-size:14px;font-weight:700;height:50px;transition:all .2s ease}.pattern-cell.empty{background:#e5e5e5;border-color:#ddd;color:#999}.pattern-cell.has-shift{border-color:#ffffff80}.pattern-cell.has-shift:hover{box-shadow:0 2px 8px #0003;transform:scale(1.1)}.pattern-cell.off-day{background:#0000;border:2px dashed #ccc;cursor:not-allowed}.pattern-cell.empty:hover{background:#d5d5d5;border-color:#bbb}.pattern-cell.drag-highlight{border:2px solid #667eea!important;box-shadow:0 0 8px #667eea80;opacity:.7;position:relative;z-index:10}.pattern-cell.drag-highlight.has-shift{opacity:.8}.shifts-menu{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:10px;display:flex;flex:0 0 320px;flex-direction:column;max-height:calc(100vh - 200px);overflow-y:auto;padding:20px}.shifts-menu p{color:#555;font-size:14px;font-weight:500;margin:0 0 15px}.rotations-list-in-menu{border-top:1px solid #e0e0e0;display:flex;flex-direction:column;gap:10px;margin-top:20px;padding-top:20px}.rotations-list-in-menu .rotation-item{align-items:center;background:#fff;border-radius:8px;box-shadow:0 1px 5px #0000001a;display:flex;justify-content:space-between;padding:12px;transition:transform .2s ease,box-shadow .2s ease}.rotations-list-in-menu .rotation-item:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.rotations-list-in-menu .rotation-info{flex:1 1;min-width:0}.rotations-list-in-menu .rotation-title{color:#333;font-size:14px;font-weight:600;margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rotations-list-in-menu .rotation-meta{color:#666;font-size:11px}.rotations-list-in-menu .rotation-actions{display:flex;flex-shrink:0;gap:5px}.rotations-list-in-menu .delete-btn,.rotations-list-in-menu .edit-btn,.rotations-list-in-menu .view-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:16px;padding:4px;transition:background .2s ease}.rotations-list-in-menu .edit-btn:hover,.rotations-list-in-menu .view-btn:hover{background:#f0f0f0}.rotations-list-in-menu .delete-btn:hover{background:#fee}.rotations-list-in-menu .empty-state{background:#fff;border-radius:8px;box-shadow:0 1px 5px #0000001a;padding:20px;text-align:center}.rotations-list-in-menu .empty-state p{color:#666;font-size:12px;margin:0}.shifts-menu-items{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr)}.shift-menu-item{align-items:center;background:#fff;border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:10px;transition:all .3s ease}.shift-menu-item:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.shift-menu-item.selected{border-color:#333;box-shadow:0 0 0 2px #fff,0 0 0 4px #667eea}.shift-menu-initials{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:35px;justify-content:center;width:35px}.shift-menu-name{color:#333;font-size:10px;font-weight:500;text-align:center}.shift-menu-duration{color:#666;font-size:9px;font-weight:400;margin-top:1px;text-align:center}.no-shifts-message{color:#999;font-size:14px;font-style:italic;margin:10px 0 0}.rotations-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.empty-state{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:40px;text-align:center}.empty-state p{color:#666;font-size:16px;margin:0}.rotation-item{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:row;gap:15px;justify-content:space-between;padding:15px;transition:transform .2s ease,box-shadow .2s ease}.rotation-item:hover{box-shadow:0 4px 15px #00000026;transform:translateY(-2px)}.rotation-info{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;gap:5px}.rotation-title{color:#333;font-size:24px;font-weight:700;margin:0}.rotation-meta{color:#666;font-size:14px}.rotation-actions{display:flex;flex-shrink:0;gap:10px}.delete-btn,.edit-btn,.view-btn{background:none;border:none;border-radius:6px;cursor:pointer;font-size:20px;padding:8px;transition:background .2s ease}.edit-btn:hover,.view-btn:hover{background:#f0f0f0}.delete-btn:hover{background:#fee}.rotation-view{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px}.rotation-view-header{align-items:center;border-bottom:1px solid #eee;display:flex;gap:20px;margin-bottom:30px;padding-bottom:20px}.back-btn{align-items:center;background:#667eea;border:none;border-radius:50%;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:24px;font-weight:700;height:50px;justify-content:center;transition:all .3s ease;width:50px}.back-btn:hover{background:#5568d3;box-shadow:0 4px 12px #667eea66;transform:scale(1.05)}.rotation-view-title h3{color:#333;font-size:24px;margin:0 0 5px}.rotation-view-title p{color:#666;font-size:14px;margin:0}.rotation-view-content{margin-top:20px}.rotation-identifier{align-items:center;background:#f5f5f5;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:30px;padding:15px 20px}.identifier-label{flex:1 1}.rotation-title-input{background:#fff;border:1px solid #ddd;border-radius:6px;color:#333;font-size:14px;padding:8px 12px;transition:border-color .3s ease;width:100%}.rotation-title-input:focus{border-color:#667eea;outline:none}.identifier-value{color:#333;font-size:16px;font-weight:600;margin-left:20px}.pattern-grid-view{margin-top:20px}.pattern-grid-view .pattern-row{margin-bottom:15px}.pattern-grid-view .pattern-cell{cursor:default}.pattern-grid-view .pattern-cell:hover{transform:none}@media (max-width:768px){.form-row{grid-template-columns:1fr}.pattern-container{flex-direction:column}.shifts-menu{flex:1 1;width:100%}.shifts-menu-items{flex-direction:row;flex-wrap:wrap;justify-content:center}.shift-menu-item{min-width:80px;width:auto}.pattern-cell{font-size:12px;height:40px;width:40px}.rotations-list{grid-template-columns:1fr}.rotation-item{align-items:center;flex-direction:row}.rotation-info{align-items:flex-start}.rotation-actions{flex-shrink:0}}.modal-content{border-radius:10px;box-shadow:0 4px 20px #0000004d;padding:30px;width:90%}.modal-content h3{color:#333;font-size:24px;margin:0 0 15px}.modal-content p{color:#666;font-size:16px;line-height:1.5;margin:0 0 25px}.modal-actions .btn-cancel,.modal-actions .btn-confirm,.modal-actions .btn-delete{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.modal-actions .btn-cancel{background:#f3f4f6}.modal-actions .btn-cancel:hover{background:#e5e7eb;box-shadow:0 2px 4px #0000001a}.modal-actions .btn-delete{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef44444d;color:#fff}.modal-actions .btn-delete:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #ef444466;transform:translateY(-1px)}.delete-warning{color:#dc2626;font-size:14px;font-weight:600;margin-top:12px}.modal-header{border-radius:10px 10px 0 0}.delete-confirm-modal{max-width:450px}.grafik-container{box-sizing:border-box;margin:0 auto;max-width:1800px;padding:20px;width:100%}.grafik-header-section{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;margin-bottom:24px;padding:24px}.grafik-controls{align-items:center;display:flex;flex-wrap:wrap;gap:20px}.control-group{align-items:center;display:flex;gap:12px}.control-group label{color:#374151;font-size:14px;font-weight:600;white-space:nowrap}.control-group select{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;color:#111827;cursor:pointer;font-size:15px;min-width:200px;padding:12px 16px;transition:all .2s ease}.control-group select:hover{border-color:#9ca3af}.control-group select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.month-navigation{gap:8px;margin-left:auto}.month-year-display{color:#111827;font-size:18px;font-weight:700;letter-spacing:-.3px;min-width:180px;text-align:center}.nav-button{align-items:center;background:linear-gradient(135deg,#4f46e5,#6366f1);border:none;border-radius:8px;box-shadow:0 2px 4px #4f46e54d;color:#fff;cursor:pointer;display:flex;font-size:18px;height:36px;justify-content:center;transition:all .2s ease;width:36px}.nav-button:hover{background:linear-gradient(135deg,#4338ca,#5b21b6);box-shadow:0 4px 8px #4f46e566;transform:translateY(-1px)}.nav-button:active{transform:translateY(0)}.clear-hours-button{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:8px;box-shadow:0 2px 4px #ef444433;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 16px;transition:all .2s ease}.clear-hours-button:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 8px #ef44444d;transform:translateY(-1px)}.clear-hours-button:active{box-shadow:0 2px 4px #ef444433;transform:translateY(0)}.clear-hours-button svg{stroke:currentColor;height:16px;width:16px}.grafik-table-container{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;overflow-x:auto;padding:24px}.grafik-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto;overflow-y:visible}.grafik-table{background:#fff;border-collapse:collapse;min-width:1200px;width:100%}.grafik-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:10}.grafik-table th{border-right:1px solid #fff3;font-size:12px;font-weight:600;letter-spacing:.5px;padding:14px 8px;text-align:center;text-transform:uppercase;white-space:nowrap}.grafik-table th:last-child{border-right:none}.employee-name-col{background:linear-gradient(135deg,#667eea,#764ba2);left:0;min-width:180px;padding-left:16px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:11}.overtime-col,.summary-col{background:linear-gradient(135deg,#5568d3,#6a3d8f);min-width:100px}.day-header.weekend{background:#ffffff26}.day-header.holiday{background:#ef444433}.day-header .day-number{font-size:16px;font-weight:700;margin-bottom:4px}.day-header .day-name{font-size:11px;font-weight:400;opacity:.9}.day-shift-info{align-items:center;border-radius:4px;box-shadow:0 1px 3px #0003;display:flex;flex-direction:column;font-size:10px;font-weight:600;gap:2px;line-height:1.2;margin-top:6px;padding:4px 6px;text-align:center}.day-shift-info .shift-week{font-size:9px;font-weight:700;letter-spacing:.5px;opacity:.95}.day-shift-info .shift-name{font-size:10px;font-weight:600;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grafik-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .2s ease}.grafik-table tbody tr:hover{background-color:#f9fafb}.grafik-table tbody tr:last-child{border-bottom:none}.employee-name-cell{background:#fff;border-right:2px solid #e5e7eb;left:0;padding:12px 16px!important;position:-webkit-sticky;position:sticky;z-index:5}.grafik-table tbody tr:hover .employee-name-cell{background:#f9fafb}.employee-info{display:flex;flex-direction:column;gap:4px}.day-cell{background:#fff;border-right:1px solid #f3f4f6}.day-cell.weekend{background:#f9fafb}.day-cell.holiday{background:#fef2f2}.day-cell.has-absence{background:#f0f9ff}.day-input-container{align-items:center;display:flex;flex-direction:column;gap:4px}.hours-input{border:1.5px solid #d1d5db;font-size:12px;padding:5px 6px;transition:all .2s ease;width:50px}.hours-input.hours-day{border-color:#3b82f6}.hours-input.hours-day:hover{border-color:#2563eb}.hours-input.hours-day:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.hours-input.hours-night{border-color:#6366f1}.hours-input.hours-night:hover{border-color:#4f46e5}.hours-input.hours-night:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.hours-input:hover{border-color:#9ca3af}.hours-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.absence-select{background:#fff;border:1px solid #e5e7eb;border-radius:4px;cursor:pointer;font-size:11px;padding:4px 6px;transition:all .2s ease;width:100%}.absence-select:hover{border-color:#d1d5db}.absence-select:focus{border-color:#667eea;outline:none}.absence-badge{box-shadow:0 2px 4px #0000001a;font-size:16px;height:32px;margin:0 auto;width:32px}.overtime-cell,.summary-cell{background:#f9fafb;border-right:1px solid #e5e7eb;font-weight:600;padding:12px 8px!important;text-align:center}.hours-summary{color:#111827;display:flex;flex-direction:column;font-size:13px;gap:4px}.hours-total{font-size:15px}.hours-total strong{color:#667eea;font-size:16px}.hours-breakdown{color:#6b7280;display:flex;flex-direction:column;font-size:11px;gap:2px}.hours-day-label{color:#3b82f6}.hours-night-label{color:#6366f1}.overtime-summary{font-size:12px}.overtime-details{align-items:center;display:flex;flex-direction:column;gap:4px}.overtime-badge{border-radius:6px;display:inline-block;font-size:13px;font-weight:600;padding:4px 10px}.overtime-breakdown{color:#6b7280;display:flex;flex-direction:column;font-size:10px;gap:2px}.overtime-100{color:#dc2626;font-size:11px;font-weight:600;margin-top:2px}.no-overtime{color:#9ca3af}.grafik-summary-section{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;margin-top:32px;padding:24px}.summary-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;gap:16px;justify-content:space-between;padding-bottom:16px}.summary-header-left{align-items:center;cursor:pointer;display:flex;flex:1 1;gap:12px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.summary-header-left:hover{opacity:.8}.generate-report-button{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;box-shadow:0 2px 4px #10b9814d;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.generate-report-button:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px #10b98166;transform:translateY(-1px)}.generate-report-button:active{transform:translateY(0)}.generate-report-button svg{flex-shrink:0}.summary-title{color:#111827;font-size:24px;font-weight:700;margin:0}.summary-toggle-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 4px #667eea4d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all .3s ease;width:36px}.summary-toggle-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 4px 8px #667eea66;transform:translateY(-1px)}.summary-toggle-button:active{transform:translateY(0)}.summary-toggle-button svg{transition:transform .3s ease}.summary-toggle-button.expanded svg{transform:rotate(180deg)}.summary-content-wrapper{margin-top:0;max-height:0;opacity:0;overflow:hidden;transition:max-height .4s ease-out,opacity .3s ease-out,margin-top .3s ease-out}.summary-content-wrapper.expanded{margin-top:24px;max-height:5000px;opacity:1;transition:max-height .5s ease-in,opacity .4s ease-in,margin-top .4s ease-in}.summary-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.employee-summary-card{background:linear-gradient(135deg,#f9fafb,#fff);border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:20px;transition:all .3s ease}.employee-summary-card:hover{border-color:#d1d5db;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.summary-card-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.summary-card-header h4{color:#111827;font-size:18px;font-weight:700;margin:0}.summary-position{background:#f3f4f6;border-radius:6px;color:#6b7280;font-size:12px;padding:4px 10px}.summary-content{gap:20px}.summary-content,.summary-group{display:flex;flex-direction:column}.summary-group{gap:8px}.summary-group h5{color:#374151;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 4px;text-transform:uppercase}.summary-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:8px 0}.summary-item:last-child{border-bottom:none}.summary-label{align-items:center;color:#6b7280;display:flex;font-size:13px;gap:6px}.summary-value{color:#111827;font-size:14px;font-weight:600}.summary-value.overtime-value{color:#dc2626}.summary-value.overtime-100-value{color:#b91c1c;font-weight:700}.no-employees-message,.no-project-message,.no-rotation-message{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014;padding:60px 20px;text-align:center}.no-employees-message p,.no-project-message p,.no-rotation-message p{color:#6b7280;font-size:16px;margin:0}@media (max-width:1366px){.grafik-container{padding:16px}.grafik-header-section,.grafik-table-container{padding:20px}.day-header{max-width:70px;min-width:70px}.day-shift-info{font-size:9px;padding:3px 4px}.day-shift-info .shift-week{font-size:8px}.day-shift-info .shift-name{font-size:9px}.hours-input{font-size:11px;padding:4px 5px;width:48px}}@media (max-width:1024px){.grafik-controls{align-items:stretch;flex-direction:column}.control-group{width:100%}.control-group select{flex:1 1;min-width:0}.month-navigation{justify-content:center;margin-left:0;width:100%}.grafik-table{min-width:1000px}}@media (max-width:768px){.grafik-container{padding:12px}.grafik-header-section{padding:16px}.grafik-table-container{padding:12px}.grafik-table{min-width:800px}.day-header{max-width:60px;min-width:60px;padding:10px 4px!important}.day-header .day-number{font-size:14px}.day-header .day-name{font-size:10px}.day-shift-info{font-size:8px;margin-top:4px;padding:2px 3px}.day-shift-info .shift-week{font-size:7px}.day-shift-info .shift-name{font-size:8px}.hours-input{font-size:11px;padding:4px 5px;width:45px}.summary-grid{grid-template-columns:1fr}.absence-select{font-size:10px;padding:3px 4px}.employee-name-col{min-width:150px}}@media (max-width:480px){.grafik-table{min-width:700px}.day-header{max-width:55px;min-width:55px}.hours-input{font-size:10px;padding:3px 4px;width:40px}.summary-grid{grid-template-columns:1fr}.employee-summary-card{padding:16px}.employee-name{font-size:13px}.employee-position{font-size:11px}.summary-header{align-items:stretch;flex-direction:column;gap:12px}.generate-report-button{justify-content:center;width:100%}}.modal-content{animation:modalSlideIn .3s ease;border-radius:16px;max-width:500px}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{background:#f9fafb;border-bottom:2px solid #e5e7eb;border-radius:16px 16px 0 0;padding:24px 32px}.modal-header h3{font-size:22px;letter-spacing:-.3px}.modal-close{border-radius:50%;color:#999;height:30px;transition:background-color .3s;width:30px}.modal-close:hover{background-color:#f0f0f0;color:#333}.modal-actions{gap:10px;margin-top:24px}.modal-actions .btn-confirm{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.modal-actions .btn-confirm:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.modal-actions .btn-cancel{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.modal-actions .btn-cancel:hover{background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px)}.grafik-table-container-new{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;overflow-x:auto;padding:24px}.grafik-table-wrapper-new{-webkit-overflow-scrolling:touch;overflow-x:auto;overflow-y:visible}.grafik-table-new{background:#fff;border-collapse:collapse;font-size:13px;min-width:2000px;width:100%}.grafik-table-new thead{position:-webkit-sticky;position:sticky;top:0;z-index:10}.grafik-table-new th{background:#f9fafb;font-size:11px;font-weight:600;letter-spacing:.3px;padding:10px 8px;white-space:nowrap}.grafik-table-new td,.grafik-table-new th{border:1px solid #e5e7eb;text-align:center}.grafik-table-new td{background:#fff;color:#111827;font-size:13px;padding:8px 6px;vertical-align:middle}.project-header-row th{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:14px;font-weight:700;padding:12px}.project-header,.project-name-header{padding-left:16px!important;text-align:left!important}.main-header-row th{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:12px;font-weight:700;letter-spacing:.3px;padding:12px 8px;text-shadow:0 1px 2px #0003}.col-summary-header{background:linear-gradient(135deg,#10b981,#059669)!important;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.summary-header-row th{background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:10px;font-weight:600;line-height:1.3;padding:8px 4px;text-align:center;white-space:normal;writing-mode:horizontal-tb}.empty-header{background:linear-gradient(135deg,#10b981,#059669)!important;border:1px solid #fff3!important}.col-no{font-size:12px;font-weight:700;left:0;max-width:50px;min-width:50px}.col-firstname,.col-lastname,.col-no{background:#e5e7eb!important;border-right:2px solid #d1d5db!important;color:#111827!important;position:-webkit-sticky;position:sticky;z-index:8}.col-firstname,.col-lastname{font-size:13px;font-weight:600;left:50px;min-width:120px;padding-left:12px!important;text-align:left!important}.col-lastname{left:170px}.col-user{left:290px;min-width:120px}.col-position,.col-user{background:#e5e7eb!important;border-right:2px solid #d1d5db!important;color:#111827!important;font-size:13px;font-weight:600;padding-left:12px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:8}.col-position{left:410px;min-width:140px}.col-contract{left:550px;min-width:120px}.col-contract,.col-shift-type{background:#e5e7eb!important;border-right:2px solid #d1d5db!important;color:#111827!important;font-size:13px;font-weight:600;padding-left:12px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:8}.col-shift-type{left:670px;min-width:200px}.col-date{font-size:11px;max-width:70px;min-width:70px;padding:10px 6px!important}.col-date .date-day-name{color:#fff;font-size:13px;font-weight:700;letter-spacing:.3px;margin-bottom:4px;text-shadow:0 1px 2px #0003}.col-date .date-day-number{color:#fff;font-size:11px;font-weight:500;opacity:.95;text-shadow:0 1px 2px #0003}.day-cell-new{background:#fff;padding:4px 2px!important;text-align:center;vertical-align:middle}.day-cell-new.weekend{background:#f9fafb}.day-cell-new.holiday{background:#fef2f2}.day-cell-new.has-absence{background:#e0f2fe}.shift-input-new{background:#fff;border:1.5px solid #d1d5db;border-radius:4px;color:#111827;font-size:13px;font-weight:500;padding:6px 4px;text-align:center;transition:all .2s ease;width:100%}.shift-input-new:hover{border-color:#667eea}.shift-input-new:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.absence-label-new{background:#dbeafe;border-radius:4px;color:#1e40af;display:inline-block;font-size:12px;font-weight:700;letter-spacing:.3px;padding:6px 8px}.shift-row.shiftDay .day-cell-new:not(.has-absence){background:#f0fdf4}.shift-row.shiftAfternoon .day-cell-new:not(.has-absence){background:#fef3c7}.shift-row.shiftNight .day-cell-new:not(.has-absence){background:#e0e7ff}.shift-row.overtimeAfternoon .day-cell-new:not(.has-absence),.shift-row.overtimeDay .day-cell-new:not(.has-absence),.shift-row.overtimeNight .day-cell-new:not(.has-absence){background:#fef2f2}.summary-cell-new{background:#f0fdf4!important;color:#111827;font-size:13px;font-weight:600;min-width:90px;padding:8px 6px!important;text-align:center}.summary-col{font-size:10px;font-weight:600;line-height:1.3;min-width:110px;padding:10px 6px!important}.shift-row.employee-first-row{border-top:3px solid #9ca3af!important}.shift-row.employee-last-row{border-bottom:3px solid #9ca3af!important}.shift-row.employee-first-row td{border-top:3px solid #9ca3af!important}.shift-row.employee-last-row td{border-bottom:3px solid #9ca3af!important}.grafik-table-new tbody tr.employee-first-row{background-color:#fafafa}.grafik-table-new tbody tr.employee-first-row .col-contract,.grafik-table-new tbody tr.employee-first-row .col-firstname,.grafik-table-new tbody tr.employee-first-row .col-lastname,.grafik-table-new tbody tr.employee-first-row .col-no,.grafik-table-new tbody tr.employee-first-row .col-position,.grafik-table-new tbody tr.employee-first-row .col-shift-type,.grafik-table-new tbody tr.employee-first-row .col-user{background:#f3f4f6!important}.grafik-table-new tbody tr:hover{background-color:#f9fafb}.grafik-table-new tbody tr:hover .col-contract,.grafik-table-new tbody tr:hover .col-firstname,.grafik-table-new tbody tr:hover .col-lastname,.grafik-table-new tbody tr:hover .col-no,.grafik-table-new tbody tr:hover .col-position,.grafik-table-new tbody tr:hover .col-shift-type,.grafik-table-new tbody tr:hover .col-user{background:#d1d5db!important}.grafik-single-card-container{margin:0 auto;width:100%}.grafik-single-card{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;overflow:hidden}.grafik-card-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px}.project-header-info{align-items:center;display:flex;gap:16px}.project-header-label{color:#fff;font-size:16px;font-weight:600;opacity:.9}.project-header-name{color:#fff;font-size:20px;font-weight:700;letter-spacing:-.3px}.grafik-card-content{overflow:visible;padding:0}.grafik-table-wrapper-single{-webkit-overflow-scrolling:touch;max-height:calc(100vh - 200px);overflow-x:auto;overflow-y:auto;position:relative}.grafik-table-single{background:#fff;border-collapse:initial;border-spacing:2px;font-size:13px;min-width:2000px;width:100%}.grafik-table-single thead{display:table-header-group}.grafik-table-single th{background:#f9fafb;font-size:11px;font-weight:600;letter-spacing:.3px;padding:10px 8px;white-space:nowrap}.grafik-table-single td,.grafik-table-single th{border:1px solid #e5e7eb;border-radius:8px;margin:2px;text-align:center}.grafik-table-single td{background:#fff;box-shadow:0 1px 2px #00000008;color:#111827;font-size:13px;padding:8px 6px;transition:all .2s ease;vertical-align:middle}.project-header-row-single th{background:linear-gradient(135deg,#4f46e5,#6366f1);box-shadow:0 2px 4px #4f46e533;color:#fff;font-size:14px;font-weight:700;padding:12px}.project-header-single,.project-name-header-single{padding-left:16px!important;text-align:left!important}.main-header-row-single th{background:linear-gradient(135deg,#4f46e5,#6366f1);box-shadow:0 1px 3px #4f46e526;color:#fff;letter-spacing:.3px;padding:12px 8px;text-shadow:0 1px 2px #00000026;top:0!important;z-index:10!important}.col-summary-header-single,.main-header-row-single th{font-size:12px;font-weight:700;position:-webkit-sticky!important;position:sticky!important;will-change:transform}.col-summary-header-single{background:linear-gradient(135deg,#059669,#10b981)!important;box-shadow:0 1px 3px #05966933;letter-spacing:.5px;text-transform:uppercase}.main-header-row-single .col-summary-header-single{top:0!important;z-index:9!important}.summary-header-row-single .col-summary-header-single{top:48px!important;z-index:8!important}.summary-header-row-single th{box-shadow:0 1px 3px #05966926;color:#fff;font-size:10px;font-weight:600;line-height:1.3;padding:8px 4px;text-align:center;white-space:normal;writing-mode:horizontal-tb}.empty-header-single,.summary-header-row-single th{background:linear-gradient(135deg,#059669,#10b981)!important;position:-webkit-sticky!important;position:sticky!important;top:48px!important;will-change:transform}.empty-header-single{border:1px solid #ffffff40!important;box-shadow:0 1px 2px #0596691a;z-index:7!important}.summary-header-row-single th.empty-header-single:first-child{left:0!important;z-index:8!important}.summary-header-row-single th.empty-header-single:nth-child(2){left:50px!important;z-index:8!important}.summary-header-row-single th.empty-header-single:nth-child(3){left:170px!important;z-index:8!important}.summary-header-row-single th.empty-header-static:nth-of-type(4){left:auto!important;z-index:7!important}.summary-header-row-single th.empty-header-static:not(:nth-of-type(4)){left:290px!important;z-index:8!important}.summary-header-row-single th.empty-header-single:has(.week-number-in-cell){left:auto!important;position:-webkit-sticky!important;position:sticky!important;z-index:6!important}.empty-header-single .week-number-in-cell{color:#fff;font-size:11px;font-weight:600;letter-spacing:.2px;text-shadow:0 1px 2px #0003}.col-no-single{font-size:12px;font-weight:700;left:0;max-width:50px;min-width:50px}.col-firstname-single,.col-lastname-single,.col-no-single{background:linear-gradient(135deg,#f8fafc,#f1f5f9)!important;border-right:2px solid #e2e8f0!important;color:#1e293b!important;position:-webkit-sticky!important;position:sticky!important;top:96px!important;will-change:transform;z-index:7!important}.col-firstname-single,.col-lastname-single{font-size:13px;font-weight:600;left:50px;min-width:120px;padding-left:12px!important;text-align:left!important}.col-lastname-single{left:170px}.col-user-single{min-width:120px}.col-position-single,.col-user-single{background:linear-gradient(135deg,#f8fafc,#f1f5f9)!important;border-right:2px solid #e2e8f0!important;color:#1e293b!important;font-size:13px;font-weight:600;padding-left:12px!important;position:-webkit-sticky!important;position:sticky!important;text-align:left!important;top:96px!important;will-change:transform;z-index:7!important}.col-position-single{min-width:140px}.col-contract-single{background:linear-gradient(135deg,#f8fafc,#f1f5f9)!important;border-right:2px solid #e2e8f0!important;color:#1e293b!important;min-width:120px}.col-contract-single,.col-shift-type-single{font-size:13px;font-weight:600;padding-left:12px!important;position:-webkit-sticky!important;position:sticky!important;text-align:left!important;top:96px!important;will-change:transform;z-index:7!important}.col-shift-type-single{background:linear-gradient(135deg,#fef3c7,#fde68a)!important;border-right:2px solid #fbbf24!important;color:#78350f!important;left:290px;min-width:200px}.col-date-single{font-size:11px;max-width:70px;min-width:70px;padding:10px 6px!important;position:-webkit-sticky!important;position:sticky!important;will-change:transform}.main-header-row-single .col-date-single{top:0!important;z-index:9!important}.summary-header-row-single .col-date-single{top:48px!important;z-index:8!important}.col-date-single .date-week-number{color:#ffffffd9;font-size:10px;font-weight:600;letter-spacing:.2px;margin-bottom:2px;opacity:.9;text-shadow:0 1px 2px #0003}.col-date-single .date-day-name{color:#fff;font-size:13px;font-weight:700;letter-spacing:.3px;margin-bottom:4px;text-shadow:0 1px 2px #0003}.col-date-single .date-day-number{color:#fff;font-size:11px;font-weight:500;opacity:.95;text-shadow:0 1px 2px #0003}.day-cell-single{background:#fff;border-radius:8px;box-shadow:0 1px 2px #00000008;margin:2px;padding:6px 4px!important;position:relative;text-align:center;transition:all .2s ease;vertical-align:middle}.day-cell-single.weekend{background:#f9fafb}.day-cell-single.holiday{background:linear-gradient(135deg,#fee2e2,#fecaca)!important;border:2px solid #ef4444!important;box-shadow:0 2px 4px #ef444433!important}.day-cell-single.has-absence{background:#e0f2fe}.day-cell-single.has-absence.has-shift-color{background:#e0f2feb3!important}.day-cell-single.has-shift-color{z-index:1}.grafik-table-single tbody .day-cell-single.has-absence.has-shift-color{border-left-style:solid!important;border-left-width:3px!important;border-right-style:solid!important;border-right-width:3px!important}.day-cell-single.day-off{background:#f3f4f6!important;opacity:.6;position:relative}.day-cell-single.day-off:before{background:repeating-linear-gradient(45deg,#0000,#0000 5px,#00000014 0,#00000014 10px);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.day-cell-single.day-off .day-off-label,.day-cell-single.day-off .shift-input-single{position:relative;z-index:1}.day-off-label{border-radius:6px;color:#9ca3af;cursor:text;display:inline-block;font-size:14px;font-weight:600;opacity:.7;padding:4px 8px;transition:all .2s ease}.day-cell-single.has-shift-color{position:relative}.day-cell-single.has-shift-color .shift-input-single{background:#ffffffe6;font-weight:600}.day-cell-single.has-shift-color .shift-input-single:focus{background:#fff;box-shadow:0 0 0 2px #0000001a}.shift-input-single::-webkit-inner-spin-button,.shift-input-single::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.shift-input-single{-webkit-appearance:textfield;appearance:textfield;background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-shadow:0 1px 2px #0000000d;color:#111827;display:inline-block;font-size:13px;font-weight:500;padding:6px 4px;text-align:center;transition:all .2s ease;width:calc(100% - 28px)}.input-with-absence-button{gap:4px}.input-with-absence-button,.input-without-absence-button{align-items:center;display:flex;width:100%}.input-without-absence-button .shift-input-single{width:100%}.absence-button{border:1.5px solid #d1d5db;border-radius:6px;color:#667eea;min-height:24px;min-width:24px;padding:0}.overtime-indicator-button{align-items:center;background:#fb71851a;border:1.5px solid #fb7185;border-radius:6px;color:#be123c;cursor:pointer;display:flex;font-size:12px;font-weight:700;height:24px;justify-content:center;min-height:24px;min-width:24px;padding:0;transition:all .2s ease;width:24px}.overtime-indicator-button:hover{background:#fb718533;border-color:#be123c;transform:scale(1.05)}.has-overtime{background:#fb718533!important}.absence-button:hover{background:#667eea;box-shadow:0 2px 4px #667eea4d;color:#fff;transform:translateY(-1px)}.absence-button:active{box-shadow:0 1px 2px #667eea33;transform:translateY(0)}.absence-button svg{stroke:currentColor;height:14px;width:14px}.shift-input-single:hover{border-color:#6366f1;box-shadow:0 2px 4px #6366f126;transform:translateY(-1px)}.shift-input-single:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a,0 2px 4px #00000014;outline:none;transform:translateY(-1px)}.absence-label-single{background:#3b82f61a;border-radius:8px;box-shadow:0 1px 2px #0000000d;color:#1e40af;display:inline-block;font-size:12px;font-weight:700;letter-spacing:.5px;padding:6px 8px;transition:all .2s ease}.absence-label-single:hover{background:#3b82f626;box-shadow:0 2px 4px #00000014;transform:translateY(-1px)}.shift-row-single.shiftAfternoon .day-cell-single:not(.has-absence),.shift-row-single.shiftDay .day-cell-single:not(.has-absence),.shift-row-single.shiftNight .day-cell-single:not(.has-absence){background:#fff}.shift-row-single.overtimeDay .day-cell-single:not(.has-absence),.shift-row-single.overtimeNight .day-cell-single:not(.has-absence){background:#fef2f2}.shift-row-single.employee-first-row-single{border-top:3px solid #9ca3af!important}.shift-row-single.employee-last-row-single{border-bottom:3px solid #9ca3af!important}.shift-row-single.employee-first-row-single td{border-top:3px solid #9ca3af!important}.shift-row-single.employee-last-row-single td{border-bottom:3px solid #9ca3af!important}.shift-row-single.overtime-first-row,.shift-row-single.overtime-first-row td{border-top:3px solid #dc2626!important;position:relative}.shift-row-single.overtime-row{background:#fef2f2}.shift-row-single.overtime-row .col-shift-label-single{background:#fee2e2!important;border-right:2px solid #dc2626!important;color:#991b1b!important;font-weight:700!important;left:290px!important;position:-webkit-sticky!important;position:sticky!important;z-index:8!important}.shift-row-single.overtime-row .day-cell-single{background:#fef2f2}.shift-row-single.overtime-row:hover,.shift-row-single.overtime-row:hover .day-cell-single{background:#fee2e2}.shift-row-single.overtime-row:hover .col-shift-label-single{background:#fecaca!important;left:290px!important;position:-webkit-sticky!important;position:sticky!important;z-index:8!important}.col-shift-label-single{background:linear-gradient(135deg,#fef3c7,#fde68a)!important;border-right:2px solid #d1d5db!important;color:#111827!important;font-size:13px;font-weight:600;left:290px;min-width:200px;padding-left:12px!important;position:-webkit-sticky!important;position:sticky!important;text-align:left!important;top:96px!important;will-change:transform;z-index:7!important}.summary-cell-single{background:#f0fdf4!important;color:#111827;font-size:13px;font-weight:600;min-width:90px;padding:8px 6px!important;text-align:center}.summary-col-single{font-size:10px;font-weight:600;left:auto!important;line-height:1.3;min-width:110px;padding:10px 6px!important;position:-webkit-sticky!important;position:sticky!important;z-index:6!important}.grafik-table-single tbody tr:hover{background-color:#f9fafb}.grafik-table-single tbody tr:hover .col-contract-single,.grafik-table-single tbody tr:hover .col-firstname-single,.grafik-table-single tbody tr:hover .col-lastname-single,.grafik-table-single tbody tr:hover .col-no-single,.grafik-table-single tbody tr:hover .col-position-single,.grafik-table-single tbody tr:hover .col-user-single{background:linear-gradient(135deg,#e2e8f0,#cbd5e1)!important}.grafik-table-single tbody tr:hover .col-shift-label-single{background:linear-gradient(135deg,#fde68a,#fcd34d)!important}.employee-card{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;overflow:hidden;transition:all .3s ease}.employee-card:hover{box-shadow:0 8px 32px #0000001f,0 2px 6px #00000014;transform:translateY(-2px)}.employee-card-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px}.employee-card-info{align-items:center;display:flex;gap:16px}.employee-card-number{align-items:center;background:#fff3;border-radius:12px;display:flex;flex-shrink:0;font-size:20px;font-weight:700;height:48px;justify-content:center;width:48px}.employee-card-name{flex:1 1}.employee-card-name-main{font-size:20px;font-weight:700;letter-spacing:-.3px;margin-bottom:6px}.employee-card-name-details{align-items:center;display:flex;font-size:14px;font-weight:500;gap:8px;opacity:.9}.employee-card-separator{opacity:.6}.employee-card-content{overflow-x:auto;padding:0}.grafik-table-wrapper-card{-webkit-overflow-scrolling:touch;overflow-x:auto;overflow-y:visible}.grafik-table-card{background:#fff;border-collapse:collapse;font-size:13px;min-width:1800px;width:100%}.grafik-table-card thead{position:-webkit-sticky;position:sticky;top:0;z-index:10}.grafik-table-card th{background:#f9fafb;border:1px solid #e5e7eb;font-size:11px;font-weight:600;letter-spacing:.3px;padding:10px 8px;text-align:center;white-space:nowrap}.grafik-table-card td{background:#fff;border:1px solid #e5e7eb;color:#111827;font-size:13px;padding:8px 6px;text-align:center;vertical-align:middle}.card-header-row th{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:12px;font-weight:700;letter-spacing:.3px;padding:12px 8px;text-shadow:0 1px 2px #0003}.col-shift-type-card{background:linear-gradient(135deg,#667eea,#764ba2)!important;left:0;min-width:180px;padding-left:12px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:11}.col-date-card{font-size:11px;max-width:70px;min-width:70px;padding:10px 6px!important}.col-date-card .date-day-name{color:#fff;font-size:13px;font-weight:700;letter-spacing:.3px;margin-bottom:4px;text-shadow:0 1px 2px #0003}.col-date-card .date-day-number{color:#fff;font-size:11px;font-weight:500;opacity:.95;text-shadow:0 1px 2px #0003}.col-summary-header-card{background:linear-gradient(135deg,#10b981,#059669)!important;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.summary-header-row-card th{background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:10px;font-weight:600;line-height:1.3;padding:8px 4px;text-align:center;white-space:normal;writing-mode:horizontal-tb}.empty-header-card{background:linear-gradient(135deg,#10b981,#059669)!important;border:1px solid #fff3!important}.summary-col-card{font-size:10px;font-weight:600;line-height:1.3;min-width:110px;padding:10px 6px!important}.col-shift-label-card{background:#f3f4f6!important;border-right:2px solid #d1d5db!important;color:#111827!important;font-size:13px;font-weight:600;left:0;min-width:180px;padding-left:12px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:8}.day-cell-card{background:#fff;padding:6px 4px!important;text-align:center;vertical-align:middle}.day-cell-card.weekend{background:#f9fafb}.day-cell-card.holiday{background:#fef2f2}.day-cell-card.has-absence{background:#e0f2fe}.shift-input-card{background:#fff;border:1.5px solid #d1d5db;border-radius:4px;color:#111827;font-size:13px;font-weight:500;padding:6px 4px;text-align:center;transition:all .2s ease;width:100%}.shift-input-card:hover{border-color:#667eea}.shift-input-card:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.absence-label-card{background:#dbeafe;border-radius:4px;color:#1e40af;display:inline-block;font-size:12px;font-weight:700;letter-spacing:.3px;padding:6px 8px}.shift-row-card.shiftDay .day-cell-card:not(.has-absence){background:#f0fdf4}.shift-row-card.shiftAfternoon .day-cell-card:not(.has-absence){background:#fef3c7}.shift-row-card.shiftNight .day-cell-card:not(.has-absence){background:#e0e7ff}.shift-row-card.overtimeDay .day-cell-card:not(.has-absence),.shift-row-card.overtimeNight .day-cell-card:not(.has-absence){background:#fef2f2}.summary-cell-card{background:#f0fdf4!important;color:#111827;font-size:13px;font-weight:600;min-width:90px;padding:8px 6px!important;text-align:center}.grafik-table-card tbody tr:hover{background-color:#f9fafb}.grafik-table-card tbody tr:hover .col-shift-label-card{background:#e5e7eb!important}.report-modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.report-modal-content{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;overflow:hidden;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.report-modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e5e7eb;color:#fff;display:flex;justify-content:space-between;padding:24px}.report-modal-header h3{font-size:20px;font-weight:700;margin:0}.report-modal-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:32px}.report-modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}.report-modal-body{padding:24px}.report-modal-info{margin-bottom:24px}.report-modal-info p{color:#6b7280;font-size:14px;line-height:1.6;margin:0 0 12px}.report-modal-info p:last-child{margin-bottom:0}.report-modal-month,.report-modal-project{color:#374151;font-size:15px}.report-modal-form{display:flex;flex-direction:column;gap:16px}.report-modal-form label{color:#374151;font-size:14px;font-weight:600}.required-asterisk{color:#ef4444}.contract-type-select{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;color:#111827;cursor:pointer;font-size:15px;padding:12px 16px;transition:all .2s ease}.contract-type-select:hover{border-color:#9ca3af}.contract-type-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.report-modal-preview{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;margin-top:8px;padding:12px 16px}.report-modal-preview p{color:#0369a1;font-size:14px;line-height:1.5;margin:0}.report-modal-footer{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.report-modal-cancel,.report-modal-generate{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.report-modal-cancel{background:#f3f4f6;color:#374151}.report-modal-cancel:hover{background:#e5e7eb}.report-modal-generate{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 4px #10b9814d;color:#fff}.report-modal-generate:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px #10b98166;transform:translateY(-1px)}.report-modal-generate:disabled{cursor:not-allowed;opacity:.5;transform:none}.grafik2-container{box-sizing:border-box;padding:20px;width:100%}.grafik2-header{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;padding:20px}.grafik2-filters{align-items:flex-end;display:flex;flex-wrap:wrap;gap:20px}.filter-group{gap:8px}.filter-group label{color:#374151;font-size:14px;font-weight:500}.filter-select{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#111827;min-width:200px;padding:10px 14px;transition:all .2s}.filter-select:hover{border-color:#9ca3af}.filter-select:focus{box-shadow:0 0 0 3px #667eea1a}.month-navigation{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:12px;padding:8px 12px}.month-nav-button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;transition:all .2s;width:32px}.month-nav-button:hover{background:#f3f4f6;border-color:#9ca3af}.month-nav-button:active{transform:scale(.95)}.month-display{color:#111827;font-size:16px;font-weight:600;min-width:180px;text-align:center}.grafik2-message{color:#6b7280;padding:40px;text-align:center}.grafik2-message,.grafik2-table-wrapper{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.grafik2-table-wrapper{overflow-x:auto;padding:20px}.grafik2-table{border-collapse:collapse;min-width:800px;width:100%}.grafik2-table thead{background:#f9fafb;position:-webkit-sticky;position:sticky;top:0;z-index:10}.grafik2-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-size:12px;font-weight:600;padding:12px 8px;text-align:center;white-space:nowrap}.employee-column{background:#f9fafb;left:0;max-width:400px;min-width:300px;padding-left:16px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:11}.day-header{max-width:80px;min-width:80px;padding:8px 4px!important}.day-header.weekend{background:#fef2f2}.day-header.empty{background:#0000;border:none}.day-header-content{display:flex;flex-direction:column;gap:4px}.day-name{color:#6b7280;font-size:11px;text-transform:uppercase}.day-number{color:#111827;font-size:16px;font-weight:700}.day-month{color:#9ca3af;font-size:10px;margin-top:2px}.summary-column{font-weight:700;min-width:100px;text-align:center;vertical-align:middle}.summary-hours-header{background:#e0f2fe!important;color:#0369a1}.summary-overtime-daily-header{background:#f3f4f6!important;border-left:2px solid #d1d5db;color:#374151}.summary-overtime-night-header{background:#f9fafb!important;border-left:2px solid #9ca3af;color:#1f2937}.summary-overtime-saturday-header{background:#fef3c7!important;border-left:2px solid #fbbf24;color:#92400e}.summary-overtime-sunday-header{background:#fee2e2!important;border-left:2px solid #ef4444;color:#991b1b}.summary-absence-header{background:#fef3c7!important;color:#92400e}.summary-label-small{color:#6b7280;display:block;font-size:10px;font-weight:400;margin-top:4px}.grafik2-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s}.grafik2-table tbody tr:hover{background:#f9fafb}.employee-cell{background:#fff;border-right:2px solid #e5e7eb;left:0;overflow:hidden;padding:12px 16px!important;position:-webkit-sticky;position:sticky;text-overflow:ellipsis;white-space:nowrap;z-index:9}.employee-row:hover .employee-cell{background:#f9fafb}.employee-cell.employee-cell-selected{background-color:#dbeafe!important;border-right:2px solid #3b82f6}.employee-row:hover .employee-cell.employee-cell-selected{background-color:#bfdbfe!important}.employee-info{align-items:center;display:flex!important;flex-direction:row!important;gap:8px;overflow:hidden;white-space:nowrap!important;width:100%}.employee-name{color:#111827;flex-shrink:1;font-size:14px;font-weight:600;max-width:200px;min-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.employee-separator{color:#9ca3af;flex-shrink:0;font-size:12px;text-align:center;width:6px}.employee-position{color:#6b7280;font-weight:500;max-width:100px;min-width:80px}.employee-position,.employee-user{flex-shrink:0;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.employee-user{color:#4b5563;max-width:120px;min-width:100px}.employee-contract{color:#6b7280;flex-shrink:1;font-size:12px;font-weight:500;min-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-cell{max-width:60px;min-width:60px;padding:8px 4px!important;position:relative;text-align:center;-webkit-user-select:none;user-select:none;vertical-align:middle}.day-cell.weekend{background:#fef2f2}.day-cell.has-absence{font-weight:600}.day-cell.overtime-normal-cell{background-color:#fed7aa!important}.day-cell.overtime-normal-cell:hover{background-color:#fdba74!important}.day-cell.overtime-premium-cell{background-color:#fecaca!important}.day-cell.overtime-premium-cell:hover{background-color:#fca5a5!important}.day-cell.weekend.overtime-normal-cell{background-color:#fed7aa!important}.day-cell.weekend.overtime-premium-cell{background-color:#fecaca!important}.cell-content{align-items:center;display:flex;justify-content:center;min-height:40px;-webkit-user-select:none;user-select:none}.day-cell.cell-selected{background-color:#dbeafe!important;border:none!important;border-radius:4px}.day-cell.cell-selected:hover{background-color:#bfdbfe!important}.cell-actions{align-items:center;display:flex;gap:4px;justify-content:center;width:100%}.hours-display-wrapper{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:35px}.hours-display{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#111827;cursor:pointer;font-size:13px;font-weight:500;padding:6px 4px;text-align:center;transition:all .2s}.overtime-badge{align-items:center;background:#fee2e2;border:1px solid #fecaca;border-radius:4px;color:#dc2626;display:inline-flex;font-size:10px;font-weight:700;gap:2px;padding:2px 6px;text-align:center}.overtime-badge.overtime-premium{background-color:#8b0000;border-color:#8b0000;color:#fff}.overtime-premium-mark{color:gold;font-size:.7rem}.hours-display:hover{background:#f0f4ff;border-color:#667eea}.hours-input{background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-weight:500;padding:6px 4px;text-align:center;width:100%}.hours-input,.hours-input:focus{outline:none!important;outline-width:0!important}.hours-input:focus{-webkit-appearance:none;appearance:none;border:1px solid #d1d5db;box-shadow:none!important}.hours-input:focus-visible{box-shadow:none!important;outline:none!important;outline-width:0!important}.absence-button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;font-size:16px;font-weight:600;height:24px;justify-content:center;transition:all .2s;width:24px}.absence-button:hover{background:#f0f4ff;border-color:#667eea;color:#667eea}.absence-badge{align-items:center;border:2px solid #0000;border-radius:6px;cursor:pointer;display:flex;justify-content:center;padding:8px 4px;transition:all .2s;width:100%}.absence-badge:hover{border-color:#0000001a;transform:scale(1.05)}.absence-icon{font-size:18px}.summary-cell{font-size:14px;font-weight:600;padding:12px 8px!important;text-align:center}.hours-summary{background:#dbeafe!important;border-left:2px solid #3b82f6;color:#1e40af}.overtime-summary{font-weight:700}.overtime-daily-summary,.overtime-summary{background:#f3f4f6!important;border-left:2px solid #d1d5db;color:#374151}.overtime-night-summary{background:#f9fafb!important;border-left:2px solid #9ca3af;color:#1f2937}.overtime-saturday-summary{background:#fef3c7!important;border-left:2px solid #fbbf24;color:#92400e}.overtime-sunday-summary{background:#fee2e2!important;border-left:2px solid #ef4444;color:#991b1b}.absence-summary{background:#fef3c7!important}.absence-type-summary,.summary-absence-type-header{border-left:2px solid #0000001a;font-weight:600}.absence-type-summary{color:#92400e}.option-modal{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:500px;width:100%}.option-modal-content{padding:24px}.option-modal-instruction{color:#6b7280;font-size:14px;margin:0 0 20px;text-align:center}.option-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.option-button{align-items:center;border:2px solid;border-radius:12px;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:12px;padding:16px 20px;text-align:left;transition:all .2s;width:100%}.option-button:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.option-button:active{transform:translateY(0)}.overtime-button{background:#dbeafe;border-color:#3b82f6;color:#1e40af}.overtime-button:hover{background:#bfdbfe;border-color:#2563eb}.absence-button-modal{background:#d1fae5;border-color:#10b981;color:#065f46}.absence-button-modal:hover{background:#a7f3d0;border-color:#059669}.option-icon{flex-shrink:0;font-size:24px}.option-label{font-weight:600}.modal-actions{margin-top:20px}.btn-cancel,.btn-confirm{border:1px solid;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.btn-cancel{background:#fff;border-color:#d1d5db;color:#374151}.btn-cancel:hover{background:#f9fafb;border-color:#9ca3af}.btn-confirm{background:#3b82f6;border-color:#3b82f6;color:#fff}.btn-confirm:hover{background:#2563eb;border-color:#2563eb}.modal-overlay{background:#00000080}.absence-modal{max-height:90vh;max-width:600px;overflow-y:auto}.absence-modal,.overtime-modal{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%}.overtime-modal{max-width:400px}.overtime-modal-content{padding:24px}.overtime-modal-instruction{color:#6b7280;font-size:14px;margin:0 0 20px;text-align:center}.overtime-input-group{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:24px}.overtime-split-inputs{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}.overtime-split-inputs .overtime-input-group{align-items:flex-start;display:flex;flex-direction:column;gap:8px;justify-content:flex-start;margin-bottom:0}.overtime-split-inputs .overtime-input-group label{color:#374151;font-size:14px;font-weight:500}.overtime-split-inputs .overtime-input-group .overtime-input{width:100%}.overtime-input{border:2px solid #d1d5db;border-radius:8px;font-size:18px;font-weight:600;outline:none;padding:12px 16px;text-align:center;transition:all .2s;width:120px}.overtime-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.overtime-unit{color:#6b7280;font-size:16px;font-weight:500}.modal-header{border-bottom:1px solid #e5e7eb;gap:12px;padding:20px 24px}.modal-header h3{color:#111827;flex:1 1;font-size:20px;font-weight:700;text-align:center}.modal-back{align-items:center;background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;font-size:24px;font-weight:600;height:32px;justify-content:center;transition:all .2s;width:32px}.modal-back:hover{background:#e5e7eb;color:#111827}.modal-close{background:#f3f4f6;border-radius:8px;color:#6b7280;flex-shrink:0;font-size:20px}.modal-close:hover{background:#e5e7eb;color:#111827}.absence-types-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));padding:24px}.absence-type-button{align-items:center;background:#fff;border:2px solid;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;font-weight:500;gap:8px;padding:16px 12px;transition:all .2s}.absence-type-button:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.absence-type-button:active{transform:translateY(0)}.absence-type-icon{font-size:24px}.absence-type-label{font-size:13px;text-align:center}.absence-type-button.remove-absence{background:#fee2e2;border-color:#ef4444;color:#dc2626;grid-column:1/-1}.absence-type-button.remove-absence:hover{background:#fecaca}@media (max-width:1366px){.grafik2-container{padding:15px}.day-cell,.day-header{max-width:70px;min-width:70px}}@media (max-width:1024px){.grafik2-filters{flex-direction:column;gap:15px}.filter-select{min-width:100%}.day-cell,.day-header{max-width:60px;min-width:60px}.absence-types-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media (max-width:768px){.grafik2-container{padding:10px}.grafik2-header{padding:15px}.grafik2-table-wrapper{padding:10px}.day-cell,.day-header{max-width:50px;min-width:50px;padding:6px 2px!important}.employee-column{min-width:120px}.hours-display{font-size:11px;padding:4px 6px}.absence-types-grid{grid-template-columns:repeat(2,1fr);padding:16px}}@media (max-width:480px){.month-display{font-size:14px;min-width:140px}.day-name{font-size:10px}.day-number{font-size:14px}.absence-types-grid{grid-template-columns:1fr}}.wgraj-dane-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:calc(100vh - 200px);padding:40px 20px}.wgraj-dane-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;margin:0 auto;max-width:800px;padding:40px}.wgraj-dane-title{color:#1a202c;font-size:32px;font-weight:700;margin-bottom:12px;text-align:center}.wgraj-dane-description{color:#718096;font-size:16px;line-height:1.6;margin-bottom:24px;text-align:center}.instructions-box{background:linear-gradient(135deg,#eef2ff,#f0f9ff);border:2px solid #c7d2fe;border-radius:12px;margin-bottom:32px;padding:24px}.instructions-title{align-items:center;color:#1a202c;display:flex;font-size:18px;font-weight:600;gap:8px;margin:0 0 16px}.instructions-list{color:#4a5568;line-height:1.8;margin:0 0 16px;padding-left:24px}.instructions-list li{margin-bottom:8px}.instructions-list li strong{color:#1a202c}.instructions-note{background-color:#fff;border-left:4px solid #667eea;border-radius:8px;color:#4a5568;font-size:14px;line-height:1.6;margin:0;padding:12px 16px}.wgraj-dane-form{display:flex;flex-direction:column;gap:24px}.form-label{align-items:center;color:#2d3748;display:flex;font-size:15px}.required-asterisk{color:#e53e3e;margin-left:4px}.form-select{background-color:#fff;border:2px solid #e2e8f0;color:#2d3748;cursor:pointer;font-size:15px;padding:12px 16px;transition:all .2s}.form-select:hover:not(:disabled){border-color:#667eea}.form-select:focus{box-shadow:0 0 0 3px #667eea1a}.form-select:disabled{background-color:#f7fafc;cursor:not-allowed;opacity:.6}.file-input-wrapper{display:flex;flex-direction:column;gap:12px}.file-input{background-color:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:15px;padding:12px 16px;transition:all .2s;width:100%}.file-input:focus,.file-input:hover:not(:disabled){border-color:#667eea}.file-input:focus{box-shadow:0 0 0 3px #667eea1a;outline:none}.file-input:disabled{background-color:#f7fafc;cursor:not-allowed;opacity:.6}.file-info{align-items:center;background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:12px;padding:12px 16px}.file-name{color:#2d3748;flex:1 1;font-size:15px}.file-size{color:#718096;font-size:14px}.upload-status{align-items:center;border-radius:8px;display:flex;font-size:15px;font-weight:500;gap:8px;padding:16px 20px}.upload-status.success{background-color:#c6f6d5;border:1px solid #9ae6b4;color:#22543d}.upload-status.error{background-color:#fed7d7;border:1px solid #fc8181;color:#742a2a}.form-actions{gap:12px;margin-top:8px}.btn-upload{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 12px #667eea66;color:#fff;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:14px 24px;transition:all .2s}.btn-upload:hover:not(:disabled){box-shadow:0 6px 16px #667eea80;transform:translateY(-2px)}.btn-upload:active:not(:disabled){transform:translateY(0)}.btn-upload:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-reset{background-color:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#2d3748;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;transition:all .2s}.btn-reset:hover:not(:disabled){background-color:#f7fafc;border-color:#cbd5e0}.btn-reset:disabled{cursor:not-allowed;opacity:.6}.no-projects-message{background-color:#fff5f5;border:1px solid #fc8181;border-radius:8px;margin-top:24px;padding:20px;text-align:center}.no-projects-message p{color:#742a2a;font-size:15px;margin:0}.kpi-info-box{background-color:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;margin-top:8px;padding:20px}.kpi-info-title{color:#1a202c;font-size:16px;font-weight:600;margin:0 0 12px}.kpi-list-preview{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.kpi-preview-item{align-items:center;background-color:#fff;border:1px solid #c7d2fe;border-radius:6px;display:inline-flex;font-size:14px;gap:6px;padding:6px 12px}.kpi-preview-name{color:#1a202c;font-weight:500}.kpi-preview-unit{color:#667eea;font-size:12px}.kpi-info-note{color:#4a5568;font-size:13px;font-style:italic;margin:0}.kpi-warning-box{background-color:#fff5f5;border:1px solid #fc8181;border-radius:8px;margin-top:8px;padding:16px 20px}.kpi-warning-box p{color:#742a2a;font-size:14px;margin:4px 0}.file-parsed-info{background-color:#eef2ff;border-radius:6px;color:#4a5568;font-size:13px;margin-top:12px;padding:12px}.file-parsed-info p{margin:4px 0}.mapping-section{margin-top:16px}.btn-mapping{background-color:#eef2ff;border:2px solid #c7d2fe;border-radius:8px;color:#667eea;cursor:pointer;font-size:15px;font-weight:600;padding:12px 20px;transition:all .2s;width:100%}.btn-mapping:hover{background-color:#e0e7ff;border-color:#a5b4fc}.kpi-results-section{background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:24px;padding:20px}.kpi-results-title{color:#1a202c;font-size:18px;font-weight:600;margin:0 0 16px}.kpi-results-list{display:flex;flex-direction:column;gap:12px}.kpi-result-item{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.kpi-result-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.kpi-result-name{color:#1a202c;font-size:15px;font-weight:600}.kpi-result-value{color:#667eea;font-size:16px;font-weight:700}.kpi-result-error{color:#e53e3e;font-size:14px}.kpi-result-target{color:#4a5568;font-size:13px;margin-top:4px}.kpi-target-met{color:#38a169;font-weight:600}.kpi-target-not-met{color:#e53e3e;font-weight:600}.kpi-result-datapoints{color:#718096;font-size:12px;font-style:italic;margin-top:4px}.mapping-modal{max-height:90vh;max-width:800px}.mapping-description{color:#4a5568;font-size:14px;line-height:1.6;margin-bottom:16px}.mapping-example-box{background-color:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;color:#1e40af;font-size:13px;line-height:1.6;margin-bottom:20px;padding:16px}.mapping-example-box strong{color:#1e3a8a;display:block;margin-bottom:8px}.mapping-example-box ul{margin:8px 0 0;padding-left:20px}.mapping-example-box li{margin-bottom:4px}.mapping-list{gap:16px;max-height:calc(90vh - 250px);overflow-y:auto}.mapping-item,.mapping-list{display:flex;flex-direction:column}.mapping-item{background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;gap:12px;padding:16px}.mapping-label{color:#2d3748;font-size:14px}.mapping-label strong{color:#1a202c}.mapping-unit{color:#667eea;font-size:12px;margin-left:4px}.mapping-select{background-color:#fff;border:2px solid #e2e8f0;border-radius:6px;color:#2d3748;cursor:pointer;font-size:14px;padding:10px 12px;transition:all .2s}.mapping-select:hover{border-color:#667eea}.mapping-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.mapping-columns-list,.mapping-columns-section{display:flex;flex-direction:column;gap:8px}.mapping-column-item{align-items:center;display:flex;gap:8px}.mapping-column-item .mapping-select{flex:1 1}.btn-remove-column{background-color:#fed7d7;border:1px solid #fc8181;border-radius:6px;color:#742a2a;cursor:pointer;font-size:16px;font-weight:600;min-width:36px;padding:8px 12px;transition:all .2s}.btn-remove-column:hover{background-color:#fc8181;color:#fff}.btn-add-column{background-color:#eef2ff;border:2px solid #c7d2fe;border-radius:6px;color:#667eea;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s;width:-webkit-fit-content;width:fit-content}.btn-add-column:hover{background-color:#e0e7ff;border-color:#a5b4fc}.mapping-operation-section{border-top:1px solid #e2e8f0;display:flex;flex-direction:column;gap:8px;margin-top:8px;padding-top:12px}.mapping-operation-label{color:#4a5568;font-size:13px;font-weight:600}.mapping-operation-hint{color:#718096;font-size:11px;font-style:italic;margin-top:4px}.mapping-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.btn-toggle-advanced{background-color:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;color:#667eea;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s}.btn-toggle-advanced:hover{background-color:#e0e7ff;border-color:#a5b4fc}.column-label{color:#4a5568;font-size:12px;font-weight:600;min-width:80px}.mapping-formula-section{background-color:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;margin-top:12px;padding:12px}.mapping-formula-label{color:#1e40af;display:block;font-size:13px;font-weight:600;margin-bottom:8px}.mapping-formula-input{background-color:#fff;border:2px solid #bae6fd;border-radius:6px;color:#1e3a8a;font-family:Courier New,monospace;font-size:14px;margin-bottom:8px;padding:10px 12px;width:100%}.mapping-formula-input:focus{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a;outline:none}.mapping-formula-examples{color:#1e40af;font-size:11px;margin-top:8px}.mapping-formula-examples ul{margin:4px 0 0;padding-left:20px}.mapping-formula-examples code{background-color:#fff;border-radius:4px;font-family:Courier New,monospace;font-size:11px;padding:2px 6px}.mapping-advanced-section{background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:16px;margin-top:16px;padding:16px}.filters-list,.mapping-aggregation-section,.mapping-filters-section,.mapping-groupby-section{display:flex;flex-direction:column;gap:8px}.filter-item{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.filter-column{flex:2 1;min-width:150px}.filter-operator{flex:1 1;min-width:120px}.filter-value{flex:1 1;min-width:100px}.mapping-preview{background-color:#fff;border:1px solid #e2e8f0;border-radius:4px;color:#718096;font-size:12px;font-style:italic;margin-top:8px;padding:8px 12px}.kpi-result-grouped{border:2px solid #c7d2fe}.kpi-result-grouped-label{color:#667eea;font-size:12px;font-weight:500;margin-left:8px}.kpi-result-groups{display:flex;flex-direction:column;gap:8px;margin-top:12px}.kpi-result-group-item{background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;padding:12px}.kpi-result-group-header{align-items:center;display:flex;justify-content:space-between}.kpi-result-group-name{color:#4a5568;font-size:14px;font-weight:600}.kpi-result-target-note{border-top:1px solid #e2e8f0;color:#4a5568;font-size:13px;margin-top:12px;padding-top:12px}.visualization-controls{margin:24px 0;text-align:center}.btn-visualization{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 6px #0000001a;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s}.btn-visualization:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-2px)}.powerbi-dashboard{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px;box-shadow:0 8px 16px #0000001a;margin-top:32px;padding:24px}.dashboard-header{margin-bottom:24px;text-align:center}.dashboard-header h3{color:#1a202c;font-size:24px;font-weight:700;margin-bottom:8px}.dashboard-header p{color:#718096;font-size:14px}.slicers-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:32px;padding:20px}.slicers-section h4{color:#2d3748;font-size:18px;font-weight:600;margin-bottom:16px}.slicers-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.slicer-item{display:flex;flex-direction:column;gap:8px}.slicer-label{color:#4a5568;font-size:14px;font-weight:600}.slicer-select{background:#fff;border:2px solid #e2e8f0;border-radius:6px;font-size:14px;max-height:200px;min-height:100px;padding:8px 12px}.slicer-item small{color:#718096;font-size:11px;font-style:italic}.kpi-cards-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.kpi-card{background:#fff;border-left:4px solid #cbd5e0;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:24px;transition:all .3s}.kpi-card:hover{box-shadow:0 8px 12px #00000026;transform:translateY(-4px)}.kpi-card.target-met{background:linear-gradient(135deg,#f0fff4,#fff);border-left-color:#48bb78}.kpi-card.target-not-met{background:linear-gradient(135deg,#fff5f5,#fff);border-left-color:#f56565}.kpi-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.kpi-card-name{color:#2d3748;font-size:16px;font-weight:600}.kpi-card-unit{background:#edf2f7;border-radius:4px;color:#718096;font-size:12px;padding:4px 8px}.kpi-card-value{color:#1a202c;font-size:36px;font-weight:700;margin-bottom:12px}.kpi-card-target{color:#4a5568;font-size:14px;margin-bottom:8px}.kpi-card-footer{border-top:1px solid #e2e8f0;color:#718096;font-size:12px;padding-top:12px}.pivot-table-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-top:32px;padding:20px}.pivot-table-section h4{color:#2d3748;font-size:18px;font-weight:600;margin-bottom:16px}.pivot-controls{display:flex;flex-wrap:wrap;gap:12px}.pivot-select{background:#fff;border:2px solid #e2e8f0;border-radius:6px;flex:1 1;font-size:14px;min-width:150px;padding:10px 12px}.dax-functions-help{background-color:#eef2ff;border-radius:6px;color:#1e40af;font-size:12px;line-height:1.6;margin-top:12px;padding:12px}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:24px}.modal-header h3{color:#1a202c;font-size:24px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.modal-close:hover{background-color:#f7fafc;color:#2d3748}.modal-body{padding:24px}.modal-actions{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:24px}.btn-cancel,.btn-save{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-cancel{background-color:#fff;border:2px solid #e2e8f0;color:#2d3748}.btn-cancel:hover{background-color:#f7fafc;border-color:#cbd5e0}.btn-save{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea66;color:#fff}.btn-save:hover{box-shadow:0 6px 16px #667eea80;transform:translateY(-2px)}@media (max-width:768px){.wgraj-dane-container{padding:20px 16px}.wgraj-dane-card{padding:24px}.wgraj-dane-title{font-size:24px}.wgraj-dane-description{font-size:14px}.form-actions{flex-direction:column}.btn-reset,.btn-upload{width:100%}}.przegladaj-kpi-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:calc(100vh - 80px);padding:20px}.przegladaj-kpi-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;margin:0 auto;max-width:1400px;padding:30px}.przegladaj-kpi-title{color:#333;font-size:28px;font-weight:700;margin-bottom:10px}.przegladaj-kpi-description{color:#666;font-size:16px;margin-bottom:30px}.form-group{margin-bottom:25px}.form-label{display:block;margin-bottom:8px}.form-select{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:12px 15px;transition:border-color .3s;width:100%}.form-select:focus{border-color:#667eea;outline:none}.loading-message,.no-data-message{color:#666;font-size:16px;padding:40px;text-align:center}.kpi-data-table-wrapper{margin-top:30px;overflow-x:auto}.kpi-data-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;width:100%}.kpi-data-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.kpi-data-table th{font-size:14px;font-weight:600;letter-spacing:.5px;padding:15px;text-align:left;text-transform:uppercase}.kpi-data-table td{border-bottom:1px solid #f0f0f0;font-size:14px;padding:15px}.kpi-data-table tbody tr:hover{background:#f8f9fa}.kpi-data-table tbody tr:last-child td{border-bottom:none}.kpi-unit{color:#666;font-size:12px;font-weight:400}.kpi-value{color:#333;font-size:18px;font-weight:700}.kpi-value.target-met{color:#27ae60}.kpi-target{color:#666;font-size:12px;margin-top:4px}.file-name{color:#333;display:block;font-weight:500}.file-size{color:#999;font-size:12px;margin-top:4px}.btn-details{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:background .3s}.btn-details:hover{background:#5568d3}.kpi-summary{background:#f8f9fa;border-radius:8px;margin-top:30px;padding:20px}.kpi-summary h3{color:#333;font-size:20px;margin-bottom:15px;margin-top:0}.kpi-summary p{color:#666;font-size:14px;margin:8px 0}.kpi-summary strong{color:#333;font-weight:600}.quality-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:calc(100vh - 80px);padding:20px}.quality-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;margin:0 auto;max-width:1400px;padding:30px}.quality-title{color:#333;font-size:28px;font-weight:700;margin-bottom:10px}.quality-description{color:#666;font-size:16px;margin-bottom:30px}.quality-form{gap:20px}.form-group,.quality-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-label{color:#333;font-size:14px;font-weight:600}.required-asterisk{color:#e74c3c}.form-input,.form-select,.form-textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 16px;transition:border-color .3s}.content-editable:focus,.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#667eea;outline:none}.content-editable,.form-textarea{min-height:100px;resize:vertical}.content-editable{background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 16px;transition:border-color .3s}.content-editable:empty:before{color:#999;content:attr(data-placeholder);pointer-events:none}.content-editable:focus{border-color:#667eea;outline:none}.form-actions{gap:15px;margin-top:10px}.btn-reset,.btn-submit{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-submit:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-reset{background:#f3f4f6;color:#333}.btn-reset:hover{background:#e5e7eb}.btn-edit-alert{align-items:center;background:#f3f4f6;border:none;border-radius:6px;color:#333;cursor:pointer;display:flex;font-size:16px;justify-content:center;line-height:1;padding:6px 12px;transition:all .3s}.btn-edit-alert:hover{background:#667eea;color:#fff;transform:scale(1.1)}.submit-status{border-radius:8px;font-size:14px;font-weight:500;padding:12px 16px}.submit-status.success{background:#d1fae5;border:1px solid #10b981;color:#065f46}.submit-status.error{background:#fee2e2;border:1px solid #ef4444;color:#991b1b}.quality-filters{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:25px}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{color:#666;font-size:13px;font-weight:600}.filter-select{border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:14px;min-width:150px;padding:8px 12px}.filter-select:focus{border-color:#667eea;outline:none}.quality-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:30px}.stat-card{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:20px;text-align:center}.stat-value{color:#333;font-size:32px;margin-bottom:5px}.stat-label{font-size:14px;font-weight:500}.alerts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.alert-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:20px;transition:all .3s}.alert-card:hover{border-color:#667eea;box-shadow:0 8px 24px #0000001a;transform:translateY(-4px)}.alert-header{align-items:flex-start;display:flex;gap:15px;justify-content:space-between;margin-bottom:15px}.alert-title{color:#333;flex:1 1;font-size:18px;font-weight:700;margin:0}.alert-badges{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.status-selector-wrapper{position:relative}.status-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23fff' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:10px;border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;outline:none;padding:4px 28px 4px 12px;transition:all .3s}.status-select:hover{opacity:.9;transform:scale(1.05)}.status-select:focus{outline:2px solid #ffffff80;outline-offset:2px}.badge{border-radius:20px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px;white-space:nowrap}.alert-description{color:#666;font-size:14px;line-height:1.6;margin-bottom:15px}.alert-details{border-top:1px solid #e9ecef;display:flex;flex-direction:column;gap:8px;padding-top:15px}.detail-item{display:flex;font-size:13px;justify-content:space-between}.detail-label{color:#666;font-weight:500}.detail-value{color:#333;font-weight:600}.detail-value.overdue{color:#dc2626;font-weight:700}.no-alerts{color:#666;padding:60px 20px;text-align:center}.no-alerts p{font-size:18px;margin-bottom:10px}.no-alerts-hint{color:#999;font-size:14px}.category-select-wrapper{align-items:flex-start;display:flex;gap:10px}.category-select-wrapper .form-select{flex:1 1}.category-actions{display:flex;gap:5px}.btn-add-category{align-items:center;background:#fff;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;display:flex;font-size:20px;font-weight:700;height:36px;justify-content:center;line-height:1;transition:all .3s;width:36px}.btn-add-category:hover{background:#667eea;color:#fff;transform:scale(1.05)}.add-category-form{align-items:center;display:flex;gap:8px;margin-top:10px}.add-category-form .form-input{flex:1 1;padding:8px 12px}.btn-cancel-category,.btn-confirm-category{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .3s}.btn-confirm-category{background:#10b981;color:#fff}.btn-confirm-category:hover{background:#059669;transform:translateY(-2px)}.btn-cancel-category{background:#f3f4f6;color:#333}.btn-cancel-category:hover{background:#e5e7eb}.categories-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.category-tag{align-items:center;background:#f3f4f6;border-radius:20px;color:#333;display:inline-flex;font-size:13px;gap:6px;padding:6px 12px}.btn-remove-category{align-items:center;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;height:18px;justify-content:center;line-height:1;padding:0;transition:background .3s;width:18px}.btn-remove-category:hover{background:#dc2626}.images-section{margin-top:10px}.btn-add-image{align-items:center;background:#fff;border:2px dashed #667eea;border-radius:8px;color:#667eea;cursor:pointer;display:flex;font-size:32px;font-weight:700;height:60px;justify-content:center;line-height:1;margin-bottom:15px;transition:all .3s;width:60px}.btn-add-image:hover{background:#667eea;border-color:#667eea;color:#fff;transform:scale(1.05)}.images-preview{margin-top:15px}.images-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.image-preview-item{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;display:flex;flex-direction:column;gap:8px;padding:10px}.image-wrapper{background:#fff;border-radius:6px;overflow:hidden;position:relative;width:100%}.image-wrapper:before{border-color:#0000 #0000001a #0000 #0000;border-style:solid;border-width:0 30px 30px 0;content:"";height:0;pointer-events:none;position:absolute;right:0;top:0;width:0;z-index:1}.preview-image{display:block;height:150px;object-fit:cover;width:100%}.image-status-overlay{box-shadow:0 2px 8px #0000004d;-webkit-clip-path:polygon(100% 0,100% 100%,0 0);clip-path:polygon(100% 0,100% 100%,0 0);height:70px;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;width:70px;z-index:2}.image-status-overlay.nok{background:#dc2626}.image-status-overlay.nok:after{color:#fff;content:"NOK";font-size:14px;font-weight:900;letter-spacing:1px;position:absolute;right:4px;text-shadow:0 1px 3px #00000080;top:18px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.image-status-overlay.ok{background:#10b981}.image-status-overlay.ok:after{color:#fff;content:"OK";font-size:14px;font-weight:900;letter-spacing:1px;position:absolute;right:16px;text-shadow:0 1px 3px #00000080;top:18px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.remove-image-btn{align-items:center;background:#dc2626e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;font-weight:700;height:28px;justify-content:center;line-height:1;position:absolute;right:5px;top:5px;transition:background .3s;width:28px;z-index:2}.remove-image-btn:hover{background:#dc2626}.image-comment-input{border:1px solid #e0e0e0;border-radius:6px;font-family:inherit;font-size:13px;padding:8px 12px;transition:border-color .3s;width:100%}.image-comment-input:focus{border-color:#667eea;outline:none}.image-status-buttons{display:flex;gap:8px}.btn-status{border:2px solid;border-radius:6px;cursor:pointer;flex:1 1;font-size:13px;font-weight:700;padding:8px 12px;text-transform:uppercase;transition:all .3s}.btn-status.nok{background:#fff;border-color:#ef4444;color:#ef4444}.btn-status.nok.active,.btn-status.nok:hover{background:#ef4444;color:#fff}.btn-status.ok{background:#fff;border-color:#10b981;color:#10b981}.btn-status.ok.active,.btn-status.ok:hover{background:#10b981;color:#fff}.image-name{color:#666;display:block;font-size:11px;overflow:hidden;padding:5px 8px;text-align:center;text-overflow:ellipsis;white-space:nowrap}.image-arrow{filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));opacity:.85;pointer-events:none;position:absolute;z-index:4}.image-arrow svg{display:block}.remove-arrow-btn{align-items:center;background:#ffd700e6;border:2px solid orange;border-radius:50%;color:#333;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:24px;justify-content:center;left:5px;line-height:1;position:absolute;top:5px;transition:background .3s;width:24px;z-index:5}.remove-arrow-btn:hover{background:gold;transform:scale(1.1)}.image-arrow-hint{color:#666;font-size:11px;font-style:italic;margin-top:5px;text-align:center}.alert-images{border-top:1px solid #e9ecef;margin-top:15px;padding-top:15px}.images-label{color:#666;font-size:13px;font-weight:600;margin-bottom:10px}.alert-images-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.alert-images-grid .alert-image-thumbnail{order:1}.alert-images-grid .alert-image-thumbnail[data-status=NOK]{order:0}.alert-images-grid .alert-image-thumbnail[data-status=OK]{order:1}.alert-image-thumbnail{aspect-ratio:1;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;min-height:120px;overflow:hidden;position:relative;transition:all .3s;width:100%}.alert-image-thumbnail:hover{border-color:#667eea;transform:scale(1.05)}.alert-image-thumbnail img{display:block;height:100%;object-fit:cover;width:100%}.alert-image-thumbnail .image-status-overlay{box-shadow:0 2px 8px #0000004d;-webkit-clip-path:polygon(100% 0,100% 100%,0 0);clip-path:polygon(100% 0,100% 100%,0 0);height:50px;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;width:50px;z-index:3}.alert-image-thumbnail .image-status-overlay.nok{background:#dc2626}.alert-image-thumbnail .image-status-overlay.nok:after{color:#fff;content:"NOK";font-size:10px;font-weight:900;letter-spacing:1px;position:absolute;right:2px;text-shadow:0 1px 3px #00000080;top:12px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.alert-image-thumbnail .image-status-overlay.ok{background:#10b981}.alert-image-thumbnail .image-status-overlay.ok:after{color:#fff;content:"OK";font-size:10px;font-weight:900;letter-spacing:1px;position:absolute;right:8px;text-shadow:0 1px 3px #00000080;top:12px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.alert-image-thumbnail .image-comment{background:#000000d9;bottom:0;color:#fff;font-size:13px;font-weight:500;left:0;line-height:1.4;max-height:40px;overflow:hidden;padding:8px 12px;position:absolute;right:0;text-align:center;text-overflow:ellipsis;white-space:nowrap;z-index:1}.image-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.alert-image-thumbnail:hover .image-overlay{opacity:1}.zoom-icon{color:#fff;font-size:24px}.image-modal-overlay{background:#000000e6;bottom:0;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.image-modal-content,.image-modal-overlay{align-items:center;display:flex;padding:20px}.image-modal-content{background:#fff;border-radius:12px;flex-direction:column;max-height:90vh;max-width:90vw;position:relative}.image-modal-close{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;font-weight:700;height:36px;justify-content:center;line-height:1;position:absolute;right:10px;top:10px;transition:background .3s;width:36px;z-index:1001}.image-modal-close:hover{background:#000000e6}.image-modal-image{border-radius:8px;display:block;max-height:80vh;max-width:100%;object-fit:contain}.image-modal-content .image-status-overlay{box-shadow:0 2px 8px #0000004d;-webkit-clip-path:polygon(100% 0,100% 100%,0 0);clip-path:polygon(100% 0,100% 100%,0 0);height:80px;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;width:80px;z-index:1003}.image-modal-content .image-status-overlay.nok{background:#dc2626}.image-modal-content .image-status-overlay.nok:after{color:#fff;content:"NOK";font-size:16px;font-weight:900;letter-spacing:1px;position:absolute;right:5px;text-shadow:0 1px 3px #00000080;top:22px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.image-modal-content .image-status-overlay.ok{background:#10b981}.image-modal-content .image-status-overlay.ok:after{color:#fff;content:"OK";font-size:16px;font-weight:900;letter-spacing:1px;position:absolute;right:20px;text-shadow:0 1px 3px #00000080;top:22px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.image-modal-name{color:#666;font-size:14px;margin-top:15px;text-align:center}.image-modal-nav{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:32px;font-weight:700;height:50px;justify-content:center;line-height:1;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s;width:50px;z-index:1002}.image-modal-nav:hover{background:#000c;transform:translateY(-50%) scale(1.1)}.image-modal-nav-prev{left:20px}.image-modal-nav-next{right:20px}.image-modal-counter{background:#000000b3;border-radius:20px;color:#fff;font-size:14px;font-weight:600;left:50%;padding:8px 16px;position:absolute;top:20px;transform:translateX(-50%);z-index:1002}.alert-modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:1000}.alert-modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:800px;overflow-y:auto;padding:30px;position:relative;width:100%}.alert-modal-close{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;font-weight:700;height:36px;justify-content:center;line-height:1;position:absolute;right:15px;top:15px;transition:background .3s;width:36px;z-index:1001}.alert-modal-close:hover{background:#000000e6}.alert-modal-nav{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:32px;font-weight:700;height:50px;justify-content:center;line-height:1;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s;width:50px;z-index:1002}.alert-modal-nav:hover{background:#000c;transform:translateY(-50%) scale(1.1)}.alert-modal-nav-prev{left:20px}.alert-modal-nav-next{right:20px}.btn-print{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s}.btn-print:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-print:active{transform:translateY(0)}.btn-generate-pdf{align-items:center;background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s;white-space:nowrap}.btn-generate-pdf:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.btn-generate-pdf:active{transform:translateY(0)}.alert-modal-header{border-bottom:2px solid #e9ecef;margin-bottom:25px;padding-bottom:20px}.alert-modal-title{color:#333;font-size:24px;font-weight:700;margin:0 0 15px}.alert-modal-badges{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.alert-modal-section{margin-bottom:25px}.alert-modal-section-title{color:#333;font-size:18px;font-weight:600;margin:0 0 12px}.alert-modal-description{color:#666;font-size:15px;line-height:1.7;margin:0}.alert-modal-section:has(.alert-modal-section-title:contains("Kroki zaradcze")),.alert-modal-section:has(.alert-modal-section-title:contains("Opis")){background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;margin-bottom:25px;padding:20px}.alert-modal-section.corrective-actions-section,.alert-modal-section.description-section{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;margin-bottom:25px;padding:20px}.alert-modal-section.description-section .alert-modal-section-title{border-bottom:2px solid #e0e0e0;color:#dc2626;margin-bottom:15px;padding-bottom:10px}.alert-modal-section.corrective-actions-section .alert-modal-section-title{border-bottom:2px solid #e0e0e0;color:#10b981;margin-bottom:15px;padding-bottom:10px}.alert-modal-section.corrective-actions-section .alert-modal-description,.alert-modal-section.description-section .alert-modal-description{background:#fff;border-left:4px solid #dc2626;border-radius:6px;color:#333;padding:15px}.alert-modal-section.corrective-actions-section .alert-modal-description{border-left-color:#10b981}.alert-modal-section.images-section{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;margin-bottom:25px;padding:20px}.alert-modal-section.images-section .alert-modal-images-grid{margin-top:0}.alert-modal-details-grid{grid-gap:15px;background:#f8f9fa;border-radius:8px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:25px;padding:20px}.alert-modal-detail-item{display:flex;flex-direction:column;gap:5px}.alert-modal-detail-item .detail-label{color:#666;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.alert-modal-detail-item .detail-value{color:#333;font-size:15px;font-weight:600}.alert-modal-images-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.alert-modal-images-grid .alert-modal-image-item{order:1}.alert-modal-images-grid .alert-modal-image-item[data-status=NOK]{order:0}.alert-modal-images-grid .alert-modal-image-item[data-status=OK]{order:1}.alert-modal-image-item{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;min-height:200px;overflow:hidden;position:relative;transition:all .3s}.alert-modal-image-item:hover{border-color:#667eea;transform:scale(1.05)}.alert-modal-image-item img{display:block;height:200px;object-fit:cover;width:100%}.alert-modal-image-item .image-status-overlay{box-shadow:0 2px 8px #0000004d;-webkit-clip-path:polygon(100% 0,100% 100%,0 0);clip-path:polygon(100% 0,100% 100%,0 0);height:60px;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;width:60px;z-index:3}.alert-modal-image-item .image-status-overlay.nok{background:#dc2626}.alert-modal-image-item .image-status-overlay.nok:after{color:#fff;content:"NOK";font-size:12px;font-weight:900;letter-spacing:1px;position:absolute;right:3px;text-shadow:0 1px 3px #00000080;top:15px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.alert-modal-image-item .image-status-overlay.ok{background:#10b981}.alert-modal-image-item .image-status-overlay.ok:after{color:#fff;content:"OK";font-size:12px;font-weight:900;letter-spacing:1px;position:absolute;right:12px;text-shadow:0 1px 3px #00000080;top:15px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.alert-modal-image-name{word-wrap:break-word;background:#f8f9fa;border-top:1px solid #e0e0e0;color:#333;font-size:14px;font-weight:500;line-height:1.5;overflow:visible;padding:12px;text-align:center;white-space:normal}@media (max-width:768px){.alert-modal-content{max-height:95vh;padding:20px}.alert-modal-title{font-size:20px}.alert-modal-details-grid{grid-template-columns:1fr}.alert-modal-images-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.form-row{grid-template-columns:1fr}.quality-filters{flex-direction:column}.filter-select{width:100%}.alerts-grid{grid-template-columns:1fr}.alert-header{flex-direction:column}}.text-editor-wrapper{background:#fff;border:1px solid #ddd;border-radius:4px;display:flex;flex-direction:column;overflow:hidden}.text-editor-toolbar{align-items:center;background:#f8f9fa;border-bottom:1px solid #ddd;display:flex;flex-wrap:wrap;gap:8px;padding:8px}.toolbar-group{align-items:center;border-right:1px solid #e0e0e0;display:flex;gap:4px;padding-right:8px}.toolbar-group:last-child{border-right:none}.toolbar-btn{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;min-width:32px;padding:6px 10px;transition:all .2s}.toolbar-btn:hover{background:#e9ecef;border-color:#adb5bd}.toolbar-btn:active{background:#dee2e6}.toolbar-btn strong{font-weight:700}.toolbar-btn em{font-style:italic}.toolbar-btn u{text-decoration:underline}.toolbar-select{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:13px;height:32px;min-width:100px;padding:6px 8px}.toolbar-select:hover{border-color:#adb5bd}.toolbar-color{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;height:32px;padding:2px;width:40px}.toolbar-color:hover{border-color:#adb5bd}.text-editor-content{border:none;font-family:Arial,sans-serif;font-size:14px;line-height:1.5;min-height:120px;outline:none;overflow-y:auto;padding:10px}.text-editor-content:empty:before{color:#999;content:attr(data-placeholder);pointer-events:none}.text-editor-content:focus{outline:none}.text-editor-content *{margin:0;padding:0}.permissions-manager{box-sizing:border-box;margin:0 auto;max-width:1600px;padding:40px 20px}.permissions-header{margin-bottom:32px;text-align:center}.permissions-header h2{color:#1a1a1a;font-size:32px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.permissions-header p{color:#6b7280;font-size:16px;font-weight:400;margin:0}.permissions-message{align-items:center;animation:slideIn .3s ease;border-left:4px solid;border-radius:10px;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:24px;padding:16px 20px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.permissions-message.error{background-color:#fef2f2;border-left-color:#ef4444;color:#dc2626}.permissions-message.success{background-color:#f0fdf4;border-left-color:#22c55e;color:#16a34a}.permissions-content{grid-gap:32px;display:grid;gap:32px;grid-template-columns:350px 1fr;min-height:600px}.permissions-sidebar{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;height:-webkit-fit-content;height:fit-content;max-height:800px;overflow-y:auto;padding:24px}.users-search{margin-bottom:24px}.search-input{border-radius:10px;box-sizing:border-box;padding:12px 16px;width:100%}.users-list h3{color:#111827;font-size:18px;font-weight:600;margin:0 0 16px}.user-item{background:#f9fafb;border:2px solid #0000;border-radius:10px;cursor:pointer;margin-bottom:8px;padding:16px;transition:all .2s ease}.user-item:hover{background:#f3f4f6;border-color:#e5e7eb}.user-item.active{background:#eff6ff;border-color:#3b82f6}.user-info{display:flex;flex-direction:column;gap:8px}.user-name{color:#111827;font-size:15px;font-weight:600}.user-details{display:flex;flex-direction:column;font-size:13px;gap:4px}.user-role{color:#6b7280;font-weight:500}.user-email{color:#9ca3af;font-size:12px}.permissions-main{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;padding:32px}.selected-user-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:32px;padding-bottom:24px}.selected-user-header h3{color:#111827;font-size:24px;font-weight:700;margin:0}.role-badge{border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.role-badge.role-owner{background:#fef3c7;color:#92400e}.role-badge.role-admin{background:#dbeafe;color:#1e40af}.role-badge.role-lider{background:#d1fae5;color:#065f46}.role-badge.role-user{background:#f3f4f6;color:#374151}.role-badge.role-employee{background:#fce7f3;color:#831843}.permissions-sections{display:flex;flex-direction:column;gap:32px;margin-bottom:32px}.permissions-module{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.module-title{color:#111827;font-size:20px;font-weight:700;margin:0 0 8px}.module-description{color:#6b7280;font-size:14px;margin:0 0 20px}.permissions-list{display:flex;flex-direction:column;gap:20px}.permissions-subsection{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.subsection-title{color:#111827;font-size:16px;font-weight:600;margin:0 0 8px}.subsection-description{color:#6b7280;font-size:13px;margin:0 0 16px}.permissions-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.permission-checkbox{align-items:flex-start;background:#fff;border:2px solid #0000;border-radius:8px;display:flex;gap:12px;padding:12px;transition:all .2s ease}.permission-checkbox:hover{background:#f9fafb;border-color:#e5e7eb}.permission-checkbox input[type=checkbox]{cursor:pointer;flex-shrink:0;height:20px;margin-top:2px;width:20px}.permission-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.permission-label{font-size:14px;font-weight:600}.permission-description{font-size:12px}.permissions-actions{border-top:2px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding-top:24px}.cancel-button,.save-button{border-radius:8px;padding:12px 24px}.save-button:hover:not(:disabled){box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.save-button:disabled{opacity:.6}.cancel-button:hover{background:#e5e7eb}.no-selection{font-size:16px;text-align:center}.no-selection,.permissions-loading{align-items:center;color:#6b7280;display:flex;height:400px;justify-content:center}.permissions-loading{font-size:18px}@media (max-width:1200px){.permissions-content{grid-template-columns:300px 1fr}}@media (max-width:968px){.permissions-content{grid-template-columns:1fr}.permissions-sidebar{max-height:300px}}.permissions-grid-container{box-sizing:border-box;margin:0 auto;max-width:100%;padding:20px}.permissions-grid-header{margin-bottom:24px;text-align:center}.permissions-grid-header h2{color:#1a1a1a;font-size:28px;font-weight:700;margin:0 0 8px}.permissions-grid-header p{color:#6b7280;font-size:14px;margin:0}.owner-info-banner{align-items:center;background:linear-gradient(135deg,#fff7ed,#ffedd5);border:1px solid #fed7aa;border-radius:8px;box-shadow:0 1px 3px #fb923c1a;display:flex;gap:10px;margin-top:16px;padding:12px 16px}.owner-info-icon{flex-shrink:0;font-size:20px}.owner-info-text{color:#7c2d12;font-size:13px;line-height:1.5}.owner-info-text strong{color:#9a3412;font-weight:700}.permissions-grid-message{align-items:center;border-radius:8px;display:flex;font-size:14px;font-weight:500;gap:8px;margin-bottom:20px;padding:12px 16px}.permissions-grid-message.error{background-color:#fef2f2;border-left:4px solid #ef4444;color:#dc2626}.permissions-grid-message.success{background-color:#f0fdf4;border-left:4px solid #22c55e;color:#16a34a}.permissions-grid-toolbar{align-items:center;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding:16px}.toolbar-left{flex:1 1;gap:16px;max-width:800px}.toolbar-left,.toolbar-right{align-items:center;display:flex}.toolbar-right{gap:12px}.search-input{border:2px solid #e5e7eb;border-radius:6px;flex:0 0 300px;font-size:14px;padding:10px 14px;transition:all .2s ease}.owner-info-text-inline{color:#6b7280;font-size:13px;font-style:italic;white-space:nowrap}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.unsaved-indicator{color:#f59e0b;font-size:13px;font-weight:500}.cancel-button,.save-button{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.save-button{background:#3b82f6;color:#fff}.save-button:hover:not(:disabled){background:#2563eb}.save-button:disabled{cursor:not-allowed;opacity:.5}.cancel-button{background:#f3f4f6;color:#374151}.cancel-button:hover:not(:disabled){background:#e5e7eb}.cancel-button:disabled{cursor:not-allowed;opacity:.5}.permissions-grid-wrapper{background:#fff;border:1px solid #e5e7eb;border-radius:8px;max-height:calc(100vh - 300px);overflow-x:auto;overflow-y:auto}.permissions-grid-table{border-collapse:initial;border-spacing:0;display:table;min-width:600px;width:100%}.permissions-grid-header-row{background:#f9fafb;display:table-row;position:-webkit-sticky;position:sticky;top:0;z-index:10}.permissions-grid-header-cell{background:#f9fafb;border-bottom:2px solid #d1d5db;border-right:1px solid #e5e7eb;display:table-cell;font-size:12px;font-weight:600;min-width:90px;padding:8px 4px;text-align:center;transition:background-color .2s ease;vertical-align:middle}.permissions-grid-header-cell-fixed{background:#f9fafb;left:0;min-width:200px;position:-webkit-sticky;position:sticky;text-align:left;z-index:11}.permissions-grid-header-cell.selected{background:#fef3c7}.header-cell-content{display:flex;flex-direction:column;gap:2px}.header-cell-label{color:#111827;font-size:11px;font-weight:600}.header-cell-label-secondary{color:#6b7280;font-size:10px;font-weight:400}.header-user-name{color:#111827;font-size:11px;font-weight:600;margin-bottom:2px}.header-user-role{color:#6b7280;font-size:10px;font-weight:500;margin-bottom:1px}.header-user-email{color:#9ca3af;font-size:9px;font-weight:400;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.permissions-grid-category-row{background:#f3f4f6;display:table-row}.permissions-grid-category-cell{background:#f3f4f6;border-bottom:1px solid #e5e7eb;border-right:1px solid #e5e7eb;display:table-cell;font-size:12px;font-weight:600;padding:6px 4px;transition:background-color .2s ease;vertical-align:middle}.permissions-grid-category-cell.selected{background:#fef3c7}.category-label{color:#111827;font-size:12px;font-weight:600}.permissions-grid-data-row{background:#fff;display:table-row;transition:background-color .2s ease}.permissions-grid-data-row:hover{background:#f9fafb}.permissions-grid-data-cell{border-bottom:1px solid #e5e7eb;border-right:1px solid #e5e7eb;display:table-cell;padding:6px 4px;text-align:center;transition:background-color .2s ease;vertical-align:middle}.permissions-grid-data-cell.selected{background:#fef3c7}.permission-label-cell{display:flex;flex-direction:column;gap:2px}.permission-label{color:#111827;font-size:11px;font-weight:500;text-align:left}.permission-description{color:#6b7280;font-size:9px;font-weight:400;max-width:180px;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.permission-checkbox-cell{align-items:center;cursor:pointer;display:flex;justify-content:center;position:relative}.permission-checkbox{cursor:pointer;height:18px;margin:0;opacity:0;position:absolute;width:18px}.checkbox-custom{align-items:center;background:#fff;border:2px solid #d1d5db;border-radius:3px;display:flex;height:18px;justify-content:center;transition:all .2s ease;width:18px}.permission-checkbox:checked+.checkbox-custom{background:#3b82f6;border-color:#3b82f6}.permission-checkbox:checked+.checkbox-custom:after{color:#fff;content:"✓";font-size:12px;font-weight:700}.permission-checkbox:hover+.checkbox-custom{border-color:#3b82f6}.permissions-grid-footer{align-items:center;background:#f9fafb;border-radius:8px;display:flex;justify-content:space-between;margin-top:20px;padding:12px 16px}.footer-info{color:#6b7280;display:flex;font-size:13px;gap:20px}.permissions-grid-loading{align-items:center;color:#6b7280;display:flex;font-size:16px;height:400px;justify-content:center}@media (max-width:1200px){.permissions-grid-header-cell-fixed{min-width:180px}.permissions-grid-header-cell{min-width:80px}}.database-viewer{background:#f5f5f5;margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.database-viewer-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;box-shadow:0 4px 6px #0000001a;color:#fff;margin-bottom:20px;padding:30px}.database-viewer-header h1{font-size:28px;margin:0 0 10px}.database-viewer-header p{margin:0;opacity:.9}.database-error{background:#fee;border:1px solid #fcc;border-radius:5px;color:#c33;margin-bottom:20px;padding:15px}.database-stats{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.database-stats h2{border-bottom:2px solid #667eea;color:#333;margin-top:0;padding-bottom:10px}.stats-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-top:15px}.stat-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;padding:15px;text-align:center}.stat-label{color:#666;font-size:12px;margin-bottom:5px;text-transform:uppercase}.stat-value{color:#667eea;font-size:24px;font-weight:700}.database-tables{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.database-tables h2{border-bottom:2px solid #667eea;color:#333;margin-top:0;padding-bottom:10px}.tables-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px}.table-button{background:#fff;border:2px solid #667eea;border-radius:5px;color:#667eea;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .3s}.table-button.active,.table-button:hover{background:#667eea;color:#fff}.table-button.active{font-weight:700}.table-count{font-size:12px;margin-left:8px;opacity:.8}.database-structure{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.database-structure h2{border-bottom:2px solid #667eea;color:#333;margin-top:0;padding-bottom:10px}.structure-table{border-collapse:collapse;margin-top:15px;width:100%}.structure-table td,.structure-table th{border-bottom:1px solid #e0e0e0;padding:10px;text-align:left}.structure-table th{background:#f8f9fa;color:#333;font-weight:700}.database-data{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.data-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:15px}.data-header h2{border-bottom:2px solid #667eea;color:#333;margin:0;padding-bottom:10px}.data-controls{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.data-controls label{align-items:center;display:flex;font-size:14px;gap:8px}.data-controls input[type=number]{border:1px solid #ddd;border-radius:3px;padding:5px;width:60px}.pagination{align-items:center;display:flex;gap:10px}.pagination button{background:#fff;border:1px solid #667eea;border-radius:3px;color:#667eea;cursor:pointer;font-size:14px;padding:5px 15px}.pagination button:hover:not(:disabled){background:#667eea;color:#fff}.pagination button:disabled{cursor:not-allowed;opacity:.5}.data-table-wrapper{max-width:100%;overflow-x:auto}.data-table{border-collapse:collapse;font-size:13px;width:100%}.data-table td,.data-table th{border-bottom:1px solid #e0e0e0;padding:8px;text-align:left;word-break:break-word}.data-table th{color:#333;font-weight:700;position:-webkit-sticky;position:sticky;top:0;z-index:1}.data-table th,.data-table tr:hover{background:#f8f9fa}.json-cell{font-family:Courier New,monospace;font-size:11px;max-width:300px}.json-cell pre{margin:0;white-space:pre-wrap;word-break:break-all}.null-value{color:#999;font-style:italic}.no-data{color:#999}.loading,.no-data{font-size:16px;padding:40px;text-align:center}.loading{color:#667eea}.data-actions{margin-bottom:20px}.add-button{background:#28a745;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px}.add-button:hover{background:#218838}.edit-form{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;padding:20px}.edit-form h3{color:#333;margin-top:0}.form-field{margin-bottom:15px}.form-field label{color:#555;display:block;font-weight:700;margin-bottom:5px}.form-field input,.form-field textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;padding:8px;width:100%}.form-field textarea{min-height:60px;resize:vertical}.form-actions{display:flex;gap:10px;margin-top:20px}.edit-button,.save-button{background:#007bff;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;padding:5px 15px}.edit-button:hover,.save-button:hover{background:#0056b3}.cancel-button{background:#6c757d;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;padding:5px 15px}.cancel-button:hover{background:#5a6268}.delete-button{background:#dc3545;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;margin-left:5px;padding:5px 15px}.delete-button:hover{background:#c82333}.data-table td input,.data-table td textarea{border:1px solid #ddd;border-radius:3px;font-size:12px;padding:4px;width:100%}.data-table td textarea{min-height:40px;resize:vertical}@media (max-width:768px){.database-viewer{padding:10px}.data-header{align-items:flex-start;flex-direction:column}.data-table{font-size:11px}.data-table td,.data-table th{padding:5px}.form-actions{flex-direction:column}.cancel-button,.delete-button,.edit-button,.save-button{margin:5px 0;width:100%}}
/*# sourceMappingURL=main.19b4c4be.css.map*/