:root {
  --bg:#0f1220; --panel:#171a2b; --muted:#9aa3b2; --text:#eef2f7;
  --blue:#3b82f6; --amber:#f59e0b; --red:#ef4444;
  --card:#1c2035; --border:#262a42; --focus:#60a5fa;
  --btn:#243047; --chip:#222741;
}

* { box-sizing: border-box; }

/* Global scrollbar styling */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--muted) transparent;
}

/* Webkit scrollbar styling for all elements */
*::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

*::-webkit-scrollbar-track {
  background: transparent;
}

*::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 4px;
  border: 1px solid var(--bg);
}

*::-webkit-scrollbar-thumb:hover {
  background: var(--muted);
}

*::-webkit-scrollbar-thumb:active {
  background: var(--focus);
}

*::-webkit-scrollbar-corner {
  background: transparent;
}
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font: 14px/1.4 system-ui, -apple-system, Segoe UI, Roboto, Arial;
  padding-bottom: 29px; /* Account for status bar height */
}

/* Status bar */
.status-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 16px;
  background: var(--panel);
  border-top: 1px solid var(--border);
  font-size: 12px;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  width: 100%;
  box-sizing: border-box;
  height: 29px; /* Explicit height for precise positioning */
}

.status-indicator {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--amber);
  transition: background-color 0.3s ease;
}

.status-indicator.connected {
  background: #10b981;
}

.status-indicator.disconnected {
  background: var(--red);
}

.status-indicator.connecting {
  background: var(--amber);
  animation: pulse 1.5s infinite;
}

.status-text {
  color: var(--muted);
  font-weight: 500;
}

/* Header bar */
.appbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--panel);
  position: sticky;
  top: 0;
  z-index: 5;
}
.title { font-size: 16px; margin: 0; font-weight: 600; }

/* User info in header */
.user-info {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
}

.user-details {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
}

.user-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.user-role {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.logout-btn {
  margin-left: 4px;
  color: var(--muted);
  transition: color 0.2s ease;
}

.logout-btn:hover {
  color: var(--red);
}

/* Header User Section */
.header-user-section {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
  flex-shrink: 0;
}

.header-user-section .user-info {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  margin-right: 8px;
}

.header-user-section .user-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  line-height: 1;
}

.header-user-section .user-role {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  line-height: 1;
}

.user-logout {
  color: var(--muted);
  transition: color 0.2s ease;
  padding: 8px;
}

.user-logout:hover {
  color: var(--red);
  background: rgba(239, 68, 68, 0.1);
}

input[type=search] {
  flex: 1; min-width: 160px;
  background: #121527; color: var(--text);
  border: 1px solid var(--border); border-radius: 8px;
  padding: 8px 10px;
}
.btn {
  background: var(--btn); border: 1px solid var(--border);
  color: var(--text); padding: 8px 10px;
  border-radius: 8px; cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.btn.small { font-size: 12px; padding: 6px 8px; }
.btn.icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; 
  aspect-ratio: 1; 
  border-radius: 10px;
  padding: 0;
}
.btn:focus { outline: 2px solid var(--focus); outline-offset: 1px; }

/* Capacity tile */
.capacity-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 6px 12px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  min-width: 80px;
}

.capacity-tile.clickable {
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}

.capacity-tile.clickable:hover {
  background: rgba(28,32,53,0.8);
  border-color: var(--muted);
}
.capacity-label {
  font-size: 10px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 500;
  text-align: center;
  line-height: 1;
}
.capacity-value {
  font-size: 18px;
  font-weight: 600;
  color: var(--text);
  line-height: 1;
}
.capacity-value.low { color: var(--red); }
.capacity-value.medium { color: var(--amber); }
.capacity-value.high { color: var(--blue); }

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

@keyframes orange-flash {
  0%, 100% { 
    background-color: #161a2b; 
    border-color: var(--border);
  }
  50% { 
    background-color: rgba(255, 165, 0, 0.15); 
    border-color: #ff9500;
  }
}

.incident.unassigned {
  animation: orange-flash 2s infinite;
}

/* Layout */
.wrap {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  padding: 12px;
  padding-bottom: 89px; /* Default space for collapsed log (60px) + status bar (29px) */
  min-height: calc(100vh - 56px);
  transition: padding-bottom 0.3s ease-in-out;
}

/* When log is expanded, add more bottom padding */
body.log-expanded .wrap {
  padding-bottom: 309px; /* Space for expanded log (280px) + status bar (29px) */
}
.columns {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.col {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  min-height: 300px;
}
.col header {
  position: relative;
  background: transparent;
  border: 0;
  padding: 10px 12px;
}
/* Titles: make Incidents identical to At Post/Roaming/On Case */
.col h2,
.rightpanel h2{
  font-size:13px;
  margin:0;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.04em;
  display:flex;
  align-items:center;   /* centres the pill vertically */
  gap:8px;              /* space between text and count */
}

.dropzone {
  flex: 1;
  padding: 10px;
  display: grid;
  gap: 10px;
  align-content: start;
}
.dropzone.drag-over {
  outline: 2px dashed var(--focus);
  outline-offset: -6px;
}

/* Crew cards */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 8px;
  align-items: center;
}

.card-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.case-status-dropdown {
  background: var(--btn);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  font-size: 11px;
  padding: 4px 6px;
  min-width: 80px;
  height: 26px;
}

.case-status-dropdown:focus {
  outline: 2px solid var(--focus);
  outline-offset: 1px;
  border-color: var(--focus);
}

.dot { width: 10px; height: 10px; border-radius: 50%; }
.dot.blue { background: var(--blue); }
.dot.amber { background: var(--amber); }
.dot.red { background: var(--red); }
.meta { font-size: 12px; color: var(--muted); }
.callsign { font-weight: 700; }

/* Right panel (incidents) */
.rightpanel {
  width: 380px;
  max-width: 48vw;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  min-height: 300px;
}
.rightpanel header {
  border: 0;
  background: transparent;
  padding: 10px 12px;
}

.incident-list {
  padding: 10px;
  display: grid;
  gap: 8px;
  overflow: auto;
}
.incident {
  background: #161a2b;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px;
  cursor: pointer;
  position: relative;
  margin-bottom: 10px; /* ✅ adds space between incident cards */
}
.incident:not(:last-child) {
  margin-bottom: 10px;
}
.incident.active { border-color: var(--focus); }
.incident.drop-hover { outline: 2px dashed var(--focus); outline-offset: -6px; }
.crew-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.tag {
  font-size: 11px;
  background: var(--chip);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 2px 8px;
}
.tag button { all: unset; margin-left: 6px; cursor: pointer; color: #b7bfd0; }

/* Floating log */
.floating-log {
  position: fixed; left: 0; right: 0; bottom: 29px; /* Position exactly above status bar */
  background: rgba(15,18,32,.95);
  backdrop-filter: saturate(140%) blur(6px);
  border-top: 1px solid var(--border);
  z-index: 10; /* Above status bar */
  transition: transform 0.3s ease-in-out;
  max-height: 40vh; /* Limit to 40% of viewport height */
  display: flex;
  flex-direction: column;
}

.log-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  background: rgba(15,18,32,.98);
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  user-select: none;
  transition: background-color 0.2s ease;
}

.log-header:hover {
  background: rgba(20,25,40,.98);
}

.log-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.log-toggle {
  font-size: 14px;
  color: var(--muted);
  transition: transform 0.2s ease;
}

.log-content {
  padding: 8px 12px;
  display: grid;
  gap: 8px;
  transition: max-height 0.3s ease-in-out, opacity 0.2s ease-in-out;
  overflow: hidden;
  flex: 1;
  min-height: 0; /* Allow flexbox to shrink */
}

.floating-log.collapsed .log-content {
  max-height: 0;
  opacity: 0;
  padding-top: 0;
  padding-bottom: 0;
}

.floating-log.collapsed .log-toggle {
  transform: rotate(180deg);
}

.log-rows { 
  display: flex; 
  flex-direction: column; 
  gap: 4px; 
  flex: 1;
  overflow: auto; 
  min-height: 0; /* Allow flexbox to shrink */
  max-height: calc(40vh - 120px); /* Reserve space for header and input */
  scrollbar-width: thin; /* Firefox */
  scrollbar-color: rgba(255,255,255,0.15) transparent; /* Firefox */
}

/* Webkit scrollbar styling for running log */
.log-rows::-webkit-scrollbar {
  width: 8px;
}

.log-rows::-webkit-scrollbar-track {
  background: transparent;
}

.log-rows::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.15);
  border-radius: 4px;
  border: 1px solid rgba(255,255,255,0.05);
}

.log-rows::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,0.25);
}

.log-rows::-webkit-scrollbar-thumb:active {
  background: rgba(255,255,255,0.35);
}
.log-row { font-size: 12px; color: var(--muted); }
.log-input { display: flex; gap: 8px; }
.log-input input, select, textarea {
  background: #121527;
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px;
}

/* Dialogs */
dialog {
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  max-width: 520px;
}

dialog form { 
  display: grid; 
  gap: 10px; 
}

dialog input,
dialog select,
dialog textarea {
  background: var(--card);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.75rem;
  font-size: 14px;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

dialog input:focus,
dialog select:focus,
dialog textarea:focus {
  outline: none;
  border-color: var(--focus);
  background: rgba(28,32,53,0.8);
}

dialog input::placeholder {
  color: var(--muted);
}

dialog label {
  color: var(--text);
  font-weight: 500;
  margin-bottom: 0.25rem;
  display: block;
}

.row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.actions { display: flex; justify-content: flex-end; gap: 8px; }
.dialog-title { 
  margin: .2rem 0 .6rem 0; 
  color: var(--text);
  font-size: 1.2rem;
}
dialog::backdrop { background: rgba(0,0,0,.55); }

/* Modal tweaks */
#incidentModal { z-index: 1000; border: 1px solid var(--border); border-radius: 12px; }
#incidentModal form { 
  display: grid; 
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem; 
}
#incidentModal h2 { margin-bottom: 0.5rem; }

/* Ensure dialog title spans full width */
#incidentModal .dialog-title {
  grid-column: 1 / -1;
  margin: .2rem 0 .6rem 0; 
  color: var(--text);
  font-size: 1.2rem;
}

/* Field group styling for incident modal */
#incidentModal .field-group {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

/* Single field groups (not inside rows) span full width */
#incidentModal > form > .field-group {
  grid-column: 1 / -1;
}

/* Row elements span full width */
#incidentModal .field-group label {
  color: var(--text);
  font-weight: 500;
  font-size: 0.85rem;
  margin-bottom: 0;
}

/* Admin modal content */
.admin-content {
  padding: 1rem 0;
}

.admin-content h4 {
  margin: 0 0 1rem 0;
  color: var(--text);
}

.admin-section {
  margin: 1.5rem 0;
  padding: 1rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.02);
}

.admin-section h5 {
  margin: 0 0 1rem 0;
  color: var(--text);
  font-size: 0.95rem;
}

.admin-actions {
  margin-top: 1rem;
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

/* Additional admin styles */
.crew-list-container,
.user-list-container,
.log-container {
  max-height: 300px;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--card);
}

.loading-message {
  padding: 2rem;
  text-align: center;
  color: var(--muted);
  font-style: italic;
}

.system-info {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.info-section {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.info-section .meta {
  padding: 0.75rem;
  background: rgba(59, 130, 246, 0.1);
  border-left: 3px solid var(--blue);
  border-radius: 4px;
  color: var(--text);
  font-size: 0.9rem;
}

.info-section .info-row {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 1rem;
  align-items: center;
  padding: 0.75rem;
  background: var(--card);
  border-radius: 4px;
  border: 1px solid var(--border);
}

.info-section .info-row label {
  font-weight: 600;
  color: var(--text);
  margin: 0;
}

.info-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.5rem;
  background: var(--card);
  border-radius: 4px;
  border: 1px solid var(--border);
}

.info-label {
  font-weight: 600;
  color: var(--text);
}

.info-value {
  color: var(--muted);
  font-family: monospace;
}

.crew-list-item,
.user-list-item,
.log-entry {
  padding: 0.75rem;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.crew-list-item:last-child,
.user-list-item:last-child,
.log-entry:last-child {
  border-bottom: none;
}

.crew-info,
.user-info-admin {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.crew-callsign,
.user-name-admin {
  font-weight: 600;
  color: var(--text);
}

.crew-details,
.user-details-admin {
  font-size: 0.85rem;
  color: var(--muted);
}

.log-entry {
  font-family: monospace;
  font-size: 0.85rem;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.25rem;
}

.log-timestamp {
  color: var(--muted);
  font-size: 0.8rem;
}

.log-message {
  color: var(--text);
}

/* Admin Modal Specific Styles */
#adminModal {
  max-width: 1000px;
  width: 95vw;
  max-height: 90vh;
  overflow-y: auto;
  padding: 0;
}

#adminModal form {
  height: auto;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  padding: 1.5rem;
  gap: 0;
}

#adminModal .dialog-title {
  margin: 0;
  padding: 0;
  font-size: 1.5rem;
  font-weight: 600;
  flex: 1;
}

#adminModal .dialog-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 2px solid var(--border);
  flex-shrink: 0;
}

#adminModal .close-btn {
  background: none;
  border: none;
  font-size: 2rem;
  color: var(--muted);
  cursor: pointer;
  padding: 0;
  width: 2rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: all 0.2s ease;
  flex-shrink: 0;
}

#adminModal .close-btn:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.1);
}

#adminModal .tab-content {
  flex: 1;
  overflow: visible;
  min-height: 0;
  padding: 0.75rem 0;
}

/* Admin Modal Tab Navigation */
#adminModal .tab-navigation {
  margin: 0 0 1rem 0;
  border-bottom: 2px solid var(--border);
  background: transparent;
  border-radius: 0;
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
}

#adminModal .tab-btn {
  background: transparent;
  border: none;
  color: var(--muted);
  padding: 0.75rem 1rem;
  cursor: pointer;
  font-size: 0.9rem;
  font-weight: 500;
  border-bottom: 2px solid transparent;
  transition: all 0.2s ease;
  border-radius: 0;
}

#adminModal .tab-btn:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.05);
}

#adminModal .tab-btn.active {
  color: var(--focus);
  border-bottom-color: var(--focus);
  background: rgba(96, 165, 250, 0.1);
}

#adminModal .tab-panel {
  display: none;
  min-height: 0;
}

#adminModal .tab-panel.active {
  display: block;
}

#adminModal .admin-section {
  margin: 0 0 1.5rem 0;
  padding: 1.25rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
}

#adminModal .admin-section:last-child {
  margin-bottom: 0;
}

#adminModal .admin-section h5 {
  margin: 0 0 1rem 0;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text);
  border-bottom: 1px solid var(--border);
  padding-bottom: 0.5rem;
}

#adminModal .row {
  display: flex;
  gap: 1rem;
  align-items: end;
}

#adminModal .row .field-group {
  flex: 1;
}

#adminModal .admin-actions {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 1rem;
}

#adminModal .admin-actions .btn {
  width: 100%;
  text-align: left;
  justify-content: flex-start;
}

#adminModal .crew-list-container,
#adminModal .user-list-container,
#adminModal .log-container {
  max-height: 300px;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 1rem;
  background: var(--bg-secondary, #2a2a2a);
}

/* Crew Management Layout */
#adminModal .crew-management-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 1rem;
}

#adminModal .crew-create-column {
  display: flex;
  flex-direction: column;
}

#adminModal .crew-actions-column {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

#adminModal .crew-create-column .admin-section {
  height: 100%;
  display: flex;
  flex-direction: column;
}

#adminModal .crew-create-column .field-group:last-of-type {
  margin-bottom: 1rem;
}

#adminModal .crew-create-column .btn {
  margin-top: auto;
  width: 100%;
  padding: 0.75rem;
  font-weight: 600;
  background: var(--focus);
  border: none;
  transition: all 0.2s;
}

#adminModal .crew-create-column .btn:hover {
  background: var(--focus-hover, #0066cc);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 122, 204, 0.3);
}

#adminModal .crew-actions-column .admin-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-top: 0;
}

#adminModal .crew-actions-column .admin-actions .btn {
  width: 100%;
  padding: 0.65rem 0.75rem;
  text-align: center;
  font-size: 0.9rem;
  background: var(--card);
  border: 1px solid var(--border);
  color: var(--text);
  transition: all 0.2s;
}

#adminModal .crew-actions-column .admin-actions .btn:hover {
  background: var(--bg-secondary);
  border-color: var(--focus);
  color: var(--focus);
  transform: translateY(-1px);
}

#adminModal .crew-list-container {
  min-height: 200px;
  max-height: 400px;
}

#adminModal .crew-list-item {
  padding: 1rem;
  margin-bottom: 0.5rem;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: all 0.2s;
}

#adminModal .crew-list-item:last-child {
  margin-bottom: 0;
  border-bottom: 1px solid var(--border);
}

#adminModal .crew-list-item:hover {
  background: var(--bg-secondary);
  border-color: var(--focus);
  transform: translateX(2px);
}

#adminModal .crew-info {
  flex: 1;
}

#adminModal .crew-callsign {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 0.25rem;
}

#adminModal .crew-details {
  font-size: 0.85rem;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

#adminModal .crew-actions {
  display: flex;
  gap: 0.5rem;
}

#adminModal .crew-actions .btn {
  padding: 0.5rem 0.75rem;
  font-size: 0.85rem;
  min-width: auto;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text);
  transition: all 0.2s;
}

#adminModal .crew-actions .btn:hover {
  background: var(--focus);
  border-color: var(--focus);
  color: white;
}

#adminModal .loading-message,
#adminModal .no-crews-message {
  text-align: center;
  padding: 2rem;
  color: var(--muted);
  font-style: italic;
}

#adminModal .admin-header {
  margin-bottom: 0.5rem;
}

#adminModal .admin-header h4 {
  margin: 0 0 0.5rem 0;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--text);
}

#adminModal .admin-header p {
  margin: 0;
  font-size: 0.95rem;
  color: var(--muted);
}

#adminModal .admin-header p span {
  font-weight: 600;
  color: var(--focus);
  font-size: 1.1rem;
}

/* Custom scrollbar for crew list */
#adminModal .crew-list-container::-webkit-scrollbar {
  width: 8px;
}

#adminModal .crew-list-container::-webkit-scrollbar-track {
  background: var(--bg);
  border-radius: 4px;
}

#adminModal .crew-list-container::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 4px;
  transition: background 0.2s;
}

#adminModal .crew-list-container::-webkit-scrollbar-thumb:hover {
  background: var(--focus);
}

/* Responsive adjustments for crew management */
@media (max-width: 1200px) {
  #adminModal .crew-management-layout,
  #adminModal .case-management-layout,
  #adminModal .user-management-layout,
  #adminModal .settings-layout,
  #adminModal .logs-layout {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  #adminModal .crew-actions-column .admin-actions,
  #adminModal .user-actions-column .admin-actions {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 768px) {
  #adminModal .crew-actions-column .admin-actions,
  #adminModal .user-actions-column .admin-actions {
    grid-template-columns: 1fr;
  }

  #adminModal .crew-list-item,
  #adminModal .user-list-item,
  #adminModal .case-list-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
  }

  #adminModal .crew-actions,
  #adminModal .user-actions,
  #adminModal .case-actions {
    width: 100%;
    justify-content: flex-end;
  }
}

/* Case Management Layout - Matches Crew Management */
#adminModal .case-management-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 1rem;
}

#adminModal .case-search-column {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

#adminModal .case-list-column {
  display: flex;
  flex-direction: column;
}

#adminModal .case-list-container {
  min-height: 200px;
  max-height: 400px;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 1rem;
  background: var(--bg-secondary, #2a2a2a);
}

#adminModal .case-list-item {
  padding: 1rem;
  margin-bottom: 0.5rem;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: all 0.2s;
}

#adminModal .case-list-item:hover {
  background: var(--bg-secondary);
  border-color: var(--focus);
  transform: translateX(2px);
}

/* User Management Layout - Matches Crew Management */
#adminModal .user-management-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 1rem;
}

#adminModal .user-create-column {
  display: flex;
  flex-direction: column;
}

#adminModal .user-actions-column {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

#adminModal .user-create-column .admin-section {
  height: 100%;
  display: flex;
  flex-direction: column;
}

#adminModal .user-create-column .field-group:last-of-type {
  margin-bottom: 1rem;
}

#adminModal .user-create-column .btn {
  margin-top: auto;
  width: 100%;
  padding: 0.75rem;
  font-weight: 600;
  background: var(--focus);
  border: none;
  transition: all 0.2s;
}

#adminModal .user-create-column .btn:hover {
  background: var(--focus-hover, #0066cc);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 122, 204, 0.3);
}

#adminModal .user-actions-column .admin-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-top: 0;
}

#adminModal .user-list-container {
  min-height: 200px;
  max-height: 400px;
}

#adminModal .user-list-item {
  padding: 1rem;
  margin-bottom: 0.5rem;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: all 0.2s;
}

#adminModal .user-list-item:hover {
  background: var(--bg-secondary);
  border-color: var(--focus);
  transform: translateX(2px);
}

/* Settings Layout - Matches Crew Management */
#adminModal .settings-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 1rem;
}

#adminModal .settings-config-column {
  display: flex;
  flex-direction: column;
}

#adminModal .settings-info-column {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

#adminModal .settings-config-column .admin-section {
  height: 100%;
  display: flex;
  flex-direction: column;
}

#adminModal .settings-config-column .field-group:last-of-type {
  margin-bottom: 1rem;
}

#adminModal .settings-config-column .btn {
  margin-top: auto;
  width: 100%;
  padding: 0.75rem;
  font-weight: 600;
  background: var(--focus);
  border: none;
  transition: all 0.2s;
}

#adminModal .settings-config-column .btn:hover {
  background: var(--focus-hover, #0066cc);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 122, 204, 0.3);
}

#adminModal .settings-info-column .admin-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-top: 0;
}

/* Logs Layout - Matches Crew Management */
#adminModal .logs-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 1rem;
}

#adminModal .logs-control-column {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

#adminModal .logs-display-column {
  display: flex;
  flex-direction: column;
}

#adminModal .log-container {
  min-height: 200px;
  max-height: 400px;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 1rem;
  background: var(--bg-secondary, #2a2a2a);
}

/* System Info Styling */
#adminModal .system-info {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

#adminModal .info-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  transition: all 0.2s;
}

#adminModal .info-row:hover {
  background: var(--bg-secondary);
  border-color: var(--focus);
}

#adminModal .info-label {
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 500;
}

#adminModal .info-value {
  color: var(--text);
  font-size: 0.95rem;
  font-weight: 600;
}

#adminModal .info-value.status-connected {
  color: #10b981;
}

#adminModal .info-value.status-error {
  color: var(--red);
}

/* Admin Section Headers with Emojis */
#adminModal .admin-section h5 {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text);
  margin: 0 0 1rem 0;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
}

/* Uniform Admin Actions Grid for all tabs */
#adminModal .admin-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-top: 0;
}

#adminModal .admin-actions .btn {
  width: 100%;
  padding: 0.65rem 0.75rem;
  text-align: center;
  font-size: 0.9rem;
  background: var(--card);
  border: 1px solid var(--border);
  color: var(--text);
  transition: all 0.2s;
  cursor: pointer;
}

#adminModal .admin-actions .btn:hover {
  background: var(--bg-secondary);
  border-color: var(--focus);
  color: var(--focus);
  transform: translateY(-1px);
}

/* Admin Section Styling */
#adminModal .admin-section {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1.25rem;
}

/* Field Group Spacing */
#adminModal .field-group {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  margin-bottom: 0.75rem;
}

#adminModal .field-group:last-of-type {
  margin-bottom: 0;
}

#adminModal .field-group label {
  color: var(--text);
  font-weight: 500;
  font-size: 0.85rem;
}

#adminModal input,
#adminModal select,
#adminModal textarea {
  width: 100%;
  padding: 0.5rem;
  border-radius: 6px;
  border: 1px solid #333;
  background: #1e1e2e;
  color: #fff;
  font-size: 0.9rem;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

#adminModal input:focus,
#adminModal select:focus,
#adminModal textarea:focus {
  outline: none;
  border-color: var(--focus);
  background: rgba(28,32,53,0.8);
}

#adminModal input::placeholder {
  color: var(--muted);
}

#incidentModal input, #incidentModal select, #incidentModal textarea {
  width: 100%; 
  padding: 0.5rem; 
  border-radius: 6px;
  border: 1px solid #333; 
  background: #1e1e2e; 
  color: #fff;
  font-size: 0.9rem;
}

#incidentModal input:focus, #incidentModal select:focus, #incidentModal textarea:focus {
  outline: none;
  border-color: var(--focus);
  background: rgba(28,32,53,0.8);
}

#incidentModal textarea { resize: vertical; }

/* Row layout for incident modal */
#incidentModal .row {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

#incidentModal .actions {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 0.5rem;
}

/* Crew Modal */
#crewModal {
  z-index: 1000;
  border: 1px solid var(--border);
  border-radius: 12px;
  max-width: 450px;
}

#crewModal form {
  display: grid;
  gap: 0.75rem;
}

/* Ensure dialog title spans full width */
#crewModal .dialog-title {
  margin: .2rem 0 .6rem 0; 
  color: var(--text);
  font-size: 1.2rem;
}

/* Field group styling for crew modal */
#crewModal .field-group {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

#crewModal .field-group label {
  color: var(--text);
  font-weight: 500;
  font-size: 0.85rem;
  margin-bottom: 0;
}

#crewModal input,
#crewModal select {
  width: 100%;
  padding: 0.5rem;
  border-radius: 6px;
  border: 1px solid #333;
  background: #1e1e2e;
  color: #fff;
  font-size: 0.9rem;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

#crewModal input:focus,
#crewModal select:focus {
  outline: none;
  border-color: var(--focus);
  background: rgba(28,32,53,0.8);
}

#crewModal input::placeholder {
  color: var(--muted);
}

#crewModal .actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 0.5rem;
}

/* Edit Incident Modal with Tabs */
#editIncidentModal {
  z-index: 1000;
  border: 1px solid var(--border);
  border-radius: 12px;
  width: 600px;
  max-width: 90vw;
  min-width: 600px;
}

#editIncidentModal form {
  display: grid;
  gap: 0.75rem;
  width: 100%;
  box-sizing: border-box;
}

/* Ensure dialog title spans full width */
#editIncidentModal .dialog-title {
  grid-column: 1 / -1;
  margin: .2rem 0 .6rem 0; 
  color: var(--text);
  font-size: 1.2rem;
}

/* Tab Navigation */
.tab-navigation {
  grid-column: 1 / -1;
  display: flex;
  border-bottom: 1px solid var(--border);
  margin-bottom: 0.75rem;
}

.tab-btn {
  background: transparent;
  border: none;
  color: var(--muted);
  padding: 0.75rem 1rem;
  cursor: pointer;
  font-size: 0.9rem;
  font-weight: 500;
  border-bottom: 2px solid transparent;
  transition: all 0.2s ease;
}

.tab-btn:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.05);
}

.tab-btn.active {
  color: var(--focus);
  border-bottom-color: var(--focus);
  background: rgba(96, 165, 250, 0.1);
}

/* Tab Content */
.tab-content {
  grid-column: 1 / -1;
  min-height: 400px;
  width: 100%;
}

.tab-panel {
  display: none;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  width: 100%;
  min-height: 400px;
}

.tab-panel.active {
  display: grid;
}

/* Field group styling for edit incident modal */
#editIncidentModal .field-group {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

/* Single field groups (not inside rows) span full width */
#editIncidentModal .tab-panel > .field-group {
  grid-column: 1 / -1;
}

/* Row elements span full width */
#editIncidentModal .row {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

#editIncidentModal .field-group label {
  color: var(--text);
  font-weight: 500;
  font-size: 0.85rem;
  margin-bottom: 0;
}

#editIncidentModal input,
#editIncidentModal select,
#editIncidentModal textarea {
  width: 100%; 
  padding: 0.5rem; 
  border-radius: 6px;
  border: 1px solid #333; 
  background: #1e1e2e; 
  color: #fff;
  font-size: 0.9rem;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

#editIncidentModal input:focus,
#editIncidentModal select:focus,
#editIncidentModal textarea:focus {
  outline: none;
  border-color: var(--focus);
  background: rgba(28,32,53,0.8);
}

#editIncidentModal input::placeholder,
#editIncidentModal textarea::placeholder {
  color: var(--muted);
}

#editIncidentModal textarea {
  resize: vertical;
  font-family: inherit;
}

#editIncidentModal .actions {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 0.5rem;
}

/* Case Log Tab Styling */
#case-log {
  grid-template-columns: 1fr;
}

.case-log-container {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  height: 100%;
  gap: 0.75rem;
}

.case-log-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
}

.case-log-header h4 {
  margin: 0;
  color: var(--text);
  font-size: 1rem;
  font-weight: 600;
}

.log-stats {
  color: var(--muted);
  font-size: 0.85rem;
}

.case-log-entries {
  flex: 1;
  max-height: 300px;
  overflow-y: auto;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 0.75rem;
}

.case-log-entries::-webkit-scrollbar {
  width: 8px;
}

.case-log-entries::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 4px;
}

.case-log-entries::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.3);
  border-radius: 4px;
}

.case-log-entries::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.5);
}

.log-entry {
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--text);
  font-size: 0.9rem;
  line-height: 1.4;
}

.log-entry:last-child {
  border-bottom: none;
}

.log-entry-time {
  color: var(--muted);
  font-size: 0.8rem;
  display: block;
  margin-bottom: 0.25rem;
}

.log-entry-content {
  color: var(--text);
}

.no-logs-message {
  color: var(--muted);
  text-align: center;
  padding: 2rem;
  font-style: italic;
}

.case-log-input {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.case-log-input input {
  flex: 1;
  padding: 0.5rem;
  border-radius: 6px;
  border: 1px solid #333;
  background: #1e1e2e;
  color: #fff;
  font-size: 0.9rem;
}

.case-log-input input:focus {
  outline: none;
  border-color: var(--focus);
  background: rgba(28,32,53,0.8);
}

.case-log-input input::placeholder {
  color: var(--muted);
}

/* Standby Capacity Modal */
#standbyCapacityModal {
  max-width: 600px;
}

.capacity-explanation {
  display: grid;
  gap: 16px;
}

.explanation-content {
  display: grid;
  gap: 20px;
}

.calculation-section .definition {
  background: var(--card);
  padding: 12px;
  border-radius: 8px;
  border-left: 3px solid var(--blue);
  margin-top: 10px;
  font-size: 14px;
  line-height: 1.5;
}

.roles-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.included-roles, .excluded-roles {
  background: var(--card);
  padding: 16px;
  border-radius: 8px;
}

.included-roles {
  border-left: 3px solid var(--blue);
}

.excluded-roles {
  border-left: 3px solid var(--red);
}

.included-roles h4, .excluded-roles h4 {
  margin: 0 0 12px 0;
  font-size: 14px;
}

.included-roles ul, .excluded-roles ul, .status-explanation ul {
  margin: 0;
  padding-left: 20px;
}

.included-roles li, .excluded-roles li, .status-explanation li {
  margin-bottom: 8px;
  line-height: 1.4;
}

.status-explanation {
  background: var(--card);
  padding: 16px;
  border-radius: 8px;
  border-left: 3px solid var(--amber);
}

.status-explanation h4 {
  margin: 0 0 12px 0;
  font-size: 14px;
}

@media (max-width: 600px) {
  .roles-section {
    grid-template-columns: 1fr;
  }
}

/* Discharge Modal */
#dischargeModal {
  max-width: 500px;
}

.discharge-confirmation {
  display: grid;
  gap: 16px;
}

.discharge-content {
  display: grid;
  gap: 16px;
}

.discharge-content ul {
  margin: 8px 0;
  padding-left: 20px;
}

.discharge-content li {
  margin-bottom: 6px;
  line-height: 1.4;
}

.discharge-warning {
  background: var(--card);
  padding: 12px;
  border-radius: 8px;
  border-left: 3px solid var(--amber);
}

.discharge-warning p {
  margin: 0;
  font-weight: 500;
}
#incidentModal .actions { grid-column: span 2; display: flex; justify-content: flex-end; gap: 0.5rem; }

/* Group header row (Active/Discharged) */
.group-head {
  display: flex; align-items: center;
  gap: 8px; padding: 6px 10px; margin: 0 4px 8px;
  border-radius: 8px; user-select: none;
  cursor: pointer; white-space: nowrap;
}
.group-head:hover { background: rgba(255,255,255,.04); }
.group-head .chev { margin-left: auto; display: inline-flex; align-items: center; }
.group-head .chev svg { width: 18px; height: 18px; }
.group-head .chev path {
  fill: none; stroke: #b7bfd0; stroke-width: 3;
  stroke-linecap: square; stroke-linejoin: miter;
  transition: opacity .15s ease, transform .18s ease;
}
.group-head[data-open="true"] .chev .chev-down { opacity: 1 }
.group-head[data-open="true"] .chev .chev-up { opacity: 0; transform: translateY(-2px) }
.group-head[data-open="false"] .chev .chev-down { opacity: 0; transform: translateY(2px) }
.group-head[data-open="false"] .chev .chev-up { opacity: 1 }

/* Section headers (all panels incl. Incidents) */
.column-header,
.panel-header,
.rightpanel > header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  padding: 10px 12px;
}

.section-heading {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.95rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  line-height: 1.2;
  margin: 0;
  color: var(--muted);
}

.count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 20px;
  padding: 0 8px;
  border-radius: 999px;
  font-size: .85rem;
  font-weight: 500;
  background: rgba(255,255,255,.08);
  color: #cfd6e4;
  line-height: 1;
  vertical-align: middle;
}

.muted-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 20px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  color: #aeb6c8;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

@media (max-width:1100px) {
  .wrap { grid-template-columns: 1fr; }
  .rightpanel { order: -1; width: auto; }
}

/* Subgroups inside "At Post" */
.subgroup-block { margin-bottom: 10px; }
.subgroup-head{ /* reuse same look as .group-head */
  display:flex; align-items:center; gap:8px;
  padding:6px 10px; border-radius:8px;
  background: rgba(255,255,255,.03);
  user-select:none; cursor:pointer;
}
.subgroup-head:hover{ background: rgba(255,255,255,.06); }
.subgroup-head .chev{ margin-left:auto; display:inline-flex; align-items:center; }
.subgroup-head .chev svg{ width:18px; height:18px; }
.subgroup-head .chev path{
  fill:none; stroke:#b7bfd0; stroke-width:3; stroke-linecap:square; stroke-linejoin:miter;
  transition:opacity .15s ease, transform .18s ease;
}
.subgroup-head[data-open="true"]  .chev .chev-down { opacity:1 }
.subgroup-head[data-open="true"]  .chev .chev-up   { opacity:0; transform:translateY(-2px) }
.subgroup-head[data-open="false"] .chev .chev-down { opacity:0; transform:translateY( 2px) }
.subgroup-head[data-open="false"] .chev .chev-up   { opacity:1 }

.subgroup-body{ padding:8px 0 0; display:grid; gap:8px; }

/* Make the At Post column scrollable */
.col[data-status="At Post"] {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Make the group container scrollable */
.col[data-status="At Post"] .groups-container {
  flex: 1;
  overflow-y: auto;
  padding-right: 4px;
  scrollbar-width: thin;
}

/* Optional: style scrollbar to match dark theme */
.col[data-status="At Post"] .groups-container::-webkit-scrollbar {
  width: 6px;
}
.col[data-status="At Post"] .groups-container::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.15);
  border-radius: 4px;
}
.col[data-status="At Post"] .groups-container::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,0.25);
}

/* Responsive adjustments for floating log */
@media (max-height: 600px) {
  .floating-log {
    max-height: 50vh; /* Allow more space on shorter screens */
  }
  
  .log-rows {
    max-height: calc(50vh - 120px);
  }
  
  body.log-expanded .wrap {
    padding-bottom: 320px; /* More space needed on shorter screens */
  }
}

@media (max-height: 400px) {
  .floating-log {
    max-height: 60vh; /* Even more space on very short screens */
  }
  
  .log-rows {
    max-height: calc(60vh - 120px);
  }
  
  body.log-expanded .wrap {
    padding-bottom: 380px; /* Even more space for log on short screens */
  }
}

/* Additional Admin Modal Improvements */
#adminModal .field-group {
  margin-bottom: 1rem;
}

#adminModal .field-group:last-child {
  margin-bottom: 0;
}

#adminModal .field-group label {
  font-weight: 500;
  margin-bottom: 0.5rem;
  color: var(--text);
}

#adminModal input,
#adminModal select {
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--bg);
  padding: 0.75rem;
  font-size: 0.95rem;
}

#adminModal input:focus,
#adminModal select:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 2px rgba(96, 165, 250, 0.2);
}

#adminModal .btn {
  border-radius: 6px;
  font-weight: 500;
  padding: 0.75rem 1rem;
  transition: all 0.2s ease;
}

#adminModal .btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

#adminModal .loading-message {
  text-align: center;
  color: var(--muted);
  font-style: italic;
  padding: 2rem;
}

/* Case Management Styles */
.case-management-layout {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.case-search-section {
  flex: 0 0 auto;
}

.case-search-controls {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.case-list-section {
  flex: 1;
}

.case-list-container {
  max-height: 400px;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--card);
}

.case-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--border);
  transition: background-color 0.2s ease;
}

.case-item:last-child {
  border-bottom: none;
}

.case-item:hover {
  background: var(--panel);
}

.case-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.case-number {
  font-weight: 600;
  color: var(--blue);
  font-size: 0.95rem;
}

.case-details {
  display: flex;
  gap: 1rem;
  font-size: 0.85rem;
  color: var(--muted);
}

.case-complaint {
  color: var(--text);
}

.case-location {
  color: var(--muted);
}

.case-timestamp {
  color: var(--muted);
  font-size: 0.8rem;
}

.case-status {
  flex: 0 0 auto;
  padding: 0.25rem 0.75rem;
  border-radius: 12px;
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.case-status.active {
  background: rgba(59, 130, 246, 0.2);
  color: var(--blue);
}

.case-status.discharged {
  background: rgba(107, 114, 128, 0.2);
  color: var(--muted);
}

.case-actions {
  flex: 0 0 auto;
  display: flex;
  gap: 0.5rem;
  margin-left: 1rem;
}

.case-action-btn {
  padding: 0.5rem;
  background: var(--btn);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.8rem;
  min-width: 70px;
  text-align: center;
}

.case-action-btn:hover {
  background: var(--panel);
  border-color: var(--focus);
  transform: translateY(-1px);
}

.case-action-btn.edit-btn {
  color: var(--blue);
}

.case-action-btn.delete-btn {
  color: var(--red);
}

.case-action-btn.delete-btn:hover {
  background: rgba(239, 68, 68, 0.1);
  border-color: var(--red);
}

/* Empty state for case list */
.no-cases-message {
  text-align: center;
  color: var(--muted);
  font-style: italic;
  padding: 3rem 2rem;
}

.no-cases-message::before {
  content: "\ea0a";
  font-family: 'coolicons';
  display: block;
  font-size: 2rem;
  margin-bottom: 0.5rem;
}

/* Loading states */
.case-item.loading {
  background: var(--panel);
  opacity: 0.6;
  pointer-events: none;
}

/* Case search input focus styles */
.case-search-controls input:focus {
  border-color: var(--focus);
  box-shadow: 0 0 0 2px rgba(96, 165, 250, 0.2);
}

/* Crew notes tooltip styles */
.callsign.has-tooltip {
  cursor: help;
  position: relative;
}

.callsign.has-tooltip:hover::after {
  content: attr(data-tooltip);
  position: absolute;
  top: 100%;
  left: 0;
  background: var(--panel);
  color: var(--text);
  padding: 8px 12px;
  border-radius: 6px;
  border: 1px solid var(--border);
  font-size: 12px;
  white-space: normal;
  max-width: 200px;
  word-wrap: break-word;
  z-index: 1000;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  animation: tooltipFadeIn 0.2s ease-out;
  pointer-events: none;
}

@keyframes tooltipFadeIn {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Additional Support Tab Styles */
.support-container {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.support-row {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.support-section {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px;
  flex: 1;
  min-width: 300px;
}

.support-section.full-width {
  flex: none;
  width: 100%;
}

.support-section h4 {
  margin: 0 0 16px 0;
  color: var(--text);
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--border);
  padding-bottom: 8px;
}

.support-section .field-group {
  margin-bottom: 12px;
}

.support-section .row .field-group {
  margin-bottom: 0;
}

/* Sidebar Styles */
.sidebar {
  position: fixed;
  top: 0;
  left: 0;
  width: 280px;
  height: 100vh;
  background: var(--panel);
  border-right: 1px solid var(--border);
  z-index: 1000;
  transform: translateX(-100%);
  transition: transform 0.3s ease-in-out;
  overflow-y: auto;
}

.sidebar.open {
  transform: translateX(0);
}

.sidebar-content {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}

.sidebar-header h3 {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--text);
}

.sidebar-close {
  background: none;
  border: none;
  color: var(--muted);
  font-size: 1.5rem;
  cursor: pointer;
  padding: 0.25rem;
  border-radius: 4px;
  transition: all 0.2s ease;
}

.sidebar-close:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.1);
}

.sidebar-nav {
  flex: 1;
  padding: 1rem 0;
  display: flex;
  flex-direction: column;
}

.sidebar-main-nav {
  flex: 0 0 auto;
}

.sidebar-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  padding: 0.75rem 1rem;
  margin: 0;
  background: none;
  border: none;
  color: var(--text);
  text-decoration: none;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.9rem;
  font-weight: 500;
  font-family: inherit;
}

.sidebar-item:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--text);
}

.sidebar-item:focus {
  outline: 2px solid var(--focus);
  outline-offset: -2px;
}

.sidebar-item.active {
  background: var(--blue) !important;
  color: white !important;
}

.sidebar-item.active:hover {
  background: var(--blue) !important;
  color: white !important;
}

.sidebar-icon {
  font-size: 1.2rem;
  width: 1.5rem;
  text-align: center;
}

.sidebar-divider {
  height: 1px;
  background: var(--border);
  margin: 0.5rem 1rem;
}

.sidebar-section {
  margin-top: auto;
  padding: 0 1rem 1rem 1rem;
}

.sidebar-section-title {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 0.75rem 0;
  padding: 0 0 0.5rem 0;
  border-bottom: 1px solid var(--border);
}

.sidebar-user-info {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 0.75rem;
}

.user-avatar {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background: var(--blue);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
}

.user-details {
  flex: 1;
}

.user-name {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text);
  margin: 0;
}

.user-role {
  font-size: 0.75rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0.125rem 0 0 0;
}

.logout-item {
  color: var(--text) !important;
  margin: 0.75rem 1rem 1rem 1rem !important;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--card);
  padding: 0.75rem 1rem !important;
  width: calc(100% - 2rem) !important;
  transition: all 0.2s ease;
  font-size: 0.9rem;
  font-weight: 500;
}

.logout-item:hover {
  background: var(--btn) !important;
  border-color: var(--muted);
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.logout-item .sidebar-icon {
  color: var(--muted);
}

.logout-item .sidebar-label {
  color: var(--text);
}

/* Sidebar Toggle Button */
#sidebarToggle {
  order: -1; /* Move to start of header */
}

/* Sidebar Overlay */
.sidebar-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.sidebar-overlay.active {
  opacity: 1;
  visibility: visible;
}

/* Responsive Sidebar */
@media (max-width: 768px) {
  .sidebar {
    width: 100%;
    max-width: 320px;
  }
}

/* Adjust main content when sidebar is open on larger screens */
@media (min-width: 1200px) {
  body.sidebar-open .wrap {
    margin-left: 280px;
    transition: margin-left 0.3s ease-in-out;
  }
  
  body.sidebar-open .appbar {
    margin-left: 280px;
    transition: margin-left 0.3s ease-in-out;
  }
  
  body.sidebar-open .status-bar {
    margin-left: 280px;
    transition: margin-left 0.3s ease-in-out;
  }
}

/* Time input styling for support sections */
.support-section input[type="time"] {
  font-family: system-ui, -apple-system, sans-serif;
}

.support-section textarea {
  resize: vertical;
  min-height: 80px;
}

/* Responsive behavior for smaller screens */
@media (max-width: 768px) {
  .support-row {
    flex-direction: column;
  }
  
  .support-section {
    min-width: unset;
  }
}

/* ---- Context Menu (Crew) ---- */
.context-menu {
  position: fixed;
  top: 0;
  left: 0;
  background: rgba(23,26,43,0.98);
  backdrop-filter: saturate(140%) blur(6px);
  border: 1px solid var(--border);
  border-radius: 10px;
  min-width: 200px;
  padding: 6px 0;
  z-index: 2000;
  box-shadow: 0 4px 24px rgba(0,0,0,0.5);
  display: none;
  animation: fadeIn 90ms ease;
}

.context-menu.open { display: block; }

.context-menu h4 {
  margin: 4px 12px 6px;
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .05em;
}

.context-menu button {
  all: unset;
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 8px 14px;
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
  position: relative;
  box-sizing: border-box;
  transition: background-color 0.15s ease;
}

.context-menu button .icon { 
  font-size: 16px; 
  width: 18px; 
  text-align: center;
  flex-shrink: 0;
}

.context-menu button .submenu-arrow {
  margin-left: auto;
  opacity: 0.5;
  font-size: 16px;
}

.context-menu button:hover {
  background: rgba(255,255,255,0.06);
}

.context-menu button:active {
  background: rgba(255,255,255,0.12);
}

.context-menu .danger { color: var(--red); }

.context-menu-sep {
  height: 1px;
  background: var(--border);
  margin: 4px 8px;
}

@keyframes fadeIn { from { opacity: 0; transform: translateY(-2px);} to { opacity:1; transform: translateY(0);} }

