:root { --bg: #ffffff; --ink: #0a0a0a; --ink-soft: #6b7280; --line: #e5e7eb; --line-soft: #f3f4f6; --hover: #f9fafb; --radius: 10px; --radius-sm: 6px; }
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background: #f8f9fa; color: var(--ink); font-size: 14px; line-height: 1.5; -webkit-font-smoothing: antialiased; }

.app-bar { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,0.92); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.app-bar-inner { max-width: 1100px; margin: 0 auto; padding: 14px 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.app-bar-brand { display: flex; align-items: center; gap: 12px; }
.app-bar-brand img { height: 34px; }
.brand-name { font-size: 15px; font-weight: 600; }
.brand-sub { font-size: 10px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.1em; }
.app-nav { display: flex; gap: 4px; align-items: center; }
.app-nav a { background: transparent; border: 1px solid transparent; padding: 8px 14px; color: var(--ink-soft); text-decoration: none; border-radius: 6px; font-size: 13px; font-weight: 500; }
.app-nav a:hover { background: #f9fafb; color: var(--ink); }
.app-nav a.active { background: var(--ink); color: #fff; }
.btn-logout { background:transparent; border:1px solid #e5e7eb; padding: 8px 14px; border-radius: 6px; cursor:pointer; font-family:inherit; margin-left:10px; color: var(--ink); }

.container { max-width: 1100px; margin: 0 auto; padding: 32px 24px 96px; }

.page-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; }
.page-header h1 { margin: 0; font-size: 24px; font-weight: 600; }
.filter-bar select { padding: 10px 14px; border: 1px solid var(--line); border-radius: 6px; font-family: inherit; font-size: 14px; background: #fff; cursor: pointer; }
.filter-bar select:focus { outline: none; border-color: var(--ink); }

.report-sheet { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: 0 4px 20px rgba(0,0,0,0.03); padding: 40px; }

.print-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 40px; border-bottom: 2px solid var(--ink); padding-bottom: 20px; }
.print-header-left img { max-height: 50px; margin-bottom: 10px; }
.print-header-left h2 { margin: 0 0 4px; font-size: 20px; }
.print-header-left p { margin: 0; font-size: 13px; color: var(--ink-soft); }
.print-header-right { text-align: right; }
.print-header-right h1 { margin: 0 0 8px; font-size: 24px; text-transform: uppercase; }
.print-header-right p { margin: 0; font-size: 14px; font-weight: 600; }

.finance-table { width: 100%; border-collapse: collapse; margin-bottom: 32px; }
.finance-table th { text-align: left; padding: 12px 16px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); font-weight: 600; border-bottom: 1px solid var(--line); background: var(--hover); }
.finance-table th.num { text-align: right; }
.finance-table th.report-header { text-align: center; border-bottom: 1px solid var(--line-soft); }
.finance-table td { padding: 8px 16px; border-bottom: 1px solid var(--line-soft); font-size: 14px; vertical-align: middle; }
.finance-table td.num { text-align: right; font-variant-numeric: tabular-nums; }
.finance-table td.total-label { text-align: right; font-weight: 700; padding-right: 24px; text-transform: uppercase; font-size: 13px; }
.week-total-row td { border-top: 2px solid var(--ink); border-bottom: none; padding-top: 16px; }
.week-total-row .num { font-size: 18px; font-weight: 700; }

.row-input { width: 100%; padding: 8px 10px; border: 1px solid transparent; background: transparent; font: inherit; font-size: 14px; text-align: right; border-radius: 4px; transition: all 0.15s; }
.row-input:hover { border-color: var(--line); background: #fff; }
.row-input:focus { outline: none; border-color: var(--ink); background: #fff; }
.row-locked .row-input { color: var(--ink-soft); cursor: not-allowed; pointer-events: none; }
.row-locked .row-input:hover { border-color: transparent; background: transparent; }

.auth-select { width: 100%; padding: 8px 10px; border: 1px solid var(--line); border-radius: 4px; font: inherit; font-size: 13px; background: #fff; cursor: pointer; }
.auth-select:focus { outline: none; border-color: var(--ink); }

.summary-box { display: flex; justify-content: flex-end; gap: 24px; align-items: center; padding: 24px; background: var(--hover); border-radius: var(--radius-sm); border: 1px solid var(--line); }
.summary-item { display: flex; flex-direction: column; gap: 4px; }
.summary-item span { font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); font-weight: 600; }
.summary-item strong { font-size: 20px; font-weight: 700; }
.wages-box input { width: 120px; padding: 8px 12px; border: 1px solid var(--line); border-radius: 4px; font: inherit; font-size: 16px; font-weight: 600; text-align: right; }
.wages-box input:focus { outline: none; border-color: var(--ink); }
.net-box strong { color: #059669; }

.actions-bar { margin-top: 24px; display: flex; justify-content: flex-end; }
.btn-print { background: var(--ink); color: #fff; border: none; padding: 12px 24px; border-radius: 8px; font-family: inherit; font-size: 15px; font-weight: 500; cursor: pointer; transition: background 0.15s; }
.btn-print:hover { background: #262626; }

/* PRINT STYLES */
@media print {
  .no-print, .app-bar, .page-header, .actions-bar { display: none !important; }
  body { background: #fff; }
  .container { padding: 0; max-width: none; }
  .report-sheet { border: none; box-shadow: none; padding: 0; border-radius: 0; }
  .row-input { border: none !important; background: transparent !important; padding: 4px 0 !important; }
  .finance-table th { background: #f3f4f6 !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}

/* Make the save lock checkbox bigger */
.finance-table input[type="checkbox"] {
  width: 22px;
  height: 22px;
  cursor: pointer;
  accent-color: #0a0a0a;
}