/* ————————————————————————————— Payroll · editorial ledger ————————————————————————————— */

:root{
  --paper:#F6F4EF;
  --card:#FCFBF8;
  --ink:#17150F;
  --muted:#8A8577;
  --faint:#B4AE9E;
  --line:#E4E0D5;
  --line-soft:#EDEAE1;
  --green:#175E43;
  --green-deep:#0E4531;
  --red:#B3261E;
  --amber:#96690C;
  --gold:#C9A227;
  --serif:"Iowan Old Style","Palatino",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"SF Pro Text","Helvetica Neue",Arial,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:14px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
button{font:inherit;color:inherit}
input,select{font:inherit;color:inherit}
[hidden]{display:none!important}

/* ——— top bar ——— */
.topbar{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 28px;
  background:var(--paper);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:baseline;gap:12px;min-width:0}
.wordmark{
  font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:26px;letter-spacing:-.02em;
}
.brand-sub{
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
  white-space:nowrap;
}
.top-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.period-chip{
  font-size:12px;color:var(--green);background:color-mix(in srgb,var(--green) 8%,transparent);
  border:1px solid color-mix(in srgb,var(--green) 25%,transparent);
  padding:5px 12px;border-radius:999px;font-variant-numeric:tabular-nums;white-space:nowrap;
}

/* ——— buttons ——— */
.btn{
  appearance:none;border:1px solid var(--ink);background:var(--ink);color:var(--paper);
  padding:8px 16px;border-radius:999px;font-size:13px;font-weight:500;cursor:pointer;
  transition:transform .12s ease,opacity .12s ease,background .12s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn.ghost:hover{border-color:var(--ink)}
.btn.tiny{padding:5px 12px;font-size:12px}
.btn:disabled{opacity:.35;cursor:default;transform:none}
.btn:disabled:hover{border-color:var(--line)}

/* ——— empty state ——— */
.empty{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 76px);padding:48px 24px}
.empty-card{
  max-width:620px;text-align:center;cursor:pointer;
  border:1.5px dashed var(--faint);border-radius:24px;
  padding:64px 56px;background:var(--card);
  transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease;
}
.empty-card:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 12px 40px rgba(23,21,15,.06)}
.empty-mark{
  font-size:34px;color:var(--green);margin-bottom:18px;
  animation:float 3s ease-in-out infinite;
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
.empty h1{font-family:var(--serif);font-weight:600;font-size:34px;letter-spacing:-.02em;margin:0 0 14px}
.empty p{color:var(--muted);margin:0 0 26px;font-size:14.5px}
.empty p em{font-style:italic;color:var(--ink)}
.empty-feats{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:26px}
.empty-feats span{
  font-size:12px;color:var(--ink);background:var(--paper);
  border:1px solid var(--line);border-radius:999px;padding:6px 13px;
}
.empty-note{font-size:12.5px!important;color:var(--faint)!important;margin-bottom:0!important}

/* ——— summary strip ——— */
.results{max-width:1280px;margin:0 auto;padding:28px 28px 80px}
.summary{
  display:grid;grid-template-columns:1.6fr repeat(5,1fr);gap:10px;margin-bottom:28px;
}
.stat{
  background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:16px 18px;min-width:0;
}
.stat.main{
  background:linear-gradient(135deg,var(--green) 0%,var(--green-deep) 100%);
  border-color:var(--green-deep);color:#F2EFE6;
}
.stat-label{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.stat.main .stat-label{color:color-mix(in srgb,#F2EFE6 65%,transparent)}
.stat-num{
  font-family:var(--serif);font-size:26px;font-weight:600;letter-spacing:-.01em;
  font-variant-numeric:tabular-nums;line-height:1.1;white-space:nowrap;
}
.stat.main .stat-num{font-size:32px}
.stat-num.date{font-size:19px;letter-spacing:0}
.stat-num .unit{font-family:var(--sans);font-size:12px;font-weight:400;color:var(--muted);margin-left:5px;letter-spacing:0}
.stat.main .unit{color:color-mix(in srgb,#F2EFE6 65%,transparent)}
.stat-sub{font-size:11.5px;color:var(--muted);margin-top:4px;font-variant-numeric:tabular-nums}
.stat.main .stat-sub{color:color-mix(in srgb,#F2EFE6 75%,transparent)}

/* ——— sheet / table ——— */
.sheet{background:var(--card);border:1px solid var(--line);border-radius:20px;overflow:hidden}
.sheet-head{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:16px 22px;border-bottom:1px solid var(--line);
}
.sheet-head h2{font-family:var(--serif);font-size:19px;font-weight:600;margin:0;letter-spacing:-.01em}
.sheet-tools{display:flex;align-items:center;gap:12px;min-width:0}
.hint{font-size:12px;color:var(--faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:340px}

.table-wrap{overflow-x:auto}
.ledger{width:100%;border-collapse:collapse;min-width:1120px}
.ledger th{
  position:sticky;top:0;background:var(--card);z-index:2;
  font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:500;
  text-align:right;padding:12px 14px;border-bottom:1px solid var(--line);white-space:nowrap;
}
.ledger th.t-l,.ledger td.t-l{text-align:left}
.ledger td{
  padding:12px 14px;border-bottom:1px solid var(--line-soft);
  text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;
}
.ledger tbody tr.mainrow{cursor:pointer;transition:background .12s ease}
.ledger tbody tr.mainrow:hover{background:color-mix(in srgb,var(--paper) 55%,transparent)}
.ledger tbody tr.mainrow.open{background:color-mix(in srgb,var(--green) 4%,transparent)}
.ledger tfoot td{
  border-top:1.5px solid var(--ink);border-bottom:none;font-weight:600;
  padding:14px;background:var(--card);
}

.c-idx{color:var(--faint);font-size:12px;width:34px}
.c-name{text-align:left!important}
.c-name .nm{font-weight:600;font-size:14.5px}
.cell-sub{font-size:11px;color:var(--faint);margin-top:1px}
.c-net{font-weight:650;font-size:15px}
.c-chev{color:var(--faint);width:24px;font-size:12px}
.c-del{width:34px;text-align:center;padding-left:2px!important;padding-right:8px!important}
.row-del{
  appearance:none;border:none;background:none;cursor:pointer;
  color:var(--faint);opacity:.4;font-size:13px;line-height:1;padding:6px;border-radius:6px;
  transition:opacity .12s ease,color .12s ease,background .12s ease;
}
.mainrow:hover .row-del{opacity:.75}
.row-del:hover{opacity:1;color:var(--red);background:color-mix(in srgb,var(--red) 10%,transparent)}
.dim{color:var(--faint);font-weight:400}
.neg{color:var(--red)}
.warn{color:var(--amber)}
.pos{color:var(--green)}

/* stars */
.c-stars{text-align:center!important}
.stars{display:inline-flex;gap:1px}
.star{
  color:#DCD7C8;font-size:16px;cursor:pointer;padding:0 1.5px;
  transition:transform .1s ease,color .1s ease;user-select:none;
}
.star:hover{transform:scale(1.25)}
.star.on{color:var(--gold)}
/* auto-scored performance — read-only stars + a % */
.stars.auto .star{cursor:default}
.stars.auto .star:hover{transform:none}
.perf-pct{
  display:block;font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums;margin-top:1px;
}

/* base input */
.c-base{white-space:nowrap}
.c-base .cur{color:var(--faint);font-size:12px;margin-right:2px}
.base-in{
  width:74px;border:none;border-bottom:1px solid var(--line);background:transparent;
  text-align:right;padding:3px 2px;font-variant-numeric:tabular-nums;font-size:14px;
  transition:border-color .12s ease;border-radius:0;
}
.base-in:hover{border-color:var(--faint)}
.base-in:focus{outline:none;border-bottom:1.5px solid var(--green)}
.base-in::-webkit-outer-spin-button,.base-in::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.base-in::placeholder{color:var(--faint)}

/* ——— expanded detail ——— */
tr.detail>td{padding:0;background:color-mix(in srgb,var(--paper) 60%,transparent);text-align:left}
.detail-in{padding:18px 22px 22px;display:flex;flex-direction:column;gap:18px}

.daygrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(104px,1fr));gap:7px}
.day{
  border:1px solid var(--line);border-radius:10px;padding:8px 10px;background:var(--card);
  min-width:0;cursor:pointer;transition:border-color .12s ease,transform .1s ease;
}
.day:hover{border-color:var(--muted);transform:translateY(-1px)}
.day.editing{outline:2px solid var(--green);outline-offset:1px}
.day.edited{border-color:color-mix(in srgb,var(--ink) 35%,transparent)}
.day-tag.edit{background:var(--ink)}
.day-d{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.day-t{font-size:12.5px;font-variant-numeric:tabular-nums;font-weight:500}
.day-f{font-size:10.5px;margin-top:3px;color:var(--muted)}
.day.ok{border-color:color-mix(in srgb,var(--green) 30%,transparent)}
.day.late{border-color:color-mix(in srgb,var(--red) 45%,transparent);background:color-mix(in srgb,var(--red) 4%,var(--card))}
.day.late .day-f{color:var(--red)}
.day.early{border-color:color-mix(in srgb,var(--amber) 50%,transparent);background:color-mix(in srgb,var(--amber) 5%,var(--card))}
.day.early .day-f{color:var(--amber)}
.day.single{border-style:dashed}
.day.abs{opacity:.5;background:transparent}
.day.abs .day-t{color:var(--faint)}
.day.off{background:transparent;border-style:dashed;opacity:.7}
.day.off .day-t{color:var(--faint);font-weight:400;font-style:italic}
.day.hol{border-color:color-mix(in srgb,var(--gold) 55%,transparent);background:color-mix(in srgb,var(--gold) 8%,var(--card))}
.day.hol.worked{border-color:var(--gold);background:color-mix(in srgb,var(--gold) 14%,var(--card))}
.day.hol .day-f{color:var(--amber)}
.day.dayoff.worked{border-color:color-mix(in srgb,var(--green) 50%,transparent);background:color-mix(in srgb,var(--green) 7%,var(--card))}
.day.dayoff.worked .day-f{color:var(--green)}
.day-tag{
  display:inline-block;font-size:8px;letter-spacing:.1em;font-weight:700;
  color:var(--card);background:var(--gold);border-radius:4px;padding:1px 4px;margin-left:3px;vertical-align:middle;
}
.day.dayoff .day-tag{background:var(--green)}

/* per-person working-days schedule */
.schedule{
  display:flex;flex-direction:column;gap:11px;
  padding:14px 16px;border:1px solid var(--line);border-radius:14px;background:var(--card);
}
.sched-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px 16px}
.sched-lbl{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.sched-hint{display:block;text-transform:none;letter-spacing:0;font-size:11px;color:var(--faint);margin-top:3px;font-weight:400}
.wdays{display:inline-flex;gap:5px}
.wday{
  min-width:40px;height:36px;padding:0 4px;border-radius:9px;cursor:pointer;
  border:1px solid var(--line);background:var(--paper);color:var(--faint);
  font-size:12.5px;font-weight:600;transition:all .12s ease;
}
.wday:hover{border-color:var(--faint);color:var(--muted)}
.wday.on{background:var(--green);border-color:var(--green);color:#F2EFE6}
.sched-count{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}
.sched-count b{color:var(--ink);font-weight:600}

.cfg{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px 16px;
  padding:16px;border:1px solid var(--line);border-radius:14px;background:var(--card);
}
.cfg label{display:flex;flex-direction:column;gap:5px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.cfg label.wide{grid-column:1/-1}
.cfg input,.cfg select{
  border:none;border-bottom:1px solid var(--line);background:transparent;
  padding:4px 1px;font-size:13.5px;letter-spacing:0;text-transform:none;color:var(--ink);
  border-radius:0;min-width:0;width:100%;
}
.cfg input:focus,.cfg select:focus{outline:none;border-bottom:1.5px solid var(--green)}
.cfg input::placeholder{color:var(--faint);font-style:italic}

.breakdown{
  display:flex;flex-wrap:wrap;gap:6px 22px;align-items:baseline;
  font-size:12.5px;color:var(--muted);font-variant-numeric:tabular-nums;
}
.breakdown b{color:var(--ink);font-weight:600}
.bk-net{margin-left:auto;font-size:13.5px}
.bk-net b{font-family:var(--serif);font-size:17px}

/* collapsible daily-punch reference */
.punches{border:1px solid var(--line-soft);border-radius:12px;overflow:hidden}
.punches>summary{
  cursor:pointer;padding:11px 15px;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);list-style:none;user-select:none;
}
.punches>summary::-webkit-details-marker{display:none}
.punches>summary::before{content:'▸  ';color:var(--faint)}
.punches[open]>summary::before{content:'▾  '}
.punches[open]>summary{border-bottom:1px solid var(--line-soft)}
.punch-hint{text-transform:none;letter-spacing:0;color:var(--faint);font-weight:400}
.punches .daygrid{padding:13px 15px;max-height:360px;overflow-y:auto}

/* hand-entered punch editor */
.day-editor{
  display:flex;flex-wrap:wrap;align-items:center;gap:8px;
  margin:12px 15px 0;padding:11px 13px;border:1px solid var(--green);border-radius:11px;
  background:color-mix(in srgb,var(--green) 6%,var(--card));
}
.de-date{font-size:12.5px;font-weight:600;color:var(--ink);white-space:nowrap}
.day-edit-in{
  flex:1;min-width:130px;border:1px solid var(--line);background:var(--card);
  padding:7px 9px;font-size:16px;font-variant-numeric:tabular-nums;border-radius:8px;color:var(--ink);
}
.day-edit-in:focus{outline:none;border-color:var(--green)}
.day-edit-in::placeholder{color:var(--faint)}

.detail-foot{display:flex;justify-content:flex-end;padding-top:2px}
.btn-danger{
  appearance:none;background:none;border:1px solid transparent;cursor:pointer;
  color:var(--red);font-size:12.5px;padding:6px 10px;border-radius:8px;
  transition:background .12s ease,border-color .12s ease;
}
.btn-danger:hover{background:color-mix(in srgb,var(--red) 8%,transparent);border-color:color-mix(in srgb,var(--red) 30%,transparent)}

.foot-note{padding:14px 22px;margin:0;font-size:12px;color:var(--faint);border-top:1px solid var(--line-soft)}

/* ——— rules drawer ——— */
.drawer-veil{position:fixed;inset:0;background:rgba(23,21,15,.25);z-index:60;backdrop-filter:blur(2px)}
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(380px,92vw);z-index:61;
  background:var(--card);border-left:1px solid var(--line);
  display:flex;flex-direction:column;
  box-shadow:-24px 0 60px rgba(23,21,15,.12);
  animation:slidein .22s cubic-bezier(.2,.8,.2,1);
}
@keyframes slidein{from{transform:translateX(30px);opacity:0}to{transform:translateX(0);opacity:1}}
.drawer-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;border-bottom:1px solid var(--line);
}
.drawer-head h2{font-family:var(--serif);font-size:20px;margin:0;font-weight:600}
.drawer-body{padding:10px 22px 30px;overflow-y:auto;flex:1}
.rule-group{padding:16px 0;border-bottom:1px solid var(--line-soft)}
.rule-group h3{
  font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--green);
  margin:0 0 12px;font-weight:600;
}
.rule-group label{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  font-size:13.5px;margin-bottom:10px;
}
.rule-group label:last-of-type{margin-bottom:0}
.rule-group input[type=number],.rule-group input[type=text]{
  border:none;border-bottom:1px solid var(--line);background:transparent;
  padding:3px 2px;width:110px;text-align:right;font-variant-numeric:tabular-nums;border-radius:0;
}
.rule-group input[type=text]{width:160px;text-align:left}
.rule-group input:focus,.rule-group select:focus{outline:none;border-bottom:1.5px solid var(--green)}
.rule-group select{
  border:none;border-bottom:1px solid var(--line);background:transparent;padding:3px 0;max-width:200px;border-radius:0;
}
.rule-group input[type=checkbox]{width:15px;height:15px;accent-color:var(--green)}
.rule-group label.row{justify-content:flex-start;gap:9px}
.rule-hint{font-size:11.5px;color:var(--faint);margin:8px 0 0}
#btnResetRules{margin-top:18px}

/* holidays editor */
.hol-add{display:flex;gap:8px;align-items:center;margin:10px 0 12px}
.hol-add input[type=date]{
  border:none;border-bottom:1px solid var(--line);background:transparent;
  padding:4px 2px;font-size:13.5px;color:var(--ink);border-radius:0;flex:1;
}
.hol-add input[type=date]:focus{outline:none;border-bottom:1.5px solid var(--green)}
.hol-list{display:flex;flex-wrap:wrap;gap:7px}
.hol-chip{
  display:inline-flex;align-items:center;gap:5px;
  font-size:12.5px;color:var(--amber);font-variant-numeric:tabular-nums;
  background:color-mix(in srgb,var(--gold) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--gold) 40%,transparent);
  border-radius:999px;padding:4px 6px 4px 11px;
}
.hol-x{
  border:none;background:none;cursor:pointer;color:var(--amber);
  font-size:15px;line-height:1;padding:0 2px;border-radius:50%;opacity:.65;
}
.hol-x:hover{opacity:1}
.hol-empty{font-size:12px;color:var(--faint);font-style:italic}

/* ——— drop veil ——— */
.drop-veil{
  position:fixed;inset:0;z-index:100;background:color-mix(in srgb,var(--paper) 80%,transparent);
  backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:26px;
}
.drop-inner{
  width:100%;height:100%;border:2px dashed var(--green);border-radius:26px;
  display:flex;align-items:center;justify-content:center;
}
.drop-inner span{font-family:var(--serif);font-style:italic;font-size:32px;color:var(--green)}

/* ——— toast ——— */
.toast{
  position:fixed;bottom:26px;left:50%;transform:translateX(-50%);z-index:120;
  background:var(--ink);color:var(--paper);padding:11px 22px;border-radius:999px;
  font-size:13px;box-shadow:0 10px 30px rgba(23,21,15,.25);
  animation:toastin .18s ease;max-width:min(640px,90vw);text-align:center;
}
@keyframes toastin{from{transform:translate(-50%,8px);opacity:0}to{transform:translate(-50%,0);opacity:1}}
.toast.bad{background:var(--red)}

/* ——— payslips (print only) ——— */
.payslips{display:none}

@media print{
  @page{margin:14mm}
  body{background:#fff}
  .app,.drawer,.drawer-veil,.drop-veil,.toast{display:none!important}
  .payslips{display:block}
  .payslip{
    border:1px solid #999;border-radius:8px;padding:18px 22px;margin-bottom:14px;
    page-break-inside:avoid;font-family:var(--sans);color:#111;
  }
  .ps-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
  .ps-co{font-family:var(--serif);font-style:italic;font-weight:600;font-size:18px}
  .ps-period{font-size:11px;color:#666;font-variant-numeric:tabular-nums}
  .ps-name{font-size:15px;font-weight:650;margin-bottom:10px}
  .ps-name span{font-weight:400;color:#666;font-size:12px;margin-left:8px}
  .ps-t{width:100%;border-collapse:collapse;font-size:12.5px}
  .ps-t td{padding:5px 0;border-bottom:1px dotted #ccc;font-variant-numeric:tabular-nums}
  .ps-t td.r{text-align:right}
  .ps-net{
    display:flex;align-items:baseline;gap:14px;margin-top:12px;
    justify-content:flex-end;
  }
  .ps-net span{font-size:10px;letter-spacing:.12em;color:#666}
  .ps-net b{font-family:var(--serif);font-size:22px}
  .ps-net i{font-style:normal;font-size:12px;color:#444}
  .ps-sign{display:flex;justify-content:space-between;margin-top:34px;font-size:10.5px;color:#666}
  .ps-sign span{border-top:1px solid #999;padding-top:5px;width:40%;text-align:center}
}

/* ——— responsive ——— */
@media(max-width:1100px){
  .summary{grid-template-columns:repeat(3,1fr)}
  .stat.main{grid-column:1/-1}
}

/* ═══ phones & small tablets: table becomes cards ═══ */
@media(max-width:720px){
  .topbar{padding:10px 14px;gap:8px 10px}
  .wordmark{font-size:22px}
  .brand-sub{display:none}
  #periodChip{display:none}          /* the date range already lives in the summary card */
  .top-actions{gap:6px}
  .top-actions .btn{padding:7px 13px;font-size:12.5px}

  .results{padding:14px 12px 64px}

  /* summary */
  .summary{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:18px}
  .stat{padding:13px 14px;border-radius:14px}
  .stat.main{grid-column:1/-1}
  .stat-num{font-size:22px}
  .stat.main .stat-num{font-size:29px}

  /* empty state */
  .empty{min-height:calc(100vh - 64px);padding:32px 16px}
  .empty-card{padding:44px 26px;border-radius:20px}
  .empty h1{font-size:26px}
  .empty p{font-size:14px}

  /* sheet chrome */
  .sheet{border-radius:16px}
  .sheet-head{padding:14px 16px;flex-wrap:wrap}
  .sheet-head h2{font-size:17px;flex:1 1 100%}
  .sheet-tools{width:100%;justify-content:space-between}
  .hint{max-width:none;flex:1}
  .foot-note{padding:14px 16px}

  /* ── table → card grid ── */
  .table-wrap{overflow:visible}
  .ledger{min-width:0;display:block}
  .ledger thead{display:none}
  .ledger tbody{display:block}

  tr.mainrow{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    grid-template-areas:
      "name  name  name  net"
      "days  late  early ot"
      "stars stars base  base";
    gap:13px 10px;
    padding:16px;
    border-bottom:1px solid var(--line);
  }
  tr.mainrow:hover{background:transparent}
  tr.mainrow.open{background:color-mix(in srgb,var(--green) 4%,transparent)}
  tr.mainrow td{padding:0;border:none;text-align:left;white-space:normal;min-width:0;font-size:14px}

  tr.mainrow .c-idx,
  tr.mainrow .c-earned,
  tr.mainrow .c-extras,
  tr.mainrow .c-deduct,
  tr.mainrow .c-chev,
  tr.mainrow .c-del{display:none}

  tr.mainrow .c-name{grid-area:name;align-self:center}
  tr.mainrow .c-name .nm{font-size:16.5px}
  tr.mainrow .c-net{grid-area:net;text-align:right;align-self:center;font-size:17px}
  tr.mainrow .c-net .cell-sub{font-size:11px;margin-top:0}
  tr.mainrow .c-days{grid-area:days}
  tr.mainrow .c-late{grid-area:late}
  tr.mainrow .c-early{grid-area:early}
  tr.mainrow .c-ot{grid-area:ot}
  tr.mainrow .c-stars{grid-area:stars;text-align:left!important;align-self:center}
  tr.mainrow .c-base{grid-area:base;text-align:right;align-self:center}

  /* field labels appear only in card mode */
  tr.mainrow td[data-label]:not(.c-name):not(.c-net)::before{
    content:attr(data-label);
    display:block;
    font-size:9.5px;letter-spacing:.09em;text-transform:uppercase;color:var(--faint);
    font-weight:500;margin-bottom:4px;
  }
  tr.mainrow .star{font-size:21px;padding:0 3px}   /* bigger tap targets */
  tr.mainrow .base-in{width:92px;font-size:16px}   /* 16px stops iOS auto-zoom */

  /* expanded detail */
  tr.detail{display:block}
  tr.detail>td{display:block;width:100%}
  .detail-in{padding:14px;gap:14px}
  .daygrid{grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:6px}
  .day{padding:7px 9px}
  .cfg{grid-template-columns:1fr 1fr;padding:14px;gap:14px 12px}
  .cfg label.wide{grid-column:1/-1}
  .cfg input,.cfg select{font-size:16px}
  .breakdown{flex-direction:column;gap:6px;align-items:stretch}
  .breakdown .bk-net{margin-left:0;margin-top:2px}

  /* totals footer as its own card */
  .ledger tfoot{display:block}
  .ledger tfoot tr{
    display:grid;grid-template-columns:repeat(2,1fr);gap:14px 10px;
    padding:18px 16px;border-top:2px solid var(--ink);
  }
  .ledger tfoot td{padding:0;border:none;text-align:left!important;background:transparent}
  .ledger tfoot .tf-label{grid-column:1/-1;font-family:var(--serif);font-size:16px}
  .ledger tfoot .c-chev,
  .ledger tfoot .c-del{display:none}
  .ledger tfoot td[data-label]::before{
    content:attr(data-label);
    display:block;font-size:9.5px;letter-spacing:.09em;text-transform:uppercase;
    color:var(--faint);font-weight:500;margin-bottom:4px;
  }

  /* rules drawer full-height comfortable */
  .drawer{width:min(420px,100vw)}
}

@media(max-width:340px){
  .top-actions .btn{padding:6px 10px;font-size:12px}
}
