@charset "UTF-8";.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.375em;border-bottom-right-radius:.375em}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle,.react-datepicker-popper--header-middle[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper--header-bottom[data-placement^=bottom] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker-popper--header-bottom[data-placement^=top] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select,.react-datepicker__header--middle,.react-datepicker__header--bottom){border-top-right-radius:.3rem}.react-datepicker__header--middle{border-top:1px solid #aeaeae;border-radius:0;margin-top:4px}.react-datepicker__header--bottom{border-bottom:none;border-top:1px solid #aeaeae;border-radius:0 0 .3rem .3rem}.react-datepicker__header-wrapper{position:relative}.react-datepicker__header-wrapper .react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:2px}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__month-select,.react-datepicker__year-select,.react-datepicker__month-year-select{background-color:transparent;border:1px solid #aeaeae;border-radius:.3rem;color:inherit;cursor:pointer;font-family:inherit;font-size:inherit;margin-top:5px;padding:2px 5px}.react-datepicker__month-select:focus-visible,.react-datepicker__year-select:focus-visible,.react-datepicker__month-year-select:focus-visible{outline:auto 1px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.5em;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:5em;margin:2px}.react-datepicker__month{margin:.5em;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:5em;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.375em;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:white;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + 1.0625em);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{text-align:center;white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__day-name--disabled,.react-datepicker__day--disabled,.react-datepicker__time-name--disabled{cursor:default;color:#ccc}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.625em;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__children-container{width:17.25em;margin:.5em;padding-right:.25em;padding-left:.25em;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.react-datepicker-popper-offset{margin-top:-.7em}:root{--accent: #1c3a6e;--accent-light: #e8eef8;--covered: #1f4a22;--covered-bg: #dfeee0;--covered-border: #7aa87d;--partial: #7a4a00;--partial-bg: #fff4e0;--partial-border: #e8a020;--missing: #7a1a1a;--missing-bg: #fde4e4;--missing-border: #c86060;--border: #e5e0d8;--text: #2c2a25;--text-mid: #6a6860;--text-dim: #9a9690;--bg: #f7f5f1;--surface: #ffffff;--sidebar-bg: #f0ede8;--sidebar-border: #dedad4;--sidebar-width: 260px;--submitted-text: #2c5030;--submitted-bg: #eef5ee;--submitted-border: #4a7a4f;--master-table-columns: minmax(120px, 1.4fr) minmax(140px, 1.8fr) minmax(90px, 1fr) minmax(90px, 1fr) minmax(75px, 1fr) minmax(115px, 1.4fr) minmax(95px, 1fr) minmax(70px, .8fr) minmax(150px, 1.8fr) minmax(130px, 1.4fr) minmax(0, 1fr)}body{background:var(--bg);font-family:DM Sans,sans-serif;font-size:15px;color:var(--text);margin:0}html,body,#root,input,textarea,select,button,.MuiInputBase-root,.MuiInputBase-input,.MuiOutlinedInput-input,.MuiOutlinedInput-root,.MuiTypography-root,.MuiButton-root,.MuiFormLabel-root,.MuiInputLabel-root,.MuiDialog-root,.MuiDialogContent-root,.MuiDialogActions-root{font-family:DM Sans,sans-serif!important}.mono,input.mono,td.mono,span.mono,.inv-table td.mono,.inv-table td.r{font-family:DM Mono,monospace!important}.po-card-header h2{font-family:"DM Serif Display",serif!important}.f-group input[type=date]{font-family:DM Sans,sans-serif;font-size:13px;padding:8px 10px;border:1.5px solid var(--border);border-radius:4px;background:white;color:var(--text);width:100%;box-sizing:border-box;outline:none;min-width:0;line-height:1.4;-webkit-appearance:none;-moz-appearance:none;appearance:none}.f-group input[type=date]:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.f-group input[type=date]:hover{border-color:var(--text-mid)}.f-group input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;transition:opacity .15s}.f-group input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.f-group input[type=date]:invalid{color:var(--text-dim)}.topbar{background:var(--accent);color:#f5f3ef;padding:8px 20px;min-height:52px;display:flex;align-items:center;gap:12px;flex-shrink:0;flex-wrap:wrap;position:sticky;top:0;z-index:100}.topbar-logo{font-family:"DM Serif Display",serif;font-size:16px;letter-spacing:.3px}.topbar-logo span{color:#a8c4f0}.topbar-sub{font-size:13px;color:#c8d8f0;border-left:1px solid #4a6a9e;padding-left:12px;margin-left:4px}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.ccss-filter{background:#1e3a6e;border:1px solid #6a8abe;color:#fff;padding:6px 12px;font-family:DM Sans,sans-serif;font-size:13px;border-radius:4px;outline:none}.ccss-filter option{background:#152e5a;color:#fff}.stats-pill{background:#1e3a6e;border:1px solid #6a8abe;border-radius:20px;padding:4px 12px;font-size:13px;color:#e8eef8;display:flex;gap:10px}.stats-pill span{color:#f5f3ef;font-weight:600;font-family:DM Mono,monospace}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);border-right:2px solid var(--text-mid);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0;position:relative}.sidebar-search{padding:10px 14px 10px 10px;border-bottom:1px solid var(--sidebar-border)}.sidebar-search input{width:100%;box-sizing:border-box;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:7px 10px;font-family:DM Sans,sans-serif;font-size:13px;border-radius:4px;outline:none}.sidebar-search input::placeholder{color:var(--text-dim)}.sidebar-scroll{flex:1;overflow-y:auto}.vendor-group{border-bottom:1px solid var(--sidebar-border)}.vendor-header{padding:11px 14px 9px;cursor:pointer;display:flex;align-items:center;gap:8px;-webkit-user-select:none;user-select:none}.vendor-header:hover,.vendor-header.active{background:var(--border)}.vendor-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.3;flex:1}.vendor-badge{font-size:12px;background:var(--border);color:var(--text-mid);padding:1px 7px;border-radius:10px;flex-shrink:0;font-weight:600}.vendor-arrow{color:var(--text-dim);font-size:12px;transition:transform .15s;flex-shrink:0}.vendor-arrow.open{transform:rotate(90deg)}.po-list{display:none;padding:0 0 6px}.po-list.open{display:block}.po-type-header{padding:6px 14px 5px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-mid);background:var(--border);border-top:1px solid var(--sidebar-border);border-bottom:1px solid var(--sidebar-border);margin-top:4px}.po-item{padding:7px 14px 7px 34px;cursor:pointer;display:flex;align-items:center;-webkit-user-select:none;user-select:none}.po-item:hover{background:var(--border)}.po-item.active{background:var(--accent-light);border-left:3px solid var(--accent)}.po-num{font-size:13px;color:var(--text);font-weight:500;flex:1}.po-item.active .po-num{color:var(--accent);font-weight:600}.po-sub-badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#4a7a4f;color:#fff;font-size:10px;font-weight:700;margin-left:6px;vertical-align:middle;flex-shrink:0}.routing-pill{font-size:10px;font-weight:700;padding:1px 4px;border-radius:3px;margin-left:4px;vertical-align:middle;display:inline-block;line-height:1}.rt-exc{background:#fdf2f2;color:#9b1c1c;border:1px solid #f8d7da}.rt-con{background:#f0fdf4;color:#166534;border:1px solid #d1fae5}.main{flex:1;min-width:0;overflow:auto;background:var(--bg);position:relative;padding:0 0 24px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-dim)}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state h3{font-weight:500;margin:0}.sidebar-resize-handle{position:absolute;top:0;right:-3px;width:6px;height:100%;cursor:col-resize;z-index:10;background:transparent;transition:background .15s}.sidebar-resize-handle:hover{background:var(--accent);opacity:.3}.sidebar-resize-handle.resizing{background:var(--accent);opacity:.5}body.resizing-sidebar{cursor:col-resize;-webkit-user-select:none;user-select:none}body.resizing-sidebar *{cursor:col-resize!important}.sidebar-toggle-btn{background:transparent;border:none;color:#f5f3ef;width:32px;height:32px;border-radius:4px;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-family:inherit;flex-shrink:0;padding:0}.sidebar-toggle-btn:hover{background:rgba(255,255,255,.1)}.sidebar-toggle-arrow{font-size:12px;transition:transform .15s;display:inline-block}.sidebar-toggle-arrow.open{transform:rotate(90deg)}.sidebar.sidebar-collapsed{width:0!important;border-right:none;overflow:hidden}.sidebar.sidebar-collapsed .sidebar-resize-handle{display:none}.rt-ps{background:#eef2ff;color:#3730a3;border:1px solid #c7d2fe}.rt-sov{background:#fef3c7;color:#78350f;border:1px solid #fcd34d}.po-item-body{flex:1;min-width:0}.po-num-line{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.po-sub-line{display:flex;align-items:center;gap:4px;margin-top:2px}.po-contract{font-size:11px;color:var(--text-dim);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.po-status-badge{font-size:11px;border-radius:3px;padding:0 4px;font-family:DM Mono,monospace;border:1px solid transparent}.po-status-badge.bg-draft{background:#fff4e0;color:#7a4a00;border-color:#e8a020}.po-status-badge.bg-covered{background:var(--covered-bg);color:var(--covered);border-color:var(--covered-border)}.po-status-badge.bg-partial{background:var(--partial-bg);color:var(--partial);border-color:var(--partial-border)}.po-status-badge.bg-missing{background:var(--missing-bg);color:var(--missing);border-color:var(--missing-border)}.po-status-badge.bg-pending{background:#fff4e0;color:#7a4a00;border-color:#e8a020}.breadcrumbs{margin-bottom:16px}.breadcrumbs-list{list-style:none;margin:0;padding:0;display:flex;align-items:center;flex-wrap:wrap;font-size:13px}.breadcrumbs-item{display:flex;align-items:center}.breadcrumbs-link{color:var(--accent, #1d4ed8);text-decoration:none;font-weight:500}.breadcrumbs-link:hover{text-decoration:underline}.breadcrumbs-current{color:var(--text-dim, #6b7280);font-weight:500}.breadcrumbs-sep{margin:0 8px;color:var(--text-dim, #9ca3af)}.admin-page{padding:24px 32px;max-width:1500px}.admin-page h1{margin:0 0 4px;font-size:22px;font-weight:600;color:var(--text)}.admin-subtitle{margin:0 0 20px;font-size:12px;color:var(--text-dim)}.admin-toolbar{display:flex;gap:12px;align-items:center;margin-bottom:16px}.admin-search{flex:1;max-width:400px;padding:6px 10px;font-size:13px;border:1px solid var(--border);border-radius:4px;background:white;color:var(--text)}.admin-search:focus{outline:none;border-color:var(--text-dim);box-shadow:0 0 0 3px var(--accent-light)}.admin-ccss-filter{padding:6px 10px;font-size:13px;border:1px solid var(--border);border-radius:4px;background:white;color:var(--text);cursor:pointer;min-width:180px}.admin-clear-filters{padding:6px 12px;font-size:12px;border:1px solid var(--border);border-radius:4px;background:white;color:var(--text);cursor:pointer}.admin-clear-filters:hover{background:var(--surface-alt, #faf9f7)}.admin-table{width:100%;border-collapse:collapse;font-size:13px;background:white;border:1px solid var(--border);border-radius:4px;overflow:hidden;table-layout:auto}.admin-table thead{background:var(--surface-alt, #faf9f7);border-bottom:1px solid var(--border)}.admin-table th{text-align:left;padding:8px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-mid);white-space:nowrap}.admin-table th.num{text-align:right}.admin-table td{padding:8px 14px;border-top:1px solid var(--border);color:var(--text);vertical-align:middle}.admin-table td.num{text-align:right;font-variant-numeric:tabular-nums}.admin-table .col-toggle{width:28px;padding:8px 0 8px 8px;color:var(--text-mid);font-size:10px;-webkit-user-select:none;user-select:none}.admin-table .col-count{width:1%}.admin-table .col-activity,.admin-table .col-token{width:1%;white-space:nowrap}.admin-table .vendor-row{cursor:pointer;background:white}.admin-table .vendor-row:hover{background:var(--surface-alt, #faf9f7)}.admin-table .vendor-row.is-open{background:var(--surface-alt, #f5f3ef)}.admin-table .vendor-row td:first-child{border-left:4px solid #0e3870}.admin-table .vendor-name{font-weight:500}.admin-table .po-detail-row{background:var(--accent-light);font-size:12px}.admin-table .po-detail-row td{color:var(--text);border-top:1px solid var(--border)}.admin-table .po-detail-row td:first-child{border-left:4px solid transparent}.admin-table .po-detail-row .mono{font-family:DM Mono,monospace}.admin-table .dim{color:var(--text);opacity:.55}.admin-table span.dim[title]{cursor:help;font-style:italic}.admin-table .sort-indicator{display:inline-block;margin-left:4px;color:var(--text);opacity:.35;font-size:10px;transition:opacity .15s}.admin-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.admin-table th.sortable:hover{background:var(--surface-alt, #f0eee9);color:var(--text)}.admin-table th.sortable:hover .sort-indicator{opacity:.8}.admin-table th.is-sorted{color:var(--text)}.admin-table th.is-sorted .sort-indicator{opacity:1;color:var(--text)}.admin-table .complete-mark{color:var(--covered, #2d6a3a);font-weight:600;margin-left:6px}.admin-table .empty-state{text-align:center;padding:24px;color:var(--text);font-style:italic}import{useMemo,useState}from "react"; import{usePOs}from "../api/hooks"; import{useAccruals}from "../state/useAccruals"; import{PO}from "../types/po"; import "./admin.css"; interface PoSummary{poKey:string;purchaseOrderNumber:string;ntpNumber:string | null;ccss:string | null;status:"submitted" | "draft" | "untouched";submittedAccrualCount:number;draftAccrualCount:number;lastActivityAt:string | null}interface VendorSummary{vendorId:string;vendorName:string;ccssNames:string[];poCount:number;submittedPoCount:number;draftPoCount:number;untouchedPoCount:number;outstandingPoCount:number;lastActivityAt:string | null;pos:PoSummary[]}type SortKey = | "vendorId" | "vendorName" | "ccss" | "poCount" | "submittedPoCount" | "draftPoCount" | "untouchedPoCount" | "outstandingPoCount" | "allSubmitted" | "lastActivityAt"; interface SortState{key:SortKey;direction:"asc" | "desc"}function buildVendorSummaries(pos: PO[],localAccruals: Record<string,{isDraft: boolean; submittedAt: string}[]>,localPOOverrides: Record<string,{submitted?: boolean; submittedAt?: string} | undefined>): VendorSummary[]{const byVendor = new Map<string,VendorSummary>();for (const po of pos) {let row = byVendor.get(po.vendorId); if (!row) {row = {vendorId: po.vendorId,vendorName: po.vendorName,ccssNames: [],poCount: 0,submittedPoCount: 0,draftPoCount: 0,untouchedPoCount: 0,outstandingPoCount: 0,lastActivityAt: null,pos: [],}; byVendor.set(po.vendorId,row);} row.poCount += 1; if (po.contractSupportSpecialist && !row.ccssNames.includes(po.contractSupportSpecialist)) {row.ccssNames.push(po.contractSupportSpecialist);} const isSubmitted = localPOOverrides[po.poKey]?.submitted === true; const accruals = localAccruals[po.poKey] || []; const hasAccruals = accruals.length > 0; let status: PoSummary["status"]; if (isSubmitted) {status = "submitted"; row.submittedPoCount += 1;} else if (hasAccruals) {status = "draft"; row.draftPoCount += 1; row.outstandingPoCount += 1;} else {status = "untouched"; row.untouchedPoCount += 1; row.outstandingPoCount += 1;} let submittedAccrualCount = 0; let draftAccrualCount = 0; for (const a of accruals) {if (a.isDraft) draftAccrualCount += 1; else submittedAccrualCount += 1;} let lastActivityAt: string | null = null; const poSubmitTime = localPOOverrides[po.poKey]?.submittedAt; if (poSubmitTime) lastActivityAt = poSubmitTime; for (const a of accruals) {if (a.submittedAt && (!lastActivityAt || a.submittedAt > lastActivityAt)) {lastActivityAt = a.submittedAt;}} if (lastActivityAt && (!row.lastActivityAt || lastActivityAt > row.lastActivityAt)) {row.lastActivityAt = lastActivityAt;} row.pos.push({poKey: po.poKey,purchaseOrderNumber: po.purchaseOrderNumber,ntpNumber: po.ntpNumber,ccss: po.contractSupportSpecialist,status,submittedAccrualCount,draftAccrualCount,lastActivityAt,});} const result = Array.from(byVendor.values());for (const v of result) {v.pos.sort((a,b) => {const aLabel = a.ntpNumber || a.purchaseOrderNumber; const bLabel = b.ntpNumber || b.purchaseOrderNumber; return aLabel.localeCompare(bLabel);});} return result}function formatRelativeTime(iso: string | null): string{if (!iso) return "—";const then = new Date(iso).getTime();if (isNaN(then)) return "—";const diffMs = Date.now() - then;const diffSec = Math.floor(diffMs / 1000);if (diffSec < 60) return "just now";const diffMin = Math.floor(diffSec / 60);if (diffMin < 60) return `${diffMin} min${diffMin === 1 ? "" : "s"} ago`;const diffHr = Math.floor(diffMin / 60);if (diffHr < 24) return `${diffHr} hour${diffHr === 1 ? "" : "s"} ago`;const diffDay = Math.floor(diffHr / 24);if (diffDay < 30) return `${diffDay} day${diffDay === 1 ? "" : "s"} ago`;return new Date(iso).toLocaleDateString()}function sortVendorSummaries(summaries: VendorSummary[],sort: SortState): VendorSummary[]{const sorted = [...summaries].sort((a,b) => {let cmp = 0; switch (sort.key) {case "vendorId": cmp = a.vendorId.localeCompare(b.vendorId); break; case "vendorName": cmp = a.vendorName.localeCompare(b.vendorName); break; case "ccss": cmp = (a.ccssNames[0] || "").localeCompare(b.ccssNames[0] || ""); break; case "poCount": cmp = a.poCount - b.poCount; break; case "submittedPoCount": cmp = a.submittedPoCount - b.submittedPoCount; break; case "draftPoCount": cmp = a.draftPoCount - b.draftPoCount; break; case "untouchedPoCount": cmp = a.untouchedPoCount - b.untouchedPoCount; break; case "outstandingPoCount": cmp = a.outstandingPoCount - b.outstandingPoCount; break; case "allSubmitted": {// Complete (Outstanding = 0) sorts as 1,incomplete as 0 // Ascending = incomplete first; descending = complete first. const aDone = a.outstandingPoCount === 0 ? 1 : 0; const bDone = b.outstandingPoCount === 0 ? 1 : 0; cmp = aDone - bDone; break;} case "lastActivityAt": if (a.lastActivityAt === null && b.lastActivityAt === null) cmp = 0; else if (a.lastActivityAt === null) cmp = 1; else if (b.lastActivityAt === null) cmp = -1; else cmp = a.lastActivityAt.localeCompare(b.lastActivityAt); break;} return sort.direction === "asc" ? cmp : -cmp;});return sorted}function filterVendorSummaries(summaries: VendorSummary[],searchQuery: string,ccssFilter: string): VendorSummary[]{const q = searchQuery.trim().toLowerCase();return summaries.filter(v => {if (ccssFilter && !v.ccssNames.includes(ccssFilter)) return false; if (!q) return true; if (v.vendorId.toLowerCase().includes(q)) return true; if (v.vendorName.toLowerCase().includes(q)) return true; if (v.ccssNames.some(c => c.toLowerCase().includes(q))) return true; if (v.pos.some(p => {const ntp = (p.ntpNumber || "").toLowerCase(); const num = (p.purchaseOrderNumber || "").toLowerCase(); return ntp.includes(q) || num.includes(q);})) return true; return false;})}interface ColumnDef{label:string;sortKey:SortKey | null;align?: "right" | "center";cssClass:string}const COLUMNS: ColumnDef[] = [{label: "",sortKey: null,cssClass: "col-toggle"},{label: "Vendor ID",sortKey: "vendorId",cssClass: "col-vendor-id"},{label: "Vendor",sortKey: "vendorName",cssClass: "col-vendor"},{label: "CCSS",sortKey: "ccss",cssClass: "col-ccss"},{label: "Count of NTP/POs",sortKey: "poCount",align: "right",cssClass: "col-count"},{label: "Submitted",sortKey: "submittedPoCount",align: "right",cssClass: "col-count"},{label: "Draft",sortKey: "draftPoCount",align: "right",cssClass: "col-count"},{label: "Untouched",sortKey: "untouchedPoCount",align: "right",cssClass: "col-count"},{label: "Outstanding",sortKey: "outstandingPoCount",align: "right",cssClass: "col-count"},{label: "All Submitted",sortKey: "allSubmitted",align: "center",cssClass: "col-all-submitted"},{label: "Last Activity",sortKey: "lastActivityAt",cssClass: "col-activity"},{label: "Vendor Accessed",sortKey: null,cssClass: "col-token"},]; function sortIndicator(col: ColumnDef,sort: SortState): string{if (!col.sortKey) return "";if (col.sortKey !== sort.key) return " ↕";return sort.direction === "asc" ? " ▲" : " ▼"}export default function AdminDashboard(){const {data: pos = [],isLoading} = usePOs();const {state} = useAccruals();const [expanded,setExpanded] = useState<Set<string>>(new Set());const [sort,setSort] = useState<SortState>({key: "vendorName",direction: "asc"});const [searchQuery,setSearchQuery] = useState("");const [ccssFilter,setCcssFilter] = useState("");const allSummaries = useMemo(() => buildVendorSummaries(pos,state.localAccruals,state.localPOOverrides),[pos,state.localAccruals,state.localPOOverrides]);// Header rollup at the vendor level — reflects the FULL data set,not // the filtered view,so the high-level "how done is everything" stays // stable as the user applies filters. const completeVendorCount = useMemo(() => allSummaries.filter(v => v.outstandingPoCount === 0).length,[allSummaries]);const remainingVendorCount = allSummaries.length - completeVendorCount;const allCcssOptions = useMemo(() => {const set = new Set<string>(); for (const v of allSummaries) {for (const c of v.ccssNames) set.add(c);} return Array.from(set).sort((a,b) => a.localeCompare(b));},[allSummaries]);const visibleSummaries = useMemo(() => {const filtered = filterVendorSummaries(allSummaries,searchQuery,ccssFilter); return sortVendorSummaries(filtered,sort);},[allSummaries,searchQuery,ccssFilter,sort]);const toggleVendor = (vendorId: string) => {setExpanded(prev => {const next = new Set(prev); if (next.has(vendorId)) next.delete(vendorId); else next.add(vendorId); return next;});};const handleSortClick = (key: SortKey) => {setSort(prev => {if (prev.key === key) {return {key,direction: prev.direction === "asc" ? "desc" : "asc"};} return {key,direction: "asc"};});};if (isLoading) {return (<div className="admin-page"> <h1>Admin Dashboard</h1> <p className="admin-subtitle">Loading vendor data…</p> </div>);} return (<div className="admin-page"> <h1>Admin Dashboard</h1> <p className="admin-subtitle"> {allSummaries.length} Vendor{allSummaries.length === 1 ? "" : "s"},{" "}{pos.length} PO{pos.length === 1 ? "" : "s"} Total {" "}· Complete: {completeVendorCount} Vendor{completeVendorCount === 1 ? "" : "s"} {" "}· Remaining: {remainingVendorCount} Vendor{remainingVendorCount === 1 ? "" : "s"} {(searchQuery || ccssFilter) && (<> — showing {visibleSummaries.length} after filter</>)} </p> <div className="admin-toolbar"> <input type="search" className="admin-search" placeholder="Search vendor ID, name, CCSS, or PO number…" value={searchQuery} onChange={e => setSearchQuery(e.target.value)} /> <select className="admin-ccss-filter" value={ccssFilter} onChange={e => setCcssFilter(e.target.value)} > <option value="">All CCSS</option> {allCcssOptions.map(c => (<option key={c} value={c}>{c}</option>))} </select> {(searchQuery || ccssFilter) && (<button className="admin-clear-filters" onClick={() => {setSearchQuery(""); setCcssFilter("");}} > Clear filters </button>)} </div> <table className="admin-table"> <thead> <tr> {COLUMNS.map((col,idx) => {const isSorted = col.sortKey === sort.key; const headerClasses = [col.cssClass,col.align === "right" ? "num" : "",col.align === "center" ? "center" : "",col.sortKey ? "sortable" : "",isSorted ? "is-sorted" : "",].filter(Boolean).join(" "); return (<th key={idx} className={headerClasses} onClick={col.sortKey ? () => handleSortClick(col.sortKey!) : undefined} > {col.label}<span className="sort-indicator">{sortIndicator(col,sort)}</span> </th>);})} </tr> </thead> <tbody> {visibleSummaries.map(v => {const isOpen = expanded.has(v.vendorId); const isComplete = v.outstandingPoCount === 0; return (<> <tr key={v.vendorId} className={`vendor-row ${isOpen ? "is-open" : ""} ${isComplete ? "is-complete" : ""}`} onClick={() => toggleVendor(v.vendorId)} > <td className="col-toggle">{isOpen ? "▾" : "▸"}</td> <td className="col-vendor-id mono">{v.vendorId}</td> <td className="col-vendor vendor-name"> {v.vendorName} {isComplete && <span className="complete-mark" title="All POs submitted"> ✓</span>} </td> <td className="col-ccss">{v.ccssNames.join(", ") || <span className="dim">—</span>}</td> <td className="num col-count">{v.poCount}</td> <td className="num col-count">{v.submittedPoCount > 0 ? v.submittedPoCount : <span className="dim">0</span>}</td> <td className="num col-count">{v.draftPoCount > 0 ? v.draftPoCount : <span className="dim">0</span>}</td> <td className="num col-count">{v.untouchedPoCount > 0 ? v.untouchedPoCount : <span className="dim">0</span>}</td> <td className="num col-count">{v.outstandingPoCount > 0 ? v.outstandingPoCount : <span className="dim">0</span>}</td> <td className="center col-all-submitted"> {isComplete ? <span className="all-submitted-yes" title="All POs submitted">✓</span> : <span className="all-submitted-no" title={`${v.outstandingPoCount} PO${v.outstandingPoCount === 1 ? "" : "s"} outstanding`}>✗</span>} </td> <td className="col-activity">{v.lastActivityAt ? formatRelativeTime(v.lastActivityAt) : <span className="dim">—</span>}</td> <td className="col-token"> <span className="dim" title="Vendor accessed tracking will be wired in when the auth/token system is connected." > pending </span> </td> </tr> {isOpen && v.pos.map(p => (<tr key={p.poKey} className="po-detail-row"> <td className="col-toggle"></td> <td className="col-vendor-id"></td> <td className="col-vendor mono">{p.ntpNumber || p.purchaseOrderNumber}</td> <td className="col-ccss">{p.ccss || <span className="dim">—</span>}</td> <td className="num col-count"></td> <td className="num col-count">{p.submittedAccrualCount > 0 ? p.submittedAccrualCount : <span className="dim">0</span>}</td> <td className="num col-count">{p.draftAccrualCount > 0 ? p.draftAccrualCount : <span className="dim">0</span>}</td> <td className="num col-count"></td> <td className="num col-count"></td> <td className="center col-all-submitted"></td> <td className="col-activity">{p.lastActivityAt ? formatRelativeTime(p.lastActivityAt) : <span className="dim">—</span>}</td> <td className="col-token"> <span className="dim" title="Per-PO open tracking will be wired in when server-side activity logging is connected." > pending </span> </td> </tr>))} </>);})} {visibleSummaries.length === 0 && (<tr> <td colSpan={COLUMNS.length} className="empty-state"> No vendors match the current filter. </td> </tr>)} </tbody> </table> </div>)}.admin-settings{padding:32px;max-width:820px;margin:0 auto}.admin-settings-content{background:#ffffff;border:1px solid var(--border, #e5e7eb);border-radius:10px;padding:32px;box-shadow:0 1px 3px #0000000d}.admin-settings-title{font-size:28px;font-weight:700;color:var(--text, #111827);margin:0 0 8px}.admin-settings-readonly-banner{background:rgba(0,0,0,.06);color:var(--text-dim, #4b5563);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:6px 12px;border-radius:4px;display:inline-block;margin-bottom:16px}.admin-settings-section{margin-top:28px;margin-bottom:28px}.admin-settings-label{display:block;font-size:15px;font-weight:600;color:var(--text, #111827);margin-bottom:4px}.admin-settings-help{font-size:13px;color:var(--text-dim, #6b7280);margin:0 0 12px;line-height:1.5}.admin-settings-input{display:block;width:100%;max-width:280px;font-size:14px;padding:10px 12px;border:1px solid var(--border, #d1d5db);border-radius:6px;color:var(--text, #111827);background:white;box-sizing:border-box;font-family:inherit}.admin-settings-input:focus{outline:2px solid var(--accent, #1d4ed8);outline-offset:-1px;border-color:var(--accent, #1d4ed8)}.admin-settings-preview{margin-top:8px;font-size:13px;color:var(--text-dim, #4b5563)}.admin-settings-textarea{display:block;width:100%;font-size:13px;padding:12px;border:1px solid var(--border, #d1d5db);border-radius:6px;color:var(--text, #111827);background:white;box-sizing:border-box;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.5;resize:vertical;min-height:240px}.admin-settings-textarea:focus{outline:2px solid var(--accent, #1d4ed8);outline-offset:-1px;border-color:var(--accent, #1d4ed8)}.admin-settings-actions{display:flex;align-items:center;gap:12px;padding-top:20px;border-top:1px solid var(--border, #e5e7eb);margin-top:24px}.admin-settings-save{background:var(--accent, #1d4ed8);color:#fff;border:none;padding:10px 22px;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;font-family:inherit;transition:opacity .15s ease}.admin-settings-save:hover:not(:disabled){opacity:.9}.admin-settings-save:disabled{opacity:.45;cursor:not-allowed}.admin-settings-reset{background:white;color:var(--text-dim, #4b5563);border:1px solid var(--border, #d1d5db);padding:10px 22px;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;font-family:inherit}.admin-settings-reset:hover{background:rgba(0,0,0,.03)}.admin-settings-saved{color:#059669;font-size:14px;font-weight:600}.admin-settings-note{margin-top:32px;padding:14px 16px;background:rgba(245,158,11,.08);border-left:3px solid rgba(245,158,11,.6);border-radius:4px;font-size:13px;line-height:1.5;color:var(--text, #1f2937)}.home-page{padding:48px 32px;max-width:1200px;margin:0 auto}.home-greeting{font-size:32px;font-weight:700;color:var(--text, #111827);margin:0 0 8px;letter-spacing:-.01em}.home-subtitle{font-size:15px;color:var(--text-dim, #6b7280);margin:0 0 28px}.home-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;max-width:760px}.home-tile{display:block;padding:24px 28px;background:#ffffff;border:1px solid var(--border, #e5e7eb);border-radius:10px;text-decoration:none;color:inherit;box-shadow:0 1px 3px #0000000d;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.home-tile:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000014;border-color:var(--accent, #1d4ed8)}.home-tile-title{font-size:18px;font-weight:600;color:var(--text, #111827);margin-bottom:6px}.home-tile-desc{font-size:13px;color:var(--text-dim, #6b7280);line-height:1.5}.vendor-home-content{max-width:760px}.vendor-action-card{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:28px 32px;margin:24px 0;background:#ffffff;border:1px solid var(--border, #e5e7eb);border-left:4px solid var(--accent, #1d4ed8);border-radius:10px;box-shadow:0 1px 3px #0000000d}.vendor-action-text{flex:1;min-width:0}.vendor-due-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim, #6b7280)}.vendor-due-date{font-size:26px;font-weight:700;color:var(--text, #111827);margin:4px 0 0;line-height:1.2}.vendor-action-sub{font-size:14px;color:var(--text-dim, #4b5563);margin-top:10px}.vendor-action-cta{display:inline-flex;align-items:center;gap:4px;padding:14px 28px;background:var(--accent, #1d4ed8);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:15px;white-space:nowrap;box-shadow:0 2px 4px #0000001a;transition:transform .15s ease,box-shadow .15s ease;flex-shrink:0}.vendor-action-cta:hover{transform:translateY(-1px);box-shadow:0 4px 10px #00000026}.vendor-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:16px 0 24px}.vendor-stat-card{padding:22px 16px;background:#ffffff;border:1px solid var(--border, #e5e7eb);border-radius:10px;text-align:center}.vendor-stat-number{font-size:38px;font-weight:700;color:var(--text, #111827);line-height:1;font-variant-numeric:tabular-nums}.vendor-stat-label{margin-top:8px;font-size:13px;color:var(--text-dim, #6b7280);font-weight:500}.vendor-instructions{margin-top:24px;padding:28px 32px;background:#ffffff;border:1px solid var(--border, #e5e7eb);border-radius:10px}.vendor-instructions-title{font-size:17px;font-weight:600;color:var(--text, #111827);margin:0 0 16px}.vendor-instructions-body{font-size:14px;line-height:1.7;color:var(--text, #1f2937);white-space:pre-wrap;font-family:inherit}@media (max-width: 640px){.vendor-action-card{flex-direction:column;align-items:stretch}.vendor-action-cta{text-align:center;justify-content:center}.vendor-stats-grid{grid-template-columns:1fr}}.po-context-band{position:sticky;top:52px;z-index:30;background:var(--surface);box-shadow:0 2px 4px #0000000f}.po-card-header{background-color:#1c3a6e!important;color:#fff;padding:10px 24px 14px;display:flex;justify-content:space-between;align-items:flex-start;gap:24px;box-sizing:border-box}.po-card-header>div{flex:1;min-width:0}.po-card-header h2{font-family:"DM Serif Display",serif;font-size:20px;font-weight:400;margin:0 0 4px;line-height:1.15}.po-card-header .hdr-line{font-size:13px;opacity:.9;line-height:1.55}.po-card-header .hdr-line.title{font-weight:500;opacity:.92;font-size:13px;letter-spacing:.3px;text-transform:uppercase}.po-card-header-right{text-align:right;font-size:13px;opacity:.9;line-height:1.55}.po-card-header-right .ccss{font-family:inherit;opacity:.9}.po-card-header .routing-pill{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.3);font-size:12px;padding:2px 8px;margin-left:8px;display:inline-block;font-weight:700;border-radius:3px;font-family:DM Mono,monospace;letter-spacing:.3px}.po-card-header .routing-pill-dept{background:rgba(255,255,255,.22)}.po-card-header .routing-pill-exception{background:rgba(220,70,70,.85);border-color:#ffc8c880}.po-card-header .routing-pill+.routing-pill{margin-left:6px}.prior-hist-toggle{display:flex;align-items:center;justify-content:space-between;padding:6px 24px;background:#f7f5f1;border-top:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;margin-top:8px}.prior-hist-toggle:hover{background:#efece5}.prior-hist-label{font-size:12px;font-weight:700;color:var(--text-dim);display:flex;align-items:center;gap:12px;text-transform:uppercase;letter-spacing:.4px}.prior-hist-label .badge{background:white;color:var(--text-mid);border:1px solid var(--border);border-radius:10px;padding:1px 10px;font-size:12px;font-weight:600;text-transform:none;letter-spacing:0;font-family:DM Mono,monospace}.prior-hist-label .total{color:var(--text-mid);font-size:12px;font-weight:400;text-transform:none;letter-spacing:0}.prior-hist-label .last{font-size:12px;color:var(--text-dim);font-weight:500;text-transform:none;letter-spacing:0;font-family:DM Mono,monospace}.prior-hist-expand-btn{font-size:12px;font-weight:600;color:var(--text-mid);background:white;border:1px solid var(--border);border-radius:4px;padding:3px 10px;display:flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0;cursor:pointer}.prior-hist-expand-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.prior-hist-arrow{font-size:12px;transition:transform .15s}.prior-hist-arrow.open{transform:rotate(180deg)}.prior-hist-panel{background:white;border-bottom:1px solid var(--border);overflow-x:auto;width:100%;min-width:0;box-sizing:border-box}.prior-hist-panel table{margin:0;border-radius:0;border:none}.accrual-note{background:var(--accent-light);border-top:1px solid #c8d8f0;border-bottom:1px solid #c8d8f0;padding:10px 24px;font-size:13px;color:var(--accent);line-height:1.5;margin-top:8px}.po-meta{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--border)}.po-meta-item{padding:8px 14px;border-right:1px solid var(--border)}.po-meta-item:last-child{border-right:none}.po-meta-label{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-dim);font-weight:600;margin-bottom:2px}.po-meta-value{font-size:13px;font-weight:500}.inline-editor-hdr{font-size:12px;font-weight:700;text-transform:uppercase;color:#fff;letter-spacing:.4px;padding:8px 20px;border-top-left-radius:4px;border-top-right-radius:4px;background:var(--accent);display:flex;align-items:center;gap:8px;font-family:DM Sans,sans-serif}.inline-editor-hdr:before{content:"✎";font-size:13px}.inline-editor-fields{display:grid;grid-template-columns:minmax(180px,1.3fr) minmax(150px,1fr) minmax(150px,1fr) minmax(150px,1fr);gap:16px;padding:14px 20px 8px;background:#fafaf7;border-bottom:1px solid var(--border);box-sizing:border-box}.inline-editor-fields .f-group.full{grid-column:1 / -1}.inline-editor-body{padding:12px 20px;background:white;box-sizing:border-box}.inline-editor-body>*:not(:last-child){margin-bottom:8px}.inline-editor-actions{padding:10px 20px;background:#f7f5f1;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;box-sizing:border-box}.inline-editor-actions .btn-save{padding:8px 20px;font-size:13px}.inline-editor-actions .btn-cancel{padding:8px 16px;font-size:13px;background:transparent;border:1.5px solid var(--border);border-radius:4px;font-weight:600;cursor:pointer;color:var(--text-mid);font-family:DM Sans,sans-serif}.inline-editor-actions .btn-draft{padding:8px 18px;font-size:13px;background:white;color:var(--text-mid);border:1.5px solid var(--border);border-radius:4px;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif}.inline-editor-actions .btn-draft:hover{background:var(--bg);border-color:var(--text-mid);color:var(--text)}.f-group{box-sizing:border-box}.f-group label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text);font-weight:700;margin-bottom:6px;font-family:DM Sans,sans-serif}.f-group input,.f-group textarea{width:100%;box-sizing:border-box;border:1.5px solid var(--border);border-radius:4px;padding:8px 10px;font-family:DM Sans,sans-serif!important;font-size:13px;line-height:1.4;color:var(--text);outline:none;background:white;text-align:left;height:36px}.f-group textarea{resize:vertical;min-height:56px;height:auto}.f-group input:focus,.f-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.f-group input:hover,.f-group textarea:hover{border-color:var(--text-mid)}.f-group.full{grid-column:1 / -1}.f-group input[readonly]{background:#f5f3ef;cursor:not-allowed}.btn-save{background:var(--accent);color:#fff;border:none;border-radius:4px;padding:8px 20px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;cursor:pointer}.accrual-section{background:#e8f2e8;border:1px solid #7aa87d;border-radius:6px;margin-bottom:14px;box-shadow:0 1px 3px #00000014}.accrual-hdr{padding:7px 14px;background:linear-gradient(to bottom,#e4f0e4,#dfeee0);border-bottom:1px solid #7aa87d;font-size:12px;font-weight:700;color:#1f4a22;text-transform:uppercase;letter-spacing:.4px;display:flex;align-items:center;gap:10px}.accrual-hdr-lbl{flex-shrink:0}.accrual-hdr-classification{display:flex;align-items:center;gap:8px;flex:1;min-width:0;font-size:12px;color:#2c6030;font-weight:500;text-transform:none;letter-spacing:0}.accrual-hdr-classification-lbl{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#4a684a;flex-shrink:0}.accrual-hdr-classification strong{font-weight:700;color:#1f4a22;flex-shrink:0}.accrual-hdr-actions{margin-left:auto;display:flex;gap:6px;flex-shrink:0}.accrual-hdr-actions button{padding:3px 10px;font-size:12px;font-weight:600;border:1px solid #7aa87d;background:white;border-radius:3px;cursor:pointer;font-family:inherit;color:#1f4a22;text-transform:none;letter-spacing:0}.accrual-hdr-actions button:hover{background:#dfeee0}.accrual-hdr-actions button.remove{color:#7a1a1a;border-color:#7a1a1a}.accrual-hdr-actions button.remove:hover{background:#fde4e4}.accrual-table{background:white}.accrual-footer{padding:8px 14px 10px;background:#eef5ee;border-top:1px solid #c8ddc8;box-shadow:inset 0 1px #1f4a2214}.accrual-line{display:flex;gap:10px;font-size:12px;color:#2c6030;line-height:1.5}.accrual-line+.accrual-line{margin-top:3px}.accrual-lbl{flex-shrink:0;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#4a684a;min-width:90px;padding-top:1px}.accrual-val{flex:1}.accrual-sub{color:#4a684a}.accrual-sov-recap{border-top:1px solid #c8ddc8;background:white;box-shadow:inset 0 1px #1f4a2214}.accrual-sov-recap-hdr{padding:7px 14px;background:linear-gradient(to bottom,#f1f7f1,#eef5ee);border-bottom:1px solid #c8ddc8;font-size:12px;font-weight:700;color:#1f4a22;text-transform:uppercase;letter-spacing:.4px;display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.accrual-sov-recap-hdr:hover{background:#e4efe4}.accrual-sov-recap-arrow{font-size:12px;transition:transform .15s;display:inline-block;width:10px;text-align:center}.accrual-sov-recap.open .accrual-sov-recap-arrow{transform:rotate(180deg)}.accrual-sov-recap-sub{font-weight:400;color:#4a684a;text-transform:none;letter-spacing:0;font-size:12px;margin-left:auto}.accrual-sov-recap-panel{display:none}.accrual-sov-recap.open .accrual-sov-recap-panel{display:block}.accrual-sov-recap .inv-total-row>.inv-gc{background:#eef5ee;color:#1f4a22}.chip-tag{font-size:12px;padding:4px 10px;border-radius:4px;font-weight:700;letter-spacing:.4px;flex-shrink:0;text-transform:uppercase;display:inline-flex;align-items:center;gap:5px}.chip-draft{background:#fff4e0;color:#7a4a00;border:1px solid #e8a020}.chip-submitted{background:var(--covered-bg);color:var(--covered);border:1px solid var(--covered-border)}.chip-resub{background:#e8eef8;color:#2c5282;border:1.5px solid #2c5282}input.me-sov-amt{width:100%;padding:4px 8px;font-family:DM Mono,monospace;font-size:12px;border:1px solid var(--border);border-radius:3px;text-align:right;outline:none;background:white}input.me-sov-amt:focus{border-color:var(--accent)}.multi-entries-wrap{margin-top:4px;display:flex;flex-direction:column;gap:8px}.po-cta-area{margin-top:16px}.remaining-block{margin:16px 0}.remaining-inner{background:#fff9eb;border:2px solid #c48418;border-radius:8px;padding:16px 20px}.remaining-inner .title{font-size:14px;font-weight:600;color:#5c3800;margin-bottom:8px}.remaining-inner .sub{font-size:13px;color:#5c3800;line-height:1.55;margin-bottom:12px}.remaining-inner .periods-list{font-weight:600}.remaining-inner .partial-note{font-size:12px;color:#6a4a00;font-style:italic}.remaining-opt{display:flex;gap:12px;padding:12px 14px;background:white;border:1.5px solid var(--border);border-radius:6px;cursor:pointer;margin-bottom:10px;align-items:flex-start}.remaining-opt input[type=checkbox]{width:20px;height:20px;margin-top:1px;accent-color:#c48418;flex-shrink:0;cursor:pointer}.remaining-opt.selected{background:#fffbef;border-color:#c48418}.remaining-opt .opt-label{font-size:13px;font-weight:600;color:var(--text)}.remaining-opt .opt-comment{font-size:12px;color:var(--text-mid);margin-top:3px}.remaining-comment label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text);display:block;margin-bottom:5px}.remaining-comment .optional{font-weight:400;color:var(--text-dim);font-size:12px;text-transform:none;letter-spacing:0}.remaining-comment textarea{width:100%;box-sizing:border-box;border:1.5px solid var(--border);border-radius:4px;padding:8px 10px;font-family:DM Sans,sans-serif;font-size:13px;resize:vertical;min-height:44px}.remaining-comment textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.all-resolved{display:flex;gap:10px;align-items:center;padding:14px 18px;margin:16px 0;background:var(--covered-bg);border:1.5px solid var(--covered-border);border-radius:8px}.all-resolved .ic{font-size:18px;color:var(--covered);font-weight:700}.all-resolved .msg{font-size:13px;color:var(--covered);font-weight:500}.cert-block{margin:16px 0;padding:16px 20px 16px 34px;background:#fff9eb;border:2px solid #c48418;border-radius:8px}.cert-label{display:flex;align-items:flex-start;gap:12px;cursor:pointer;font-size:13px;line-height:1.45;margin:0}.cert-label input[type=checkbox]{width:20px;height:20px;margin-top:1px;cursor:pointer;accent-color:#c48418;flex-shrink:0}.cert-label .text strong{color:#5c3800;font-weight:700}.submit-bar{padding:14px 18px;text-align:center;border-top:1px solid var(--border);margin-top:16px}.submit-bar .submit-hint{font-size:13px;color:var(--accent);font-weight:500;background:var(--accent-light);border-left:3px solid var(--accent);border-radius:0 4px 4px 0;padding:8px 12px;margin-bottom:10px;text-align:center;line-height:1.5;display:block;max-width:100%}.submit-bar .submit-hint.ready{color:var(--covered);background:var(--covered-bg);border-left-color:var(--covered-border);font-weight:600;text-align:center;display:block}.submit-bar .btn-submit{padding:11px 36px;font-size:13px;font-weight:600}.submit-bar .btn-submit:disabled{opacity:.4;cursor:not-allowed}.accruals-launcher{display:flex;align-items:center;gap:14px;padding:8px 24px}.accruals-launcher-hint{font-size:12px;color:var(--text-dim);font-style:italic}.month-accruals-section{border-left:3px solid #7aa87d;background:#fafff9!important}.month-accruals-section .inv-section-hdr{background:#e8f2e8;color:#1f4a22}.f-group .react-datepicker-wrapper,.f-group .react-datepicker__input-container{width:100%;display:block}.f-group .react-datepicker__input-container input{cursor:pointer}.react-datepicker-popper{z-index:1400}.react-datepicker{font-family:DM Sans,sans-serif!important;border:1.5px solid var(--accent);border-radius:6px;box-shadow:0 6px 20px #1c3a6e2e;font-size:13px}.react-datepicker__header{background:var(--accent);color:#fff;border-bottom:1px solid var(--accent);border-top-left-radius:4px;border-top-right-radius:4px}.react-datepicker__current-month,.react-datepicker__day-name,.react-datepicker-time__header{color:#fff!important;font-family:DM Sans,sans-serif!important}.react-datepicker__navigation{top:10px}.react-datepicker__day{font-family:DM Sans,sans-serif;color:var(--text)}.react-datepicker__day:hover{background:var(--accent-light)}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range{background:var(--accent)!important;color:#fff!important}.react-datepicker__day--keyboard-selected{background:var(--accent-light);color:var(--accent)}.react-datepicker__day--disabled{color:var(--text-dim);cursor:not-allowed}.react-datepicker__month-dropdown-container,.react-datepicker__year-dropdown-container{font-family:DM Sans,sans-serif;font-size:12px}@media (max-width: 900px){.inline-editor-fields{grid-template-columns:1fr 1fr}.inline-editor-fields .f-group.full{grid-column:1 / -1}}@media (max-width: 600px){.inline-editor-fields{grid-template-columns:1fr}.inline-editor-actions{flex-wrap:wrap}}.inv-pending-row{font-style:italic;background-color:#fffbeb}.draft-warning-banner{display:flex;align-items:center;gap:10px;padding:8px 24px;font-size:13px;line-height:1.4;border-top:1px solid;border-bottom:1px solid}.draft-warning-stale{background:#fff4e0;color:#7a4a00;border-color:#e8a020}.draft-warning-very-stale{background:#fde7d4;color:#7a3a00;border-color:#d97a3a}.draft-warning-icon{font-size:14px;flex-shrink:0}.draft-warning-text{flex:1}.draft-warning-dismiss{background:transparent;border:none;color:inherit;opacity:.6;font-size:18px;line-height:1;cursor:pointer;padding:0 4px;flex-shrink:0}.draft-warning-dismiss:hover{opacity:1}.submitted-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#eef5ee;border-bottom:1px solid #c8ddc8;border-left:4px solid #4a7a4f;padding:10px 16px}.submitted-banner-body{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.submitted-banner-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#4a7a4f;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.submitted-banner-text{min-width:0}.submitted-banner-title{font-size:13px;font-weight:700;color:#2c5030;letter-spacing:.2px}.submitted-banner-sub{font-size:12px;color:#4a684a;line-height:1.5;margin-top:1px}.submitted-banner-btn{background:white;color:#2c5030;border:1.5px solid #4a7a4f;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;padding:6px 14px;border-radius:5px;cursor:pointer;white-space:nowrap;transition:all .12s;flex-shrink:0}.submitted-banner-btn:hover{background:#dfeee0}.po-locked .po-action-btn,.po-locked .row-add-btn,.po-locked .accrual-hdr-actions{display:none}.po-locked .cert-label{opacity:.6;pointer-events:none}.po-locked .remaining-block{opacity:.7;pointer-events:none}.po-locked .btn-save{opacity:.4!important;pointer-events:none;cursor:not-allowed}.po-locked .submitted-banner-btn{opacity:1!important;pointer-events:auto!important;cursor:pointer!important}.form-error-banner{margin:0 20px 12px;padding:10px 14px;background:var(--missing-bg);border:1px solid var(--missing-border);border-left:4px solid var(--missing);border-radius:4px;color:var(--missing);font-size:13px;line-height:1.5}.form-error-banner-title{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}.form-error-banner-list{margin:0;padding-left:18px}.form-error-banner-list li{margin-bottom:2px}.form-error-banner-list li:last-child{margin-bottom:0}.field-error{margin-top:4px;font-size:12px;color:var(--missing);line-height:1.4}.f-group.has-error input,.f-group.has-error textarea{border-color:var(--missing)}.f-group.has-error input:focus,.f-group.has-error textarea:focus{border-color:var(--missing);box-shadow:0 0 0 3px var(--missing-bg)}.f-group.has-error .react-datepicker__input-container input{border-color:var(--missing)}.status-pill{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px;font-family:DM Sans,sans-serif;white-space:nowrap}.pill-covered{background:var(--covered-bg);color:var(--covered);border:1px solid var(--covered-border)}.pill-partial{background:var(--partial-bg);color:var(--partial);border:1px solid var(--partial-border)}.pill-missing{background:var(--missing-bg);color:var(--missing);border:1px solid var(--missing-border)}.pill-prentp{background:#f0ede8;color:var(--text-mid);border:1px solid #c8c4be}.pill-pending{background:#fff4e0;color:#7a4a00;border:1px solid #e8a020}.pill-notreq{background:#f0ede8;color:var(--text-mid);border:1px solid #d8d2c6}.pill-needs{background:var(--partial-bg);color:var(--partial);border:1px solid var(--partial-border)}.fy-tag{display:inline-block;margin-left:8px;padding:1px 6px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border-radius:3px;cursor:help}.fy-tag.fy-current{color:#1f4a22;background:#dfeee0;border:1px solid #7aa87d}.fy-tag.fy-prior{color:var(--text-dim);background:#f0ede8;border:1px solid #c8c4be}.months-toolbar-wrap{background:#f7f5f1;border-top:1px solid var(--border);margin-top:8px}.months-toolbar-meta{display:flex;align-items:center;gap:14px;padding:8px 24px;border-bottom:1px solid var(--border)}.months-toolbar-counts{display:flex;gap:14px;align-items:center;margin-right:auto}.mtc-item{font-size:12px;color:var(--text-mid);font-weight:600;text-transform:uppercase;letter-spacing:.3px;display:flex;align-items:center;gap:6px;white-space:nowrap}.mtc-prefix{font-size:12px;color:var(--text-mid);font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.mtc-val{font-family:DM Mono,monospace;font-weight:700;font-size:13px;padding:1px 7px;border-radius:3px;min-width:20px;text-align:center}.mtc-covered{background:var(--covered-bg);color:var(--covered);border:1px solid var(--covered-border)}.mtc-partial{background:var(--partial-bg);color:var(--partial);border:1px solid var(--partial-border)}.mtc-missing{background:var(--missing-bg);color:var(--missing);border:1px solid var(--missing-border)}.toolbar-btn{padding:4px 12px;font-size:12px;font-weight:600;background:white;color:var(--text-mid);border:1px solid var(--border);border-radius:4px;cursor:pointer;font-family:inherit;white-space:nowrap}.toolbar-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.months-table-wrap{background:white;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.months-table{display:grid;grid-template-columns:var(--master-table-columns)}.mth-head{padding:6px 8px 5px;background:white;border-bottom:2px solid var(--border);font-size:12px;font-weight:700;text-transform:uppercase;color:var(--text-dim);letter-spacing:.4px;min-height:32px;display:flex;align-items:flex-end;white-space:normal;line-height:1.25}.mth-head.mth-count,.mth-head.mth-action{justify-content:flex-end;text-align:right}.mth-head.mth-coverage{justify-content:flex-start;text-align:left}.mth-head.mth-invs,.mth-head.mth-pfrom,.mth-head.mth-pto,.mth-head.mth-pending{justify-content:flex-start}.mth-head.mth-action{padding-right:16px}.month-row-contents{display:contents}.month-row-contents>.mth-cell,.month-row-contents>.month-count,.month-row-contents>.month-invs,.month-row-contents>.month-date,.month-row-contents>.month-pending,.month-row-contents>.month-hint{padding:3px 8px;cursor:pointer;align-self:stretch;border-bottom:1px solid var(--border);min-height:28px;display:flex;align-items:center}.month-row-contents>.mth-spacer-cell{align-self:stretch;border-bottom:1px solid var(--border);min-height:28px;cursor:pointer}.month-row-contents:hover>.mth-spacer-cell{background:#faf9f7}.month-row-contents>.mth-period-cell{flex-direction:row;align-items:center;justify-content:flex-start}.month-row-contents>.month-count{justify-content:flex-end}.month-row-contents>.month-invs{justify-content:flex-start}.month-row-contents>.month-pending{justify-content:flex-start}.month-row-contents>.month-hint{justify-content:flex-end;padding-right:8px}.month-row-contents:hover>.mth-cell,.month-row-contents:hover>.month-count,.month-row-contents:hover>.month-invs,.month-row-contents:hover>.month-date,.month-row-contents:hover>.month-pending,.month-row-contents:hover>.month-hint{background:#faf9f7}.month-row-contents>.expand-cell{border-bottom:1px solid var(--border);min-height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer}.month-row-contents:hover>.expand-cell{background:#faf9f7}.month-count{font-size:13px;color:var(--text-mid);text-align:right;font-family:DM Mono,monospace;font-weight:400}.month-invs{font-family:DM Mono,monospace;font-size:13px;color:var(--text-mid);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left;min-width:0;max-width:100%;display:block}.month-date{font-family:DM Mono,monospace;font-size:13px;color:var(--text-mid);text-align:left;white-space:nowrap}.month-label-text{font-size:14px;font-weight:600;color:var(--text)}.response-panel{grid-column:1 / -1;background:#eee7d9;box-shadow:inset 4px 0 0 var(--accent);border-bottom:2px solid var(--accent);padding:4px 0 6px}.expand-btn{background:transparent;color:var(--text-mid);border:none;font-size:14px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center}.expand-btn:hover{color:var(--accent)}.expand-arrow{display:inline-block;color:var(--text-dim);font-size:10px;margin-right:6px;flex-shrink:0}.row-add-btn{padding:4px 10px;margin-right:8px;background:white;border:1px solid var(--accent);color:var(--accent);border-radius:4px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap}.row-add-btn:hover{background:var(--accent-light)}.row-add-btn:disabled{opacity:.5;cursor:not-allowed}.inv-section{background:white;border:1px solid var(--border);border-radius:6px;margin-bottom:8px}.response-panel .inv-section:last-child{margin-bottom:0}.inv-section-hdr{padding:5px 14px;background:#ede4d0;border-bottom:1px solid #d4c8a8;font-size:12px;font-weight:700;color:#6b5a30;text-transform:uppercase;letter-spacing:.4px}.inv-grid{display:grid;grid-template-columns:var(--master-table-columns)}.inv-gh{font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-dim);font-weight:600;padding:4px 10px;background:#f7f5f1;border-bottom:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center}.inv-gh-right{justify-content:flex-end;text-align:right}.inv-grow{display:contents}.inv-gc{font-size:13px;padding:6px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;white-space:nowrap;overflow:hidden;min-width:0}.inv-gc.mono{font-family:DM Mono,monospace}.inv-gc-right{justify-content:flex-end}.inv-pending-row>.inv-gc{background:#fff9eb;color:#7a4a00;font-style:italic}.inv-grow:last-child>.inv-gc{border-bottom:none}.inv-gc.inv-gc-empty{color:var(--text-dim);font-style:italic;justify-content:center}.prior-fy-row>.inv-gc{color:var(--text-dim)}.inv-grow.inv-total-row>.inv-gc{background:#faf9f7;border-top:2px solid var(--border);border-bottom:none;font-weight:700;color:var(--text);padding-top:8px;padding-bottom:8px}.inv-grow.sov-blank-highlight>.inv-gc{background:#fef3f3}.inv-grow:nth-of-type(2n)>.inv-gc{background:#faf9f7}.inv-grow.inv-pending-row>.inv-gc{background:#fff9eb}.prior-hist-toggle{background:#dbe1e8;border-color:#b8c0c9}.prior-hist-toggle:hover{background:#ccd3dc}.prior-hist-toggle .prior-hist-label{color:var(--accent)}.prior-hist-panel .inv-gh{background:#dbe1e8;color:var(--accent);border-bottom:1px solid #b8c0c9}.month-invs-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1 1 auto}.mtc-prefix{font-weight:600;color:#4b5563;margin-right:4px}
