*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;color:#2c3e50;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}.sidebar{background:linear-gradient(180deg,#6b21a8,#7c3aed 50%,#4c1d95);box-shadow:4px 0 20px #00000026;display:flex;flex-direction:column;height:100vh;left:0;overflow:hidden;position:fixed;top:0;transition:width .3s cubic-bezier(.4,0,.2,1);width:280px;z-index:1000}.sidebar.closed{width:80px}.sidebar-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border-bottom:1px solid #ffffff1a;padding:2rem 1.5rem;position:relative}.logo-text{color:#fff;font-size:1.5rem;font-weight:700;letter-spacing:.5px;text-shadow:0 2px 4px #0003;transition:opacity .3s ease;white-space:nowrap}.sidebar.closed .logo-text{opacity:0;overflow:hidden;width:0}.hamburger-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;box-shadow:0 2px 8px #0003;color:#fff;cursor:pointer;display:flex;font-size:1.25rem;height:45px;justify-content:center;padding:.75rem;position:absolute;right:1.5rem;top:2rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:45px}.hamburger-btn:hover{background:#fff3;box-shadow:0 4px 12px #0000004d;transform:scale(1.05)}.sidebar.closed .hamburger-btn{left:50%;margin:0;position:absolute;right:auto;top:50%;transform:translate(-50%,-50%)}.sidebar-nav{flex:1 1;overflow-y:auto;padding:1.5rem 0}.nav-item-group{margin:.25rem 0}.nav-item{align-items:center;border-radius:10px;color:#fffc;cursor:pointer;display:flex;margin:.25rem .75rem;padding:1rem 1.5rem;position:relative;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.nav-item.parent{justify-content:space-between}.nav-item:before{background:linear-gradient(180deg,#a855f7,#9333ea);border-radius:0 4px 4px 0;content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:4px}.nav-item:hover{background:#ffffff1a;box-shadow:0 2px 8px #0003;color:#fff;transform:translateX(4px)}.nav-item.active{background:#a855f733;box-shadow:0 2px 12px #a855f74d;color:#fff}.nav-item.active:before{opacity:1}.nav-item.expanded{background:#ffffff14}.nav-icon{font-size:1.25rem;margin-right:1rem;min-width:1.25rem;transition:transform .3s ease}.nav-item:hover .nav-icon{transform:scale(1.1)}.expand-icon{align-items:center;display:flex;font-size:.9rem;margin-left:auto;transition:transform .3s ease}.nav-text{flex:1 1;transition:opacity .3s ease}.sidebar.closed .nav-text{opacity:0;overflow:hidden;width:0}.sidebar.closed .nav-icon{margin-right:0}.sidebar.closed .expand-icon{display:none}.sub-menu{animation:slideDown .3s ease-out;overflow:hidden}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:300px;opacity:1}}.sub-nav-item{align-items:center;border-radius:8px;color:#ffffffb3;display:flex;font-size:.95rem;margin:.25rem .75rem;padding:.75rem 1.5rem .75rem 3.5rem;position:relative;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.sub-nav-item:before{background:#ffffff4d;border-radius:50%;content:"";height:6px;left:2rem;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:6px}.sub-nav-item:hover{background:#ffffff14;color:#fff;padding-left:3.75rem}.sub-nav-item:hover:before{background:#a855f7cc;transform:translateY(-50%) scale(1.3)}.sub-nav-item.active{background:#a855f726;color:#fff}.sub-nav-item.active:before{background:#a855f7;transform:translateY(-50%) scale(1.5)}.sub-nav-icon{font-size:1rem;margin-right:.75rem;min-width:1rem;opacity:.8}.sub-nav-item:hover .sub-nav-icon{opacity:1;transform:scale(1.05)}.sidebar-footer{background:#0000001a;border-top:1px solid #ffffff1a;padding:1.5rem}.logout-btn{align-items:center;background:#e74c3c33;border:1px solid #e74c3c4d;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:1rem;padding:1rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;width:100%}.logout-btn:hover{background:#e74c3c4d;box-shadow:0 4px 12px #e74c3c66;transform:translateY(-2px)}.logout-btn .nav-icon{font-size:1.25rem;margin-right:1rem}.sidebar.closed .logout-btn .nav-text{opacity:0;overflow:hidden;width:0}.sidebar.closed .logout-btn .nav-icon{margin-right:0}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0);width:280px}}.login-container{align-items:center;background:linear-gradient(135deg,#2c3e50,#34495e 50%,#1a252f);display:flex;justify-content:center;min-height:100vh;padding:2rem}.login-box{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:450px;overflow:hidden;width:100%}.login-header{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;padding:2.5rem 2rem;text-align:center}.login-header h1{font-size:2rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 2px 4px #0003}.login-header p{font-size:.95rem;opacity:.95}.login-form{padding:2.5rem 2rem}.login-form h2{color:#2c3e50;font-size:1.75rem;font-weight:600;margin-bottom:1.5rem}.form-group input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.login-btn{background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:8px;box-shadow:0 4px 12px #3498db4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.login-btn:hover:not(:disabled){box-shadow:0 6px 20px #3498db66;transform:translateY(-2px)}.login-btn:disabled{cursor:not-allowed;opacity:.6}.form-footer a{color:#3498db}.form-footer a:hover{color:#2980b9}.test-credentials{background:#3498db0d;border:1px solid #3498db33;border-radius:8px;font-size:.85rem;margin-top:1.5rem;padding:1rem}.test-credentials p{color:#34495e;margin:.25rem 0}.test-credentials code{background:#3498db1a;border-radius:4px;color:#2980b9;font-family:Courier New,monospace;font-weight:600;padding:.2rem .5rem}.register-container{align-items:center;background:linear-gradient(135deg,#2c3e50,#34495e 50%,#1a252f);display:flex;justify-content:center;min-height:100vh;padding:2rem}.register-box{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;overflow:hidden;width:100%}.register-header{background:linear-gradient(135deg,#27ae60,#229954);color:#fff;padding:2.5rem 2rem;text-align:center}.register-header h1{font-size:2rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 2px 4px #0003}.register-header p{font-size:.95rem;opacity:.95}.register-form{padding:2.5rem 2rem}.register-form h2{color:#2c3e50;font-size:1.75rem;font-weight:600;margin-bottom:1.5rem}.error-message{background:#e74c3c1a;border:1px solid #e74c3c4d;border-radius:8px;color:#c0392b;font-size:.9rem;padding:1rem}.error-message,.form-group{margin-bottom:1.5rem}.form-group label{color:#34495e;display:block;font-size:.95rem;font-weight:500;margin-bottom:.5rem}.form-group input{background:#f8f9fa;border:2px solid #e0e6ed;border-radius:8px;font-size:1rem;padding:.875rem 1rem;transition:all .3s ease;width:100%}.form-group input:focus{background:#fff;border-color:#27ae60;box-shadow:0 0 0 3px #27ae601a;outline:none}.register-btn{background:linear-gradient(135deg,#27ae60,#229954);border:none;border-radius:8px;box-shadow:0 4px 12px #27ae604d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.register-btn:hover:not(:disabled){box-shadow:0 6px 20px #27ae6066;transform:translateY(-2px)}.register-btn:disabled{cursor:not-allowed;opacity:.6}.form-footer{border-top:1px solid #e0e6ed;margin-top:1.5rem;padding-top:1.5rem;text-align:center}.form-footer p{color:#7f8c8d;font-size:.9rem}.form-footer a{color:#27ae60;font-weight:600;text-decoration:none;transition:color .3s ease}.form-footer a:hover{color:#229954;text-decoration:underline}.dashboard{padding:0}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{color:#2c3e50;font-size:2rem;font-weight:700;margin-bottom:.5rem}.dashboard-header p{color:#7f8c8d;font-size:1rem}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border-left:4px solid #0000;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:1.5rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.stat-card:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-4px)}.stat-card.projects{border-left-color:#3498db}.stat-card.budget{border-left-color:#27ae60}.stat-card.equipment{border-left-color:#e67e22}.stat-card.materials{border-left-color:#9b59b6}.stat-card.workers{border-left-color:#e74c3c}.stat-card.tasks{border-left-color:#1abc9c}.stat-icon{align-items:center;background:#3498db1a;border-radius:12px;color:#3498db;display:flex;font-size:2.5rem;height:70px;justify-content:center;width:70px}.stat-card.budget .stat-icon{background:#27ae601a;color:#27ae60}.stat-card.equipment .stat-icon{background:#e67e221a;color:#e67e22}.stat-card.materials .stat-icon{background:#9b59b61a;color:#9b59b6}.stat-card.workers .stat-icon{background:#e74c3c1a;color:#e74c3c}.stat-card.tasks .stat-icon{background:#1abc9c1a;color:#1abc9c}.stat-content{flex:1 1}.stat-content h3{color:#7f8c8d;font-size:.9rem;font-weight:500;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.stat-value{color:#2c3e50;font-size:2rem;font-weight:700;margin-bottom:.5rem}.stat-details{display:flex;font-size:.85rem;gap:1rem}.stat-details span{border-radius:20px;font-weight:500;padding:.25rem .75rem}.stat-details .active{background:#3498db1a;color:#3498db}.stat-details .completed{background:#27ae601a;color:#27ae60}.stat-details .in-use{background:#e67e221a;color:#e67e22}.stat-details .available{background:#1abc9c1a;color:#1abc9c}.stat-details .low-stock{background:#e74c3c1a;color:#e74c3c}.stat-details .spent{background:#9b59b61a;color:#9b59b6}.stat-details .in-progress{background:#f1c40f1a;color:#f39c12}.recent-projects{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:2rem}.recent-projects h2{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.projects-list{grid-gap:1.5rem;display:grid;gap:1.5rem}.project-card{border:1px solid #e0e6ed;border-radius:8px;padding:1.5rem;transition:all .3s ease}.project-card:hover{border-color:#3498db;box-shadow:0 4px 12px #3498db26}.project-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.project-header h3{color:#2c3e50;font-size:1.1rem;font-weight:600}.status{font-size:.8rem}.project-progress{margin-bottom:1rem}.progress-text{color:#7f8c8d;font-size:.85rem;font-weight:500}.project-budget{color:#34495e;display:flex;font-size:.9rem;font-weight:500;justify-content:space-between}.error,.loading{color:#7f8c8d;font-size:1.1rem;padding:3rem;text-align:center}.error{color:#e74c3c}.projects-page{padding:0}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.page-header h1{color:#2c3e50;font-size:2rem;font-weight:700;margin-bottom:.25rem}.page-header p{color:#7f8c8d;font-size:1rem}.btn-add{align-items:center;background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:8px;box-shadow:0 4px 12px #3498db4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.875rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-add:hover{box-shadow:0 6px 20px #3498db66;transform:translateY(-2px)}.projects-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.project-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.project-card:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-4px)}.card-header{align-items:center;background:linear-gradient(135deg,#ecf0f1,#bdc3c7);display:flex;justify-content:space-between;padding:1.5rem}.card-header h3{color:#2c3e50;font-size:1.25rem;font-weight:600;margin:0}.status{border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.375rem .875rem;text-transform:uppercase}.status.planning{background:#f1c40f1a;color:#f39c12}.status.in-progress{background:#3498db1a;color:#3498db}.status.completed{background:#27ae601a;color:#27ae60}.status.on-hold{background:#e74c3c1a;color:#e74c3c}.card-body{padding:1.5rem}.card-body p{color:#34495e;font-size:.95rem;margin:.5rem 0}.progress-section{margin:1rem 0}.progress-bar{background:#e0e6ed;border-radius:4px;height:8px;margin-bottom:.5rem;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#3498db,#2980b9);border-radius:4px;height:100%;transition:width .3s ease}.budget-info{color:#34495e;display:flex;font-size:.9rem;font-weight:600;justify-content:space-between;margin-top:1rem}.card-actions{background:#f8f9fa;border-top:1px solid #e0e6ed;display:flex;gap:.75rem;padding:1rem 1.5rem}.btn-delete,.btn-edit{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;flex:1 1;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem;transition:all .3s ease}.btn-edit{background:#3498db1a;color:#3498db}.btn-edit:hover{background:#3498db33;transform:translateY(-2px)}.btn-delete{background:#e74c3c1a;color:#e74c3c}.btn-delete:hover{background:#e74c3c33;transform:translateY(-2px)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;padding:2rem;width:90%}.modal-content h2{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.modal-content input,.modal-content select,.modal-content textarea{background:#f8f9fa;border:2px solid #e0e6ed;border-radius:8px;font-size:1rem;margin-bottom:1rem;padding:.875rem;transition:all .3s ease;width:100%}.modal-content input:focus,.modal-content select:focus,.modal-content textarea:focus{background:#fff;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.875rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);box-shadow:0 4px 12px #3498db4d;color:#fff}.btn-primary:hover{box-shadow:0 6px 20px #3498db66;transform:translateY(-2px)}.btn-secondary{background:#e0e6ed;color:#34495e}.btn-secondary:hover{background:#bdc3c7}.loading{color:#7f8c8d;font-size:1.1rem;padding:3rem;text-align:center}.equipment-page{padding:0}.equipment-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.equipment-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.equipment-card:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-4px)}.materials-page{padding:0}.materials-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.material-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.material-card:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-4px)}.workers-page{padding:0}.workers-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.worker-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.worker-card:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-4px)}.tasks-page{padding:0}.tasks-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.task-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.task-card:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-4px)}.priority{border-radius:12px;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.priority.low{background:#1abc9c1a;color:#1abc9c}.priority.medium{background:#f1c40f1a;color:#f39c12}.priority.high{background:#e67e221a;color:#e67e22}.priority.critical{background:#e74c3c1a;color:#e74c3c}.app-container{background:#f5f7fa;display:flex;min-height:100vh}.main-content{flex:1 1;margin-left:280px;min-height:100vh;padding:2rem;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.main-content.sidebar-closed{margin-left:80px}.loading-screen{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#34495e;color:#fff;display:flex;font-size:1.5rem;height:100vh;justify-content:center}@media (max-width:768px){.main-content{margin-left:0;padding:1rem}.main-content.sidebar-open{margin-left:0}}