.kpi-timesheet-screen { display: flex; flex-direction: column; gap: 14px; padding-bottom: 12px; }
.kpi-timesheet-card,.kpi-timesheet-panel { background: #fff; border: 1px solid #dbe3ee; border-radius: 20px; box-shadow: 0 14px 34px rgba(15, 23, 42, 0.05); }
.kpi-timesheet-card { padding: 16px; }
.kpi-timesheet-hero,.kpi-timesheet-nav,.kpi-timesheet-card--summary { display: grid; gap: 14px; }
.kpi-timesheet-card--nav,.kpi-timesheet-card--switch { display: grid; gap: 14px; }
.kpi-timesheet-identity,.kpi-timesheet-nav-month { min-width: 0; }
.kpi-timesheet-eyebrow { color: #64748b; font-size: 12px; font-weight: 600; letter-spacing: 0.03em; text-transform: uppercase; }
.kpi-timesheet-title { margin: 6px 0 0; color: #0f172a; font-size: 28px; line-height: 1.05; font-weight: 700; }
.kpi-timesheet-meta { margin-top: 8px; color: #516173; font-size: 14px; }
.kpi-timesheet-rate-card { display: grid; gap: 10px; padding: 14px; border: 1px solid #e2e8f0; border-radius: 18px; background: #f8fbff; }
.kpi-timesheet-rate-value { color: #0f172a; font-size: 24px; font-weight: 700; line-height: 1; }
.kpi-timesheet-rate-value span { color: #64748b; font-size: 13px; font-weight: 600; margin-left: 4px; }
.kpi-timesheet-rate-input { width: 100%; min-height: 46px; padding: 0 12px; border: 1px solid #cbd5e1; border-radius: 14px; background: #fff; color: #0f172a; font-size: 15px; font-weight: 600; box-sizing: border-box; }
.kpi-timesheet-actions,.kpi-timesheet-card--summary { display: grid; gap: 10px; }
.kpi-timesheet-btn,.kpi-timesheet-nav-btn,.kpi-timesheet-switch-btn { border: 1px solid transparent; border-radius: 14px; background: #fff; color: #0f172a; transition: background-color 180ms ease, border-color 180ms ease, box-shadow 180ms ease; }
.kpi-timesheet-btn { min-height: 42px; padding: 0 14px; font-size: 14px; font-weight: 600; }
.kpi-timesheet-btn--ghost { border-color: #d7e1ec; background: #f8fafc; }
.kpi-timesheet-btn--secondary { border-color: #d7e1ec; background: #fff; color: #334155; }
.kpi-timesheet-btn--danger { border-color: #eed6d6; background: #fff7f7; color: #9f2f2f; }
.kpi-timesheet-nav { grid-template-columns: 44px minmax(0, 1fr) 44px; align-items: center; }
.kpi-timesheet-nav-btn { width: 44px; height: 44px; font-size: 18px; font-weight: 600; border-color: #d7e1ec; box-shadow: 0 4px 10px rgba(15, 23, 42, 0.04); }
.kpi-timesheet-nav-month { text-align: center; }
.kpi-timesheet-nav-title { margin-top: 4px; color: #0f172a; font-size: 22px; font-weight: 700; }
.kpi-timesheet-switch { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 4px; padding: 4px; border-radius: 18px; background: #eef3f8; }
.kpi-timesheet-switch-btn { min-height: 48px; padding: 0 16px; font-size: 14px; font-weight: 600; color: #66788a; }
.kpi-timesheet-switch-btn:hover { background: rgba(255, 255, 255, 0.55); }
.kpi-timesheet-switch-btn.is-active { border-color: #dbe4f0; background: #fff; color: #0f172a; box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08); }
.kpi-timesheet-summary-metric { display: grid; gap: 6px; padding: 14px; border: 1px solid #e2e8f0; border-radius: 18px; background: #f8fafc; }
.kpi-timesheet-summary-metric span { color: #64748b; font-size: 13px; }
.kpi-timesheet-summary-metric strong { color: #0f172a; font-size: 22px; line-height: 1.1; font-weight: 700; }
.kpi-timesheet-panel { padding: 14px; }
.kpi-timesheet-list { display: grid; gap: 10px; }
.kpi-timesheet-list-day { display: grid; gap: 8px; padding: 14px; border: 1px solid #e2e8f0; border-radius: 16px; background: #fbfdff; transition: border-color 180ms ease, box-shadow 180ms ease, background-color 180ms ease; }
.kpi-timesheet-list-day-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.kpi-timesheet-list-day-title { color: #0f172a; font-size: 16px; font-weight: 600; }
.kpi-timesheet-list-day-hours { color: #1e293b; font-size: 16px; font-weight: 700; white-space: nowrap; }
.kpi-timesheet-list-day-meta { color: #64748b; font-size: 13px; line-height: 1.4; }
.kpi-timesheet-btn:hover,.kpi-timesheet-nav-btn:hover,.kpi-timesheet-list-day:hover { border-color: #c7d2df; box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06); }
.kpi-timesheet-btn:active,.kpi-timesheet-nav-btn:active,.kpi-timesheet-list-day:active { box-shadow: 0 5px 12px rgba(15, 23, 42, 0.08); background: #f8fafc; }
@media (min-width: 721px) {
  .kpi-timesheet-screen { gap: 16px; }
  .kpi-timesheet-card,.kpi-timesheet-panel { border-radius: 22px; }
  .kpi-timesheet-card,.kpi-timesheet-panel { padding: 20px; }
  .kpi-timesheet-hero { grid-template-columns: minmax(0, 1fr) minmax(280px, 360px); align-items: start; }
  .kpi-timesheet-card--nav { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: 18px; }
  .kpi-timesheet-card--summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .kpi-timesheet-switch { max-width: 320px; }
}
