/*!
 * DashTemplate.com — Hospital CEO Cockpit · Template Styles
 * © 2025 DashTemplate.com. All Rights Reserved.
 * License: https://dashtemplate.com/license
 */
:root {
  --dt-template-primary: #0EA5E9;
  --dt-template-accent:  #14B8A6;
  --med-alert:           #EF4444;
  --med-warn:            #F59E0B;
  --med-ok:              #22C55E;
  --med-blue:            #0EA5E9;
  --med-teal:            #14B8A6;
}

/* ── Big-screen KPI strip ── */
.kpi-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.kpi-tile {
  background: var(--dt-surface);
  border: 1px solid var(--dt-border);
  border-radius: 10px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
  overflow: hidden;
  transition: border-color .2s;
}
.kpi-tile::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--tile-color, var(--med-blue));
}
.kpi-tile__label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--dt-text-3);
}
.kpi-tile__value {
  font-size: 28px;
  font-weight: 800;
  color: var(--dt-text);
  line-height: 1;
  letter-spacing: -.02em;
}
.kpi-tile__sub {
  font-size: 10.5px;
  color: var(--dt-text-2);
}
.kpi-tile__badge {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 20px;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  margin-top: 2px;
  width: fit-content;
}
.badge-ok   { background: rgba(34,197,94,.15);  color: #22C55E; }
.badge-warn { background: rgba(245,158,11,.15); color: #F59E0B; }
.badge-alert{ background: rgba(239,68,68,.15);  color: #EF4444; }

/* ── Alert ticker ── */
.alert-ticker {
  background: rgba(239,68,68,.08);
  border: 1px solid rgba(239,68,68,.25);
  border-radius: 8px;
  padding: 8px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--dt-text-2);
  margin-bottom: 14px;
  overflow: hidden;
}
.alert-ticker__dot {
  width: 6px; height: 6px;
  background: #EF4444;
  border-radius: 50%;
  flex-shrink: 0;
  animation: pulse-dot 1.5s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%,100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .5; transform: scale(.7); }
}
.alert-ticker__label {
  font-weight: 700;
  color: #EF4444;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .06em;
  flex-shrink: 0;
}
.alert-ticker__msg {
  white-space: nowrap;
  animation: ticker-scroll 30s linear infinite;
}
@keyframes ticker-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-60%); }
}

/* ── Department heat grid ── */
.dept-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.dept-cell {
  background: var(--dt-surface-2);
  border: 1px solid var(--dt-border);
  border-radius: 8px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  cursor: default;
  transition: border-color .2s, background .2s;
}
.dept-cell:hover {
  background: var(--dt-surface-3);
  border-color: rgba(14,165,233,.3);
}
.dept-cell__name {
  font-size: 10.5px;
  font-weight: 600;
  color: var(--dt-text);
}
.dept-cell__occ {
  font-size: 18px;
  font-weight: 800;
  line-height: 1;
}
.dept-cell__bar {
  height: 4px;
  background: var(--dt-surface-3);
  border-radius: 4px;
  overflow: hidden;
}
.dept-cell__fill {
  height: 100%;
  border-radius: 4px;
}
.dept-cell__meta {
  font-size: 9.5px;
  color: var(--dt-text-3);
}
.occ-critical { color: #EF4444; }
.occ-warn     { color: #F59E0B; }
.occ-ok       { color: #22C55E; }
.fill-critical { background: #EF4444; }
.fill-warn     { background: #F59E0B; }
.fill-ok       { background: #22C55E; }

/* ── Revenue donut legend ── */
.rev-legend {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 4px 0;
}
.rev-legend-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: var(--dt-text-2);
}
.rev-legend-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.rev-legend-val {
  margin-left: auto;
  font-weight: 600;
  color: var(--dt-text);
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px;
}

/* ── Compliance bar ── */
.compliance-row {
  display: grid;
  grid-template-columns: 110px 1fr 52px;
  gap: 10px;
  align-items: center;
  padding: 7px 0;
  border-bottom: 1px solid var(--dt-border);
  font-size: 11px;
}
.compliance-row:last-child { border-bottom: none; }
.compliance-row__name { color: var(--dt-text-2); }
.compliance-bar {
  height: 6px;
  background: var(--dt-surface-3);
  border-radius: 4px;
  overflow: hidden;
}
.compliance-fill {
  height: 100%;
  border-radius: 4px;
  transition: width .6s ease;
}
.compliance-row__val {
  text-align: right;
  font-weight: 600;
  color: var(--dt-text);
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px;
}

/* ── Sub-screen cards ── */
.sub-screens-bar {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 16px;
}
