/* Grouped Summary view mode — operator buckets with hour heatmap.
   Loaded via config_modules.css_file when this view is enabled. */

.grouped-summary {
  --grouped-accent: rgba(59, 130, 246, 0.8);
}

/* Hour activity strip ---------------------------------------------- */

.grouped-hour-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(38px, 1fr));
  gap: 4px;
}

.grouped-hour-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 4px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  cursor: pointer;
  transition: transform 0.1s, background 0.1s, border-color 0.1s;
  min-height: 36px;
  position: relative;
}

.grouped-hour-cell:hover {
  transform: translateY(-1px);
  border-color: rgba(59, 130, 246, 0.4);
}

.grouped-hour-cell.intensity-0 { background: rgba(255, 255, 255, 0.02); }
.grouped-hour-cell.intensity-1 { background: rgba(59, 130, 246, 0.10); }
.grouped-hour-cell.intensity-2 { background: rgba(59, 130, 246, 0.20); }
.grouped-hour-cell.intensity-3 { background: rgba(59, 130, 246, 0.35); }
.grouped-hour-cell.intensity-4 { background: rgba(59, 130, 246, 0.55); }
.grouped-hour-cell.intensity-5 { background: rgba(59, 130, 246, 0.80); }

/* Current hour (today only) — subtle amber outline */
.grouped-hour-cell.is-current {
  border-color: rgba(251, 191, 36, 0.6);
  box-shadow: 0 0 0 1px rgba(251, 191, 36, 0.4);
}

/* User-clicked hour — strong blue focus */
.grouped-hour-cell.is-active {
  transform: translateY(-2px) scale(1.08);
  border-color: rgba(59, 130, 246, 0.9);
  box-shadow:
    0 0 0 2px rgba(59, 130, 246, 0.6),
    0 4px 14px rgba(59, 130, 246, 0.35);
  background: rgba(59, 130, 246, 0.75);
  z-index: 2;
}

.grouped-hour-label {
  font-size: 12px;
  font-weight: 600;
  font-family: 'JetBrains Mono', monospace;
  color: rgba(255, 255, 255, 0.75);
  line-height: 1;
}

.grouped-hour-cell.intensity-4 .grouped-hour-label,
.grouped-hour-cell.intensity-5 .grouped-hour-label,
.grouped-hour-cell.is-active .grouped-hour-label { color: #fff; }

/* Operator group rows ---------------------------------------------- */

.grouped-op-row + .grouped-op-row {
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.grouped-op-header {
  display: grid;
  grid-template-columns: 24px 64px minmax(120px, 1.4fr) minmax(140px, 2fr) minmax(120px, 1fr) 50px;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  cursor: pointer;
  transition: background 0.1s;
}

.grouped-op-header:hover { background: rgba(255, 255, 255, 0.04); }

.grouped-op-chevron {
  color: rgba(255, 255, 255, 0.5);
  font-size: 10px;
  text-align: center;
}

.grouped-op-row.is-expanded .grouped-op-chevron { color: rgba(147, 197, 253, 0.9); }

.grouped-op-badge {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 3px 8px;
  border-radius: 4px;
  text-align: center;
  font-family: 'JetBrains Mono', monospace;
  background: rgba(107, 114, 128, 0.25);
  color: #d1d5db;
}
.grouped-op-badge.op-LOT    { background: rgba(220, 38, 38, 0.25); color: #fca5a5; }
.grouped-op-badge.op-WZZ    { background: rgba(168, 85, 247, 0.25); color: #d8b4fe; }
.grouped-op-badge.op-ENT    { background: rgba(234, 88, 12, 0.25); color: #fdba74; }
.grouped-op-badge.op-EU     { background: rgba(59, 130, 246, 0.25); color: #93c5fd; }
.grouped-op-badge.op-INTL   { background: rgba(14, 165, 233, 0.25); color: #7dd3fc; }
.grouped-op-badge.op-GA     { background: rgba(34, 197, 94, 0.25); color: #86efac; }
.grouped-op-badge.op-GOV    { background: rgba(245, 158, 11, 0.25); color: #fcd34d; }
.grouped-op-badge.op-GROUND { background: rgba(234, 179, 8, 0.25); color: #fde68a; }
.grouped-op-badge.op-OTHER  { background: rgba(107, 114, 128, 0.25); color: #d1d5db; }

.grouped-op-name {
  font-size: 14px;
  color: rgba(229, 231, 235, 0.95);
  font-weight: 500;
}

.grouped-op-sparkline {
  display: flex;
  align-items: flex-end;
  gap: 2px;
  height: 28px;
  background: rgba(255, 255, 255, 0.02);
  padding: 2px;
  border-radius: 4px;
}

.grouped-spark-bar {
  flex: 1;
  min-height: 2px;
  background: linear-gradient(to top,
              rgba(59, 130, 246, 0.4),
              rgba(59, 130, 246, 0.85));
  border-radius: 1px 1px 0 0;
}

.grouped-spark-bar.is-selected {
  background: linear-gradient(to top,
              rgba(251, 191, 36, 0.7),
              rgba(251, 191, 36, 1));
}

.grouped-op-stats {
  font-size: 12px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.grouped-op-count {
  text-align: right;
  font-size: 18px;
  font-weight: 700;
  color: rgba(229, 231, 235, 0.95);
  font-family: 'JetBrains Mono', monospace;
}

/* Expanded body ---------------------------------------------------- */

.grouped-op-body {
  padding: 4px 16px 16px;
  background: rgba(0, 0, 0, 0.15);
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}

.grouped-aircraft-grid {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.grouped-aircraft-pill {
  display: grid;
  grid-template-columns: 88px 1fr;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 4px;
  min-width: 0;
}

.grouped-aircraft-reg {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  font-weight: 600;
  color: #93c5fd;
  background: transparent;
  border: 1px solid rgba(147, 197, 253, 0.2);
  padding: 4px 8px;
  border-radius: 4px;
  cursor: pointer;
  text-align: center;
  transition: background 0.1s, border-color 0.1s, color 0.1s;
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.grouped-aircraft-reg:hover {
  background: rgba(59, 130, 246, 0.2);
  border-color: rgba(59, 130, 246, 0.5);
  color: #fff;
}

.grouped-aircraft-callsign-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  min-width: 0;
}

.grouped-cs-chip {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  padding: 3px 8px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 3px;
  color: rgba(229, 231, 235, 0.85);
  cursor: pointer;
  transition: background 0.1s, border-color 0.1s, color 0.1s;
  white-space: nowrap;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  line-height: 1.2;
  gap: 1px;
}

.grouped-cs-time {
  font-size: 9px;
  opacity: 0.65;
  letter-spacing: -0.02em;
  color: rgba(229, 231, 235, 0.7);
}

.grouped-cs-chip:hover .grouped-cs-time { opacity: 0.95; }

.grouped-cs-chip:hover {
  background: rgba(59, 130, 246, 0.25);
  border-color: rgba(59, 130, 246, 0.5);
  color: #fff;
}

.grouped-cs-chip.is-dim {
  opacity: 0.3;
  background: rgba(255, 255, 255, 0.02);
}

.grouped-cs-chip.is-dim:hover {
  opacity: 0.85;
  background: rgba(59, 130, 246, 0.15);
}

/* Responsive ------------------------------------------------------- */

@media (max-width: 768px) {
  .grouped-op-header {
    grid-template-columns: 18px 52px 1fr 60px;
    gap: 8px;
    padding: 10px 12px;
  }
  .grouped-op-sparkline,
  .grouped-op-stats { display: none; }
  .grouped-op-count { font-size: 14px; }
  .grouped-hour-strip {
    grid-template-columns: repeat(8, 1fr);
  }
}
