/* ===== Design System: Warm Professional — Workforce Management ===== */

/* --- Custom Properties (Design Tokens) --- */
:root {
  --color-primary: #1e2a4a;
  --color-primary-hover: #162040;
  --color-primary-light: #e8ecf4;
  --color-secondary: #4a5568;
  --color-secondary-light: #8a94a6;
  --color-accent: #e8654a;
  --color-accent-hover: #d4552e;
  --color-success: #4a9e7a;
  --color-success-bg: #e6f5ee;
  --color-success-text: #1e6b4a;
  --color-error: #d94452;
  --color-error-bg: #fce8ea;
  --color-error-text: #a31b28;
  --color-warning-bg: #fef3d6;
  --color-warning-text: #8a6414;
  --color-bg: #faf8f5;
  --color-card: #ffffff;
  --color-border: #e8e4df;
  --color-text: #2d2d2d;
  --color-text-muted: #7a7a7a;
  --color-draft-bg: #f2f0ed;
  --color-draft-text: #5a5a5a;
  --color-locked-bg: #e8e4df;
  --color-locked-text: #2d2d2d;

  --font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: ui-monospace, 'SF Mono', 'Cascadia Code', 'Consolas', monospace;
  --font-size-base: 15px;
  --font-size-sm: 14px;
  --font-size-xs: 11px;
  --font-size-h1: 22px;
  --font-size-h2: 18px;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;

  --radius-sm: 8px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-pill: 20px;

  --shadow-sm: 0 1px 3px rgba(45,45,45,0.04);
  --shadow-md: 0 2px 8px rgba(45,45,45,0.06);
  --shadow-lg: 0 8px 24px rgba(45,45,45,0.1);

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-12: 48px;
}

/* --- Base Reset --- */
*, *::before, *::after { box-sizing: border-box; }

html body {
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-normal);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.55;
  margin: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* --- Bootstrap Overrides --- */
body .container, body .container-fluid, body .container-sm, body .container-md, body .container-lg, body .container-xl, body .container-xxl {
  font-family: var(--font-family);
}

body .card {
  background: var(--color-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  border: none;
  padding: var(--space-6);
  margin-bottom: var(--space-5);
}
body .card-compact { padding: var(--space-4); }

body .btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font-family: var(--font-family); font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold);
  padding: 10px 20px; border-radius: var(--radius-md);
  border: 2px solid transparent; cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none; line-height: 1.4;
  min-height: 44px;
  letter-spacing: 0.01em;
}
body .btn:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  box-shadow: none;
}
body .btn-sm {
  font-size: var(--font-size-xs); padding: 6px 14px; min-height: 36px;
  border-radius: var(--radius-sm);
}
body .btn-primary {
  background: var(--color-accent); color: #fff; border-color: var(--color-accent);
}
body .btn-primary:hover, body .btn-primary:focus {
  background: var(--color-accent-hover); border-color: var(--color-accent-hover); color: #fff;
  transform: translateY(-1px); box-shadow: 0 4px 12px rgba(232,101,74,0.25);
}
body .btn-secondary {
  background: var(--color-card); color: var(--color-primary); border-color: var(--color-border);
}
body .btn-secondary:hover, body .btn-secondary:focus {
  background: var(--color-bg); border-color: var(--color-secondary-light); color: var(--color-primary);
}
body .btn-danger {
  background: var(--color-error); color: #fff; border-color: var(--color-error);
}
body .btn-danger:hover, body .btn-danger:focus {
  background: #c13040; border-color: #c13040; color: #fff;
}
body .btn-ghost {
  background: transparent; border-color: transparent; color: var(--color-accent);
}
body .btn-ghost:hover {
  background: rgba(232,101,74,0.08); color: var(--color-accent-hover);
}
body .btn-outline-primary {
  background: transparent; color: var(--color-accent); border-color: var(--color-accent);
}
body .btn-outline-primary:hover {
  background: var(--color-accent); color: #fff;
}
body .btn-outline-secondary {
  background: transparent; color: var(--color-secondary); border-color: var(--color-border);
}
body .btn-outline-secondary:hover {
  background: var(--color-bg); color: var(--color-text); border-color: var(--color-secondary-light);
}

/* Bootstrap form overrides */
body .form-control, body .form-select {
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  background-color: var(--color-card);
  color: var(--color-text);
  padding: 10px 14px;
  min-height: 48px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
body .form-control:focus, body .form-select:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(232,101,74,0.15);
  outline: none;
}
body .form-control-sm {
  min-height: auto;
  padding: 6px 10px;
}
body .form-label {
  font-weight: var(--font-weight-semibold);
  color: var(--color-secondary);
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-1);
}

/* Bootstrap table overrides */
body .table {
  --bs-table-bg: transparent;
  --bs-table-border-color: var(--color-border);
  font-family: var(--font-family);
}
body .table > thead > tr > th {
  background: var(--color-bg);
  color: var(--color-text-muted);
  font-weight: var(--font-weight-semibold);
  border-bottom: 2px solid var(--color-border);
  padding: 14px 16px;
}
body .table > tbody > tr > td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
}
body .table > tbody > tr:hover > td {
  background: #f8f5f1;
}

/* Bootstrap alert overrides */
body .alert {
  border-radius: var(--radius-md);
  border: none;
  font-family: var(--font-family);
}

/* Bootstrap badge override */
body .badge:not(.nav-badge) {
  font-family: var(--font-family);
  font-weight: var(--font-weight-semibold);
  border-radius: var(--radius-pill);
}

/* Bootstrap nav override */
body .navbar, body .nav {
  font-family: var(--font-family);
}

/* Bootstrap row/col override for warm feel */
.row {
  --bs-gutter-x: 1.25rem;
}

/* --- Typography --- */
body h1, body h2, body h3, body h4 {
  font-family: var(--font-family);
  font-weight: var(--font-weight-bold);
  margin: 0 0 var(--space-4);
  color: var(--color-primary);
}
body h1 { font-size: var(--font-size-h1); }
body h2 { font-size: var(--font-size-h2); }
body .text-muted { color: var(--color-text-muted); font-size: var(--font-size-sm); }

a {
  color: var(--color-accent);
  text-decoration: none;
  transition: color 0.15s;
}
a:hover { color: var(--color-accent-hover); }

/* --- Nav Bar — Deep Navy with Warm Accents --- */
.app-header {
  background: linear-gradient(180deg, #1e2a4a 0%, #172040 100%);
  position: sticky; top: 0; z-index: 40;
  box-shadow: 0 2px 16px rgba(30,42,74,0.18);
}
.app-nav-scroll-wrap {
  position: relative;
}
.app-nav-scroll-wrap.has-overflow::after {
  content: ''; position: absolute; right: 0; top: 0; bottom: 0; width: 48px;
  background: linear-gradient(90deg, transparent, rgba(30,42,74,0.9));
  pointer-events: none; z-index: 2;
}
.app-nav-scroll-wrap.scrolled-end::after { display: none; }
.app-nav-row {
  display: flex; gap: var(--space-1); padding: var(--space-3) var(--space-4);
  overflow-x: auto; white-space: nowrap;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.app-nav-row::-webkit-scrollbar { display: none; }
body .nav-link {
  color: rgba(255,255,255,0.7); text-decoration: none;
  font-size: var(--font-size-sm); font-weight: var(--font-weight-medium);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm);
  transition: all 0.2s ease;
  min-height: 44px; display: inline-flex; align-items: center;
  position: relative;
  border-bottom: 2px solid transparent;
}
body .nav-link:hover {
  color: #fff;
  background: rgba(255,255,255,0.06);
}
body .nav-link.active {
  color: #fff;
  background: transparent;
  border-bottom-color: var(--color-accent);
  font-weight: var(--font-weight-semibold);
}
.nav-badge {
  background: var(--color-accent); color: #fff;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-bold);
  padding: 2px 8px; border-radius: var(--radius-pill);
  margin-left: var(--space-1);
}

/* --- Layout --- */
.main-container { max-width: 1200px; margin: 0 auto; padding: var(--space-8) var(--space-4); }
@media (max-width: 720px) {
  .main-container { padding: var(--space-5) var(--space-3); }
}

/* --- Cards (standalone, non-Bootstrap) --- */
/* Already handled by .card above */

/* --- Buttons (standalone) --- */
/* Already handled by .btn above */

/* --- Status Badges --- */
.badge {
  display: inline-block; font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
  padding: 3px 12px; border-radius: var(--radius-pill);
  text-transform: uppercase; letter-spacing: 0.5px;
}
.badge-pending { background: var(--color-warning-bg); color: var(--color-warning-text); }
.badge-approved, .badge-reviewed { background: var(--color-success-bg); color: var(--color-success-text); }
.badge-rejected { background: var(--color-error-bg); color: var(--color-error-text); }
.badge-draft { background: var(--color-draft-bg); color: var(--color-draft-text); }
.badge-locked { background: var(--color-locked-bg); color: var(--color-locked-text); }

/* --- Tables --- */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
table { width: 100%; border-collapse: collapse; }
th {
  background: var(--color-bg); color: var(--color-text-muted);
  font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold);
  text-align: left; padding: 14px 16px;
  border-bottom: 2px solid var(--color-border);
  text-transform: uppercase; letter-spacing: 0.4px;
}
td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
}
tr:hover td { background: #f8f5f1; }
.num { font-variant-numeric: tabular-nums; text-align: right; font-family: var(--font-mono); }

/* --- Forms --- */
label {
  display: block; font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold);
  color: var(--color-secondary); margin-bottom: var(--space-1);
}
input[type="text"], input[type="email"], input[type="password"], input[type="number"],
input[type="date"], input[type="time"], input[type="tel"], select, textarea {
  width: 100%; font-family: var(--font-family); font-size: var(--font-size-base);
  padding: 12px 14px; border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md); background: var(--color-card);
  transition: border-color 0.2s, box-shadow 0.2s;
  min-height: 48px;
  color: var(--color-text);
}
input:focus, select:focus, textarea:focus {
  outline: none; border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(232,101,74,0.15);
}
input::placeholder, textarea::placeholder {
  color: #b0aaa2;
}
.form-group { margin-bottom: var(--space-5); }
.form-row { display: grid; gap: var(--space-4); }
@media (min-width: 540px) { .form-row-2 { grid-template-columns: 1fr 1fr; } }
@media (min-width: 768px) { .form-row-3 { grid-template-columns: 1fr 1fr 1fr; } }

/* --- Flash Messages — Full-width banners with left accent bar --- */
.flash {
  padding: var(--space-4) var(--space-5); border-radius: var(--radius-md);
  margin-bottom: var(--space-5); font-size: var(--font-size-sm); font-weight: var(--font-weight-medium);
  border-left: 4px solid transparent;
}
.flash-info { background: var(--color-primary-light); color: var(--color-primary); border-left-color: var(--color-primary); }
.flash-error, .flash-danger { background: var(--color-error-bg); color: var(--color-error-text); border-left-color: var(--color-error); }
.flash-success { background: var(--color-success-bg); color: var(--color-success-text); border-left-color: var(--color-success); }
.flash-warning { background: var(--color-warning-bg); color: var(--color-warning-text); border-left-color: #d4922a; }

/* --- Page Header Pattern --- */
.page-head { margin-bottom: var(--space-8); }
.page-title {
  font-size: var(--font-size-h1); font-weight: 800;
  color: var(--color-primary); margin: 0;
  letter-spacing: -0.02em;
}
.page-subtitle { font-size: var(--font-size-sm); color: var(--color-text-muted); margin-top: var(--space-1); }

/* --- Filter Bar --- */
.filter-card {
  background: var(--color-card); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm); padding: var(--space-5);
  margin-bottom: var(--space-5);
  display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: end;
  border: 1px solid var(--color-border);
}

/* --- Empty State --- */
.empty-state { text-align: center; padding: var(--space-12) var(--space-4); color: var(--color-text-muted); }
.empty-state-icon { font-size: 48px; margin-bottom: var(--space-4); opacity: 0.25; }

/* --- Mobile Cards (table replacement) --- */
.mobile-card-list { display: none; }
@media (max-width: 640px) {
  .desktop-table { display: none; }
  .mobile-card-list { display: block; }
}
.mobile-card {
  background: var(--color-card); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm); padding: var(--space-5);
  margin-bottom: var(--space-3);
  border: 1px solid var(--color-border);
}
.mobile-card-row { display: flex; justify-content: space-between; align-items: center; padding: var(--space-2) 0; }
.mobile-card-label { font-size: var(--font-size-sm); color: var(--color-text-muted); }
.mobile-card-value { font-weight: var(--font-weight-semibold); }
.mobile-card-header {
  font-weight: var(--font-weight-bold); font-size: var(--font-size-base);
  margin-bottom: var(--space-3); border-bottom: 1px solid var(--color-border);
  padding-bottom: var(--space-3); color: var(--color-primary);
}

/* --- Skip Link (accessibility) --- */
.skip-link {
  position: absolute; top: -40px; left: 0;
  background: var(--color-primary); color: #fff; padding: var(--space-2) var(--space-4);
  z-index: 9999; transition: top 0.2s;
  border-radius: 0 0 var(--radius-sm) 0;
  font-weight: var(--font-weight-semibold);
}
.skip-link:focus { top: 0; color: #fff; }

/* --- Utility --- */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
.flex { display: flex; }
.flex-between { display: flex; justify-content: space-between; align-items: center; }
.flex-wrap { flex-wrap: wrap; }
.gap-2 { gap: var(--space-2); }
.gap-3 { gap: var(--space-3); }
.gap-4 { gap: var(--space-4); }
.mt-4 { margin-top: var(--space-4); }
.mb-4 { margin-bottom: var(--space-4); }
.text-right { text-align: right; }
.text-center { text-align: center; }
.font-mono { font-variant-numeric: tabular-nums; font-family: var(--font-mono); }

/* --- Login / Signup Page --- */
.login-page-wrap { max-width: 420px; margin: 0 auto; }

/* ===== Employees page ===== */

/* Back link */
.back-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 600; color: var(--color-text-muted);
  text-decoration: none; transition: color .15s;
}
.back-link:hover { color: var(--color-primary); }

/* Search bar */
.emp-search { margin-bottom: 14px; position: relative; }
.emp-search input {
  width: 100%; max-width: 400px;
  padding: 12px 14px 12px 38px; font-size: 14px;
  border: 1.5px solid var(--color-border); border-radius: var(--radius-md);
  background: #fff; outline: none; min-height: 48px;
}
.emp-search input:focus { border-color: var(--color-accent); box-shadow: 0 0 0 3px rgba(232,101,74,.15); }
.emp-search-icon {
  position: absolute; left: 13px; top: 50%; transform: translateY(-50%);
  color: #b0aaa2; font-size: 14px; pointer-events: none;
}

/* Create employee collapsible panel */
.create-panel {
  margin-bottom: 20px; border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); background: #fff; overflow: hidden;
}
.create-panel > summary {
  list-style: none; padding: 14px 18px; font-weight: 700;
  font-size: 14px; cursor: pointer; color: var(--color-primary);
  background: var(--color-bg); border-bottom: 1px solid var(--color-border);
  transition: background .15s;
}
.create-panel > summary:hover { background: #f2eeea; }
.create-panel > summary::-webkit-details-marker { display: none; }
.create-panel[open] > summary { border-bottom: 1px solid var(--color-border); }
.create-panel-body { padding: 18px 18px; }
.create-section-label {
  font-weight: 700; font-size: 12px; text-transform: uppercase;
  letter-spacing: .04em; color: var(--color-text-muted); margin: 0 0 10px;
}
.create-section-label:not(:first-child) { margin-top: 20px; }
.employee-create-form { max-width: 1020px; }
.employee-create-form .row > div { min-width: 210px; }

/* Section dividers */
.section-divider { border: none; border-top: 1px solid var(--color-border); margin: 24px 0 16px; }
.section-head { display: flex; align-items: baseline; gap: 8px; margin: 0 0 12px; }
.section-title { font-size: 16px; font-weight: 800; margin: 0; color: var(--color-primary); }

/* Deactivate panel */
.deactivate-panel {
  margin-top: 10px; padding: 12px; border: 1px solid var(--color-border);
  border-radius: var(--radius-md); background: var(--color-bg);
}

/* Desktop table — employees page uses 900px breakpoint */
.emp-table-wrap { }
@media (max-width: 900px) {
  .emp-table-wrap .desktop-table { display: none; }
  .emp-cards { display: block !important; }
  .employee-create-form { max-width: 100%; }
  .employee-create-form .row > div { min-width: 0; }
}
.emp-cards { display: none; }
@media (max-width: 900px) { .emp-cards { display: block; } }
@media (min-width: 641px) and (max-width: 900px) {
  .emp-table-wrap .desktop-table { display: none; }
}

/* ===== Employee Entries page (720px breakpoint) ===== */

.ee-desktop-table { }
.ee-mobile-list { display: none; }

/* Row highlight */
tr.ee-stratford td { background: #fdf8ee; }
tr.ee-stratford:hover td { background: #faf2e2; }
tr.ee-holiday td { background: var(--color-bg); }
tr.ee-holiday:hover td { background: #f2eeea; }

/* Mobile card items */
.ee-mobile-card {
  padding: 16px 18px; border-bottom: 1px solid var(--color-border);
}
.ee-mobile-card:last-child { border-bottom: none; }
.ee-mobile-card.stratford { border-left: 3px solid #d4922a; }
.ee-mobile-card.holiday { border-left: 3px solid #c5c0ba; }

@media (max-width: 720px) {
  .ee-desktop-table { display: none; }
  .ee-mobile-list { display: block; }
}

/* ===== Employee Entries Readonly (My Hours) page ===== */

/* Period selector */
.period-select {
  min-width: 320px; font-weight: 600; font-size: 15px;
  padding: 12px 14px; border-radius: var(--radius-md);
  border: 1.5px solid var(--color-border); background: #fff;
  transition: border-color .15s, box-shadow .15s; cursor: pointer;
  font-family: var(--font-family);
}
.period-select:focus {
  outline: none; border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(232,101,74,.15);
}

/* Summary cards */
.my-hours-summary { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 24px; }
.summary-card {
  border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  padding: 20px 22px; background: #fff;
  position: relative; overflow: hidden;
}
.summary-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--color-primary), #3a4f7a);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.summary-label {
  font-size: 11px; color: var(--color-text-muted); margin-bottom: 10px;
  text-transform: uppercase; letter-spacing: .05em; font-weight: 600;
}
.summary-value {
  font-size: 32px; font-weight: 800; line-height: 1; color: var(--color-primary);
  font-family: var(--font-mono);
}
.summary-value-row { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.summary-premium {
  font-size: 12px; font-weight: 700; color: var(--color-warning-text);
  background: var(--color-warning-bg); border: 1px solid #f0d78a;
  border-radius: 999px; padding: 3px 10px;
}

/* Week groups */
.week-group {
  margin-bottom: 14px; border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); overflow: hidden; background: #fff;
  transition: box-shadow .2s;
}
.week-group:hover { box-shadow: var(--shadow-md); }
.week-group-head {
  background: var(--color-bg); padding: 14px 18px;
  display: flex; justify-content: space-between; align-items: center; gap: 8px;
  border-bottom: 1px solid var(--color-border);
  cursor: pointer; user-select: none; transition: background .15s;
}
.week-group-head:hover { background: #f2eeea; }
.week-range { font-weight: 700; font-size: 13px; color: var(--color-primary); }
.week-total-badge {
  font-size: 13px; font-weight: 800; color: var(--color-primary);
  background: #fff; border: 1px solid var(--color-border);
  border-radius: 999px; padding: 4px 14px;
  font-family: var(--font-mono);
}
.week-collapse-icon { font-size: 12px; color: var(--color-text-muted); transition: transform .2s; margin-left: 4px; }
.week-group.collapsed .week-collapse-icon { transform: rotate(-90deg); }
.week-group.collapsed .week-group-body { display: none; }

/* Shift row highlights */
.stratford-row { background: #fdf8ee; }
.stratford-row:hover { background: #faf2e2; }
.stratford-badge, .holiday-badge {
  display: inline-block; font-size: 10px; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase;
  color: var(--color-warning-text); background: var(--color-warning-bg); border: 1px solid #f0d78a;
  border-radius: 999px; padding: 2px 8px; vertical-align: middle;
}
.holiday-row { background: var(--color-bg); }
.holiday-row:hover { background: #f2eeea; }
.holiday-note { color: var(--color-warning-text); font-weight: 700; }
.hours-col { white-space: nowrap; font-family: var(--font-mono); }
.paid-flag {
  display: inline-block; color: var(--color-success-text); font-weight: 800; font-size: 10px;
  letter-spacing: .04em; text-transform: uppercase;
  background: var(--color-success-bg); border: 1px solid #8edbb5;
  border-radius: 999px; padding: 1px 7px;
}

/* Desktop/mobile toggle for hours tables */
.desktop-hours-table { }
.desktop-hours-table table { background: #fff; }
.desktop-hours-table table tbody tr { transition: background .1s; }
.desktop-hours-table table tbody tr:hover { background: #f8f5f1; }
.desktop-hours-table table tbody tr.stratford-row:hover { background: #faf2e2; }
.desktop-hours-table table tbody tr.holiday-row:hover { background: #f2eeea; }
.mobile-hours-list { display: none; }

.mobile-shift {
  padding: 16px 18px; border-top: 1px solid var(--color-border); transition: background .1s;
}
.mobile-shift:hover { background: #f8f5f1; }
.mobile-shift:last-child { border-bottom: none; }
.mobile-shift.stratford-row { border-left: 3px solid #d4922a; }
.mobile-shift.stratford-row:hover { background: #faf2e2; }
.mobile-shift.holiday-row { border-left: 3px solid #c5c0ba; }
.mobile-shift.holiday-row:hover { background: #f2eeea; }

@media (max-width: 720px) {
  .my-hours-summary { grid-template-columns: 1fr; gap: 10px; margin-bottom: 20px; }
  .period-select { min-width: 100%; font-size: 15px; }
  .desktop-hours-table { display: none; }
  .mobile-hours-list { display: block; }
  .summary-card { padding: 16px 18px; }
  .summary-value { font-size: 28px; }
  .week-group-head {
    flex-direction: column; align-items: flex-start;
    gap: 4px; padding: 14px 16px;
  }
  .week-range { font-size: 14px; }
  .mobile-shift { padding: 14px 16px; }
  .filter-card { padding: var(--space-4); margin-bottom: var(--space-4); display: block; }
  .filter-card .form-group { margin-bottom: var(--space-3); }
  .filter-card select,
  .filter-card input[type="date"],
  .filter-card input[type="text"],
  .filter-card input[type="number"] { width: 100%; }
}
@media (min-width: 721px) {
  .my-hours-summary { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
}

/* --- Logout Button (in nav) --- */
.nav-logout-form { display: inline; }
.nav-logout-btn {
  background: none; border: none; cursor: pointer;
  color: rgba(255,255,255,0.65); font: inherit;
  font-size: var(--font-size-sm); font-weight: var(--font-weight-medium);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm);
  transition: all 0.2s;
}
.nav-logout-btn:hover { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.95); }
.nav-logout-btn:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }

/* --- Timesheet Specific --- */

/* z-index plan: header th 4, sticky-col 3, corner 5, save-bar 30, mobile-ctx 50 */

/* Period selector */
.ts-period-select-wrap { position: relative; display: inline-block; }
.ts-period-select {
  padding: 10px 40px 10px var(--space-4);
  font-size: var(--font-size-base); font-weight: var(--font-weight-semibold);
  border: 1.5px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-card); color: var(--color-text);
  min-width: 340px; appearance: none; -webkit-appearance: none;
  cursor: pointer; transition: border-color .15s, box-shadow .15s;
  font-family: var(--font-family);
}
.ts-period-select:focus {
  outline: none; border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(232,101,74,.15);
}
.ts-period-select-wrap::after {
  content: ''; position: absolute; right: 14px; top: 50%; transform: translateY(-50%);
  border: 5px solid transparent; border-top: 6px solid var(--color-text-muted);
  pointer-events: none;
}

/* Card section label (small uppercase label inside cards) */
.ts-card-label {
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
  color: var(--color-text-muted); text-transform: uppercase;
  letter-spacing: .04em; margin-bottom: var(--space-2);
}
.ts-field-label {
  display: block; font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
  color: var(--color-text-muted); text-transform: uppercase;
  letter-spacing: .04em; margin-bottom: var(--space-1);
}
.ts-help { font-size: 12px; color: var(--color-secondary-light); margin-top: var(--space-1); }

/* Week tiles (period jump navigation) */
.week-tiles { display: flex; flex-wrap: wrap; gap: var(--space-1); }
.week-tile {
  border: 1px solid var(--color-border); background: var(--color-card);
  border-radius: var(--radius-sm); padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold);
  color: var(--color-secondary); cursor: pointer; transition: all .15s;
  font-family: var(--font-family);
}
.week-tile:hover { background: var(--color-bg); border-color: var(--color-secondary-light); color: var(--color-text); }
.week-tile:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }
.week-tile.active {
  border-color: var(--color-primary); background: var(--color-primary); color: #fff;
  box-shadow: var(--shadow-sm);
}

/* Status card row (period lock/review status) */
.ts-status-card {
  background: var(--color-card); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-4); display: flex; flex-wrap: wrap;
  align-items: center; gap: var(--space-3);
}
.ts-status-actions { display: flex; gap: var(--space-1); align-items: center; margin-left: auto; }
.ts-status-meta { font-size: 12px; color: var(--color-secondary-light); }

/* Week nav (non-period week navigation) */
.ts-week-nav-card {
  background: var(--color-card); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-4);
}
.week-nav { display: flex; align-items: center; gap: var(--space-2); justify-content: center; }
.week-nav-label {
  font-weight: var(--font-weight-semibold); font-size: var(--font-size-base);
  color: var(--color-text); min-width: 220px; text-align: center;
}

/* Period details toggle suppression */
details.ts-period-week > summary { list-style: none; cursor: default; pointer-events: none; }
details.ts-period-week > summary::-webkit-details-marker { display: none; }

/* Week summary header */
.ts-week-head {
  font-weight: var(--font-weight-semibold); font-size: var(--font-size-base);
  color: var(--color-text); margin: var(--space-3) 0 var(--space-2); cursor: pointer;
}

/* Toolbar */
.ts-toolbar {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2);
  margin-bottom: var(--space-4); background: var(--color-bg);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
}
.ts-toolbar-push { margin-left: auto; display: flex; gap: var(--space-2); align-items: center; }

/* Manage panel (roster add/copy/reorder) */
.ts-manage-panel {
  display: none; background: var(--color-bg); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-3); flex-wrap: wrap; gap: var(--space-2); align-items: flex-end;
}
.ts-manage-panel.visible { display: flex; }
.ts-manage-group { display: flex; gap: var(--space-2); align-items: flex-end; }
.ts-manage-group select { font-size: var(--font-size-sm); padding: 8px var(--space-3); width: auto; }

/* Scroll wrapper + grid chrome */
.ts-grid-wrap {
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-card);
}

/* Grid table */
.ts-grid {
  border-collapse: separate; border-spacing: 0;
  width: 100%; background: var(--color-card);
  font-size: var(--font-size-sm);
}

/* Sticky header row */
.ts-grid thead th {
  position: sticky; top: 0; z-index: 4;
  background: var(--color-bg); border-bottom: 2px solid var(--color-border);
  padding: var(--space-2) var(--space-2); text-align: center;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
  color: var(--color-secondary); white-space: nowrap;
  text-transform: none; letter-spacing: normal;
}
.ts-grid thead th:first-child { text-align: left; }

/* Sticky employee-name column */
.ts-grid th:first-child,
.ts-grid td:first-child {
  position: sticky; left: 0; z-index: 3; background: inherit;
  min-width: 130px; width: 1%; white-space: nowrap;
}
.ts-grid thead th:first-child { z-index: 5; background: var(--color-bg); }

/* Scroll shadow when scrolled horizontally */
.ts-grid-wrap.is-scrolled td:first-child::after,
.ts-grid-wrap.is-scrolled th:first-child::after {
  content: ''; position: absolute; top: 0; bottom: 0; right: -5px; width: 5px;
  background: linear-gradient(90deg, rgba(45,45,45,.045), transparent);
  pointer-events: none;
}

/* Body cells */
.ts-grid td {
  padding: var(--space-1) var(--space-1); vertical-align: top;
  border-bottom: 1px solid #f0ece7; position: relative;
}
.ts-grid tbody tr:last-child td { border-bottom: none; }

/* Department separator row */
.ts-dept td {
  background: #ede9e3; font-weight: 800; font-size: var(--font-size-xs);
  text-transform: uppercase; letter-spacing: .04em;
  color: var(--color-text-muted); padding: var(--space-1) var(--space-2);
  border-bottom: 1px solid var(--color-border);
}

/* Employee name cell */
.ts-name { display: flex; align-items: center; gap: var(--space-1); padding: 2px 0; }
.ts-name strong { font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold); color: var(--color-text); }
.ts-name .row-controls { margin-left: auto; display: none; align-items: center; gap: var(--space-1); }
details.controls-visible .ts-name .row-controls { display: flex; }
details.controls-visible .ts-grid td:first-child,
details.controls-visible .ts-grid th:first-child { min-width: 220px; }

/* Row states */
.ts-row td { background: var(--color-card); transition: background .08s; }
.ts-row:nth-child(even of .ts-row) td { background: #fdfcfa; }
.ts-row:hover td { background: #f8f5f1; }
.ts-row.active td { background: #eaf0f8; }
.ts-row:nth-child(even of .ts-row) td:first-child { background: #fdfcfa; }
.ts-row:hover td:first-child { background: #f8f5f1; }
.ts-row.active td:first-child { background: #eaf0f8; }

/* Today column */
th.ts-today { background: #edf0f8; color: var(--color-primary); border-bottom-color: #8aa0d4; }
th.ts-today .today-dot {
  display: inline-block; width: 5px; height: 5px;
  background: var(--color-accent); border-radius: 50%; margin-left: 3px; vertical-align: middle;
}
td.ts-today { background: #f5f4f8; }
.ts-row:hover td.ts-today { background: #eae8f0; }
.ts-row.active td.ts-today { background: #e2e0f0; }

/* Holiday + outside-period cells */
td.ts-holiday { background: var(--color-warning-bg); }
.ts-row:hover td.ts-holiday { background: #fdefc5; }
.ts-row.active td.ts-holiday { background: var(--color-warning-bg); }
td.ts-outside { background: var(--color-bg); }
th.ts-outside { background: var(--color-draft-bg); color: var(--color-text-muted); }

/* Cell flags (holiday/outside/stratford) */
.ts-flag {
  display: inline-block; margin-bottom: var(--space-1);
  font-size: 9px; font-weight: 800; text-transform: uppercase;
  letter-spacing: .04em; border-radius: var(--radius-pill); padding: 1px 7px;
}
.ts-flag-holiday  { color: var(--color-warning-text); background: var(--color-warning-bg); border: 1px solid #f0d78a; }
.ts-flag-outside  { color: var(--color-draft-text); background: var(--color-draft-bg); border: 1px solid var(--color-border); }
.ts-flag-stratford { color: var(--color-warning-text); background: var(--color-warning-bg); border: 1px solid #f0d78a; }

/* Shift input pair container */
.ts-cell { display: flex; flex-direction: column; gap: 3px; }
.ts-shift-row { display: flex; align-items: center; gap: 3px; flex-wrap: wrap; }
.ts-shift-row .sep { color: var(--color-secondary-light); font-size: var(--font-size-sm); }

/* Time inputs (narrow, tabular) */
.ts-grid input.t,
.ts-grid .form-control-sm.t {
  width: 64px; min-width: 64px; padding: 4px 6px;
  font-size: var(--font-size-sm); border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm); font-variant-numeric: tabular-nums;
  background: var(--color-card); transition: border-color .15s, box-shadow .15s;
  min-height: unset;
  font-family: var(--font-family);
}
.ts-grid input.t::placeholder,
.ts-grid .form-control-sm.t::placeholder { color: #c5c0ba; opacity: 1; font-weight: 400; }
.ts-grid input.t:focus,
.ts-grid .form-control-sm.t:focus {
  outline: none; border-color: var(--color-accent);
  box-shadow: 0 0 0 2px rgba(232,101,74,.18);
}
.ts-grid input.t:disabled,
.ts-grid .form-control-sm.t:disabled {
  background: var(--color-bg); color: var(--color-secondary-light); border-color: var(--color-border);
}

/* Filled-cell dot indicator */
.ts-cell.has-data::before {
  content: ''; position: absolute; top: 4px; right: 4px;
  width: 5px; height: 5px; background: var(--color-success);
  border-radius: 50%; pointer-events: none;
}

/* Stratford label */
.ts-strat-label {
  display: flex; gap: 5px; align-items: center;
  margin-bottom: 3px; font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-xs); color: var(--color-text-muted);
}

/* Extras (More details) */
details.ts-extras > summary { cursor: pointer; user-select: none; color: var(--color-text-muted); font-size: var(--font-size-xs); }
details.ts-extras > summary::-webkit-details-marker { display: none; }
.ts-extras-body { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-1); margin-top: var(--space-1); }
.ts-extras-body .full { grid-column: 1 / -1; }
.ts-extras-body .divider {
  grid-column: 1 / -1; border-top: 1px solid var(--color-border);
  padding-top: var(--space-1); margin-top: 2px;
}

/* Warn badge (suspicious long shift) */
.ts-grid .warn-badge { padding: 1px 6px; gap: 4px; font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold); }
.ts-grid .review-btn { margin-left: var(--space-1); padding: 1px 6px; font-size: var(--font-size-xs); line-height: 1.1; border-radius: var(--radius-pill); }

/* Save bar (sticky bottom) */
.ts-save {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-5); margin-top: var(--space-3);
  background: var(--color-card); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); position: sticky; bottom: 10px;
  z-index: 30; box-shadow: 0 -2px 16px rgba(45,45,45,.08);
}
.ts-save-btn {
  padding: 8px 24px; font-size: var(--font-size-sm); font-weight: var(--font-weight-bold);
  border-radius: var(--radius-md); background: var(--color-accent); color: #fff;
  border: none; cursor: pointer; white-space: nowrap;
  transition: all .15s; font-family: var(--font-family);
}
.ts-save-btn:hover { background: var(--color-accent-hover); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(232,101,74,.25); }
.ts-save-btn:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }
.ts-save-btn:disabled { opacity: .45; cursor: not-allowed; transform: none; box-shadow: none; }
.ts-save-status {
  font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold);
  color: var(--color-text-muted); display: flex; align-items: center; gap: var(--space-1);
}
.ts-save-status .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--color-success); flex-shrink: 0; }
.ts-save-status.unsaved .dot { background: var(--color-accent); }
.ts-save-hint { font-size: 12px; color: var(--color-secondary-light); margin-left: auto; }
.ts-save-hint kbd {
  display: inline-block; padding: 2px 5px; font-size: 10px;
  font-family: var(--font-mono); background: var(--color-bg);
  border: 1px solid var(--color-border); border-radius: 4px;
  box-shadow: 0 1px 0 var(--color-border);
}

/* Mobile context bar */
.ts-mobile-ctx { display: none; }

/* -- Desktop tweaks -- */
@media (min-width: 769px) {
  .ts-grid input.t,
  .ts-grid .form-control-sm.t { width: 66px; min-width: 66px; font-size: var(--font-size-sm); padding: 5px 7px; }
  .ts-grid thead th { padding: var(--space-2) var(--space-2); }
}

/* -- Mobile -- */
@media (max-width: 768px) {
  .ts-mobile-ctx {
    display: flex; position: fixed; left: 8px; right: 8px; z-index: 50;
    top: 54px;
    background: var(--color-card); border: 1px solid var(--color-border);
    border-radius: var(--radius-md); padding: var(--space-2) var(--space-3);
    font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold);
    color: var(--color-secondary); gap: var(--space-3); white-space: nowrap;
    box-shadow: var(--shadow-lg);
  }
  .ts-grid input.t,
  .ts-grid .form-control-sm.t { font-size: 16px; line-height: 1.2; }
  .ts-grid td:first-child,
  .ts-grid th:first-child { min-width: 90px; }
  .ts-toolbar { gap: var(--space-2); padding: var(--space-2) var(--space-3); }
  .ts-toolbar-push { margin-left: 0; width: 100%; justify-content: space-between; }
  .ts-manage-panel { padding: var(--space-2) var(--space-3); }
  .ts-manage-group { flex-wrap: wrap; }
  .ts-period-select { min-width: 100%; font-size: 16px; }
  .week-nav { flex-wrap: nowrap; }
  .week-nav-label { min-width: 0; font-size: var(--font-size-sm); }
  .ts-status-card { flex-direction: column; align-items: flex-start; gap: var(--space-2); }
  .ts-status-actions { margin-left: 0; flex-wrap: wrap; }
  .ts-save { flex-wrap: wrap; gap: var(--space-2); padding: var(--space-2) var(--space-3); bottom: 6px; }
  .ts-save-hint { margin-left: 0; }
  .ts-save-hint kbd { display: none; }
  .week-tile { padding: var(--space-1) var(--space-2); font-size: 12px; }
}
