*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;color:var(--text);line-height:1.6;margin:0;padding:0;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--brand-teal: #005F60;--brand-teal-dark: #004b4d;--brand-teal-light: #4db6ac;--brand-teal-gradient: linear-gradient(135deg, #4db6ac 0%, #009688 100%);--nav-text: #e0e0e0;--nav-text-hover: #ffffff;--content-bg: #f4f7f6;--surface: #ffffff;--text: #1f2937;--text-secondary: #6b7280;--border: #e5e7eb;--border-light: #f3f4f6;--shadow: rgba(0, 0, 0, .1);--shadow-light: rgba(0, 0, 0, .05)}.app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--content-bg);position:relative}.app-header{background-color:var(--brand-teal);color:#fff;padding:0 1.5rem;min-height:64px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;position:fixed;top:0;left:0;right:0;width:100%;z-index:100}.upshop-header{background-color:var(--brand-teal)}.app-header h1{font-size:1.5rem;font-weight:600}.header-left{display:flex;align-items:center;gap:1rem}.header-right{display:flex;align-items:center;gap:.75rem}.header-brand{display:flex;flex-direction:column;gap:.25rem}.app-title{margin:0;font-size:1.5rem;font-weight:600;color:#fff}.app-subtitle{margin:0;font-size:.875rem;color:#ffffffe6;font-weight:400}.back-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.back-button:hover{background:#ffffff4d;border-color:#ffffff80}.hamburger-menu-container{position:relative}.hamburger-button{background:#ffffff26;border:1px solid rgba(255,255,255,.25);color:#fff;width:40px;height:40px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:1.2rem}.hamburger-button:hover{background:#ffffff40;border-color:#fff6}.hamburger-button:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.menu-overlay{position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .2s ease-in-out}.hamburger-menu{position:fixed;top:0;left:0;width:280px;height:100vh;background:var(--surface);box-shadow:2px 0 8px var(--shadow);z-index:1000;display:flex;flex-direction:column;animation:slideIn .3s ease-out;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.menu-header{background-color:var(--brand-teal);color:#fff;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.menu-header h2{margin:0;font-size:1.25rem;font-weight:600}.menu-items{list-style:none;padding:0;margin:0;flex:1}.menu-items li{border-bottom:1px solid var(--border)}.menu-item{width:100%;padding:1rem 1.5rem;background:none;border:none;text-align:left;cursor:pointer;display:flex;align-items:center;gap:1rem;color:var(--text);font-size:1rem;transition:all .2s;font-family:inherit}.menu-item:hover{background-color:var(--content-bg);color:var(--brand-teal)}.menu-item.active{background-color:#005f601a;color:var(--brand-teal);font-weight:600;border-left:4px solid var(--brand-teal-light)}.menu-icon{width:20px;text-align:center;font-size:1.1rem}.plan-info{display:flex;flex-direction:column;align-items:flex-end;font-size:.9rem}.plan-name{font-weight:600}.plan-meta{font-size:.85rem;opacity:.9}.app-nav{background-color:var(--surface);border-bottom:1px solid var(--border);display:flex;gap:0;box-shadow:0 1px 3px var(--shadow-light);position:fixed;top:64px;left:0;right:0;width:100%;z-index:99}.app-nav button{padding:1rem 2rem;border:none;background:none;cursor:pointer;font-size:1rem;color:#64748b;border-bottom:3px solid transparent;transition:all .2s ease;font-family:inherit;border-radius:0;font-weight:500}.app-nav button:hover{background-color:transparent;color:var(--brand-teal)}.app-nav button.active{color:var(--brand-teal);border-bottom-color:var(--brand-teal-light);background:transparent;font-weight:500}.app-main{flex:1;background-color:var(--content-bg);padding:1.5rem 2rem;max-width:1400px;margin:112px auto 0;width:100%}.tab-content{background-color:var(--surface);border-radius:8px;padding:2rem;box-shadow:0 1px 3px var(--shadow-light);border:1px solid var(--border-light)}.form-section{margin-bottom:1.5rem}.form-field{margin-bottom:1rem}label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}input[type=text],input[type=number],input[type=month],select{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}input[type=number]{max-width:200px}button{padding:.75rem 1.5rem;border:none;border-radius:8px;background:var(--brand-teal-gradient);color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s;font-family:inherit;box-shadow:0 2px 4px #4db6ac33}button:hover:not(:disabled){background:linear-gradient(135deg,#009688,#00796b);box-shadow:0 4px 8px #4db6ac4d;transform:translateY(-1px)}button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #4db6ac33}button:disabled{background-color:#ccc;cursor:not-allowed}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.errors{background-color:#fee;border:1px solid #fcc;border-radius:4px;padding:1rem;margin:1rem 0}.errors ul{list-style:none}.errors li{color:#c33;margin:.25rem 0}.error{color:#c33}table{width:100%;border-collapse:collapse;margin:1rem 0}th,td{padding:.75rem;text-align:left;border-bottom:1px solid #e0e0e0}th{background-color:#f5f5f5;font-weight:600}.plans-table th{background-color:var(--brand-teal)!important;color:#fff!important;font-weight:700!important}.gantt-chart{margin-top:2rem;width:100%;overflow-x:auto}.gantt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.gantt-header h2{margin:0}.gantt-legend{display:flex;gap:1.5rem}.gantt-container{display:flex;flex-direction:row;border:1px solid #e0e0e0;border-radius:4px;overflow:hidden;background-color:#fff;position:relative}.gantt-sidebar{flex-shrink:0;width:350px;border-right:2px solid var(--brand-teal);background-color:#f9f9f9;display:flex;flex-direction:column}.gantt-sidebar-header{display:flex;padding:.75rem;background-color:var(--brand-teal);color:#fff;font-weight:600;font-size:.9rem;position:sticky;top:0;z-index:11;border-right:2px solid var(--brand-teal);height:64px;min-height:64px;max-height:64px;align-items:center;box-sizing:border-box}.sidebar-cell{padding:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;height:100%;box-sizing:border-box;width:100%}.sidebar-cell.work-type-label{padding:.5rem .75rem}.sidebar-cell.initiative-content{display:flex!important;flex-direction:column!important;justify-content:center;gap:.25rem;width:100%;padding:.5rem .75rem;white-space:normal!important;overflow:visible}.initiative-name-line{display:flex;align-items:center;gap:.5rem;width:100%}.initiative-icon{flex-shrink:0;color:var(--brand-teal);font-size:.9rem}.initiative-name-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;color:var(--brand-teal);min-width:0}.initiative-sp-line{font-size:.85rem;color:#666;padding-left:1.5rem}.gantt-sidebar-row{display:flex;padding:0;border-bottom:1px solid #e0e0e0;cursor:pointer;transition:background-color .2s;height:60px;min-height:60px;max-height:60px;align-items:stretch;box-sizing:border-box}.gantt-sidebar-row:hover{background-color:#f0f0f0}.gantt-sidebar-row:last-child{border-bottom:none}.initiative-name{font-weight:500;color:var(--brand-teal)}.points-value,.priority-value{text-align:center;color:#666;font-size:.9rem}.work-type-value{text-align:center;font-size:.85rem;padding:.25rem .5rem;border-radius:4px;background-color:#e3f2fd;color:#1976d2}.gantt-timeline-wrapper{flex:1;overflow-x:auto;min-width:0;display:flex;flex-direction:column;position:relative}.gantt-timeline{flex:1;min-width:0;display:flex;flex-direction:column;position:relative}.gantt-timeline-header{display:flex;background-color:var(--brand-teal);color:#fff;position:sticky;top:0;z-index:11;flex-shrink:0;min-height:64px;height:64px;align-items:stretch;width:max-content;box-sizing:border-box;border-bottom:1px solid rgba(255,255,255,.25)}.gantt-month-header{padding:.45rem .6rem;text-align:left;font-size:.8rem;border-right:1px solid rgba(255,255,255,.2);min-width:135px;display:flex;flex-direction:column;gap:.2rem;box-sizing:border-box;justify-content:center;min-height:64px;height:64px;position:relative}.month-header-label{display:flex;align-items:center;justify-content:space-between;font-weight:600;gap:.35rem}.month-header-label span:first-child{white-space:nowrap}.month-header-input{display:flex;align-items:center;gap:.35rem;margin-top:.05rem}.month-header-input input{flex:1;padding:.15rem .35rem;border-radius:5px;border:1px solid rgba(255,255,255,.4);font-size:.75rem;background-color:#ffffff26;color:#fff}.month-header-input input::placeholder{color:#ffffffb3}.month-input-reset{background:transparent;border:none;color:#ffffffb3;font-size:1rem;cursor:pointer;padding:0 .25rem}.month-input-reset:hover{color:#ffebee}.month-header-total{font-size:.7rem;color:#fffc;font-weight:600;margin-top:auto}.gantt-timeline-body{display:flex;flex-direction:column;width:max-content}.gantt-row{display:flex;border-bottom:1px solid #e0e0e0;height:60px;min-height:60px;max-height:60px;position:relative;align-items:stretch;box-sizing:border-box}.gantt-row:last-child{border-bottom:none}.gantt-cell{border-right:1px solid #e0e0e0;padding:0;display:flex;align-items:center;justify-content:center;position:relative;height:60px;box-sizing:border-box}.gantt-cell.empty{background-color:#fafafa}.gantt-bar,.gantt-bar-continuous{height:40px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:600;position:absolute;transition:opacity .2s;cursor:pointer;padding:0 .25rem;box-sizing:border-box}.gantt-bar:hover,.gantt-bar-continuous:hover{opacity:.9;z-index:2}.gantt-bar.over-capacity,.gantt-bar-continuous.over-capacity{border:2px solid #ff0000;box-shadow:0 0 4px #ff000080}.gantt-bar-label{text-shadow:1px 1px 2px rgba(0,0,0,.5)}.gantt-empty-message,.gantt-empty-timeline{padding:2rem;text-align:center;color:#999}.gantt-work-type-summary{display:flex;flex-direction:column;border-top:2px solid var(--brand-teal);overflow:visible;width:max-content;min-width:100%}.gantt-work-type-row{display:flex;border-bottom:1px solid #e0e0e0;height:60px;min-height:60px;max-height:60px;position:relative;background-color:#fafafa;box-sizing:border-box}.gantt-sidebar-work-type{width:350px;flex-shrink:0;border-right:2px solid var(--brand-teal);display:flex;align-items:center;padding:0;background-color:#f9f9f9;box-sizing:border-box;border-bottom:1px solid #e0e0e0;height:60px;min-height:60px;max-height:60px;position:sticky;left:0;z-index:10}.work-type-label{font-weight:600;color:var(--brand-teal);display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;box-sizing:border-box}.gantt-timeline-work-type{flex:1;display:flex;position:relative;width:max-content;overflow:visible}.gantt-work-type-cell{border-right:1px solid #e0e0e0;padding:0;display:flex;align-items:center;justify-content:center;position:relative;height:60px;box-sizing:border-box}.gantt-capacity-summary{display:flex;border-top:2px solid var(--brand-teal);background-color:#f5f5f5;width:max-content;min-width:100%}.gantt-sidebar-summary{width:350px;flex-shrink:0;border-right:2px solid var(--brand-teal);padding:0;background-color:#f9f9f9;border-bottom:1px solid #e0e0e0;height:60px;min-height:60px;max-height:60px;display:flex;align-items:center;box-sizing:border-box;position:sticky;left:0;z-index:10}.summary-label{padding:.5rem .75rem;box-sizing:border-box;width:100%;font-weight:600;color:var(--brand-teal)}.gantt-timeline-summary{flex:1;display:flex;width:max-content;overflow:visible}.gantt-summary-cell{border-right:1px solid #e0e0e0;padding:.5rem;display:flex;flex-direction:column;gap:.25rem;min-width:120px}.control-hint{margin:0;font-size:.85rem;color:var(--text-secondary)}.timeline-override-banner{margin:.5rem 0;padding:.75rem 1rem;border-radius:8px;background-color:#00968814;border:1px solid rgba(0,150,136,.2);display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:.9rem}.summary-bar-container{display:flex;height:20px;border-radius:4px;overflow:hidden;border:1px solid #ddd}.summary-bar{height:100%;transition:width .2s}.summary-text{font-size:.85rem;text-align:center;color:#666;font-weight:500}.summary-text.over{color:#c33;font-weight:600}.scenario-selector{margin-bottom:1.5rem;padding:1rem;background-color:#fff;border-radius:4px;box-shadow:0 1px 3px #0000001a}.scenario-selector-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.scenario-selector-header label{display:flex;align-items:center;gap:.5rem;font-weight:500}.scenario-dropdown{padding:.5rem 1rem;font-size:1rem;border:1px solid #ddd;border-radius:4px;background-color:#fff;min-width:250px;cursor:pointer;transition:border-color .2s}.scenario-dropdown:hover{border-color:var(--brand-teal)}.scenario-dropdown:focus{outline:none;border-color:var(--brand-teal);box-shadow:0 0 0 2px #2c3e5033}.scenario-actions-compact{display:flex;gap:.5rem;align-items:center}.scenario-actions-compact .button-small{padding:.4rem .8rem;font-size:.9rem}.scenario-active-indicator{font-size:.9rem;color:#4b5563;margin-top:.5rem}.scenario-active-indicator strong{color:var(--brand-teal)}.scenarios-list{display:none}.scenario-item{border:1px solid #e0e0e0;border-radius:4px;padding:1rem;display:flex;justify-content:space-between;align-items:center}.scenario-item.active{border-color:var(--brand-teal);background-color:#f0f4f8}.scenario-info h4{margin-bottom:.5rem}.scenario-percentages,.scenario-capacity{display:flex;gap:1rem;font-size:.9rem;color:#666}.scenario-actions{display:flex;gap:.5rem}.size-map-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin:1rem 0}.size-input label{display:flex;align-items:center;gap:.5rem}.size-label{font-size:.9rem;color:#666}.size-map-preview table{max-width:300px}.plan-actions{margin-top:2rem;padding-top:2rem;border-top:1px solid #e0e0e0}.action-buttons{display:flex;gap:1rem;flex-wrap:wrap}.import-label{display:inline-block;padding:.5rem 1rem;border-radius:4px;background-color:var(--brand-teal);color:#fff;cursor:pointer;font-size:1rem;transition:background-color .2s}.import-label:hover{background-color:var(--brand-teal-dark)}.plan-list-view{min-height:100vh;background-color:var(--content-bg);display:flex;flex-direction:column}.plans-table-header{display:flex;justify-content:space-between;align-items:center;margin:0;padding:0 .5rem;padding-bottom:0;min-height:40px}.plans-header-actions{display:flex;gap:.75rem;align-items:center}.plans-table-title{margin:0;font-size:1.5rem;font-weight:600;color:var(--brand-teal);line-height:1;display:flex;align-items:center}.add-plan-button{background:var(--brand-teal-gradient);color:#fff;padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;box-shadow:0 2px 4px #4db6ac33;transition:all .2s;font-family:inherit;line-height:1;display:flex;align-items:center;height:fit-content}.add-plan-button:hover{background:linear-gradient(135deg,#009688,#00796b);box-shadow:0 4px 8px #4db6ac4d;transform:translateY(-1px)}.import-plan-button{background:#fff;color:var(--brand-teal);border:2px solid var(--brand-teal);padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s;font-family:inherit;line-height:1;display:flex;align-items:center;gap:.5rem;height:fit-content}.import-plan-button:hover:not(:disabled){background:var(--brand-teal);color:#fff;transform:translateY(-1px)}.import-plan-button:disabled{opacity:.5;cursor:not-allowed}.initiatives-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:0 .5rem;min-height:40px}.initiatives-table-title{margin:0;font-size:1.5rem;font-weight:600;color:var(--brand-teal);line-height:1;display:flex;align-items:center}.add-initiative-button{background:var(--brand-teal-gradient);color:#fff;padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;box-shadow:0 2px 4px #4db6ac33;transition:all .2s;font-family:inherit;line-height:1;display:flex;align-items:center;height:fit-content}.add-initiative-button:hover{background:linear-gradient(135deg,#009688,#00796b);box-shadow:0 4px 8px #4db6ac4d;transform:translateY(-1px)}.initiatives-table-container{max-width:1400px;margin:0 auto;padding:0 2rem 2rem;background-color:var(--surface);border-radius:8px;box-shadow:0 1px 3px var(--shadow-light);overflow:hidden;border:1px solid var(--border-light)}.initiatives-table{width:100%;border-collapse:collapse;background-color:var(--surface)}.initiatives-table thead{background-color:var(--brand-teal)}.initiatives-table th{padding:1rem;text-align:left;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid rgba(255,255,255,.3);color:#fff!important;text-shadow:0 2px 4px rgba(0,0,0,.5);background-color:var(--brand-teal)!important;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.initiatives-table th.actions-column{text-align:center;width:120px}.initiatives-table tbody tr{border-bottom:1px solid var(--border);transition:background-color .2s;cursor:pointer}.initiatives-table tbody tr:hover{background-color:var(--content-bg)}.initiatives-table tbody tr:last-child{border-bottom:none}.initiatives-table td{padding:1rem;color:var(--text);vertical-align:middle}.initiatives-table .actions-cell{text-align:center;padding:.5rem}.initiatives-table .delete-row-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px}.initiatives-table .delete-row-button:hover{background-color:#fee;color:#c33}.initiatives-table .delete-row-button:focus{outline:2px solid var(--brand-teal);outline-offset:2px}.teams-list-view{min-height:100vh;background-color:var(--content-bg);display:flex;flex-direction:column}.teams-list-view .plans-table-container{padding:.5rem 1rem 1.5rem!important}.teams-list-view .plans-table-container .plans-table-header{margin:0!important;padding:0 .5rem!important;padding-top:0!important;padding-bottom:0!important;min-height:auto!important;height:auto!important}.teams-list-view .plans-table-container .plans-table-header h2{margin:0!important;padding:0!important;line-height:1!important}.teams-list-view .plans-table-container .plans-table{margin:0!important;border-spacing:0!important;border-collapse:collapse!important}.teams-list-view .plans-table-container .plans-table thead,.teams-list-view .plans-table-container .plans-table thead tr{margin:0!important;padding:0!important}.teams-list-view .plans-table-container .plans-table thead th{margin:0!important;padding-top:1rem!important}.teams-table-header{display:flex;justify-content:space-between;align-items:center;margin:0!important;padding:0 .5rem .25rem!important;min-height:40px}.teams-header-actions{display:flex;gap:1rem;align-items:center}.teams-table-title{margin:0;font-size:1.5rem;font-weight:600;color:var(--brand-teal);line-height:1;display:flex;align-items:center}.add-team-button{background:var(--brand-teal-gradient);color:#fff;padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;box-shadow:0 2px 4px #4db6ac33;transition:all .2s;font-family:inherit;line-height:1;display:flex;align-items:center;height:fit-content}.add-team-button:hover{background:linear-gradient(135deg,#009688,#00796b);box-shadow:0 4px 8px #4db6ac4d;transform:translateY(-1px)}.teams-table-container{max-width:1400px;margin:0 auto;padding:.5rem 1rem 1.5rem;background-color:var(--surface);border-radius:8px;box-shadow:0 1px 3px var(--shadow-light);overflow:hidden;border:1px solid var(--border-light)}.teams-table-container>.teams-table-header{margin:0!important;padding:0 .5rem .25rem!important}.teams-table-container>.teams-table{margin:0!important}.teams-table{width:100%;border-collapse:collapse;background-color:var(--surface)}.teams-table thead{background-color:var(--brand-teal)}.teams-table th{padding:1rem;text-align:left;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid rgba(255,255,255,.3);color:#fff!important;text-shadow:0 2px 4px rgba(0,0,0,.5);background-color:var(--brand-teal)!important;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.teams-table th.actions-column{text-align:center;width:80px}.teams-table tbody tr{border-bottom:1px solid var(--border);transition:background-color .2s;cursor:pointer}.teams-table tbody tr:hover{background-color:var(--content-bg)}.teams-table tbody tr:last-child{border-bottom:none}.teams-table td{padding:1rem;color:var(--text);vertical-align:middle}.team-name-cell{font-weight:500}.team-name-cell strong{color:var(--brand-teal);font-weight:600}.teams-table .actions-cell{text-align:center;padding:.5rem}.teams-table .delete-row-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px}.teams-table .delete-row-button:hover{background-color:#fee;color:#c33}.teams-table .delete-row-button:focus{outline:2px solid var(--brand-teal);outline-offset:2px}.team-form-container{max-width:800px;margin:0 auto;background-color:var(--surface);border-radius:8px;box-shadow:0 1px 3px var(--shadow-light);border:1px solid var(--border-light);padding:2rem}.team-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.team-form-header h2{margin:0;color:var(--brand-teal);font-size:1.5rem;font-weight:600}.cancel-button{background:#fff;color:var(--text);border:2px solid var(--border);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s;font-family:inherit}.cancel-button:hover{background:var(--content-bg);border-color:var(--brand-teal)}.team-form{display:flex;flex-direction:column;gap:1.5rem}.team-form .form-field label{display:flex;flex-direction:column;gap:.5rem;font-weight:500}.team-form .form-field input{padding:.75rem;border:1px solid var(--border);border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .2s}.team-form .form-field input:focus{outline:none;border-color:var(--brand-teal);box-shadow:0 0 0 3px #005f601a}.team-form .form-field small{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.team-form .required{color:#ef4444}.team-form .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem;padding-top:1.5rem;border-top:1px solid var(--border)}.loading-message{padding:2rem;text-align:center;color:#666}.empty-state{max-width:600px;margin:4rem auto;padding:3rem;text-align:center;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.empty-state h2{margin-bottom:1rem;color:var(--brand-teal)}.empty-state p{margin-bottom:2rem;color:#666}.plans-table-container{max-width:1400px;margin:0 auto;padding:.5rem 1rem 1.5rem;background-color:var(--surface);border-radius:8px;box-shadow:0 1px 3px var(--shadow-light);overflow:hidden;border:1px solid var(--border-light)}.plans-table-container .plans-table-header+.plans-table{margin-top:0!important;padding-top:0!important}.plans-table-container .plans-table-header{margin-bottom:0!important;padding-bottom:0!important}.plans-table-container>.plans-table-header{margin:0!important;padding:0 .5rem!important;padding-bottom:0!important}.plans-table-container>.plans-table-header h2{margin:0!important;padding:0!important}.plans-table-container>.plans-table{margin:0!important;padding:0!important}.plans-table-container>.plans-table thead{margin:0!important;padding:0!important}.plans-table-container>.plans-table thead tr{margin:0!important;padding:0!important}.plans-table-container>.plans-table thead tr th{margin:0!important;padding-top:1rem!important}.plans-table{width:100%;border-collapse:collapse;background-color:var(--surface);margin:0}.plans-table thead{background-color:var(--brand-teal)}.plans-table th{padding:1rem;text-align:left;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid rgba(255,255,255,.3);color:#fff!important;text-shadow:0 2px 4px rgba(0,0,0,.5);background-color:var(--brand-teal)!important;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.plans-table th.actions-column{text-align:center;width:80px}.plans-table tbody tr{border-bottom:1px solid var(--border);transition:background-color .2s;cursor:pointer}.work-type-settings{background:var(--surface);border:1px solid var(--border-light);border-radius:12px;padding:1.5rem;box-shadow:0 1px 2px var(--shadow-light)}.work-type-table-wrapper{overflow-x:auto;margin-top:1rem}.work-type-table{width:100%;border-collapse:collapse}.work-type-table th,.work-type-table td{text-align:left;padding:.75rem .5rem;border-bottom:1px solid var(--border-light)}.work-type-name{display:flex;align-items:center;gap:.75rem;font-weight:600;color:var(--text)}.work-type-name-input{flex:1;min-width:160px;padding:.4rem .6rem;border:1px solid var(--border);border-radius:6px;font-weight:500;font-family:inherit;transition:border-color .2s,box-shadow .2s}.work-type-name-input:focus{border-color:var(--brand-teal);outline:none;box-shadow:0 0 0 2px #00968826}.color-swatch{width:20px;height:20px;border-radius:4px;border:1px solid var(--border);display:inline-block}.work-type-table input[type=text]{width:120px;font-family:inherit}.work-type-form{margin-top:1.5rem;display:flex;flex-direction:column;gap:1rem}.work-type-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.hex-input-group{display:flex;gap:.5rem;align-items:center}.hex-input-group input[type=color]{width:48px;height:38px;padding:0;border:none;background:transparent;cursor:pointer}.work-type-hint{margin:0;font-size:.9rem;color:var(--text-secondary)}.input-error{border-color:#e53935}.input-error-text{color:#e53935;font-size:.8rem;margin-top:.35rem}.plans-table tbody tr:hover{background-color:var(--content-bg)}.plans-table tbody tr:last-child{border-bottom:none}.plans-table td{padding:1rem;color:var(--text);vertical-align:middle}.plan-name-cell{font-weight:500}.plan-name-cell strong{color:var(--brand-teal);font-weight:600}.actions-cell{text-align:center;padding:.5rem}.delete-row-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px}.delete-row-button:hover{background-color:#fee;color:#c33}.delete-row-button:focus{outline:2px solid var(--brand-teal);outline-offset:2px}@media(max-width:768px){.app-main{padding:1rem}.app-nav{flex-wrap:wrap}.app-nav button{padding:.75rem 1rem;font-size:.9rem}.scenario-item{flex-direction:column;align-items:flex-start;gap:1rem}.scenario-actions{width:100%;justify-content:flex-start}.plans-table-header{flex-direction:column;align-items:flex-start;gap:1rem;padding:0}.plans-header-actions{width:100%;flex-direction:column;gap:.75rem}.import-plan-button,.add-plan-button{width:100%;justify-content:center}.plans-table-title{font-size:1.25rem}.add-plan-button{width:100%;justify-content:center}.initiatives-table-header{flex-direction:column;align-items:flex-start;gap:1rem;padding:0}.initiatives-table-title{font-size:1.25rem}.add-initiative-button{width:100%;justify-content:center}.initiatives-table-container{padding:0 1rem;margin:1rem auto}.initiatives-table{font-size:.9rem}.initiatives-table th,.initiatives-table td{padding:.75rem .5rem}.initiatives-table th:first-child,.initiatives-table td:first-child{padding-left:1rem}.initiatives-table th:last-child,.initiatives-table td:last-child{padding-right:1rem}.teams-table-header{flex-direction:column;align-items:flex-start;gap:1rem;padding:0}.teams-table-title{font-size:1.25rem}.teams-header-actions{width:100%;flex-direction:column;gap:.75rem}.add-team-button,.teams-table-container{padding:0 1rem;margin:1rem auto}.teams-table{font-size:.9rem}.teams-table th,.teams-table td{padding:.75rem .5rem}.teams-table th:first-child,.teams-table td:first-child{padding-left:1rem}.teams-table th:last-child,.teams-table td:last-child{padding-right:1rem}.plans-table-container{padding:0 1rem;margin:1rem auto}.plans-table{font-size:.9rem}.plans-table th,.plans-table td{padding:.75rem .5rem}.plans-table th:first-child,.plans-table td:first-child{padding-left:1rem}.plans-table th:last-child,.plans-table td:last-child{padding-right:1rem}}.team-selector-status{margin-top:8px;font-size:.9rem;color:#555}.team-selector-status.error{color:#c62828}.suite-id-label{display:block;font-size:.75rem;color:#666}.roadmap-page{display:flex;flex-direction:column;gap:24px;padding:24px}.roadmap-loading,.roadmap-error,.roadmap-empty{text-align:center;padding:48px 0;color:#555}.roadmap-error .error-detail{color:#c62828;margin-top:8px}.roadmap-suite-card{background:#fff;border-radius:12px;box-shadow:0 2px 6px #00000014;padding:24px}.roadmap-suite-header{display:flex;justify-content:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:16px;align-items:center}.roadmap-suite-pill{padding:8px 16px;border-radius:999px;color:#fff;font-weight:600;font-size:.95rem}.roadmap-empty-suite{padding:16px;border:1px dashed #ccc;border-radius:8px;color:#666;text-align:center}.roadmap-timeline{display:flex;gap:16px;align-items:flex-start}.roadmap-scroll-area{flex:1;overflow-x:auto}.roadmap-grid{display:grid;grid-template-columns:220px auto;column-gap:16px;row-gap:12px;align-items:start;width:max-content;margin-top:16px}.roadmap-label-spacer{grid-column:1 / 2;height:48px}.roadmap-months{grid-column:2 / 3;display:flex;gap:0;padding-bottom:8px;border-bottom:1px solid #eee;font-size:.85rem;color:#666}.roadmap-month{min-width:96px;text-align:center}.roadmap-row-label{min-width:220px;display:flex;flex-direction:column;gap:4px;justify-content:center}.roadmap-row-label strong,.roadmap-row-label span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.roadmap-row-label span{font-size:.85rem;color:#666}.roadmap-row-track{overflow:hidden}.roadmap-row-track .gantt-row{border-bottom:none;height:48px;min-height:48px;max-height:48px}.roadmap-row-track .gantt-cell{height:48px;border-right:1px solid #f0f0f0}.roadmap-row-track .gantt-cell.empty{background-color:#f9fafb}.roadmap-row-track .gantt-bar-continuous{height:32px;border-radius:6px}.product-suite-settings{border-top:1px solid var(--border-light);padding-top:16px}.product-suite-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.product-suite-row{display:flex;align-items:center;gap:16px;padding:12px 16px;border:1px solid var(--border-light);border-radius:8px;background:#fff}.product-suite-chip{width:24px;height:24px;border-radius:50%}.product-suite-info p{margin:4px 0 0;color:#555;font-size:.9rem}.product-suite-actions{margin-left:auto;display:flex;gap:12px}.button-link{background:none;border:none;color:var(--brand-teal);cursor:pointer;padding:0}.button-link.danger{color:#c62828}.product-suite-form textarea{width:100%;min-height:80px;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-family:inherit}.product-suite-form label{margin-top:12px}
