/* Minimal, consistent UI for all templates */
:root{
  --bg: #F7F8FA;
  --panel: #FFFFFF;
  --text: #111827;
  --muted: #6B7280;
  --border: #E6E8EE;
  --border2: #EEF0F4;
  --primary: #2563EB;
  --primary-ink: #1D4ED8;
  --danger: #DC2626;
  --warning: #D97706;
  --success: #16A34A;
  --shadow: 0 10px 30px rgba(17, 24, 39, 0.08);
  --radius: 14px;
}

*{ box-sizing:border-box; }
html, body{ height:100%; }
body{
  margin:0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
}

a{ color: var(--primary-ink); text-decoration:none; }
a:hover{ text-decoration:underline; }

.layout{ display:flex; min-height:100vh; }

.sidebar{
  width: 260px;
  background: var(--panel);
  border-right: 1px solid var(--border);
  padding: 18px 16px;
  display:flex;
  flex-direction:column;
  gap: 14px;
}
.sidebar__brand{ padding: 2px 4px 10px; }
.sidebar__logo{ font-weight: 700; font-size: 15px; }
.sidebar__sub{ font-size: 12px; color: var(--muted); margin-top: 2px; }
.sidebar__footer{ margin-top:auto; padding-top: 10px; border-top: 1px solid var(--border2); }

.nav{ display:flex; flex-direction:column; gap: 6px; }
.nav__item{
  display:block;
  padding: 10px 10px;
  border-radius: 10px;
  color: #374151;
}
.nav__item:hover{
  background: #F3F4F6;
  text-decoration:none;
}
.nav__item--muted{ color: var(--muted); }

.main{ flex:1; display:flex; flex-direction:column; }
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 18px 22px;
}
.topbar__title{
  font-size: 20px;
  font-weight: 700;
}
.topbar__actions{ display:flex; gap: 10px; align-items:center; }

.content{
  padding: 0 22px 22px;
  max-width: 1200px;
  width: 100%;
}

.stack{ display:flex; flex-direction:column; gap: 12px; }

.panel{
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 1px 4px rgba(17, 24, 39, 0.06);
}
.panel--p16{ padding: 16px; }
.panel--p20{ padding: 20px; }

.h2{ font-size: 16px; font-weight: 700; margin:0; }
.p{ margin:0; color: var(--muted); font-size: 13px; line-height: 1.4; }
.help{ font-size: 12px; color: var(--muted); }

.controls{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  align-items:flex-end;
}
.field label{
  display:block;
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 4px;
}
input[type="text"], input[type="password"], input[type="date"], select{
  padding: 8px 10px;
  font-size: 13px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: #fff;
  outline: none;
}
input[type="text"]:focus, input[type="password"]:focus, input[type="date"]:focus, select:focus{
  border-color: rgba(37, 99, 235, 0.5);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.10);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 8px 12px;
  font-size: 13px;
  border-radius: 12px;
  border: 1px solid transparent;
  cursor:pointer;
  text-decoration:none;
  user-select:none;
}
.btn--primary{ background: var(--primary); color:#fff; }
.btn--primary:hover{ background: #1E4FD8; text-decoration:none; }
.btn--ghost{ background: #fff; border-color: var(--border); color: #374151; }
.btn--ghost:hover{ background: #F3F4F6; text-decoration:none; }
.btn--danger{ background: #fff; border-color: rgba(220,38,38,0.35); color: var(--danger); }
.btn--danger:hover{ background: rgba(220,38,38,0.06); text-decoration:none; }
.btn--sm{ padding: 6px 10px; border-radius: 10px; font-size: 12px; }

.badge{
  display:inline-flex;
  align-items:center;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  border: 1px solid transparent;
}
.badge--ok{ background: rgba(22,163,74,0.10); color: #166534; border-color: rgba(22,163,74,0.20); }
.badge--warn{ background: rgba(217,119,6,0.10); color: #92400E; border-color: rgba(217,119,6,0.20); }
.badge--danger{ background: rgba(220,38,38,0.10); color: #991B1B; border-color: rgba(220,38,38,0.20); }
.badge--muted{ background: #F3F4F6; color: #374151; border-color: var(--border); }

table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
}
.table{
  overflow:hidden;
}
.table table{
  background: transparent;
}
.table th{
  font-size: 12px;
  color: var(--muted);
  font-weight: 700;
  text-align:left;
  background: #F8FAFC;
  border-bottom: 1px solid var(--border2);
  padding: 10px 12px;
}
.table td{
  font-size: 13px;
  border-bottom: 1px solid var(--border2);
  padding: 10px 12px;
  vertical-align: top;
}
.table tr:hover td{ background: #FAFBFC; }

.empty{
  padding: 18px;
  color: var(--muted);
  font-size: 13px;
}

/* Login is special (no sidebar) */
.auth{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 24px;
  background: var(--bg);
}
.auth__card{
  width: 380px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--shadow);
  padding: 28px;
}
.auth__title{ font-size: 20px; font-weight: 800; margin: 0 0 6px; }
.auth__sub{ font-size: 13px; color: var(--muted); margin: 0 0 18px; }
.auth__error{
  background: rgba(220,38,38,0.08);
  border: 1px solid rgba(220,38,38,0.20);
  color: #991B1B;
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 13px;
  margin-bottom: 12px;
}

/* Legacy class compatibility (keeps existing templates readable) */
.period-tabs{ display:flex; gap:8px; flex-wrap:wrap; }
.period-tabs a{
  padding: 8px 12px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 999px;
  color: #374151;
  font-size: 13px;
}
.period-tabs a.active{
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
  text-decoration:none;
}

.cards{ display:grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; }
.card{
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 14px;
  box-shadow: 0 1px 4px rgba(17, 24, 39, 0.06);
  text-align:center;
}
.card .num{ font-size: 26px; font-weight: 800; margin-bottom: 4px; color: var(--text); }
.card .label{ font-size: 12px; color: var(--muted); }
.card .num.green{ color: var(--success); }
.card .num.red{ color: var(--danger); }
.card .num.orange{ color: var(--warning); }
.card .num.blue{ color: var(--primary-ink); }

.pm-grid{ display:grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 12px; }
.pm-card{
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px;
  box-shadow: 0 1px 4px rgba(17, 24, 39, 0.06);
}
.pm-card .pm-name{ font-weight: 800; font-size: 15px; margin-bottom: 8px; }
.pm-card .pm-row{ display:flex; justify-content:space-between; font-size: 13px; padding: 4px 0; color: var(--muted); }
.pm-card .pm-row span:last-child{ font-weight: 700; color: var(--text); }

.badge-warn{ background: rgba(217,119,6,0.10); color: #92400E; border: 1px solid rgba(217,119,6,0.20); }
.badge-danger{ background: rgba(220,38,38,0.10); color: #991B1B; border: 1px solid rgba(220,38,38,0.20); }
.badge-ok{ background: rgba(22,163,74,0.10); color: #166534; border: 1px solid rgba(22,163,74,0.20); }

/* ---- UX upgrades ---- */
.nav-toggle{ position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }

.nav-scrim{
  display:none;
}

.nav-open{
  display:none;
  width: 40px;
  height: 40px;
  align-items:center;
  justify-content:center;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: #fff;
  cursor: pointer;
  user-select:none;
  margin-right: 10px;
}

.topbar__left{
  display:flex;
  align-items:center;
  min-width: 0;
}
.topbar__title{ min-width: 0; }

.nav__item.is-active{
  background: rgba(37, 99, 235, 0.10);
  color: var(--primary-ink);
  border: 1px solid rgba(37, 99, 235, 0.18);
}

.sidebar{
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: auto;
}

.main{
  min-width: 0;
}

.topbar{
  position: sticky;
  top: 0;
  z-index: 5;
  background: rgba(247, 248, 250, 0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border2);
}

.content{
  max-width: 1400px;
  width: 100%;
}

.table-scroll{
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--panel);
  margin: 10px 0 18px;
}

.panel .table-scroll{
  margin: 0;
}

.table-scroll table{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed; /* prevents columns from visually merging */
}

.table-scroll th,
.table-scroll td{
  padding: 10px 12px;
  border-bottom: 1px solid var(--border2);
  vertical-align: top;
  font-size: 13px;
  line-height: 1.35;
  word-break: break-word;
}

.table-scroll thead th{
  position: sticky;
  top: 0;
  z-index: 1;
  background: #F8FAFC;
  font-size: 12px;
  color: var(--muted);
  font-weight: 800;
  letter-spacing: 0.01em;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}

.table-scroll tbody tr:nth-child(even) td{
  background: #FBFCFE;
}

.table-scroll tbody tr:hover td{
  background: #F3F4F6;
}

/* Column sizing helpers (used by dashboard colgroups) */
.col-time{ width: 10%; }
.col-chat{ width: 18%; }
.col-chat-wide{ width: 34%; }
.col-person{ width: 14%; }
.col-metric{ width: 9%; }
.col-text{ width: 18%; }
.col-text-wide{ width: 30%; }
.col-status{ width: 12%; }

.table-scroll .details-body{
  margin-top: 8px;
  white-space: pre-wrap;
  font-size: 12px;
  color: #111827;
}

.table-scroll .details-stack{
  margin-top: 8px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.table-scroll .details-label{
  font-size: 12px;
  font-weight: 800;
  color: var(--muted);
}

.table-scroll .details-pre{
  white-space: pre-wrap;
  padding: 10px 10px;
  border-radius: 10px;
  border: 1px solid var(--border);
  font-size: 12px;
  line-height: 1.35;
}

.table-scroll .details-pre--neutral{
  background: #F3F4F6;
}

.table-scroll .details-pre--accent{
  background: rgba(37, 99, 235, 0.08);
}

/* Common dashboard columns */
.table-scroll td.num,
.table-scroll th.num{
  text-align: right;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.table-scroll td.nowrap,
.table-scroll th.nowrap{
  white-space: nowrap;
}

.table-scroll details > summary{
  cursor: pointer;
  color: var(--primary-ink);
}

.table-scroll .cell-muted{
  color: var(--muted);
}

/* Dashboard headings spacing */
h2{
  margin: 18px 0 8px;
  font-size: 16px;
  font-weight: 800;
  color: #111827;
}

.title-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin: 10px 0 8px;
}

/* Employees filter chips */
.filters{ display:flex; flex-wrap:wrap; gap: 8px; margin: 10px 0 12px; }
.filters a{
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: #fff;
  color: #374151;
  font-size: 13px;
  text-decoration:none;
}
.filters a:hover{ background:#F3F4F6; text-decoration:none; }
.filters a.active{
  border-color: rgba(37, 99, 235, 0.35);
  background: rgba(37, 99, 235, 0.10);
  color: var(--primary-ink);
  font-weight: 800;
}

/* Analytics / Charts block */
.analytics-block{
  margin: 4px 0;
}
.analytics-toggle{
  cursor: pointer;
  font-size: 16px;
  font-weight: 800;
  color: #111827;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  user-select: none;
}
.analytics-toggle::-webkit-details-marker{ display:none; }
.analytics-toggle::before{
  content: "▸";
  font-size: 12px;
  color: var(--muted);
  transition: transform 120ms;
}
details[open] .analytics-toggle::before{ transform: rotate(90deg); }

.charts-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
  gap: 16px;
  margin-top: 12px;
}
.chart-panel{
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: 0 1px 4px rgba(17,24,39,0.06);
}
.chart-panel--wide{
  grid-column: 1 / -1;
}
.chart-panel__title{
  font-size: 13px;
  font-weight: 700;
  color: var(--muted);
  margin: 0 0 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.chart-loading{
  display: flex;
  align-items: center;
  justify-content: center;
  height: 180px;
  color: var(--muted);
  font-size: 13px;
}

@media (max-width: 860px){
  .charts-grid{ grid-template-columns: 1fr; }
  .chart-panel--wide{ grid-column: auto; }
}

/* Pagination */
.pagination{
  display: flex;
  gap: 4px;
  align-items: center;
  padding: 12px 0 4px;
  flex-wrap: wrap;
}
.pagination__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 8px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: #fff;
  color: #374151;
  font-size: 13px;
  text-decoration: none;
  user-select: none;
  cursor: pointer;
}
.pagination__btn:hover{ background: #F3F4F6; text-decoration: none; }
.pagination__btn.is-active{
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
  font-weight: 700;
}
.pagination__btn.is-disabled{
  opacity: 0.4;
  pointer-events: none;
}
.pagination__info{
  font-size: 12px;
  color: var(--muted);
  margin-left: 6px;
}

@media (max-width: 980px){
  .layout{ position: relative; }
  .sidebar{
    position: fixed;
    left: 0;
    top: 0;
    height: 100vh;
    width: min(320px, 92vw);
    transform: translateX(-110%);
    transition: transform 160ms ease;
    z-index: 30;
    box-shadow: var(--shadow);
  }
  .nav-open{ display:inline-flex; }
  .nav-scrim{
    display:none;
    position: fixed;
    inset: 0;
    background: rgba(17, 24, 39, 0.35);
    z-index: 20;
  }
  .nav-toggle:checked ~ .layout .sidebar{
    transform: translateX(0);
  }
  .nav-toggle:checked ~ .layout .nav-scrim{
    display:block;
  }
  .content{ padding: 0 14px 16px; }
  .topbar{ padding: 14px; }
}

