:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:#f5f7fa;color:#212529}.main-layout{display:flex;height:100vh;overflow:hidden}.sidebar{background:linear-gradient(180deg,#1a1a2e,#16213e);color:#fff;transition:width .3s ease;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000001a}.sidebar.open{width:280px}.sidebar.closed{width:70px}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1);min-height:120px}.logo{width:auto;height:40px;margin-bottom:10px;object-fit:contain}.app-title{font-size:16px;font-weight:600;margin:0;line-height:1.4;color:#00d4aa}.sidebar-nav{flex:1;padding:20px 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 20px;color:#ffffffb3;text-decoration:none;transition:all .2s ease;cursor:pointer}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#00d4aa33;color:#00d4aa;border-left:3px solid #00d4aa}.sidebar.closed .nav-item{justify-content:center;padding:12px}.sidebar.closed .nav-item span{display:none}.nav-item-wrapper{display:flex;flex-direction:column}.submenu{display:flex;flex-direction:column;background:#0003;margin-top:4px;margin-bottom:4px}.submenu-item{display:flex;align-items:center;padding:10px 20px 10px 52px;color:#fff9;text-decoration:none;font-size:14px;transition:all .2s ease}.submenu-item:hover{background:#ffffff1a;color:#fff}.submenu-item.active{background:#00d4aa26;color:#00d4aa;border-left:2px solid #00d4aa}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#f5f7fa}.top-header{background:#fff;padding:15px 20px;box-shadow:0 2px 4px #0000000d;display:flex;align-items:center;gap:20px}.toggle-sidebar{background:none;border:none;cursor:pointer;padding:8px;border-radius:4px;transition:background .2s;display:flex;align-items:center;justify-content:center}.toggle-sidebar:hover{background:#f0f0f0}.toggle-theme{background:none;border:none;cursor:pointer;padding:8px;border-radius:4px;transition:background .2s;display:flex;align-items:center;justify-content:center;margin-left:auto;color:#6c757d}.toggle-theme:hover{background:#f0f0f0;color:#00d4aa}.content{flex:1;padding:30px;overflow-y:auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;outline:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#00d4aa;color:#fff}.btn-primary:hover:not(:disabled){background:#00b893;box-shadow:0 4px 8px #00d4aa4d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333}.btn-icon{display:flex;align-items:center}.dashboard-container{max-width:1400px;margin:0 auto}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;gap:20px;box-shadow:0 2px 8px #00000014;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.stat-icon{width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.stat-content{flex:1}.stat-content h3{margin:0;font-size:32px;font-weight:700;color:#212529}.stat-content p{margin:4px 0;color:#6c757d;font-size:14px;font-weight:500}.stat-detail{font-size:12px;color:#00d4aa;font-weight:500}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:20px;margin-bottom:30px}.chart-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}.chart-card h3{margin:0 0 20px;font-size:18px;font-weight:600;color:#212529}.chart-card-highlight{grid-column:1 / -1;background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #00d4aa;box-shadow:0 4px 16px #00d4aa26}.chart-card-highlight h3{color:#00d4aa;font-size:20px;font-weight:700}.custom-tooltip{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:12px;box-shadow:0 2px 8px #0000001a}.custom-tooltip p{margin:4px 0;font-size:14px;color:#495057}.custom-tooltip .label{color:#00d4aa;font-weight:600;margin-bottom:8px}.quick-actions{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}.quick-actions h3{margin:0 0 20px;font-size:18px;font-weight:600;color:#212529}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.action-link{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#f8f9fa;border-radius:8px;text-decoration:none;color:#495057;font-weight:500;transition:all .2s}.action-link:hover{background:#00d4aa;color:#fff;transform:translate(4px)}.action-link svg{color:#00d4aa;transition:color .2s}.action-link:hover svg{color:#fff}@media(max-width:768px){.stats-grid,.charts-grid,.actions-grid{grid-template-columns:1fr}}.table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:#f8f9fa;border-bottom:2px solid #e9ecef}.data-table th{padding:12px 16px;text-align:left;font-weight:600;color:#495057;font-size:14px}.data-table tbody tr{border-bottom:1px solid #e9ecef;transition:background-color .2s}.data-table tbody tr:hover{background:#f8f9fa}.data-table tbody tr.clickable{cursor:pointer}.data-table td{padding:12px 16px;color:#212529;font-size:14px}.table-loading,.table-empty{padding:40px;text-align:center;color:#6c757d;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d}.search-bar{position:relative;display:flex;align-items:center;background:#fff;border:1px solid #dee2e6;border-radius:6px;padding:8px 12px;max-width:400px}.search-icon{color:#6c757d;margin-right:8px}.search-input{flex:1;border:none;outline:none;font-size:14px;color:#212529}.search-input::placeholder{color:#adb5bd}.pagination-container{display:flex;align-items:center;justify-content:space-between;padding:20px;background:#fff;border-radius:8px;margin-top:20px;box-shadow:0 2px 4px #0000000d;flex-wrap:wrap;gap:16px}.pagination-info{color:#6c757d;font-size:14px}.pagination-controls{display:flex;align-items:center;gap:8px}.page-nav{background:#fff;border:1px solid #dee2e6;border-radius:4px;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#495057}.page-nav:hover:not(:disabled){background:#f8f9fa;border-color:#00d4aa;color:#00d4aa}.page-nav:disabled{opacity:.4;cursor:not-allowed}.page-numbers{display:flex;gap:4px}.page-number{background:#fff;border:1px solid #dee2e6;border-radius:4px;padding:8px 12px;cursor:pointer;font-size:14px;transition:all .2s;color:#495057;min-width:40px}.page-number:hover{background:#f8f9fa;border-color:#00d4aa;color:#00d4aa}.page-number.active{background:#00d4aa;border-color:#00d4aa;color:#fff;font-weight:600}.page-size-selector{display:flex;align-items:center;gap:8px}.page-size-selector label{font-size:14px;color:#6c757d}.page-size-selector select{padding:8px 12px;border:1px solid #dee2e6;border-radius:4px;font-size:14px;cursor:pointer;background:#fff}.page-size-selector select:focus{outline:none;border-color:#00d4aa}@media(max-width:768px){.pagination-container{flex-direction:column;align-items:stretch}.pagination-info,.pagination-controls,.page-size-selector{justify-content:center}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e9ecef}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:#212529}.modal-close{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.modal-close:hover{background:#f8f9fa}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end;gap:12px}.detail-modal-content{max-height:70vh;overflow-y:auto;padding:.5rem}.detail-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color, #e0e0e0)}.detail-section:last-of-type{border-bottom:none}.detail-section h3{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:var(--primary-color, #2563eb)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.detail-field{display:flex;flex-direction:column;gap:.25rem}.detail-field.full-width{grid-column:1 / -1}.detail-field label{font-size:.875rem;font-weight:600;color:var(--text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.025em}.detail-field span{font-size:1rem;color:var(--text-primary, #1f2937)}.detail-description,.detail-notes{margin:.5rem 0 0;padding:.75rem;background-color:var(--bg-secondary, #f9fafb);border-radius:.375rem;color:var(--text-primary, #1f2937);line-height:1.5}.detail-list{display:flex;flex-direction:column;gap:.75rem}.detail-list-item{padding:.75rem;background-color:var(--bg-secondary, #f9fafb);border-radius:.375rem;border-left:3px solid var(--primary-color, #2563eb)}.detail-list-item strong{color:var(--text-primary, #1f2937)}.experience-item{display:flex;flex-direction:column;gap:.5rem}.detail-footer{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color, #e0e0e0);font-size:.875rem;color:var(--text-secondary, #6b7280);text-align:right}.badge{display:inline-block;padding:.25rem .75rem;font-size:.875rem;font-weight:600;border-radius:9999px;text-align:center}.badge-success{background-color:#dcfce7;color:#166534}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-info{background-color:#dbeafe;color:#1e40af}.ml-2{margin-left:.5rem}.mt-1{margin-top:.25rem}.text-muted{color:var(--text-secondary, #6b7280);font-size:.875rem}.page-container{max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-header h1{margin:0;font-size:28px;font-weight:600;color:#212529}.page-toolbar{margin-bottom:20px;display:flex;gap:12px;align-items:center}.error-message{background:#f8d7da;color:#721c24;padding:12px 16px;border-radius:4px;border-left:4px solid #dc3545;margin-bottom:20px;font-size:14px}.action-buttons{display:flex;gap:8px}.action-btn{padding:6px;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.action-btn.edit{background:#00d4aa;color:#fff}.action-btn.edit:hover{background:#00b893}.action-btn.delete{background:#dc3545;color:#fff}.action-btn.delete:hover{background:#c82333}.badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;display:inline-block}.badge-success{background:#d4edda;color:#155724}.badge-danger{background:#f8d7da;color:#721c24}.form-container{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 4px #0000000d}.form-section{margin-bottom:32px}.form-section h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#212529;border-bottom:2px solid #e9ecef;padding-bottom:8px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-group label{margin-bottom:6px;font-weight:500;color:#495057;font-size:14px}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#00d4aa;box-shadow:0 0 0 3px #00d4aa1a}.form-group textarea{resize:vertical;min-height:100px}.checkbox-group label{flex-direction:row;align-items:center;gap:8px}.checkbox-group input[type=checkbox]{width:auto;margin:0}.form-group-checkbox{display:flex;align-items:center;padding-top:24px}.form-group-checkbox .checkbox-label{display:flex;flex-direction:row;align-items:center;gap:10px;cursor:pointer;font-weight:500;color:#495057;font-size:14px;margin:0}.form-group-checkbox .checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#00d4aa}.form-group-checkbox .checkbox-label span{-webkit-user-select:none;user-select:none}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid #e9ecef}.detail-container{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 4px #0000000d}.detail-section{margin-bottom:32px}.detail-section:last-child{margin-bottom:0}.detail-section h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#212529;border-bottom:2px solid #e9ecef;padding-bottom:8px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.detail-item{display:flex;flex-direction:column}.detail-item.full-width{grid-column:1 / -1}.detail-item label{font-size:12px;font-weight:500;color:#6c757d;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.detail-item span{font-size:14px;color:#212529}.tags-container{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.tag{display:inline-flex;align-items:center;gap:6px;background:#e9ecef;padding:6px 12px;border-radius:16px;font-size:13px;color:#495057}.tag button{background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;color:#6c757d;transition:color .2s}.tag button:hover{color:#dc3545}.experience-form{background:#f8f9fa;padding:20px;border-radius:8px;margin-bottom:20px}.experiences-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}.experience-card{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:16px}.experience-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.experience-header h4{margin:0;font-size:16px;color:#212529}.experience-dates{color:#6c757d;font-size:13px;margin-bottom:8px}.experience-tech{color:#00d4aa;font-size:13px;font-weight:500;margin-bottom:8px}.experience-desc{color:#495057;font-size:14px;margin:0}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;margin-top:16px}.skill-card{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:16px}.skill-card h4{margin:0 0 8px;font-size:16px;color:#212529}.skill-category{display:inline-block;background:#00d4aa;color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;text-transform:uppercase;margin-bottom:8px}.skill-level{margin:12px 0}.skill-level-bar{height:8px;background:#e9ecef;border-radius:4px;overflow:hidden;margin-bottom:4px}.skill-level-fill{height:100%;background:linear-gradient(90deg,#00d4aa,#00b893);transition:width .3s}.skill-level-text{font-size:12px;color:#6c757d;font-weight:500}.skill-desc{margin:8px 0 0;font-size:13px;color:#6c757d}.certifications-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}.certification-card{background:#fff;border:1px solid #dee2e6;border-left:4px solid #00d4aa;border-radius:8px;padding:16px}.certification-card h4{margin:0 0 8px;font-size:16px;color:#212529}.cert-ente{color:#6c757d;font-size:13px;margin:0 0 8px}.cert-dates{display:flex;gap:16px;font-size:13px;color:#6c757d;margin-bottom:8px}.cert-desc{margin:8px 0 0;font-size:14px;color:#495057}.experiences-timeline{position:relative;padding-left:30px;margin-top:16px}.experiences-timeline:before{content:"";position:absolute;left:10px;top:10px;bottom:10px;width:2px;background:#dee2e6}.experience-item{position:relative;margin-bottom:24px}.experience-timeline-dot{position:absolute;left:-26px;top:5px;width:12px;height:12px;background:#00d4aa;border:3px solid white;border-radius:50%;box-shadow:0 0 0 2px #00d4aa}.experience-content{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:16px}.experience-content h4{margin:0 0 8px;font-size:16px;color:#212529}.experience-period{color:#6c757d;font-size:13px;margin:0 0 12px}.experience-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.tech-tag{background:#e9ecef;padding:4px 10px;border-radius:12px;font-size:12px;color:#495057}.experience-description{margin:0;font-size:14px;color:#495057;line-height:1.6}.action-btn.view{background:#17a2b8;color:#fff}.action-btn.view:hover{background:#138496}.action-btn.pdf{background:#6c757d;color:#fff}.action-btn.pdf:hover{background:#5a6268}.searchable-select{position:relative;min-width:200px}.searchable-select-input-wrapper{display:flex;align-items:center;position:relative}.searchable-select-input{width:100%;padding:8px 32px 8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--card-bg);color:var(--text-primary);font-size:14px;font-weight:500;cursor:text;transition:all .2s ease}.searchable-select-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #00d4aa1a}.searchable-select-input:hover{border-color:var(--primary-color)}.searchable-select-input::placeholder{color:var(--text-secondary);font-weight:400}.searchable-select-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-secondary);font-size:18px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:4px;transition:all .2s ease}.searchable-select-clear:hover{background:var(--hover-bg);color:var(--text-primary)}.searchable-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;box-shadow:var(--shadow-md);max-height:280px;overflow-y:auto;z-index:1000}.searchable-select-option{display:flex;flex-direction:column;padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background .15s ease}.searchable-select-option:last-child{border-bottom:none}.searchable-select-option:hover{background:var(--hover-bg)}.searchable-select-option.selected{background:#00d4aa1a}.searchable-select-option.selected:hover{background:#00d4aa26}.searchable-select-option .option-label{font-size:14px;font-weight:500;color:var(--text-primary)}.searchable-select-option .option-secondary{font-size:12px;color:var(--text-secondary);margin-top:2px}.searchable-select-no-results{padding:12px;text-align:center;color:var(--text-secondary);font-size:14px}@media(max-width:768px){.searchable-select{min-width:100%}}.gantt-container{padding:24px;background:var(--bg-primary);min-height:100vh}.gantt-header{margin-bottom:24px}.gantt-header h1{display:flex;align-items:center;gap:12px;color:var(--text-primary);font-size:28px;font-weight:600;margin-bottom:20px}.title-icon{color:var(--primary-color)}.gantt-controls{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.time-selector{display:flex;gap:8px;background:var(--card-bg);padding:4px;border-radius:8px;box-shadow:var(--shadow-sm)}.time-btn{padding:8px 16px;border:none;background:transparent;color:var(--text-secondary);border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s ease}.time-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.time-btn.active{background:var(--primary-color);color:#fff;box-shadow:0 2px 4px #00d4aa4d}.navigation-controls{display:flex;align-items:center;gap:8px;background:var(--card-bg);padding:4px;border-radius:8px;box-shadow:var(--shadow-sm)}.nav-btn,.today-btn{padding:8px 12px;border:none;background:transparent;color:var(--text-secondary);border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.nav-btn:hover,.today-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.refresh-btn,.allocate-btn{padding:8px 16px;border:none;background:var(--primary-color);color:#fff;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s ease;box-shadow:var(--shadow-sm)}.filter-utente-select{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--card-bg);color:var(--text-primary);font-size:14px;font-weight:500;min-width:200px;cursor:pointer;transition:all .2s ease}.filter-utente-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #00d4aa1a}.filter-utente-select:hover{border-color:var(--primary-color)}.refresh-btn:hover,.allocate-btn:hover{background:var(--primary-hover);box-shadow:var(--shadow-md)}.legend{display:flex;align-items:center;gap:20px;padding:12px 16px;background:var(--card-bg);border-radius:8px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.legend-item{display:flex;align-items:center;gap:8px}.legend-color{width:24px;height:24px;border-radius:4px;border:1px solid rgba(0,0,0,.1)}.legend-color.green{background:#4ade80}.legend-color.yellow{background:#fbbf24}.legend-color.blue{background:#60a5fa}.legend-color.red{background:#ef4444}.legend-color.holiday{background:#fecaca}.legend-label{font-size:14px;color:var(--text-secondary);font-weight:500}.gantt-table-wrapper{overflow-x:auto;background:var(--card-bg);border-radius:8px;box-shadow:var(--shadow-md);max-height:calc(100vh - 280px);overflow-y:auto}.gantt-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.gantt-table thead{position:sticky;top:0;z-index:10;background:var(--card-bg)}.gantt-table th{padding:12px 8px;text-align:center;font-weight:600;color:var(--text-primary);background:var(--table-header-bg, #f8f9fa);border-bottom:2px solid var(--border-color);white-space:nowrap}.gantt-table th.sticky-col{position:sticky;left:0;z-index:20;background:var(--table-header-bg, #f8f9fa)}.gantt-table th.name-col{min-width:180px;text-align:left;padding-left:16px}.gantt-table th.role-col{left:180px;min-width:150px;text-align:left;padding-left:16px}.period-header{min-width:80px;font-size:13px}.period-dates{font-size:11px;font-weight:400;color:var(--text-secondary);margin-top:4px}.gantt-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .2s ease}.gantt-table tbody tr:hover{background:var(--hover-bg)}.gantt-table tbody tr.user-row{font-weight:600;background:var(--table-header-bg, #f8f9fa)}.gantt-table tbody tr.user-row:hover{background:var(--hover-bg)}.gantt-table tbody tr.project-row{background:var(--card-bg)}.gantt-table tbody tr.project-row:hover{background:var(--hover-bg)}.gantt-table td{padding:8px;text-align:center;border-right:1px solid var(--border-color)}.gantt-table td.sticky-col{position:sticky;background:var(--card-bg);z-index:5}.gantt-table tbody tr:hover td.sticky-col{background:var(--hover-bg)}.gantt-table td.name-col{left:0;font-weight:600;color:var(--text-primary);text-align:left;padding-left:16px}.gantt-table td.role-col{left:180px;color:var(--text-secondary);font-size:13px;text-align:left;padding-left:16px}.gantt-cell{min-width:80px;height:60px;vertical-align:middle;background:var(--card-bg);position:relative}.gantt-cell.green{background:#4ade80}.gantt-cell.yellow{background:#fbbf24}.gantt-cell.blue{background:#60a5fa}.gantt-cell.red{background:#ef4444;color:#fff}.gantt-cell.holiday{background:#fecaca;color:var(--text-secondary)}.gantt-cell.holiday .percentage{color:var(--text-secondary)}.cell-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:4px}.percentage{font-weight:700;font-size:14px}.gantt-cell.red .percentage{color:#fff}.allocations{display:flex;flex-direction:column;gap:2px;max-width:100%}.allocation-item{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;padding:2px 6px;border-radius:4px;transition:all .2s ease}.allocation-item.clickable{cursor:pointer}.allocation-item.clickable:hover{background:#0000001a;transform:scale(1.05)}.gantt-cell.red .allocation-item.clickable:hover{background:#fff3}.project-name{font-weight:500;color:#000000b3}.gantt-cell.red .project-name{color:#ffffffe6}.expand-btn{background:none;border:none;padding:4px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s ease;border-radius:4px;margin-right:8px}.expand-btn:hover{background:var(--hover-bg);color:var(--primary-color)}.user-name-cell{display:flex;align-items:center}.project-name-cell{padding-left:32px;color:var(--text-secondary);font-weight:500;font-size:13px}.clickable-cell{cursor:pointer}.clickable-cell:hover{background-color:#00d4aa1a!important}.loading-message,.no-data-message{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px;background:var(--card-bg);border-radius:8px;box-shadow:var(--shadow-sm)}@media(max-width:768px){.gantt-container{padding:16px}.gantt-header h1{font-size:22px}.gantt-controls{flex-direction:column;align-items:stretch}.refresh-btn{margin-left:0;width:100%}.legend{flex-wrap:wrap;gap:12px}.refresh-btn,.allocate-btn{margin-left:0;width:100%}}.allocation-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-weight:600;color:var(--text-primary);font-size:14px}.form-group select,.form-group input,.form-group textarea{padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-family:inherit;background:var(--card-bg);color:var(--text-primary);transition:border-color .2s ease}.form-group select:focus,.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #00d4aa1a}.form-group select:disabled,.form-group input:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-error{padding:12px;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:14px;font-weight:500}.btn-primary,.btn-secondary,.btn-danger{padding:10px 20px;border:none;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--card-bg);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--hover-bg)}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;box-shadow:0 4px 6px #ef44444d}.btn-primary:disabled,.btn-secondary:disabled,.btn-danger:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.form-row{grid-template-columns:1fr}}.gitlab-stats-container{padding:1.5rem}.gitlab-stats-container .page-header{margin-bottom:1.5rem}.gitlab-stats-container .page-header h1{display:flex;align-items:center;gap:.75rem;font-size:1.75rem;color:var(--text-primary)}.filters-card{background:var(--card-bg);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000001a}.filters-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.filter-group input,.filter-group select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-primary);font-size:.875rem;min-width:150px}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #00d4aa33}.btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--secondary-bg);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--hover-bg)}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{display:flex;align-items:center;gap:.5rem;padding:1rem;background:#fff5f5;border:1px solid #feb2b2;border-radius:6px;color:#c53030;margin-bottom:1.5rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;text-align:center;color:var(--text-secondary)}.loading-container p{margin-top:1rem}.loading-hint{font-size:.875rem;opacity:.7}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.summary-card{display:flex;align-items:center;gap:1rem;background:var(--card-bg);border-radius:8px;padding:1rem;box-shadow:0 2px 4px #0000001a}.summary-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:8px;color:#fff}.summary-content h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.summary-content p{font-size:.75rem;color:var(--text-secondary);margin:0}.chart-card{background:var(--card-bg);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000001a}.chart-card h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.table-card{background:var(--card-bg);border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.table-card h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.table-container{overflow-x:auto;max-height:600px;overflow-y:auto}.stats-table{width:100%;border-collapse:collapse;font-size:.875rem}.stats-table th,.stats-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border-color)}.stats-table th{font-weight:600;color:var(--text-secondary);background:var(--secondary-bg);position:sticky;top:0;z-index:1}.stats-table tbody tr:hover{background:var(--hover-bg)}.stats-table td.additions{color:#28a745;font-weight:500}.stats-table td.deletions{color:#dc3545;font-weight:500}.stats-table td.total{font-weight:600;color:var(--primary-color)}.stats-table td.merged{color:#28a745;font-weight:500}.stats-table td.closed{color:#6c757d}.autocomplete-container{position:relative}.autocomplete-input-wrapper{display:flex;align-items:center;gap:.25rem}.autocomplete-input-wrapper input{flex:1;min-width:140px}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px #00000026;max-height:250px;overflow-y:auto;z-index:100;margin-top:4px}.autocomplete-item{display:flex;flex-direction:column;padding:.6rem .75rem;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background .15s}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover{background:var(--hover-bg)}.autocomplete-item .item-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.autocomplete-item .item-email{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.autocomplete-loading{padding:.75rem;text-align:center;color:var(--text-secondary);font-size:.875rem}.clear-selection{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:var(--secondary-bg);color:var(--text-secondary);border-radius:4px;cursor:pointer;font-size:1rem;font-weight:700;transition:all .15s}.clear-selection:hover{background:#dc3545;color:#fff}.refresh-list-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid var(--border-color);background:var(--secondary-bg);color:var(--text-secondary);border-radius:4px;cursor:pointer;transition:all .15s}.refresh-list-btn:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.refresh-list-btn .spinning{animation:spin 1s linear infinite}@media(max-width:768px){.filters-row{flex-direction:column;align-items:stretch}.filter-group,.filter-group input,.filter-group select{width:100%}.btn{width:100%;justify-content:center}.summary-cards{grid-template-columns:repeat(2,1fr)}.autocomplete-container,.autocomplete-input-wrapper input{width:100%}}*{margin:0;padding:0;box-sizing:border-box}#root{width:100%;height:100vh;overflow:hidden}:root[data-theme=light]{--bg-primary: #f5f7fa;--bg-secondary: #ffffff;--bg-tertiary: #f8f9fa;--text-primary: #212529;--text-secondary: #6c757d;--text-tertiary: #495057;--border-color: #dee2e6;--border-light: #e9ecef;--primary-color: #00d4aa;--primary-hover: #00b893;--primary-light: rgba(0, 212, 170, .1);--sidebar-bg: linear-gradient(180deg, #1a1a2e 0%, #16213e 100%);--sidebar-text: rgba(255, 255, 255, .7);--sidebar-text-hover: #ffffff;--sidebar-active-bg: rgba(0, 212, 170, .2);--sidebar-active-text: #00d4aa;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .12);--success-bg: #d4edda;--success-text: #155724;--danger-bg: #f8d7da;--danger-text: #721c24;--warning-bg: #fff3cd;--warning-text: #856404}:root[data-theme=dark]{--bg-primary: #1a1a2e;--bg-secondary: #252540;--bg-tertiary: #2d2d44;--text-primary: #e9ecef;--text-secondary: #adb5bd;--text-tertiary: #ced4da;--border-color: #3d3d5c;--border-light: #343452;--primary-color: #00d4aa;--primary-hover: #00e4ba;--primary-light: rgba(0, 212, 170, .15);--sidebar-bg: linear-gradient(180deg, #0f0f1e 0%, #16213e 100%);--sidebar-text: rgba(255, 255, 255, .6);--sidebar-text-hover: #ffffff;--sidebar-active-bg: rgba(0, 212, 170, .25);--sidebar-active-text: #00d4aa;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 2px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .5);--success-bg: #1e4d2b;--success-text: #75f394;--danger-bg: #4d1e24;--danger-text: #f38b8b;--warning-bg: #4d3d1e;--warning-text: #f3d78b}body{background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s,color .3s}.page-container{background:transparent}.main-content{background:var(--bg-primary)}.top-header{background:var(--bg-secondary);box-shadow:var(--shadow-sm)}.sidebar{background:var(--sidebar-bg)}.nav-item{color:var(--sidebar-text)}.nav-item:hover{color:var(--sidebar-text-hover)}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text)}.form-container,.detail-container,.table-container,.stat-card,.chart-card,.quick-actions{background:var(--bg-secondary);box-shadow:var(--shadow-md)}.data-table thead{background:var(--bg-tertiary);border-bottom:2px solid var(--border-color)}.data-table th{color:var(--text-tertiary)}.data-table tbody tr{border-bottom:1px solid var(--border-light)}.data-table tbody tr:hover{background:var(--bg-tertiary)}.data-table td{color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-color);background:var(--bg-secondary)}.modal-content{background:var(--bg-secondary);color:var(--text-primary)}.modal-header,.modal-footer{border-color:var(--border-light)}.search-bar{background:var(--bg-secondary);border:1px solid var(--border-color)}.search-input{background:transparent;color:var(--text-primary)}.badge-success{background:var(--success-bg);color:var(--success-text)}.badge-danger{background:var(--danger-bg);color:var(--danger-text)}.experience-card,.skill-card,.certification-card{background:var(--bg-secondary);border-color:var(--border-color)}.page-number,.page-nav{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-tertiary)}.page-number:hover,.page-nav:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--primary-color);color:var(--primary-color)}.action-link{background:var(--bg-tertiary);color:var(--text-tertiary)}.action-link:hover{background:var(--primary-color);color:#fff}
