/* F4CAST v3 -- Briegan Editorial Design */
:root{
  --paper:      #f3efe7;
  --paper-2:    #ece7dc;
  --paper-3:    #e2ddd0;
  --paper-4:    #d6d1c3;
  --ink-0:      #1a1816;
  --ink-1:      #2e2a25;
  --ink-2:      #6c6660;
  --ink-3:      #9a948c;
  --ink-4:      #bdb7ad;

  --line-1: rgba(26,24,22,0.08);
  --line-2: rgba(26,24,22,0.14);
  --line-3: rgba(26,24,22,0.28);

  --accent:    #b8532a;
  --accent-hi: #c76237;
  --accent-wash: #f1e5da;
  --accent-ink:  #5b2312;

  --ok:   #607a4e;
  --warn: #b8852f;
  --bad:  #a7463a;

  --serif:   "Fraunces", "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --sans:    "Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --display: var(--serif);
}

*{box-sizing:border-box; margin:0; padding:0}
html,body{height:100%}
body{
  background:var(--paper);
  color:var(--ink-1);
  font-family:var(--sans);
  font-size:14px;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","ss02","cv11";
}
::selection{background:var(--accent); color:var(--paper)}

*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--paper-4); border-radius:8px}
*::-webkit-scrollbar-track{background:transparent}

.mono{font-family:var(--mono); font-variant-numeric:tabular-nums; letter-spacing:0}
.num{font-family:var(--mono); font-variant-numeric:tabular-nums; text-align:right}
.lbl{
  font-family:var(--sans);
  font-size:10.5px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-2);
  font-weight:600;
}
.display{
  font-family:var(--display);
  font-weight:400;
  letter-spacing:-0.01em;
  font-variant-numeric:tabular-nums;
}

/* ---- App Shell ---- */
#app{
  display:none;
  min-height:100vh;
  flex-direction:column;
}

/* ---- Lock Screen ---- */
#lock-screen{
  min-height:100vh;
  display:flex;
  place-items:center;
  justify-content:center;
  padding:40px 18px;
  position:relative;
  background:var(--paper);
}
#lock-screen.hidden{ display:none }

.lock-topbar{
  position:absolute; top:28px; left:36px; right:36px;
  display:flex; justify-content:space-between; align-items:center;
}
.lock-topbar .brand-text{
  font-family:var(--serif); font-size:18px; color:var(--ink-0); letter-spacing:.02em;
}
.lock-topbar .brand-text .amp{
  font-style:italic; color:var(--ink-2); font-weight:400;
}
.lock-topbar .date-text{
  font-family:var(--sans); font-size:11.5px; color:var(--ink-2);
  letter-spacing:.06em; text-transform:uppercase; font-weight:500;
}

.lock-card{
  width:min(480px, 100%);
  background:transparent;
  border:0;
  padding:48px 8px;
}
.lock-card .eyebrow{
  font-size:11px; color:var(--accent); letter-spacing:.18em; text-transform:uppercase;
  font-weight:600; margin-bottom:18px; font-family:var(--sans);
}
.lock-card h1{
  font-family:var(--serif); font-size:64px; font-weight:400;
  letter-spacing:-0.035em; color:var(--ink-0);
  line-height:0.95; margin:0;
}
.lock-card .subtitle{
  font-family:var(--serif); font-size:22px; font-weight:400;
  color:var(--ink-2); font-style:italic;
  letter-spacing:-0.01em; margin:14px 0 40px; line-height:1.35;
}

.lock-form{
  display:flex; flex-direction:column; gap:14px;
}
.lock-form .form-label{
  display:block; margin-bottom:6px; font-size:10.5px;
}
.lock-form .input-wrap{
  position:relative;
}
.lock-form input[type="text"],
.lock-form input[type="password"]{
  background:var(--paper);
  border:0; border-bottom:1.5px solid var(--line-3);
  color:var(--ink-0);
  font-family:var(--serif); font-weight:400; font-size:22px;
  padding:14px 110px 14px 2px;
  width:100%; outline:0;
  letter-spacing:.02em; border-radius:0;
}
.lock-form input:focus{
  border-color:var(--accent);
}
.lock-form input::placeholder{
  color:var(--ink-3); font-style:italic;
}
.lock-form input.error{
  border-color:var(--bad);
}
.lock-form input.success{
  border-color:var(--ok);
}

.lock-form .submit-btn{
  position:absolute; right:0; top:50%; transform:translateY(-50%);
  display:inline-flex; align-items:center; gap:8px;
  background:var(--ink-0); color:var(--paper); border:1px solid var(--ink-0);
  font-family:var(--sans); font-size:12px; font-weight:500;
  padding:10px 16px; cursor:pointer; border-radius:1px;
  letter-spacing:0.02em;
  transition:all .14s;
}
.lock-form .submit-btn:hover{
  background:var(--accent); border-color:var(--accent);
}

.lock-form .form-footer{
  margin-top:18px; display:flex; justify-content:space-between; align-items:center;
  font-family:var(--sans); font-size:12px; color:var(--ink-2); font-weight:500;
}
.lock-form .form-footer a{
  color:var(--ink-2); text-decoration:none; border-bottom:1px solid var(--line-2);
}

.lock-stats{
  margin-top:72px; padding-top:26px; border-top:1px solid var(--line-1);
  display:flex; gap:36px; flex-wrap:wrap;
  font-family:var(--sans); font-size:12px; color:var(--ink-2); font-weight:500;
}
.lock-stats .stat-label{
  font-size:10px; margin-bottom:5px;
}
.lock-stats .stat-value{
  font-family:var(--serif); font-size:22px; color:var(--ink-0); font-weight:400;
  letter-spacing:-0.02em;
}

.lock-error{
  color:var(--bad); font-size:12px; font-family:var(--sans);
  text-align:center; min-height:20px;
}

.lock-bottom{
  position:absolute; bottom:24px; left:36px; right:36px;
  display:flex; justify-content:space-between;
  font-family:var(--sans); font-size:11px; color:var(--ink-3); font-weight:500;
}
.lock-bottom .tagline{
  font-style:italic; font-family:var(--serif); font-size:13px;
}

/* ---- Topbar ---- */
.topbar{
  display:grid;
  grid-template-columns: auto 1fr auto;
  gap:28px; align-items:center;
  padding:22px 36px 18px;
  background:var(--paper);
  border-bottom:1px solid var(--line-1);
  position:sticky; top:0; z-index:10;
}
.brand{display:flex; align-items:center; gap:14px}
.brand-name{
  font-family:var(--serif); font-weight:400; letter-spacing:0.02em;
  font-size:22px; color:var(--ink-0); line-height:1;
}
.brand-name .amp{
  font-style:italic; color:var(--ink-2); font-weight:400;
}
.brand-sub{
  font-family:var(--sans); font-size:10.5px; color:var(--ink-2);
  letter-spacing:0.14em; text-transform:uppercase; margin-top:4px; font-weight:500;
}

.tabs{display:flex; align-self:stretch; gap:4px; justify-content:center}
.tab{
  position:relative;
  padding:8px 14px;
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--sans); font-size:13px; font-weight:500;
  letter-spacing:0.01em; text-transform:none;
  color:var(--ink-2);
  cursor:pointer; background:transparent; border:0;
  transition:color .15s;
}
.tab:hover{color:var(--ink-0)}
.tab.active{color:var(--ink-0)}
.tab.active::after{
  content:""; position:absolute; left:14px; right:14px; bottom:-1px;
  height:1.5px; background:var(--accent);
}

.sysstat{
  display:flex; align-items:center; gap:18px;
  font-family:var(--sans); font-size:11.5px; color:var(--ink-2);
  letter-spacing:0; text-transform:none; font-weight:500;
}
.sysstat .seg{display:flex; gap:7px; align-items:center}
.sysstat .v{color:var(--ink-0)}
.sysstat .v.mono{font-family:var(--mono); font-size:11.5px}
.sysstat .divider{
  width:1px; height:16px; background:var(--line-2);
}
.sysstat .avatar{
  width:28px; height:28px; border-radius:50%;
  background:var(--ink-0); color:var(--paper);
  display:grid; place-items:center;
  font-family:var(--serif); font-size:12px; font-weight:500;
}
.sysstat .signout-btn{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--paper); border:1px solid var(--line-2); border-radius:1px;
  color:var(--ink-0); font-family:var(--sans); font-size:11.5px; font-weight:500;
  padding:6px 10px; cursor:pointer; transition:all .14s;
}
.sysstat .signout-btn:hover{
  border-color:var(--ink-0); background:var(--paper-2);
}

/* ---- Content ---- */
.content{flex:1}
.page{display:none; padding:40px 56px 64px; flex-direction:column; gap:32px; max-width:1500px; margin:0 auto;}
.page.active{display:flex}

@media (max-width:900px){ .page{padding:28px 28px 48px; gap:24px} }
@media (max-width:640px){ .page{padding:20px 16px 64px; gap:20px} }

/* ---- Page Header ---- */
.pagehead{
  display:flex; align-items:flex-end; justify-content:space-between; gap:32px; flex-wrap:wrap;
  padding:8px 0 24px;
  border-bottom:1px solid var(--line-2);
}
.pagehead h2{
  margin:0;
  font-family:var(--serif);
  font-size:54px; font-weight:400; letter-spacing:-0.025em;
  color:var(--ink-0); line-height:1;
}
@media (max-width:640px){ .pagehead h2{font-size:36px} }
.eyebrow{
  font-size:11px; color:var(--accent); letter-spacing:.18em; text-transform:uppercase;
  font-weight:600; margin-bottom:10px; font-family:var(--sans);
}
.pagehead-meta{
  display:flex; gap:22px; flex-wrap:wrap;
}
.pagehead-meta .meta-item{
  display:flex; flex-direction:column; gap:4px;
}
.pagehead-meta .meta-item .lbl{
  font-size:10.5px;
}
.pagehead-meta .meta-item .mono{
  color:var(--ink-0); font-size:13px;
}

/* ---- KPI Grid ---- */
.kpi-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:0;
  border-top:1px solid var(--line-2);
  border-bottom:1px solid var(--line-2);
}
@media (max-width:900px){ .kpi-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:520px){ .kpi-grid{grid-template-columns:1fr} }

.kpi{
  position:relative; background:transparent; border:0;
  border-right:1px solid var(--line-1);
  padding:24px 28px 22px; overflow:hidden;
}
.kpi:last-child{ border-right:0 }
.kpi-k{
  font-family:var(--sans); font-size:10.5px; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--ink-2); font-weight:600;
}
.kpi-v{
  font-family:var(--serif); font-weight:400; color:var(--ink-0);
  font-size:56px; line-height:1; margin-top:14px;
  letter-spacing:-0.02em; font-variant-numeric:tabular-nums;
}
.kpi-d{
  margin-top:12px;
  font-family:var(--sans); font-size:11.5px; color:var(--ink-2);
  letter-spacing:0; text-transform:none; font-weight:500;
}

/* ---- Panels ---- */
.panel{
  background:var(--paper); border:1px solid var(--line-1);
  border-radius:2px; position:relative;
}
.panel-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 20px; border-bottom:1px solid var(--line-1); background:transparent;
}
.panel-title{
  font-family:var(--sans); font-size:11.5px; font-weight:600;
  letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-1);
}
.panel-meta{
  font-family:var(--sans); font-size:11px; color:var(--ink-3);
  letter-spacing:0.1em; text-transform:uppercase; font-weight:500;
}
.panel-body{padding:20px}

/* ---- Tables ---- */
.tbl{width:100%; border-collapse:collapse; font-size:13.5px}
.tbl thead th{
  font-family:var(--sans); font-weight:600;
  font-size:10.5px; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--ink-2); text-align:left;
  padding:14px 18px; border-bottom:1px solid var(--line-2);
  background:transparent; cursor:pointer;
}
.tbl tbody td{
  padding:16px 18px; border-bottom:1px solid var(--line-1);
  color:var(--ink-1); font-family:var(--mono); font-size:12.5px;
  font-variant-numeric:tabular-nums;
}
.tbl tbody tr:hover td{ background:var(--paper-2) }
.tbl td.lbl-cell{
  font-family:var(--serif); color:var(--ink-0); font-weight:400;
  letter-spacing:0; font-size:16px; text-transform:none;
}
.tbl .num, .tbl td.num{text-align:right}
.v-pos{color:var(--ok)} .v-neg{color:var(--bad)} .v-flat{color:var(--ink-3)}
.tbl tfoot td{
  background:var(--paper-2) !important;
  border-top:1.5px solid var(--ink-0) !important;
  color:var(--ink-0) !important;
}
.tbl tfoot td.lbl-cell{
  font-family:var(--sans) !important; font-weight:700 !important;
  font-size:11px !important; letter-spacing:.14em !important; text-transform:uppercase !important;
}

/* ---- Job Cards ---- */
.job-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(340px, 1fr)); gap:14px;
}
.jobcard{
  position:relative; background:var(--paper);
  border:1px solid var(--line-1); border-radius:2px;
  padding:22px 24px 20px 26px;
  transition:border-color .15s, transform .15s;
  cursor:pointer; overflow:hidden;
}
.jobcard:hover{
  border-color:var(--ink-0); transform:translateY(-1px);
}

.health-edge{
  position:absolute; left:0; top:0; bottom:0; width:2px;
}
.health-edge.ok  { background:var(--ok) }
.health-edge.warn{ background:var(--warn) }
.health-edge.bad { background:var(--bad) }

.jobcard .job-no{
  font-family:var(--mono); font-size:10px; color:var(--ink-3); letter-spacing:.14em;
}
.jobcard .job-status{
  font-size:9px; letter-spacing:.14em; text-transform:uppercase; font-weight:600;
}
.jobcard .job-name-text{
  margin:6px 0 4px;
  font-family:var(--serif); font-weight:500; font-size:20px;
  color:var(--ink-0); letter-spacing:0; line-height:1.1;
}
.jobcard .job-meta{
  display:flex; gap:8px; align-items:center;
  font-size:11px; color:var(--ink-2); font-family:var(--mono); letter-spacing:.06em;
}
.jobcard .dot-sep{
  width:3px; height:3px; background:var(--ink-3); border-radius:50%;
}
.jobcard .metric-grid{
  display:grid; grid-template-columns:1fr 1fr 1fr; gap:0;
  margin-top:14px; border:1px solid var(--line-1); background:var(--paper-2);
}
.jobcard .metric-cell{
  padding:10px 12px;
}
.jobcard .metric-cell + .metric-cell{
  border-left:1px solid var(--line-1);
}
.jobcard .metric-cell .lbl{font-size:9px}
.jobcard .metric-cell .val{
  font-family:var(--serif); font-size:20px; font-weight:500;
  margin-top:4px; font-variant-numeric:tabular-nums;
}

.jobcard .completion-row{margin-top:14px}
.jobcard .completion-row .top-line{
  display:flex; justify-content:space-between; align-items:baseline; margin-bottom:6px;
}
.jobcard .pct-num{
  font-family:var(--serif); font-size:18px; color:var(--ink-0);
}
.jobcard .pct-sign{color:var(--ink-3)}

.bar{
  position:relative; height:3px; background:var(--paper-4);
  border:0; border-radius:2px; overflow:hidden;
}
.bar > span{
  position:absolute; left:0; top:0; bottom:0;
  background:var(--accent);
}
.bar.thin{height:2px}

.jobcard .pm-row{
  display:flex; justify-content:space-between; align-items:center; margin-top:10px;
}
.jobcard .pm-avatar{
  font-family:var(--mono); font-size:10px; width:26px; height:26px;
  display:grid; place-items:center;
  background:var(--paper-3); border:1px solid var(--line-3);
  color:var(--ink-0); letter-spacing:.04em;
}
.jobcard .pm-name{
  font-size:11px; color:var(--ink-2); font-family:var(--mono); letter-spacing:.06em;
}

/* ---- Gauge/Dial ---- */
.gauge{position:relative}
.gauge svg{width:100%; height:100%; display:block}
.gauge .read{
  position:absolute; inset:0; display:grid; place-items:center;
  font-family:var(--serif); font-weight:400; color:var(--ink-0);
  letter-spacing:-0.02em; line-height:1; font-variant-numeric:tabular-nums;
}

/* ---- Chipbar / Filter ---- */
.chipbar{display:flex; gap:8px; flex-wrap:wrap; align-items:center}
.chipbar .lbl{margin-right:6px; align-self:center}

/* ---- Buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--paper); border:1px solid var(--line-2); border-radius:1px;
  color:var(--ink-0); font-family:var(--sans); font-size:12px; font-weight:500;
  letter-spacing:0.02em; text-transform:none;
  padding:9px 14px; cursor:pointer; transition:all .14s;
}
.btn:hover{border-color:var(--ink-0); background:var(--paper-2)}
.btn.primary{
  background:var(--ink-0); color:var(--paper); border-color:var(--ink-0);
}
.btn.primary:hover{background:var(--accent); border-color:var(--accent); color:var(--paper)}

.chip-btn{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--paper); border:1px solid var(--line-2); border-radius:1px;
  color:var(--ink-2); font-family:var(--sans); font-size:10px; font-weight:500;
  padding:6px 10px; cursor:pointer; transition:all .14s; white-space:nowrap;
}
.chip-btn:hover{border-color:var(--ink-0); color:var(--ink-0)}
.chip-btn.active{
  background:var(--paper-2); border-color:var(--accent); color:var(--ink-0);
}
.chip-btn .health-dot{
  width:6px; height:6px; display:inline-block;
}

/* ---- Health legend ---- */
.health-legend{
  display:flex; gap:14px; align-items:center;
  font-family:var(--mono); font-size:10px; color:var(--ink-2);
  letter-spacing:.12em; text-transform:uppercase;
}
.health-legend .swatch{
  display:inline-block; width:10px; height:3px; margin-right:6px;
}

/* ---- Summary stat cards (Job Detail) ---- */
.stat-card{
  position:relative; background:var(--paper);
  border:1px solid var(--line-1); padding:16px 18px;
}
.stat-card.accent{
  background:var(--accent-wash); border-color:var(--accent);
}
.stat-card .lbl{font-size:10px}
.stat-card .big-val{
  font-family:var(--serif); font-size:36px; font-weight:400;
  color:var(--ink-0); margin-top:8px; line-height:1;
  font-variant-numeric:tabular-nums; letter-spacing:-0.02em;
}
.stat-card.accent .big-val{color:var(--accent)}
.stat-card .sub{
  font-family:var(--mono); font-size:10px; color:var(--ink-2);
  letter-spacing:.12em; text-transform:uppercase; margin-top:8px;
}

/* ---- Tile (cash/billing blocks) ---- */
.tile{
  background:var(--paper-2); border:1px solid var(--line-1); padding:10px 12px;
}
.tile .lbl{font-size:9px}
.tile .tile-val{
  font-family:var(--serif); font-size:18px; color:var(--ink-0);
  margin-top:3px; font-variant-numeric:tabular-nums;
}

/* ---- Timeline ---- */
.tl{position:relative; padding-left:20px}
.tl::before{
  content:""; position:absolute; left:5px; top:8px; bottom:8px;
  width:1px; background:var(--line-2);
}
.tl-item{position:relative; padding:14px 0; border-bottom:1px solid var(--line-1)}
.tl-item:last-child{border-bottom:0}
.tl-item::before{
  content:""; position:absolute; left:-19px; top:20px;
  width:9px; height:9px; border-radius:50%;
  background:var(--paper); border:1.5px solid var(--ink-0);
}

/* ---- Pill ---- */
.pill{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--sans); font-size:10.5px; letter-spacing:.08em;
  text-transform:uppercase; padding:3px 8px;
  border:1px solid var(--line-2); color:var(--ink-1);
  background:var(--paper-2); border-radius:1px; font-weight:600;
}
.pill.ok   { color:var(--ok);   border-color:color-mix(in oklab, var(--ok),   var(--paper) 65%); background:color-mix(in oklab, var(--ok), var(--paper) 90%) }
.pill.warn { color:var(--warn); border-color:color-mix(in oklab, var(--warn), var(--paper) 65%); background:color-mix(in oklab, var(--warn), var(--paper) 90%) }
.pill.bad  { color:var(--bad);  border-color:color-mix(in oklab, var(--bad),  var(--paper) 65%); background:color-mix(in oklab, var(--bad), var(--paper) 90%) }

/* ---- Form fields (Monthly Entry) ---- */
.form-grid-2{
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
}
.field{display:flex; flex-direction:column; gap:8px}
.field .ipt{
  display:flex; align-items:center;
  background:var(--paper); border:0; border-bottom:1px solid var(--line-2);
  padding:10px 2px; transition:border-color .12s; border-radius:0;
}
.field .ipt:focus-within{border-color:var(--accent)}
.field .ipt input{
  flex:1; background:transparent; border:0; outline:0;
  font-family:var(--mono); font-size:15px; color:var(--ink-0);
  text-align:right;
}
.field .prefix{color:var(--ink-3); margin-right:6px; font-family:var(--mono); font-size:13px}
.field .suffix{color:var(--ink-3); margin-left:6px; font-family:var(--mono); font-size:12px}
.field.calc .ipt{border-bottom-color:var(--accent)}
.field.calc .ipt input{color:var(--accent); font-family:var(--serif); font-size:18px}
.field .tag-auto{
  display:inline-flex; align-items:center; gap:5px;
  font-family:var(--sans); font-size:9.5px; color:var(--accent);
  letter-spacing:.14em; text-transform:uppercase; font-weight:600;
}
.field .tag-auto::before{content:""; width:4px; height:4px; background:var(--accent); border-radius:50%}

/* ---- GP Block ---- */
.gp-block{
  padding:16px 18px;
}
.gp-block.border-l{border-left:1px solid var(--line-2)}
.gp-block.accent{background:var(--accent-wash)}
.gp-block .lbl{font-size:9px}
.gp-block .gp-val{
  font-family:var(--serif); font-size:26px; margin-top:4px;
  color:var(--ink-0); font-variant-numeric:tabular-nums;
}
.gp-block.accent .gp-val{color:var(--accent)}
.gp-block .gp-sub{
  font-family:var(--mono); font-size:10px; color:var(--ink-3);
  letter-spacing:.12em; margin-top:3px; text-transform:uppercase;
}

/* ---- Scenario cards (Forecast) ---- */
.scn{
  position:relative; background:var(--paper);
  border:1px solid var(--line-1); border-radius:2px;
  padding:26px 26px 22px;
}
.scn::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:2px;
}
.scn.opt::before{background:var(--ok)}
.scn.lik::before{background:var(--accent)}
.scn.pes::before{background:var(--bad)}

/* ---- Sticky submit bar (Entry) ---- */
.submit-bar{
  position:sticky; bottom:30px;
  display:flex; align-items:center; gap:12px;
  padding:12px 16px;
  background:var(--paper); border:1px solid var(--line-3);
  box-shadow:0 -6px 20px -10px rgba(0,0,0,.08);
}

/* ---- Footer ---- */
.footer-strip{
  border-top:1px solid var(--line-1);
  padding:14px 36px;
  display:flex; justify-content:space-between; align-items:center; gap:14px;
  font-family:var(--sans); font-size:11px; color:var(--ink-3);
  letter-spacing:0; text-transform:none;
  background:var(--paper);
  position:sticky; bottom:0; z-index:5; font-weight:500;
}
.footer-strip span{display:flex; align-items:center; gap:8px}

/* ---- Animations ---- */
@keyframes fade{from{opacity:0; transform:translateY(4px)} to{opacity:1; transform:none}}
.fade{animation:fade .35s ease-out both}
@keyframes blink{50%{opacity:.35}}
.blink{animation:blink 1s steps(1) infinite}

/* ---- Toast ---- */
.toast{
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%);
  background:var(--ink-0); color:var(--paper);
  padding:14px 28px; border-radius:2px;
  font-family:var(--sans); font-weight:500; font-size:13px;
  z-index:1000; animation:fade .3s ease;
  box-shadow:0 8px 32px rgba(0,0,0,.15);
}

/* ---- Modal ---- */
.modal-overlay{
  display:none; position:fixed; top:0; left:0; right:0; bottom:0;
  background:rgba(26,24,22,.5); z-index:200;
  align-items:center; justify-content:center;
}
.modal-overlay.active{display:flex}
.modal{
  background:var(--paper); border:1px solid var(--line-2);
  border-radius:2px; padding:28px; width:90%; max-width:500px;
  max-height:80vh; overflow-y:auto;
  box-shadow:0 24px 64px rgba(0,0,0,.15);
}
.modal h2{
  margin-bottom:18px; font-family:var(--serif); font-size:24px;
  font-weight:400; color:var(--ink-0);
}
.modal .form-group{display:flex; flex-direction:column; gap:6px; margin-bottom:14px}
.modal .form-group label{font-size:10.5px}
.modal .form-group input{
  background:var(--paper); border:0; border-bottom:1px solid var(--line-2);
  padding:10px 2px; font-family:var(--sans); font-size:15px; color:var(--ink-0);
  outline:0; border-radius:0;
}
.modal .form-group input:focus{border-color:var(--accent)}
.modal .btn-row{display:flex; gap:12px; margin-top:20px}

/* ---- Responsive ---- */
@media (max-width:720px){
  .footer-strip > span:nth-child(2){display:none}
  .sysstat{display:none}
  .brand-sub{display:none}
  .tabs{overflow-x:auto; justify-content:flex-start}
  .kpi-v{font-size:38px}
  .topbar{padding:16px 18px; grid-template-columns:1fr; gap:12px}
}

/* ---- Range input ---- */
input[type="range"]{accent-color:var(--accent)}

/* ---- Editable table cell ---- */
.edit-cell{
  width:100%; background:transparent; border:0; outline:0;
  padding:12px 14px; text-align:right;
  font-family:var(--mono); color:var(--ink-0); font-size:13px; font-weight:600;
  border-bottom:1px dashed var(--accent);
}

/* ---- Cost table styling for entry page ---- */
.cost-table{
  width:100%; border-collapse:collapse; font-size:13px;
}
.cost-table th{
  font-family:var(--sans); font-weight:600;
  font-size:10.5px; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--ink-2); text-align:left;
  padding:14px 18px; border-bottom:1px solid var(--line-2);
}
.cost-table th.right, .cost-table td.right{text-align:right}
.cost-table td{
  padding:10px 12px; border-bottom:1px solid var(--line-1);
  color:var(--ink-1); font-family:var(--mono); font-size:12.5px;
}
.cost-table input{
  background:var(--paper); border:0; border-bottom:1px solid var(--line-2);
  padding:8px 4px; color:var(--ink-0); font-family:var(--mono); font-size:13px;
  width:100%; text-align:right; outline:0; border-radius:0;
}
.cost-table input:focus{border-color:var(--accent)}
.cost-table tr.total-row td{
  font-weight:700; border-top:1.5px solid var(--ink-0);
  color:var(--ink-0); background:var(--paper-2);
  font-family:var(--mono);
}
.cost-table .variance-positive{color:var(--ok)}
.cost-table .variance-negative{color:var(--bad)}

/* Entry page selects */
.entry-select{
  background:var(--paper); border:1px solid var(--line-2);
  color:var(--ink-0); padding:8px 12px; border-radius:1px;
  font-family:var(--sans); font-size:13px; outline:0;
}
.entry-select:focus{border-color:var(--accent)}

/* Card style for entry page */
.card{
  background:var(--paper); border:1px solid var(--line-1);
  border-radius:2px; padding:22px; margin-bottom:16px;
}
.card-title{
  font-family:var(--sans); font-size:11.5px; font-weight:600;
  letter-spacing:0.14em; text-transform:uppercase;
  color:var(--ink-1); margin-bottom:14px;
}

.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.form-grid.three-col{grid-template-columns:1fr 1fr 1fr}
.form-group{display:flex; flex-direction:column; gap:4px}
.form-group.full-width{grid-column:1 / -1}
.form-group label{
  font-family:var(--sans); font-size:10.5px; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--ink-2); font-weight:600;
}
.form-group input, .form-group select, .form-group textarea{
  background:var(--paper); border:0; border-bottom:1px solid var(--line-2);
  padding:10px 2px; color:var(--ink-0); font-family:var(--mono); font-size:14px;
  outline:0; border-radius:0;
}
.form-group input:focus, .form-group select:focus{border-color:var(--accent)}
.form-group textarea{
  resize:vertical; min-height:60px; border:1px solid var(--line-2);
  padding:10px; font-family:var(--sans); border-radius:2px;
}
.form-group .calc-field{
  color:var(--accent); font-family:var(--serif); font-size:16px;
  border-bottom-color:var(--accent);
}

.btn-row{display:flex; gap:12px; margin-top:16px}

/* Empty state */
.empty-state{
  text-align:center; padding:60px 20px; color:var(--ink-2);
}
.empty-state h3{
  font-family:var(--serif); font-size:24px; margin-bottom:8px;
  color:var(--ink-0); font-weight:400;
}

/* Section header */
.section-header{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:16px;
}
.section-header h2{
  font-family:var(--serif); font-size:28px; font-weight:400;
  color:var(--ink-0);
}

/* Summary row (used in dashboard) */
.summary-row{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(200px, 1fr)); gap:16px;
  margin-bottom:24px;
}
.summary-item{
  background:var(--paper); border:1px solid var(--line-1);
  border-radius:2px; padding:20px; text-align:center;
}
.summary-item .value{
  font-family:var(--serif); font-size:32px; font-weight:400;
  color:var(--ink-0); letter-spacing:-0.02em; font-variant-numeric:tabular-nums;
}
.summary-item .label{
  font-family:var(--sans); font-size:10.5px; color:var(--ink-2);
  text-transform:uppercase; letter-spacing:0.14em; margin-top:6px; font-weight:600;
}

@media (max-width:768px){
  .form-grid{grid-template-columns:1fr}
  .form-grid.three-col{grid-template-columns:1fr 1fr}
  .job-grid{grid-template-columns:1fr}
  .summary-row{grid-template-columns:1fr 1fr}
}
@media (max-width:480px){
  .form-grid.three-col{grid-template-columns:1fr}
  .summary-row{grid-template-columns:1fr}
}
