/* ============================================
   TIMESHEETS MODULE
   36-hour week · Flexi/TOIL ±15h · Appointments
   ============================================ */

/* ---- Flexi Balance Card ---- */
.flexi-balance-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--space-5);
}

.flexi-balance-top {
  display: flex;
  align-items: flex-start;
  gap: var(--space-6);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.flexi-balance-label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semi);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: var(--space-1);
}

.flexi-balance-value {
  font-size: var(--text-2xl);
  font-weight: var(--weight-extra);
  letter-spacing: -0.03em;
  line-height: 1;
}

.flexi-rules {
  display: flex;
  gap: var(--space-5);
  align-items: center;
  flex-wrap: wrap;
  margin-left: auto;
  align-self: center;
}

.flexi-rule {
  font-size: var(--text-xs);
  color: var(--text-muted);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.flexi-rule strong {
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: var(--navy);
}

/* Flexi meter */
.flexi-meter-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

.flexi-meter-limit {
  font-size: var(--text-xs);
  font-weight: var(--weight-semi);
  white-space: nowrap;
  min-width: 36px;
}

.flexi-meter-limit:last-child { text-align: right; }

.flexi-meter-track {
  flex: 1;
  height: 12px;
  background: linear-gradient(to right, var(--error-light) 0%, var(--error-light) 50%, var(--success-light) 50%, var(--success-light) 100%);
  border-radius: var(--radius-full);
  position: relative;
  border: 1px solid var(--border);
  overflow: visible;
}

.flexi-meter-track::before {
  content: '';
  position: absolute;
  left: 50%;
  top: -4px;
  bottom: -4px;
  width: 1px;
  background: var(--border-mid);
  transform: translateX(-50%);
}

.flexi-meter-cursor {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--navy);
  border: 2.5px solid var(--white);
  box-shadow: var(--shadow-sm);
  transition: left 0.35s cubic-bezier(.4,0,.2,1);
  z-index: 2;
}

/* ---- Week Navigation ---- */
.ts-week-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
  gap: var(--space-3);
  flex-wrap: wrap;
}

.ts-week-nav {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.ts-week-label {
  font-size: var(--text-sm);
  font-weight: var(--weight-semi);
  color: var(--navy);
  min-width: 210px;
  text-align: center;
}

/* ---- Weekly Timesheet Table ---- */
.ts-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.ts-table th {
  font-size: var(--text-xs);
  font-weight: var(--weight-semi);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  padding: var(--space-3) var(--space-4);
  text-align: left;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}

.ts-table th:last-child { text-align: right; }

.ts-table td {
  padding: var(--space-2) var(--space-4);
  border-bottom: 1px solid var(--surface);
  vertical-align: middle;
  color: var(--text-primary);
}

.ts-table tbody tr:last-child td { border-bottom: none; }

.ts-table tfoot td {
  padding: var(--space-3) var(--space-4);
  border-top: 2px solid var(--border);
}

.ts-row--today > td { background: var(--primary-light); }

.ts-day-cell {
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: var(--navy);
  width: 44px;
}

.ts-date-cell {
  color: var(--text-muted);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  width: 60px;
}

.ts-time-input {
  font-family: var(--font);
  font-size: var(--text-sm);
  color: var(--text-primary);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 5px 8px;
  background: var(--white);
  width: 96px;
  transition: border-color var(--transition);
  cursor: pointer;
}
.ts-time-input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(31,175,140,.1); }
.ts-time-input:disabled { background: var(--surface); color: var(--text-muted); cursor: default; }

.ts-break-select {
  font-family: var(--font);
  font-size: var(--text-sm);
  color: var(--text-primary);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 5px 8px;
  background: var(--white);
  cursor: pointer;
  transition: border-color var(--transition);
}
.ts-break-select:focus { outline: none; border-color: var(--primary); }
.ts-break-select:disabled { background: var(--surface); color: var(--text-muted); cursor: default; }

.ts-appt-label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--text-secondary);
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}

.ts-appt-label input[type="checkbox"] {
  accent-color: var(--primary);
  width: 15px;
  height: 15px;
  cursor: pointer;
}

.ts-appt-label input[type="checkbox"]:disabled { cursor: default; }

.ts-net-cell {
  font-weight: var(--weight-semi);
  color: var(--navy);
  text-align: right;
  white-space: nowrap;
  min-width: 72px;
}

.ts-net--under { color: var(--error) !important; }
.ts-net--over  { color: var(--success) !important; }

.ts-net-total {
  font-size: var(--text-md);
  font-weight: var(--weight-bold);
  color: var(--navy);
  text-align: right;
}

/* ---- Summary Strip ---- */
.ts-summary-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.ts-summary-item {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  box-shadow: var(--shadow-sm);
}

.ts-summary-label {
  display: block;
  font-size: var(--text-xs);
  font-weight: var(--weight-semi);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: var(--space-2);
}

.ts-summary-value {
  display: block;
  font-size: var(--text-xl);
  font-weight: var(--weight-extra);
  color: var(--navy);
  letter-spacing: -0.02em;
  line-height: 1;
}

/* ---- Appointments ---- */
.ts-appt-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--surface);
  font-size: var(--text-sm);
}
.ts-appt-item:last-child { border-bottom: none; }

.ts-appt-day { font-weight: var(--weight-medium); color: var(--text-primary); }

.ts-appt-empty {
  font-size: var(--text-sm);
  color: var(--text-muted);
  padding: var(--space-2) 0;
}

/* ---- Action Row ---- */
.ts-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
  margin-top: var(--space-2);
  padding-top: var(--space-4);
}

/* ---- Manager Table Additions ---- */
.ts-bal-positive { color: var(--success); font-weight: var(--weight-semi); }
.ts-bal-negative { color: var(--error); font-weight: var(--weight-semi); }
.ts-bal-neutral  { color: var(--text-muted); font-weight: var(--weight-medium); }

.ts-delta-over  { color: var(--success); font-weight: var(--weight-semi); }
.ts-delta-under { color: var(--error); font-weight: var(--weight-semi); }

/* ---- History Tab ---- */
.ts-history-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--surface);
  font-size: var(--text-sm);
}
.ts-history-row:last-child { border-bottom: none; }
.ts-history-week { min-width: 180px; color: var(--text-secondary); font-weight: var(--weight-medium); }
.ts-history-hours { min-width: 80px; font-weight: var(--weight-semi); color: var(--navy); }
.ts-history-delta { min-width: 80px; }

/* ---- Toast Notification ---- */
.ts-toast {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-md);
  font-family: var(--font);
  font-size: var(--text-sm);
  font-weight: var(--weight-semi);
  box-shadow: var(--shadow-lg);
  z-index: 999;
  transform: translateY(16px);
  opacity: 0;
  transition: all 0.25s ease;
  pointer-events: none;
}
.ts-toast--show { transform: translateY(0); opacity: 1; }
.ts-toast--success { background: var(--success); color: white; }
.ts-toast--error   { background: var(--error); color: white; }
.ts-toast--info    { background: var(--info); color: white; }

/* ---- My Schedule Card ---- */
.ts-schedule-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-3);
}

.ts-schedule-day {
  background: var(--surface);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  text-align: center;
}

.ts-schedule-day-name {
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: var(--space-2);
}

.ts-schedule-times {
  font-size: var(--text-sm);
  font-weight: var(--weight-semi);
  color: var(--navy);
  margin-bottom: var(--space-1);
}

.ts-schedule-net {
  font-size: var(--text-xs);
  color: var(--primary);
  font-weight: var(--weight-semi);
}

/* ---- Responsive ---- */
@media (max-width: 1024px) {
  .ts-summary-strip { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .ts-summary-strip { grid-template-columns: repeat(2, 1fr); }
  .ts-table th:nth-child(5),
  .ts-table td:nth-child(5) { display: none; }  /* hide Break on small screens */
  .flexi-rules { display: none; }
  .ts-week-label { min-width: 160px; font-size: var(--text-xs); }
  .ts-schedule-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .ts-schedule-grid .ts-schedule-day:last-child { grid-column: span 2; }
}

@media (max-width: 480px) {
  .ts-summary-strip { grid-template-columns: 1fr; }
  .ts-time-input { width: 78px; }
}
