:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:#f5f5f5}#root{min-height:100vh}a{font-weight:500;color:#007acc;text-decoration:inherit}a:hover{color:#005a9e}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.auth-card{background:#fff;border-radius:12px;padding:3rem;width:100%;max-width:420px;box-shadow:0 20px 40px #0000001a;animation:slideUp .6s ease-out}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{max-width:250px;height:auto;margin-bottom:.5rem}.auth-header h1{color:#333;font-size:2rem;margin:0 0 .5rem;font-weight:700}.auth-header h2{color:#555;font-size:1.5rem;margin:0 0 .5rem;font-weight:600}.auth-header p{color:#666;margin:0;font-size:1rem;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#333;font-size:.9rem}.form-group input{padding:.875rem 1rem;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:all .2s ease;background:#fff}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f8f9fa;cursor:not-allowed}.input-help{font-size:.8rem;color:#666;margin-top:.25rem}.error-message{background:#fee;color:#c53030;padding:.875rem 1rem;border-radius:8px;border:1px solid #fed7d7;font-size:.9rem;font-weight:500;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.auth-button{padding:.875rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.auth-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.auth-button.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.auth-button.primary:active:not(:disabled){transform:translateY(0)}.auth-button:disabled{background:#e2e8f0;color:#a0aec0;cursor:not-allowed;transform:none!important;box-shadow:none!important}.auth-footer{text-align:center;padding-top:2rem;border-top:1px solid #e2e8f0;margin-top:2rem}.auth-footer p{color:#666;margin:0;font-size:.9rem}.link-button{background:none;border:none;color:#667eea;cursor:pointer;font-weight:600;font-size:inherit;text-decoration:underline;padding:0;transition:color .2s ease}.link-button:hover:not(:disabled){color:#5a67d8}.link-button:disabled{color:#a0aec0;cursor:not-allowed}.user-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 2px 4px #0000000d;flex-shrink:0}.app-logo{flex-shrink:0}.app-logo h1{margin:0;color:#667eea;font-size:1.5rem;font-weight:700}.app-logo .company-name{color:#764ba2;font-weight:600}.user-info{display:flex;align-items:center;gap:1rem;margin-left:auto}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.2rem}.user-details h3{margin:0;color:#333;font-size:1rem}.user-details p{margin:0;color:#666;font-size:.875rem}.logout-button{background:#dc3545;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background-color .2s}.logout-button:hover{background:#c82333}@media(max-width:480px){.auth-container{padding:1rem}.auth-card{padding:2rem}.auth-header h1{font-size:1.75rem}.auth-header h2{font-size:1.25rem}}.invite-alert-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.invite-alert-container{background:#fff;border-radius:12px;padding:2rem;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 40px #00000026;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.invite-alert-header{text-align:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.invite-alert-header h3{margin:0 0 .5rem;color:#333;font-size:1.5rem}.invite-alert-header p{margin:0;color:#666;font-size:1rem}.invite-list{display:flex;flex-direction:column;gap:1rem}.invite-item{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;border:1px solid #e2e8f0;border-radius:8px;background:#f8f9fa;transition:all .2s ease}.invite-item:hover{border-color:#cbd5e0;background:#f1f3f4}.invite-info{flex:1;margin-right:1rem}.invite-project{font-size:1.1rem;margin-bottom:.5rem;color:#333}.invite-details{font-size:.9rem;color:#666;margin-bottom:.25rem}.invite-expiry{font-size:.8rem;color:#888;font-style:italic}.invite-actions{display:flex;gap:.5rem;flex-shrink:0}.accept-button{background:#28a745;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.accept-button:hover{background:#218838;transform:translateY(-1px)}.decline-button{background:#6c757d;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.decline-button:hover{background:#5a6268;transform:translateY(-1px)}.invite-alert-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid #e2e8f0;text-align:center}.invite-note{margin:0;font-size:.875rem;color:#666;font-style:italic}@media(max-width:480px){.invite-alert-container{padding:1.5rem;margin:1rem;max-width:none}.invite-item{flex-direction:column;align-items:stretch;gap:1rem}.invite-info{margin-right:0}.invite-actions{justify-content:stretch}.accept-button,.decline-button{flex:1}}.company-selection-screen{min-height:100vh;background:#f5f7fa;padding:2rem}.invites-banner{max-width:1200px;margin:0 auto 2rem;background-color:#fff4e6;border:1px solid #ffa94d;border-radius:8px;padding:20px}.invites-banner h3{margin:0 0 16px;color:#d9480f}.invite-card{background:#fff;padding:16px;border-radius:6px;border:1px solid #ffd8a8;display:flex;justify-content:space-between;align-items:center}.invite-info{display:flex;flex-direction:column;gap:6px}.invite-info strong{font-size:16px;color:#212529}.invite-details{font-size:14px;color:#6c757d}.invite-role-badge{display:inline-block;padding:4px 8px;background-color:#e7f5ff;color:#1971c2;border-radius:4px;font-size:12px;font-weight:500;width:fit-content}.accept-invite-button{padding:8px 16px;background-color:#37b24d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500}.accept-invite-button:hover{background-color:#2f9e44}.decline-invite-button{padding:8px 16px;background-color:#e9ecef;color:#495057;border:none;border-radius:4px;cursor:pointer;font-weight:500}.decline-invite-button:hover{background-color:#dee2e6}.company-selection-header{max-width:1200px;margin:0 auto 2rem;display:flex;justify-content:space-between;align-items:center}.company-selection-header h1{margin:0;color:#333;font-size:2rem}.create-company-button{background:#6f42c1;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.create-company-button:hover{background:#5a32a3}.loading-state{display:flex;align-items:center;justify-content:center;min-height:50vh;color:#666;font-style:italic;font-size:1.2rem}.companies-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.no-companies{grid-column:1 / -1;text-align:center;padding:4rem 2rem;background:#fff;border-radius:8px;border:2px dashed #e0e0e0}.no-companies p{margin:.5rem 0;color:#666;font-size:1.1rem}.no-companies p:first-child{font-weight:600;color:#333}.company-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000000d}.company-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:#6f42c1}.company-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.company-card-header h2{margin:0;color:#333;font-size:1.5rem;word-break:break-word;flex:1}.role-badge{font-size:.75rem;font-weight:600;padding:.35rem .75rem;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}.role-badge.administrator{background:#6f42c1;color:#fff}.role-badge.member{background:#e9ecef;color:#6c757d}.company-card-body{display:flex;flex-direction:column;gap:.75rem}.company-info{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #f0f0f0}.company-info:last-child{border-bottom:none}.info-label{font-size:.875rem;color:#6c757d;font-weight:500}.info-value{font-size:.875rem;color:#333;font-weight:600}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#6f42c1;box-shadow:0 0 0 2px #6f42c133}.cancel-button:hover:not(:disabled){background:#5a6268}.cancel-button:disabled{opacity:.6;cursor:not-allowed}.create-button{background:#6f42c1;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.create-button:hover:not(:disabled){background:#5a32a3}@media(max-width:768px){.company-selection-header{flex-direction:column;align-items:flex-start;gap:1rem}.create-company-button{width:100%}.companies-grid{grid-template-columns:1fr}}.company-members{background:#fff;border-radius:8px;width:600px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.company-members-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e5e7eb}.company-members-header h2{margin:0;font-size:1.5rem;color:#1f2937}.close-button{background:none;border:none;font-size:2rem;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.close-button:hover{background:#f3f4f6;color:#1f2937}.invite-section{padding:20px;border-bottom:1px solid #e5e7eb}.invite-section h3{margin:0 0 16px;font-size:1.1rem;color:#374151}.invite-form{display:flex;gap:12px;flex-wrap:wrap}.invite-email-input{flex:1;min-width:200px;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem}.invite-email-input:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 3px #007acc1a}.invite-role-select{padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem;background:#fff;cursor:pointer}.invite-role-select:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 3px #007acc1a}.invite-submit-button{padding:10px 20px;background:#007acc;color:#fff;border:none;border-radius:6px;font-size:.95rem;cursor:pointer;font-weight:500;transition:background .2s}.invite-submit-button:hover:not(:disabled){background:#005a9e}.invite-submit-button:disabled{background:#9ca3af;cursor:not-allowed}.members-list{padding:20px;overflow-y:auto;flex:1}.members-list h3{margin:0 0 16px;font-size:1.1rem;color:#374151}.members-grid{display:flex;flex-direction:column;gap:12px}.member-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;transition:all .2s}.member-item:hover{border-color:#d1d5db;box-shadow:0 1px 3px #0000001a}.member-item.founder{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#fbbf24}.member-info{display:flex;flex-direction:column;gap:4px}.member-name{font-weight:500;color:#1f2937;font-size:.95rem}.member-detail{font-size:.85rem;color:#6b7280}.role-badge{padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:500;white-space:nowrap}.role-badge.admin{background:#ddd6fe;color:#6b21a8}.role-badge.member{background:#e5e7eb;color:#374151}.role-badge.readonly{background:#fef3c7;color:#92400e}.role-badge.founder{background:#fbbf24;color:#78350f}@media(max-width:640px){.company-members{width:100%;max-width:100%;height:100vh;max-height:100vh;border-radius:0}.invite-form{flex-direction:column}.invite-email-input{width:100%}}.project-list{padding:2rem;width:100%;box-sizing:border-box}.invites-banner{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #3b82f6;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.invites-banner h3{margin:0 0 1rem;color:#1e40af;font-size:1.1rem}.invites-list{display:flex;flex-direction:column;gap:12px}.invite-card{background:#fff;padding:1rem;border-radius:8px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000001a}.invite-info{display:flex;align-items:center;gap:12px}.invite-info strong{font-size:1rem;color:#1f2937}.invite-role-badge{padding:4px 12px;background:#e0e7ff;color:#4338ca;border-radius:12px;font-size:.85rem;font-weight:500}.invite-actions{display:flex;gap:8px}.accept-invite-button{background:#10b981;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.accept-invite-button:hover{background:#059669}.decline-invite-button{background:#6b7280;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.decline-invite-button:hover{background:#4b5563}.project-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.project-list-header h1{margin:0;color:#333}.header-buttons{display:flex;gap:12px}.team-members-button{background:#6b7280;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.team-members-button:hover:not(:disabled){background:#4b5563}.team-members-button:disabled{background:#ccc;cursor:not-allowed}.create-button{background:#007acc;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.create-button:hover{background:#005a9e}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.project-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000001a}.project-card:hover{border-color:#007acc;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.project-card.team-project{border-left:4px solid #28a745;background:linear-gradient(135deg,#fff,#f8fff9)}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.project-title-area{flex:1;display:flex;flex-direction:column;gap:.5rem}.project-card-header h3{margin:0;color:#333;font-size:1.25rem}.team-badge{background:#28a745;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:12px;text-transform:uppercase;letter-spacing:.5px;align-self:flex-start}.project-actions{display:flex;gap:.5rem;align-items:center}.invite-button{background:#007acc;color:#fff;border:none;width:32px;height:32px;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:background-color .2s}.delete-button{background:#dc3545;color:#fff;border:none;width:24px;height:24px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:background-color .2s}.delete-button:hover{background:#c82333}.project-description{color:#666;margin-bottom:1rem;line-height:1.5}.project-meta{display:flex;justify-content:space-between;align-items:flex-end;font-size:.875rem;color:#888;flex-wrap:wrap;gap:.5rem}.project-stats{display:flex;gap:1rem}.project-details{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.task-count,.member-count{font-weight:500}.member-count{color:#28a745}.user-role{font-weight:600;color:#007acc;font-size:.8rem}.empty-state{grid-column:1 / -1;text-align:center;color:#666;font-style:italic;padding:3rem}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 2px #007acc33}.modal-choice-buttons{justify-content:center;margin-bottom:1rem}.choice-button{background:#f0f0f0;color:#333;border:2px solid #ddd;padding:1rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .2s;min-width:150px}.choice-button:hover{background:#e0e0e0;border-color:#007acc}.builtin-description{font-size:.9rem;color:#666;margin:.5rem 0 1rem;padding:.75rem;background:#f8f9fa;border-radius:4px;border-left:3px solid #007acc}.dashboards-section{margin-top:3rem;padding-top:2rem;border-top:2px solid #e0e0e0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.section-header h2{margin:0;color:#333;font-size:1.75rem}.add-dashboard-button{background:#6f42c1;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.add-dashboard-button:hover{background:#5a32a3}.add-dashboard-button:disabled{background:#ccc;cursor:not-allowed}.dashboards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.dashboard-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000001a;border-left:4px solid #6f42c1}.dashboard-card:hover{border-color:#6f42c1;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.dashboard-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.dashboard-card-header h3{margin:0;color:#333;font-size:1.25rem}.dashboard-meta{font-size:.875rem;color:#888}.dashboard-date{font-weight:500}.loading-state{text-align:center;color:#666;font-style:italic;padding:2rem}.statistics-section{margin-top:3rem;padding-top:2rem;border-top:2px solid #e0e0e0}.add-statistic-button{background:#ff6b35;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.add-statistic-button:hover{background:#e55a2b}.add-statistic-button:disabled{background:#ccc;cursor:not-allowed}.statistics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.statistic-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;transition:all .2s;box-shadow:0 2px 4px #0000001a;border-left:4px solid #ff6b35;cursor:pointer}.statistic-card:hover{border-color:#ff6b35;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.statistic-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.statistic-info{display:flex;flex-direction:column;gap:.5rem;flex:1}.statistic-card-header h3{margin:0;color:#333;font-size:1.25rem}.statistic-abbreviation{display:inline-block;background:#ff6b35;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;align-self:flex-start}.statistic-meta{font-size:.875rem;color:#888}.statistic-date{font-weight:500}.orgcharts-section{margin-top:3rem;padding-top:2rem;border-top:2px solid #e0e0e0}.add-orgchart-button{background:#8b5cf6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.add-orgchart-button:hover{background:#7c3aed}.add-orgchart-button:disabled{background:#ccc;cursor:not-allowed}.orgcharts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.orgchart-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;transition:all .2s;box-shadow:0 2px 4px #0000001a;border-left:4px solid #8b5cf6;cursor:pointer}.orgchart-card:hover{border-color:#8b5cf6;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.orgchart-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.orgchart-card-header h3{margin:0;color:#333;font-size:1.25rem}.orgchart-meta{font-size:.875rem;color:#888}.orgchart-date{font-weight:500}.project-editor{padding:20px;width:100%;box-sizing:border-box;display:flex;flex-direction:column;height:100%;overflow:hidden}.project-editor-header{display:flex;align-items:flex-start;gap:2rem;margin-bottom:2rem;flex-wrap:wrap;flex-shrink:0}.project-info{flex:1;min-width:300px}.project-title-row{display:flex;align-items:baseline;gap:1rem}.project-info h1{margin:0 0 .5rem;color:#333}.project-total-duration{font-size:1rem;font-weight:600;color:#007acc;background:#e7f3ff;padding:.25rem .75rem;border-radius:12px}.project-info p{margin:0;color:#666;line-height:1.5}.header-actions{display:flex;gap:1rem;align-items:center}.view-members-button{background:#6f42c1;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s;white-space:nowrap}.view-members-button:hover{background:#5a32a3}.invite-button{background:#007acc;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s;white-space:nowrap}.invite-button:hover{background:#005a9e}.add-task-button{background:#28a745;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s;white-space:nowrap}.add-task-button:hover{background:#218838}.add-section-button{background:#6f42c1;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s;white-space:nowrap}.add-section-button:hover{background:#5a32a3}.tasks-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;flex:1;min-height:0;display:flex;flex-direction:column}.empty-tasks{padding:3rem;text-align:center;color:#666;font-style:italic}.tasks-grid{display:flex;flex-direction:column;overflow:hidden;flex:1;min-height:0}.grid-header{display:grid;gap:0;flex-shrink:0;overflow-y:scroll}.tasks-scroll-area{flex:1;overflow-y:scroll;min-height:0}.header-cell{background:#f8f9fa;padding:1rem;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;border-right:1px solid #dee2e6;box-sizing:border-box}.header-cell:last-child{border-right:none}.header-cell.draggable-header{cursor:grab;-webkit-user-select:none;user-select:none;transition:background-color .2s,transform .1s}.header-cell.draggable-header:hover{background:#e9ecef}.header-cell.draggable-header:active{cursor:grabbing}.header-cell.draggable-header.dragging{opacity:.5;background:#dee2e6}.header-cell.draggable-header.drag-over-left{background:#cfe2ff;border-left:3px solid #0d6efd}.header-cell.draggable-header.drag-over-right{background:#cfe2ff;border-right:3px solid #0d6efd}.header-cell-actions{display:flex;align-items:center;justify-content:center}.column-selector-button{width:32px;height:32px;border:none;background:transparent;color:#666;font-size:1.25rem;cursor:pointer;border-radius:4px;transition:background-color .2s,color .2s;display:flex;align-items:center;justify-content:center;padding:0}.column-selector-button:hover{background:#dee2e6;color:#333}.column-selector-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.column-selector-item{display:flex;align-items:center;gap:.75rem}.column-selector-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.column-selector-item input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.column-selector-item label{cursor:pointer;font-size:1rem;color:#333;margin:0}.task-row-wrapper{cursor:move;transition:opacity .2s;overflow:visible}.task-row-wrapper.dragging{opacity:.4}.task-row-wrapper:hover .task-cell{background-color:#f8f9fa}.task-row-wrapper:hover .edit-icon-button{opacity:1}.task-row{display:grid;gap:0;overflow:visible}.task-cell{padding:.5rem 1rem;border-bottom:1px solid #dee2e6;border-right:1px solid #dee2e6;display:flex;align-items:center;transition:background-color .2s;overflow:visible;box-sizing:border-box}.task-cell:last-child{border-right:none}.task-name-display{display:flex;align-items:center;gap:30px}.task-name-text{font-weight:500;color:#333}.chat-indicator{background:none;border:none;cursor:pointer;padding:.25rem;font-size:1rem;color:#007bff;animation:pulse 2s ease-in-out infinite;margin-right:.25rem}.chat-indicator:hover{transform:scale(1.2)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.edit-icon-button{background:none;border:none;cursor:pointer;padding:.25rem;font-size:1rem;opacity:0;transition:opacity .2s;color:#666}.edit-icon-button:hover{opacity:1!important;color:#007acc}.task-name-input{width:100%;border:1px solid #007acc;padding:.5rem;font-size:1rem;font-weight:500;color:#333;border-radius:4px;background:#fff;box-shadow:0 0 0 2px #007acc1a}.task-name-input:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 2px #007acc33}.task-description-input{width:100%;border:1px solid transparent;padding:.5rem;font-size:.875rem;color:#666;border-radius:4px;resize:vertical;min-height:28px;transition:border-color .2s,background-color .2s;background:transparent;font-family:inherit}.task-description-input:hover{background:#f8f9fa;border-color:#dee2e6}.task-description-input:focus{outline:none;background:#fff;border-color:#007acc;box-shadow:0 0 0 2px #007acc1a}.task-description-input::placeholder{color:#adb5bd;font-style:italic}.task-date-input{border:1px solid transparent;padding:.5rem;font-size:.875rem;color:#666;border-radius:4px;background:transparent;cursor:pointer;transition:border-color .2s,background-color .2s}.task-date-input:hover{background:#f8f9fa;border-color:#dee2e6}.task-date-input:focus{outline:none;background:#fff;border-color:#007acc;box-shadow:0 0 0 2px #007acc1a}.task-duration-input{width:100%;max-width:90px;border:1px solid transparent;padding:.5rem;font-size:.875rem;color:#666;border-radius:4px;background:transparent;transition:border-color .2s,background-color .2s;box-sizing:border-box}.task-duration-input:hover{background:#f8f9fa;border-color:#dee2e6}.task-duration-input:focus{outline:none;background:#fff;border-color:#007acc;box-shadow:0 0 0 2px #007acc1a}.section-summary-row{cursor:default}.section-summary-row .task-cell{background:#f8f9fa}.section-summary-label{font-weight:600;color:#495057}.section-duration-total{font-weight:600;color:#007acc;padding:.25rem .5rem;background:#e7f3ff;border-radius:4px}.status-select{padding:.5rem 2rem .5rem .5rem;border:none;border-radius:4px;font-size:.875rem;cursor:pointer;color:#fff;font-weight:500;transition:opacity .2s;appearance:none;background-repeat:no-repeat;background-position:right .5rem center;background-size:12px;background-image:url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12"><path fill="white" d="M6 9L1 4h10z"/></svg>')}.status-select:focus{outline:none;opacity:.9}.status-select option{color:#fff;font-weight:500;padding:.5rem}.task-assigned{justify-content:center}.assigned-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:100%}.assign-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%);background:#fff;border:1px solid #dee2e6;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:200px;max-height:300px;overflow-y:auto;margin-top:4px}.assign-dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;background:#fff;transition:background-color .2s}.assign-dropdown-item:hover{background:#f8f9fa}.assign-dropdown-item:first-child{border-radius:6px 6px 0 0}.assign-dropdown-item:last-child{border-radius:0 0 6px 6px}.assign-dropdown-text{color:#333;font-size:.875rem;font-weight:400}.assigned-avatar-small{width:28px;height:28px;border-radius:50%;background:#007acc;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;flex-shrink:0}.unassigned-avatar-small{width:28px;height:28px;border-radius:50%;background:#dee2e6;color:#6c757d;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:500;flex-shrink:0}.assigned-avatar{width:32px;height:32px;border-radius:50%;background:#007acc;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;cursor:pointer}.unassigned-avatar{width:32px;height:32px;border-radius:50%;background:#dee2e6;color:#6c757d;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:500;cursor:pointer}.task-actions{gap:.5rem;justify-content:center}.section-row{display:grid;grid-template-columns:3fr 1fr;gap:0;background:#e9ecef;border-bottom:1px solid #dee2e6;padding:.75rem 1rem;font-weight:600;align-items:center}.section-content{display:flex;align-items:center;gap:.75rem}.section-toggle{background:none;border:none;cursor:pointer;padding:.25rem;font-size:1rem;color:#495057;transition:color .2s;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.section-toggle:hover{color:#007acc}.section-name-display{display:flex;align-items:center;gap:.5rem;flex:1}.section-name-text{font-weight:600;color:#495057;font-size:1rem}.section-name-input{flex:1;border:1px solid #007acc;padding:.5rem;font-size:1rem;font-weight:600;color:#495057;border-radius:4px;background:#fff;box-shadow:0 0 0 2px #007acc1a}.section-name-input:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 2px #007acc33}.section-actions{display:flex;justify-content:flex-end;gap:.5rem}.menu-button-container{position:relative}.menu-button{width:28px;height:28px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#495057;transition:background-color .2s,border-color .2s}.menu-button:hover{background:#e9ecef;border-color:#adb5bd}.menu-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid #dee2e6;border-radius:4px;box-shadow:0 2px 8px #00000026;z-index:100;min-width:100px;overflow:hidden}.menu-item{width:100%;padding:.5rem 1rem;background:none;border:none;text-align:left;cursor:pointer;font-size:.875rem;color:#495057;transition:background-color .2s}.menu-item:hover{background:#f8f9fa}.menu-item-danger{color:#dc3545}.menu-item-danger:hover{background:#fff5f5}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 2px #007acc33}.save-button{background:#28a745;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.save-button:hover{background:#218838}.save-button:disabled{background:#ccc;cursor:not-allowed}@media(max-width:768px){.project-editor-header{flex-direction:column;align-items:stretch;gap:1rem}.tasks-grid{grid-template-columns:1fr}.header-cell,.task-cell{border-right:none}.task-cell{padding:.75rem}.task-actions{justify-content:flex-start}}.section-row{transition:background-color .2s;cursor:pointer}.section-row:hover{background:#dee2e6}.section-row.selected{background:#cfe2ff;border-left:3px solid #0d6efd}.task-row-wrapper.selected .task-cell{background-color:#cfe2ff;border-left:3px solid #0d6efd}.project-editor-body{display:flex;flex:1;min-height:0;overflow:hidden}.project-main-content{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.side-panel{display:flex;flex-shrink:0;background:#f8f9fa;border-left:1px solid #dee2e6;overflow:hidden;position:relative}.side-panel.closed{width:35px}.side-panel.open{min-width:300px}.side-panel-resize-handle{position:absolute;left:0;top:0;bottom:0;width:6px;cursor:ew-resize;background:transparent;z-index:10;transition:background .2s}.side-panel-resize-handle:hover,.side-panel-resize-handle:active{background:#007bff4d}.side-panel-toggle{width:35px;min-width:35px;background:#e9ecef;border:none;border-right:1px solid #dee2e6;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#495057;transition:background-color .2s}.side-panel-toggle:hover{background:#dee2e6}.side-panel-content{flex:1;overflow:hidden}.side-panel-inner{padding:1rem;height:100%;overflow-y:auto}.side-panel-inner h3{margin:0 0 1rem;color:#333;font-size:1.1rem}.side-panel-inner p{color:#666;font-size:.875rem}.history-placeholder,.history-loading,.history-empty{color:#888;font-style:italic;text-align:center;padding:1rem}.history-list{display:flex;flex-direction:column;gap:1rem}.history-entry{background:#fff;border:1px solid #dee2e6;border-radius:6px;padding:.75rem}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.history-action{font-weight:600;font-size:.8rem;padding:.15rem .5rem;border-radius:3px}.history-action-created{background:#d4edda;color:#155724}.history-action-updated{background:#cce5ff;color:#004085}.history-action-deleted{background:#f8d7da;color:#721c24}.history-user{font-size:.8rem;color:#666}.history-timestamp{font-size:.75rem;color:#888;margin-bottom:.5rem}.history-changes{border-top:1px solid #eee;padding-top:.5rem;margin-top:.25rem}.history-change{font-size:.8rem;margin-bottom:.25rem;display:flex;flex-wrap:wrap;align-items:center;gap:.25rem}.change-field{font-weight:500;color:#495057}.change-old{color:#dc3545;text-decoration:line-through;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.change-arrow{color:#888}.change-new{color:#28a745;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-entry{background:#f8f9fa;border-left:3px solid #007bff}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.comment-user{font-weight:600;color:#333;font-size:.85rem}.comment-timestamp{font-size:.7rem;color:#888}.comment-message{font-size:.9rem;color:#333;line-height:1.4;white-space:pre-wrap;word-break:break-word}.comment-mentions{margin-top:.5rem;font-size:.75rem;color:#007bff}.comment-input-container{margin-top:auto;padding-top:1rem;border-top:1px solid #dee2e6;display:flex;gap:.5rem;align-items:flex-end}.comment-input-wrapper{flex:1;position:relative}.comment-textarea{width:100%;padding:.5rem;border:1px solid #ced4da;border-radius:6px;font-size:.85rem;resize:none;font-family:inherit;line-height:1.4}.comment-textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.comment-textarea:disabled{background:#f5f5f5;cursor:not-allowed}.comment-submit-btn{padding:.5rem 1rem;background:#007bff;color:#fff;border:none;border-radius:6px;font-size:.85rem;cursor:pointer;font-weight:500;transition:background .2s}.comment-submit-btn:hover:not(:disabled){background:#0056b3}.comment-submit-btn:disabled{background:#ccc;cursor:not-allowed}.mention-dropdown{position:absolute;bottom:100%;left:0;right:0;background:#fff;border:1px solid #dee2e6;border-radius:6px;box-shadow:0 4px 12px #00000026;max-height:200px;overflow-y:auto;margin-bottom:4px;z-index:100}.mention-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;cursor:pointer;transition:background .15s}.mention-item:hover{background:#f0f0f0}.mention-avatar{width:28px;height:28px;border-radius:50%;background:#007bff;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600}.mention-name{font-size:.85rem;color:#333}.side-panel-inner{display:flex;flex-direction:column;height:100%}.side-panel-inner h3{margin:0 0 1rem;flex-shrink:0}.side-panel-inner .history-list{flex:1;overflow-y:auto;padding-right:4px}.side-panel-inner .history-placeholder,.side-panel-inner .history-loading,.side-panel-inner .history-empty{flex:1}.graph-controls{display:flex;flex-wrap:wrap;gap:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px;margin-top:1rem;align-items:flex-end;justify-content:center}.graph-control-group{display:flex;flex-direction:column;gap:.5rem}.graph-control-group label{font-size:.875rem;font-weight:600;color:#495057}.graph-control-group select,.graph-control-group input{padding:.5rem .75rem;border:1px solid #ced4da;border-radius:4px;font-size:.875rem;min-width:140px;background:#fff}.graph-control-group select:focus,.graph-control-group input:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 2px #007acc33}.graph-control-group input[type=number]{width:100px;min-width:100px}.graph-control-group input[type=date]{min-width:160px}.statistic-editor{height:100%;display:flex;flex-direction:column;background-color:#fff}.statistic-editor.loading,.statistic-editor.error{display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#666}.statistic-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:1.5rem 2rem;flex-shrink:0}.statistic-header-content{display:flex;align-items:center;gap:1.5rem}.statistic-title-section{display:flex;align-items:center;gap:1rem}.statistic-title-section h1{margin:0;font-size:1.75rem;color:#333}.statistic-abbr-badge{background:#ff6b35;color:#fff;font-size:.875rem;font-weight:600;padding:.35rem .75rem;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}.statistic-content{flex:1;overflow:auto;padding:2rem}.graph-section{margin-bottom:3rem}.graph-section h2{margin:0 0 1.5rem;color:#333;font-size:1.5rem}.graph-container{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:2rem;display:flex;flex-direction:column;align-items:center}.statistic-graph{display:block}.data-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:2rem;max-width:600px;margin:0 auto}.data-section-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.data-section-header h2{margin:0;color:#333;font-size:1.5rem}.add-data-point{display:flex;gap:.75rem;align-items:center}.add-data-point input[type=date],.add-data-point input[type=number]{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem}.add-data-point input[type=number]{width:150px}.add-data-point button{background:#007acc;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:6px;font-size:.95rem;cursor:pointer;transition:background-color .2s}.add-data-point button:hover:not(:disabled){background:#005a9e}.add-data-point button:disabled{background:#ccc;cursor:not-allowed}.data-grid{border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}.data-grid-header{display:grid;grid-template-columns:150px 100px 80px;background:#f5f5f5;font-weight:600;border-bottom:2px solid #e0e0e0}.data-grid-row{display:grid;grid-template-columns:150px 100px 80px;border-bottom:1px solid #e0e0e0}.data-grid-row:last-child{border-bottom:none}.data-grid-row:hover{background:#f9f9f9}.data-grid-cell{padding:.75rem 1rem;display:flex;align-items:center}.empty-data{padding:3rem 2rem;text-align:center;color:#666;font-style:italic}.auto-calculation-info{padding:1.5rem 2rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #28a745}.auto-calculation-info p{margin:0 0 .5rem;color:#555;line-height:1.5}.auto-calculation-info p:last-child{margin-bottom:0}.delete-data-button{background:#dc3545;color:#fff;border:none;width:28px;height:28px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:background-color .2s}.delete-data-button:hover{background:#c82333}.graph-scrollbar-container{margin-top:.5rem;display:flex;align-items:center}.graph-scrollbar{-webkit-appearance:none;appearance:none;height:8px;background:#e0e0e0;border-radius:4px;outline:none;cursor:pointer}.graph-scrollbar::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:#007acc;border-radius:50%;cursor:pointer;transition:background .2s}.graph-scrollbar::-webkit-slider-thumb:hover{background:#005a9e}.graph-scrollbar::-moz-range-thumb{width:20px;height:20px;background:#007acc;border-radius:50%;cursor:pointer;border:none;transition:background .2s}.graph-scrollbar::-moz-range-thumb:hover{background:#005a9e}.settings-button{background:#6c757d;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s;margin-left:1rem}.settings-button:hover{background:#5a6268}.modal-content{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.settings-modal{max-width:550px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.25rem;color:#333}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0;line-height:1}.modal-close:hover{color:#333}.settings-form{padding:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333;font-size:.875rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.625rem .75rem;border:1px solid #ced4da;border-radius:6px;font-size:.875rem;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 3px #007acc26}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e0e0e0;background:#f8f9fa;border-radius:0 0 12px 12px}.cancel-button{background:#e9ecef;color:#495057;border:none;padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.cancel-button:hover{background:#dee2e6}.save-button{background:#007acc;color:#fff;border:none;padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.save-button:hover{background:#005a9e}.save-button:disabled{background:#adb5bd;cursor:not-allowed}.org-chart-editor{display:flex;flex-direction:column;height:100%;overflow:hidden}.org-chart-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #e0e0e0;background:#fff;flex-shrink:0}.org-chart-header h1{margin:0;font-size:24px;color:#333}.org-chart-loading,.org-chart-error{display:flex;align-items:center;justify-content:center;height:200px;color:#666;font-size:16px}.org-chart-toolbar{display:flex;align-items:center;gap:8px;padding:0 20px;height:35px;min-height:35px;background:#f5f5f5;border-bottom:1px solid #e0e0e0;flex-shrink:0}.toolbar-button{height:27px;padding:0 12px;border:1px solid #ccc;border-radius:4px;background:#fff;color:#333;font-size:13px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.toolbar-button:hover{background:#e8e8e8;border-color:#999}.toolbar-button:active{background:#ddd}.toolbar-button:disabled{background:#f5f5f5;color:#aaa;border-color:#ddd;cursor:not-allowed}.toolbar-button:disabled:hover{background:#f5f5f5;border-color:#ddd}.toolbar-button.toolbar-button-danger{color:#dc2626;border-color:#dc2626}.toolbar-button.toolbar-button-danger:hover{background:#fef2f2;border-color:#b91c1c}.toolbar-button.toolbar-zoom{width:27px;padding:0;font-size:16px;font-weight:700}.toolbar-separator{width:1px;height:20px;background:#ccc;margin:0 8px}.toolbar-zoom-level{font-size:12px;color:#666;min-width:45px;text-align:center}.org-chart-canvas{flex:1;background:#e8e8e8;overflow:hidden;position:relative}.org-chart-canvas-content{position:absolute;top:0;left:0;width:10000px;height:10000px;background-image:linear-gradient(rgba(0,0,0,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.05) 1px,transparent 1px);background-size:20px 20px}.org-chart-empty-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#888;font-size:16px;text-align:center;pointer-events:none}.division-box{position:absolute;min-width:300px;min-height:400px;border:2px solid;border-radius:8px;background:#fff;box-shadow:0 2px 8px #00000026;overflow:hidden;cursor:pointer;transition:box-shadow .2s ease;display:flex;flex-direction:column}.division-box:hover{box-shadow:0 4px 16px #00000040}.division-box.selected{box-shadow:0 8px 32px #0000004d}.division-header{display:flex;align-items:center;gap:10px;padding:12px 16px;color:#fff;font-weight:600;min-height:44px;box-sizing:border-box}.division-header.raised{min-height:74px;padding-top:12px;align-items:flex-start}.division-number{background:#ffffff40;padding:2px 8px;border-radius:4px;font-size:13px}.division-name{font-size:16px}.division-content{padding:4px;flex:1;overflow:hidden;display:flex;flex-direction:column}.division-empty-hint{color:#999;font-size:14px;text-align:center;padding:20px}.positions-section{flex-shrink:0}.positions-section.has-fixed-height{overflow-y:auto}.positions-list{display:flex;flex-direction:column;gap:4px}.position-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;padding:3px 8px;cursor:pointer;transition:background-color .15s,border-color .15s}.position-card:hover{background:#e9ecef}.position-card.selected{background:#e3f2fd;border-color:#2196f3}.position-title{font-weight:600;font-size:14px;color:#333;margin-bottom:1px}.position-holder{font-size:13px;color:#666}.position-holder.position-vacant{color:#999;font-style:italic}.departments-container{display:flex;flex-wrap:nowrap;gap:0;flex:1;min-height:300px;margin-top:4px;border-top:1px solid #e0e0e0;overflow:hidden}.department-box{display:flex;flex-direction:column;border:1px solid;border-radius:4px;background:#fff;overflow:hidden;flex:1 1 0;min-width:150px;min-height:80px;cursor:pointer;transition:box-shadow .15s ease}.department-box:hover{box-shadow:0 2px 8px #00000026}.department-box.selected{box-shadow:0 0 0 3px #3b82f680}.department-header{display:flex;align-items:center;gap:6px;padding:6px 10px;color:#fff;font-weight:500;font-size:13px;min-height:28px;box-sizing:border-box;opacity:.9}.department-number{background:#ffffff40;padding:1px 6px;border-radius:3px;font-size:11px}.department-name{font-size:13px}.department-content{padding:4px;flex:1;overflow-y:auto}.department-empty-hint{color:#bbb;font-size:12px;text-align:center;padding:10px}.vfps-section{width:100%;flex-shrink:0;border-top:1px solid #e0e0e0;margin-top:4px;background:#fff}.vfps-content{padding:8px 8px 20px}.vfps-label{font-size:11px;font-weight:600;color:#666;text-transform:uppercase;margin-bottom:4px}.vfps-text{font-size:13px;color:#333;line-height:1.4;white-space:pre-wrap;word-wrap:break-word}.modal{background:#fff;border-radius:8px;padding:24px;min-width:400px;max-width:500px;box-shadow:0 4px 20px #0000004d}.modal h2{margin:0 0 20px;font-size:20px;color:#333}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#555;font-size:14px}.form-group input[type=text]{width:100%;padding:10px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px;box-sizing:border-box}.form-group input[type=text]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.form-select{width:100%;padding:10px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px;box-sizing:border-box;background:#fff;cursor:pointer}.form-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500;color:#333}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-hint{display:block;margin-top:4px;font-size:12px;color:#888}.form-textarea{width:100%;padding:8px 10px;border:1px solid #ccc;border-radius:4px;font-size:14px;font-family:inherit;resize:vertical;min-height:80px}.form-textarea:focus{border-color:#4a90d9;outline:none}.color-picker-row{display:flex;align-items:center;gap:12px}.color-picker{width:50px;height:36px;padding:2px;border:1px solid #ccc;border-radius:4px;cursor:pointer}.color-value{font-family:monospace;font-size:14px;color:#666}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.cancel-button{padding:10px 20px;border:1px solid #ccc;border-radius:4px;background:#fff;color:#333;font-size:14px;cursor:pointer}.cancel-button:hover{background:#f5f5f5}.create-button{padding:10px 20px;border:none;border-radius:4px;background:#3b82f6;color:#fff;font-size:14px;cursor:pointer}.create-button:hover{background:#2563eb}.create-button:disabled{background:#ccc;cursor:not-allowed}.widget-base{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;transition:box-shadow .2s;display:flex;flex-direction:column;-webkit-user-select:none;user-select:none}.widget-base:hover{box-shadow:0 4px 8px #00000026}.widget-base.dragging{box-shadow:0 8px 16px #0000004d;cursor:grabbing;z-index:1000}.widget-base.resizing{box-shadow:0 8px 16px #0000004d;z-index:1000}.widget-resize-handle{position:absolute;bottom:0;right:0;width:16px;height:16px;cursor:nwse-resize;background:linear-gradient(135deg,transparent 0%,transparent 50%,#007acc 50%,#007acc 100%);border-bottom-right-radius:6px;z-index:10;opacity:.6;transition:opacity .2s}.widget-base:hover .widget-resize-handle{opacity:1}.widget-resize-handle:hover{background:linear-gradient(135deg,transparent 0%,transparent 50%,#005a9e 50%,#005a9e 100%)}.widget-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:flex-start;cursor:grab;flex-shrink:0}.widget-header:active{cursor:grabbing}.widget-header-left{flex:1;display:flex;flex-direction:column;gap:.25rem}.widget-type{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#6c757d}.widget-title{font-size:1.25rem;font-weight:600;color:#333;line-height:1.2}.widget-header-right{position:relative;flex-shrink:0}.widget-menu-button{background:transparent;border:none;color:#6c757d;font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;line-height:1;border-radius:4px;transition:all .2s}.widget-menu-button:hover{background:#e9ecef;color:#333}.widget-menu{position:absolute;top:100%;right:0;margin-top:.25rem;background:#fff;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 4px 8px #00000026;z-index:1001;min-width:150px}.widget-menu-item{display:block;width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;color:#333;font-size:.875rem;transition:background-color .2s}.widget-menu-item:hover{background:#f8f9fa}.widget-menu-item.delete{color:#dc3545}.widget-menu-item.delete:hover{background:#fff5f5}.widget-content{flex:1;padding:1rem;overflow:auto}.project-widget{display:flex;flex-direction:column;height:100%;overflow:hidden}.project-widget-loading,.project-widget-error{display:flex;align-items:center;justify-content:center;height:100%;color:#666;font-style:italic}.project-widget-stats-compact{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;border-bottom:1px solid #e9ecef;flex-shrink:0;font-size:.875rem;color:#666;height:40px}.stat-compact{font-weight:500}.stat-compact.completion{color:#28a745;font-weight:600}.stat-separator{color:#ccc}.project-widget-tasks{flex:1;overflow-y:auto;overflow-x:hidden}.task-section{margin-bottom:1rem}.task-section-header{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#6c757d;padding:.5rem .5rem .25rem;background:#f8f9fa;border-bottom:1px solid #e9ecef;position:sticky;top:0;z-index:1}.task-list{display:flex;flex-direction:column}.task-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem .5rem;border-bottom:1px solid #f0f0f0;transition:background-color .2s;justify-content:space-between}.task-status{font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;white-space:nowrap;flex-shrink:0}.task-status.not-started{background:#e9ecef;color:#6c757d}.task-status.in-progress{background:#cfe2ff;color:#007acc}.task-status.completed{background:#d1e7dd;color:#28a745}.task-status.on-hold{background:#fff3cd;color:#856404}.task-info{flex:1;min-width:0}.task-name{font-size:.875rem;color:#333;font-weight:500;line-height:1.3;word-wrap:break-word}.task-due{font-size:.75rem;color:#6c757d;margin-top:.25rem}.no-tasks{padding:2rem 1rem;text-align:center;color:#999;font-style:italic;font-size:.875rem}.statistic-widget-content{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff;position:relative}.statistic-widget-edit-btn{position:absolute;top:8px;right:8px;width:24px;height:24px;background:#007acc;color:#fff;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:background-color .2s;z-index:10}.statistic-widget-edit-btn:hover{background:#005a9e}.statistic-widget-add-data{position:absolute;top:8px;left:8px;right:8px;display:flex;gap:6px;align-items:center;background:#fff;padding:6px;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 2px 4px #0000001a;z-index:10}.statistic-widget-date-input,.statistic-widget-value-input{padding:4px 6px;border:1px solid #ddd;border-radius:3px;font-size:12px}.statistic-widget-date-input{flex:1}.statistic-widget-value-input{width:80px}.statistic-widget-save-btn,.statistic-widget-cancel-btn{width:24px;height:24px;border:none;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:background-color .2s}.statistic-widget-save-btn{background:#28a745;color:#fff}.statistic-widget-save-btn:hover:not(:disabled){background:#218838}.statistic-widget-save-btn:disabled{background:#ccc;cursor:not-allowed}.statistic-widget-cancel-btn{background:#dc3545;color:#fff}.statistic-widget-cancel-btn:hover{background:#c82333}.statistic-widget-graph{display:block}.statistic-widget-loading,.statistic-widget-error{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#666;font-size:.9rem}.statistic-widget-error{color:#dc3545}.my-targets-widget{display:flex;flex-direction:column;overflow:hidden;width:calc(100% + 2rem);height:calc(100% + 2rem);margin:-1rem;box-sizing:border-box}.widget-content:has(.my-targets-widget){overflow:hidden}.my-targets-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:0;width:100%;box-sizing:border-box;scrollbar-gutter:stable}.loading{display:flex;align-items:center;justify-content:center;height:100%;color:#666;font-style:italic}.empty-state{display:flex;align-items:center;justify-content:center;height:100%;color:#666;font-style:italic;text-align:center;padding:2rem}.projects-list{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:100%;padding:.5rem;box-sizing:border-box}.project-group{background:#fff;border-radius:6px;overflow:hidden;width:100%;max-width:100%;box-sizing:border-box}.project-header{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#007acc;color:#fff;font-weight:600;cursor:pointer;transition:background-color .2s;max-width:100%;box-sizing:border-box}.project-header:hover{background:#005a9e}.project-icon{font-size:1rem}.project-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;word-break:break-all}.task-count{font-size:.875rem;opacity:.9;flex-shrink:0}.tasks-list{display:flex;flex-direction:column;max-width:100%}.task-item{padding:.75rem .75rem .75rem 2rem;border-bottom:1px solid #e9ecef;cursor:pointer;transition:background-color .2s;max-width:100%;box-sizing:border-box}.task-item:last-child{border-bottom:none}.task-item:hover{background:#f8f9fa}.task-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.25rem;max-width:100%;min-width:0}.task-name{font-weight:600;color:#333;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;word-break:break-all}.task-status{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;color:#fff;white-space:nowrap;flex-shrink:0}.task-due{font-size:.875rem;color:#666;margin-top:.25rem}.my-graphs-widget-content{width:100%;height:100%;overflow:auto;padding:10px;box-sizing:border-box}.my-graphs-widget-loading{display:flex;align-items:center;justify-content:center;height:100%;color:#666;font-size:14px}.my-graphs-widget-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#666;text-align:center;padding:20px}.my-graphs-widget-empty p{margin:0 0 8px}.my-graphs-widget-hint{font-size:12px;color:#999}.my-graphs-grid{display:grid;width:100%}.my-graphs-item{background:#fff;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden;cursor:pointer;transition:box-shadow .2s,transform .1s}.my-graphs-item:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.my-graphs-item-header{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#f5f5f5;border-bottom:1px solid #e0e0e0}.my-graphs-item-abbrev{font-weight:600;font-size:12px;color:#333;background:#e0e0e0;padding:2px 6px;border-radius:3px}.my-graphs-item-name{font-size:12px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.my-graphs-mini-graph{display:block}.org-chart-widget{width:100%;height:100%;overflow:hidden;background:#fafafa;position:relative}.org-chart-widget.loading,.org-chart-widget.error{display:flex;align-items:center;justify-content:center;color:#888;font-size:14px}.org-chart-widget-content{position:absolute}.org-widget-division{position:absolute;border:2px solid;border-radius:6px;background:#fff;box-shadow:0 1px 4px #0000001a;display:flex;flex-direction:column;overflow:hidden}.org-widget-division-header{display:flex;align-items:center;gap:6px;padding:6px 10px;color:#fff;font-weight:600;font-size:11px;min-height:28px}.org-widget-division-header.raised{min-height:58px;padding-top:36px}.org-widget-division-number{background:#ffffff40;padding:2px 6px;border-radius:3px;font-size:10px}.org-widget-division-name{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.org-widget-division-content{flex:1;padding:4px;overflow:hidden;display:flex;flex-direction:column}.org-widget-positions-section{margin-bottom:4px}.org-widget-position{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:3px;padding:3px 6px;margin-bottom:2px}.org-widget-position-title{font-size:9px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.org-widget-position-holder{font-size:8px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.org-widget-departments{display:flex;gap:4px;flex:1;min-height:0;border-top:1px solid #e0e0e0;padding-top:4px}.org-widget-department{flex:1;border:1px solid;border-radius:4px;background:#fff;overflow:hidden;display:flex;flex-direction:column;min-width:0}.org-widget-department-header{display:flex;align-items:center;gap:4px;padding:3px 6px;color:#fff;font-size:9px;min-height:20px;opacity:.9}.org-widget-department-number{background:#ffffff40;padding:1px 4px;border-radius:2px;font-size:8px}.org-widget-department-name{font-size:9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.org-widget-department-content{flex:1;padding:3px;overflow:hidden}.org-widget-vfps{border-top:1px solid #e0e0e0;padding:4px;margin-top:auto;background:#fff}.org-widget-vfps-label{font-size:8px;font-weight:600;color:#666;text-transform:uppercase;margin-bottom:2px}.org-widget-vfps-text{font-size:9px;color:#333;line-height:1.3;white-space:pre-wrap;overflow:hidden;max-height:40px}.org-widget-empty{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#888;font-size:12px}.division-widget{width:100%;height:100%;overflow:hidden;background:#fafafa;position:relative}.division-widget.loading,.division-widget.error{display:flex;align-items:center;justify-content:center;color:#888;font-size:14px}.division-widget-content{position:absolute}.div-widget-division{border:2px solid;border-radius:6px;background:#fff;box-shadow:0 1px 4px #0000001a;display:flex;flex-direction:column;overflow:hidden}.div-widget-division-header{display:flex;align-items:center;gap:8px;padding:8px 12px;color:#fff;font-weight:600;font-size:13px;min-height:32px}.div-widget-division-header.raised{min-height:62px;padding-top:38px}.div-widget-division-number{background:#ffffff40;padding:2px 8px;border-radius:4px;font-size:11px}.div-widget-division-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.div-widget-division-content{flex:1;padding:8px;overflow:hidden;display:flex;flex-direction:column}.div-widget-positions-section{margin-bottom:8px}.div-widget-position{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:4px;padding:4px 8px;margin-bottom:4px}.div-widget-position-title{font-size:11px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.div-widget-position-holder{font-size:10px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.div-widget-departments{display:flex;gap:8px;flex:1;min-height:0;border-top:1px solid #e0e0e0;padding-top:8px}.div-widget-department{flex:1;border:1px solid;border-radius:4px;background:#fff;overflow:hidden;display:flex;flex-direction:column;min-width:0}.div-widget-department-header{display:flex;align-items:center;gap:6px;padding:4px 8px;color:#fff;font-size:11px;min-height:24px;opacity:.9}.div-widget-department-number{background:#ffffff40;padding:2px 6px;border-radius:3px;font-size:10px}.div-widget-department-name{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.div-widget-department-content{flex:1;padding:6px;overflow:hidden}.div-widget-vfps{border-top:1px solid #e0e0e0;padding:6px;margin-top:auto;background:#fff}.div-widget-vfps-label{font-size:9px;font-weight:600;color:#666;text-transform:uppercase;margin-bottom:4px}.div-widget-vfps-text{font-size:11px;color:#333;line-height:1.4;white-space:pre-wrap;overflow:hidden;max-height:60px}.dashboard-page{display:flex;flex-direction:column;height:100%;width:100%;background:#f5f7fa;overflow:hidden;flex:1}.dashboard-header{background:#fff;padding:1.5rem 2rem;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d;display:flex;align-items:center;gap:1.5rem;flex-shrink:0;z-index:100}.dashboard-header h1{margin:0;color:#333;font-size:1.75rem;flex:1}.dashboard-scrollable{flex:1;overflow:auto;position:relative}.widgets-canvas{position:relative;min-height:100%;width:100%;padding:0 16px 0 0;overflow-x:hidden;box-sizing:border-box}.empty-widgets-canvas{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#666;font-style:italic;background:#fff;border:2px dashed #e0e0e0;border-radius:8px;padding:4rem 2rem;max-width:500px}.add-widget-button-header{background:#6f42c1;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.add-widget-button-header:hover{background:#5a32a3}.loading-state{display:flex;align-items:center;justify-content:center;height:100vh;color:#666;font-style:italic}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;padding:2rem;border-radius:8px;width:90%;max-width:500px;box-shadow:0 10px 25px #0003}.modal h2{margin-top:0;margin-bottom:1.5rem;color:#333}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box;background:#fff}.form-group select:focus{outline:none;border-color:#6f42c1;box-shadow:0 0 0 2px #6f42c133}.info-message{padding:1rem;background:#f8f9fa;border-left:4px solid #6f42c1;color:#666;border-radius:4px;margin-bottom:1rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.cancel-button{background:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.cancel-button:hover{background:#5a6268}.add-button{background:#6f42c1;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.add-button:hover{background:#5a32a3}.add-button:disabled{background:#ccc;cursor:not-allowed}@media(max-width:768px){.dashboard-header{flex-wrap:wrap}.dashboard-header h1{flex-basis:100%;order:-1}}.app{height:100vh;background-color:#f5f5f5;overflow:hidden;display:flex;flex-direction:column}.app-content{flex:1;background-color:#f5f5f5;overflow:auto;display:flex;flex-direction:column}.app-logo{display:flex;align-items:center;gap:1rem}.header-logo-container{display:flex;align-items:center;gap:.5rem}.header-logo{height:40px;width:auto}.header-logo-container .company-name{font-size:1.5rem;font-weight:600;color:#333}.header-back-button{width:40px;height:40px;border:none;background:#6c757d;color:#fff;font-size:1.5rem;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;border-radius:4px;padding:0;flex-shrink:0}.header-back-button:hover{background:#5a6268}.header-back-button:active{background:#495057}
