:root {
  --bg: #eef0f3;
  --card: #ffffff;
  --border: #cbd2da;
  --border-strong: #9ca3af;
  --text: #0f172a;
  --muted: #475569;
  --accent: #1d4ed8;
  --hol: #1d4ed8;
  --school: #7e22ce;
  --warn: #b45309;
  --ok: #15803d;
  --row-hover: #f8fafc;
  --row-me: #fef3c7;
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);
  --shadow-md: 0 4px 12px rgba(15, 23, 42, .08);
  font-family: 'Inter', -apple-system, system-ui, sans-serif;
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--bg); color: var(--text); }
.topbar {
  display: flex; align-items: center; gap: 1.5rem;
  padding: .8rem 1.2rem; border-bottom: 1px solid var(--border-strong);
  background: var(--card); box-shadow: var(--shadow-sm);
}
.topbar .brand { font-weight: 700; }
.topbar .nav { display: flex; gap: 1rem; flex: 1; }
.topbar .nav a { color: var(--muted); text-decoration: none; padding: .25rem 0; }
.topbar .nav a.is-active { color: var(--text); border-bottom: 2px solid var(--accent); }
.you-menu summary { cursor: pointer; list-style: none; }
.you-menu .you-menu-body {
  position: absolute; right: 1rem; background: var(--card);
  border: 1px solid var(--border-strong); border-radius: 8px; padding: .5rem; margin-top: .5rem;
  box-shadow: var(--shadow-md);
}
.main { max-width: 1100px; margin: 0 auto; padding: 1.5rem; }
.login-card { max-width: 320px; margin: 4rem auto; padding: 1.5rem;
  background: var(--card); border: 1px solid var(--border-strong); border-radius: 12px; box-shadow: var(--shadow-md); }
.login-card label { display: block; margin: .8rem 0; font-weight: 500; }
.login-card input { width: 100%; padding: .55rem; border: 1px solid var(--border-strong); border-radius: 6px; }
.login-card input:focus { outline: 2px solid var(--accent); outline-offset: -1px; border-color: var(--accent); }
.login-card .form-error { color: #b91c1c; }
.button, button[type="submit"] {
  background: var(--accent); color: white; border: 0; padding: .55rem 1rem;
  border-radius: 6px; cursor: pointer; font-weight: 500;
}
button.link { background: none; color: var(--text); border: 0; cursor: pointer; padding: 0; }

.week-header { display: flex; align-items: center; justify-content: space-between; margin: 1rem 0; }
.anomaly-badge { background: #fef3c7; color: var(--warn); padding: .25rem .75rem; border-radius: 999px; font-size: .75rem; font-weight: 500; margin-right: auto; margin-left: 1rem; }
.week-nav a { padding: .3rem .65rem; border: 1px solid var(--border-strong); border-radius: 6px; text-decoration: none; color: var(--text); margin-left: .25rem; background: var(--card); font-weight: 500; }
.week-nav a:hover { background: var(--accent); color: white; border-color: var(--accent); }
.now-strip { background: var(--card); border: 1px solid var(--border-strong); border-radius: 8px;
  padding: .7rem 1rem; margin: .5rem 0 1rem; display: flex; justify-content: space-between; align-items: center;
  box-shadow: var(--shadow-sm); font-weight: 500; }
.timesheet { width: 100%; border-collapse: collapse; background: var(--card); border: 1px solid var(--border-strong); border-radius: 12px; overflow: hidden; box-shadow: var(--shadow-sm); }
.timesheet th { background: #e2e8f0; color: var(--text); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; padding: .6rem .75rem; text-align: right; border-bottom: 2px solid var(--border-strong); }
.timesheet th:first-child { text-align: left; }
.timesheet td { padding: .6rem .75rem; text-align: right; border-top: 1px solid var(--border); font-variant-numeric: tabular-nums; }
.timesheet td:first-child { text-align: left; font-weight: 600; }
.timesheet tbody tr:hover { background: var(--row-hover); }
.timesheet tr.is-me { background: var(--row-me); box-shadow: inset 4px 0 0 var(--accent); }
.timesheet tr.is-me:hover { background: #fde68a; }
.timesheet .cell-holiday { color: var(--hol); font-weight: 600; font-style: italic; }
.timesheet .cell-school { color: var(--school); font-weight: 600; font-style: italic; }
.timesheet .cell-warn { background: #fef3c7; }
.timesheet .cell-warn sup.anomaly { color: var(--warn); margin-left: .15rem; font-weight: 700; }
.timesheet .cell-today { font-weight: 700; background: #dbeafe; }
.timesheet .goal { color: var(--text); font-weight: 500; }
button.ghost { background: var(--card); border: 1px solid var(--border-strong); padding: .4rem .85rem; border-radius: 6px; cursor: pointer; font-weight: 500; color: var(--text); }
button.ghost:hover { background: var(--accent); color: white; border-color: var(--accent); }

.cell { position: relative; }
.cell .tt { display: none; position: absolute; top: 100%; left: 0; z-index: 5;
  background: white; border: 1px solid var(--border-strong); padding: .5rem; border-radius: 8px;
  font-size: .8rem; min-width: 220px; box-shadow: var(--shadow-md); text-align: left; }
.cell:hover .tt, .cell:focus-within .tt { display: block; }
.punches-tooltip ul { list-style: none; padding: 0; margin: .35rem 0 0; }
.punches-tooltip li { display: flex; gap: .5rem; padding: .15rem 0; }
.punches-tooltip .kind-in { color: var(--ok); }
.punches-tooltip .kind-out { color: var(--muted); }
.punches-tooltip .src { color: var(--muted); margin-left: auto; font-size: .7rem; }

.panel { background: var(--card); border: 1px solid var(--border-strong); border-radius: 12px;
  padding: 1rem; margin-bottom: 1.25rem; box-shadow: var(--shadow-sm); }
.panel header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: .75rem; }
.panel header small { color: var(--muted); }
.attainment { width: 100%; border-collapse: collapse; }
.attainment td { padding: .25rem .5rem; }
.attainment .bar { display: inline-block; width: 100%; max-width: 120px; height: 18px;
  background: linear-gradient(to right, #16a34a99 var(--pct), #f1f5f9 0); border-radius: 4px; padding: 0 .25rem; font-size: .75rem; line-height: 18px; color: white; text-shadow: 0 1px 1px rgba(0,0,0,.25); }
.cov-grid { display: grid; grid-template-columns: 32px repeat(24, 1fr); gap: 2px; }
.cov-grid .cov-day, .cov-grid .cov-hour { font-size: .65rem; color: var(--muted); text-align: center; }
.cov-grid .cov-cell { height: 16px; border-radius: 2px; background: #f1f5f9; }
.chart-controls { margin-bottom: 1rem; }
.chart-controls fieldset { border: 1px solid var(--border); border-radius: 8px; padding: .5rem 1rem; display: inline-flex; gap: 1rem; align-items: center; }
.chart-controls legend { font-size: .75rem; color: var(--muted); }

.admin-tabs { display: flex; gap: 1rem; margin-bottom: 1rem; border-bottom: 1px solid var(--border); }
.admin-tabs a { padding: .5rem 0; color: var(--muted); text-decoration: none; }
.admin-tabs a.is-active { color: var(--text); border-bottom: 2px solid var(--accent); }
.admin-edit-controls { display: flex; gap: 1rem; margin-bottom: 1rem; }
.drawer { background: var(--card); border: 1px solid var(--border-strong); border-radius: 12px;
  padding: 1rem; margin-top: 1rem; box-shadow: var(--shadow-md); }
.drawer header { display: flex; justify-content: space-between; align-items: baseline; }
.drawer .punch-list { list-style: none; padding: 0; }
.drawer .punch-list li { display: flex; gap: .75rem; padding: .35rem 0; align-items: center; border-bottom: 1px solid var(--border); }

.user-card { background: var(--card); border: 1px solid var(--border-strong); border-radius: 8px; padding: .8rem; margin-bottom: .5rem; box-shadow: var(--shadow-sm); }
.user-card.is-inactive { opacity: .6; }
.user-card summary { display: flex; gap: .5rem; align-items: baseline; cursor: pointer; list-style: none; }
.user-card form { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: .5rem; margin-top: .8rem; }
.user-card .pill { background: var(--accent); color: white; font-size: .65rem; padding: .15rem .5rem; border-radius: 999px; }
.user-card .pill.warn { background: var(--warn); }
.user-actions { display: flex; gap: .5rem; align-items: center; margin-top: .75rem; }
.user-actions .token-out { background: #f1f5f9; padding: .35rem .5rem; border-radius: 4px; font-size: .7rem; }

.year-nav { display: flex; gap: 1rem; align-items: center; margin: 1rem 0; }
.holidays { width: 100%; border-collapse: collapse; background: var(--card); border: 1px solid var(--border-strong); border-radius: 8px; box-shadow: var(--shadow-sm); }
.holidays th { padding: .55rem .75rem; text-align: left; background: #e2e8f0; border-bottom: 2px solid var(--border-strong); font-size: .68rem; text-transform: uppercase; letter-spacing: .08em; color: var(--text); }
.holidays td { padding: .55rem .75rem; text-align: left; border-top: 1px solid var(--border); }
.holidays tr.is-custom { background: #fef3c7; }
.holidays tbody tr:hover { background: var(--row-hover); }
.add-custom { margin-top: 1rem; }

.schedule-header { display: flex; justify-content: space-between; align-items: center; margin: 1rem 0; }
.schedule-toolbar { display: flex; gap: .5rem; }

.sched-week { margin-bottom: 1.5rem; }
.sched-week-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: .25rem; }
.sched-table { width: 100%; border-collapse: collapse; background: var(--card);
  border: 1px solid var(--border-strong); border-radius: 8px; overflow: hidden; box-shadow: var(--shadow-sm); }
.sched-table th { background: #e2e8f0; color: var(--text); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase;
  padding: .5rem .6rem; text-align: right; border-bottom: 2px solid var(--border-strong); }
.sched-table th:first-child { text-align: left; }
.sched-table td { padding: .5rem .6rem; text-align: right; border-top: 1px solid var(--border); font-variant-numeric: tabular-nums; }
.sched-table td:first-child { text-align: left; font-weight: 500; }
.sched-cell { cursor: pointer; min-width: 3rem; }
.sched-cell.sched-vacation { color: var(--ok); font-weight: 600; }
.sched-cell.sched-sick     { color: var(--warn); font-weight: 600; }
.sched-cell.sched-off      { color: var(--muted); }
.sched-cell.sched-draft    { font-style: italic; background: #f8fafc; border: 1px dashed var(--border-strong); }
.sched-cell.sched-confirmed { font-weight: 500; }
.sched-cell:hover { outline: 2px solid var(--accent); outline-offset: -2px; }
.sched-vac { color: var(--accent); font-weight: 600; cursor: pointer; }
.cell-popover { background: var(--card); border: 1px solid var(--border-strong); border-radius: 8px;
  padding: 1rem; box-shadow: var(--shadow-md); position: fixed; top: 50%; left: 50%;
  transform: translate(-50%, -50%); z-index: 100; min-width: 280px; }
.cell-popover header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: .8rem; }
.cell-popover form label { display: block; margin: .4rem 0; }
.cell-popover form input[type=number], .cell-popover form select { width: 100%; padding: .35rem; border: 1px solid var(--border-strong); border-radius: 4px; }
.cell-popover form input[type=checkbox] { margin-right: .35rem; }

.workday-checks { display: inline-flex; gap: .35rem; }
.workday-check { font-size: .75rem; }

a.ghost { background: var(--card); border: 1px solid var(--border-strong); padding: .4rem .85rem; border-radius: 6px; cursor: pointer; font-weight: 500; color: var(--text); text-decoration: none; display: inline-flex; align-items: center; }
a.ghost:hover { background: var(--accent); color: white; border-color: var(--accent); }

.schedule-toolbar { display: flex; gap: .65rem; align-items: center; flex-wrap: wrap; }
.inline-label { display: inline-flex; align-items: center; gap: .35rem; font-size: .8rem; color: var(--muted); }
.inline-label input[type=week], .inline-label select { padding: .35rem .5rem; border: 1px solid var(--border-strong); border-radius: 6px; background: var(--card); color: var(--text); font: inherit; }

/* ─── Schedule print view ─── */
.print-body { font-family: 'Inter', -apple-system, system-ui, sans-serif; color: #111; }
.print-controls { display: flex; gap: 1rem; align-items: center; padding: .75rem 1rem;
  background: #f3f4f6; border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: 10; }
.print-controls button { background: var(--accent); color: white; border: 0; padding: .55rem 1.25rem;
  border-radius: 6px; cursor: pointer; font-weight: 600; font-size: .9rem; }
.print-controls button:hover { filter: brightness(1.1); }
.print-title { padding: 1.5rem 2rem .25rem; }
.print-title h1 { font-size: 1.6rem; font-weight: 700; margin: 0; letter-spacing: -.01em; }
.print-range { color: #555; font-size: .9rem; margin-top: .15rem; }
.print-week { padding: 0 2rem 1rem; }
.print-week-header { display: flex; align-items: baseline; gap: 1rem; margin: .8rem 0 .3rem; }
.print-week-header h2 { font-size: 1.05rem; font-weight: 600; margin: 0; }
.print-week-dates { color: #555; font-size: .85rem; font-variant-numeric: tabular-nums; }
.print-table { width: 100%; border-collapse: collapse; font-size: 11pt; font-variant-numeric: tabular-nums; }
.print-table th, .print-table td { border: 1px solid #999; padding: .45rem .55rem; text-align: right; }
.print-table th { background: #e2e8f0; font-weight: 600; font-size: 10pt; text-transform: uppercase; letter-spacing: .04em; }
.print-table th:first-child, .print-name { text-align: left; }
.print-name { font-weight: 600; }
.print-total { font-weight: 700; background: #f3f4f6; }
.print-cell.print-vacation { color: #166534; font-weight: 700; background: #dcfce7; }
.print-cell.print-sick     { color: #b45309; font-weight: 700; background: #fef3c7; }
.print-cell.print-off      { color: #888; }
.print-cell .lbl  { font-size: 1rem; }
.print-cell .duty { color: #2563eb; font-weight: 700; }
.print-legend { padding: 1rem 2rem; display: flex; gap: 1.5rem; flex-wrap: wrap;
  font-size: .8rem; color: #555; border-top: 1px solid var(--border); margin-top: 1rem; }
.print-legend .generated { margin-left: auto; font-style: italic; color: #888; }

@media print {
  @page { size: A4 landscape; margin: 1.2cm 1.5cm; }
  body.print-body { background: white; }
  .topbar, .schedule-toolbar, nav, .print-controls { display: none !important; }
  .print-title { padding: 0 0 .5rem 0; }
  .print-title h1 { font-size: 1.3rem; }
  .print-week { padding: 0; page-break-after: always; }
  .print-week:last-of-type { page-break-after: auto; }
  .print-week-header { margin: .5rem 0 .25rem; }
  .print-week-header h2 { font-size: .95rem; }
  .print-table { font-size: 9.5pt; }
  .print-table th, .print-table td { padding: .25rem .4rem; }
  .print-legend { padding: .5rem 0; font-size: 8pt; }
  .print-cell.print-vacation, .print-cell.print-sick { background: white; }  /* save toner */
}
@media screen {
  body.print-body { background: white; padding: 0; max-width: 1100px; margin: 0 auto; }
}
.import-review { background: var(--card); border: 1px solid var(--border-strong); border-radius: 12px; padding: 1rem; margin-bottom: 1.25rem; box-shadow: var(--shadow-sm); }
.import-review-header { display: flex; gap: 1rem; justify-content: space-between; align-items: flex-start; margin-bottom: 1rem; flex-wrap: wrap; }
.import-review-actions { display: flex; gap: .5rem; }
.import-warnings { list-style: none; padding: 0; margin: .35rem 0 0; font-size: .8rem; color: var(--warn); }
.import-warnings li { padding: .15rem 0; }
.import-table { width: 100%; border-collapse: collapse; font-variant-numeric: tabular-nums; }
.import-table th { background: #e2e8f0; font-size: .68rem; text-transform: uppercase; letter-spacing: .08em; padding: .5rem .6rem; text-align: right; border-bottom: 2px solid var(--border-strong); }
.import-table th:first-child { text-align: left; }
.import-table td { padding: .55rem .6rem; text-align: right; border-top: 1px solid var(--border); }
.import-table td:first-child { text-align: left; font-weight: 500; }
.import-cell.low-conf { background: #fef3c7; outline: 2px solid var(--warn); outline-offset: -2px; }
.import-cell.med-conf { background: #fef9c3; }
.import-cell.has-conflict { outline: 2px solid #b91c1c; outline-offset: -2px; }
.import-cell .lbl { font-weight: 700; }

/* Photo-import loading indicator */
.import-indicator { display: none; align-items: center; gap: .65rem;
  background: var(--card); border: 1px solid var(--border-strong); border-radius: 8px;
  padding: .8rem 1rem; margin: .75rem 0; color: var(--text); font-weight: 500;
  box-shadow: var(--shadow-sm); }
.htmx-request .import-indicator,
.htmx-request.import-indicator { display: flex; }
.import-indicator .spinner {
  width: 18px; height: 18px; border: 3px solid var(--border-strong);
  border-top-color: var(--accent); border-radius: 50%;
  animation: import-spin .75s linear infinite;
}
@keyframes import-spin { to { transform: rotate(360deg); } }
.import-notice { background: #dcfce7; border: 1px solid #86efac; border-radius: 8px; padding: .6rem 1rem; margin-bottom: .75rem; color: #166534; font-size: .9rem; }
.ocr-model-group { display: flex; align-items: center; gap: .3rem; }
.ocr-model-group input[type=text] { width: 13rem; }
.ocr-pull-status { font-size: .8rem; white-space: nowrap; }
.ocr-pull-status.pulling { color: var(--muted); }
.ocr-pull-status.done { color: #166534; }
.ocr-pull-status.error { color: #b91c1c; }

/* Day-only schedule grid styling */
.sched-cell { font-size: 1.1rem; font-weight: 600; }
.sched-cell.sched-work { color: var(--ok); }
.sched-cell.sched-vacation { color: var(--accent); background: #dbeafe; }
.sched-cell.sched-sick { color: var(--warn); background: #fef3c7; }
.sched-cell.sched-off { color: var(--muted); font-weight: 400; }
.sched-cell.sched-school { color: var(--school); background: #f3e8ff; }
.sched-cell.sched-holiday { color: var(--hol); background: #dbeafe; }
.sched-legend { display: flex; gap: 1.25rem; padding: .5rem .25rem 0; font-size: .75rem; color: var(--muted); }
.sched-legend span { white-space: nowrap; }

/* Import-review debug + cell hover */
.import-cell { cursor: help; }
.import-debug { margin-top: 1rem; }
.import-debug summary { cursor: pointer; color: var(--muted); font-size: .85rem; padding: .25rem 0; }
.import-debug summary:hover { color: var(--text); }
.import-debug-table { width: 100%; border-collapse: collapse; margin-top: .5rem; font-size: .8rem; }
.import-debug-table th { background: #f3f4f6; padding: .35rem .5rem; text-align: left; border-bottom: 1px solid var(--border); font-weight: 500; }
.import-debug-table td { padding: .3rem .5rem; border-top: 1px solid var(--border); }
.import-debug-table .conf-high { color: var(--ok); font-weight: 600; }
.import-debug-table .conf-medium { color: #d97706; }
.import-debug-table .conf-low { color: var(--warn); font-weight: 600; }
.import-review-header .pill { display: inline-block; background: var(--accent); color: white; font-size: .65rem; padding: .15rem .5rem; border-radius: 999px; vertical-align: middle; margin: 0 .25rem; }
.import-review-actions button[disabled] { opacity: .55; cursor: not-allowed; }

/* Hidden but accessible file input — display:none would block native
   browser file-pick on click() in some browsers. */
.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); border: 0;
}
label.ghost { display: inline-flex; align-items: center; }
