/* Self-hosted fonts (SIL OFL 1.1) — no CDN. Added Round 1. */
@font-face{font-family:'Inter';font-style:normal;font-weight:100 900;font-display:swap;src:url('/css/fonts/inter-variable.woff2') format('woff2');}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:100 800;font-display:swap;src:url('/css/fonts/jetbrains-mono-variable.woff2') format('woff2');}
/* ════════════════════════════════════════════════════════════════
   Eshwa App — Glass Style (R1.5)
   ════════════════════════════════════════════════════════════════
   Single shared stylesheet. Loaded via a <link> tag at the END of
   every page's <head>, so it overrides each page's inline <style>.

   Philosophy:
   - iOS / macOS Sequoia frosted-glass aesthetic
   - Light theme primary
   - Soft elevation (subtle shadows, no hard borders where avoidable)
   - Generous whitespace
   - System font stack with proper hierarchy
   - All numbers tabular
   - Smooth transitions (no fast hover feel)
   - Status pills get tinted backgrounds, not borders

   Safe to remove: just delete the <link> tag from any page → that
   page reverts to its inline style.
   ════════════════════════════════════════════════════════════════ */

/* ─── Design Tokens ──────────────────────────────────────────── */
:root {
  /* Base colours (override existing :root) */
  --bg:           #f3f4f6 !important;
  --surface:      #ffffff !important;
  --surface-2:    #f9fafb !important;
  --border:       #e5e7eb !important;
  --border-2:     #d1d5db !important;
  --text:         #0f172a !important;
  --text2:        #64748b !important;
  --text3:        #94a3b8 !important;

  /* Brand */
  --accent:       #1a7a3a !important;
  --accent-soft:  rgba(26,122,58,.08);
  --gold:         #c79e4a;
  --green:        #16a34a !important;
  --amber:        #f59e0b !important;
  --red:          #dc2626 !important;
  --blue:         #3b82f6;
  --purple:       #8b5cf6;

  /* Glass tokens */
  --glass-bg:        rgba(255,255,255,0.72);
  --glass-bg-strong: rgba(255,255,255,0.86);
  --glass-blur:      saturate(180%) blur(20px);
  --glass-border:    rgba(255,255,255,0.5);

  /* Shadows — layered iOS-style */
  --shadow-1: 0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.04);
  --shadow-2: 0 2px 4px rgba(15,23,42,.04), 0 4px 12px rgba(15,23,42,.06);
  --shadow-3: 0 4px 8px rgba(15,23,42,.06), 0 12px 28px rgba(15,23,42,.10);
  --shadow-modal: 0 20px 50px -12px rgba(15,23,42,.30), 0 0 0 1px rgba(15,23,42,.05);

  /* Radius */
  --r-sm:  6px;
  --r-md:  10px;
  --r-lg:  14px;
  --r-xl:  18px;
  --r-pill: 999px;

  /* Type scale */
  --t-display: 28px;
  --t-h1: 22px;
  --t-h2: 17px;
  --t-h3: 15px;
  --t-body: 14px;
  --t-sm: 13px;
  --t-xs: 11px;
  --t-micro: 10px;

  /* Spacing scale */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 20px;
  --s-6: 24px;
  --s-8: 32px;
}

/* Subtle gradient body background — adds depth */
body {
  background:
    radial-gradient(1200px 800px at 0% 0%, rgba(26,122,58,0.04), transparent 50%),
    radial-gradient(1200px 800px at 100% 100%, rgba(199,158,74,0.04), transparent 50%),
    var(--bg) !important;
  background-attachment: fixed !important;
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  font-feature-settings: "tnum" 1, "kern" 1 !important;
  letter-spacing: -0.005em !important;
  color: var(--text) !important;
  line-height: 1.5 !important;
}

/* Dark theme */
[data-theme="dark"] {
  --bg:           #0a0e1a !important;
  --surface:      #131927 !important;
  --surface-2:    #1c2335 !important;
  --border:       rgba(255,255,255,0.08) !important;
  --border-2:     rgba(255,255,255,0.14) !important;
  --text:         #f1f5f9 !important;
  --text2:        #94a3b8 !important;
  --text3:        #64748b !important;
  --glass-bg:        rgba(20,26,40,0.72);
  --glass-bg-strong: rgba(20,26,40,0.86);
  --glass-border:    rgba(255,255,255,0.08);
  --shadow-1: 0 1px 2px rgba(0,0,0,.3), 0 1px 3px rgba(0,0,0,.2);
  --shadow-2: 0 2px 4px rgba(0,0,0,.3), 0 4px 12px rgba(0,0,0,.3);
  --shadow-3: 0 4px 8px rgba(0,0,0,.3), 0 12px 28px rgba(0,0,0,.4);
  --shadow-modal: 0 20px 50px -12px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,0.05);
}
[data-theme="dark"] body {
  background:
    radial-gradient(1200px 800px at 0% 0%, rgba(26,122,58,0.10), transparent 50%),
    radial-gradient(1200px 800px at 100% 100%, rgba(199,158,74,0.06), transparent 50%),
    var(--bg) !important;
}

/* ─── Topbar (sticky, glass) ────────────────────────────────── */
.topbar, header[class*="top"], .top-bar, nav.topbar {
  background: var(--glass-bg) !important;
  -webkit-backdrop-filter: var(--glass-blur);
  backdrop-filter: var(--glass-blur);
  border-bottom: 1px solid var(--glass-border) !important;
  padding: 12px 22px !important;
}

/* ─── Page container ─────────────────────────────────────────── */
.page, .container, main.container {
  padding: 22px !important;
  max-width: 1400px !important;
  margin: 0 auto !important;
}

/* ─── Tabs ───────────────────────────────────────────────────── */
.tabs, .pd-tabs {
  border-bottom: 1px solid var(--border) !important;
  gap: 2px !important;
  margin-bottom: 18px !important;
}
.tab, .pd-tab {
  padding: 10px 16px !important;
  font-size: var(--t-sm) !important;
  font-weight: 500 !important;
  color: var(--text2) !important;
  border-bottom: 2px solid transparent !important;
  transition: color .18s ease, border-color .18s ease, background .18s ease !important;
  border-radius: var(--r-md) var(--r-md) 0 0 !important;
}
.tab:hover, .pd-tab:hover {
  color: var(--text) !important;
  background: var(--surface-2) !important;
}
.tab.active, .pd-tab.active {
  color: var(--accent) !important;
  border-bottom-color: var(--accent) !important;
  font-weight: 600 !important;
  background: transparent !important;
}

/* ─── Buttons ────────────────────────────────────────────────── */
.btn {
  padding: 8px 14px !important;
  border: 1px solid var(--border) !important;
  background: var(--surface) !important;
  border-radius: var(--r-md) !important;
  cursor: pointer !important;
  font-size: var(--t-sm) !important;
  font-weight: 500 !important;
  color: var(--text) !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  transition: all .18s ease !important;
  box-shadow: var(--shadow-1) !important;
  white-space: nowrap !important;
  font-family: inherit !important;
}
.btn:hover {
  background: var(--surface-2) !important;
  border-color: var(--border-2) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-2) !important;
}
.btn:active {
  transform: translateY(0) !important;
  box-shadow: var(--shadow-1) !important;
}
.btn-primary {
  background: linear-gradient(180deg, #1f8c43 0%, var(--accent) 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: var(--shadow-1), 0 1px 0 rgba(255,255,255,0.2) inset !important;
}
.btn-primary:hover {
  background: linear-gradient(180deg, #239849 0%, #1d8541 100%) !important;
  box-shadow: var(--shadow-2), 0 1px 0 rgba(255,255,255,0.2) inset !important;
}
.btn-sm {
  padding: 6px 11px !important;
  font-size: var(--t-xs) !important;
}

/* ─── Cards (project list cards, generic cards) ──────────────── */
.p-card, .card, .lead-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  padding: 16px !important;
  box-shadow: var(--shadow-1) !important;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease !important;
}
.p-card:hover, .card:hover, .lead-card:hover {
  transform: translateY(-2px) !important;
  box-shadow: var(--shadow-2) !important;
  border-color: var(--border-2) !important;
}

/* Project cards — keep coloured left border accent */
.p-card {
  border-left-width: 4px !important;
}
.p-card[data-tint] {
  background: var(--card-tint, var(--surface)) !important;
  position: relative !important;
}
.p-card[data-tint]::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.40);
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
}
.p-card[data-tint] > * { position: relative; z-index: 1; }
[data-theme="dark"] .p-card[data-tint]::after { background: rgba(0,0,0,0.30); }

.p-name {
  font-size: var(--t-h3) !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
}
.p-status {
  font-size: var(--t-micro) !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em !important;
  padding: 3px 9px !important;
  border-radius: var(--r-pill) !important;
  background: var(--surface-2) !important;
  border: 1px solid var(--border) !important;
  text-transform: capitalize !important;
}
.p-date {
  font-size: var(--t-xs) !important;
  font-weight: 500 !important;
  padding: 3px 9px !important;
  border-radius: var(--r-pill) !important;
  background: var(--surface-2) !important;
  border: 1px solid var(--border) !important;
}

/* Status pill colour-coding */
.p-status:not([class*="-"]) { /* default */ }
.p-card[data-status="pending"] .p-status,
.p-status.pending { background: rgba(245,158,11,.12) !important; color: #92400e !important; border-color: rgba(245,158,11,.3) !important; }
.p-status.production, .p-card[data-status="production"] .p-status { background: rgba(59,130,246,.12) !important; color: #1d4ed8 !important; border-color: rgba(59,130,246,.3) !important; }
.p-status.ready, .p-card[data-status="ready"] .p-status { background: rgba(139,92,246,.12) !important; color: #6d28d9 !important; border-color: rgba(139,92,246,.3) !important; }
.p-status.dispatched, .p-card[data-status="dispatched"] .p-status { background: rgba(13,148,136,.12) !important; color: #0f766e !important; border-color: rgba(13,148,136,.3) !important; }
.p-status.completed, .p-card[data-status="completed"] .p-status { background: rgba(22,163,74,.12) !important; color: #15803d !important; border-color: rgba(22,163,74,.3) !important; }
.p-status.archived, .p-card[data-status="archived"] .p-status { background: rgba(115,115,115,.12) !important; color: #525252 !important; border-color: rgba(115,115,115,.3) !important; }

/* ─── Stats boxes ────────────────────────────────────────────── */
.p-stats div, .pd-stats .box, .sbox, .stat-box {
  background: var(--surface-2) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  padding: 10px 12px !important;
}
.p-stats .l, .pd-stats .l, .sbox .l, .stat-box .l, .stat-label {
  font-size: var(--t-micro) !important;
  font-weight: 600 !important;
  color: var(--text2) !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  opacity: 1 !important;
}
.p-stats .v, .pd-stats .v, .sbox .v, .stat-box .v, .stat-value {
  font-size: var(--t-h2) !important;
  font-weight: 700 !important;
  font-variant-numeric: tabular-nums !important;
  letter-spacing: -0.01em !important;
}

/* ─── Detail page header ─────────────────────────────────────── */
.pd-head {
  background: var(--glass-bg-strong) !important;
  -webkit-backdrop-filter: var(--glass-blur);
  backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--r-lg) !important;
  border-left-width: 5px !important;
  padding: 18px 22px !important;
  box-shadow: var(--shadow-2) !important;
  margin-bottom: 18px !important;
}
.pd-title {
  font-size: var(--t-display) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 6px !important;
}
.pd-sub {
  font-size: var(--t-sm) !important;
  color: var(--text2) !important;
  margin-bottom: 14px !important;
}
.pd-dates .pd-d {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  padding: 8px 12px !important;
}
.pd-dates .pd-d.overdue {
  background: rgba(220,38,38,0.06) !important;
  border-color: rgba(220,38,38,0.3) !important;
}

/* ─── Kanban board ───────────────────────────────────────────── */
.kcol {
  background: var(--surface-2) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  padding: 12px !important;
  box-shadow: none !important;
}
.kcol.drag-over {
  background: rgba(26,122,58,0.08) !important;
  border-color: var(--accent) !important;
}
.kcol-name {
  font-size: var(--t-sm) !important;
  font-weight: 600 !important;
  letter-spacing: -0.005em !important;
}
.kcol-count {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  font-size: var(--t-micro) !important;
  font-weight: 600 !important;
  padding: 2px 8px !important;
  border-radius: var(--r-pill) !important;
}

.tcard {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  padding: 11px 13px !important;
  margin-bottom: 8px !important;
  box-shadow: var(--shadow-1) !important;
  transition: transform .15s ease, box-shadow .15s ease !important;
}
.tcard:hover {
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-2) !important;
}
.tcard.dragging {
  opacity: 0.5 !important;
  transform: rotate(1deg) !important;
}
.tcard.done {
  background: rgba(22,163,74,0.05) !important;
  border-left: 3px solid var(--green) !important;
}
.tcard-title {
  font-size: var(--t-sm) !important;
  line-height: 1.45 !important;
  font-weight: 500 !important;
}
.tcard.bold .tcard-title {
  font-weight: 700 !important;
}

/* ─── Tables ─────────────────────────────────────────────────── */
.tbl-wrap, .table-wrap {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-1) !important;
}
table {
  width: 100% !important;
  border-collapse: collapse !important;
}
table th {
  background: var(--surface-2) !important;
  font-size: var(--t-xs) !important;
  font-weight: 600 !important;
  color: var(--text2) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  padding: 10px 14px !important;
  text-align: left !important;
  border-bottom: 1px solid var(--border) !important;
}
table td {
  padding: 11px 14px !important;
  font-size: var(--t-sm) !important;
  border-bottom: 1px solid var(--border) !important;
  vertical-align: middle !important;
}
table tbody tr:last-child td {
  border-bottom: none !important;
}
table tbody tr {
  transition: background .12s ease !important;
}
table tbody tr:hover {
  background: var(--surface-2) !important;
}
table .num {
  font-variant-numeric: tabular-nums !important;
  text-align: right !important;
}

/* ─── Forms ──────────────────────────────────────────────────── */
input[type="text"], input[type="number"], input[type="date"],
input[type="email"], input[type="tel"], input[type="search"],
input[type="password"], textarea, select {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  padding: 9px 12px !important;
  font-size: var(--t-sm) !important;
  font-family: inherit !important;
  color: var(--text) !important;
  transition: border-color .15s ease, box-shadow .15s ease !important;
  line-height: 1.4 !important;
}
input[type="text"]:focus, input[type="number"]:focus, input[type="date"]:focus,
input[type="email"]:focus, input[type="tel"]:focus, input[type="search"]:focus,
input[type="password"]:focus, textarea:focus, select:focus {
  outline: none !important;
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(26,122,58,0.12) !important;
}
input[readonly] {
  background: var(--surface-2) !important;
  cursor: not-allowed !important;
}

/* ─── Modals ─────────────────────────────────────────────────── */
[id$="Modal"][style*="display:flex"],
[id$="Modal"][style*="display: flex"],
.modal-bg.show {
  background: rgba(15,23,42,0.40) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  backdrop-filter: blur(8px) !important;
}
[id$="Modal"] > div,
.modal-bg .modal,
.modal {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-xl) !important;
  box-shadow: var(--shadow-modal) !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  animation: modalIn .22s cubic-bezier(.2,.7,.3,1) !important;
}
@keyframes modalIn {
  from { opacity: 0; transform: translateY(8px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
/* Modal header (top section with title + ×) */
[id$="Modal"] > div > div:first-child {
  padding: 14px 20px !important;
  border-bottom: 1px solid var(--border) !important;
  background: var(--surface-2) !important;
}
[id$="Modal"] h3 {
  font-size: var(--t-h2) !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
}
/* Modal footer (action buttons row) */
[id$="Modal"] > div > div:last-child {
  padding: 12px 20px !important;
  border-top: 1px solid var(--border) !important;
  background: var(--surface-2) !important;
}

/* ─── Pills, badges, chips ───────────────────────────────────── */
.chip, .badge, .pill {
  border-radius: var(--r-pill) !important;
  padding: 3px 9px !important;
  font-size: var(--t-xs) !important;
  font-weight: 500 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
}

/* ─── Empty states ───────────────────────────────────────────── */
.empty {
  text-align: center !important;
  padding: 48px 24px !important;
  color: var(--text3) !important;
  font-size: var(--t-sm) !important;
  background: var(--surface-2) !important;
  border: 1px dashed var(--border) !important;
  border-radius: var(--r-lg) !important;
}

/* ─── Summary bar ────────────────────────────────────────────── */
.summary-bar {
  gap: 12px !important;
  margin-bottom: 18px !important;
}

/* ─── Toast (used app-wide) ──────────────────────────────────── */
#ew_toast, #toast {
  background: rgba(15,23,42,0.92) !important;
  -webkit-backdrop-filter: var(--glass-blur);
  backdrop-filter: var(--glass-blur);
  border-radius: var(--r-pill) !important;
  padding: 11px 22px !important;
  font-size: var(--t-sm) !important;
  font-weight: 500 !important;
  box-shadow: var(--shadow-3) !important;
  color: #fff !important;
}

/* ─── Dashboard tiles (home page) ────────────────────────────── */
.app-tile, .tile {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-xl) !important;
  padding: 22px !important;
  box-shadow: var(--shadow-1) !important;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease !important;
  text-decoration: none !important;
  color: var(--text) !important;
  position: relative !important;
  overflow: hidden !important;
}
.app-tile:hover, .tile:hover {
  transform: translateY(-3px) !important;
  box-shadow: var(--shadow-3) !important;
}
.app-tile::before, .tile::before {
  content: "" !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 3px !important;
  background: var(--app-color, var(--accent)) !important;
  opacity: 0.85 !important;
}
.app-icon {
  font-size: 28px !important;
  margin-bottom: 12px !important;
}
.app-name {
  font-size: var(--t-h3) !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  margin-bottom: 4px !important;
}
.app-desc {
  font-size: var(--t-xs) !important;
  color: var(--text2) !important;
  line-height: 1.45 !important;
}

/* ─── Scrollbars (subtle) ────────────────────────────────────── */
::-webkit-scrollbar { width: 8px !important; height: 8px !important; }
::-webkit-scrollbar-track { background: transparent !important; }
::-webkit-scrollbar-thumb {
  background: rgba(15,23,42,0.15) !important;
  border-radius: 4px !important;
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(15,23,42,0.25) !important;
}
[data-theme="dark"] ::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.10) !important;
}

/* ─── Selection colour ───────────────────────────────────────── */
::selection {
  background: rgba(26,122,58,0.20) !important;
  color: var(--text) !important;
}

/* ─── Focus ring (keyboard accessibility) ───────────────────── */
button:focus-visible, .btn:focus-visible, a:focus-visible {
  outline: 2px solid var(--accent) !important;
  outline-offset: 2px !important;
}

/* ─── Quill editor (notes) ───────────────────────────────────── */
.ql-toolbar.ql-snow {
  border: 1px solid var(--border) !important;
  border-radius: var(--r-md) var(--r-md) 0 0 !important;
  background: var(--surface-2) !important;
}
.ql-container.ql-snow {
  border: 1px solid var(--border) !important;
  border-top: none !important;
  border-radius: 0 0 var(--r-md) var(--r-md) !important;
  background: var(--surface) !important;
  font-size: var(--t-body) !important;
  font-family: inherit !important;
}

/* ─── Mobile breakpoint ──────────────────────────────────────── */
@media (max-width: 600px) {
  .page, .container { padding: 14px !important; }
  .pd-title { font-size: 22px !important; }
  .topbar { padding: 10px 14px !important; }
  table th, table td { padding: 9px 10px !important; font-size: 12px !important; }
  .modal { max-height: 95vh !important; }
  [id$="Modal"] > div { max-height: 95vh !important; }
}

/* ─── Print ──────────────────────────────────────────────────── */
@media print {
  .topbar, .tabs, .pd-tabs, .btn { display: none !important; }
  body { background: #fff !important; }
}

/* ─── ATTENDANCE PAGE EXCEPTIONS ─────────────────────────────── */
/* Scoped to .att-page so glass.css table/input rules don't blow up
   the dense attendance grid and the Worker Advance modal. */

/* CRITICAL: Override table { width: 100% } that stretches the grid.
   The grid needs width:auto so it respects min-width and scrolls. */
.att-page .grid-wrap {
  overflow-x: auto !important;
  overflow-y: visible !important;
  padding: 12px !important;
  -webkit-overflow-scrolling: touch !important;
}
.att-page table.att-grid {
  width: auto !important;
  min-width: 1100px !important;
  border-collapse: collapse !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
}

/* Restore the attendance grid table cells */
.att-page table.att-grid th {
  font-size: 10px !important;
  font-weight: 600 !important;
  padding: 6px 3px !important;
  text-align: center !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
  background: var(--surface2) !important;
  border: 1px solid var(--border) !important;
  color: var(--text3) !important;
}
.att-page table.att-grid th.worker-col {
  text-align: left !important;
  padding: 6px 10px !important;
  min-width: 110px !important;
  position: sticky !important;
  left: 0 !important;
  z-index: 2 !important;
}
.att-page table.att-grid th.tot-head {
  font-size: 9px !important;
  background: var(--surface3) !important;
}
.att-page table.att-grid td {
  padding: 2px !important;
  font-size: 12px !important;
  text-align: center !important;
  vertical-align: top !important;
  border: 1px solid var(--border) !important;
}
.att-page table.att-grid td.worker-name-cell {
  text-align: left !important;
  padding: 6px 10px !important;
  font-weight: 500 !important;
  white-space: nowrap !important;
  background: var(--surface2) !important;
  position: sticky !important;
  left: 0 !important;
  z-index: 1 !important;
  border-right: 2px solid var(--border2) !important;
}
.att-page table.att-grid td.tot-cell {
  font-size: 11px !important;
  font-weight: 600 !important;
  padding: 4px 6px !important;
  white-space: nowrap !important;
  vertical-align: middle !important;
  background: var(--surface2) !important;
  font-family: var(--mono) !important;
}
.att-page table.att-grid tbody tr:hover {
  background: transparent !important;
}
.att-page table.att-grid td.sun-cell {
  background: #faf5ff !important;
}
.att-page table.att-grid tbody tr:last-child td {
  border-bottom: 1px solid var(--border) !important;
}

/* Restore status buttons inside the grid */
.att-page .status-btn {
  display: block !important;
  width: 34px !important;
  height: 22px !important;
  border-radius: 4px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 0 !important;
  margin: 1px auto !important;
  line-height: 1 !important;
  cursor: pointer !important;
  border: none !important;
  transition: background .1s !important;
}
.att-page .status-btn.empty {
  font-size: 9px !important;
}
.att-page .status-btn.sun-p {
  font-size: 13px !important;
}

/* Restore OT input */
.att-page .ot-input {
  display: block !important;
  width: 34px !important;
  height: 18px !important;
  border: 1px solid var(--border) !important;
  border-radius: 3px !important;
  text-align: center !important;
  font-size: 10px !important;
  padding: 0 !important;
  margin: 1px auto !important;
  line-height: 1 !important;
  background: var(--surface2) !important;
  color: var(--text) !important;
  outline: none !important;
  font-family: var(--mono) !important;
}
.att-page .day-cell {
  padding: 2px 1px !important;
  min-width: 38px !important;
}

/* Restore the Worker Advance modal */
.att-page #advModal {
  display: none !important;
}
.att-page #advModal.on,
.att-page #advModal.show,
.att-page #advModal[style*="display:flex"],
.att-page #advModal[style*="display: flex"] {
  display: flex !important;
}
.att-page #advModal .mhead {
  padding: 12px 16px !important;
  border-bottom: 1px solid var(--border) !important;
  background: var(--surface) !important;
}
.att-page #advModal .mhead-title {
  font-size: 14px !important;
  font-weight: 600 !important;
}
.att-page #advModal .mbody {
  padding: 16px !important;
  gap: 12px !important;
}
.att-page #advModal .mfoot {
  padding: 10px 16px !important;
  border-top: 1px solid var(--border) !important;
  background: var(--surface2) !important;
}
.att-page #advModal .fg label {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--text3) !important;
  margin-bottom: 3px !important;
}
.att-page #advModal .fg input,
.att-page #advModal .fg select,
.att-page #advModal .fg textarea {
  width: 100% !important;
  padding: 8px 10px !important;
  font-size: 13px !important;
  border: 1px solid var(--border) !important;
  background: var(--surface2) !important;
  color: var(--text) !important;
  font-family: var(--font) !important;
}
.att-page #advModal .adv-item {
  padding: 7px 10px !important;
  font-size: 12px !important;
  border-bottom: 1px solid var(--border) !important;
}

/* MOBILE: Key fix — reduce table content width so scroll appears naturally */
@media (max-width: 768px) {
  .att-page table.att-grid {
    min-width: 650px !important;
    width: auto !important;
  }
  
  .att-page table.att-grid th,
  .att-page table.att-grid td {
    padding: 2px 0.5px !important;
    font-size: 9px !important;
  }
  
  .att-page table.att-grid th.worker-col,
  .att-page table.att-grid td.worker-name-cell {
    padding: 4px 5px !important;
    min-width: 65px !important;
  }
  
  .att-page .day-cell {
    min-width: 28px !important;
  }
  
  .att-page .status-btn {
    width: 24px !important;
    height: 16px !important;
    font-size: 8px !important;
    padding: 0 !important;
    margin: 1px auto !important;
  }
  
  .att-page .ot-input {
    width: 24px !important;
    height: 14px !important;
    font-size: 7px !important;
    padding: 0 !important;
  }
}
