*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-size:14px;line-height:1.5;overflow:hidden}button,input,textarea,select{font-family:inherit;font-size:inherit}::-webkit-scrollbar-corner{background:0 0}*{scrollbar-width:thin;scrollbar-color:#ffffff26 transparent}:root{--bg-base:#111;--bg-surface:#181818;--bg-elevated:#141414fa;--bg-selected:#222;--bg-hover:#1e1e1e;--border:#444;--border-hi:#555;--border-sub:#222;--text-1:#fff;--text-2:#ffffffb3;--text-3:#ffffff73;--divider:#222}*,:before,:after{box-sizing:border-box}body{background:var(--bg-base);color:var(--text-1);margin:0;font-family:system-ui,sans-serif;font-size:15px;line-height:1.45}.app{background:var(--bg-base);height:100vh;color:var(--text-1);flex-direction:column;display:flex;overflow:hidden}.app-header{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:100;flex-shrink:0;align-items:center;gap:10px;height:42px;padding:0 14px;display:flex;position:relative}.header-spacer{flex:1}.file-menu-wrap{position:relative}.file-menu-trigger{border:1px solid var(--border);color:var(--text-1);cursor:pointer;background:#111;border-radius:0;align-items:center;gap:5px;height:28px;padding:3px 10px;font-family:system-ui,sans-serif;font-size:14px;display:flex}.file-menu-trigger:hover{background:var(--bg-selected)}.file-menu-backdrop{z-index:199;position:fixed;inset:0}.file-menu{border:1px solid var(--border);z-index:200;background:#181818;border-radius:0;min-width:152px;padding:4px 0;position:absolute;top:calc(100% + 3px);left:0;box-shadow:0 8px 20px #00000073}.file-menu button{width:100%;color:var(--text-1);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:7px 14px;font-family:system-ui,sans-serif;font-size:14px;display:flex}.file-menu button:hover{background:var(--bg-selected)}.file-menu button svg{opacity:.65;flex-shrink:0}.file-menu hr{border:none;border-top:1px solid var(--border-sub);margin:3px 0}.app-brand{-webkit-user-select:none;user-select:none;flex-shrink:0;align-items:baseline;gap:5px;display:flex}.app-brand-name{letter-spacing:.02em;color:var(--text-1);font-size:15px;font-weight:700}.app-brand-version{color:var(--text-3);letter-spacing:.04em;font-size:11px}.app-filename{color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;text-overflow:ellipsis;max-width:260px;font-size:13px;overflow:hidden}.app-filename:hover{color:var(--text-1)}.app-body{flex:1;display:flex;overflow:hidden}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:232px;display:flex;overflow-y:auto}.sidebar-hd{text-transform:uppercase;letter-spacing:1px;color:var(--text-3);border-bottom:1px solid var(--border-sub);flex-shrink:0;justify-content:space-between;align-items:center;padding:9px 10px 8px;font-size:12px;display:flex}.icon-btn{border:1px solid var(--border);color:var(--text-2);cursor:pointer;background:#111;border-radius:0;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;padding:0;display:flex}.icon-btn:hover{background:var(--bg-selected);color:var(--text-1)}.icon-btn--sm{opacity:0;background:0 0;border:none;width:18px;height:18px;transition:opacity .1s}.ep-row:hover .icon-btn--sm{opacity:1}.icon-btn--sm:hover{opacity:1;background:var(--bg-selected)!important}.ep-list{flex:1;padding:4px 0}.ep-row{cursor:pointer;color:var(--text-2);-webkit-user-select:none;user-select:none;align-items:center;gap:5px;padding:6px 8px;font-size:14px;display:flex}.ep-row:hover{background:var(--bg-hover);color:var(--text-1)}.ep-row--active{background:var(--bg-selected);color:var(--text-1)}.ep-chevron{width:14px;color:var(--text-3);flex-shrink:0;align-items:center;display:flex}.ep-name{flex:1;font-weight:500}.ep-count{color:var(--text-3);background:#222;border-radius:0;padding:1px 6px;font-size:12px}.shot-list{padding:3px 0 6px 18px}.shot-row{cursor:pointer;border-left:2px solid #0000;border-radius:0;align-items:center;gap:5px;margin-bottom:1px;padding:5px 7px;font-size:13px;display:flex}.shot-row:hover{background:var(--bg-hover)}.shot-row--active{background:var(--bg-selected)}.shot-row-name{color:var(--text-1);flex:1;font-family:Courier New,Courier,monospace;font-size:12px}.shot-row-status{white-space:nowrap;font-size:12px}.add-shot-btn{width:100%;color:var(--text-3);cursor:pointer;text-align:left;background:0 0;border:1px dashed #444;border-radius:0;align-items:center;gap:5px;margin-top:4px;padding:5px 7px;font-family:system-ui,sans-serif;font-size:13px;display:flex}.add-shot-btn:hover{background:var(--bg-hover);color:var(--text-2);border-color:#666}.empty-hint{color:var(--text-3);padding:14px 10px;font-size:13px;line-height:1.7}.main{background:var(--bg-base);flex-direction:column;flex:1;display:flex;overflow:hidden}.ep-tabs{background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;padding:6px 12px 0;display:flex;overflow:auto hidden}.ep-tab{color:var(--text-3);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:5px 14px;font-family:system-ui,sans-serif;font-size:14px}.ep-tab:hover{color:var(--text-2)}.ep-tab--active{color:var(--text-1);border-bottom-color:#888}.content-cols{flex:1;min-height:0;display:flex;overflow:hidden}.centre-col{border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:8px;width:600px;padding:8px;display:flex;overflow:hidden}.centre-col>.panel:first-child{flex:17;min-height:0}.centre-col>.panel:last-child{flex:10;min-height:0}.right-col{flex-direction:row;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.pie-section{flex-direction:column;flex:1;align-items:center;gap:8px;min-width:0;min-height:0;padding:10px 14px 8px;display:flex;overflow:hidden}.pie-container{flex:1;justify-content:center;align-items:center;width:100%;min-height:0;display:flex}.pie-canvas{cursor:pointer;display:block}.legend{flex-direction:column;flex-shrink:0;gap:4px;width:100%;display:flex}.legend-phase-header{text-transform:uppercase;letter-spacing:1px;color:var(--text-3);margin-top:2px;font-size:11px}.legend-divider{background:var(--border-sub);height:1px;margin:3px 0 2px}.legend-items-row{flex-wrap:wrap;gap:4px 14px;display:flex}.legend-item{color:var(--text-2);align-items:center;gap:6px;font-size:13px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.pie-controls{flex-direction:column;flex-shrink:0;gap:6px;width:100%;display:flex}.pie-header{justify-content:space-between;align-items:center;width:100%;display:flex}.chart-hint{color:var(--text-3);margin:0;font-size:13px;font-style:italic}.pie-mode-toggle{flex-shrink:0;display:flex}.pie-mode-btn{border:1px solid var(--border);color:var(--text-3);cursor:pointer;white-space:nowrap;background:#111;border-radius:0;height:24px;padding:0 9px;font-family:system-ui,sans-serif;font-size:12px}.pie-mode-btn+.pie-mode-btn{border-left:none}.pie-mode-btn:hover:not(.pie-mode-btn--active){background:var(--bg-hover);color:var(--text-2)}.pie-mode-btn--active{color:var(--text-1);background:#222;border-color:#777}.pie-tooltip{border:1px solid var(--border-hi);pointer-events:none;z-index:500;background:#141414fa;border-radius:0;min-width:155px;padding:8px 12px;position:fixed;box-shadow:0 6px 20px #0000008c}.pie-tooltip-name{color:#fff;font-family:Courier New,Courier,monospace;font-size:14px;font-weight:700;line-height:1.4}.pie-tooltip-status{margin-top:3px;font-size:14px;line-height:1.4}.panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:0;flex-direction:column;min-width:0;min-height:0;display:flex;overflow:hidden}.panel-hd{text-transform:uppercase;letter-spacing:1px;color:var(--text-3);border-bottom:1px solid var(--border-sub);flex-shrink:0;padding:7px 12px;font-size:12px}.panel-body{flex-direction:column;flex:1;min-height:0;padding:10px 12px;display:flex;overflow-y:auto}.panel-empty{color:var(--text-3);margin:0;font-size:14px;font-style:italic}.notes-area{border:1px solid var(--border-hi);width:100%;min-height:80px;color:var(--text-1);resize:none;background:#111;border-radius:0;flex:1;padding:8px 10px;font-family:system-ui,sans-serif;font-size:15px;line-height:1.55}.notes-area:focus{border-color:#777;outline:none}.shot-detail{flex-direction:column;gap:12px;display:flex}.detail-field{flex-direction:column;gap:5px;display:flex}.field-label{text-transform:uppercase;letter-spacing:.9px;color:var(--text-3);font-size:12px}.field-input{border:1px solid var(--border-hi);color:var(--text-1);background:#111;border-radius:0;padding:5px 8px;font-family:system-ui,sans-serif;font-size:15px}.field-input:focus{border-color:#777;outline:none}.field-input--mono{font-family:Courier New,Courier,monospace}.field-input--sm{width:90px}input[type=date]::-webkit-calendar-picker-indicator{filter:invert();opacity:.65;cursor:pointer}.field-textarea{border:1px solid var(--border-hi);color:var(--text-1);resize:vertical;background:#111;border-radius:0;width:100%;padding:7px 8px;font-family:system-ui,sans-serif;font-size:15px;line-height:1.55}.field-textarea:focus{border-color:#777;outline:none}.status-buttons{flex-wrap:wrap;gap:5px;display:flex}.status-btn{cursor:pointer;white-space:nowrap;border:1px solid;border-radius:0;align-items:center;height:26px;padding:3px 10px;font-family:system-ui,sans-serif;font-size:13px;display:flex}.status-btn:hover{opacity:.8}.status-btn--active{font-weight:600}.detail-actions{border-top:1px solid var(--border-sub);margin-top:2px;padding-top:7px}.detail-actions .btn{align-items:center;gap:6px;height:28px;padding:3px 10px;font-size:14px;display:flex}.btn{border:1px solid var(--border);height:30px;color:var(--text-1);cursor:pointer;white-space:nowrap;background:#111;border-radius:0;align-items:center;gap:6px;padding:0 14px;font-family:system-ui,sans-serif;font-size:14px;display:inline-flex}.btn:hover{background:var(--bg-selected)}.btn--primary{color:#fff;background:#222;border-color:#666}.btn--primary:hover{background:#2e2e2e;border-color:#888}.btn--danger{border-color:var(--border);color:var(--text-2);background:0 0}.btn--danger:hover{background:var(--bg-selected)}.btn:disabled{opacity:.35;cursor:not-allowed}.empty-state{color:var(--text-3);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:32px;display:flex}.empty-state-icon{font-size:48px}.empty-state h2{color:var(--text-2);margin:0;font-size:20px}.empty-state p{margin:0;font-size:15px}.overlay{z-index:1000;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--border-hi);background:#141414fa;border-radius:6px;flex-direction:column;gap:12px;width:90%;max-width:460px;padding:24px;display:flex;box-shadow:0 10px 30px #0000008c}.modal h2{margin:0;font-size:17px;font-weight:600}.modal p{color:var(--text-2);margin:0;font-size:15px;line-height:1.6}.modal strong{color:var(--text-1)}.modal em{color:var(--text-2)}.modal code{color:#a5f3fc;background:#111;border-radius:0;padding:1px 5px;font-family:Courier New,Courier,monospace;font-size:13px}.modal-footer{justify-content:flex-end;gap:6px;margin-top:4px;display:flex}.modal-field{flex-direction:column;gap:5px;display:flex}.modal-hint{color:var(--text-3);margin:0;font-size:13px;line-height:1.5}.modal-checkbox-label{cursor:pointer;color:var(--text-1);align-items:center;gap:7px;font-size:15px;display:flex}.modal-rate-row{align-items:center;gap:8px;margin-top:3px;padding-left:4px;display:flex}.currency-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.currency-presets{gap:0;display:flex}.currency-preset-btn{border:1px solid var(--border);color:var(--text-2);cursor:pointer;white-space:nowrap;background:#111;border-radius:0;height:28px;padding:0 8px;font-family:system-ui,sans-serif;font-size:13px}.currency-preset-btn+.currency-preset-btn{border-left:none}.currency-preset-btn:hover{background:var(--bg-selected);color:var(--text-1)}.currency-preset-btn--active{color:var(--text-1);background:#222;border-color:#777}.field-input--xs{text-align:center;width:48px}.autosave-status{color:#5699a5;-webkit-user-select:none;user-select:none;letter-spacing:.2px;flex-shrink:0;align-items:center;gap:4px;font-size:13px;display:flex}.header-field{flex-shrink:0;align-items:center;gap:5px;display:flex}.header-field-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.8px;-webkit-user-select:none;user-select:none;font-size:13px}.header-field-input{border:1px solid var(--border);width:58px;color:var(--text-1);text-align:right;background:#111;border-radius:0;height:26px;padding:2px 6px;font-family:Courier New,Courier,monospace;font-size:14px}.header-field-input:focus{border-color:#777;outline:none}.sort-select{border:1px solid var(--border);width:100%;color:var(--text-2);cursor:pointer;background:#111;border-radius:0;height:26px;margin-bottom:4px;padding:3px 5px;font-family:system-ui,sans-serif;font-size:13px}.sort-select:focus{border-color:#777;outline:none}.shot-row-deadline{border-radius:50%;flex-shrink:0;width:6px;height:6px}.detail-info-row{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.detail-info-cell{flex-direction:column;flex-shrink:0;gap:4px;display:flex}.detail-info-cell--date{flex:1;min-width:140px}.detail-info-date-wrap{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.detail-info-value{color:var(--text-3);white-space:nowrap;font-family:Courier New,Courier,monospace;font-size:14px;line-height:30px}.detail-info-delete{flex-shrink:0;align-items:center;gap:6px;height:30px;padding:0 10px;font-size:13px;display:flex}.detail-secondary-value{color:var(--text-3);font-size:14px;line-height:32px}.detail-shot-cost{color:#5699a5;font-weight:600}.detail-due-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.deadline-badge{white-space:nowrap;border:1px solid;border-radius:0;padding:2px 8px;font-size:13px;font-weight:600}.tracker-section{flex-direction:column;flex-shrink:0;gap:4px;width:100%;display:flex}.tracker-header{justify-content:space-between;align-items:baseline;display:flex}.tracker-label{text-transform:uppercase;letter-spacing:.9px;color:var(--text-3);font-size:12px}.tracker-value{color:var(--text-2);font-family:Courier New,Courier,monospace;font-size:13px}.tracker-bar{background:#222;border-radius:0;height:5px;overflow:hidden}.tracker-fill{border-radius:0;height:100%;transition:width .4s}.tracker-fill--frames{background:#3b82f6}.tracker-fill--cost{background:#8b5cf6}.modal--wide{max-width:560px}.status-editor{flex-direction:column;gap:4px;margin-top:4px;display:flex}.status-editor-row{align-items:center;gap:4px;display:flex}.status-editor-input{flex:1;height:30px;padding:4px 8px;font-size:14px}.status-editor-btn{border:1px solid var(--border);width:28px;height:30px;color:var(--text-2);cursor:pointer;background:#111;border-radius:0;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-family:system-ui,sans-serif;font-size:14px;display:flex}.status-editor-btn:hover:not(:disabled){background:var(--bg-selected);color:var(--text-1)}.status-editor-btn:disabled{opacity:.25;cursor:not-allowed}.status-editor-btn--remove{color:var(--text-3)}.status-editor-btn--remove:hover:not(:disabled){color:#ef4444}.status-editor-footer{gap:6px;margin-top:4px;display:flex}.invoice-panel{border-left:1px solid var(--border);border-top:none;border-bottom:none;border-right:none;border-radius:0;flex-shrink:0;width:210px}.invoice-panel-hd{justify-content:space-between;align-items:center;display:flex}.invoice-count{color:#2f6270;background:#2f62701f;border:1px solid #2f627059;border-radius:0;padding:1px 6px;font-size:11px;font-weight:700;line-height:1.6}.invoice-summary{color:var(--text-2);border-bottom:1px solid var(--border-sub);background:#2f62700f;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:5px;padding:6px 12px;font-size:12px;display:flex}.invoice-summary-sep{color:var(--text-3)}.invoice-list{padding:0;overflow-y:auto}.invoice-list .panel-empty{padding-left:12px}.invoice-item{cursor:pointer;border-bottom:1px solid var(--border-sub);padding:8px 12px;transition:background 80ms}.invoice-item:hover{background:var(--bg-hover)}.invoice-item--active{background:var(--bg-selected)}.invoice-item-name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-family:Courier New,Courier,monospace;font-size:12px;display:block;overflow:hidden}.invoice-item-ep{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:11px;display:block}.detail-dayrate-row{flex-wrap:wrap;gap:20px;display:flex}.detail-dayrate-item{flex-direction:column;gap:3px;display:flex}.detail-dayrate-value{color:var(--text-2);font-family:Courier New,Courier,monospace;font-size:14px}.detail-dayrate-cost{color:#5699a5;font-weight:600}.day-rate-options{flex-direction:column;gap:8px;margin-top:8px;padding-left:2px;display:flex}.modal-sub-field{flex-direction:column;gap:5px;display:flex}.field-input--time{width:80px;padding:4px 6px;font-size:14px}.cost-summary-section{flex-shrink:0;width:100%}.cost-summary-toggle{color:var(--text-3);text-transform:uppercase;letter-spacing:.9px;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:5px;width:100%;padding:4px 0;font-family:system-ui,sans-serif;font-size:12px;display:flex}.cost-summary-toggle:hover{color:var(--text-2)}.cost-table{border-collapse:collapse;width:100%;margin-top:4px;font-size:12px}.cost-table th{color:var(--text-3);text-transform:uppercase;letter-spacing:.7px;border-bottom:1px solid var(--border-sub);padding:3px 6px 4px;font-size:11px;font-weight:500}.cost-table td{border-bottom:1px solid var(--border-sub);color:var(--text-2);padding:4px 6px}.cost-table tbody tr{cursor:pointer}.cost-table tbody tr:hover td{background:var(--bg-hover)}.cost-table-row--selected td{background:var(--bg-selected)}.cost-table-shot{text-align:left;font-family:Courier New,Courier,monospace}.cost-table-time{text-align:right;white-space:nowrap}.cost-table-cost{text-align:right;white-space:nowrap;color:#5699a5}.cost-table-total{color:var(--text-1);border-top:1px solid var(--border);border-bottom:none;font-weight:600}.work-log{flex-direction:column;gap:3px;margin-top:2px;display:flex}.work-log-row{align-items:center;gap:7px;font-family:Courier New,Courier,monospace;font-size:12px;line-height:1.6;display:flex}.work-log-time{color:var(--text-2)}.work-log-sep{color:var(--text-3);font-size:11px}.work-log-duration{color:var(--text-3);margin-left:1px;font-size:11px}.work-log-active{color:#2f6270;letter-spacing:.3px;font-family:system-ui,sans-serif;font-size:11px;font-weight:600}.work-toggle-btn{width:100%;color:var(--text-2);cursor:pointer;background:#161616;border:1px solid #3a3a3a;border-radius:0;align-items:center;gap:7px;padding:7px 12px;font-family:system-ui,sans-serif;font-size:14px;font-weight:500;transition:background .12s,border-color .12s,color .12s;display:flex}.work-toggle-btn:hover{color:#2f6270;background:#1e1e1e;border-color:#2f6270}.work-toggle-btn--active{color:#2f6270;background:#2f62701f;border-color:#2f6270}.work-toggle-btn--active:hover{background:#2f62702e}.active-shot-indicator{color:#2f6270;flex-shrink:0;align-items:center;gap:7px;width:100%;padding:2px 0;font-size:13px;display:flex}.active-shot-icon{flex-shrink:0;font-size:11px}.active-shot-name{white-space:nowrap;text-overflow:ellipsis;font-family:Courier New,Courier,monospace;overflow:hidden}.shot-row-active-dot{background:#2f6270;border-radius:50%;flex-shrink:0;width:6px;height:6px;box-shadow:0 0 4px #2f627088}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#333;border-radius:0}::-webkit-scrollbar-thumb:hover{background:#444}
