/* ─────────────────────────────────────────────────────────────────
   EnRUD Rebuild — shared visual styles (lib/base.css)
   Loaded by every page. Page-specific tweaks go inline in the page.
   ───────────────────────────────────────────────────────────────── */

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Barlow',sans-serif;background:#0e1117;color:#d8dde8;min-height:100vh}

/* Centered single-column layout used by sign-in / picker / portal pages */
.layout-center{min-height:100vh;display:flex;align-items:center;justify-content:center}
.wrap{width:100%;max-width:520px;padding:2rem}

/* Branding */
.logo{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:2.8rem;letter-spacing:3px;color:#e8a020;text-align:center;margin-bottom:.25rem}
.logo span{color:#d8dde8}
.badge-rebuild{display:inline-block;background:rgba(232,160,32,.15);border:1px solid #e8a020;color:#e8a020;font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-size:.65rem;padding:.15rem .55rem;border-radius:20px;margin-left:.5rem;vertical-align:middle}
.tagline{text-align:center;font-size:.8rem;letter-spacing:2px;text-transform:uppercase;color:#7a8399;margin-bottom:2.5rem}

/* Card containers */
.card{background:#161b27;border:1px solid #2a3045;border-top:3px solid #e8a020;border-radius:10px;padding:2rem}

/* Section heading */
h2{font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;letter-spacing:2px;text-transform:uppercase;color:#7a8399;margin-bottom:1.5rem;text-align:center}

/* Form controls */
.fg{margin-bottom:1.25rem}
label{display:block;font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;color:#7a8399;margin-bottom:.4rem;font-weight:600}
input[type=email],input[type=password],input[type=text]{width:100%;background:#1e2435;border:1px solid #2a3045;border-radius:6px;color:#d8dde8;font-family:'Barlow',sans-serif;font-size:1rem;padding:.7rem 1rem;outline:none;transition:border-color .2s}
input[type=email]:focus,input[type=password]:focus,input[type=text]:focus{border-color:#e8a020}

/* Buttons */
.btn{width:100%;background:#e8a020;border:none;border-radius:6px;color:#000;font-family:'Barlow Condensed',sans-serif;font-size:1.1rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:.8rem;cursor:pointer;margin-top:.5rem;transition:background .2s}
.btn:hover{background:#f0c060}
.btn:disabled{opacity:.5;cursor:wait}
.btn-secondary{background:transparent;border:1px solid #2a3045;color:#d8dde8;margin-top:1rem}
.btn-secondary:hover{background:#1e2435;color:#e8a020;border-color:#e8a020}

/* Inline error */
.err{background:rgba(231,76,60,.15);border:1px solid #e74c3c;border-radius:6px;color:#e74c3c;font-size:.85rem;padding:.6rem 1rem;margin-bottom:1rem}

/* Top status bar (loaded library, ready, errors)
   Successful "ok" state auto-fades upward after a brief delay so it
   doesn't block the page header. Errors don't fade — they stay
   visible until a new status replaces them. */
.status-bar{position:fixed;top:0;left:0;right:0;background:#1e2435;border-bottom:1px solid #2a3045;padding:.4rem 1rem;font-size:.75rem;color:#7a8399;text-align:center;font-family:'Barlow',sans-serif;letter-spacing:.5px;z-index:1000}
.status-bar.ok{color:#27ae60;border-bottom-color:#27ae60;animation:status-fade 3s forwards}
.status-bar.err{color:#e74c3c;border-bottom-color:#e74c3c}
@keyframes status-fade{
  0%,65% {opacity:1;transform:translateY(0)}
  100%   {opacity:0;transform:translateY(-100%);pointer-events:none}
}

/* Role badges (used in pickers and portal welcomes) */
.role-badge{display:inline-block;font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-size:.75rem;padding:.3rem .8rem;border-radius:20px}
.rb-admin{background:rgba(155,89,182,.18);border:1px solid #9b59b6;color:#bf83d6}
.rb-supervisor{background:rgba(52,152,219,.18);border:1px solid #3498db;color:#d8dde8}
.rb-employee{background:rgba(232,160,32,.15);border:1px solid #e8a020;color:#e8a020}

code{background:#0e1117;padding:.1rem .4rem;border-radius:3px;font-size:.78rem;color:#d8dde8;font-family:monospace;word-break:break-all}

/* ═════════════════════════════════════════════════════════════════
   Admin layout: top header, left sidebar, main content
   Used by every admin-*.html page.
   ═════════════════════════════════════════════════════════════════ */

.admin-layout{display:grid;grid-template-columns:240px 1fr;grid-template-rows:auto 1fr;min-height:100vh}
.admin-header{grid-column:1 / -1;background:#161b27;border-bottom:1px solid #2a3045;padding:.75rem 1.25rem;display:flex;align-items:center;justify-content:space-between}
.admin-header .brand{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.4rem;letter-spacing:2px;color:#e8a020;display:inline-flex;align-items:center;gap:.55rem}
.admin-header .brand::before{content:'';display:inline-block;width:36px;height:36px;background-image:url('../images/enrud-logo.jpg');background-size:contain;background-repeat:no-repeat;background-position:center;flex:0 0 36px}
.admin-header .brand span{color:#d8dde8}
.admin-header .header-right{display:flex;align-items:center;gap:.75rem}
.admin-header .who{font-size:.85rem;color:#7a8399}
.sign-out-link{background:transparent;border:1px solid #2a3045;color:#d8dde8;font-family:'Barlow Condensed',sans-serif;font-size:.75rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:.4rem .8rem;border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}
.sign-out-link:hover{background:#1e2435;border-color:#e8a020;color:#e8a020}

/* Notifications bell (session 14) — text link with optional unread badge. */
.notif-link{display:inline-flex;align-items:center;gap:.4rem;color:#d8dde8;text-decoration:none;font-family:'Barlow Condensed',sans-serif;font-size:.75rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:.4rem .8rem;border-radius:6px;border:1px solid #2a3045;transition:background .15s,border-color .15s,color .15s}
.notif-link:hover{background:#1e2435;border-color:#e8a020;color:#e8a020}
.notif-link.has-unread{border-color:#e8a020;color:#e8a020;background:rgba(232,160,32,.08)}
.notif-badge{display:inline-block;background:#e8a020;color:#0e1117;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.7rem;line-height:1;padding:.15rem .4rem;border-radius:10px;min-width:1rem;text-align:center}

.admin-sidebar{background:#161b27;border-right:1px solid #2a3045;padding:1.25rem 0;position:sticky;top:0;align-self:start;max-height:100vh;overflow-y:auto}
.admin-sidebar .nav-group{margin-bottom:1rem}
.admin-sidebar .nav-group-label{font-family:'Barlow Condensed',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#7a8399;padding:.25rem 1.5rem;margin-bottom:.25rem}
.admin-sidebar .nav-subgroup-label{font-family:'Barlow',sans-serif;font-size:.68rem;font-weight:600;letter-spacing:.4px;color:#5a627a;padding:.5rem 1.5rem .15rem;text-transform:none}
.admin-sidebar .nav-link{display:flex;align-items:center;justify-content:space-between;padding:.55rem 1.5rem;color:#d8dde8;text-decoration:none;font-size:.9rem;font-family:'Barlow',sans-serif;transition:background .15s,color .15s;border-left:3px solid transparent}
.admin-sidebar .nav-link:hover{background:#1e2435;color:#e8a020}
.admin-sidebar .nav-link.active{background:#1e2435;color:#e8a020;border-left-color:#e8a020;font-weight:600}
.admin-sidebar .nav-link.disabled{color:#5a627a;cursor:not-allowed;font-style:italic}
.admin-sidebar .nav-link.disabled:hover{background:transparent;color:#5a627a}
.nav-hint{font-size:.65rem;letter-spacing:1px;text-transform:uppercase;color:#7a8399;background:rgba(122,131,153,.12);padding:.1rem .4rem;border-radius:3px;font-family:'Barlow Condensed',sans-serif;font-weight:700}
.nav-badge{display:inline-block;background:#e8a020;color:#0e1117;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.65rem;line-height:1;padding:.15rem .42rem;border-radius:10px;min-width:1rem;text-align:center;letter-spacing:0;text-transform:none}
.admin-sidebar .nav-link.has-pending{color:#e8a020}

.admin-content{padding:2rem 1.5rem;max-width:1400px;width:100%}
.admin-content h1{font-family:'Barlow Condensed',sans-serif;font-size:2rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#d8dde8;margin-bottom:.25rem}
.admin-content .subhead{color:#7a8399;font-size:.9rem;margin-bottom:1.75rem}

/* Card variant for admin pages — left-aligned heading, inner content */
.admin-content .card h2{text-align:left;margin-bottom:.75rem}

/* Scroll wrapper for data tables. Auto-applied by admin-shell.js so
   every data-table gets its own scrollbar without per-page HTML edits.
   max-height kicks in only when the table is taller than the cap, so
   short tables stay un-scrolled; long ones get their own scroll while
   the page chrome (h1, filters) keeps scrolling with the browser. */
.data-table-scroll{max-height:70vh;overflow:auto;border-radius:8px;margin-bottom:1.5rem}
.data-table-scroll > .data-table{margin-bottom:0;border-radius:0}

/* Data tables for list views */
.data-table{width:100%;border-collapse:collapse;background:#161b27;border:1px solid #2a3045;border-radius:8px;overflow:clip;margin-bottom:1.5rem}
.data-table th{background:#1e2435;color:#7a8399;font-family:'Barlow Condensed',sans-serif;font-size:.75rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;text-align:left;padding:.7rem 1rem;border-bottom:1px solid #2a3045;position:sticky;top:0;z-index:5}
/* Sticky column headers on admin CRUD pages (.sheet-table). Per-page
   style blocks define the background/colors but never `position`, so
   this rule applies cleanly without conflicts. */
.sheet-table thead th{position:sticky;top:0;z-index:5}
.data-table td{padding:.7rem 1rem;border-bottom:1px solid #2a3045;color:#d8dde8;font-size:.9rem;vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:#1a1f2e}
.data-table input[type=text],.data-table input[type=email]{background:#0e1117;border:1px solid #2a3045;color:#d8dde8;padding:.4rem .6rem;width:100%;border-radius:4px;font-family:'Barlow',sans-serif;font-size:.9rem}
.data-table input[type=text]:focus,.data-table input[type=email]:focus{border-color:#e8a020;outline:none}
.row-actions{display:flex;gap:.4rem;justify-content:flex-end}
.icon-btn{background:transparent;border:1px solid #2a3045;color:#7a8399;width:30px;height:30px;border-radius:5px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:.95rem;transition:all .15s;font-family:inherit}
.icon-btn:hover{border-color:#e8a020;color:#e8a020;background:#1e2435}
.icon-btn.danger:hover{border-color:#e74c3c;color:#e74c3c}
.icon-btn.save:hover{border-color:#27ae60;color:#27ae60}

.inactive-row td:not(:last-child){opacity:.5}
.inactive-badge{display:inline-block;font-size:.65rem;font-family:'Barlow Condensed',sans-serif;letter-spacing:1.5px;text-transform:uppercase;color:#7a8399;background:rgba(122,131,153,.15);padding:.1rem .45rem;border-radius:3px;margin-left:.5rem;font-weight:700}

.btn-primary{background:#e8a020;border:none;border-radius:6px;color:#000;font-family:'Barlow Condensed',sans-serif;font-size:.95rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:.55rem 1.2rem;cursor:pointer;transition:background .2s}
.btn-primary:hover{background:#f0c060}
.btn-primary:disabled{opacity:.5;cursor:wait}

/* Toast */
.toast-spot{position:fixed;bottom:1.5rem;right:1.5rem;z-index:1000;pointer-events:none}
.toast{background:#27ae60;color:#000;padding:.7rem 1.2rem;border-radius:6px;font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-size:.85rem;box-shadow:0 4px 12px rgba(0,0,0,.3);opacity:0;transform:translateY(10px);transition:opacity .25s,transform .25s}
.toast.show{opacity:1;transform:translateY(0)}
.toast.err{background:#e74c3c;color:#fff}

.empty-msg{color:#7a8399;text-align:center;padding:2rem;font-style:italic}

/* ═════════════════════════════════════════════════════════════════
   Master/detail layout (used by admin-tasks.html and similar)
   ═════════════════════════════════════════════════════════════════ */

.master-detail{display:grid;grid-template-columns:320px 1fr;gap:1.5rem;align-items:start}
@media (max-width:900px){.master-detail{grid-template-columns:1fr}}

.master-pane{background:#161b27;border:1px solid #2a3045;border-radius:8px;padding:1.25rem;position:sticky;top:1rem}
.master-pane h2{text-align:left;margin-bottom:.75rem}
.master-list{list-style:none;margin:0;padding:0;max-height:65vh;overflow-y:auto}
.master-list li{padding:.55rem .75rem;border-radius:5px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:.9rem;transition:background .15s,color .15s;border-left:3px solid transparent}
.master-list li:hover{background:#1e2435}
.master-list li.selected{background:#1e2435;color:#e8a020;border-left-color:#e8a020;font-weight:600}
.master-list li.inactive{opacity:.5;font-style:italic}
.master-list .item-meta{display:flex;align-items:center;gap:.35rem;flex-shrink:0}

/* Color-coded classification badges */
.cls-badge{display:inline-block;font-family:'Barlow Condensed',sans-serif;font-size:.6rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:.1rem .35rem;border-radius:3px}
.cls-billable{background:rgba(39,174,96,.18);border:1px solid #27ae60;color:#52c785}
.cls-non_billable{background:rgba(122,131,153,.18);border:1px solid #7a8399;color:#a8aebd}
.cls-sales{background:rgba(155,89,182,.18);border:1px solid #9b59b6;color:#bf83d6}
.cls-pto{background:rgba(52,152,219,.18);border:1px solid #3498db;color:#d8dde8}
.cls-holiday{background:rgba(232,160,32,.18);border:1px solid #e8a020;color:#e8a020}

.detail-pane{background:#161b27;border:1px solid #2a3045;border-radius:8px;padding:1.5rem;min-height:400px}
.detail-empty{color:#7a8399;text-align:center;padding:3rem 1rem;font-style:italic}
.detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:.5rem;flex-wrap:wrap}
.detail-header h2{margin:0;text-align:left;flex-grow:1;font-size:1.4rem;color:#d8dde8;letter-spacing:1.5px}
.detail-header .row-actions{margin:0}

.field-group{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid #2a3045}
.field-group:last-child{border-bottom:none}
.field-group label{font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase;color:#7a8399;margin-bottom:.4rem;font-weight:600;display:block}
.field-group select{width:100%;background:#1e2435;border:1px solid #2a3045;color:#d8dde8;font-family:'Barlow',sans-serif;font-size:.95rem;padding:.55rem .75rem;border-radius:5px;cursor:pointer}
.field-group select:focus{border-color:#e8a020;outline:none}

.checkbox-list{display:flex;flex-direction:column;gap:.5rem}
.checkbox-list label{display:flex;align-items:center;gap:.55rem;cursor:pointer;color:#d8dde8;font-size:.95rem;text-transform:none;letter-spacing:0;font-weight:400;padding:.4rem .6rem;border-radius:4px;transition:background .15s}
.checkbox-list label:hover{background:#1e2435}
.checkbox-list input[type=checkbox]{accent-color:#e8a020;width:16px;height:16px;cursor:pointer;margin:0}
.checkbox-list input[type=checkbox]:disabled{cursor:not-allowed}
.locked-badge{display:inline-block;font-size:.6rem;font-family:'Barlow Condensed',sans-serif;letter-spacing:1px;text-transform:uppercase;color:#e8a020;background:rgba(232,160,32,.12);padding:.05rem .35rem;border-radius:3px;margin-left:.4rem;font-weight:700}

/* Subtasks list inside detail pane */
.subtask-list{list-style:none;margin:0;padding:0}
.subtask-list li{display:flex;align-items:center;justify-content:space-between;padding:.45rem .6rem;border-radius:4px;background:#1e2435;margin-bottom:.4rem;font-size:.9rem;gap:.5rem}
.subtask-list li.inactive{opacity:.5;font-style:italic}
.subtask-list .subtask-actions{display:flex;gap:.3rem;flex-shrink:0}
.subtask-add-row{display:flex;gap:.4rem;margin-top:.6rem}
.subtask-add-row input{flex-grow:1;background:#0e1117;border:1px solid #2a3045;color:#d8dde8;padding:.45rem .6rem;border-radius:4px;font-family:'Barlow',sans-serif;font-size:.9rem}
.subtask-add-row input:focus{border-color:#e8a020;outline:none}
.subtask-add-row button{flex-shrink:0}

/* ═════════════════════════════════════════════════════════════════
   Timesheet grid (app-week.html — session 4b)
   ═════════════════════════════════════════════════════════════════ */

.ts-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.autosave-state{font-size:.8rem;color:#7a8399;font-style:italic}
.autosave-state.saving{color:#e8a020}
.autosave-state.saved{color:#27ae60}
.autosave-state.err{color:#e74c3c;font-style:normal}

.ts-grid-wrap{overflow-x:auto;background:#161b27;border:1px solid #2a3045;border-radius:8px}
.ts-grid{width:100%;border-collapse:collapse;font-size:.85rem}
.ts-grid th{background:#1e2435;color:#7a8399;font-family:'Barlow Condensed',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;text-align:left;padding:.45rem .4rem;border-bottom:1px solid #2a3045;white-space:nowrap}
.ts-grid th.day{text-align:center;width:54px;padding-left:.3rem;padding-right:.3rem}
.ts-grid th.day.weekend{color:#e8a020}
.ts-grid th.total-col{text-align:right;width:60px}
.ts-grid td{padding:.3rem .35rem;border-bottom:1px solid #2a3045;color:#d8dde8;vertical-align:middle}
.ts-grid tr:last-child td{border-bottom:none}

.ts-grid select{background:#0e1117;border:1px solid #2a3045;color:#d8dde8;padding:.3rem .45rem;border-radius:4px;font-family:'Barlow',sans-serif;font-size:.85rem;width:100%;cursor:pointer}
.ts-grid select:focus{border-color:#e8a020;outline:none}
.ts-grid input[type=number].hours-cell{background:#0e1117;border:1px solid #2a3045;color:#d8dde8;padding:.3rem .25rem;width:46px;border-radius:4px;font-family:'Barlow',sans-serif;font-size:.85rem;text-align:center;font-variant-numeric:tabular-nums}
.ts-grid input[type=number].hours-cell:focus{border-color:#e8a020;outline:none}
.ts-grid input[type=number].hours-cell.weekend{background:#1a1a26}
.ts-grid input[type=number]::-webkit-inner-spin-button,
.ts-grid input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}

.ts-grid td.row-total,.ts-grid td.day-total{text-align:right;font-variant-numeric:tabular-nums;font-weight:600;color:#e8a020}
.ts-grid tfoot td{background:#1e2435;font-family:'Barlow Condensed',sans-serif;font-size:.85rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#7a8399;border-top:2px solid #2a3045}
.ts-grid tfoot td.day-total{color:#e8a020}
.ts-grid tfoot td#grand-total-cell{color:#27ae60;font-size:1rem}

.ts-grid .icon-btn{padding:0;width:26px;height:26px;font-size:.9rem}

.ts-empty{padding:2.5rem 1.5rem;text-align:center;color:#7a8399;font-style:italic}

/* The "Project Project_number — Site" label in the projects dropdown */
.proj-cell select option{font-family:'Barlow',sans-serif}

/* ── Tabs nav (used in app-week.html) ─────────────────────── */
.tabs-nav{display:flex;gap:.25rem;margin-bottom:1rem;border-bottom:1px solid #2a3045;flex-wrap:wrap}
.tab-btn{background:transparent;border:none;color:#7a8399;font-family:'Barlow Condensed',sans-serif;font-size:.85rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:.6rem 1rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}
.tab-btn:hover{color:#d8dde8}
.tab-btn.active{color:#e8a020;border-bottom-color:#e8a020}
.section-h3{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#e8a020;margin:1.5rem 0 .75rem 0}
.section-h3:first-of-type{margin-top:0}

/* ── Submission status panel (top of week editor) ────────── */
.submission-status{display:flex;align-items:center;gap:1rem;background:#161b27;border:1px solid #2a3045;border-left:3px solid #e8a020;border-radius:8px;padding:.75rem 1.25rem;margin-bottom:1.25rem;flex-wrap:wrap}
.submission-status .status-text{flex-grow:1;color:#7a8399;font-size:.85rem;line-height:1.5}
.submission-status .status-text strong{color:#d8dde8}
.submission-status .status-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.submission-status.is-draft     {border-left-color:#7a8399}
.submission-status.is-submitted {border-left-color:#3498db}
.submission-status.is-approved  {border-left-color:#27ae60}
.submission-status.is-rejected  {border-left-color:#e74c3c}

/* When the week is locked (status ≠ draft / recalled), gray out
   entry inputs to indicate read-only. Status-panel buttons are
   excluded so the user can still recall or sign out. */
body[data-editable="false"] section[data-tab] input,
body[data-editable="false"] section[data-tab] select{
  pointer-events:none;opacity:.55;cursor:not-allowed;background:#1a1a26 !important
}
body[data-editable="false"] section[data-tab] .btn-primary,
body[data-editable="false"] section[data-tab] .icon-btn{
  opacity:.4;pointer-events:none;cursor:not-allowed
}
body[data-editable="false"] section[data-tab] input[type=checkbox]{
  background:transparent !important
}

/* Validation errors on submit */
.validation-list{list-style:disc;padding-left:1.25rem;color:#e74c3c;font-size:.85rem;margin-top:.5rem;line-height:1.6}

/* ── Modal overlay (used by approval review modal) ──────── */
.modal-overlay{position:fixed;inset:0;background:rgba(14,17,23,.85);z-index:2000;display:none;align-items:flex-start;justify-content:center;padding:3rem 1rem;overflow-y:auto}
.modal-overlay.open{display:flex}
.modal-card{background:#161b27;border:1px solid #2a3045;border-top:3px solid #e8a020;border-radius:10px;padding:1.5rem 2rem;width:100%;max-width:720px;max-height:calc(100vh - 6rem);overflow-y:auto}
.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}
.modal-header h2{margin:0;text-align:left;color:#d8dde8;font-size:1.5rem;letter-spacing:1.5px}
.modal-header .modal-close{background:transparent;border:none;color:#7a8399;font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;line-height:1}
.modal-header .modal-close:hover{color:#e8a020}
.modal-card h3.section-h3{margin-top:1.25rem}
.modal-card .summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1.5rem;font-size:.9rem;color:#d8dde8}
.modal-card .summary-grid .label{color:#7a8399}
.modal-card textarea{width:100%;background:#0e1117;border:1px solid #2a3045;color:#d8dde8;padding:.6rem .75rem;border-radius:6px;font-family:'Barlow',sans-serif;font-size:.9rem;resize:vertical;min-height:80px;line-height:1.5}
.modal-card textarea:focus{border-color:#e8a020;outline:none}
.modal-actions{display:flex;gap:.5rem;margin-top:1.25rem;flex-wrap:wrap;justify-content:flex-end}
.modal-actions .btn-primary{padding:.55rem 1.1rem}
.btn-success{background:#27ae60;border:none;border-radius:6px;color:#000;font-family:'Barlow Condensed',sans-serif;font-size:.95rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:.55rem 1.1rem;cursor:pointer;transition:background .2s}
.btn-success:hover{background:#3ec47a}
.btn-warn{background:#16a8b3;border:none;border-radius:6px;color:#000;font-family:'Barlow Condensed',sans-serif;font-size:.95rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:.55rem 1.1rem;cursor:pointer;transition:background .2s}
.btn-warn:hover{background:#22c2cf}
.btn-danger{background:#e74c3c;border:none;border-radius:6px;color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:.95rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:.55rem 1.1rem;cursor:pointer;transition:background .2s}
.btn-danger:hover{background:#ec6253}

/* Approval queue list (clickable rows) */
.approval-list tr.clickable{cursor:pointer}
.approval-list tr.clickable:hover td{background:#1a1f2e}

/* ── Budget grid editor ─────────────────────────────────── */
.bud-grid{width:100%;border-collapse:collapse;font-size:.85rem;min-width:1100px}
.bud-grid th{background:#1e2435;color:#7a8399;font-family:'Barlow Condensed',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;text-align:left;padding:.55rem .55rem;border-bottom:1px solid #2a3045;white-space:nowrap;position:sticky;top:0;z-index:5}
.bud-grid th.month{text-align:right;width:90px}
.bud-grid th.total-col{text-align:right;width:100px}
.bud-grid td{padding:.35rem .4rem;border-bottom:1px solid #2a3045;color:#d8dde8;vertical-align:middle}
.bud-grid tr:last-child td{border-bottom:none}
.bud-grid select{background:#0e1117;border:1px solid #2a3045;color:#d8dde8;padding:.3rem .45rem;border-radius:4px;font-family:'Barlow',sans-serif;font-size:.85rem;width:100%;cursor:pointer}
.bud-grid select:focus{border-color:#e8a020;outline:none}
.bud-grid input[type=number]{background:#0e1117;border:1px solid #2a3045;color:#d8dde8;padding:.3rem .35rem;width:80px;border-radius:4px;font-family:'Barlow',sans-serif;font-size:.85rem;text-align:right;font-variant-numeric:tabular-nums}
.bud-grid input[type=number]:focus{border-color:#e8a020;outline:none}
.bud-grid input[type=number]::-webkit-inner-spin-button,
.bud-grid input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.bud-grid td.row-total,.bud-grid td.month-total{text-align:right;font-variant-numeric:tabular-nums;font-weight:600;color:#e8a020}
.bud-grid tfoot td{background:#1e2435;font-family:'Barlow Condensed',sans-serif;font-size:.85rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#7a8399;border-top:2px solid #2a3045}
.bud-grid tfoot td.month-total{color:#e8a020}
.bud-grid tfoot td.grand-total{color:#27ae60;font-size:1rem}
.bud-grid .icon-btn{padding:0;width:26px;height:26px;font-size:.9rem}
.bud-grid-wrap{overflow-x:auto;background:#161b27;border:1px solid #2a3045;border-radius:8px}

/* Rate-input cells in the labor rates sub-table */
.rate-table{width:100%;border-collapse:collapse;font-size:.85rem}
.rate-table th{text-align:left;color:#7a8399;font-family:'Barlow Condensed',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:.5rem .55rem;border-bottom:1px solid #2a3045;background:#1e2435}
.rate-table th.num{text-align:right}
.rate-table td{padding:.35rem .4rem;border-bottom:1px solid #2a3045;color:#d8dde8}
.rate-table td.skill-name{color:#d8dde8;font-size:.85rem;padding-left:.6rem}
.rate-table td.num{text-align:right}
.rate-table input[type=number]{background:#0e1117;border:1px solid #2a3045;color:#d8dde8;padding:.3rem .45rem;width:100px;border-radius:4px;font-family:'Barlow',sans-serif;font-size:.85rem;text-align:right;font-variant-numeric:tabular-nums}
.rate-table input[type=number]:focus{border-color:#e8a020;outline:none}
.rate-table input[type=number]::-webkit-inner-spin-button,
.rate-table input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.rate-table tr:last-child td{border-bottom:none}

/* Compact "rate sheet" layout — wider detail pane than tasks since
   the labor rates table is wide. */
.rate-master-detail{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;align-items:start}
@media (max-width:1100px){.rate-master-detail{grid-template-columns:1fr}}

.field-row{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1rem}
.field-row .field-group{flex:1;margin-bottom:0;padding-bottom:0;border-bottom:none}
.field-group input[type=text],.field-group input[type=number]{background:#1e2435;border:1px solid #2a3045;color:#d8dde8;font-family:'Barlow',sans-serif;font-size:.95rem;padding:.55rem .75rem;border-radius:5px;width:100%}
.field-group input:focus{border-color:#e8a020;outline:none}
