:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh;scrollbar-gutter:stable}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s;-webkit-user-select:none;user-select:none}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}a,input[type=button],input[type=submit],input[type=reset],[role=button],[onclick],.clickable{-webkit-user-select:none;user-select:none}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.tool-page-template{height:100vh;background:#f3f4f6;color:#1f2937;display:flex;flex-direction:column;overflow:hidden}.tool-page-template .header{background:#35363a;border-bottom:1px solid #2a2b2f;padding:.875rem 2rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 4px #0003;margin:0;width:100%;position:sticky;top:0;z-index:1000}.tool-page-template .header-left{display:flex;align-items:center;gap:1.5rem;flex:1}.tool-page-template .header-right{display:flex;align-items:center;gap:1rem;margin-left:auto;justify-content:flex-end}.tool-page-template .logo-link{display:flex;align-items:center;text-decoration:none;transition:opacity .2s ease}.tool-page-template .logo-link:hover{opacity:.8}.tool-page-template .logo{height:40px}.tool-page-template .header-title{font-size:1.25rem;font-weight:600;color:#fff;margin:0}.tool-page-template .hamburger-menu{position:relative}.tool-page-template .hamburger-button{background:none;border:none;width:32px;height:32px;cursor:pointer;color:#fff;transition:opacity .2s ease;outline:none!important;box-shadow:none!important}.tool-page-template .hamburger-button:hover{opacity:.8}.tool-page-template .hamburger-button:focus{outline:none!important;border:none!important;box-shadow:none!important}.tool-page-template .dropdown-menu{position:absolute;top:100%;left:0;background:#fff;border-radius:8px;box-shadow:0 10px 25px #00000026;padding:.5rem 0;min-width:220px;z-index:1100;border:none;margin-top:.25rem}.tool-page-template .menu-section+.menu-section{border-top:1px solid #f3f4f6;margin-top:.25rem;padding-top:.25rem}.tool-page-template .menu-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;color:#3fae49;padding:.25rem 1rem;letter-spacing:.05em}.tool-page-template .menu-item{display:block;width:100%;text-align:left;padding:.375rem 1rem;font-size:.875rem;font-weight:500;color:#374151;background:none;border:none;cursor:pointer;transition:background-color .2s ease}.tool-page-template .menu-item:hover{background:#f9fafb;color:#111827}.tool-page-template .user-menu{position:relative;display:flex;align-items:center;gap:.5rem;justify-content:flex-end}.tool-page-template .user-info{font-size:.875rem;color:#fff}.tool-page-template .user-name{font-size:.875rem;color:#fff;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s ease}.tool-page-template .user-name:hover,.tool-page-template .user-name:focus{background:#ffffff1a;outline:none}.tool-page-template .user-dropdown{position:absolute;top:100%;right:0;background:#fff;border-radius:6px;box-shadow:0 10px 25px #00000026;padding:.5rem 0;min-width:160px;z-index:1100;border:1px solid #e5e7eb;margin-top:.25rem}.tool-page-template .logout-link{display:block;width:100%;text-align:left;padding:.75rem 1rem;font-size:.875rem;color:#374151;background:none;border:none;cursor:pointer;transition:background-color .2s ease}.tool-page-template .logout-link:hover{background:#f3f4f6;color:#111827}.tool-page-template .header-actions{display:flex;align-items:center;gap:.75rem}.tool-page-template__permissions-warning{margin:1rem 2rem 0;padding:.75rem 1rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;color:#92400e;font-size:.875rem}.tool-page-template__content{padding-top:2rem;flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto}.tool-page-template__loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:#f3f4f6;color:#1f2937;text-align:center;padding:2rem}.tool-page-template__access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 2rem;max-width:480px;margin:0 auto;flex:1}.tool-page-template__access-denied-icon{color:#9ca3af;margin-bottom:1.5rem}.tool-page-template__access-denied h2{margin:0 0 .75rem;font-size:1.5rem;font-weight:600;color:#374151}.tool-page-template__access-denied p{margin:0 0 2rem;font-size:1rem;color:#6b7280;line-height:1.5}.tool-page-template__access-denied-button{background:#3bae4a;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.tool-page-template__access-denied-button:hover{background:#2d8a3a}@media(max-width:768px){.tool-page-template .header{padding:1rem}.tool-page-template .header-left{gap:1rem}.tool-page-template .header-actions{flex-wrap:wrap;justify-content:flex-start;gap:.5rem}.tool-page-template .user-info{display:none}}.login-container,.login-container *,.login-container *:before,.login-container *:after{box-sizing:border-box}:root{--ctc-green: #3fae49;--ctc-grey: #333439;--ctc-light-grey: #6b7280;--ctc-bg-grey: #f8fafc;--ctc-border: #d1d5db;--ctc-white: white;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1)}body:has(.login-container){margin:0;padding:0;overflow:hidden}.login-container{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:#f3f4f6;position:fixed;top:0;left:0;overflow:hidden;z-index:9999}.background-pattern{position:absolute;inset:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%2339A947' fill-opacity='0.1'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");z-index:1}.login-card{background:var(--ctc-white);border-radius:12px;box-shadow:var(--shadow-lg);padding:0;width:100%;max-width:360px;position:relative;z-index:2;overflow:hidden}.login-header{text-align:center;margin-bottom:0}.logo-banner{background:var(--ctc-grey);padding:1.25rem 1rem;margin-bottom:1.5rem;display:flex;justify-content:center;align-items:center}.login-logo{width:140px;height:auto}.login-title{font-size:1.75rem;font-weight:400;color:var(--ctc-grey);margin-bottom:1.25rem;padding:0 2rem}.login-form{width:100%;padding:0 2rem 2rem}.form-group{margin-bottom:1.25rem;position:relative}.form-group.focused .form-label{color:var(--ctc-green);transform:translateY(-.25rem);font-size:.875rem}.form-label{display:block;font-size:.95rem;font-weight:600;color:var(--ctc-grey);margin-bottom:.5rem;transition:all .2s ease}.form-input{width:100%;padding:.875rem 1rem;border:2px solid var(--ctc-border);border-radius:8px;font-size:1rem;background:var(--ctc-white);color:var(--ctc-grey);transition:all .2s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:var(--ctc-green);box-shadow:0 0 0 3px #39a9471a}.form-input::placeholder{color:#9ca3af}.form-input.error{border-color:#ef4444;background-color:#fef2f2}.login-button{width:100%;background:var(--ctc-green);color:var(--ctc-white);border:none;border-radius:8px;padding:.875rem;font-size:1.05rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:.75rem}.login-button:hover{background:#35a843;transform:translateY(-1px);box-shadow:var(--shadow-md)}.login-button:active{transform:translateY(0)}.login-button:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem;border-radius:6px;font-size:.875rem;margin-bottom:1rem}.container{max-width:1600px;margin:0 auto;padding:2rem}.admin-panel{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:24px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid #e5e5e5}.users-table-container{margin-top:24px}.admin-header h1{margin:0;color:#333439;font-size:28px;font-weight:600}.section-title{margin:0;color:#333439;font-size:1.5rem;font-weight:600}.users-table-container{margin-top:1rem}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e5e5e5}.users-table th:last-child{padding-left:26px}.users-table th{background-color:#f8f9fa;font-weight:600;color:#333439;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.users-table tr:hover{background-color:#f8f9fa}.users-table tr:last-child td{border-bottom:none}.role-select{padding:6px 8px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:14px;min-width:140px}.role-select:focus{outline:none;border-color:#3fae49;box-shadow:0 0 0 2px #39a94733}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;min-width:70px;text-align:center}.status-active{background-color:#d1f2eb;color:#0f5132}.status-pending{background-color:#fff3cd;color:#856404}.status-inactive{background-color:#f8d7da;color:#721c24}.empty-state{text-align:center;padding:48px 24px;color:#666}.empty-state p{margin:0;font-size:16px}.action-buttons{display:flex;gap:8px;align-items:center}.btn-small{font-size:12px;padding:4px 8px;min-width:60px}.btn-danger{background-color:#dc3545;color:#fff;border:1px solid #dc3545}.btn-danger:disabled{background-color:#6c757d;border-color:#6c757d;cursor:not-allowed}.admin-modal-overlay{position:fixed!important;inset:0;background-color:#00000080;display:flex!important;align-items:center;justify-content:center;z-index:9999}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:320px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 25px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px;border-bottom:1px solid #e5e5e5}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:#333439}.modal-close{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#333}.modal-body{padding:24px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px 24px;border-top:1px solid #e5e5e5}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#333439;font-size:14px}.form-group input:not([type=checkbox]),.form-group select{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:4px;font-size:13px;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3fae49;box-shadow:0 0 0 2px #39a94733}.form-group small{display:block;margin-top:4px;color:#666;font-size:12px}.checkbox-label{display:flex!important;align-items:center;gap:8px;margin-bottom:6px!important;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px!important;height:18px!important;min-width:18px;min-height:18px;margin:0;cursor:pointer;accent-color:#3fae49}.checkbox-row{display:flex;align-items:center;gap:10px;margin-top:4px}.checkbox-row .permission-checkbox{margin-top:0}.checkbox-row .checkbox-text{cursor:pointer;margin-top:4px}.checkbox-text{font-weight:500;color:#333439;font-size:14px}.edit-user-modal-content{max-width:500px!important;width:90%!important;overflow-y:visible!important;max-height:none!important}.btn{display:inline-block;padding:10px 16px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333439;text-decoration:none;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.modal-content .btn,.modal-content button.btn{color:#333439!important;background-color:#fff}.modal-content .btn-primary,.modal-content button.btn-primary{background-color:#3fae49!important;border-color:#3fae49!important;color:#fff!important}.btn:hover{background-color:#f8f9fa;border-color:#ccc}.btn:disabled{background-color:#e9ecef;border-color:#ccc;color:#333;cursor:not-allowed}.btn-primary{background-color:#3fae49;border:none!important;color:#fff}.btn-primary:hover{background-color:#2d8635}.btn-danger{background-color:#dc3545;border-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333;border-color:#bd2130}.edit-btn,.delete-btn{background:#ef4444;color:#fff;border:none;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center}.edit-btn{background:#6b7280;margin-right:.5rem}.edit-btn:hover{background:#4b5563}.delete-btn:hover{background:#dc2626}.permissions-section{margin-top:3rem}.permissions-header{display:flex;justify-content:space-between;align-items:center;margin:2rem 0 1rem}.permissions-table-container{overflow-x:auto;border:1px solid #e5e5e5;border-radius:8px}.permissions-table{width:100%;border-collapse:collapse;background:#fff}.permissions-table th{background:#f8f9fa;padding:12px;font-weight:600;color:#333439;border-bottom:2px solid #e5e5e5;text-align:center;white-space:nowrap}.permissions-table th:first-child{text-align:left;width:300px;background:#f8f9fa;color:#333439}.permissions-table th:not(:first-child){width:100px;min-width:100px}.permissions-table td{padding:10px 12px;border-bottom:1px solid #e5e5e5;text-align:center}.permissions-table td:first-child{text-align:left;font-weight:500;background:#f8f9fa;border-right:1px solid #e5e5e5}.permission-checkbox{width:18px;height:18px;cursor:pointer;accent-color:#3fae49;appearance:none;-webkit-appearance:none;-moz-appearance:none;border:2px solid #d1d5db;border-radius:3px;background:#fff;position:relative;transition:all .2s ease}.permission-checkbox:checked{background:#3fae49;border-color:#3fae49}.permission-checkbox:checked:after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.permission-checkbox:disabled{cursor:not-allowed;opacity:.6;background:#f3f4f6;border-color:#d1d5db}.permission-checkbox:disabled:checked{background:#9ca3af;border-color:#9ca3af}.permissions-actions{margin-top:1rem;display:flex;gap:1rem;justify-content:flex-end}.role-header{font-size:14px;font-weight:600}.category-row td{background:#f3f4f6!important;font-weight:600;color:#374151;border-top:2px solid #9ca3af}.category-row td:first-child{background:#f3f4f6!important;color:#374151}.error-message{color:#dc3545;font-size:14px;margin-bottom:16px;padding:8px 12px;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px}.success-message{color:#155724;font-size:14px;margin-bottom:16px;padding:8px 12px;background-color:#d1eddb;border:1px solid #c3e6cb;border-radius:4px}.warning-message{color:#155724;font-size:14px;margin:0 24px 24px;padding:12px;background-color:#d1eddb;border:1px solid #3fae49;border-radius:4px}.warning-message strong{display:block;margin-bottom:8px}.warning-message .credentials-row{display:flex;justify-content:space-between;align-items:flex-end}.warning-message .credentials{flex:1}.warning-message .btn{background-color:#fff;border-color:#3fae49;color:#155724}.warning-message .btn:hover{background-color:#f0fff4}.profile-tabs{display:flex;border-bottom:1px solid #e5e5e5;margin-bottom:24px;background-color:#f8f9fa;border-radius:8px 8px 0 0;padding:4px;gap:4px}.tab-button{background:transparent;border:1px solid transparent;border-radius:6px;padding:12px 20px;font-size:14px;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-width:120px;text-align:center}.tab-button:hover{color:#333;background-color:#e9ecef;border-color:#dee2e6}.tab-button.active{color:#3fae49;background-color:#fff;border-color:#e5e5e5;box-shadow:0 2px 4px #0000000d;font-weight:600}.profile-form-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;margin-bottom:1.5rem;max-width:800px;margin-left:auto;margin-right:auto}.profile-form-container h3{font-size:1rem;font-weight:600;color:#374151;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #3fae49}.form-note{background:#f9fafb;border:1px solid #e5e7eb;padding:.75rem;border-radius:4px;font-size:.875rem;color:#6b7280;margin-bottom:1rem}@media(max-width:768px){.admin-page{padding:16px}.admin-header{flex-direction:column;gap:16px;align-items:stretch}.users-table-container{overflow-x:auto}.users-table{min-width:600px}.modal-content{width:95%;margin:16px}}.header-btn{padding:.375rem .75rem;font-size:.875rem;border:1px solid rgba(255,255,255,.3);border-radius:4px;background:#fff3;color:#fff;cursor:pointer;transition:border-color .2s ease;outline:none;-webkit-user-select:none;user-select:none}.header-btn:hover:not(:disabled){border-color:#3fae49}.header-btn:focus{outline:none;border-color:#3fae49}.header-btn:disabled{background:#ffffff1a;color:#ffffff80;cursor:not-allowed;opacity:.5}.header-btn.export-btn{border:1px solid rgba(255,255,255,.3);border-radius:.25rem}.header-btn.export-btn:hover:not(:disabled){border-color:#3fae49}.header-btn.export-btn:focus{outline:none;border-color:#3fae49}body{margin:0;padding:0}.planning-page{min-height:calc(100vh - 73px);background:#f3f4f6}.header{background:#35363a;border-bottom:1px solid #2a2b2f;padding:.875rem 2rem;display:flex;align-items:center;box-shadow:0 2px 4px #0003;position:sticky;top:0;z-index:1000;width:100%;margin:0}.planning-header{display:grid!important;grid-template-columns:1fr auto 1fr!important;-webkit-user-select:none;user-select:none}.header-left{display:flex;align-items:center;gap:1.5rem}.planning-header .header-left{justify-self:start}.header-center{display:flex;align-items:center}.planning-header .header-center{justify-self:center}.logo{height:40px}.header-title{font-size:1.25rem;font-weight:600;color:#fff;margin:0}.header-right{display:flex;align-items:center;gap:1rem;margin-left:auto}.planning-header .header-right{margin-left:initial;justify-self:end}.hamburger-menu{position:relative}.hamburger-button{background:none;border:none;width:32px;height:32px;cursor:pointer;color:#fff;transition:opacity .2s ease;outline:none!important;box-shadow:none!important;-webkit-user-select:none;user-select:none}.hamburger-button:hover{opacity:.8}.hamburger-button:focus{outline:none!important;box-shadow:none!important;border:none!important}.dropdown-menu{position:absolute;top:100%;left:0;background:#fff;border-radius:8px;box-shadow:0 10px 25px #00000026;padding:.5rem 0;min-width:200px;z-index:1000;border:1px solid #e5e7eb;margin-top:2px}.menu-item{display:block;padding:.375rem 1rem;color:#374151;text-decoration:none;font-size:.875rem;font-weight:500;transition:background-color .2s ease;border:none;background:none;text-align:left;width:100%;cursor:pointer;-webkit-user-select:none;user-select:none}.menu-item:hover{background:#f9fafb;color:#1f2937}.user-info{font-size:.875rem;color:#fff}.user-menu{position:relative}.user-name{font-size:.875rem;color:#fff;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.user-name:hover{background:#ffffff1a}.user-dropdown{position:absolute;top:100%;right:0;background:#fff;border-radius:6px;box-shadow:0 10px 25px #00000026;padding:.5rem 0;min-width:120px;z-index:1000;border:1px solid #e5e7eb;margin-top:.25rem}.logout-link{display:block;padding:.75rem 1rem;color:#374151;text-decoration:none;font-size:.875rem;transition:background-color .2s ease}.logout-link:hover{background:#f9fafb;color:#1f2937}.menu-section+.menu-section{border-top:1px solid #f3f4f6;margin-top:.25rem;padding-top:.25rem}.menu-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;color:#3fae49;padding:.25rem 1rem;letter-spacing:.05em}.apply-banner{background:#fef3c7;border-bottom:1px solid #f59e0b;padding:.75rem 2rem;box-shadow:0 1px 2px #0000000d;z-index:90}.apply-banner-content{display:flex;justify-content:space-between;align-items:center;max-width:100%}.changes-indicator{font-size:.875rem;font-weight:600;color:#92400e}.apply-btn{background:#3fae49;color:#fff;border:none;padding:.625rem 1.25rem;border-radius:6px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.apply-btn:hover{background:#2d8a3a}.container{max-width:1600px;margin:2rem auto;padding:0 2rem;-webkit-user-select:none;user-select:none}.section{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a;-webkit-user-select:none;user-select:none}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.section-title{font-size:1.25rem;font-weight:600;color:#1f2937}.toggle-container{display:flex;align-items:center;gap:.5rem}.toggle-label{font-size:.875rem;color:#6b7280}.toggle-switch{position:relative;width:48px;height:24px;background:#9ca3af;border-radius:12px;cursor:pointer;transition:background .3s;-webkit-user-select:none;user-select:none}.toggle-switch.active{background:#3bae4a}.toggle-slider{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s;box-shadow:0 2px 4px #0003;-webkit-user-select:none;user-select:none}.toggle-switch.active .toggle-slider{transform:translate(24px)}.controls-group{display:flex;gap:1rem;align-items:center;transform:translateY(-8px) translate(-3px)}.table-wrapper{overflow-x:auto;border:1px solid #e5e7eb;border-radius:6px;-webkit-user-select:none;user-select:none}.planning-table{width:100%;border-collapse:collapse;font-size:.875rem;table-layout:fixed;-webkit-user-select:none;user-select:none}.planning-table th{background:#f9fafb;padding:.75rem 1rem;text-align:center;font-weight:600;font-size:1.1rem;color:#374151;border-bottom:2px solid #e5e7eb;border-right:1px solid #e5e7eb;-webkit-user-select:none;user-select:none}.planning-table td{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;vertical-align:middle;height:3.5rem;line-height:1.2em;-webkit-user-select:none;user-select:none}.planning-table tr:not(.workforce-row):hover{background:#f9fafb}.first-col{width:300px;font-weight:500;text-align:left!important;-webkit-user-select:none;user-select:none}.financial{text-align:right;font-weight:400;-webkit-user-select:none;user-select:none}.financial.total{font-weight:500}.revenue-cell{font-weight:600}.fy-column{background:#f6f8f6;border-left:1px solid #e5e7eb}th.fy-column{background:#3bae4a;color:#fff}.planning-table .project-name{font-weight:500;font-size:1rem;color:#1f2937;cursor:pointer;text-decoration:none;margin:0;vertical-align:middle;-webkit-user-select:none;user-select:none}.planning-table .project-name:hover{color:#3fae49;text-decoration:underline}.spread-pattern{display:flex;align-items:flex-end;justify-content:center;height:22px;gap:1.5px;width:100%;padding:0 2px;-webkit-user-select:none;user-select:none}.spread-bar{width:2.5px;background:#3bae4a;border-radius:1px}.pattern-even .spread-bar{height:16px}.pattern-front_loaded .spread-bar:nth-child(1){height:20px}.pattern-front_loaded .spread-bar:nth-child(2){height:20px}.pattern-front_loaded .spread-bar:nth-child(3){height:17px}.pattern-front_loaded .spread-bar:nth-child(4){height:14px}.pattern-front_loaded .spread-bar:nth-child(5){height:11px}.pattern-front_loaded .spread-bar:nth-child(6){height:8px}.pattern-front_loaded .spread-bar:nth-child(7){height:5px}.pattern-front_loaded .spread-bar:nth-child(8){height:3px}.pattern-back_loaded .spread-bar:nth-child(1){height:3px}.pattern-back_loaded .spread-bar:nth-child(2){height:5px}.pattern-back_loaded .spread-bar:nth-child(3){height:8px}.pattern-back_loaded .spread-bar:nth-child(4){height:11px}.pattern-back_loaded .spread-bar:nth-child(5){height:14px}.pattern-back_loaded .spread-bar:nth-child(6){height:17px}.pattern-back_loaded .spread-bar:nth-child(7){height:20px}.pattern-back_loaded .spread-bar:nth-child(8){height:20px}.pattern-bell_curve .spread-bar:nth-child(1){height:4px}.pattern-bell_curve .spread-bar:nth-child(2){height:8px}.pattern-bell_curve .spread-bar:nth-child(3){height:14px}.pattern-bell_curve .spread-bar:nth-child(4){height:20px}.pattern-bell_curve .spread-bar:nth-child(5){height:20px}.pattern-bell_curve .spread-bar:nth-child(6){height:14px}.pattern-bell_curve .spread-bar:nth-child(7){height:8px}.pattern-bell_curve .spread-bar:nth-child(8){height:4px}.pattern-s_curve .spread-bar:nth-child(1){height:2px}.pattern-s_curve .spread-bar:nth-child(2){height:4px}.pattern-s_curve .spread-bar:nth-child(3){height:7px}.pattern-s_curve .spread-bar:nth-child(4){height:12px}.pattern-s_curve .spread-bar:nth-child(5){height:16px}.pattern-s_curve .spread-bar:nth-child(6){height:19px}.pattern-s_curve .spread-bar:nth-child(7){height:20px}.pattern-s_curve .spread-bar:nth-child(8){height:20px}.pattern-plateau .spread-bar:nth-child(1){height:2px}.pattern-plateau .spread-bar:nth-child(2){height:15px}.pattern-plateau .spread-bar:nth-child(3){height:20px}.pattern-plateau .spread-bar:nth-child(4){height:20px}.pattern-plateau .spread-bar:nth-child(5){height:20px}.pattern-plateau .spread-bar:nth-child(6){height:20px}.pattern-plateau .spread-bar:nth-child(7){height:15px}.pattern-plateau .spread-bar:nth-child(8){height:2px}.in-out-toggle{display:inline-block;position:relative;width:48px;height:24px;background:#3bae4a;border-radius:12px;cursor:pointer;margin:0 auto;-webkit-user-select:none;user-select:none}.in-out-toggle.out{background:#9ca3af}.in-out-slider{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s;box-shadow:0 2px 4px #0003;transform:translate(24px);-webkit-user-select:none;user-select:none}.in-out-toggle.out .in-out-slider{transform:translate(0)}.planning-table tr.excluded{opacity:.5;color:#9ca3af}.planning-table tr.excluded .project-name{color:#a0a0a0}.planning-table tr.excluded .spread-pattern{opacity:.4}.summary-row{background:#f9fafb;font-weight:600}.summary-row td{background:#f9fafb!important;border-top:2px solid #d1d5db;border-bottom:3px solid #e2e8f0;padding:1rem}.section-spacer{height:20px;border:none}.section-spacer td{background:transparent!important;border:none!important;padding:0!important}.workforce-year-headers{height:48px}.workforce-year-headers td{vertical-align:middle}.workforce-year-headers .fy-column{background:#3bae4a!important;color:#fff;font-weight:600;text-align:center;vertical-align:middle;font-size:1rem;width:100px}.workforce-row td{padding:.75rem;border-bottom:1px solid #e5e7eb}.workforce-row .first-col{font-weight:600;font-size:1.1rem;color:#374151}.staff-cell,.hourly-cost-cell,.hourly-rate-cell,.profit-cell,.profit-margin-cell{text-align:center;-webkit-user-select:none;user-select:none}.financial-cell-positive{background-color:#f6f8f6}.financial-cell-negative{background-color:#fef2f2}.staff-cell:hover,.hourly-cost-cell:hover,.hourly-rate-cell:hover,.profit-cell:hover,.profit-margin-cell:hover{cursor:pointer}.staff-cell:hover,.financial-cell-positive:hover{background-color:#ebf7ed!important}.financial-cell-negative:hover{background-color:#fee2e2!important}.editable-date{cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s;position:relative;display:inline-block;min-width:115px;width:115px;height:1.7rem;-webkit-user-select:none;user-select:none}.editable-date:hover{background:#f0fdf4}.date-input{position:absolute;inset:0;width:100%;height:100%;padding:0;margin:0;border:1px solid #3b82f6;border-radius:3px;font-size:.875rem!important;line-height:1.2em;font-family:inherit;text-align:center;box-sizing:border-box;background:#fff}.date-input:focus{outline:none;border-color:#1d4ed8;box-shadow:0 0 0 3px #3b82f61a}.shape-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:1000;align-items:center;justify-content:center}.shape-modal.show{display:flex}.shape-modal-content{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 10px 25px #0003;max-width:500px;width:90%}.shape-modal-title{font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;color:#1f2937;text-align:center}.shape-options{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.shape-option{display:flex;flex-direction:column;align-items:center;padding:1rem;border:2px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.shape-option:hover{border-color:#3bae4a;background:#f0fdf4}.shape-option.selected{border-color:#3bae4a;background:#dcfce7}.shape-option-pattern{margin-bottom:.5rem}.shape-option-name{font-size:.875rem;font-weight:500;color:#374151}.shape-modal-buttons{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.btn{padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s;border:none;font-size:.875rem;-webkit-user-select:none;user-select:none}.btn:focus{outline:none}.btn-secondary{background:#f3f4f6!important;color:#374151!important}.btn-secondary:hover{background:#e5e7eb!important}.btn-primary{background:#3bae4a!important;color:#fff!important}.btn-primary:hover{background:#16a34a!important}.btn-disabled{background:#d1d5db!important;color:#9ca3af!important;cursor:not-allowed!important}.btn-disabled:hover{background:#d1d5db!important}.spread-pattern.clickable{cursor:pointer}.spread-pattern.clickable:hover{opacity:.8}.spread-pattern.disabled,.in-out-toggle.disabled{cursor:not-allowed!important;opacity:.5}.project-modal-backdrop{position:fixed;inset:0;background:#00000080;display:none;align-items:center;justify-content:center;z-index:2000;padding:1rem;animation:fadeIn .2s ease-out}.project-modal-backdrop.show{display:flex}.project-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;width:100%;max-height:95vh;overflow:hidden;animation:slideIn .3s ease-out}.project-name-header{display:flex;align-items:center;gap:1rem;padding:1.5rem 2rem 1rem;border-bottom:1px solid #e5e7eb}.project-name-input{flex:1;font-size:1.5rem;font-weight:600;padding:.75rem 1rem;border:2px solid #3fae49;border-radius:8px;color:#3fae49;outline:none;transition:border-color .2s}.project-name-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.project-name-input::placeholder{color:#9ca3af}.project-modal-close{background:none;border:none;padding:.5rem;cursor:pointer;font-size:1.25rem;color:#6b7280;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.project-modal-close:hover{background:#e5e7eb;color:#374151}.project-modal-content{padding:0;overflow-y:auto;max-height:calc(95vh - 80px)}.project-form{display:flex;flex-direction:column;min-height:400px}.project-form-content{padding:1.5rem 2rem 2rem;display:flex;flex-direction:column;gap:1.5rem}.project-date-row,.project-budget-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem;align-items:start}.project-field{display:flex;flex-direction:column;gap:.5rem}.project-label{font-size:.875rem;font-weight:500;color:#374151}.project-input,.project-select{padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;outline:none;transition:border-color .2s}.project-input[type=date]{position:relative;z-index:9999;background:#fff;cursor:pointer}.project-input[type=number]::-webkit-outer-spin-button,.project-input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.project-input[type=number]{-moz-appearance:textfield}.project-input:focus,.project-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.project-help-text{font-size:.75rem;color:#6b7280;margin-top:.25rem}.effective-rate-display{font-size:1.125rem;font-weight:600;color:#374151;padding-top:.5rem;margin-top:-4px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.project-form-actions{display:flex;justify-content:flex-end;align-items:center;gap:1rem;padding:1.5rem 2rem;border-top:1px solid #e5e7eb;background:#f8fafc}.project-btn{padding:.75rem 1.5rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;min-width:100px;-webkit-user-select:none;user-select:none}.project-btn-cancel{background:#fff;color:#6b7280;border:1px solid #d1d5db}.project-btn-cancel:hover{background:#f9fafb;border-color:#9ca3af}.project-btn-submit{background:linear-gradient(135deg,#3fae49,#2d7a32);color:#fff;box-shadow:0 2px 4px #39a9474d}.project-btn-submit:hover{background:linear-gradient(135deg,#4bc653,#3fae49);transform:translateY(-1px);box-shadow:0 4px 8px #39a94766}.project-btn-delete{background:#ef4444;color:#fff;margin-right:auto}.project-btn-delete:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 8px #ef44444d}.add-project-btn{background:#3b82f6;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;margin-left:.5rem;padding:0;display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;transform:translateY(-2px) translate(10px);-webkit-user-select:none;user-select:none}.project-name-cell{padding:.75rem}.project-name-content{display:flex;align-items:center;gap:.75rem}.project-validation-errors{grid-column:1 / -1;margin-top:.5rem}.project-error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:.75rem;margin-bottom:.5rem;color:#dc2626;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.project-error-message:last-child{margin-bottom:0}.project-name-content input[type=checkbox]{width:1rem;height:1rem;cursor:pointer}.project-name-btn{background:none;border:none;color:#2563eb;text-decoration:underline;cursor:pointer;font-size:.875rem;padding:0;text-align:left;transition:color .2s ease;-webkit-user-select:none;user-select:none}.project-name-btn:hover{color:#1d4ed8}.date-input{width:100%;max-width:140px;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem}.date-input:focus{outline:none;border-color:#3fae49;box-shadow:0 0 0 2px #39a9471a}.pattern-select{width:100%;max-width:140px;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem;background:#fff}.pattern-select:focus{outline:none;border-color:#3fae49;box-shadow:0 0 0 2px #39a9471a}.budget-cell{font-weight:600;color:#059669}.fy-cell{text-align:center;font-weight:500;color:#374151}.workforce-overlay{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:2px solid #e5e7eb;box-shadow:0 -4px 6px -1px #0000001a;z-index:50}.overlay-actions{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;border-bottom:1px solid #e5e7eb}.status-indicator{display:flex;align-items:center}.status-text{background:#10b981;color:#fff;padding:.375rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.action-buttons{display:flex;gap:.5rem;align-items:center}.save-button{background:#3fae49;color:#fff;border:none;padding:.625rem 1.25rem;border-radius:6px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.save-button:hover:not(:disabled){background:#2d8a3a}.save-button:disabled{background:#d1d5db;color:#6b7280;cursor:not-allowed}.overlay-content{padding:1rem 2rem}.capacity-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.capacity-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.capacity-label{font-size:.875rem;color:#6b7280;font-weight:500}.capacity-value{font-size:1rem;font-weight:600;color:#111827}.capacity-value.good{color:#059669}.capacity-value.warning{color:#d97706}.capacity-value.danger{color:#dc2626}.loading-state{display:flex;justify-content:center;align-items:center;min-height:60vh;font-size:1.125rem;color:#6b7280}@media(max-width:768px){.header{padding:1rem}.apply-banner{padding:.75rem 1rem}.apply-banner-content{flex-direction:column;gap:.75rem;align-items:stretch}.planning-table-container{margin:1rem;border-radius:0}.planning-table{font-size:.75rem}.planning-table th,.planning-table td{padding:.5rem .25rem}.project-name-col{min-width:150px;width:150px}.fy-col{width:80px}.overlay-actions{padding:.75rem 1rem;flex-direction:column;gap:.75rem;align-items:stretch}.overlay-content{padding:.75rem 1rem}.capacity-section{grid-template-columns:1fr;gap:.75rem}.capacity-item{padding:.5rem .75rem}}@media(max-width:480px){.planning-table-container{margin:.5rem;overflow-x:scroll}.project-name-content{flex-direction:column;align-items:flex-start;gap:.5rem}.date-input,.pattern-select{max-width:100px;font-size:.75rem}}.project-name-container{display:flex;align-items:center;position:relative;padding-left:28px}.project-sort-arrows{display:flex;flex-direction:column;gap:1px;position:absolute;left:0;top:50%;transform:translateY(-50%)}.sort-arrow{background:none;border:none;outline:none;font-size:1.1rem;line-height:1;color:#4b5563;cursor:pointer;padding:2px 3px;border-radius:3px;transition:all .15s ease;min-width:14px;height:16px;display:flex;align-items:center;justify-content:center;opacity:.9;font-weight:600;-webkit-user-select:none;user-select:none}.sort-arrow:focus{outline:none!important;border:none!important;box-shadow:none!important}.sort-arrow:hover:not(.disabled){background-color:#f3f4f6;color:#374151;opacity:1;transform:scale(1.1)}.sort-arrow:active:not(.disabled){background-color:#d1d5db;transform:scale(.95)}.sort-arrow.disabled{color:#d1d5db;cursor:not-allowed;opacity:.4}.project-name{flex:1}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;padding:50px}.loading-spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #39A947;border-radius:50%;animation:spin 1s linear infinite}.page-loading p{color:#666;font-size:16px;margin:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:#f3f4f6;color:#111827;line-height:1.5;margin:0;padding:0}.dashboard{min-height:100vh;background:#f3f4f6}.dashboard .user-info{color:#9ca3af;font-size:.875rem}.btn{padding:.5rem 1rem;border:1px solid #4b5563;border-radius:6px;background:transparent;color:#d1d5db;font-size:.875rem;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block}.btn:hover{background:#4b5563;color:#fff}.btn-danger{border-color:#dc2626;color:#fca5a5}.btn-danger:hover{background:#dc2626;color:#fff}.main-content{max-width:1200px;margin:0 auto;padding:2rem}.welcome-section{margin-bottom:2rem}.welcome-title{font-size:2rem;font-weight:600;color:#111827;margin:0 0 .5rem}.welcome-subtitle{color:#6b7280;margin:0 0 2rem}.links-section{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.section-title{font-size:1.25rem;font-weight:600;color:#111827;margin:0 0 1.5rem}.links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.mockup-link{display:block;padding:1rem;border:1px solid #e5e7eb;border-radius:6px;text-decoration:none;color:#111827;transition:all .2s ease}.mockup-link:hover{border-color:#3fae49;background:#f0f9ff;transform:translateY(-1px)}.link-title{font-weight:600;margin:0 0 .5rem}.link-description{font-size:.875rem;color:#6b7280;margin:0}
